## 1.124.0
This commit is contained in:
		
							
								
								
									
										24
									
								
								type-script-helper/.eslintrc.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								type-script-helper/.eslintrc.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,24 @@ | ||||
| { | ||||
|     "root": true, | ||||
|     "parser": "@typescript-eslint/parser", | ||||
|     "parserOptions": { | ||||
|         "ecmaVersion": 6, | ||||
|         "sourceType": "module" | ||||
|     }, | ||||
|     "plugins": [ | ||||
|         "@typescript-eslint" | ||||
|     ], | ||||
|     "rules": { | ||||
|         "@typescript-eslint/naming-convention": "warn", | ||||
|         "@typescript-eslint/semi": "warn", | ||||
|         "curly": "warn", | ||||
|         "eqeqeq": "warn", | ||||
|         "no-throw-literal": "warn", | ||||
|         "semi": "off" | ||||
|     }, | ||||
|     "ignorePatterns": [ | ||||
|         "out", | ||||
|         "dist", | ||||
|         "**/*.d.ts" | ||||
|     ] | ||||
| } | ||||
							
								
								
									
										8
									
								
								type-script-helper/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								type-script-helper/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | ||||
| .vscode-test/ | ||||
| .vscode/helper/** | ||||
| *.vsix | ||||
| dist | ||||
| node_modules | ||||
| out | ||||
| src/*.js* | ||||
| !src/embed.js | ||||
							
								
								
									
										5
									
								
								type-script-helper/.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								type-script-helper/.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | ||||
| { | ||||
|   // See http://go.microsoft.com/fwlink/?LinkId=827846 | ||||
|   // for the documentation about the extensions.json format | ||||
|   "recommendations": ["dbaeumer.vscode-eslint", "amodio.tsl-problem-matcher"] | ||||
| } | ||||
							
								
								
									
										30
									
								
								type-script-helper/.vscode/launch.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								type-script-helper/.vscode/launch.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| // A launch configuration that compiles the extension and then opens it inside a new window | ||||
| // Use IntelliSense to learn about possible attributes. | ||||
| // Hover to view descriptions of existing attributes. | ||||
| // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 | ||||
| { | ||||
|   "version": "0.2.0", | ||||
|   "configurations": [ | ||||
|     { | ||||
|       "name": "Run Extension", | ||||
|       "type": "extensionHost", | ||||
|       "request": "launch", | ||||
|       "preLaunchTask": "npm: webpack", | ||||
|       "args": [ | ||||
|         "--extensionDevelopmentPath=${workspaceFolder}" | ||||
|       ], | ||||
|       "outFiles": [ | ||||
|         "${workspaceFolder}/dist/**/*.js" | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "type": "node", | ||||
|       "request": "launch", | ||||
|       "name": "Launch Program", | ||||
|       "program": "${workspaceFolder}/src/extension.ts", | ||||
|       "outFiles": [ | ||||
|         "${workspaceFolder}/out/**/*.js" | ||||
|       ] | ||||
|     } | ||||
|   ] | ||||
| } | ||||
							
								
								
									
										11
									
								
								type-script-helper/.vscode/mklink.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								type-script-helper/.vscode/mklink.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| --- | ||||
| type: "note" | ||||
| created: "2023-10-20T03:53:13.742Z" | ||||
| updated: "2023-10-20T04:00:37.259Z" | ||||
| --- | ||||
|  | ||||
| # mklink | ||||
|  | ||||
| ```bash | ||||
| mklink /J "L:\Git\YO-VSCode\type-script-helper\net8.0\win-x64\publish" "L:\DevOps\Mesa_FI\File-Folder-Helper\bin\Release\net8.0\win-x64\publish" | ||||
| ``` | ||||
							
								
								
									
										29
									
								
								type-script-helper/.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								type-script-helper/.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | ||||
| { | ||||
|   "[markdown]": { | ||||
|     "editor.wordWrap": "off" | ||||
|   }, | ||||
|   "cSpell.words": [ | ||||
|     "Infineon", | ||||
|     "initialise", | ||||
|     "Kanban", | ||||
|     "Phares", | ||||
|     "signalr", | ||||
|     "VSIX", | ||||
|     "Weightest", | ||||
|     "WSJF" | ||||
|   ], | ||||
|   "files.eol": "\n", | ||||
|   "files.exclude": { | ||||
|     "**/dist": false, | ||||
|     "**/node_modules": true, | ||||
|     "**/out": false | ||||
|   }, | ||||
|   "files.watcherExclude": { | ||||
|     "**/node_modules": true | ||||
|   }, | ||||
|   "explorer.sortOrder": "default", | ||||
|   "search.exclude": { | ||||
|     "**/dist": true, | ||||
|     "**/out": true | ||||
|   } | ||||
| } | ||||
							
								
								
									
										63
									
								
								type-script-helper/.vscode/tasks.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								type-script-helper/.vscode/tasks.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,63 @@ | ||||
| { | ||||
|   "tasks": [ | ||||
|     { | ||||
|       "type": "npm", | ||||
|       "script": "tsc-build", | ||||
|       "group": "build", | ||||
|       "problemMatcher": [], | ||||
|       "label": "npm: tsc-build", | ||||
|       "detail": "tsc" | ||||
|     }, | ||||
|     { | ||||
|       "type": "npm", | ||||
|       "script": "tsc-clean", | ||||
|       "problemMatcher": [], | ||||
|       "label": "npm: tsc-clean", | ||||
|       "detail": "tsc --build --clean" | ||||
|     }, | ||||
|     { | ||||
|       "type": "npm", | ||||
|       "script": "vscode:package", | ||||
|       "problemMatcher": [], | ||||
|       "label": "npm: vscode:package", | ||||
|       "detail": "node node_modules/@vscode/vsce/vsce package" | ||||
|     }, | ||||
|     { | ||||
|       "type": "npm", | ||||
|       "script": "vscode:login", | ||||
|       "problemMatcher": [], | ||||
|       "label": "npm: vscode:login", | ||||
|       "detail": "node node_modules/@vscode/vsce/vsce login Infineon-Technologies-AG-Mesa-FI" | ||||
|     }, | ||||
|     { | ||||
|       "type": "npm", | ||||
|       "script": "vscode:ls-publishers", | ||||
|       "problemMatcher": [], | ||||
|       "label": "npm: vscode:ls-publishers", | ||||
|       "detail": "node node_modules/@vscode/vsce/vsce ls-publishers" | ||||
|     }, | ||||
|     { | ||||
|       "type": "npm", | ||||
|       "script": "vscode:publish", | ||||
|       "problemMatcher": [], | ||||
|       "label": "npm: vscode:publish", | ||||
|       "detail": "node node_modules/@vscode/vsce/vsce publish" | ||||
|     }, | ||||
|     { | ||||
|       "type": "npm", | ||||
|       "script": "watch", | ||||
|       "group": "build", | ||||
|       "problemMatcher": [], | ||||
|       "label": "npm: watch", | ||||
|       "detail": "concurrently \"rollup -c -w\" \"webpack --watch --config ./build/node-extension.webpack.config.js\"" | ||||
|     }, | ||||
|     { | ||||
|       "type": "npm", | ||||
|       "script": "webpack", | ||||
|       "problemMatcher": [], | ||||
|       "label": "npm: webpack", | ||||
|       "detail": "webpack --config ./build/node-extension.webpack.config.js" | ||||
|     } | ||||
|   ], | ||||
|   "version": "2.0.0" | ||||
| } | ||||
							
								
								
									
										14
									
								
								type-script-helper/.vscodeignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								type-script-helper/.vscodeignore
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | ||||
| .gitignore | ||||
| .vscode-test/** | ||||
| .vscode/** | ||||
| .yarnrc | ||||
| **/.eslintrc.json | ||||
| **/*.map | ||||
| **/*.ts | ||||
| **/tsconfig.json | ||||
| build/** | ||||
| node_modules/** | ||||
| src/** | ||||
| webviews/** | ||||
| vsc-extension-quickstart.md | ||||
| webpack.config.js | ||||
							
								
								
									
										27
									
								
								type-script-helper/LICENSE.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								type-script-helper/LICENSE.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,27 @@ | ||||
| --- | ||||
| type: "note" | ||||
| created: "2022-03-10T21:18:17.054Z" | ||||
| updated: "2022-03-10T21:18:17.054Z" | ||||
| --- | ||||
|  | ||||
| # LICENSE | ||||
|  | ||||
| Copyright (c) Twitter Inc | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in | ||||
| all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
| THE SOFTWARE. | ||||
							
								
								
									
										268
									
								
								type-script-helper/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										268
									
								
								type-script-helper/README.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,268 @@ | ||||
| --- | ||||
| type: "read-me" | ||||
| created: "2023-09-30T01:47:18.241Z" | ||||
| updated: "2023-09-30T01:47:18.242Z" | ||||
| --- | ||||
|  | ||||
| # type-script-helper README | ||||
|  | ||||
| ## Features | ||||
|  | ||||
| See Contributions tab | ||||
|  | ||||
| ## Requirements | ||||
|  | ||||
| ```bash | ||||
| # https://code.visualstudio.com/api/get-started/your-first-extension | ||||
| npm install -g yo generator-code | ||||
|  | ||||
| yo code | ||||
|  | ||||
| # ? What type of extension do you want to create? New Extension (TypeScript) | ||||
| # ? What's the name of your extension? HelloWorld | ||||
| ### Press <Enter> to choose default for all options below ### | ||||
|  | ||||
| # ? What's the identifier of your extension? hello-world | ||||
| # ? What's the description of your extension? LEAVE BLANK | ||||
| # ? Initialize a git repository? Yes | ||||
| # ? Bundle the source code with webpack? No (should be yes?) | ||||
| # ? Which package manager to use? npm | ||||
|  | ||||
| # ? Do you want to open the new folder with Visual Studio Code? Open with `code` | ||||
|  | ||||
| npm install -g @vscode/vsce | ||||
|  | ||||
| vsce package | ||||
| ``` | ||||
|  | ||||
| ## Extension Settings | ||||
|  | ||||
| None | ||||
|  | ||||
| ## Known Issues | ||||
|  | ||||
| None | ||||
|  | ||||
| ## Release Notes | ||||
|  | ||||
| ## 1.2.4 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Search Google | ||||
|  | ||||
| ## 1.2.8 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Search Google (Read Only Lines Helper) | ||||
|  | ||||
| ## 1.2.9, 1.3.0, 1.3.1, 1.3.2 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Quick Fix - Camel Case Properties | ||||
| - Quick Fix - CS0108 (Data Annotations) | ||||
| - Quick Fix - Proper Case Properties | ||||
| - Quick Fix - Public (Expression Body) | ||||
|  | ||||
| ## 1.3.3, 1.3.4 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Quick Fix - Instance Field to Calisthenics | ||||
|  | ||||
| ## 1.3.5, 1.3.6, 1.3.7, 1.3.8, 1.3.9, 1.3.10, 1.3.11 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Code Generator - Quick Pick {promiseLinesHelper.codeGeneratorQuickPick} | ||||
| - Open in New Window {open-in-new-window.open} | ||||
| - Learned npm install will do similar to nuget restore | ||||
| - Learned npm audit fix | ||||
| - Learned npm audit fix --force | ||||
| - Learned npm run compile will do similar to build | ||||
| - Quick Fix - Instance Field to Calisthenics | ||||
|  | ||||
| ## 1.3.12, 1.3.13, 1.3.14 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Split by Space Reverse Join Sort lines (ascending, case sensitive) | ||||
| - PathWithoutBracketsSingularized | ||||
|  | ||||
| ## 1.3.15 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Distinct list | ||||
|  | ||||
| ## 1.4.1 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - new yo code template | ||||
|  | ||||
| ## 1.4.2 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Insert date time | ||||
|  | ||||
| ## 1.4.3 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Moved Insert date time | ||||
| - Transform to Popper Case | ||||
|  | ||||
| ## 1.4.4 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Transform to Param Case | ||||
|  | ||||
| ## 1.5.1 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - columns-to-cards-webview-view-provider | ||||
| - file-folder-helper-exe | ||||
| - clickable list | ||||
|  | ||||
| ## 1.5.2 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - file-folder-helper-exe net8.0 | ||||
|  | ||||
| ## 1.5.3 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Updated File-Folder-Helper ccea8de8cf49343dd4190a77ac755d233bb4e528 | ||||
|  | ||||
| ## 1.6.0 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Updated File-Folder-Helper 4e3f06bb44b7e85ba40a5e589e6ca871cbdbfb3e | ||||
|  | ||||
| ## 1.6.1 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Updated File-Folder-Helper 299aa19d538bcfd5e06e4743a5a05f6d62960a80 | ||||
| - code --install-extension D:\Tmp\phares\type-script-helper-1.6.1.vsix | ||||
| - code-insiders --install-extension D:\Tmp\phares\type-script-helper-1.6.1.vsix | ||||
|  | ||||
| ## 1.6.2 | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Updated File-Folder-Helper 47e6b85c218f994216fb35d44906850a790c36d0 | ||||
| - Open with Text Editor Kanban | ||||
|  | ||||
| ## 1.6.4 Fri Aug 02 2024 13:07:24 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Wrap directory in quotes | ||||
|  | ||||
| ## 1.7.0 Fri Aug 30 2024 11:13:09 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Copy Syntax In Light Theme | ||||
| - [Copy-Syntax-in-Light](https://github.com/Ahmed-Adel-Morsi/Copy-Syntax-in-Light) | ||||
|  | ||||
| ## 1.8.0 Wed Nov 06 2024 06:03:59 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Change insert date to include epoch seconds and ticks * | ||||
|  | ||||
| ## 1.9.0 1735586943373 = 638711837433730000 = Mon Dec 30 2024 12:29:02 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Insert All Extensions (Not Disabled) | ||||
|  | ||||
| ## 1.110.0 1735689397890 = 638712861978900000 = Tue Dec 31 2024 16:56:37 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Open Sub-Kanban in New Window | ||||
|  | ||||
| ## 1.111.0 1736196204601 = 638717930046010000 = 2025-0.Winter = Mon Jan 06 2025 13:43:24 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Added season to insert date | ||||
| - Removed | ||||
|     - kanban.refreshBoth | ||||
|     - kanban.refreshSidebar | ||||
|     - kanban.refreshWebview | ||||
|     - kanban.debugReload | ||||
|     - columns-to-cards-webview-view-provider-view | ||||
|  | ||||
| - Open Sub-Kanban in New Window | ||||
|  | ||||
| ## 1.111.1 1738206291411 = 638738030914110000 = 2025-0.Winter = Wed Jan 29 2025 20:04:50 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Changed trigger for code-insiders | ||||
|  | ||||
| ## 1.112.0 1738349146299 = 638739459462990000 = 2025-0.Winter = Fri Jan 31 2025 11:45:45 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Added Cost of Delay (CoD) | ||||
|  | ||||
| ## 1.113.0 1739287994496 = 638748847944960000 = 2025-0.Winter = Tue Feb 11 2025 08:33:14 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Add Code Insiders lines when not present | ||||
|  | ||||
| ## 1.114.0 1739295723637 = 638748925236370000 = 2025-0.Winter = Tue Feb 11 2025 10:42:03 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - infineon-mes-mike-phares | ||||
|  | ||||
| ## 1.115.0 1739295727065 = 638748925270650000 = 2025-0.Winter = Tue Feb 11 2025 10:42:06 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Infineon-Technologies-AG-Mesa-FI | ||||
|  | ||||
| ## 1.116.0 1740441381597 = 638760381815970000 = 2025-0.Winter = Mon Feb 24 2025 16:56:21 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Calculator | ||||
| - Explorer Sort Order | ||||
|  | ||||
| ## 1.117.0 1740671831803 = 638762686318030000 = 2025-0.Winter = Thu Feb 27 2025 08:57:11 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Close active after opening Sub-Kanban when directory found | ||||
|  | ||||
| ## 1.118.0 1741303103654 = 638768999036540000 = 2025-0.Winter = Thu Mar 06 2025 16:18:23 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Add search page for Backlog | ||||
|  | ||||
| ## 1.119.0 1744337196592 = 638799339965920000 = 2025-1.Spring = Thu Apr 10 2025 19:06:36 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Changed ADO Priority servers | ||||
|  | ||||
| ## 1.120.0 1744401374311 = 638799981743110000 = 2025-1.Spring = Fri Apr 11 2025 12:56:13 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Sidebar button for view command pallette images | ||||
|  | ||||
| ## 1.121.0 1744403802837 = 638800006028370000 = 2025-1.Spring = Fri Apr 11 2025 13:36:42 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Extension logo | ||||
|  | ||||
| ## 1.122.0 1744403802837 = 638800006028370000 = 2025-1.Spring = Fri Apr 11 2025 13:36:42 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Extension to javascript communication | ||||
| - cod-1-122-0.js | ||||
|  | ||||
| ## 1.123.0 1745545527205 = 638811423272050000 = 2025-1.Spring = Thu Apr 24 2025 18:45:26 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Enable find within Cost of Delay (CoD) | ||||
|  | ||||
| ## 1.123.1 1746135167656 = 638817319676560000 = 2025-1.Spring = Thu May 01 2025 14:32:47 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Spelling fixes | ||||
|  | ||||
| ## 1.124.0 1749244041290 = 638848408412900000 = 2025-2.Spring = Fri Jun 06 2025 14:07:20 GMT-0700 (Mountain Standard Time) | ||||
| ----------------------------------------------------------------------------------------------------------- | ||||
|  | ||||
| - Delete remaining column-to-cards files | ||||
| - Bun support | ||||
| - Spelling of pallette | ||||
| - FileSync prep | ||||
| - json remove null lines | ||||
| - Remove lines containing highlighted | ||||
							
								
								
									
										41
									
								
								type-script-helper/build/node-extension.webpack.config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								type-script-helper/build/node-extension.webpack.config.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | ||||
| //@ts-check | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| const path = require('path'); | ||||
|  | ||||
| /**@type {import('webpack').Configuration}*/ | ||||
| const config = { | ||||
|   target: 'node', // vscode extensions run in a Node.js-context 📖 -> https://webpack.js.org/configuration/node/ | ||||
| 	mode: 'none', // this leaves the source code as close as possible to the original (when packaging we set this to 'production') | ||||
|  | ||||
|   entry: './src/extension.ts', // the entry point of this extension, 📖 -> https://webpack.js.org/configuration/entry-context/ | ||||
|   output: { | ||||
|     // the bundle is stored in the 'dist' folder (check package.json), 📖 -> https://webpack.js.org/configuration/output/ | ||||
|     path: path.resolve(__dirname, '..', 'dist'), | ||||
|     filename: 'extension.js', | ||||
|     libraryTarget: 'commonjs2' | ||||
|   }, | ||||
|   devtool: 'nosources-source-map', | ||||
|   externals: { | ||||
|     vscode: 'commonjs vscode' // the vscode-module is created on-the-fly and must be excluded. Add other modules that cannot be webpack'ed, 📖 -> https://webpack.js.org/configuration/externals/ | ||||
|   }, | ||||
|   resolve: { | ||||
|     // support reading TypeScript and JavaScript files, 📖 -> https://github.com/TypeStrong/ts-loader | ||||
|     extensions: ['.ts', '.js'] | ||||
|   }, | ||||
|   module: { | ||||
|     rules: [ | ||||
|       { | ||||
|         test: /\.ts$/, | ||||
|         exclude: /node_modules/, | ||||
|         use: [ | ||||
|           { | ||||
|             loader: 'ts-loader' | ||||
|           } | ||||
|         ] | ||||
|       } | ||||
|     ] | ||||
|   } | ||||
| }; | ||||
| module.exports = config; | ||||
							
								
								
									
										1444
									
								
								type-script-helper/bun.lock
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1444
									
								
								type-script-helper/bun.lock
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								type-script-helper/media/LOGO_RGB.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								type-script-helper/media/LOGO_RGB.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 51 KiB | 
							
								
								
									
										
											BIN
										
									
								
								type-script-helper/media/Screenshot 2025-04-11 125031.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								type-script-helper/media/Screenshot 2025-04-11 125031.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 8.2 KiB | 
							
								
								
									
										
											BIN
										
									
								
								type-script-helper/media/Screenshot 2025-04-11 125350.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								type-script-helper/media/Screenshot 2025-04-11 125350.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 17 KiB | 
							
								
								
									
										20
									
								
								type-script-helper/media/bootstrap.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								type-script-helper/media/bootstrap.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1
									
								
								type-script-helper/media/checklist.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								type-script-helper/media/checklist.svg
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| <svg width="16" height="16" viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg" fill="currentColor"><path fill-rule="evenodd" clip-rule="evenodd" d="M3.75 4.48h-.71L2 3.43l.71-.7.69.68L4.81 2l.71.71-1.77 1.77zM6.99 3h8v1h-8V3zm0 3h8v1h-8V6zm8 3h-8v1h8V9zm-8 3h8v1h-8v-1zM3.04 7.48h.71l1.77-1.77-.71-.7L3.4 6.42l-.69-.69-.71.71 1.04 1.04zm.71 3.01h-.71L2 9.45l.71-.71.69.69 1.41-1.42.71.71-1.77 1.77zm-.71 3.01h.71l1.77-1.77-.71-.71-1.41 1.42-.69-.69-.71.7 1.04 1.05z"/></svg> | ||||
| After Width: | Height: | Size: 479 B | 
							
								
								
									
										37
									
								
								type-script-helper/media/cod.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								type-script-helper/media/cod.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,37 @@ | ||||
| #HeaderGridDiv, | ||||
| #DetailsGridDiv { | ||||
|     font-size: 12px; | ||||
|     min-width: 1200px; | ||||
|     max-width: 1200px; | ||||
| } | ||||
|  | ||||
| #HeaderGrid { | ||||
|     font-family: monospace; | ||||
|     margin-top: 60px; | ||||
| } | ||||
|  | ||||
| #HeaderGrid tr td { | ||||
|     max-width: 200px; | ||||
|     padding: 5px; | ||||
| } | ||||
|  | ||||
| #AllGrid { | ||||
|     font-family: monospace; | ||||
| } | ||||
|  | ||||
| .navbar-brand { | ||||
|     min-width: 1200px; | ||||
|     background-color: whitesmoke; | ||||
| } | ||||
|  | ||||
| tr:nth-of-type(odd) { | ||||
|     background-color: #eee; | ||||
| } | ||||
|  | ||||
| #AllTextarea { | ||||
|     font-family: monospace; | ||||
| } | ||||
|  | ||||
| #th-span { | ||||
|     margin-right: 500px; | ||||
| } | ||||
							
								
								
									
										51
									
								
								type-script-helper/media/cost-of-delay.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								type-script-helper/media/cost-of-delay.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,51 @@ | ||||
| $(document).ready(function () { | ||||
|     const fromHtml = true; | ||||
|     const username = _webviewUsername; | ||||
|     const machineId = _webviewMachineId; | ||||
|     const baseUri = 'https://eaf-dev.mes.infineon.com'; | ||||
|     const apiUrl = 'https://eaf-dev.mes.infineon.com/api/v1/ado/'; | ||||
|     const windowLocationHRef = window.location.href + '?site=' + _webviewSite + 'view=' + _webviewView; | ||||
|     const signalRUrl = baseUri + '/signalr'; | ||||
|     const workItems = { | ||||
|         a: baseUri + '/markdown/bugs-features-with-parents.json?v=2025-04-10-15-59', | ||||
|         b: baseUri + '/markdown/{[]}.json?v=2025-04-10-15-59', | ||||
|         timeout: 3000, | ||||
|     }; | ||||
|     const b = { | ||||
|         page: 'business', | ||||
|         description: 'Value', | ||||
|         th: 'Business Value', | ||||
|         span: 'What is the relative value to the Customer or business?<br>• Do our users prefer this over that?<br>• What is the revenue impact on our business?<br>• Is there a potential penalty or other negative effects if we delay?' | ||||
|     }; | ||||
|     const r = { | ||||
|         page: 'risk', | ||||
|         description: 'Risk', | ||||
|         th: 'Risk Reduction and/or Opportunity Enablement', | ||||
|         span: 'What else does this do for our business?<br>• Reduce the risk of this or future delivery?<br>• Is there value in the information we will receive?<br>• Enable new business opportunities?' | ||||
|     }; | ||||
|     const t = { | ||||
|         page: 'time', | ||||
|         description: 'Critical', | ||||
|         th: 'Time Criticality', | ||||
|         span: 'How does user/business value decay over time?<br>• Is there a fixed deadline?<br>• Will they wait for us or move to another Solution?<br>• What is the current effect on Customer satisfaction?' | ||||
|     }; | ||||
|     const c = { | ||||
|         page: 'cod', | ||||
|         description: 'CoD', | ||||
|         th: 'Cost of Delay (CoD)', | ||||
|         span: "Cost of Delay (CoD) is the money lost by delaying or not doing a job for a specific time. It's a measure of the economic value of a job over time." | ||||
|     }; | ||||
|     const e = { | ||||
|         page: 'effort', | ||||
|         description: 'Effort', | ||||
|         th: 'Effort', | ||||
|         span: 'Effort' | ||||
|     }; | ||||
|     const w = { | ||||
|         page: 'wsjf', | ||||
|         description: 'WSJF', | ||||
|         th: 'Weightest Shortest Job First calculation (WSJF)', | ||||
|         span: 'Weightest Shortest Job First calculation (see @SCALE formula)' | ||||
|     }; | ||||
|     initIndex(fromHtml, username, machineId, windowLocationHRef, workItems, b, r, t, c, e, w, apiUrl, signalRUrl); | ||||
| }); | ||||
							
								
								
									
										4
									
								
								type-script-helper/media/jquery-1.6.4.min.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								type-script-helper/media/jquery-1.6.4.min.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										9
									
								
								type-script-helper/media/jquery.signalR-2.4.3.min.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								type-script-helper/media/jquery.signalR-2.4.3.min.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								type-script-helper/media/lowres-LOGO_Black.png.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								type-script-helper/media/lowres-LOGO_Black.png.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 20 KiB | 
							
								
								
									
										7
									
								
								type-script-helper/media/main.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								type-script-helper/media/main.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| // This script will be run within the webview itself | ||||
| // It cannot access the main VS Code APIs directly. | ||||
| (function () { | ||||
|   const vscode = acquireVsCodeApi(); | ||||
|  | ||||
|   console.log("hello there from javascript"); | ||||
| })(); | ||||
							
								
								
									
										30
									
								
								type-script-helper/media/reset.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								type-script-helper/media/reset.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| html { | ||||
|   box-sizing: border-box; | ||||
|   font-size: 13px; | ||||
| } | ||||
|  | ||||
| *, | ||||
| *:before, | ||||
| *:after { | ||||
|   box-sizing: inherit; | ||||
| } | ||||
|  | ||||
| body, | ||||
| h1, | ||||
| h2, | ||||
| h3, | ||||
| h4, | ||||
| h5, | ||||
| h6, | ||||
| p, | ||||
| ol, | ||||
| ul { | ||||
|   margin: 0; | ||||
|   padding: 0; | ||||
|   font-weight: normal; | ||||
| } | ||||
|  | ||||
| img { | ||||
|   max-width: 100%; | ||||
|   height: auto; | ||||
| } | ||||
							
								
								
									
										91
									
								
								type-script-helper/media/vscode.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								type-script-helper/media/vscode.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,91 @@ | ||||
| :root { | ||||
|   --container-paddding: 20px; | ||||
|   --input-padding-vertical: 6px; | ||||
|   --input-padding-horizontal: 4px; | ||||
|   --input-margin-vertical: 4px; | ||||
|   --input-margin-horizontal: 0; | ||||
| } | ||||
|  | ||||
| body { | ||||
|   padding: 0 var(--container-paddding); | ||||
|   color: var(--vscode-foreground); | ||||
|   font-size: var(--vscode-font-size); | ||||
|   font-weight: var(--vscode-font-weight); | ||||
|   font-family: var(--vscode-font-family); | ||||
|   background-color: var(--vscode-editor-background); | ||||
| } | ||||
|  | ||||
| ol, | ||||
| ul { | ||||
|   padding-left: var(--container-paddding); | ||||
| } | ||||
|  | ||||
| body > *, | ||||
| form > * { | ||||
|   margin-block-start: var(--input-margin-vertical); | ||||
|   margin-block-end: var(--input-margin-vertical); | ||||
| } | ||||
|  | ||||
| *:focus { | ||||
|   outline-color: var(--vscode-focusBorder) !important; | ||||
| } | ||||
|  | ||||
| a { | ||||
|   color: var(--vscode-textLink-foreground); | ||||
| } | ||||
|  | ||||
| a:hover, | ||||
| a:active { | ||||
|   color: var(--vscode-textLink-activeForeground); | ||||
| } | ||||
|  | ||||
| code { | ||||
|   font-size: var(--vscode-editor-font-size); | ||||
|   font-family: var(--vscode-editor-font-family); | ||||
| } | ||||
|  | ||||
| button { | ||||
|   border: none; | ||||
|   padding: var(--input-padding-vertical) var(--input-padding-horizontal); | ||||
|   width: 100%; | ||||
|   text-align: center; | ||||
|   outline: 1px solid transparent; | ||||
|   outline-offset: 2px !important; | ||||
|   color: var(--vscode-button-foreground); | ||||
|   background: var(--vscode-button-background); | ||||
| } | ||||
|  | ||||
| button:hover { | ||||
|   cursor: pointer; | ||||
|   background: var(--vscode-button-hoverBackground); | ||||
| } | ||||
|  | ||||
| button:focus { | ||||
|   outline-color: var(--vscode-focusBorder); | ||||
| } | ||||
|  | ||||
| button.secondary { | ||||
|   color: var(--vscode-button-secondaryForeground); | ||||
|   background: var(--vscode-button-secondaryBackground); | ||||
| } | ||||
|  | ||||
| button.secondary:hover { | ||||
|   background: var(--vscode-button-secondaryHoverBackground); | ||||
| } | ||||
|  | ||||
| input:not([type="checkbox"]), | ||||
| textarea { | ||||
|   display: block; | ||||
|   width: 100%; | ||||
|   border: none; | ||||
|   font-family: var(--vscode-font-family); | ||||
|   padding: var(--input-padding-vertical) var(--input-padding-horizontal); | ||||
|   color: var(--vscode-input-foreground); | ||||
|   outline-color: var(--vscode-input-border); | ||||
|   background-color: var(--vscode-input-background); | ||||
| } | ||||
|  | ||||
| input::placeholder, | ||||
| textarea::placeholder { | ||||
|   color: var(--vscode-input-placeholderForeground); | ||||
| } | ||||
							
								
								
									
										373
									
								
								type-script-helper/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										373
									
								
								type-script-helper/package.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,373 @@ | ||||
| { | ||||
|   "activationEvents": [ | ||||
|     "onLanguage:csharp", | ||||
|     "onLanguage:markdown", | ||||
|     "onLanguage:javascript", | ||||
|     "onLanguage:json", | ||||
|     "onLanguage:typescript", | ||||
|     "onLanguage:yaml" | ||||
|   ], | ||||
|   "categories": [ | ||||
|     "Other" | ||||
|   ], | ||||
|   "contributes": { | ||||
|     "commands": [ | ||||
|       { | ||||
|         "category": "Calculate", | ||||
|         "command": "extension.calcAppendWithCursor", | ||||
|         "title": "Calculate and append in front of cursor" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Calculate", | ||||
|         "command": "extension.calcAppend", | ||||
|         "title": "Calculate and append" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Calculate", | ||||
|         "command": "extension.calcReplaceWithCursor", | ||||
|         "title": "Calculate and replace in front of cursor" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Explorer", | ||||
|         "command": "extension.rotateExplorerSortOrder", | ||||
|         "title": "Rotate Explorer Sort Order" | ||||
|       }, | ||||
|       { | ||||
|         "category": "FileSync", | ||||
|         "command": "webview.fileSync", | ||||
|         "title": "FileSync" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Calculate", | ||||
|         "command": "extension.calcReplace", | ||||
|         "title": "Calculate and replace" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Helper", | ||||
|         "command": "copyHelper.copySyntaxInLight", | ||||
|         "title": "Copy Syntax In Light Theme" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Helper", | ||||
|         "command": "open-in-new-window.open", | ||||
|         "title": "Open in New Window" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Helper", | ||||
|         "command": "promiseLinesHelper.codeGeneratorQuickPick", | ||||
|         "title": "Code Generator - Quick Pick" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Helper", | ||||
|         "command": "promiseLinesHelper.insertDateTime", | ||||
|         "title": "Insert DateTime" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Helper", | ||||
|         "command": "promiseLinesHelper.insertAllExtensions", | ||||
|         "title": "Insert All Extensions (Not Disabled)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Helper", | ||||
|         "command": "promiseLinesHelper.transformToParamCase", | ||||
|         "title": "Transform to Param (Kebab) Case" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Helper", | ||||
|         "command": "promiseLinesHelper.transformToProperCase", | ||||
|         "title": "Transform to Proper (Pascal) Case" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Helper", | ||||
|         "command": "readOnlyLinesHelper.searchGoogle", | ||||
|         "title": "Search Google" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Kanban", | ||||
|         "command": "kanban.openInNewWindow", | ||||
|         "title": "Open Sub-Kanban in New Window" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Kanban", | ||||
|         "command": "kanban.openWithTextEditor", | ||||
|         "title": "Open with Text Editor Kanban" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Leominster", | ||||
|         "command": "webview.backlogLeominster", | ||||
|         "title": "Backlog (Bugs & Features with parents)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Leominster", | ||||
|         "command": "webview.costOfDelayLeominster", | ||||
|         "title": "Cost of Delay (CoD)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Leominster", | ||||
|         "command": "webview.costOfDelayLiveLeominster", | ||||
|         "title": "Cost of Delay (CoD) - Live Update" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Leominster", | ||||
|         "command": "webview.costOfDelayEffortLeominster", | ||||
|         "title": "Effort" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Leominster", | ||||
|         "command": "webview.costOfDelayWSJFLeominster", | ||||
|         "title": "Weightest Shortest Job First calculation (WSJF)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Markdown", | ||||
|         "command": "markdown.newMarkdownFile", | ||||
|         "title": "New Markdown File" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Mesa", | ||||
|         "command": "webview.backlogMesa", | ||||
|         "title": "Backlog (Bugs & Features with parents)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Mesa", | ||||
|         "command": "webview.costOfDelayMesa", | ||||
|         "title": "Cost of Delay (CoD)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Mesa", | ||||
|         "command": "webview.costOfDelayLiveMesa", | ||||
|         "title": "Cost of Delay (CoD) - Live Update" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Mesa", | ||||
|         "command": "webview.costOfDelayEffortMesa", | ||||
|         "title": "Effort" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Mesa", | ||||
|         "command": "webview.costOfDelayWSJFMesa", | ||||
|         "title": "Weightest Shortest Job First calculation (WSJF)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Quick Fix", | ||||
|         "command": "replaceLinesHelper.quickFixCamelCaseProperties", | ||||
|         "title": "Camel Case Properties" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Quick Fix", | ||||
|         "command": "replaceLinesHelper.quickFixCS0108", | ||||
|         "title": " CS0108 (Data Annotations)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Quick Fix", | ||||
|         "command": "replaceLinesHelper.quickFixInstanceFieldToCalisthenics", | ||||
|         "title": "Instance Field to Calisthenics" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Quick Fix", | ||||
|         "command": "replaceLinesHelper.quickFixProperCaseProperties", | ||||
|         "title": "Proper Case Properties" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Quick Fix", | ||||
|         "command": "replaceLinesHelper.quickFixPublic", | ||||
|         "title": "Public (Expression Body)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.addCSharpComment", | ||||
|         "title": "Add C# Comment" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.addVBComment", | ||||
|         "title": "Add VB Comment" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.convertToRegularExpression", | ||||
|         "title": "Convert to Regular Expression" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.cutEachLine", | ||||
|         "title": "Cut each line after |||" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.distinctLines", | ||||
|         "title": "Distinct Lines" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.expandSql", | ||||
|         "title": "Expand Sql" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.listToListFamily", | ||||
|         "title": "List to list family (Kristy, Mike ...)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.listToListWrappedComma", | ||||
|         "title": "List to list wrapped comma" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.prettySql", | ||||
|         "title": "Pretty Sql" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.removeComment", | ||||
|         "title": "Remove comment" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.removeJsonNullValues", | ||||
|         "title": "Remove json null values" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.removeLinesContainingHighlighted", | ||||
|         "title": "Remove lines containing highlighted" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.sortLength", | ||||
|         "title": "Sort by Length" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.sortNormal", | ||||
|         "title": "My Sort lines (ascending, case sensitive)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.splitBySpaceReverseJoinSort", | ||||
|         "title": "Split by Space Reverse Join Sort lines (ascending, case sensitive)" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.unwrapSql", | ||||
|         "title": "Un-wrap Sql" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.wrapSqlCSharp", | ||||
|         "title": "Wrap Sql for C#" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Replace", | ||||
|         "command": "replaceLinesHelper.wrapSqlVB", | ||||
|         "title": "Wrap Sql for VB" | ||||
|       }, | ||||
|       { | ||||
|         "category": "Webview", | ||||
|         "command": "webview.example", | ||||
|         "title": "Webview Example" | ||||
|       } | ||||
|     ], | ||||
|     "configuration": { | ||||
|       "properties": { | ||||
|         "fileTemplates.author": { | ||||
|           "default": null, | ||||
|           "description": "Value to use to replace #{author} variable.", | ||||
|           "type": [ | ||||
|             "string", | ||||
|             "Mike Phares" | ||||
|           ] | ||||
|         }, | ||||
|         "fileTemplates.company": { | ||||
|           "default": null, | ||||
|           "description": "Value to use to replace #{company} variable.", | ||||
|           "type": [ | ||||
|             "string", | ||||
|             "Infineon Technologies Americas Corp." | ||||
|           ] | ||||
|         } | ||||
|       }, | ||||
|       "title": "Cost of Delay Helper Configuration", | ||||
|       "type": "object" | ||||
|     }, | ||||
|     "views": { | ||||
|       "view-command-pallete-webview-view-provider-view": [ | ||||
|         { | ||||
|           "contextualTitle": "Infineon Technologies Americas Corp.", | ||||
|           "icon": "media/lowres-LOGO_Black.png.png", | ||||
|           "id": "view-command-pallete-webview-view-provider", | ||||
|           "name": "Infineon", | ||||
|           "type": "webview" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     "viewsContainers": { | ||||
|       "activitybar": [ | ||||
|         { | ||||
|           "icon": "media/lowres-LOGO_Black.png.png", | ||||
|           "id": "view-command-pallete-webview-view-provider-view", | ||||
|           "title": "Infineon Technologies Americas Corp." | ||||
|         } | ||||
|       ] | ||||
|     } | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "@vscode/vsce": "^3.2.1", | ||||
|     "polka": "^0.5.2" | ||||
|   }, | ||||
|   "description": "Cost of Delay Helper", | ||||
|   "devDependencies": { | ||||
|     "@nodelib/fs.stat": "^3.0.0", | ||||
|     "@types/mocha": "^10.0.6", | ||||
|     "@types/node": "^18.11.0", | ||||
|     "@types/vscode": "^1.63.0", | ||||
|     "@typescript-eslint/eslint-plugin": "^5.40.0", | ||||
|     "@typescript-eslint/parser": "^5.40.0", | ||||
|     "@vscode/test-electron": "^2.4.0", | ||||
|     "@vscode/test-web": "*", | ||||
|     "concurrently": "^8.2.2", | ||||
|     "editor-calc": "^2.1.0", | ||||
|     "eslint": "^8.25.0", | ||||
|     "eslint-config-prettier": "^8.5.0", | ||||
|     "eslint-plugin-prettier": "^4.2.1", | ||||
|     "glob": "^10.4.1", | ||||
|     "mocha": "^10.4.0", | ||||
|     "prettier": "^2.7.1", | ||||
|     "ts-loader": "^9.4.1", | ||||
|     "typescript": "^4.8.4", | ||||
|     "webpack": "^5.74.0", | ||||
|     "webpack-cli": "^4.10.0" | ||||
|   }, | ||||
|   "displayName": "Cost of Delay Helper", | ||||
|   "engines": { | ||||
|     "vscode": "^1.79.0" | ||||
|   }, | ||||
|   "icon": "media/LOGO_RGB.png", | ||||
|   "keywords": [ | ||||
|     "Backlog", | ||||
|     "CoD", | ||||
|     "Cost of Delay (CoD)", | ||||
|     "FI", | ||||
|     "Infineon", | ||||
|     "Leominster", | ||||
|     "Mesa", | ||||
|     "Phares", | ||||
|     "Weightest Shortest Job First calculation (WSJF)", | ||||
|     "WSJF" | ||||
|   ], | ||||
|   "main": "./dist/extension.js", | ||||
|   "name": "infineon-technologies-ag-mesa-fi-cost-of-delay-helper", | ||||
|   "publisher": "Infineon-Technologies-AG-Mesa-FI", | ||||
|   "repository": "https://gitea.phares.duckdns.org/phares3757/yo-vscode.git", | ||||
|   "scripts": { | ||||
|     "tsc-build": "tsc", | ||||
|     "tsc-clean": "tsc --build --clean", | ||||
|     "vscode:login": "node node_modules/@vscode/vsce/vsce login Infineon-Technologies-AG-Mesa-FI", | ||||
|     "vscode:ls-publishers": "node node_modules/@vscode/vsce/vsce ls-publishers", | ||||
|     "vscode:package": "node node_modules/@vscode/vsce/vsce package", | ||||
|     "vscode:publish": "node node_modules/@vscode/vsce/vsce publish", | ||||
|     "watch": "concurrently \"rollup -c -w\" \"webpack --watch --config ./build/node-extension.webpack.config.js\"", | ||||
|     "webpack": "webpack --config ./build/node-extension.webpack.config.js" | ||||
|   }, | ||||
|   "version": "1.124.0" | ||||
| } | ||||
							
								
								
									
										22
									
								
								type-script-helper/src/Card.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								type-script-helper/src/Card.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { H2HexColor } from "./H2HexColor"; | ||||
| import { LineNumber } from "./LineNumber"; | ||||
| import { H2NoCheckboxes } from "./H2NoCheckboxes"; | ||||
| import { H2WithCheckboxes } from "./H2WithCheckboxes"; | ||||
|  | ||||
| export type Card = { | ||||
|   Assignees: Array<string>; | ||||
|   CreationDateTime: Date; | ||||
|   Directory: string; | ||||
|   Extension: string; | ||||
|   File: string; | ||||
|   FileName: string; | ||||
|   FileNameWithoutExtension: string; | ||||
|   H1: string; | ||||
|   H2HexColorCollection: Array<H2HexColor>; | ||||
|   H2NoCheckboxesCollection: Array<H2NoCheckboxes>; | ||||
|   H2WithCheckboxesCollection: Array<H2WithCheckboxes>; | ||||
|   LastWriteDateTime: Date; | ||||
|   LineNumber: LineNumber; | ||||
|   RequestedDateTime: string; | ||||
|   Type: string; | ||||
| }; | ||||
							
								
								
									
										4
									
								
								type-script-helper/src/H2HexColor.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								type-script-helper/src/H2HexColor.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | ||||
| export type H2HexColor = { | ||||
|   H2: string; | ||||
|   HexColor: string; | ||||
| }; | ||||
							
								
								
									
										5
									
								
								type-script-helper/src/H2NoCheckboxes.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								type-script-helper/src/H2NoCheckboxes.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | ||||
|  | ||||
| export type H2NoCheckboxes = { | ||||
|   H2: string; | ||||
|   Lines: Array<string>; | ||||
| }; | ||||
							
								
								
									
										7
									
								
								type-script-helper/src/H2WithCheckboxes.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								type-script-helper/src/H2WithCheckboxes.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
|  | ||||
| export type H2WithCheckboxes = { | ||||
|   Completed: number; | ||||
|   H2: string; | ||||
|   NotCompleted: number; | ||||
|   Total: number; | ||||
| }; | ||||
							
								
								
									
										9
									
								
								type-script-helper/src/LineNumber.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								type-script-helper/src/LineNumber.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,9 @@ | ||||
|  | ||||
| export type LineNumber = { | ||||
|   Created: number; | ||||
|   H1: number; | ||||
|   FrontMatterYamlEnd: number; | ||||
|   Status: number; | ||||
|   Type: number; | ||||
|   Updated: number; | ||||
| }; | ||||
							
								
								
									
										5
									
								
								type-script-helper/src/PostMessage.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								type-script-helper/src/PostMessage.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | ||||
|  | ||||
| export type PostMessage = { | ||||
|   type: string; | ||||
|   value: any; | ||||
| }; | ||||
							
								
								
									
										7
									
								
								type-script-helper/src/ReceivedMessage.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								type-script-helper/src/ReceivedMessage.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
|  | ||||
| export type ReceivedMessage = { | ||||
|   command: string; | ||||
|   collection: Array<any>; | ||||
|   subcommand: string; | ||||
|   value: any; | ||||
| }; | ||||
| @ -0,0 +1,65 @@ | ||||
| import * as vscode from "vscode"; | ||||
| import { getNonce } from "./getNonce"; | ||||
|  | ||||
| export class ViewCommandPalletteWebviewViewProvider implements vscode.WebviewViewProvider { | ||||
|   _webviewView?: vscode.WebviewView; | ||||
|  | ||||
|   constructor(private readonly _extensionContext: vscode.ExtensionContext) { | ||||
|   } | ||||
|  | ||||
|   public revive(webviewView: vscode.WebviewView) { | ||||
|     this._webviewView = webviewView; | ||||
|   } | ||||
|  | ||||
|   public resolveWebviewView(webviewView: vscode.WebviewView) { | ||||
|     this._webviewView = webviewView; | ||||
|     webviewView.webview.options = { | ||||
|       // Allow scripts in the webview | ||||
|       enableScripts: true, | ||||
|  | ||||
|       localResourceRoots: [this._extensionContext.extensionUri], | ||||
|     }; | ||||
|  | ||||
|     webviewView.webview.html = this._getHtmlForWebview(webviewView.webview); | ||||
|   } | ||||
|  | ||||
|   private _getHtmlForWebview(webview: vscode.Webview) { | ||||
|  | ||||
|     const imageA = webview.asWebviewUri( | ||||
|       vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "Screenshot 2025-04-11 125031.png") | ||||
|     ); | ||||
|     const imageB = webview.asWebviewUri( | ||||
|       vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "Screenshot 2025-04-11 125350.png") | ||||
|     ); | ||||
|  | ||||
|     // Use a nonce to only allow a specific script to be run. | ||||
|     const nonce = getNonce(); | ||||
|  | ||||
|     return `<!DOCTYPE html> | ||||
| 			<html lang="en"> | ||||
| 			<head> | ||||
| 				<meta charset="UTF-8"> | ||||
| 				<!-- | ||||
| 					Use a content security policy to only allow loading images from https or from our extension directory, | ||||
| 					and only allow scripts that have a specific nonce. | ||||
|         --> | ||||
|         <meta http-equiv="Content-Security-Policy" | ||||
|           content="img-src https: data:; | ||||
|           style-src 'unsafe-inline' ${webview.cspSource}; | ||||
|           script-src 'nonce-${nonce}';"> | ||||
| 				<meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
| 			</head> | ||||
|       <body> | ||||
|       <h1>Infineon Technologies Americas Corp.</h1> | ||||
|       <ul> | ||||
|         <li>View</li> | ||||
|         <li>Command Pallette... Ctrl+Shift+P</li> | ||||
|         <li>Type Mesa or Leominster</li> | ||||
|         <li>Select item</li> | ||||
|       </ul> | ||||
|       <img src="${imageA}" alt="Screenshot 2025-04-11 125031.png" width="75%" height="75%"> | ||||
|       <img src="${imageB}" alt="Screenshot 2025-04-11 125350" width="75%" height="75%"> | ||||
| 			</body> | ||||
| 			</html>`; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										223
									
								
								type-script-helper/src/WebviewPanelCostOfDelay.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										223
									
								
								type-script-helper/src/WebviewPanelCostOfDelay.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,223 @@ | ||||
| import * as vscode from "vscode"; | ||||
| import { getNonce } from "./getNonce"; | ||||
| import { apiBaseUrl } from "./constants"; | ||||
|  | ||||
| export class WebviewPanelCostOfDelay { | ||||
|   /** | ||||
|    * Track the currently panel. Only allow a single panel to exist at a time. | ||||
|    */ | ||||
|   public static _site: string; | ||||
|   public static _view: string; | ||||
|   public static _title: string; | ||||
|   public static currentPanel: WebviewPanelCostOfDelay | undefined; | ||||
|  | ||||
|   public static readonly viewType = "web-view-panel"; | ||||
|  | ||||
|   private _disposables: vscode.Disposable[] = []; | ||||
|  | ||||
|   public static createOrShow(extensionContext: vscode.ExtensionContext, site: string, view: string) { | ||||
|     this._site = site; | ||||
|     this._view = view; | ||||
|  | ||||
|     const column = vscode.window.activeTextEditor | ||||
|       ? vscode.window.activeTextEditor.viewColumn | ||||
|       : undefined; | ||||
|  | ||||
|     const title = view === '' ? 'Cost of Delay (CoD)' : | ||||
|       view === 'EFFORT' ? 'Effort' : | ||||
|         view === 'LIVE' ? 'Cost of Delay (CoD) - Live Update' : | ||||
|           view === 'HTML' ? 'Backlog (Bugs & Features with parents)' : | ||||
|             view === 'WSJF' ? 'Weightest Shortest Job First calculation (WSJF)' : | ||||
|               'CoD'; | ||||
|     this._title = title; | ||||
|  | ||||
|     // If we already have a panel, show it. | ||||
|     if (WebviewPanelCostOfDelay.currentPanel) { | ||||
|       WebviewPanelCostOfDelay.currentPanel._panel.reveal(column); | ||||
|       WebviewPanelCostOfDelay.currentPanel._update(site, title, view); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|     // Otherwise, create a new panel. | ||||
|     const panel = vscode.window.createWebviewPanel( | ||||
|       WebviewPanelCostOfDelay.viewType, | ||||
|       title, | ||||
|       column || vscode.ViewColumn.One, | ||||
|       { | ||||
|         // Enable javascript in the webview | ||||
|         enableScripts: true, | ||||
|         enableFindWidget: true, | ||||
|  | ||||
|         // And restrict the webview to only loading content from our extension's `media` directory. | ||||
|         localResourceRoots: [ | ||||
|           vscode.Uri.joinPath(extensionContext.extensionUri, "media"), | ||||
|           vscode.Uri.joinPath(extensionContext.extensionUri, "out/compiled"), | ||||
|         ], | ||||
|       } | ||||
|     ); | ||||
|  | ||||
|     WebviewPanelCostOfDelay.currentPanel = new WebviewPanelCostOfDelay(extensionContext, panel, site, title, view); | ||||
|   } | ||||
|  | ||||
|   public static kill() { | ||||
|     WebviewPanelCostOfDelay.currentPanel?.dispose(); | ||||
|     WebviewPanelCostOfDelay.currentPanel = undefined; | ||||
|   } | ||||
|  | ||||
|   public static revive(panel: vscode.WebviewPanel, extensionContext: vscode.ExtensionContext) { | ||||
|     WebviewPanelCostOfDelay.currentPanel = new WebviewPanelCostOfDelay(extensionContext, panel, this._site, this._title, this._view); | ||||
|   } | ||||
|  | ||||
|   private constructor(private readonly _extensionContext: vscode.ExtensionContext, private readonly _panel: vscode.WebviewPanel, site: string, title: string, view: string) { | ||||
|  | ||||
|     // Set the webview's initial html content | ||||
|     this._update(site, title, view); | ||||
|  | ||||
|     // Listen for when the panel is disposed | ||||
|     // This happens when the user closes the panel or when the panel is closed programmatically | ||||
|     this._panel.onDidDispose(() => this.dispose(), null, this._disposables); | ||||
|  | ||||
|     // Handle messages from the webview | ||||
|     this._panel.webview.onDidReceiveMessage( | ||||
|       (message) => { | ||||
|         switch (message.command) { | ||||
|           case "alert": | ||||
|             vscode.window.showErrorMessage(message.text); | ||||
|             return; | ||||
|           default: | ||||
|             vscode.window.showErrorMessage(message.text); | ||||
|             break; | ||||
|         } | ||||
|       }, | ||||
|       null, | ||||
|       this._disposables | ||||
|     ); | ||||
|   } | ||||
|  | ||||
|   public dispose() { | ||||
|     WebviewPanelCostOfDelay.currentPanel = undefined; | ||||
|  | ||||
|     // Clean up our resources | ||||
|     this._panel.dispose(); | ||||
|  | ||||
|     while (this._disposables.length) { | ||||
|       const x = this._disposables.pop(); | ||||
|       if (x) { | ||||
|         x.dispose(); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   private async _update(site: string, title: string, view: string) { | ||||
|     const webview = this._panel.webview; | ||||
|     this._panel.webview.html = this._getHtmlForWebview(site, title, view, webview); | ||||
|     webview.onDidReceiveMessage(async (message: string) => { | ||||
|       vscode.window.showErrorMessage(message); | ||||
|     }); | ||||
|   } | ||||
|  | ||||
|   private _getHtmlForWebview(site: string, title: string, view: string, webview: vscode.Webview) { | ||||
|     const baseUri = 'https://eaf-dev.mes.infineon.com'; | ||||
|     const scriptUri = 'cod-1-123-0.js?v=2025-04-14-08-10'; | ||||
|  | ||||
|     // Use a nonce to only allow a specific script to be run. | ||||
|     const nonce = getNonce(); | ||||
|  | ||||
|     if (view === 'HTML') { | ||||
|       return `<!DOCTYPE html> | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
|     <title>Infineon - ${title}</title> | ||||
| </head> | ||||
| <body> | ||||
|   <iframe width="100%" style="height: 100vh;" src="${baseUri}/html/mes.html?site=${site}" title="${title}"> | ||||
|   </iframe> | ||||
| </body> | ||||
| </html>`; | ||||
|     } | ||||
|     else { | ||||
|       const styleBootstrapUri = webview.asWebviewUri( | ||||
|         vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "bootstrap.min.css") | ||||
|       ); | ||||
|       const styleCostOfDelayUri = webview.asWebviewUri( | ||||
|         vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "cod.css") | ||||
|       ); | ||||
|       const scriptJQueryUri = webview.asWebviewUri( | ||||
|         vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "jquery-1.6.4.min.js") | ||||
|       ); | ||||
|       const scriptSignalRUri = webview.asWebviewUri( | ||||
|         vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "jquery.signalR-2.4.3.min.js") | ||||
|       ); | ||||
|       const scriptCostOfDelayUri = webview.asWebviewUri( | ||||
|         vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "cost-of-delay.js") | ||||
|       ); | ||||
|  | ||||
|       return `<!DOCTYPE html> | ||||
| <html lang="en"> | ||||
|  | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
|     <title>Infineon - ${title}</title> | ||||
|     <link href="${styleBootstrapUri}" rel="stylesheet" /> | ||||
|     <link href="${styleCostOfDelayUri}" rel="stylesheet" /> | ||||
|     <script nonce="${nonce}" src="${scriptJQueryUri}"></script> | ||||
|     <script nonce="${nonce}" src="${scriptSignalRUri}"></script> | ||||
|     <script nonce="${nonce}" src="${baseUri}/js/${scriptUri}" type="text/javascript"></script> | ||||
|     <script nonce="${nonce}"> | ||||
|       const _webviewSite = '${site}'; | ||||
|       const _webviewView = '${view}'; | ||||
|       const acquiredVsCodeApi = acquireVsCodeApi(); | ||||
|       const apiBaseUrl = ${JSON.stringify(apiBaseUrl)} | ||||
|       const _webviewUsername = '${process.env.USERNAME}'; | ||||
|       const _webviewMachineId = '${vscode.env.machineId}'; | ||||
|     </script> | ||||
| </head> | ||||
|  | ||||
| <body> | ||||
|     <div class="navbar navbar-fixed-top"> | ||||
|         <div class="container-fluid"> | ||||
|             <div class="navbar-header"> | ||||
|                 <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse"> | ||||
|                     <span class="icon-bar"></span> | ||||
|                     <span class="icon-bar"></span> | ||||
|                     <span class="icon-bar"></span> | ||||
|                 </button> | ||||
|                 <div class="navbar-brand"> | ||||
|                     <span id="siteHeader"> </span> - | ||||
|                     <span id="th-span"> </span> | ||||
|                     <button id="toggle">Toggle</button> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="navbar-collapse collapse"> | ||||
|                 <ul class="nav navbar-nav"> | ||||
|                 </ul> | ||||
|                 <p class="navbar-text navbar-right"> | ||||
|                       | ||||
|                 </p> | ||||
|             </div> | ||||
|         </div> | ||||
|     </div> | ||||
|     <div class="container-fluid body-content" style="margin-top: 40px; margin-left: 15px;"> | ||||
|         <div id="HeaderGridDiv"> | ||||
|             <table id="HeaderGrid" border="1"></table> | ||||
|         </div> | ||||
|  | ||||
|         <br />  | ||||
|  | ||||
|         <div id="AllGridDiv"> | ||||
|             <table id="AllGrid"></table> | ||||
|         </div> | ||||
|  | ||||
|         <textarea id="AllTextarea" rows="20" cols="147"></textarea> | ||||
|     </div> | ||||
|  | ||||
|   <script nonce="${nonce}" src="${scriptCostOfDelayUri}"></script> | ||||
| </body> | ||||
|  | ||||
| </html>`; | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										167
									
								
								type-script-helper/src/WebviewPanelExample.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										167
									
								
								type-script-helper/src/WebviewPanelExample.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,167 @@ | ||||
| import * as vscode from "vscode"; | ||||
| import { getNonce } from "./getNonce"; | ||||
| import { apiBaseUrl } from "./constants"; | ||||
| import { PostMessage } from "./PostMessage"; | ||||
|  | ||||
| export function refreshWebviewPanelExample(extensionContext: vscode.ExtensionContext): any { | ||||
|   WebviewPanelExample.kill(); | ||||
|   WebviewPanelExample.createOrShow(extensionContext); | ||||
| } | ||||
|  | ||||
| export class WebviewPanelExample { | ||||
|   /** | ||||
|    * Track the currently panel. Only allow a single panel to exist at a time. | ||||
|    */ | ||||
|   public static currentPanel: WebviewPanelExample | undefined; | ||||
|  | ||||
|   public static readonly viewType = "web-view-panel"; | ||||
|  | ||||
|   private _disposables: vscode.Disposable[] = []; | ||||
|  | ||||
|   public static createOrShow(extensionContext: vscode.ExtensionContext) { | ||||
|     const column = vscode.window.activeTextEditor | ||||
|       ? vscode.window.activeTextEditor.viewColumn | ||||
|       : undefined; | ||||
|  | ||||
|     // If we already have a panel, show it. | ||||
|     if (WebviewPanelExample.currentPanel) { | ||||
|       WebviewPanelExample.currentPanel._panel.reveal(column); | ||||
|       WebviewPanelExample.currentPanel._update(); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|     // Otherwise, create a new panel. | ||||
|     const panel = vscode.window.createWebviewPanel( | ||||
|       WebviewPanelExample.viewType, | ||||
|       "Web-View-Panel", | ||||
|       column || vscode.ViewColumn.One, | ||||
|       { | ||||
|         // Enable javascript in the webview | ||||
|         enableScripts: true, | ||||
|         enableFindWidget: true, | ||||
|  | ||||
|         // And restrict the webview to only loading content from our extension's `media` directory. | ||||
|         localResourceRoots: [ | ||||
|           vscode.Uri.joinPath(extensionContext.extensionUri, "media"), | ||||
|           vscode.Uri.joinPath(extensionContext.extensionUri, "out/compiled"), | ||||
|         ], | ||||
|       } | ||||
|     ); | ||||
|  | ||||
|     WebviewPanelExample.currentPanel = new WebviewPanelExample(panel, extensionContext); | ||||
|   } | ||||
|  | ||||
|   public static kill() { | ||||
|     WebviewPanelExample.currentPanel?.dispose(); | ||||
|     WebviewPanelExample.currentPanel = undefined; | ||||
|   } | ||||
|  | ||||
|   public static revive(panel: vscode.WebviewPanel, extensionContext: vscode.ExtensionContext) { | ||||
|     WebviewPanelExample.currentPanel = new WebviewPanelExample(panel, extensionContext); | ||||
|   } | ||||
|  | ||||
|   private constructor(private readonly _panel: vscode.WebviewPanel, private readonly _extensionContext: vscode.ExtensionContext) { | ||||
|  | ||||
|     // Set the webview's initial html content | ||||
|     this._update(); | ||||
|  | ||||
|     // Listen for when the panel is disposed | ||||
|     // This happens when the user closes the panel or when the panel is closed programmatically | ||||
|     this._panel.onDidDispose(() => this.dispose(), null, this._disposables); | ||||
|  | ||||
|     // // Handle messages from the webview | ||||
|     // this._panel.webview.onDidReceiveMessage( | ||||
|     //   (message) => { | ||||
|     //     switch (message.command) { | ||||
|     //       case "alert": | ||||
|     //         vscode.window.showErrorMessage(message.text); | ||||
|     //         return; | ||||
|     //     } | ||||
|     //   }, | ||||
|     //   null, | ||||
|     //   this._disposables | ||||
|     // ); | ||||
|   } | ||||
|  | ||||
|   public dispose() { | ||||
|     WebviewPanelExample.currentPanel = undefined; | ||||
|  | ||||
|     // Clean up our resources | ||||
|     this._panel.dispose(); | ||||
|  | ||||
|     while (this._disposables.length) { | ||||
|       const x = this._disposables.pop(); | ||||
|       if (x) { | ||||
|         x.dispose(); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   private async _update() { | ||||
|     const webview = this._panel.webview; | ||||
|  | ||||
|     this._panel.webview.html = this._getHtmlForWebview(webview); | ||||
|     webview.onDidReceiveMessage(async (postMessage: PostMessage) => { | ||||
|       switch (postMessage.type) {         | ||||
|         case "on-info": | ||||
|           if (!postMessage.value) | ||||
|             return; | ||||
|           vscode.window.showInformationMessage(postMessage.value); | ||||
|           break; | ||||
|         case "on-error": | ||||
|           if (!postMessage.value) | ||||
|             return; | ||||
|           vscode.window.showErrorMessage(postMessage.value); | ||||
|           break; | ||||
|         default: | ||||
|           vscode.window.showErrorMessage(postMessage.type); | ||||
|           break; | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
|  | ||||
|   private _getHtmlForWebview(webview: vscode.Webview) { | ||||
|     const styleResetUri = webview.asWebviewUri( | ||||
|       vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "reset.css") | ||||
|     ); | ||||
|     const styleVSCodeUri = webview.asWebviewUri( | ||||
|       vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "vscode.css") | ||||
|     ); | ||||
|  | ||||
|     const scriptUri = webview.asWebviewUri( | ||||
|       vscode.Uri.joinPath(this._extensionContext.extensionUri, "out", "compiled/DisplayDate.js") | ||||
|     ); | ||||
|     const styleMainUri = webview.asWebviewUri( | ||||
|       vscode.Uri.joinPath(this._extensionContext.extensionUri, "out", "compiled/DisplayDate.css") | ||||
|     ); | ||||
|  | ||||
|     // Use a nonce to only allow a specific script to be run. | ||||
|     const nonce = getNonce(); | ||||
|  | ||||
|     return `<!DOCTYPE html> | ||||
| 			<html lang="en"> | ||||
| 			<head> | ||||
| 				<meta charset="UTF-8"> | ||||
| 				<!-- | ||||
| 					Use a content security policy to only allow loading images from https or from our extension directory, | ||||
| 					and only allow scripts that have a specific nonce. | ||||
|         --> | ||||
|         <meta http-equiv="Content-Security-Policy" | ||||
|           content="img-src https: data:; | ||||
|           style-src 'unsafe-inline' ${webview.cspSource}; | ||||
|           script-src 'nonce-${nonce}';"> | ||||
| 				<meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
| 				<link href="${styleResetUri}" rel="stylesheet"> | ||||
| 				<link href="${styleVSCodeUri}" rel="stylesheet"> | ||||
|         <link href="${styleMainUri}" rel="stylesheet"> | ||||
|         <script nonce="${nonce}"> | ||||
|           const acquiredVsCodeApi = acquireVsCodeApi(); | ||||
|           const apiBaseUrl = ${JSON.stringify(apiBaseUrl)} | ||||
|         </script> | ||||
| 			</head> | ||||
|       <body> | ||||
| 				<script nonce="${nonce}" src="${scriptUri}"></script> | ||||
| 			</body> | ||||
| 			</html>`; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										241
									
								
								type-script-helper/src/WebviewPanelFileSync.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										241
									
								
								type-script-helper/src/WebviewPanelFileSync.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,241 @@ | ||||
| import { readFile } from 'fs'; | ||||
| import * as vscode from 'vscode'; | ||||
| import { getNonce } from './getNonce'; | ||||
| import { fileFolderHelperExe } from './constants'; | ||||
| import { ExecException, exec } from 'child_process'; | ||||
| import { ReceivedMessage } from './ReceivedMessage'; | ||||
|  | ||||
| async function postRelativePath(extensionUri: vscode.Uri, webviewPanel: vscode.WebviewPanel, receivedMessage: ReceivedMessage) { | ||||
|   if (vscode.workspace.workspaceFolders === undefined) { | ||||
|     vscode.window.showInformationMessage('Open workspace first!'); | ||||
|   } | ||||
|   else { | ||||
|     const workspaceFoldersZero = vscode.workspace.workspaceFolders[0].uri; | ||||
|     const inputUri: vscode.Uri = vscode.Uri.joinPath(workspaceFoldersZero, '.vscode', 'input.json'); | ||||
|     readFile(inputUri.fsPath, (err, data) => | ||||
|       inputUriRead(extensionUri, webviewPanel, receivedMessage, workspaceFoldersZero, inputUri, err, data.toString('utf8'))); | ||||
|   } | ||||
| } | ||||
|  | ||||
| function inputUriRead(extensionUri: vscode.Uri, webviewPanel: vscode.WebviewPanel, receivedMessage: ReceivedMessage, workspaceFoldersZero: vscode.Uri, inputUri: vscode.Uri, err: NodeJS.ErrnoException | null, data: string) { | ||||
|   if (err) { | ||||
|     vscode.window.showInformationMessage(`<${inputUri.fsPath}> doesn't exist! ${err.message}`); | ||||
|   } | ||||
|   else { | ||||
|     const jsonObject: any = JSON.parse(data); | ||||
|     if (!jsonObject.BaseAddresses || !jsonObject.Page || jsonObject.BaseAddresses.length === 0) { | ||||
|       vscode.window.showInformationMessage(`<${inputUri.fsPath}> doesn't have valid json! ${data}`); | ||||
|     } | ||||
|     else { | ||||
|       const relativePathUri: vscode.Uri = vscode.Uri.joinPath(workspaceFoldersZero, '.vscode', 'RelativePath.json'); | ||||
|       const fileFolderHelper: vscode.Uri = vscode.Uri.joinPath(extensionUri, 'net8.0', 'win-x64', 'publish', fileFolderHelperExe); | ||||
|       const command: string = `${fileFolderHelper.fsPath} s X "${workspaceFoldersZero.fsPath}" Day-Helper-2025-05-19 "${inputUri.fsPath}"`; | ||||
|       exec(command, (error, stdout, stderr) => | ||||
|         execCallback(webviewPanel, receivedMessage, jsonObject, relativePathUri, error, stdout, stderr)); | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| function execCallback(webviewPanel: vscode.WebviewPanel, receivedMessage: ReceivedMessage, jsonObject: any, relativePathUri: vscode.Uri, error: ExecException | null, stdout: string, stderr: string) { | ||||
|   if (error) { | ||||
|     vscode.window.showInformationMessage(error.message); | ||||
|     return; | ||||
|   } | ||||
|   if (stderr) { | ||||
|     vscode.window.showInformationMessage(stderr); | ||||
|     return; | ||||
|   } | ||||
|   console.log(`stdout: ${stdout}`); | ||||
|   readFile(relativePathUri.fsPath, (err, data) => | ||||
|     relativePathUriRead(webviewPanel, receivedMessage, jsonObject, relativePathUri, err, data.toString('utf8'))); | ||||
| }; | ||||
|  | ||||
| function relativePathUriRead(webviewPanel: vscode.WebviewPanel, receivedMessage: ReceivedMessage, jsonObject: any, relativePathUri: vscode.Uri, err: NodeJS.ErrnoException | null, data: string) { | ||||
|   if (err) { | ||||
|     vscode.window.showInformationMessage(`<${relativePathUri.fsPath}> doesn't exist! ${err.message}`); | ||||
|   } | ||||
|   else { | ||||
|     // const jsonObject: any = JSON.parse(data); | ||||
|     // const receivedMessage: ReceivedMessage = { command: 'File-Folder-Helper', subcommand: 'post', value: jsonObject, collection: [] }; | ||||
|     // receivedMessage.command = 'done'; | ||||
|     // webviewPanel.webview.postMessage(receivedMessage); | ||||
|     const message = { command: receivedMessage.subcommand, from: receivedMessage.command + '-' + receivedMessage.subcommand, input: jsonObject, relativePath: data }; | ||||
|     webviewPanel.webview.postMessage(message); | ||||
|   } | ||||
| } | ||||
|  | ||||
| export class WebviewPanelFileSync { | ||||
|  | ||||
|   public static _title: string; | ||||
|   public static readonly viewType = 'web-view-panel'; | ||||
|   public static currentPanel: WebviewPanelFileSync | undefined; | ||||
|  | ||||
|   private _disposables: vscode.Disposable[] = []; | ||||
|  | ||||
|   public static createOrShow(extensionContext: vscode.ExtensionContext, title: string) { | ||||
|     this._title = title; | ||||
|  | ||||
|     const column = vscode.window.activeTextEditor | ||||
|       ? vscode.window.activeTextEditor.viewColumn | ||||
|       : undefined; | ||||
|  | ||||
|     if (WebviewPanelFileSync.currentPanel) { | ||||
|       WebviewPanelFileSync.currentPanel._panel.reveal(column); | ||||
|       WebviewPanelFileSync.currentPanel._update(title); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|     const panel = vscode.window.createWebviewPanel( | ||||
|       WebviewPanelFileSync.viewType, | ||||
|       title, | ||||
|       column || vscode.ViewColumn.One, | ||||
|       { | ||||
|         enableScripts: true, | ||||
|         enableFindWidget: true, | ||||
|         localResourceRoots: [ | ||||
|           vscode.Uri.joinPath(extensionContext.extensionUri, 'dist'), | ||||
|           vscode.Uri.joinPath(extensionContext.extensionUri, 'media'), | ||||
|         ], | ||||
|       } | ||||
|     ); | ||||
|  | ||||
|     WebviewPanelFileSync.currentPanel = new WebviewPanelFileSync(extensionContext, panel, title); | ||||
|   } | ||||
|  | ||||
|   public static kill() { | ||||
|     WebviewPanelFileSync.currentPanel?.dispose(); | ||||
|     WebviewPanelFileSync.currentPanel = undefined; | ||||
|   } | ||||
|  | ||||
|   public static revive(panel: vscode.WebviewPanel, extensionContext: vscode.ExtensionContext) { | ||||
|     WebviewPanelFileSync.currentPanel = new WebviewPanelFileSync(extensionContext, panel, this._title); | ||||
|   } | ||||
|  | ||||
|   public dispose() { | ||||
|     WebviewPanelFileSync.currentPanel = undefined; | ||||
|     this._panel.dispose(); | ||||
|     while (this._disposables.length) { | ||||
|       const x = this._disposables.pop(); | ||||
|       if (x) { | ||||
|         x.dispose(); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   private constructor(private readonly _extensionContext: vscode.ExtensionContext, private readonly _panel: vscode.WebviewPanel, title: string) { | ||||
|     this._update(title); | ||||
|     this._panel.onDidDispose(() => this.dispose(), null, this._disposables); | ||||
|   } | ||||
|  | ||||
|   private async _update(title: string) { | ||||
|     const webview = this._panel.webview; | ||||
|     this._panel.webview.html = this._getHtmlForWebview(title, webview); | ||||
|     webview.onDidReceiveMessage( | ||||
|       (receivedMessage: ReceivedMessage) => { | ||||
|         WebviewPanelFileSync.onDidReceiveMessage( | ||||
|           this._extensionContext.extensionUri, | ||||
|           this._panel, | ||||
|           receivedMessage | ||||
|         ); | ||||
|       }, | ||||
|       null, | ||||
|       this._disposables | ||||
|     ); | ||||
|   } | ||||
|  | ||||
|   private static onDidReceiveMessage(extensionUri: vscode.Uri, webviewPanel: vscode.WebviewPanel, receivedMessage: ReceivedMessage) { | ||||
|     switch (receivedMessage.command) { | ||||
|       case 'alert': | ||||
|         vscode.window.showErrorMessage(receivedMessage.value); | ||||
|         return; | ||||
|       case fileFolderHelperExe: | ||||
|         if (receivedMessage.subcommand === 'post') { | ||||
|           postRelativePath(extensionUri, webviewPanel, receivedMessage); | ||||
|         } | ||||
|         return; | ||||
|       default: | ||||
|         vscode.window.showErrorMessage(receivedMessage.value); | ||||
|         break; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   private _getHtmlForWebview(title: string, webview: vscode.Webview) { | ||||
|     // Use a nonce to only allow a specific script to be run. | ||||
|     const nonce = getNonce(); | ||||
|  | ||||
|     if (title === 'HTML') { | ||||
|       return `<!DOCTYPE html> | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
|     <title>Infineon - ${title}</title> | ||||
| </head> | ||||
| <body> | ||||
|   ${title} | ||||
| </body> | ||||
| </html>`; | ||||
|     } | ||||
|     else { | ||||
|       const styleCostOfDelayUri = webview.asWebviewUri(vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "cod.css")); | ||||
|       const scriptEmbedRollup = webview.asWebviewUri(vscode.Uri.joinPath(this._extensionContext.extensionUri, "dist", "embed-rollup.js")); | ||||
|       const scriptJQueryUri = webview.asWebviewUri(vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "jquery-1.6.4.min.js")); | ||||
|       const styleBootstrapUri = webview.asWebviewUri(vscode.Uri.joinPath(this._extensionContext.extensionUri, "media", "bootstrap.min.css")); | ||||
|  | ||||
|       return `<!DOCTYPE html> | ||||
| <html lang="en"> | ||||
|  | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
|     <title>Infineon - ${title}</title> | ||||
|     <link href="${styleBootstrapUri}" rel="stylesheet" /> | ||||
|     <link href="${styleCostOfDelayUri}" rel="stylesheet" /> | ||||
|     <script nonce="${nonce}" src="${scriptJQueryUri}" type="text/javascript"></script> | ||||
|     <script nonce="${nonce}" type="text/javascript"> | ||||
|       const acquiredVsCodeApi = acquireVsCodeApi(); | ||||
|       const _webviewUsername = '${process.env.USERNAME}'; | ||||
|       const _webviewMachineId = '${vscode.env.machineId}'; | ||||
|     </script> | ||||
| </head> | ||||
|  | ||||
| <body> | ||||
|     <div class="navbar navbar-fixed-top"> | ||||
|         <div class="container-fluid"> | ||||
|             <div class="navbar-header"> | ||||
|                 <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse"> | ||||
|                     <span class="icon-bar"></span> | ||||
|                     <span class="icon-bar"></span> | ||||
|                     <span class="icon-bar"></span> | ||||
|                 </button> | ||||
|                 <div class="navbar-brand"> | ||||
|                     <span id="siteHeader"> </span> - | ||||
|                     <span id="th-span"> </span> | ||||
|                     <button id="toggle" onclick="getRelativePathAndPost()">Toggle</button> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="navbar-collapse collapse"> | ||||
|                 <ul class="nav navbar-nav"> | ||||
|                 </ul> | ||||
|                 <p class="navbar-text navbar-right"> | ||||
|                       | ||||
|                 </p> | ||||
|             </div> | ||||
|         </div> | ||||
|     </div> | ||||
|     <div class="container-fluid body-content" style="margin-top: 40px; margin-left: 15px;"> | ||||
|         <script nonce="${nonce}" src="${scriptEmbedRollup}" type="text/javascript"></script> | ||||
|  | ||||
|         <div id="HeaderGridDiv"> | ||||
|             <table id="HeaderGrid" border="1"></table> | ||||
|         </div> | ||||
|  | ||||
|         <br />  | ||||
|  | ||||
|         <textarea id="AllTextarea" rows="20" cols="147"></textarea> | ||||
|     </div> | ||||
| </body> | ||||
| </html>`; | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										193
									
								
								type-script-helper/src/calculator.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										193
									
								
								type-script-helper/src/calculator.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,193 @@ | ||||
| import * as vscode from 'vscode'; | ||||
| import * as editorCalc from 'editor-calc'; | ||||
|  | ||||
| export class CalcProvider implements vscode.CompletionItemProvider { | ||||
|   public enableActive: boolean; | ||||
|  | ||||
|   private decorationType: vscode.TextEditorDecorationType; | ||||
|  | ||||
|   constructor( | ||||
|     public config: vscode.WorkspaceConfiguration, | ||||
|     private onError: (error: unknown) => any, | ||||
|   ) { | ||||
|     this.enableActive = false; | ||||
|     this.decorationType = vscode.window.createTextEditorDecorationType({ | ||||
|       dark: { | ||||
|         border: '1px dashed gray', | ||||
|       }, | ||||
|       light: { | ||||
|         border: '1px dashed black', | ||||
|       }, | ||||
|     }); | ||||
|   } | ||||
|  | ||||
|   public async highlight(range: vscode.Range) { | ||||
|     const editor = vscode.window.activeTextEditor; | ||||
|     if (editor) { | ||||
|       editor.setDecorations(this.decorationType, [range]); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   public async clearHighlight() { | ||||
|     const editor = vscode.window.activeTextEditor; | ||||
|     if (editor) { | ||||
|       editor.setDecorations(this.decorationType, []); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   public calculateLine( | ||||
|     position: vscode.Position, | ||||
|     exprLine: string, | ||||
|   ): { | ||||
|     skip: number; | ||||
|     result: string; | ||||
|     insertText: string; | ||||
|     expressionRange: vscode.Range; | ||||
|     expressionWithEqualSignRange: vscode.Range; | ||||
|     expressionEndRange: vscode.Range; | ||||
|   } | null { | ||||
|     let skip, result; | ||||
|     try { | ||||
|       ({ skip, result } = editorCalc.calculate(exprLine)); | ||||
|     } catch (error) { | ||||
|       this.onError(error); | ||||
|       return null; | ||||
|     } | ||||
|     const formulaRaw = exprLine.slice(skip); | ||||
|     const leftMatches = formulaRaw.match(/^\s+/); | ||||
|     const leftEmpty = leftMatches ? leftMatches[0].length : 0; | ||||
|     const rightMatches = formulaRaw.match(/[\s=]+$/); | ||||
|     const rightEmpty = rightMatches ? rightMatches[0].length : 0; | ||||
|  | ||||
|     const insertText = exprLine.endsWith(' =') ? ` ${result}` : result; | ||||
|  | ||||
|     return { | ||||
|       skip, | ||||
|       result, | ||||
|       insertText, | ||||
|       expressionRange: new vscode.Range( | ||||
|         position.line, | ||||
|         skip + leftEmpty, | ||||
|         position.line, | ||||
|         position.character - rightEmpty, | ||||
|       ), | ||||
|       expressionWithEqualSignRange: new vscode.Range( | ||||
|         position.line, | ||||
|         skip + leftEmpty, | ||||
|         position.line, | ||||
|         position.character, | ||||
|       ), | ||||
|       expressionEndRange: new vscode.Range( | ||||
|         position.line, | ||||
|         position.character, | ||||
|         position.line, | ||||
|         position.character, | ||||
|       ), | ||||
|     }; | ||||
|   } | ||||
|  | ||||
|   private getCompletionResultsFromExtraCursors(document: vscode.TextDocument): { | ||||
|     additionalReplacements: vscode.Range[]; | ||||
|     additionalTextInserts: string[]; | ||||
|     additionalResults: string[]; | ||||
|   } { | ||||
|     const additionalReplacements = []; | ||||
|     const additionalTextInserts = []; | ||||
|     const additionalResults = []; | ||||
|  | ||||
|     const editor = vscode.window.activeTextEditor; | ||||
|     if (editor) { | ||||
|       for (const selection of editor.selections.slice(1)) { | ||||
|         const position = selection.active; | ||||
|         const exprLine = document.getText( | ||||
|           new vscode.Range(new vscode.Position(position.line, 0), position), | ||||
|         ); | ||||
|         const lineCalcResult = this.calculateLine(position, exprLine); | ||||
|         if (lineCalcResult == null) { | ||||
|           continue; | ||||
|         } | ||||
|         const { expressionWithEqualSignRange, insertText, result } = | ||||
|           lineCalcResult; | ||||
|         additionalReplacements.push(expressionWithEqualSignRange); | ||||
|         additionalTextInserts.push(insertText); | ||||
|         additionalResults.push(result); | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     return { additionalReplacements, additionalTextInserts, additionalResults }; | ||||
|   } | ||||
|  | ||||
|   public async provideCompletionItems( | ||||
|     document: vscode.TextDocument, | ||||
|     position: vscode.Position, | ||||
|     _token: vscode.CancellationToken, | ||||
|     _context: vscode.CompletionContext, | ||||
|   ): Promise<vscode.CompletionItem[]> { | ||||
|     const exprLine = document.getText( | ||||
|       new vscode.Range(new vscode.Position(position.line, 0), position), | ||||
|     ); | ||||
|     if (!this.enableActive && !exprLine.trimRight().endsWith('=')) { | ||||
|       return []; | ||||
|     } | ||||
|     const lineCalcResult = this.calculateLine(position, exprLine); | ||||
|     if (lineCalcResult == null) { | ||||
|       return []; | ||||
|     } | ||||
|     const { | ||||
|       skip, | ||||
|       result, | ||||
|       expressionRange, | ||||
|       expressionWithEqualSignRange, | ||||
|       expressionEndRange, | ||||
|       insertText, | ||||
|     } = lineCalcResult; | ||||
|  | ||||
|     this.clearHighlight().catch(this.onError); | ||||
|  | ||||
|     this.highlight(expressionRange).catch(this.onError); | ||||
|  | ||||
|     const { additionalReplacements, additionalTextInserts, additionalResults } = | ||||
|       this.getCompletionResultsFromExtraCursors(document); | ||||
|     const documentationPostfix = | ||||
|       additionalResults.length > 0 ? ' (multiple)' : ''; | ||||
|  | ||||
|     return [ | ||||
|       { | ||||
|         label: result, | ||||
|         kind: vscode.CompletionItemKind.Constant, | ||||
|         detail: `calc append${documentationPostfix}`, | ||||
|         documentation: `\`${exprLine | ||||
|           .slice(skip) | ||||
|           .trimStart()}${insertText}\`${documentationPostfix}`, | ||||
|         range: expressionEndRange, | ||||
|         additionalTextEdits: [ | ||||
|           vscode.TextEdit.insert(expressionWithEqualSignRange.end, insertText), | ||||
|           ...additionalReplacements.map((replacementRange, i) => | ||||
|             vscode.TextEdit.insert(replacementRange.end, additionalTextInserts[i]), | ||||
|           ), | ||||
|         ], | ||||
|         insertText: '', // text specified here will be inserted on every line | ||||
|       }, | ||||
|       { | ||||
|         label: result, | ||||
|         kind: vscode.CompletionItemKind.Constant, | ||||
|         detail: `calc replace${documentationPostfix}`, | ||||
|         documentation: `\`${result}\`${documentationPostfix}`, | ||||
|         additionalTextEdits: [ | ||||
|           vscode.TextEdit.replace(expressionWithEqualSignRange, result), | ||||
|           ...additionalReplacements.map((replacementRange, i) => | ||||
|             vscode.TextEdit.replace(replacementRange, additionalResults[i]), | ||||
|           ), | ||||
|         ], | ||||
|         insertText: '', | ||||
|       }, | ||||
|     ]; | ||||
|   } | ||||
|  | ||||
|   async resolveCompletionItem( | ||||
|     item: vscode.CompletionItem, | ||||
|     _token: vscode.CancellationToken, | ||||
|   ): Promise<vscode.CompletionItem> { | ||||
|     return item; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										3
									
								
								type-script-helper/src/constants.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								type-script-helper/src/constants.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| export const key: string = 'type-script-helper'; | ||||
| export const apiBaseUrl: string = 'http://localhost:3002'; | ||||
| export const fileFolderHelperExe: string = 'File-Folder-Helper.exe' | ||||
							
								
								
									
										37
									
								
								type-script-helper/src/copyHelper.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								type-script-helper/src/copyHelper.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,37 @@ | ||||
| import * as vscode from 'vscode'; | ||||
|  | ||||
| async function copySyntaxInLightLogic(): Promise<any> { | ||||
|     try { | ||||
|         // Get the current configuration | ||||
|         const config = vscode.workspace.getConfiguration(); | ||||
|  | ||||
|         // Get the current color theme | ||||
|         const currentTheme = config.get("workbench.colorTheme"); | ||||
|  | ||||
|         // Set the color theme to "Default Light+" | ||||
|         await config.update( | ||||
|             "workbench.colorTheme", | ||||
|             "Default Light Modern", | ||||
|             vscode.ConfigurationTarget.Global | ||||
|         ); | ||||
|  | ||||
|         // Copy Selected Text | ||||
|         await vscode.commands.executeCommand( | ||||
|             "editor.action.clipboardCopyAction" | ||||
|         ); | ||||
|  | ||||
|         // Show success message | ||||
|         vscode.window.showInformationMessage("Text copied in Light Mode"); | ||||
|  | ||||
|         // Switch back to dark theme | ||||
|         await config.update( | ||||
|             "workbench.colorTheme", | ||||
|             currentTheme, | ||||
|             vscode.ConfigurationTarget.Global | ||||
|         ); | ||||
|     } catch (error) { | ||||
|         vscode.window.showErrorMessage(`Error: ${error}`); | ||||
|     } | ||||
| } | ||||
|  | ||||
| export const copySyntaxInLight = () => copySyntaxInLightLogic(); | ||||
							
								
								
									
										203
									
								
								type-script-helper/src/extension.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										203
									
								
								type-script-helper/src/extension.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,203 @@ | ||||
| // The module 'vscode' contains the VS Code extensibility API | ||||
| // Import the module and reference it with the alias vscode in your code below | ||||
| import * as vscode from 'vscode'; | ||||
| import * as Calculator from './calculator'; | ||||
| import * as copyHelper from './copyHelper'; | ||||
| import * as kanbanHelper from './kanbanHelper'; | ||||
| import * as markdownHelper from './markdownHelper'; | ||||
| import * as settingsHelper from './settingsHelper'; | ||||
| import * as promiseLinesHelper from './promiseLinesHelper'; | ||||
| import * as replaceLinesHelper from './replaceLinesHelper'; | ||||
| import * as readOnlyLinesHelper from './readOnlyLinesHelper'; | ||||
| import * as WebviewPanelExample from './WebviewPanelExample'; | ||||
| import * as WebviewPanelFileSync from './WebviewPanelFileSync'; | ||||
| import * as WebviewPanelCostOfDelay from './WebviewPanelCostOfDelay'; | ||||
| import { ViewCommandPalletteWebviewViewProvider } from "./ViewCommandPalletteWebviewViewProvider"; | ||||
|  | ||||
| // This method is called when your extension is activated | ||||
| // Your extension is activated the very first time the command is executed | ||||
| export async function activate(extensionContext: vscode.ExtensionContext) { | ||||
|  | ||||
| 	const viewCommandPalletteWebviewViewProvider = new ViewCommandPalletteWebviewViewProvider(extensionContext); | ||||
| 	extensionContext.subscriptions.push(vscode.window.registerWebviewViewProvider("view-command-Pallette-webview-view-provider", viewCommandPalletteWebviewViewProvider)); | ||||
|  | ||||
| 	const config = vscode.workspace.getConfiguration('calc'); | ||||
| 	const outputChannel = vscode.window.createOutputChannel('calc'); | ||||
|  | ||||
| 	const onError = (error: unknown) => { | ||||
| 		if (error instanceof Error) { | ||||
| 			outputChannel.appendLine(error.message); | ||||
| 			if (error.stack) outputChannel.appendLine(error.stack); | ||||
| 		} else { | ||||
| 			outputChannel.appendLine((error as any).toString().message); | ||||
| 		} | ||||
| 	}; | ||||
|  | ||||
| 	const calcProvider = new Calculator.CalcProvider(config, onError); | ||||
|  | ||||
| 	extensionContext.subscriptions.push( | ||||
| 		vscode.languages.registerCompletionItemProvider('*', calcProvider, '=', ' '), | ||||
| 		vscode.workspace.onDidOpenTextDocument(() => { | ||||
| 			calcProvider.clearHighlight().catch(onError); | ||||
| 		}), | ||||
| 		vscode.window.onDidChangeTextEditorSelection(() => { | ||||
| 			calcProvider.clearHighlight().catch(onError); | ||||
| 		}), | ||||
| 	); | ||||
|  | ||||
| 	function getWebviewView(title: string) { | ||||
| 		const column = vscode.window.activeTextEditor | ||||
| 			? vscode.window.activeTextEditor.viewColumn | ||||
| 			: undefined; | ||||
|  | ||||
| 		// Otherwise, create a new panel. | ||||
| 		const webviewView = vscode.window.createWebviewPanel( | ||||
| 			"web-view-panel", | ||||
| 			title, | ||||
| 			column || vscode.ViewColumn.One, | ||||
| 			{ | ||||
| 				// Enable javascript in the webview | ||||
| 				enableScripts: true, | ||||
|  | ||||
| 				// And restrict the webview to only loading content from our extension's `media` directory. | ||||
| 				localResourceRoots: [ | ||||
| 					vscode.Uri.joinPath(extensionContext.extensionUri, "media"), | ||||
| 					vscode.Uri.joinPath(extensionContext.extensionUri, "out/compiled"), | ||||
| 				], | ||||
| 			} | ||||
| 		); | ||||
| 		return webviewView; | ||||
| 	} | ||||
|  | ||||
| 	async function replaceResultsWithPositions( | ||||
| 		editor: vscode.TextEditor, | ||||
| 		positionsAndExpressions: [vscode.Position, string][], | ||||
| 		mode: 'append' | 'replace', | ||||
| 	) { | ||||
| 		await editor.edit((editBuilder) => { | ||||
| 			for (const [position, expression] of positionsAndExpressions) { | ||||
| 				const lineCalcResult = calcProvider.calculateLine(position, expression); | ||||
| 				if (lineCalcResult == null) { | ||||
| 					continue; | ||||
| 				} | ||||
| 				const { insertText, expressionWithEqualSignRange, expressionEndRange } = | ||||
| 					lineCalcResult; | ||||
|  | ||||
| 				if (mode === 'append') { | ||||
| 					const endWithEqual = expression.trimEnd().endsWith('='); | ||||
| 					editBuilder.replace( | ||||
| 						expressionEndRange, | ||||
| 						endWithEqual ? insertText : ` = ${insertText}`, | ||||
| 					); | ||||
| 				} else if (mode === 'replace') { | ||||
| 					editBuilder.replace(expressionWithEqualSignRange, insertText); | ||||
| 				} | ||||
| 			} | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	async function replaceResult( | ||||
| 		mode: 'append' | 'replace', | ||||
| 		withCursor: boolean, | ||||
| 	) { | ||||
| 		const editor = vscode.window.activeTextEditor; | ||||
| 		if (!editor || !editor.selection.isEmpty) { | ||||
| 			return; | ||||
| 		} | ||||
| 		const doc = editor.document; | ||||
|  | ||||
| 		let positionsAndExpressions; | ||||
| 		if (withCursor) { | ||||
| 			positionsAndExpressions = editor.selections.map( | ||||
| 				(selection) => | ||||
| 					<[vscode.Position, string]>[ | ||||
| 						selection.active, | ||||
| 						doc | ||||
| 							.lineAt(selection.active.line) | ||||
| 							.text.slice(0, selection.active.character), | ||||
| 					], | ||||
| 			); | ||||
| 		} else { | ||||
| 			const uniqueLineNumbers = [ | ||||
| 				...new Set(editor.selections.map((selection) => selection.active.line)), | ||||
| 			]; | ||||
| 			positionsAndExpressions = uniqueLineNumbers.map((number) => { | ||||
| 				const line = doc.lineAt(number); | ||||
| 				return <[vscode.Position, string]>[line.range.end, line.text]; | ||||
| 			}); | ||||
| 		} | ||||
| 		await replaceResultsWithPositions(editor, positionsAndExpressions, mode); | ||||
| 	} | ||||
|  | ||||
| 	extensionContext.subscriptions.push( | ||||
| 		vscode.commands.registerTextEditorCommand('extension.calcAppendWithCursor', () => { | ||||
| 			replaceResult('append', true).catch(onError); | ||||
| 		}), | ||||
| 		vscode.commands.registerTextEditorCommand('extension.calcAppend', () => { | ||||
| 			replaceResult('append', false).catch(onError); | ||||
| 		}), | ||||
| 		vscode.commands.registerTextEditorCommand( | ||||
| 			'extension.calcReplaceWithCursor', | ||||
| 			() => { | ||||
| 				replaceResult('replace', true).catch(onError); | ||||
| 			}, | ||||
| 		), | ||||
| 		vscode.commands.registerTextEditorCommand('extension.calcReplace', () => { | ||||
| 			replaceResult('replace', false).catch(onError); | ||||
| 		}), | ||||
| 	); | ||||
|  | ||||
| 	const commands = [ | ||||
| 		vscode.commands.registerCommand("copyHelper.copySyntaxInLight", copyHelper.copySyntaxInLight), | ||||
| 		vscode.commands.registerCommand("extension.rotateExplorerSortOrder", settingsHelper.rotateExplorerSortOrder), | ||||
| 		vscode.commands.registerCommand("kanban.openWithTextEditor", kanbanHelper.openWithTextEditor), | ||||
| 		vscode.commands.registerCommand("kanban.openInNewWindow", kanbanHelper.openInNewWindow), | ||||
| 		vscode.commands.registerCommand("markdown.newMarkdownFile", markdownHelper.newMarkdownFile), | ||||
| 		vscode.commands.registerCommand('promiseLinesHelper.codeGeneratorQuickPick', promiseLinesHelper.codeGeneratorQuickPick), | ||||
| 		vscode.commands.registerCommand('promiseLinesHelper.insertDateTime', promiseLinesHelper.insertDateTime), | ||||
| 		vscode.commands.registerCommand("promiseLinesHelper.insertAllExtensions", promiseLinesHelper.insertAllExtensions), | ||||
| 		vscode.commands.registerCommand('promiseLinesHelper.transformToProperCase', promiseLinesHelper.transformToProperCase), | ||||
| 		vscode.commands.registerCommand('promiseLinesHelper.transformToParamCase', promiseLinesHelper.transformToParamCase), | ||||
| 		vscode.commands.registerCommand('readOnlyLinesHelper.searchGoogle', readOnlyLinesHelper.searchGoogle), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.addCSharpComment', replaceLinesHelper.addCSharpComment), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.addVBComment', replaceLinesHelper.addVBComment), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.convertToRegularExpression', replaceLinesHelper.convertToRegularExpression), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.cutEachLine', replaceLinesHelper.cutEachLine), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.distinctLines', replaceLinesHelper.distinctLines), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.expandSql', replaceLinesHelper.expandSql), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.listToListFamily', replaceLinesHelper.listToListFamily), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.listToListWrappedComma', replaceLinesHelper.listToListWrappedComma), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.prettySql', replaceLinesHelper.prettySql), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.quickFixCamelCaseProperties', replaceLinesHelper.quickFixCamelCaseProperties), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.quickFixCS0108', replaceLinesHelper.quickFixCS0108), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.quickFixInstanceFieldToCalisthenics', replaceLinesHelper.quickFixInstanceFieldToCalisthenics), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.quickFixProperCaseProperties', replaceLinesHelper.quickFixProperCaseProperties), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.quickFixPublic', replaceLinesHelper.quickFixPublic), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.removeComment', replaceLinesHelper.removeComment), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.removeJsonNullValues', replaceLinesHelper.removeJsonNullValues), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.removeLinesContainingHighlighted', replaceLinesHelper.removeLinesContainingHighlighted), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.sortLength', replaceLinesHelper.sortLength), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.sortNormal', replaceLinesHelper.sortNormal), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.splitBySpaceReverseJoinSort', replaceLinesHelper.splitBySpaceReverseJoinSort), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.unwrapSql', replaceLinesHelper.unwrapSql), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.wrapSqlCSharp', replaceLinesHelper.wrapSqlCSharp), | ||||
| 		vscode.commands.registerCommand('replaceLinesHelper.wrapSqlVB', replaceLinesHelper.wrapSqlVB), | ||||
| 		vscode.commands.registerCommand("webview.fileSync", () => { WebviewPanelFileSync.WebviewPanelFileSync.createOrShow(extensionContext, 'File-Sync'); }), | ||||
| 		vscode.commands.registerCommand("webview.backlogMesa", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'MES', 'HTML'); }), | ||||
| 		vscode.commands.registerCommand("webview.costOfDelayMesa", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'MES', ''); }), | ||||
| 		vscode.commands.registerCommand("webview.costOfDelayEffortMesa", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'MES', 'EFFORT'); }), | ||||
| 		vscode.commands.registerCommand("webview.costOfDelayLiveMesa", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'MES', 'LIVE'); }), | ||||
| 		vscode.commands.registerCommand("webview.costOfDelayWSJFMesa", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'MES', 'WSJF'); }), | ||||
| 		vscode.commands.registerCommand("webview.backlogLeominster", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'LEO', 'HTML'); }), | ||||
| 		vscode.commands.registerCommand("webview.costOfDelayLeominster", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'LEO', ''); }), | ||||
| 		vscode.commands.registerCommand("webview.costOfDelayEffortLeominster", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'LEO', 'EFFORT'); }), | ||||
| 		vscode.commands.registerCommand("webview.costOfDelayLiveLeominster", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'LEO', 'LIVE'); }), | ||||
| 		vscode.commands.registerCommand("webview.costOfDelayWSJFLeominster", () => { WebviewPanelCostOfDelay.WebviewPanelCostOfDelay.createOrShow(extensionContext, 'LEO', 'WSJF'); }), | ||||
| 		vscode.commands.registerCommand("webview.example", () => { WebviewPanelExample.WebviewPanelExample.createOrShow(extensionContext); }) | ||||
| 	]; | ||||
|  | ||||
| 	commands.forEach(command => extensionContext.subscriptions.push(command)); | ||||
| } | ||||
|  | ||||
| // This method is called when your extension is deactivated | ||||
| export function deactivate() { } | ||||
							
								
								
									
										9
									
								
								type-script-helper/src/getNonce.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								type-script-helper/src/getNonce.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,9 @@ | ||||
| export function getNonce() { | ||||
|   let text = ""; | ||||
|   const possible = | ||||
|     "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; | ||||
|   for (let i = 0; i < 32; i++) { | ||||
|     text += possible.charAt(Math.floor(Math.random() * possible.length)); | ||||
|   } | ||||
|   return text; | ||||
| } | ||||
							
								
								
									
										126
									
								
								type-script-helper/src/kanbanHelper.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								type-script-helper/src/kanbanHelper.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,126 @@ | ||||
| import * as vscode from 'vscode'; | ||||
| import { paramCase } from './promiseLinesHelper'; | ||||
|  | ||||
| async function updateWithLogic(textDocument: vscode.TextDocument) { | ||||
|     await vscode.window.showTextDocument(textDocument); | ||||
|     const textEditor = vscode.window.activeTextEditor; | ||||
|     if (!textEditor) { | ||||
|         return undefined; | ||||
|     } | ||||
|     const now: Date = new Date(); | ||||
|     const time: number = now.getTime(); | ||||
|     const year: number = now.getFullYear(); | ||||
|     const start: Date = new Date(year, 0, 0); | ||||
|     const oneDay: number = 1000 * 60 * 60 * 24; | ||||
|     const timezoneOffset: number = now.getTimezoneOffset(); | ||||
|     let segments: string[] = textDocument.fileName.split('\\'); | ||||
|     const diff: number = (time - start.getTime()) + ((start.getTimezoneOffset() - timezoneOffset) * 60 * 1000); | ||||
|     const day: number = Math.floor(diff / oneDay); | ||||
|     const seconds: number = time.valueOf() + timezoneOffset; | ||||
|     let notLastThree: string[] = segments.slice(0, -3); | ||||
|     let season: string = year + "-"; | ||||
|     if (day < 78) { | ||||
|         season += "0.Winter"; | ||||
|     } else if (day < 124) { | ||||
|         season += "1.Spring"; | ||||
|     } else if (day < 171) { | ||||
|         season += "2.Spring"; | ||||
|     } else if (day < 217) { | ||||
|         season += "3.Summer"; | ||||
|     } else if (day < 264) { | ||||
|         season += "4.Summer"; | ||||
|     } else if (day < 309) { | ||||
|         season += "5.Fall"; | ||||
|     } else if (day < 354) { | ||||
|         season += "6.Fall"; | ||||
|     } else { | ||||
|         season += "7.Winter"; | ||||
|     } | ||||
|     let path: string = notLastThree.join('\\') + `\\${year}\\${season}\\${seconds}`; | ||||
|     const uri = vscode.Uri.parse(path); | ||||
|     textEditor.edit(editBuilder => { | ||||
|         let text: string = `\r\n## Code Insiders\r\n\r\n- [code-insiders](${path})\r\n\r\n## Sub-tasks\r\n\r\n- [ ] To do`; | ||||
|         let position: vscode.Position = new vscode.Position(textDocument.lineCount, 0); | ||||
|         editBuilder.insert(position, text); | ||||
|     }); | ||||
| } | ||||
|  | ||||
| async function openInNewWindowLogic(): Promise<any> { | ||||
|     if (vscode.workspace.workspaceFolders === undefined) { | ||||
|         vscode.window.showInformationMessage("Open workspace first!"); | ||||
|         return; | ||||
|     } | ||||
|     if (vscode.window.tabGroups.activeTabGroup.activeTab === undefined) { | ||||
|         vscode.window.showInformationMessage("Open a tab first!"); | ||||
|         return; | ||||
|     } | ||||
|     const activeTab = vscode.window.tabGroups.activeTabGroup.activeTab; | ||||
|     const tabs: vscode.Tab[] = vscode.window.tabGroups.all.map(tagGroup => tagGroup.tabs).flat(); | ||||
|     const index = tabs.findIndex(tab => tab.label === activeTab.label); | ||||
|     const paramCaseActiveTabLabel: string = paramCase(activeTab.label); | ||||
|     vscode.window.showInformationMessage(`Searching for <${paramCaseActiveTabLabel}>`); | ||||
|     const fileUris: vscode.Uri[] = await vscode.workspace.findFiles(`**/${paramCaseActiveTabLabel}*`); | ||||
|     if (fileUris.length === 0) { | ||||
|         vscode.window.showInformationMessage(`Didn't find a file matching <${paramCaseActiveTabLabel}>!`); | ||||
|         return; | ||||
|     } | ||||
|     for (let i = 0; i < fileUris.length; ++i) { | ||||
|         let found: boolean = false; | ||||
|         const textDocument: vscode.TextDocument = await vscode.workspace.openTextDocument(fileUris[i]); | ||||
|         for (let j = 0; j < textDocument.lineCount; ++j) { | ||||
|             const text = textDocument.lineAt(j).text; | ||||
|             if (text.endsWith(')')) { | ||||
|                 if (text.startsWith("- [code](")) { | ||||
|                     found = true; | ||||
|                     const uri = vscode.Uri.parse("file:" + text.substring(9, text.length - 1)); | ||||
|                     await vscode.commands.executeCommand('vscode.openFolder', uri, true); | ||||
|                     break; | ||||
|                 } | ||||
|                 if (text.startsWith("- [codium](")) { | ||||
|                     found = true; | ||||
|                     const uri = vscode.Uri.parse("file:" + text.substring(11, text.length - 1)); | ||||
|                     await vscode.commands.executeCommand('vscode.openFolder', uri, true); | ||||
|                     break; | ||||
|                 } | ||||
|                 if (text.startsWith("- [code-insiders](")) { | ||||
|                     found = true; | ||||
|                     const uri = vscode.Uri.parse("file:" + text.substring(18, text.length - 1)); | ||||
|                     await vscode.commands.executeCommand('vscode.openFolder', uri, true); | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (!found) { | ||||
|             updateWithLogic(textDocument); | ||||
|         } | ||||
|         else if (index !== -1) { | ||||
|             await vscode.window.tabGroups.close(tabs[index]); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| async function openWithTextEditorLogic(): Promise<any> { | ||||
|     if (vscode.workspace.workspaceFolders === undefined) { | ||||
|         vscode.window.showInformationMessage("Open workspace first!"); | ||||
|         return; | ||||
|     } | ||||
|     if (vscode.window.tabGroups.activeTabGroup.activeTab === undefined) { | ||||
|         vscode.window.showInformationMessage("Open a tab first!"); | ||||
|         return; | ||||
|     } | ||||
|     const activeTabLabel = vscode.window.tabGroups.activeTabGroup.activeTab.label; | ||||
|     const paramCaseActiveTabLabel: string = paramCase(activeTabLabel); | ||||
|     vscode.window.showInformationMessage(`Searching for <${paramCaseActiveTabLabel}>`); | ||||
|     const fileUris: vscode.Uri[] = await vscode.workspace.findFiles(`**/${paramCaseActiveTabLabel}*`); | ||||
|     if (fileUris.length === 0) { | ||||
|         vscode.window.showInformationMessage(`Didn't find a file matching <${paramCaseActiveTabLabel}>!`); | ||||
|         return; | ||||
|     } | ||||
|     for (let i = 0; i < fileUris.length; ++i) { | ||||
|         const textDocument: vscode.TextDocument = await vscode.workspace.openTextDocument(fileUris[i]); | ||||
|         await vscode.window.showTextDocument(textDocument); | ||||
|     } | ||||
| } | ||||
|  | ||||
| export const openInNewWindow = () => openInNewWindowLogic(); | ||||
| export const openWithTextEditor = () => openWithTextEditorLogic(); | ||||
							
								
								
									
										22
									
								
								type-script-helper/src/markdownHelper.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								type-script-helper/src/markdownHelper.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import * as vscode from 'vscode'; | ||||
| import { paramCase } from './promiseLinesHelper'; | ||||
|  | ||||
| async function newMarkdownFileLogic(): Promise<any> { | ||||
|     console.log(vscode.window.tabGroups.activeTabGroup.activeTab?.label); | ||||
|     if (vscode.workspace.workspaceFolders === undefined) { | ||||
|         vscode.window.showInformationMessage("Open workspace first!"); | ||||
|         return; | ||||
|     } | ||||
|     const workspaceFoldersZero = vscode.workspace.workspaceFolders[0].uri; | ||||
|     const cardTitle = await vscode.window.showInputBox({ prompt: 'Provide title for card.' }); | ||||
|     if (cardTitle === undefined) | ||||
|         return; | ||||
|     const paramCaseCardTitle: string = paramCase(cardTitle); | ||||
|     const fileUri: vscode.Uri = vscode.Uri.joinPath(workspaceFoldersZero, `${paramCaseCardTitle}.md`); | ||||
|     const buffer: Buffer = Buffer.from(`# ${cardTitle}`, 'utf8'); | ||||
|     await vscode.workspace.fs.writeFile(fileUri, buffer); | ||||
|     const textDocument: vscode.TextDocument = await vscode.workspace.openTextDocument(fileUri); | ||||
|     vscode.window.showTextDocument(textDocument); | ||||
| } | ||||
|  | ||||
| export const newMarkdownFile = () => newMarkdownFileLogic(); | ||||
							
								
								
									
										266
									
								
								type-script-helper/src/promiseLinesHelper.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										266
									
								
								type-script-helper/src/promiseLinesHelper.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,266 @@ | ||||
| import * as vscode from 'vscode'; | ||||
|  | ||||
| function codeGeneratorQuickPickLogic(): undefined { | ||||
|     const textEditor = vscode.window.activeTextEditor; | ||||
|     if (!textEditor) { | ||||
|         return undefined; | ||||
|     } | ||||
|     let thenable = vscode.window.showQuickPick( | ||||
|         [ | ||||
|             { | ||||
|                 label: "Class name", | ||||
|                 detail: "Segments Minus One (Object || Array)", | ||||
|                 output: "%ClassName%" | ||||
|             }, { | ||||
|                 label: "Class name (Camel-Cased)", | ||||
|                 detail: "Segments Minus One (Object || Array)", | ||||
|                 output: "%ClassNameCamelCased%" | ||||
|             }, { | ||||
|                 label: "Class name (Camel-Cased and Plural)", | ||||
|                 detail: "Segments Minus One (Object || Array)", | ||||
|                 output: "%ClassNameCamelCasedPlural%" | ||||
|             }, { | ||||
|                 label: "Class name (Plural)", | ||||
|                 detail: "Segments Minus One (Object || Array)", | ||||
|                 output: "%ClassNamePlural%" | ||||
|             }, { | ||||
|                 label: "Key Without Brackets Segment at Level", | ||||
|                 detail: "", | ||||
|                 output: "%KeyWithoutBracketsSegmentAtLevel%" | ||||
|             }, { | ||||
|                 label: "Name", | ||||
|                 detail: "Segments Last only name (no path)", | ||||
|                 output: "%Name%" | ||||
|             }, { | ||||
|                 label: "Namespace", | ||||
|                 detail: "Namespace", | ||||
|                 output: "%namespace%" | ||||
|             }, { | ||||
|                 label: "Name (Camel-Cased)", | ||||
|                 detail: "Segments Last only name (no path)", | ||||
|                 output: "%NameCamelCased%" | ||||
|             }, { | ||||
|                 label: "Name (Camel-Cased and Plural)", | ||||
|                 detail: "Segments Last only name (no path)", | ||||
|                 output: "%NameCamelCasedPlural%" | ||||
|             }, { | ||||
|                 label: "Name Detail", | ||||
|                 detail: "", | ||||
|                 output: "%NameDetail%" | ||||
|             }, { | ||||
|                 label: "Name Detail (Camel-Cased)", | ||||
|                 detail: "", | ||||
|                 output: "%NameDetailCamelCased%" | ||||
|             }, { | ||||
|                 label: "Name Detail (Humanized)", | ||||
|                 detail: "", | ||||
|                 output: "%NameDetailHumanized%" | ||||
|             }, { | ||||
|                 label: "Name Detail (Humanized) *Collection", | ||||
|                 detail: "", | ||||
|                 output: "%NameDetailHumanizedCollection%" | ||||
|             }, { | ||||
|                 label: "Name (Humanized)", | ||||
|                 detail: "Segments Last only name (no path)", | ||||
|                 output: "%NameHumanized%" | ||||
|             }, { | ||||
|                 label: "Name (Null Segments)", | ||||
|                 detail: "", | ||||
|                 output: "%NameNullSegments%" | ||||
|             }, { | ||||
|                 label: "Name (Null Segments) *Collection", | ||||
|                 detail: "", | ||||
|                 output: "%NameNullSegmentsCollection%" | ||||
|             }, { | ||||
|                 label: "Name (Plural)", | ||||
|                 detail: "Segments Last only name (no path)", | ||||
|                 output: "%NamePlural%" | ||||
|             }, { | ||||
|                 label: "Name Segments", | ||||
|                 detail: "", | ||||
|                 output: "%NameSegments%" | ||||
|             }, { | ||||
|                 label: "Name Segments *Collection", | ||||
|                 detail: "", | ||||
|                 output: "%NameSegmentsCollection%" | ||||
|             }, { | ||||
|                 label: "Path without Brackets (Singularized)", | ||||
|                 detail: "", | ||||
|                 output: "%PathWithoutBracketsSingularized%" | ||||
|             }, { | ||||
|                 label: "Suggested Type", | ||||
|                 detail: "Type based on values in *.json file", | ||||
|                 output: "%SuggestedType%" | ||||
|             }, { | ||||
|                 label: "Suggested Type Id", | ||||
|                 detail: "", | ||||
|                 output: "%SuggestedTypeId%" | ||||
|             }, { | ||||
|                 label: "Suggested Type Id (Camel-Cased)", | ||||
|                 detail: "", | ||||
|                 output: "%SuggestedTypeIdCamelCased%" | ||||
|             }, { | ||||
|                 label: "Type", | ||||
|                 detail: "Segments Minus One (!Object && !Array)", | ||||
|                 output: "%Type%" | ||||
|             }, { | ||||
|                 label: "Type (Camel-Cased)", | ||||
|                 detail: "Segments Minus One (!Object && !Array)", | ||||
|                 output: "%TypeCamelCased%" | ||||
|             } | ||||
|         ] | ||||
|     ).then(item => { | ||||
|         if (!item) { | ||||
|             return; | ||||
|         } | ||||
|         const selection = textEditor.selection; | ||||
|         return textEditor.edit(editBuilder => { | ||||
|             var range; | ||||
|             if (selection.isEmpty) { | ||||
|                 editBuilder.insert(selection.start, item.output) | ||||
|             } | ||||
|             else { | ||||
|                 range = new vscode.Range(selection.start.line, selection.start.character, selection.end.line, selection.end.character); | ||||
|                 editBuilder.replace(range, item.output); | ||||
|             } | ||||
|         }); | ||||
|     }); | ||||
|     return undefined; | ||||
| } | ||||
|  | ||||
| function insertDateTimeLogic(): undefined { | ||||
|     const textEditor = vscode.window.activeTextEditor; | ||||
|     if (!textEditor) { | ||||
|         return undefined; | ||||
|     } | ||||
|     const selection = textEditor.selection; | ||||
|     textEditor.edit(editBuilder => { | ||||
|         var range; | ||||
|         const now: Date = new Date(); | ||||
|         const time: number = now.getTime(); | ||||
|         const year: number = now.getFullYear(); | ||||
|         const start: Date = new Date(year, 0, 0); | ||||
|         const oneDay: number = 1000 * 60 * 60 * 24; | ||||
|         const timezoneOffset: number = now.getTimezoneOffset(); | ||||
|         const diff: number = (time - start.getTime()) + ((start.getTimezoneOffset() - timezoneOffset) * 60 * 1000); | ||||
|         const seconds: number = time.valueOf() + timezoneOffset; | ||||
|         const day: number = Math.floor(diff / oneDay); | ||||
|         const epoch: number = seconds * 10000; | ||||
|         const ticks: number = epoch + 621355968000000000; | ||||
|         let season: string = year + "-"; | ||||
|         if (day < 78) { | ||||
|             season += "0.Winter"; | ||||
|         } else if (day < 124) { | ||||
|             season += "1.Spring"; | ||||
|         } else if (day < 171) { | ||||
|             season += "2.Spring"; | ||||
|         } else if (day < 217) { | ||||
|             season += "3.Summer"; | ||||
|         } else if (day < 264) { | ||||
|             season += "4.Summer"; | ||||
|         } else if (day < 309) { | ||||
|             season += "5.Fall"; | ||||
|         } else if (day < 354) { | ||||
|             season += "6.Fall"; | ||||
|         } else { | ||||
|             season += "7.Winter"; | ||||
|         } | ||||
|         const dateText = seconds + " = " + ticks + " = " + season + " = " + now.toString(); | ||||
|         if (selection.isEmpty) { | ||||
|             editBuilder.insert(selection.start, dateText) | ||||
|         } | ||||
|         else { | ||||
|             range = new vscode.Range(selection.start.line, selection.start.character, selection.end.line, selection.end.character); | ||||
|             editBuilder.replace(range, dateText); | ||||
|         } | ||||
|     }); | ||||
|     return undefined; | ||||
| } | ||||
|  | ||||
| function insertAllExtensionsLogic(): undefined { | ||||
|     const textEditor = vscode.window.activeTextEditor; | ||||
|     if (!textEditor) { | ||||
|         return undefined; | ||||
|     } | ||||
|     const selection = textEditor.selection; | ||||
|     textEditor.edit(editBuilder => { | ||||
|         var range; | ||||
|         let extensions = vscode.extensions.all; | ||||
|         let text = extensions.map(extension => extension.id).join("\n"); | ||||
|         if (selection.isEmpty) { | ||||
|             editBuilder.insert(selection.start, text) | ||||
|         } | ||||
|         else { | ||||
|             range = new vscode.Range(selection.start.line, selection.start.character, selection.end.line, selection.end.character); | ||||
|             editBuilder.replace(range, text); | ||||
|         } | ||||
|     }); | ||||
|     return undefined; | ||||
| } | ||||
|  | ||||
| function camelCase(str: string) { | ||||
|     return str.replace(/(?:^\w|[A-Z]|\b\w|\s+)/g, function (match, index) { | ||||
|         if (+match === 0) return ""; | ||||
|         return index === 0 ? match.toLowerCase() : match.toUpperCase(); | ||||
|     }); | ||||
| } | ||||
|  | ||||
| function transformToProperCaseLogic(): undefined { | ||||
|     const textEditor = vscode.window.activeTextEditor; | ||||
|     if (!textEditor) { | ||||
|         return undefined; | ||||
|     } | ||||
|     const selection = textEditor.selection; | ||||
|     textEditor.edit(editBuilder => { | ||||
|         var range; | ||||
|         if (selection.isEmpty) { | ||||
|             return undefined; | ||||
|         } | ||||
|         else { | ||||
|             range = new vscode.Range(selection.start.line, selection.start.character, selection.end.line, selection.end.character); | ||||
|             const highlighted = textEditor.document.getText(range); | ||||
|             let camelCased = camelCase(highlighted); | ||||
|             let properCased = camelCased.substring(0, 1).toUpperCase() + camelCased.substring(1, camelCased.length); | ||||
|             editBuilder.replace(range, properCased); | ||||
|         } | ||||
|     }); | ||||
|     return undefined; | ||||
| } | ||||
|  | ||||
| export function paramCase(str: string) { | ||||
|     return str | ||||
|         .replace( | ||||
|             /([A-Z]+(.))/g, | ||||
|             (_, separator, letter, offset) => (offset ? "-" + separator : separator).toLowerCase() | ||||
|         ) | ||||
|         .split(/[\s!?.,@:;|\\/"'`£$%\^&*{}[\]()<>~#+\-=_¬]+/g) | ||||
|         .join('-') | ||||
|         .replace(/(^-|-$)/g, ''); | ||||
| }; | ||||
|  | ||||
| function transformToParamCaseLogic(): undefined { | ||||
|     const textEditor = vscode.window.activeTextEditor; | ||||
|     if (!textEditor) { | ||||
|         return undefined; | ||||
|     } | ||||
|     const selection = textEditor.selection; | ||||
|     textEditor.edit(editBuilder => { | ||||
|         var range; | ||||
|         if (selection.isEmpty) { | ||||
|             return undefined; | ||||
|         } | ||||
|         else { | ||||
|             range = new vscode.Range(selection.start.line, selection.start.character, selection.end.line, selection.end.character); | ||||
|             const highlighted = textEditor.document.getText(range); | ||||
|             let paramCased = paramCase(highlighted); | ||||
|             editBuilder.replace(range, paramCased); | ||||
|         } | ||||
|     }); | ||||
|     return undefined; | ||||
| } | ||||
|  | ||||
| export const codeGeneratorQuickPick = () => codeGeneratorQuickPickLogic(); | ||||
| export const insertDateTime = () => insertDateTimeLogic(); | ||||
| export const insertAllExtensions = () => insertAllExtensionsLogic(); | ||||
| export const transformToProperCase = () => transformToProperCaseLogic(); | ||||
| export const transformToParamCase = () => transformToParamCaseLogic(); | ||||
							
								
								
									
										55
									
								
								type-script-helper/src/readOnlyLinesHelper.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								type-script-helper/src/readOnlyLinesHelper.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | ||||
| import * as vscode from 'vscode'; | ||||
|  | ||||
| enum LinesAction { | ||||
|     searchGoogle | ||||
| } | ||||
|  | ||||
| function searchGoogleLogic(text: string, lines: string[]): void { | ||||
|     let searchText: string = ''; | ||||
|     if (text.length > 0) { | ||||
|         searchText = text.trim(); | ||||
|     } | ||||
|     else if (lines.length > 0) { | ||||
|         searchText = lines[0].trim(); | ||||
|     } | ||||
|     else | ||||
|         return undefined; | ||||
|     if (searchText != '') { | ||||
|         vscode.env.openExternal( | ||||
|             vscode.Uri.parse(`https://www.google.com/search?q=${lines[0].trim()}`) | ||||
|         ) | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getLines(textEditor: vscode.TextEditor, startLine: number, endLine: number) { | ||||
|     let results: string[] = []; | ||||
|     for (let i = startLine; i <= endLine; i++) { | ||||
|         results.push(textEditor.document.lineAt(i).text); | ||||
|     } | ||||
|     return results; | ||||
| } | ||||
|  | ||||
| function linesFunction(linesAction: LinesAction): Thenable<boolean> | undefined { | ||||
|     const textEditor = vscode.window.activeTextEditor; | ||||
|     if (!textEditor) { | ||||
|         return undefined; | ||||
|     } | ||||
|     let text = ''; | ||||
|     var startLine = 0; | ||||
|     var endLine = textEditor.document.lineCount - 1; | ||||
|     const selection = textEditor.selection; | ||||
|     if (!selection.isEmpty) { | ||||
|         startLine = selection.start.line; | ||||
|         endLine = selection.end.line; | ||||
|         let range = new vscode.Range(selection.start, selection.end) | ||||
|         text = textEditor.document.getText(range); | ||||
|     } | ||||
|     let lines: string[] = getLines(textEditor, startLine, endLine); | ||||
|     switch (linesAction) { | ||||
|         case LinesAction.searchGoogle: { searchGoogleLogic(text, lines); break; } | ||||
|         default: { throw new Error(); } | ||||
|     } | ||||
|     return undefined; | ||||
| } | ||||
|  | ||||
| export const searchGoogle = () => linesFunction(LinesAction.searchGoogle); | ||||
							
								
								
									
										484
									
								
								type-script-helper/src/replaceLinesHelper.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										484
									
								
								type-script-helper/src/replaceLinesHelper.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,484 @@ | ||||
| import * as vscode from 'vscode'; | ||||
|  | ||||
| type ArrayTransformer = (lines: string[]) => string[]; | ||||
| type SortingAlgorithm = (a: string, b: string) => number; | ||||
|  | ||||
| enum LinesAction { | ||||
|     addCSharpComment, | ||||
|     addVBComment, | ||||
|     convertToRegularExpression, | ||||
|     cutEachLine, | ||||
|     distinctLines, | ||||
|     expandSql, | ||||
|     listToListFamily, | ||||
|     listToListWrappedComma, | ||||
|     prettySql, | ||||
|     quickFixCamelCaseProperties, | ||||
|     quickFixCS0108, | ||||
|     quickFixInstanceFieldToCalisthenics, | ||||
|     quickFixProperCaseProperties, | ||||
|     quickFixPublic, | ||||
|     pdsfToFixedWidth, | ||||
|     removeComment, | ||||
|     removeJsonNullValues, | ||||
|     removeLinesContainingHighlighted, | ||||
|     sortLength, | ||||
|     sortNormal, | ||||
|     splitBySpaceReverseJoinSort, | ||||
|     unwrapSql, | ||||
|     wrapSqlCSharp, | ||||
|     wrapSqlVB | ||||
| } | ||||
|  | ||||
| function removeBlanks(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         if (lines[i].trim() === '') { | ||||
|             lines.splice(i, 1); | ||||
|             i--; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| function getLines(textEditor: vscode.TextEditor, startLine: number, endLine: number) { | ||||
|     let results: string[] = []; | ||||
|     for (let i = startLine; i <= endLine; i++) { | ||||
|         results.push(textEditor.document.lineAt(i).text); | ||||
|     } | ||||
|     return results; | ||||
| } | ||||
|  | ||||
| function addCSharpCommentLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = '//' + lines[i].trim(); | ||||
|     } | ||||
| } | ||||
|  | ||||
| function addVBCommentLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = "'" + lines[i].trim(); | ||||
|     } | ||||
| } | ||||
|  | ||||
| function convertToRegularExpressionLogic(lines: string[]): string[] { | ||||
|     let results: string[]; | ||||
|     let result: string = ""; | ||||
|     let explicitLines = 50; | ||||
|     for (let i = 0; i < lines.length - 1 && i < explicitLines; ++i) { | ||||
|         result = result + lines[i].trim(). | ||||
|             split('\\').join('\\\\'). | ||||
|             split('(').join('\\('). | ||||
|             split(')').join('\\)'). | ||||
|             split('[').join('\\['). | ||||
|             split(']').join('\\]'). | ||||
|             split('{').join('\\{'). | ||||
|             split('}').join('\\}'). | ||||
|             split('.').join('\\.'). | ||||
|             split('*').join('\\*'). | ||||
|             split('+').join('\\+'). | ||||
|             split('?').join('\\?'). | ||||
|             split('|').join('\\|'). | ||||
|             split('$').join('\\$'). | ||||
|             split('^').join('\\^') + | ||||
|             '~'; | ||||
|     } | ||||
|     for (let i = explicitLines; i < lines.length - 1; ++i) { | ||||
|         result = result + '.*~'; | ||||
|     } | ||||
|     result = result. | ||||
|         substring(0, result.length - 1). | ||||
|         split('~').join('\\r\\n\?\\s\*'); | ||||
|     results = [result]; | ||||
|     return results; | ||||
| } | ||||
|  | ||||
| function expandSqlLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = ' ' + lines[i]; | ||||
|         lines[i] = lines[i]. | ||||
|             split(' select ').join(' SELECT\r\n'). | ||||
|             split(' from ').join('\r\n FROM '). | ||||
|             split(' where ').join('\r\n WHERE '). | ||||
|             split(' and ').join('\r\n and '). | ||||
|             split(' join ').join('\r\n join '). | ||||
|             split(' left join ').join('\r\n left join '). | ||||
|             split(' on ').join('\r\n ON '). | ||||
|             split(' group by ').join('\r\n GROUP BY '). | ||||
|             split(' order by ').join('\r\n ORDER BY '). | ||||
|             split(' SELECT ').join(' SELECT\r\n'). | ||||
|             split(' FROM ').join('\r\n FROM '). | ||||
|             split(' WHERE ').join('\r\n WHERE '). | ||||
|             split(' AND ').join('\r\n AND '). | ||||
|             split(' JOIN ').join('\r\n JOIN '). | ||||
|             split(' LEFT JOIN ').join('\r\n LEFT JOIN '). | ||||
|             split(' ON ').join('\r\n ON '). | ||||
|             split(' GROUP BY ').join('\r\n GROUP BY '). | ||||
|             split(' ORDER BY ').join('\r\n ORDER BY '). | ||||
|             split('\r\n\r\n').join('\r\n'). | ||||
|             trim(); | ||||
|     } | ||||
|     removeBlanks(lines); | ||||
|     prettySqlLogic(lines); | ||||
| } | ||||
|  | ||||
| function listToListFamilyLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = "Kristy" + lines[i].trim() + "Mike" + lines[i].trim() + "Jason" + lines[i].trim() + "Mackenzie" + lines[i].trim() + "Logan" + lines[i].trim() + "Lilly" + lines[i].trim() + "Chelsea" + lines[i].trim() + "Piper" + lines[i].trim(); | ||||
|     } | ||||
| } | ||||
|  | ||||
| function listToListWrappedCommaLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = "'" + lines[i].trim() + "',"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function prettySqlLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = ' ' + lines[i]; | ||||
|         lines[i] = lines[i]. | ||||
|             split(' select ').join(' SELECT '). | ||||
|             split(' distinct ').join(' DISTINCT '). | ||||
|             split(' as ').join(' AS '). | ||||
|             split(' from ').join(' FROM '). | ||||
|             split(' where ').join(' WHERE '). | ||||
|             split(' and ').join(' AND '). | ||||
|             split(' join ').join(' JOIN '). | ||||
|             split(' left join ').join(' LEFT JOIN '). | ||||
|             split(' on ').join(' ON '). | ||||
|             split(' group by ').join(' GROUP BY '). | ||||
|             split(' order by ').join(' ORDER BY '). | ||||
|             split('\r\n\r\n').join('\r\n'). | ||||
|             trim(); | ||||
|     } | ||||
|     removeBlanks(lines); | ||||
| } | ||||
|  | ||||
| function camelCase(str: string) { | ||||
|     return str.replace(/(?:^\w|[A-Z]|\b\w|\s+)/g, function (match, index) { | ||||
|         if (+match === 0) return ""; | ||||
|         return index === 0 ? match.toLowerCase() : match.toUpperCase(); | ||||
|     }); | ||||
| } | ||||
|  | ||||
| function toCapitalizedWords(name: string) { | ||||
|     let words = name.match(/[A-Za-z][a-z]*|[0-9]+/g) || []; | ||||
|     return words.map(capitalize).join(" "); | ||||
| } | ||||
|  | ||||
| function capitalize(word: string) { | ||||
|     return word.charAt(0).toUpperCase() + word.substring(1); | ||||
| } | ||||
|  | ||||
| function quickFixCamelCasePropertiesLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         let segments = lines[i].trim().split(' '); | ||||
|         if (segments.length < 2 || segments.length > 3) | ||||
|             continue; | ||||
|         let leftPadding = lines[i].substring(0, lines[i].indexOf(segments[0])); | ||||
|         if (segments.length === 2) segments = ('protected ' + lines[i].trim()).split(' '); | ||||
|         let camelCased = camelCase(segments[2]); | ||||
|         lines[i] = leftPadding + segments[0] + ' ' + segments[1] + ' ' + camelCased; | ||||
|     } | ||||
|     removeBlanks(lines); | ||||
| } | ||||
|  | ||||
| function quickFixCS0108Logic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         let segments = lines[i].trim().split(' '); | ||||
|         if (segments.length < 2 || segments.length > 3) | ||||
|             continue; | ||||
|         let leftPadding = lines[i].substring(0, lines[i].indexOf(segments[0])); | ||||
|         if (segments.length === 2) segments = ('protected ' + lines[i].trim()).split(' '); | ||||
|         let camelCased = camelCase(segments[2]); | ||||
|         let properCased = camelCased.substring(0, 1).toUpperCase() + camelCased.substring(1, camelCased.length - 1); | ||||
|         let capitalizedWords = toCapitalizedWords(properCased); | ||||
|         lines[i] = leftPadding + '[Display(Name = "' + capitalizedWords + '"), Required] public new ' + segments[1] + ' ' + properCased + ' { get; set; }'; | ||||
|     } | ||||
|     removeBlanks(lines); | ||||
| } | ||||
|  | ||||
| function quickFixInstanceFieldToCalisthenicsLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         let segments = lines[i].trim().split(' '); | ||||
|         if (segments.length !== 2) | ||||
|             continue; | ||||
|         let leftPadding = lines[i].substring(0, lines[i].indexOf(segments[0])); | ||||
|         let type = segments[0]; | ||||
|         let name = segments[1].split(';')[0]; | ||||
|         let singularName = name; | ||||
|         if (name[name.length - 1] === 's') { | ||||
|             if (name[name.length - 2] === 'e') { | ||||
|                 if (name[name.length - 3] === 'i') { | ||||
|                     singularName = name.substring(0, singularName.length - 3) + 'y'; | ||||
|                 } | ||||
|                 else | ||||
|                     singularName = name.substring(0, singularName.length - 2); | ||||
|             } | ||||
|             else | ||||
|                 singularName = name.substring(0, singularName.length - 1); | ||||
|         } | ||||
|         segments = type.split('<'); | ||||
|         if (segments.length === 2) | ||||
|             lines[i] = leftPadding + 'public ' + segments[0] + '<' + singularName + '> ' + name + ' { get; } //' + segments[1].split('>')[0]; | ||||
|         else { | ||||
|             segments = type.split('['); | ||||
|             if (segments.length === 2) | ||||
|                 lines[i] = leftPadding + 'public ' + singularName + '[] ' + name + ' { get; } //' + segments[0]; | ||||
|             else | ||||
|                 lines[i] = leftPadding + 'public ' + singularName + ' ' + name + ' { get; } //' + type; | ||||
|         } | ||||
|     } | ||||
|     removeBlanks(lines); | ||||
| } | ||||
|  | ||||
| function quickFixProperCasePropertiesLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         let segments = lines[i].trim().split(' '); | ||||
|         if (segments.length < 2 || segments.length > 3) | ||||
|             continue; | ||||
|         let leftPadding = lines[i].substring(0, lines[i].indexOf(segments[0])); | ||||
|         if (segments.length === 2) segments = ('protected ' + lines[i].trim()).split(' '); | ||||
|         let camelCased = camelCase(segments[2]); | ||||
|         let properCased = camelCased.substring(0, 1).toUpperCase() + camelCased.substring(1, camelCased.length - 1); | ||||
|         lines[i] = leftPadding + segments[0] + ' ' + segments[1] + ' ' + properCased + ';'; | ||||
|     } | ||||
|     removeBlanks(lines); | ||||
| } | ||||
|  | ||||
| function quickFixPublicLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         let segments = lines[i].trim().split(' '); | ||||
|         if (segments.length < 2 || segments.length > 3) | ||||
|             continue; | ||||
|         let leftPadding = lines[i].substring(0, lines[i].indexOf(segments[0])); | ||||
|         if (segments.length === 2) segments = ('protected ' + lines[i].trim()).split(' '); | ||||
|         let camelCased = camelCase(segments[2]); | ||||
|         let properCased = camelCased.substring(0, 1).toUpperCase() + camelCased.substring(1, camelCased.length - 1); | ||||
|         lines[i] = leftPadding + 'public ' + segments[1] + ' ' + properCased + ' => ' + camelCased; | ||||
|     } | ||||
|     removeBlanks(lines); | ||||
| } | ||||
|  | ||||
| function removeCommentLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = lines[i].trim(); | ||||
|         if (lines[i].length > 1 && lines[i][0] === '/' && lines[i][1] === '/') { | ||||
|             lines[i] = lines[i].substr(2); | ||||
|         } | ||||
|         if (lines[i].length > 0 && lines[i][0] === "'") { | ||||
|             lines[i] = lines[i].substr(1); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| function removeJsonNullValuesLogic(lines: string[]): void { | ||||
|     let text = ': null,'; | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = lines[i].trim(); | ||||
|         if (text.length > 1 && lines[i].length > 1 && lines[i].includes(text)) { | ||||
|             lines[i] = ''; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| function removeLinesContainingHighlightedLogic(lines: string[], text: string): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = lines[i].trim(); | ||||
|         if (text.length > 1 && lines[i].length > 1 && lines[i].includes(text)) { | ||||
|             lines[i] = ''; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| function makeSorter(algorithm?: SortingAlgorithm): ArrayTransformer { | ||||
|     return function (lines: string[]): string[] { | ||||
|         return lines.sort(algorithm); | ||||
|     }; | ||||
| } | ||||
|  | ||||
| function sortNormalLogic(lines: string[]): void { | ||||
|     var transformers: ArrayTransformer[] = []; | ||||
|     transformers.push(makeSorter()); | ||||
|  | ||||
|     removeBlanks(lines); | ||||
|  | ||||
|     lines = transformers.reduce((currentLines, transform) => transform(currentLines), lines); | ||||
| } | ||||
|  | ||||
| function splitBySpaceReverseJoinSortLogic(lines: string[]): void { | ||||
|     var transformers: ArrayTransformer[] = []; | ||||
|     transformers.push(makeSorter()); | ||||
|  | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = lines[i].split(' ').reverse().join(' '); | ||||
|     } | ||||
|  | ||||
|     removeBlanks(lines); | ||||
|  | ||||
|     lines = transformers.reduce((currentLines, transform) => transform(currentLines), lines); | ||||
|  | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = lines[i].split(' ').reverse().join(' '); | ||||
|     } | ||||
| } | ||||
|  | ||||
| function unwrapSqlLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = "//" + lines[i]. | ||||
|             split('sql = "').join(''). | ||||
|             split('sql = sql & "').join(''). | ||||
|             split('sql.Append("').join(''). | ||||
|             split('.Append("').join(''). | ||||
|             split('Append("').join(''). | ||||
|             split('");').join(''). | ||||
|             split('").').join(''). | ||||
|             split('")').join(''). | ||||
|             split('" & ').join('$'). | ||||
|             split(' & "').join('$'). | ||||
|             split('"').join(''). | ||||
|             trim(); | ||||
|     } | ||||
| } | ||||
|  | ||||
| function wrapSqlCSharpLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = lines[i].trim(); | ||||
|         if (lines[i].length > 1 && lines[i][0] === '/' && lines[i][1] === '/') { | ||||
|             lines[i] = lines[i].substr(2); | ||||
|         } | ||||
|         lines[i] = 'Append(" ' + lines[i] + ' ").'; | ||||
|     } | ||||
|     if (lines.length > 0) { | ||||
|         lines[0] = 'sql.' + lines[0]; | ||||
|         lines[lines.length - 1] = lines[lines.length - 1].split(' ").').join(' ");'); | ||||
|     } | ||||
| } | ||||
|  | ||||
| function wrapSqlVBLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         lines[i] = lines[i].trim(); | ||||
|         if (lines[i].length > 0 && lines[i][0] === "'") { | ||||
|             lines[i] = lines[i].substr(1); | ||||
|         } | ||||
|         lines[i] = 'Append(" ' + lines[i] + ' ").'; | ||||
|     } | ||||
|     if (lines.length > 0) { | ||||
|         lines[0] = 'sql.' + lines[0]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| function sortLengthLogic(lines: string[]): void { | ||||
|     lines.sort(function (a, b) { | ||||
|         // ASC  -> a.length - b.length | ||||
|         // DESC -> b.length - a.length | ||||
|         return a.length - b.length || // sort by length, if equal then | ||||
|             a.localeCompare(b);    // sort by dictionary order | ||||
|     }); | ||||
|     removeBlanks(lines); | ||||
| } | ||||
|  | ||||
| function cutEachLineLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         if (lines[i].length > 0 && lines[i].indexOf("|||") > 0) { | ||||
|             lines[i] = lines[i].substr(0, lines[i].indexOf("|||")); | ||||
|         } | ||||
|         lines[i] = lines[i].trim(); | ||||
|     } | ||||
|     removeBlanks(lines); | ||||
| } | ||||
|  | ||||
| function distinctLinesLogic(lines: string[]): void { | ||||
|     for (let i = 0; i < lines.length; ++i) { | ||||
|         if (lines[i].trim() === '' || lines.indexOf(lines[i]) !== lines.lastIndexOf(lines[i])) { | ||||
|             lines.splice(i, 1); | ||||
|             i--; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| function returnLines(textEditor: vscode.TextEditor, startLine: number, endLine: number, lines: string[]) { | ||||
|     return textEditor.edit(editBuilder => { | ||||
|         const range = new vscode.Range(startLine, 0, endLine, textEditor.document.lineAt(endLine).text.length); | ||||
|         editBuilder.replace(range, lines.join('\n')); | ||||
|     }); | ||||
| } | ||||
|  | ||||
| function linesFunction(linesAction: LinesAction): Thenable<boolean> | undefined { | ||||
|     const textEditor = vscode.window.activeTextEditor; | ||||
|     if (!textEditor) { | ||||
|         return undefined; | ||||
|     } | ||||
|     let text; | ||||
|     var endLine; | ||||
|     var startLine; | ||||
|     const selection = textEditor.selection; | ||||
|     if (selection.isEmpty) { | ||||
|         text = ''; | ||||
|         startLine = 0; | ||||
|         endLine = textEditor.document.lineCount - 1; | ||||
|     } else { | ||||
|         if (linesAction !== LinesAction.removeLinesContainingHighlighted) { | ||||
|             text = ''; | ||||
|             endLine = selection.end.line; | ||||
|             startLine = selection.start.line; | ||||
|         } else { | ||||
|             startLine = 0; | ||||
|             endLine = textEditor.document.lineCount - 1; | ||||
|             let range = new vscode.Range(selection.start, selection.end) | ||||
|             text = textEditor.document.getText(range); | ||||
|         } | ||||
|     } | ||||
|     let lines: string[] = getLines(textEditor, startLine, endLine); | ||||
|     switch (linesAction) { | ||||
|         case LinesAction.addCSharpComment: { addCSharpCommentLogic(lines); break; } | ||||
|         case LinesAction.addVBComment: { addVBCommentLogic(lines); break; } | ||||
|         case LinesAction.convertToRegularExpression: { lines = convertToRegularExpressionLogic(lines); break; } | ||||
|         case LinesAction.cutEachLine: { cutEachLineLogic(lines); break; } | ||||
|         case LinesAction.distinctLines: { distinctLinesLogic(lines); break; } | ||||
|         case LinesAction.expandSql: { expandSqlLogic(lines); break; } | ||||
|         case LinesAction.listToListFamily: { listToListFamilyLogic(lines); break; } | ||||
|         case LinesAction.listToListWrappedComma: { listToListWrappedCommaLogic(lines); break; } | ||||
|         case LinesAction.prettySql: { prettySqlLogic(lines); break; } | ||||
|         case LinesAction.quickFixCamelCaseProperties: { quickFixCamelCasePropertiesLogic(lines); break; } | ||||
|         case LinesAction.quickFixCS0108: { quickFixCS0108Logic(lines); break; } | ||||
|         case LinesAction.quickFixInstanceFieldToCalisthenics: { quickFixInstanceFieldToCalisthenicsLogic(lines); break; } | ||||
|         case LinesAction.quickFixProperCaseProperties: { quickFixProperCasePropertiesLogic(lines); break; } | ||||
|         case LinesAction.quickFixPublic: { quickFixPublicLogic(lines); break; } | ||||
|         case LinesAction.removeComment: { removeCommentLogic(lines); break; } | ||||
|         case LinesAction.removeJsonNullValues: { removeJsonNullValuesLogic(lines); break; } | ||||
|         case LinesAction.removeLinesContainingHighlighted: { removeLinesContainingHighlightedLogic(lines, text); break; } | ||||
|         case LinesAction.sortLength: { sortLengthLogic(lines); break; } | ||||
|         case LinesAction.sortNormal: { sortNormalLogic(lines); break; } | ||||
|         case LinesAction.splitBySpaceReverseJoinSort: { splitBySpaceReverseJoinSortLogic(lines); break; } | ||||
|         case LinesAction.unwrapSql: { unwrapSqlLogic(lines); break; } | ||||
|         case LinesAction.wrapSqlCSharp: { wrapSqlCSharpLogic(lines); break; } | ||||
|         case LinesAction.wrapSqlVB: { wrapSqlVBLogic(lines); break; } | ||||
|         default: { throw new Error(); } | ||||
|     } | ||||
|     return returnLines(textEditor, startLine, endLine, lines); | ||||
| } | ||||
|  | ||||
| export const addCSharpComment = () => linesFunction(LinesAction.addCSharpComment); | ||||
| export const addVBComment = () => linesFunction(LinesAction.addVBComment); | ||||
| export const convertToRegularExpression = () => linesFunction(LinesAction.convertToRegularExpression); | ||||
| export const cutEachLine = () => linesFunction(LinesAction.cutEachLine); | ||||
| export const distinctLines = () => linesFunction(LinesAction.distinctLines); | ||||
| export const expandSql = () => linesFunction(LinesAction.expandSql); | ||||
| export const listToListFamily = () => linesFunction(LinesAction.listToListFamily); | ||||
| export const listToListWrappedComma = () => linesFunction(LinesAction.listToListWrappedComma); | ||||
| export const prettySql = () => linesFunction(LinesAction.prettySql); | ||||
| export const quickFixCamelCaseProperties = () => linesFunction(LinesAction.quickFixCamelCaseProperties); | ||||
| export const quickFixCS0108 = () => linesFunction(LinesAction.quickFixCS0108); | ||||
| export const quickFixInstanceFieldToCalisthenics = () => linesFunction(LinesAction.quickFixInstanceFieldToCalisthenics); | ||||
| export const quickFixProperCaseProperties = () => linesFunction(LinesAction.quickFixProperCaseProperties); | ||||
| export const quickFixPublic = () => linesFunction(LinesAction.quickFixPublic); | ||||
| export const pdsfToFixedWidth = () => linesFunction(LinesAction.pdsfToFixedWidth); | ||||
| export const removeComment = () => linesFunction(LinesAction.removeComment); | ||||
| export const removeJsonNullValues = () => linesFunction(LinesAction.removeJsonNullValues); | ||||
| export const removeLinesContainingHighlighted = () => linesFunction(LinesAction.removeLinesContainingHighlighted); | ||||
| export const sortLength = () => linesFunction(LinesAction.sortLength); | ||||
| export const sortNormal = () => linesFunction(LinesAction.sortNormal); | ||||
| export const splitBySpaceReverseJoinSort = () => linesFunction(LinesAction.splitBySpaceReverseJoinSort); | ||||
| export const unwrapSql = () => linesFunction(LinesAction.unwrapSql); | ||||
| export const wrapSqlCSharp = () => linesFunction(LinesAction.wrapSqlCSharp); | ||||
| export const wrapSqlVB = () => linesFunction(LinesAction.wrapSqlVB); | ||||
							
								
								
									
										29
									
								
								type-script-helper/src/settingsHelper.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								type-script-helper/src/settingsHelper.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | ||||
| import * as vscode from 'vscode'; | ||||
|  | ||||
| async function rotateExplorerSortOrderLogic(): Promise<any> { | ||||
|     const config = vscode.workspace.getConfiguration("explorer"); | ||||
|     const sortOrder = config.get("sortOrder"); | ||||
|     let sortOrderOptions = [ | ||||
|         "default", | ||||
|         "modified", | ||||
|         "type", | ||||
|         "mixed", | ||||
|         "filesFirst", | ||||
|         "foldersNestsFiles", | ||||
|     ]; | ||||
|     let index = sortOrderOptions.findIndex(l => l === sortOrder); | ||||
|     if (index !== -1) | ||||
|         index++; | ||||
|     else | ||||
|         index = 0; | ||||
|     if (index >= sortOrderOptions.length) | ||||
|         index = 0; | ||||
|     let value = sortOrderOptions[index]; | ||||
|     await config.update("sortOrder", value); | ||||
|     index++;     | ||||
|     if (index >= sortOrderOptions.length) | ||||
|         index = 0; | ||||
|     vscode.window.showInformationMessage(`Explorer Sort Order set to: ${value}; next will be: ${sortOrderOptions[index]};`); | ||||
| } | ||||
|  | ||||
| export const rotateExplorerSortOrder = () => rotateExplorerSortOrderLogic(); | ||||
							
								
								
									
										19
									
								
								type-script-helper/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								type-script-helper/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,19 @@ | ||||
| { | ||||
| 	"compilerOptions": { | ||||
| 		"typeRoots": ["./node_modules/@types"], | ||||
| 		"allowSyntheticDefaultImports": true, | ||||
| 		"lib": [ | ||||
| 			"ES2020" | ||||
| 		], | ||||
| 		"module": "commonjs", | ||||
| 		"rootDir": "src", | ||||
| 		"sourceMap": true, | ||||
| 		"strict": true, | ||||
| 		"target": "ES2020" | ||||
| 	}, | ||||
| 	"exclude": [ | ||||
| 		"node_modules", | ||||
| 		".vscode-test", | ||||
| 		"webviews" | ||||
| 	] | ||||
| } | ||||
							
								
								
									
										55
									
								
								type-script-helper/vsc-extension-quickstart.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								type-script-helper/vsc-extension-quickstart.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | ||||
| --- | ||||
| type: "note" | ||||
| created: "2023-07-07T16:15:27.822Z" | ||||
| updated: "2023-07-07T16:15:27.822Z" | ||||
| --- | ||||
|  | ||||
| # vsc-extension-quickstart | ||||
|  | ||||
| # Welcome to your VS Code Extension | ||||
|  | ||||
| ## What's in the folder | ||||
|  | ||||
| * This folder contains all of the files necessary for your extension. | ||||
| * `package.json` - this is the manifest file in which you declare your extension and command. | ||||
|   * The sample plugin registers a command and defines its title and command name. With this information VS Code can show the command in the command palette. It doesn’t yet need to load the plugin. | ||||
| * `src/extension.ts` - this is the main file where you will provide the implementation of your command. | ||||
|   * The file exports one function, `activate`, which is called the very first time your extension is activated (in this case by executing the command). Inside the `activate` function we call `registerCommand`. | ||||
|   * We pass the function containing the implementation of the command as the second parameter to `registerCommand`. | ||||
|  | ||||
| ## Setup | ||||
|  | ||||
| * install the recommended extensions (amodio.tsl-problem-matcher and dbaeumer.vscode-eslint) | ||||
|  | ||||
|  | ||||
| ## Get up and running straight away | ||||
|  | ||||
| * Press `F5` to open a new window with your extension loaded. | ||||
| * Run your command from the command palette by pressing (`Ctrl+Shift+P` or `Cmd+Shift+P` on Mac) and typing `Hello World`. | ||||
| * Set breakpoints in your code inside `src/extension.ts` to debug your extension. | ||||
| * Find output from your extension in the debug console. | ||||
|  | ||||
| ## Make changes | ||||
|  | ||||
| * You can relaunch the extension from the debug toolbar after changing code in `src/extension.ts`. | ||||
| * You can also reload (`Ctrl+R` or `Cmd+R` on Mac) the VS Code window with your extension to load your changes. | ||||
|  | ||||
|  | ||||
| ## Explore the API | ||||
|  | ||||
| * You can open the full set of our API when you open the file `node_modules/@types/vscode/index.d.ts`. | ||||
|  | ||||
| ## Run tests | ||||
|  | ||||
| * Open the debug viewlet (`Ctrl+Shift+D` or `Cmd+Shift+D` on Mac) and from the launch configuration dropdown pick `Extension Tests`. | ||||
| * Press `F5` to run the tests in a new window with your extension loaded. | ||||
| * See the output of the test result in the debug console. | ||||
| * Make changes to `src/test/suite/extension.test.ts` or create new test files inside the `test/suite` folder. | ||||
|   * The provided test runner will only consider files matching the name pattern `**.test.ts`. | ||||
|   * You can create folders inside the `test` folder to structure your tests any way you want. | ||||
|  | ||||
| ## Go further | ||||
|  | ||||
| * Reduce the extension size and improve the startup time by [bundling your extension](https://code.visualstudio.com/api/working-with-extensions/bundling-extension). | ||||
| * [Publish your extension](https://code.visualstudio.com/api/working-with-extensions/publishing-extension) on the VS Code extension marketplace. | ||||
| * Automate builds by setting up [Continuous Integration](https://code.visualstudio.com/api/working-with-extensions/continuous-integration). | ||||
		Reference in New Issue
	
	Block a user