├── .editorconfig ├── .eslintrc.json ├── .gitignore ├── .vscode ├── extensions.json ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── LICENCE ├── README.md ├── assets ├── extract-to-dir.gif ├── github_logo.png └── icon.png ├── package-lock.json ├── package.json ├── src ├── code-actions.ts ├── directories-picker.ts ├── editor.ts ├── extension.ts ├── file-picker.ts ├── file-system.ts ├── modules │ ├── extract-to-folder-template.ts │ └── extract-to-folder.ts ├── template-parser.ts └── test │ ├── runTest.ts │ └── suite │ ├── extension.test.ts │ └── index.ts └── tsconfig.json /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | indent_style = space 5 | indent_size = 2 6 | charset = utf-8 7 | trim_trailing_whitespace = false 8 | insert_final_newline = false -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "root": true, 3 | "parser": "@typescript-eslint/parser", 4 | "parserOptions": { 5 | "ecmaVersion": 6, 6 | "sourceType": "module" 7 | }, 8 | "plugins": [ 9 | "@typescript-eslint" 10 | ], 11 | "rules": { 12 | "@typescript-eslint/class-name-casing": "warn", 13 | "@typescript-eslint/semi": "warn", 14 | "curly": "warn", 15 | "eqeqeq": "warn", 16 | "no-throw-literal": "warn", 17 | "semi": "off" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules 3 | .vscode-test/ 4 | *.vsix 5 | .idea -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See http://go.microsoft.com/fwlink/?LinkId=827846 3 | // for the documentation about the extensions.json format 4 | "recommendations": [ 5 | "dbaeumer.vscode-eslint" 6 | ] 7 | } 8 | -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that compiles the extension and then opens it inside a new window 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | { 6 | "version": "0.2.0", 7 | "configurations": [ 8 | { 9 | "name": "Run Extension", 10 | "type": "extensionHost", 11 | "request": "launch", 12 | "runtimeExecutable": "${execPath}", 13 | "args": [ 14 | "--extensionDevelopmentPath=${workspaceFolder}" 15 | ], 16 | "outFiles": [ 17 | "${workspaceFolder}/out/**/*.js" 18 | ], 19 | "preLaunchTask": "${defaultBuildTask}" 20 | }, 21 | { 22 | "name": "Extension Tests", 23 | "type": "extensionHost", 24 | "request": "launch", 25 | "runtimeExecutable": "${execPath}", 26 | "args": [ 27 | "--disable-extensions", 28 | "--extensionDevelopmentPath=${workspaceFolder}", 29 | "--extensionTestsPath=${workspaceFolder}/out/test/suite/index" 30 | ], 31 | "outFiles": [ 32 | "${workspaceFolder}/out/test/**/*.js" 33 | ], 34 | "preLaunchTask": "${defaultBuildTask}" 35 | } 36 | ] 37 | } 38 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | // Place your settings in this file to overwrite default and user settings. 2 | { 3 | "files.exclude": { 4 | "out": false // set this to true to hide the "out" folder with the compiled JS files 5 | }, 6 | "search.exclude": { 7 | "out": true // set this to false to include "out" folder in search results 8 | }, 9 | // Turn off tsc task auto detection since we have the necessary tasks as npm scripts 10 | "typescript.tsc.autoDetect": "off" 11 | } -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | // See https://go.microsoft.com/fwlink/?LinkId=733558 2 | // for the documentation about the tasks.json format 3 | { 4 | "version": "2.0.0", 5 | "tasks": [ 6 | { 7 | "type": "npm", 8 | "script": "watch", 9 | "problemMatcher": "$tsc-watch", 10 | "isBackground": true, 11 | "presentation": { 12 | "reveal": "never" 13 | }, 14 | "group": { 15 | "kind": "build", 16 | "isDefault": true 17 | } 18 | } 19 | ] 20 | } 21 | -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | out/test/** 4 | src/** 5 | .gitignore 6 | vsc-extension-quickstart.md 7 | **/tsconfig.json 8 | **/.eslintrc.json 9 | **/*.map 10 | **/*.ts 11 | .idea/** -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | ## 0.1.3 4 | 5 | - Fix: Illigal character on Windows 6 | 7 | ## 0.1.2 8 | 9 | - Fix: add typescript as dependency (since it required) 10 | 11 | ## 0.1.1 12 | 13 | - Fix: Get style extension from parent component (to remove schematics complexity) 14 | - Fix: reference (for example `#ref`) extraction is now not happening for local declarations 15 | - Fix: Hyphen is now allowed in component filename 16 | 17 | ## 0.1.0 18 | 19 | - Get style file extension from `@schematics/angular:component` 20 | - Fix extraction of structural directives (ngFor etc..) 21 | 22 | ## 0.0.5 23 | 24 | - Fix wrong contructor keyword placement 25 | 26 | ## 0.0.4 27 | 28 | - Avoiding duplicate inputs 29 | 30 | ## 0.0.3 31 | 32 | - Adding missing dependency 33 | 34 | ## 0.0.2 35 | 36 | - Bug fix of command key 37 | 38 | ## 0.0.1 39 | 40 | - Initial release -------------------------------------------------------------------------------- /LICENCE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 obenjiro 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |

2 | 3 |

4 | 5 | # ARRR - VSCode extension 6 | 7 | 8 | [![Badge for version for Visual Studio Code extension](https://vsmarketplacebadge.apphb.com/version-short/obenjiro.arrr.svg?color=blue&style=?style=for-the-badge&logo=visual-studio-code)](https://marketplace.visualstudio.com/items?itemName=obenjiro.arrr&wt.mc_id=angular_essentials-github-jopapa) [![Installs](https://vsmarketplacebadge.apphb.com/installs-short/obenjiro.arrr.svg?color=blue&style=flat-square)](https://marketplace.visualstudio.com/items?itemName=obenjiro.arrr) [![Rating](https://vsmarketplacebadge.apphb.com/rating-short/obenjiro.arrr.svg?color=blue&style=flat-square)](https://marketplace.visualstudio.com/items?itemName=obenjiro.arrr) 9 | 10 | 11 | ARRR - is a first extension that provides Rapid Refactoring geeRs for your Angular codebase. 12 | 13 | ## Highlights 14 | 15 | - Allows extracting HTML into new component 16 | - Automatic Modules Updates 17 | - Generates HTML, CSS, TS and spec files 18 | 19 | ## Installation 20 | 21 | Go to the link below and click `Install`. 22 | 23 | [Visual Studio Code Market Place: arrr](https://marketplace.visualstudio.com/items?itemName=obenjiro.arrr) 24 | 25 | ## Features 26 | 27 | ### Extracting HTML into a new Component 28 | 29 | arrr allows easy extraction of HTML into new Angular components. Just select the HTML to extract, and arrr will handle all the rest: 30 | 31 | - It will identify all Inputs to the newly created component. 32 | - Replace extracted HTML with newly created component, while providing it with all the Inputs. 33 | 34 | ![Example of HTML extraction](https://github.com/obenjiro/vscode-arrr/blob/master/assets/extract-to-dir.gif?raw=true) 35 | 36 | ## Contribute 37 | 38 | Feel free to open issues or PRs! 39 | 40 | ### Getting started 41 | 42 | In order to start working all you need to do is: 43 | 44 | ```sh 45 | $ git clone git@github.com:obenjiro/vscode-arrr.git 46 | $ cd vscode-arrr 47 | $ npm install 48 | $ code . 49 | ``` 50 | 51 | ### Running Extension 52 | 53 | - Go to VSCode debug sidebar 54 | - Select `Extension` from the dropdown 55 | - Hit `F5` 56 | 57 | ### Running Tests 58 | 59 | - Go to VSCode debug sidebar 60 | - Select `Extension Tests` from the dropdown 61 | - Hit `F5` 62 | 63 | ### Commit messages 64 | 65 | Please refer to to the following [guide](https://marketplace.visualstudio.com/items?itemName=obenjiro.arrr). 66 | 67 | -------------------------------------------------------------------------------- /assets/extract-to-dir.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/obenjiro/vscode-arrr/74b455e903234414213efcf1d6720e5bde42f640/assets/extract-to-dir.gif -------------------------------------------------------------------------------- /assets/github_logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/obenjiro/vscode-arrr/74b455e903234414213efcf1d6720e5bde42f640/assets/github_logo.png -------------------------------------------------------------------------------- /assets/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/obenjiro/vscode-arrr/74b455e903234414213efcf1d6720e5bde42f640/assets/icon.png -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "arrr", 3 | "version": "0.1.3", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@angular/compiler": { 8 | "version": "10.0.7", 9 | "resolved": "https://registry.npmjs.org/@angular/compiler/-/compiler-10.0.7.tgz", 10 | "integrity": "sha512-ut4aq7G0OwpRM2jhWjqN7RR02z9ybwFlP8j+2cr+6wwxZLUB+Gwe+O8iuz6h98O7F9yZx8Lbr5bQ07xbiHgdag==", 11 | "requires": { 12 | "tslib": "^2.0.0" 13 | }, 14 | "dependencies": { 15 | "tslib": { 16 | "version": "2.0.0", 17 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.0.0.tgz", 18 | "integrity": "sha512-lTqkx847PI7xEDYJntxZH89L2/aXInsyF2luSafe/+0fHOMjlBNXdH6th7f70qxLDhul7KZK0zC8V5ZIyHl0/g==" 19 | } 20 | } 21 | }, 22 | "@babel/code-frame": { 23 | "version": "7.10.4", 24 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", 25 | "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", 26 | "dev": true, 27 | "requires": { 28 | "@babel/highlight": "^7.10.4" 29 | } 30 | }, 31 | "@babel/helper-validator-identifier": { 32 | "version": "7.10.4", 33 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", 34 | "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", 35 | "dev": true 36 | }, 37 | "@babel/highlight": { 38 | "version": "7.10.4", 39 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 40 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 41 | "dev": true, 42 | "requires": { 43 | "@babel/helper-validator-identifier": "^7.10.4", 44 | "chalk": "^2.0.0", 45 | "js-tokens": "^4.0.0" 46 | } 47 | }, 48 | "@types/color-name": { 49 | "version": "1.1.1", 50 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 51 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 52 | "dev": true 53 | }, 54 | "@types/eslint-visitor-keys": { 55 | "version": "1.0.0", 56 | "resolved": "https://registry.npmjs.org/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 57 | "integrity": "sha512-OCutwjDZ4aFS6PB1UZ988C4YgwlBHJd6wCeQqaLdmadZ/7e+w79+hbMUFC1QXDNCmdyoRfAFdm0RypzwR+Qpag==", 58 | "dev": true 59 | }, 60 | "@types/glob": { 61 | "version": "7.1.3", 62 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.3.tgz", 63 | "integrity": "sha512-SEYeGAIQIQX8NN6LDKprLjbrd5dARM5EXsd8GI/A5l0apYI1fGMWgPHSe4ZKL4eozlAyI+doUE9XbYS4xCkQ1w==", 64 | "dev": true, 65 | "requires": { 66 | "@types/minimatch": "*", 67 | "@types/node": "*" 68 | } 69 | }, 70 | "@types/json-schema": { 71 | "version": "7.0.5", 72 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.5.tgz", 73 | "integrity": "sha512-7+2BITlgjgDhH0vvwZU/HZJVyk+2XUlvxXe8dFMedNX/aMkaOq++rMAFXc0tM7ij15QaWlbdQASBR9dihi+bDQ==", 74 | "dev": true 75 | }, 76 | "@types/minimatch": { 77 | "version": "3.0.3", 78 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", 79 | "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==", 80 | "dev": true 81 | }, 82 | "@types/mkdirp": { 83 | "version": "1.0.1", 84 | "resolved": "https://registry.npmjs.org/@types/mkdirp/-/mkdirp-1.0.1.tgz", 85 | "integrity": "sha512-HkGSK7CGAXncr8Qn/0VqNtExEE+PHMWb+qlR1faHMao7ng6P3tAaoWWBMdva0gL5h4zprjIO89GJOLXsMcDm1Q==", 86 | "requires": { 87 | "@types/node": "*" 88 | } 89 | }, 90 | "@types/mocha": { 91 | "version": "7.0.2", 92 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-7.0.2.tgz", 93 | "integrity": "sha512-ZvO2tAcjmMi8V/5Z3JsyofMe3hasRcaw88cto5etSVMwVQfeivGAlEYmaQgceUSVYFofVjT+ioHsATjdWcFt1w==", 94 | "dev": true 95 | }, 96 | "@types/node": { 97 | "version": "13.13.15", 98 | "resolved": "https://registry.npmjs.org/@types/node/-/node-13.13.15.tgz", 99 | "integrity": "sha512-kwbcs0jySLxzLsa2nWUAGOd/s21WU1jebrEdtzhsj1D4Yps1EOuyI1Qcu+FD56dL7NRNIJtDDjcqIG22NwkgLw==" 100 | }, 101 | "@types/vscode": { 102 | "version": "1.47.0", 103 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.47.0.tgz", 104 | "integrity": "sha512-nJA37ykkz9FYA0ZOQUSc3OZnhuzEW2vUhUEo4MiduUo82jGwwcLfyvmgd/Q7b0WrZAAceojGhZybg319L24bTA==", 105 | "dev": true 106 | }, 107 | "@typescript-eslint/eslint-plugin": { 108 | "version": "2.34.0", 109 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-2.34.0.tgz", 110 | "integrity": "sha512-4zY3Z88rEE99+CNvTbXSyovv2z9PNOVffTWD2W8QF5s2prBQtwN2zadqERcrHpcR7O/+KMI3fcTAmUUhK/iQcQ==", 111 | "dev": true, 112 | "requires": { 113 | "@typescript-eslint/experimental-utils": "2.34.0", 114 | "functional-red-black-tree": "^1.0.1", 115 | "regexpp": "^3.0.0", 116 | "tsutils": "^3.17.1" 117 | } 118 | }, 119 | "@typescript-eslint/experimental-utils": { 120 | "version": "2.34.0", 121 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-2.34.0.tgz", 122 | "integrity": "sha512-eS6FTkq+wuMJ+sgtuNTtcqavWXqsflWcfBnlYhg/nS4aZ1leewkXGbvBhaapn1q6qf4M71bsR1tez5JTRMuqwA==", 123 | "dev": true, 124 | "requires": { 125 | "@types/json-schema": "^7.0.3", 126 | "@typescript-eslint/typescript-estree": "2.34.0", 127 | "eslint-scope": "^5.0.0", 128 | "eslint-utils": "^2.0.0" 129 | } 130 | }, 131 | "@typescript-eslint/parser": { 132 | "version": "2.34.0", 133 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-2.34.0.tgz", 134 | "integrity": "sha512-03ilO0ucSD0EPTw2X4PntSIRFtDPWjrVq7C3/Z3VQHRC7+13YB55rcJI3Jt+YgeHbjUdJPcPa7b23rXCBokuyA==", 135 | "dev": true, 136 | "requires": { 137 | "@types/eslint-visitor-keys": "^1.0.0", 138 | "@typescript-eslint/experimental-utils": "2.34.0", 139 | "@typescript-eslint/typescript-estree": "2.34.0", 140 | "eslint-visitor-keys": "^1.1.0" 141 | } 142 | }, 143 | "@typescript-eslint/typescript-estree": { 144 | "version": "2.34.0", 145 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-2.34.0.tgz", 146 | "integrity": "sha512-OMAr+nJWKdlVM9LOqCqh3pQQPwxHAN7Du8DR6dmwCrAmxtiXQnhHJ6tBNtf+cggqfo51SG/FCwnKhXCIM7hnVg==", 147 | "dev": true, 148 | "requires": { 149 | "debug": "^4.1.1", 150 | "eslint-visitor-keys": "^1.1.0", 151 | "glob": "^7.1.6", 152 | "is-glob": "^4.0.1", 153 | "lodash": "^4.17.15", 154 | "semver": "^7.3.2", 155 | "tsutils": "^3.17.1" 156 | } 157 | }, 158 | "acorn": { 159 | "version": "7.4.0", 160 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.0.tgz", 161 | "integrity": "sha512-+G7P8jJmCHr+S+cLfQxygbWhXy+8YTVGzAkpEbcLo2mLoL7tij/VG41QSHACSf5QgYRhMZYHuNc6drJaO0Da+w==", 162 | "dev": true 163 | }, 164 | "acorn-jsx": { 165 | "version": "5.2.0", 166 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.2.0.tgz", 167 | "integrity": "sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ==", 168 | "dev": true 169 | }, 170 | "agent-base": { 171 | "version": "4.3.0", 172 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-4.3.0.tgz", 173 | "integrity": "sha512-salcGninV0nPrwpGNn4VTXBb1SOuXQBiqbrNXoeizJsHrsL6ERFM2Ne3JUSBWRE6aeNJI2ROP/WEEIDUiDe3cg==", 174 | "dev": true, 175 | "requires": { 176 | "es6-promisify": "^5.0.0" 177 | } 178 | }, 179 | "ajv": { 180 | "version": "6.12.3", 181 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.3.tgz", 182 | "integrity": "sha512-4K0cK3L1hsqk9xIb2z9vs/XU+PGJZ9PNpJRDS9YLzmNdX6jmVPfamLvTJr0aDAusnHyCHO6MjzlkAsgtqp9teA==", 183 | "dev": true, 184 | "requires": { 185 | "fast-deep-equal": "^3.1.1", 186 | "fast-json-stable-stringify": "^2.0.0", 187 | "json-schema-traverse": "^0.4.1", 188 | "uri-js": "^4.2.2" 189 | } 190 | }, 191 | "ansi-colors": { 192 | "version": "3.2.3", 193 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 194 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 195 | "dev": true 196 | }, 197 | "ansi-escapes": { 198 | "version": "4.3.1", 199 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 200 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 201 | "dev": true, 202 | "requires": { 203 | "type-fest": "^0.11.0" 204 | }, 205 | "dependencies": { 206 | "type-fest": { 207 | "version": "0.11.0", 208 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 209 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 210 | "dev": true 211 | } 212 | } 213 | }, 214 | "ansi-regex": { 215 | "version": "5.0.0", 216 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 217 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 218 | "dev": true 219 | }, 220 | "ansi-styles": { 221 | "version": "3.2.1", 222 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 223 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 224 | "dev": true, 225 | "requires": { 226 | "color-convert": "^1.9.0" 227 | } 228 | }, 229 | "anymatch": { 230 | "version": "3.1.1", 231 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 232 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 233 | "dev": true, 234 | "requires": { 235 | "normalize-path": "^3.0.0", 236 | "picomatch": "^2.0.4" 237 | } 238 | }, 239 | "argparse": { 240 | "version": "1.0.10", 241 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 242 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 243 | "dev": true, 244 | "requires": { 245 | "sprintf-js": "~1.0.2" 246 | } 247 | }, 248 | "astral-regex": { 249 | "version": "1.0.0", 250 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 251 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 252 | "dev": true 253 | }, 254 | "balanced-match": { 255 | "version": "1.0.0", 256 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 257 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 258 | }, 259 | "binary-extensions": { 260 | "version": "2.1.0", 261 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz", 262 | "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==", 263 | "dev": true 264 | }, 265 | "brace-expansion": { 266 | "version": "1.1.11", 267 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 268 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 269 | "requires": { 270 | "balanced-match": "^1.0.0", 271 | "concat-map": "0.0.1" 272 | } 273 | }, 274 | "braces": { 275 | "version": "3.0.2", 276 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 277 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 278 | "dev": true, 279 | "requires": { 280 | "fill-range": "^7.0.1" 281 | } 282 | }, 283 | "browser-stdout": { 284 | "version": "1.3.1", 285 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 286 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 287 | "dev": true 288 | }, 289 | "callsites": { 290 | "version": "3.1.0", 291 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 292 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 293 | "dev": true 294 | }, 295 | "camel-case": { 296 | "version": "4.1.1", 297 | "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-4.1.1.tgz", 298 | "integrity": "sha512-7fa2WcG4fYFkclIvEmxBbTvmibwF2/agfEBc6q3lOpVu0A13ltLsA+Hr/8Hp6kp5f+G7hKi6t8lys6XxP+1K6Q==", 299 | "requires": { 300 | "pascal-case": "^3.1.1", 301 | "tslib": "^1.10.0" 302 | } 303 | }, 304 | "camelcase": { 305 | "version": "5.3.1", 306 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 307 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 308 | "dev": true 309 | }, 310 | "capital-case": { 311 | "version": "1.0.3", 312 | "resolved": "https://registry.npmjs.org/capital-case/-/capital-case-1.0.3.tgz", 313 | "integrity": "sha512-OlUSJpUr7SY0uZFOxcwnDOU7/MpHlKTZx2mqnDYQFrDudXLFm0JJ9wr/l4csB+rh2Ug0OPuoSO53PqiZBqno9A==", 314 | "requires": { 315 | "no-case": "^3.0.3", 316 | "tslib": "^1.10.0", 317 | "upper-case-first": "^2.0.1" 318 | } 319 | }, 320 | "chalk": { 321 | "version": "2.4.2", 322 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 323 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 324 | "dev": true, 325 | "requires": { 326 | "ansi-styles": "^3.2.1", 327 | "escape-string-regexp": "^1.0.5", 328 | "supports-color": "^5.3.0" 329 | } 330 | }, 331 | "change-case": { 332 | "version": "4.1.1", 333 | "resolved": "https://registry.npmjs.org/change-case/-/change-case-4.1.1.tgz", 334 | "integrity": "sha512-qRlUWn/hXnX1R1LBDF/RelJLiqNjKjUqlmuBVSEIyye8kq49CXqkZWKmi8XeUAdDXWFOcGLUMZ+aHn3Q5lzUXw==", 335 | "requires": { 336 | "camel-case": "^4.1.1", 337 | "capital-case": "^1.0.3", 338 | "constant-case": "^3.0.3", 339 | "dot-case": "^3.0.3", 340 | "header-case": "^2.0.3", 341 | "no-case": "^3.0.3", 342 | "param-case": "^3.0.3", 343 | "pascal-case": "^3.1.1", 344 | "path-case": "^3.0.3", 345 | "sentence-case": "^3.0.3", 346 | "snake-case": "^3.0.3", 347 | "tslib": "^1.10.0" 348 | } 349 | }, 350 | "chardet": { 351 | "version": "0.7.0", 352 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 353 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 354 | "dev": true 355 | }, 356 | "chokidar": { 357 | "version": "3.3.0", 358 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.0.tgz", 359 | "integrity": "sha512-dGmKLDdT3Gdl7fBUe8XK+gAtGmzy5Fn0XkkWQuYxGIgWVPPse2CxFA5mtrlD0TOHaHjEUqkWNyP1XdHoJES/4A==", 360 | "dev": true, 361 | "requires": { 362 | "anymatch": "~3.1.1", 363 | "braces": "~3.0.2", 364 | "fsevents": "~2.1.1", 365 | "glob-parent": "~5.1.0", 366 | "is-binary-path": "~2.1.0", 367 | "is-glob": "~4.0.1", 368 | "normalize-path": "~3.0.0", 369 | "readdirp": "~3.2.0" 370 | } 371 | }, 372 | "cli-cursor": { 373 | "version": "3.1.0", 374 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 375 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 376 | "dev": true, 377 | "requires": { 378 | "restore-cursor": "^3.1.0" 379 | } 380 | }, 381 | "cli-width": { 382 | "version": "3.0.0", 383 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz", 384 | "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==", 385 | "dev": true 386 | }, 387 | "cliui": { 388 | "version": "5.0.0", 389 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 390 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 391 | "dev": true, 392 | "requires": { 393 | "string-width": "^3.1.0", 394 | "strip-ansi": "^5.2.0", 395 | "wrap-ansi": "^5.1.0" 396 | }, 397 | "dependencies": { 398 | "emoji-regex": { 399 | "version": "7.0.3", 400 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 401 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 402 | "dev": true 403 | }, 404 | "is-fullwidth-code-point": { 405 | "version": "2.0.0", 406 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 407 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 408 | "dev": true 409 | }, 410 | "string-width": { 411 | "version": "3.1.0", 412 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 413 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 414 | "dev": true, 415 | "requires": { 416 | "emoji-regex": "^7.0.1", 417 | "is-fullwidth-code-point": "^2.0.0", 418 | "strip-ansi": "^5.1.0" 419 | } 420 | } 421 | } 422 | }, 423 | "color-convert": { 424 | "version": "1.9.3", 425 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 426 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 427 | "dev": true, 428 | "requires": { 429 | "color-name": "1.1.3" 430 | } 431 | }, 432 | "color-name": { 433 | "version": "1.1.3", 434 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 435 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 436 | "dev": true 437 | }, 438 | "concat-map": { 439 | "version": "0.0.1", 440 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 441 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 442 | }, 443 | "constant-case": { 444 | "version": "3.0.3", 445 | "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-3.0.3.tgz", 446 | "integrity": "sha512-FXtsSnnrFYpzDmvwDGQW+l8XK3GV1coLyBN0eBz16ZUzGaZcT2ANVCJmLeuw2GQgxKHQIe9e0w2dzkSfaRlUmA==", 447 | "requires": { 448 | "no-case": "^3.0.3", 449 | "tslib": "^1.10.0", 450 | "upper-case": "^2.0.1" 451 | } 452 | }, 453 | "cross-spawn": { 454 | "version": "6.0.5", 455 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 456 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 457 | "dev": true, 458 | "requires": { 459 | "nice-try": "^1.0.4", 460 | "path-key": "^2.0.1", 461 | "semver": "^5.5.0", 462 | "shebang-command": "^1.2.0", 463 | "which": "^1.2.9" 464 | }, 465 | "dependencies": { 466 | "semver": { 467 | "version": "5.7.1", 468 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 469 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 470 | "dev": true 471 | } 472 | } 473 | }, 474 | "debug": { 475 | "version": "4.1.1", 476 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 477 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 478 | "dev": true, 479 | "requires": { 480 | "ms": "^2.1.1" 481 | } 482 | }, 483 | "decamelize": { 484 | "version": "1.2.0", 485 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 486 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 487 | "dev": true 488 | }, 489 | "deep-is": { 490 | "version": "0.1.3", 491 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 492 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 493 | "dev": true 494 | }, 495 | "define-properties": { 496 | "version": "1.1.3", 497 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 498 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 499 | "dev": true, 500 | "requires": { 501 | "object-keys": "^1.0.12" 502 | } 503 | }, 504 | "diff": { 505 | "version": "3.5.0", 506 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 507 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 508 | "dev": true 509 | }, 510 | "doctrine": { 511 | "version": "3.0.0", 512 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 513 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 514 | "dev": true, 515 | "requires": { 516 | "esutils": "^2.0.2" 517 | } 518 | }, 519 | "dot-case": { 520 | "version": "3.0.3", 521 | "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.3.tgz", 522 | "integrity": "sha512-7hwEmg6RiSQfm/GwPL4AAWXKy3YNNZA3oFv2Pdiey0mwkRCPZ9x6SZbkLcn8Ma5PYeVokzoD4Twv2n7LKp5WeA==", 523 | "requires": { 524 | "no-case": "^3.0.3", 525 | "tslib": "^1.10.0" 526 | } 527 | }, 528 | "emoji-regex": { 529 | "version": "8.0.0", 530 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 531 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 532 | "dev": true 533 | }, 534 | "es-abstract": { 535 | "version": "1.17.6", 536 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.6.tgz", 537 | "integrity": "sha512-Fr89bON3WFyUi5EvAeI48QTWX0AyekGgLA8H+c+7fbfCkJwRWRMLd8CQedNEyJuoYYhmtEqY92pgte1FAhBlhw==", 538 | "dev": true, 539 | "requires": { 540 | "es-to-primitive": "^1.2.1", 541 | "function-bind": "^1.1.1", 542 | "has": "^1.0.3", 543 | "has-symbols": "^1.0.1", 544 | "is-callable": "^1.2.0", 545 | "is-regex": "^1.1.0", 546 | "object-inspect": "^1.7.0", 547 | "object-keys": "^1.1.1", 548 | "object.assign": "^4.1.0", 549 | "string.prototype.trimend": "^1.0.1", 550 | "string.prototype.trimstart": "^1.0.1" 551 | } 552 | }, 553 | "es-to-primitive": { 554 | "version": "1.2.1", 555 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 556 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 557 | "dev": true, 558 | "requires": { 559 | "is-callable": "^1.1.4", 560 | "is-date-object": "^1.0.1", 561 | "is-symbol": "^1.0.2" 562 | } 563 | }, 564 | "es6-promise": { 565 | "version": "4.2.8", 566 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz", 567 | "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", 568 | "dev": true 569 | }, 570 | "es6-promisify": { 571 | "version": "5.0.0", 572 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-5.0.0.tgz", 573 | "integrity": "sha1-UQnWLz5W6pZ8S2NQWu8IKRyKUgM=", 574 | "dev": true, 575 | "requires": { 576 | "es6-promise": "^4.0.3" 577 | } 578 | }, 579 | "escape-string-regexp": { 580 | "version": "1.0.5", 581 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 582 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 583 | "dev": true 584 | }, 585 | "eslint": { 586 | "version": "6.8.0", 587 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", 588 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", 589 | "dev": true, 590 | "requires": { 591 | "@babel/code-frame": "^7.0.0", 592 | "ajv": "^6.10.0", 593 | "chalk": "^2.1.0", 594 | "cross-spawn": "^6.0.5", 595 | "debug": "^4.0.1", 596 | "doctrine": "^3.0.0", 597 | "eslint-scope": "^5.0.0", 598 | "eslint-utils": "^1.4.3", 599 | "eslint-visitor-keys": "^1.1.0", 600 | "espree": "^6.1.2", 601 | "esquery": "^1.0.1", 602 | "esutils": "^2.0.2", 603 | "file-entry-cache": "^5.0.1", 604 | "functional-red-black-tree": "^1.0.1", 605 | "glob-parent": "^5.0.0", 606 | "globals": "^12.1.0", 607 | "ignore": "^4.0.6", 608 | "import-fresh": "^3.0.0", 609 | "imurmurhash": "^0.1.4", 610 | "inquirer": "^7.0.0", 611 | "is-glob": "^4.0.0", 612 | "js-yaml": "^3.13.1", 613 | "json-stable-stringify-without-jsonify": "^1.0.1", 614 | "levn": "^0.3.0", 615 | "lodash": "^4.17.14", 616 | "minimatch": "^3.0.4", 617 | "mkdirp": "^0.5.1", 618 | "natural-compare": "^1.4.0", 619 | "optionator": "^0.8.3", 620 | "progress": "^2.0.0", 621 | "regexpp": "^2.0.1", 622 | "semver": "^6.1.2", 623 | "strip-ansi": "^5.2.0", 624 | "strip-json-comments": "^3.0.1", 625 | "table": "^5.2.3", 626 | "text-table": "^0.2.0", 627 | "v8-compile-cache": "^2.0.3" 628 | }, 629 | "dependencies": { 630 | "eslint-utils": { 631 | "version": "1.4.3", 632 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 633 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 634 | "dev": true, 635 | "requires": { 636 | "eslint-visitor-keys": "^1.1.0" 637 | } 638 | }, 639 | "mkdirp": { 640 | "version": "0.5.5", 641 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 642 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 643 | "dev": true, 644 | "requires": { 645 | "minimist": "^1.2.5" 646 | } 647 | }, 648 | "regexpp": { 649 | "version": "2.0.1", 650 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 651 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 652 | "dev": true 653 | }, 654 | "semver": { 655 | "version": "6.3.0", 656 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 657 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 658 | "dev": true 659 | } 660 | } 661 | }, 662 | "eslint-scope": { 663 | "version": "5.1.0", 664 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.0.tgz", 665 | "integrity": "sha512-iiGRvtxWqgtx5m8EyQUJihBloE4EnYeGE/bz1wSPwJE6tZuJUtHlhqDM4Xj2ukE8Dyy1+HCZ4hE0fzIVMzb58w==", 666 | "dev": true, 667 | "requires": { 668 | "esrecurse": "^4.1.0", 669 | "estraverse": "^4.1.1" 670 | } 671 | }, 672 | "eslint-utils": { 673 | "version": "2.1.0", 674 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 675 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 676 | "dev": true, 677 | "requires": { 678 | "eslint-visitor-keys": "^1.1.0" 679 | } 680 | }, 681 | "eslint-visitor-keys": { 682 | "version": "1.3.0", 683 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 684 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 685 | "dev": true 686 | }, 687 | "espree": { 688 | "version": "6.2.1", 689 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz", 690 | "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==", 691 | "dev": true, 692 | "requires": { 693 | "acorn": "^7.1.1", 694 | "acorn-jsx": "^5.2.0", 695 | "eslint-visitor-keys": "^1.1.0" 696 | } 697 | }, 698 | "esprima": { 699 | "version": "4.0.1", 700 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 701 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 702 | "dev": true 703 | }, 704 | "esquery": { 705 | "version": "1.3.1", 706 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 707 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 708 | "dev": true, 709 | "requires": { 710 | "estraverse": "^5.1.0" 711 | }, 712 | "dependencies": { 713 | "estraverse": { 714 | "version": "5.1.0", 715 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.1.0.tgz", 716 | "integrity": "sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw==", 717 | "dev": true 718 | } 719 | } 720 | }, 721 | "esrecurse": { 722 | "version": "4.2.1", 723 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 724 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 725 | "dev": true, 726 | "requires": { 727 | "estraverse": "^4.1.0" 728 | } 729 | }, 730 | "estraverse": { 731 | "version": "4.3.0", 732 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 733 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 734 | "dev": true 735 | }, 736 | "esutils": { 737 | "version": "2.0.3", 738 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 739 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 740 | "dev": true 741 | }, 742 | "external-editor": { 743 | "version": "3.1.0", 744 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 745 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 746 | "dev": true, 747 | "requires": { 748 | "chardet": "^0.7.0", 749 | "iconv-lite": "^0.4.24", 750 | "tmp": "^0.0.33" 751 | } 752 | }, 753 | "fast-deep-equal": { 754 | "version": "3.1.3", 755 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 756 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 757 | "dev": true 758 | }, 759 | "fast-json-stable-stringify": { 760 | "version": "2.1.0", 761 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 762 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 763 | "dev": true 764 | }, 765 | "fast-levenshtein": { 766 | "version": "2.0.6", 767 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 768 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 769 | "dev": true 770 | }, 771 | "figures": { 772 | "version": "3.2.0", 773 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 774 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 775 | "dev": true, 776 | "requires": { 777 | "escape-string-regexp": "^1.0.5" 778 | } 779 | }, 780 | "file-entry-cache": { 781 | "version": "5.0.1", 782 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 783 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 784 | "dev": true, 785 | "requires": { 786 | "flat-cache": "^2.0.1" 787 | } 788 | }, 789 | "fill-range": { 790 | "version": "7.0.1", 791 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 792 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 793 | "dev": true, 794 | "requires": { 795 | "to-regex-range": "^5.0.1" 796 | } 797 | }, 798 | "flat": { 799 | "version": "4.1.0", 800 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 801 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 802 | "dev": true, 803 | "requires": { 804 | "is-buffer": "~2.0.3" 805 | } 806 | }, 807 | "flat-cache": { 808 | "version": "2.0.1", 809 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 810 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 811 | "dev": true, 812 | "requires": { 813 | "flatted": "^2.0.0", 814 | "rimraf": "2.6.3", 815 | "write": "1.0.3" 816 | } 817 | }, 818 | "flatted": { 819 | "version": "2.0.2", 820 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 821 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 822 | "dev": true 823 | }, 824 | "fs.realpath": { 825 | "version": "1.0.0", 826 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 827 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 828 | }, 829 | "fsevents": { 830 | "version": "2.1.3", 831 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", 832 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", 833 | "dev": true, 834 | "optional": true 835 | }, 836 | "function-bind": { 837 | "version": "1.1.1", 838 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 839 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 840 | "dev": true 841 | }, 842 | "functional-red-black-tree": { 843 | "version": "1.0.1", 844 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 845 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 846 | "dev": true 847 | }, 848 | "get-caller-file": { 849 | "version": "2.0.5", 850 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 851 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 852 | "dev": true 853 | }, 854 | "gitignore-to-glob": { 855 | "version": "0.3.0", 856 | "resolved": "https://registry.npmjs.org/gitignore-to-glob/-/gitignore-to-glob-0.3.0.tgz", 857 | "integrity": "sha1-WfMqs9m2bOUCmcPtJMsO9CoJTOs=" 858 | }, 859 | "glob": { 860 | "version": "7.1.6", 861 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 862 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 863 | "requires": { 864 | "fs.realpath": "^1.0.0", 865 | "inflight": "^1.0.4", 866 | "inherits": "2", 867 | "minimatch": "^3.0.4", 868 | "once": "^1.3.0", 869 | "path-is-absolute": "^1.0.0" 870 | } 871 | }, 872 | "glob-parent": { 873 | "version": "5.1.1", 874 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 875 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 876 | "dev": true, 877 | "requires": { 878 | "is-glob": "^4.0.1" 879 | } 880 | }, 881 | "globals": { 882 | "version": "12.4.0", 883 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 884 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 885 | "dev": true, 886 | "requires": { 887 | "type-fest": "^0.8.1" 888 | } 889 | }, 890 | "growl": { 891 | "version": "1.10.5", 892 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 893 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 894 | "dev": true 895 | }, 896 | "has": { 897 | "version": "1.0.3", 898 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 899 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 900 | "dev": true, 901 | "requires": { 902 | "function-bind": "^1.1.1" 903 | } 904 | }, 905 | "has-flag": { 906 | "version": "3.0.0", 907 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 908 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 909 | "dev": true 910 | }, 911 | "has-symbols": { 912 | "version": "1.0.1", 913 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 914 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 915 | "dev": true 916 | }, 917 | "he": { 918 | "version": "1.2.0", 919 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 920 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 921 | "dev": true 922 | }, 923 | "header-case": { 924 | "version": "2.0.3", 925 | "resolved": "https://registry.npmjs.org/header-case/-/header-case-2.0.3.tgz", 926 | "integrity": "sha512-LChe/V32mnUQnTwTxd3aAlNMk8ia9tjCDb/LjYtoMrdAPApxLB+azejUk5ERZIZdIqvinwv6BAUuFXH/tQPdZA==", 927 | "requires": { 928 | "capital-case": "^1.0.3", 929 | "tslib": "^1.10.0" 930 | } 931 | }, 932 | "http-proxy-agent": { 933 | "version": "2.1.0", 934 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-2.1.0.tgz", 935 | "integrity": "sha512-qwHbBLV7WviBl0rQsOzH6o5lwyOIvwp/BdFnvVxXORldu5TmjFfjzBcWUWS5kWAZhmv+JtiDhSuQCp4sBfbIgg==", 936 | "dev": true, 937 | "requires": { 938 | "agent-base": "4", 939 | "debug": "3.1.0" 940 | }, 941 | "dependencies": { 942 | "debug": { 943 | "version": "3.1.0", 944 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 945 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 946 | "dev": true, 947 | "requires": { 948 | "ms": "2.0.0" 949 | } 950 | }, 951 | "ms": { 952 | "version": "2.0.0", 953 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 954 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 955 | "dev": true 956 | } 957 | } 958 | }, 959 | "https-proxy-agent": { 960 | "version": "2.2.4", 961 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-2.2.4.tgz", 962 | "integrity": "sha512-OmvfoQ53WLjtA9HeYP9RNrWMJzzAz1JGaSFr1nijg0PVR1JaD/xbJq1mdEIIlxGpXp9eSe/O2LgU9DJmTPd0Eg==", 963 | "dev": true, 964 | "requires": { 965 | "agent-base": "^4.3.0", 966 | "debug": "^3.1.0" 967 | }, 968 | "dependencies": { 969 | "debug": { 970 | "version": "3.2.6", 971 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 972 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 973 | "dev": true, 974 | "requires": { 975 | "ms": "^2.1.1" 976 | } 977 | } 978 | } 979 | }, 980 | "iconv-lite": { 981 | "version": "0.4.24", 982 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 983 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 984 | "dev": true, 985 | "requires": { 986 | "safer-buffer": ">= 2.1.2 < 3" 987 | } 988 | }, 989 | "ignore": { 990 | "version": "4.0.6", 991 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 992 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 993 | "dev": true 994 | }, 995 | "import-fresh": { 996 | "version": "3.2.1", 997 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 998 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 999 | "dev": true, 1000 | "requires": { 1001 | "parent-module": "^1.0.0", 1002 | "resolve-from": "^4.0.0" 1003 | } 1004 | }, 1005 | "imurmurhash": { 1006 | "version": "0.1.4", 1007 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1008 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1009 | "dev": true 1010 | }, 1011 | "inflight": { 1012 | "version": "1.0.6", 1013 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1014 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1015 | "requires": { 1016 | "once": "^1.3.0", 1017 | "wrappy": "1" 1018 | } 1019 | }, 1020 | "inherits": { 1021 | "version": "2.0.4", 1022 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1023 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1024 | }, 1025 | "inquirer": { 1026 | "version": "7.3.3", 1027 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.3.3.tgz", 1028 | "integrity": "sha512-JG3eIAj5V9CwcGvuOmoo6LB9kbAYT8HXffUl6memuszlwDC/qvFAJw49XJ5NROSFNPxp3iQg1GqkFhaY/CR0IA==", 1029 | "dev": true, 1030 | "requires": { 1031 | "ansi-escapes": "^4.2.1", 1032 | "chalk": "^4.1.0", 1033 | "cli-cursor": "^3.1.0", 1034 | "cli-width": "^3.0.0", 1035 | "external-editor": "^3.0.3", 1036 | "figures": "^3.0.0", 1037 | "lodash": "^4.17.19", 1038 | "mute-stream": "0.0.8", 1039 | "run-async": "^2.4.0", 1040 | "rxjs": "^6.6.0", 1041 | "string-width": "^4.1.0", 1042 | "strip-ansi": "^6.0.0", 1043 | "through": "^2.3.6" 1044 | }, 1045 | "dependencies": { 1046 | "ansi-styles": { 1047 | "version": "4.2.1", 1048 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 1049 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 1050 | "dev": true, 1051 | "requires": { 1052 | "@types/color-name": "^1.1.1", 1053 | "color-convert": "^2.0.1" 1054 | } 1055 | }, 1056 | "chalk": { 1057 | "version": "4.1.0", 1058 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 1059 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 1060 | "dev": true, 1061 | "requires": { 1062 | "ansi-styles": "^4.1.0", 1063 | "supports-color": "^7.1.0" 1064 | } 1065 | }, 1066 | "color-convert": { 1067 | "version": "2.0.1", 1068 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1069 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1070 | "dev": true, 1071 | "requires": { 1072 | "color-name": "~1.1.4" 1073 | } 1074 | }, 1075 | "color-name": { 1076 | "version": "1.1.4", 1077 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1078 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1079 | "dev": true 1080 | }, 1081 | "has-flag": { 1082 | "version": "4.0.0", 1083 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1084 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1085 | "dev": true 1086 | }, 1087 | "strip-ansi": { 1088 | "version": "6.0.0", 1089 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1090 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1091 | "dev": true, 1092 | "requires": { 1093 | "ansi-regex": "^5.0.0" 1094 | } 1095 | }, 1096 | "supports-color": { 1097 | "version": "7.1.0", 1098 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1099 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1100 | "dev": true, 1101 | "requires": { 1102 | "has-flag": "^4.0.0" 1103 | } 1104 | } 1105 | } 1106 | }, 1107 | "is-binary-path": { 1108 | "version": "2.1.0", 1109 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1110 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1111 | "dev": true, 1112 | "requires": { 1113 | "binary-extensions": "^2.0.0" 1114 | } 1115 | }, 1116 | "is-buffer": { 1117 | "version": "2.0.4", 1118 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 1119 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 1120 | "dev": true 1121 | }, 1122 | "is-callable": { 1123 | "version": "1.2.0", 1124 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.0.tgz", 1125 | "integrity": "sha512-pyVD9AaGLxtg6srb2Ng6ynWJqkHU9bEM087AKck0w8QwDarTfNcpIYoU8x8Hv2Icm8u6kFJM18Dag8lyqGkviw==", 1126 | "dev": true 1127 | }, 1128 | "is-date-object": { 1129 | "version": "1.0.2", 1130 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1131 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1132 | "dev": true 1133 | }, 1134 | "is-extglob": { 1135 | "version": "2.1.1", 1136 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1137 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1138 | "dev": true 1139 | }, 1140 | "is-fullwidth-code-point": { 1141 | "version": "3.0.0", 1142 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1143 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1144 | "dev": true 1145 | }, 1146 | "is-glob": { 1147 | "version": "4.0.1", 1148 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1149 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1150 | "dev": true, 1151 | "requires": { 1152 | "is-extglob": "^2.1.1" 1153 | } 1154 | }, 1155 | "is-number": { 1156 | "version": "7.0.0", 1157 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1158 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1159 | "dev": true 1160 | }, 1161 | "is-regex": { 1162 | "version": "1.1.1", 1163 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.1.tgz", 1164 | "integrity": "sha512-1+QkEcxiLlB7VEyFtyBg94e08OAsvq7FUBgApTq/w2ymCLyKJgDPsybBENVtA7XCQEgEXxKPonG+mvYRxh/LIg==", 1165 | "dev": true, 1166 | "requires": { 1167 | "has-symbols": "^1.0.1" 1168 | } 1169 | }, 1170 | "is-symbol": { 1171 | "version": "1.0.3", 1172 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1173 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1174 | "dev": true, 1175 | "requires": { 1176 | "has-symbols": "^1.0.1" 1177 | } 1178 | }, 1179 | "isexe": { 1180 | "version": "2.0.0", 1181 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1182 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1183 | "dev": true 1184 | }, 1185 | "js-tokens": { 1186 | "version": "4.0.0", 1187 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1188 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1189 | "dev": true 1190 | }, 1191 | "js-yaml": { 1192 | "version": "3.14.0", 1193 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 1194 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 1195 | "dev": true, 1196 | "requires": { 1197 | "argparse": "^1.0.7", 1198 | "esprima": "^4.0.0" 1199 | } 1200 | }, 1201 | "json-schema-traverse": { 1202 | "version": "0.4.1", 1203 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1204 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1205 | "dev": true 1206 | }, 1207 | "json-stable-stringify-without-jsonify": { 1208 | "version": "1.0.1", 1209 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1210 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1211 | "dev": true 1212 | }, 1213 | "levn": { 1214 | "version": "0.3.0", 1215 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1216 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1217 | "dev": true, 1218 | "requires": { 1219 | "prelude-ls": "~1.1.2", 1220 | "type-check": "~0.3.2" 1221 | } 1222 | }, 1223 | "lodash": { 1224 | "version": "4.17.19", 1225 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 1226 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==", 1227 | "dev": true 1228 | }, 1229 | "log-symbols": { 1230 | "version": "3.0.0", 1231 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz", 1232 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==", 1233 | "dev": true, 1234 | "requires": { 1235 | "chalk": "^2.4.2" 1236 | } 1237 | }, 1238 | "lower-case": { 1239 | "version": "2.0.1", 1240 | "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.1.tgz", 1241 | "integrity": "sha512-LiWgfDLLb1dwbFQZsSglpRj+1ctGnayXz3Uv0/WO8n558JycT5fg6zkNcnW0G68Nn0aEldTFeEfmjCfmqry/rQ==", 1242 | "requires": { 1243 | "tslib": "^1.10.0" 1244 | } 1245 | }, 1246 | "mimic-fn": { 1247 | "version": "2.1.0", 1248 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1249 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1250 | "dev": true 1251 | }, 1252 | "minimatch": { 1253 | "version": "3.0.4", 1254 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1255 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1256 | "requires": { 1257 | "brace-expansion": "^1.1.7" 1258 | } 1259 | }, 1260 | "minimist": { 1261 | "version": "1.2.5", 1262 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1263 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1264 | "dev": true 1265 | }, 1266 | "mkdirp": { 1267 | "version": "1.0.4", 1268 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1269 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==" 1270 | }, 1271 | "mocha": { 1272 | "version": "7.2.0", 1273 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-7.2.0.tgz", 1274 | "integrity": "sha512-O9CIypScywTVpNaRrCAgoUnJgozpIofjKUYmJhiCIJMiuYnLI6otcb1/kpW9/n/tJODHGZ7i8aLQoDVsMtOKQQ==", 1275 | "dev": true, 1276 | "requires": { 1277 | "ansi-colors": "3.2.3", 1278 | "browser-stdout": "1.3.1", 1279 | "chokidar": "3.3.0", 1280 | "debug": "3.2.6", 1281 | "diff": "3.5.0", 1282 | "escape-string-regexp": "1.0.5", 1283 | "find-up": "3.0.0", 1284 | "glob": "7.1.3", 1285 | "growl": "1.10.5", 1286 | "he": "1.2.0", 1287 | "js-yaml": "3.13.1", 1288 | "log-symbols": "3.0.0", 1289 | "minimatch": "3.0.4", 1290 | "mkdirp": "0.5.5", 1291 | "ms": "2.1.1", 1292 | "node-environment-flags": "1.0.6", 1293 | "object.assign": "4.1.0", 1294 | "strip-json-comments": "2.0.1", 1295 | "supports-color": "6.0.0", 1296 | "which": "1.3.1", 1297 | "wide-align": "1.1.3", 1298 | "yargs": "13.3.2", 1299 | "yargs-parser": "13.1.2", 1300 | "yargs-unparser": "1.6.0" 1301 | }, 1302 | "dependencies": { 1303 | "debug": { 1304 | "version": "3.2.6", 1305 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 1306 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1307 | "dev": true, 1308 | "requires": { 1309 | "ms": "^2.1.1" 1310 | } 1311 | }, 1312 | "find-up": { 1313 | "version": "3.0.0", 1314 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 1315 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 1316 | "dev": true, 1317 | "requires": { 1318 | "locate-path": "^3.0.0" 1319 | } 1320 | }, 1321 | "glob": { 1322 | "version": "7.1.3", 1323 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1324 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1325 | "dev": true, 1326 | "requires": { 1327 | "fs.realpath": "^1.0.0", 1328 | "inflight": "^1.0.4", 1329 | "inherits": "2", 1330 | "minimatch": "^3.0.4", 1331 | "once": "^1.3.0", 1332 | "path-is-absolute": "^1.0.0" 1333 | } 1334 | }, 1335 | "js-yaml": { 1336 | "version": "3.13.1", 1337 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1338 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1339 | "dev": true, 1340 | "requires": { 1341 | "argparse": "^1.0.7", 1342 | "esprima": "^4.0.0" 1343 | } 1344 | }, 1345 | "locate-path": { 1346 | "version": "3.0.0", 1347 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1348 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1349 | "dev": true, 1350 | "requires": { 1351 | "p-locate": "^3.0.0", 1352 | "path-exists": "^3.0.0" 1353 | } 1354 | }, 1355 | "mkdirp": { 1356 | "version": "0.5.5", 1357 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1358 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1359 | "dev": true, 1360 | "requires": { 1361 | "minimist": "^1.2.5" 1362 | } 1363 | }, 1364 | "ms": { 1365 | "version": "2.1.1", 1366 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1367 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1368 | "dev": true 1369 | }, 1370 | "p-locate": { 1371 | "version": "3.0.0", 1372 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1373 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1374 | "dev": true, 1375 | "requires": { 1376 | "p-limit": "^2.0.0" 1377 | } 1378 | }, 1379 | "path-exists": { 1380 | "version": "3.0.0", 1381 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1382 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1383 | "dev": true 1384 | }, 1385 | "strip-json-comments": { 1386 | "version": "2.0.1", 1387 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1388 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1389 | "dev": true 1390 | }, 1391 | "supports-color": { 1392 | "version": "6.0.0", 1393 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 1394 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 1395 | "dev": true, 1396 | "requires": { 1397 | "has-flag": "^3.0.0" 1398 | } 1399 | } 1400 | } 1401 | }, 1402 | "ms": { 1403 | "version": "2.1.2", 1404 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1405 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1406 | "dev": true 1407 | }, 1408 | "mute-stream": { 1409 | "version": "0.0.8", 1410 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1411 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1412 | "dev": true 1413 | }, 1414 | "natural-compare": { 1415 | "version": "1.4.0", 1416 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1417 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1418 | "dev": true 1419 | }, 1420 | "nice-try": { 1421 | "version": "1.0.5", 1422 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1423 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1424 | "dev": true 1425 | }, 1426 | "no-case": { 1427 | "version": "3.0.3", 1428 | "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.3.tgz", 1429 | "integrity": "sha512-ehY/mVQCf9BL0gKfsJBvFJen+1V//U+0HQMPrWct40ixE4jnv0bfvxDbWtAHL9EcaPEOJHVVYKoQn1TlZUB8Tw==", 1430 | "requires": { 1431 | "lower-case": "^2.0.1", 1432 | "tslib": "^1.10.0" 1433 | } 1434 | }, 1435 | "node-environment-flags": { 1436 | "version": "1.0.6", 1437 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.6.tgz", 1438 | "integrity": "sha512-5Evy2epuL+6TM0lCQGpFIj6KwiEsGh1SrHUhTbNX+sLbBtjidPZFAnVK9y5yU1+h//RitLbRHTIMyxQPtxMdHw==", 1439 | "dev": true, 1440 | "requires": { 1441 | "object.getownpropertydescriptors": "^2.0.3", 1442 | "semver": "^5.7.0" 1443 | }, 1444 | "dependencies": { 1445 | "semver": { 1446 | "version": "5.7.1", 1447 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1448 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1449 | "dev": true 1450 | } 1451 | } 1452 | }, 1453 | "normalize-path": { 1454 | "version": "3.0.0", 1455 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1456 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1457 | "dev": true 1458 | }, 1459 | "object-inspect": { 1460 | "version": "1.8.0", 1461 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 1462 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", 1463 | "dev": true 1464 | }, 1465 | "object-keys": { 1466 | "version": "1.1.1", 1467 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1468 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1469 | "dev": true 1470 | }, 1471 | "object.assign": { 1472 | "version": "4.1.0", 1473 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1474 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1475 | "dev": true, 1476 | "requires": { 1477 | "define-properties": "^1.1.2", 1478 | "function-bind": "^1.1.1", 1479 | "has-symbols": "^1.0.0", 1480 | "object-keys": "^1.0.11" 1481 | } 1482 | }, 1483 | "object.getownpropertydescriptors": { 1484 | "version": "2.1.0", 1485 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", 1486 | "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", 1487 | "dev": true, 1488 | "requires": { 1489 | "define-properties": "^1.1.3", 1490 | "es-abstract": "^1.17.0-next.1" 1491 | } 1492 | }, 1493 | "once": { 1494 | "version": "1.4.0", 1495 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1496 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1497 | "requires": { 1498 | "wrappy": "1" 1499 | } 1500 | }, 1501 | "onetime": { 1502 | "version": "5.1.1", 1503 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.1.tgz", 1504 | "integrity": "sha512-ZpZpjcJeugQfWsfyQlshVoowIIQ1qBGSVll4rfDq6JJVO//fesjoX808hXWfBjY+ROZgpKDI5TRSRBSoJiZ8eg==", 1505 | "dev": true, 1506 | "requires": { 1507 | "mimic-fn": "^2.1.0" 1508 | } 1509 | }, 1510 | "optionator": { 1511 | "version": "0.8.3", 1512 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 1513 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 1514 | "dev": true, 1515 | "requires": { 1516 | "deep-is": "~0.1.3", 1517 | "fast-levenshtein": "~2.0.6", 1518 | "levn": "~0.3.0", 1519 | "prelude-ls": "~1.1.2", 1520 | "type-check": "~0.3.2", 1521 | "word-wrap": "~1.2.3" 1522 | } 1523 | }, 1524 | "os-tmpdir": { 1525 | "version": "1.0.2", 1526 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1527 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1528 | "dev": true 1529 | }, 1530 | "p-limit": { 1531 | "version": "2.3.0", 1532 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 1533 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 1534 | "dev": true, 1535 | "requires": { 1536 | "p-try": "^2.0.0" 1537 | } 1538 | }, 1539 | "p-try": { 1540 | "version": "2.2.0", 1541 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1542 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1543 | "dev": true 1544 | }, 1545 | "param-case": { 1546 | "version": "3.0.3", 1547 | "resolved": "https://registry.npmjs.org/param-case/-/param-case-3.0.3.tgz", 1548 | "integrity": "sha512-VWBVyimc1+QrzappRs7waeN2YmoZFCGXWASRYX1/rGHtXqEcrGEIDm+jqIwFa2fRXNgQEwrxaYuIrX0WcAguTA==", 1549 | "requires": { 1550 | "dot-case": "^3.0.3", 1551 | "tslib": "^1.10.0" 1552 | } 1553 | }, 1554 | "parent-module": { 1555 | "version": "1.0.1", 1556 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1557 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1558 | "dev": true, 1559 | "requires": { 1560 | "callsites": "^3.0.0" 1561 | } 1562 | }, 1563 | "pascal-case": { 1564 | "version": "3.1.1", 1565 | "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.1.tgz", 1566 | "integrity": "sha512-XIeHKqIrsquVTQL2crjq3NfJUxmdLasn3TYOU0VBM+UX2a6ztAWBlJQBePLGY7VHW8+2dRadeIPK5+KImwTxQA==", 1567 | "requires": { 1568 | "no-case": "^3.0.3", 1569 | "tslib": "^1.10.0" 1570 | } 1571 | }, 1572 | "path-case": { 1573 | "version": "3.0.3", 1574 | "resolved": "https://registry.npmjs.org/path-case/-/path-case-3.0.3.tgz", 1575 | "integrity": "sha512-UMFU6UETFpCNWbIWNczshPrnK/7JAXBP2NYw80ojElbQ2+JYxdqWDBkvvqM93u4u6oLmuJ/tPOf2tM8KtXv4eg==", 1576 | "requires": { 1577 | "dot-case": "^3.0.3", 1578 | "tslib": "^1.10.0" 1579 | } 1580 | }, 1581 | "path-is-absolute": { 1582 | "version": "1.0.1", 1583 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1584 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1585 | }, 1586 | "path-key": { 1587 | "version": "2.0.1", 1588 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1589 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1590 | "dev": true 1591 | }, 1592 | "picomatch": { 1593 | "version": "2.2.2", 1594 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 1595 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 1596 | "dev": true 1597 | }, 1598 | "prelude-ls": { 1599 | "version": "1.1.2", 1600 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1601 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1602 | "dev": true 1603 | }, 1604 | "progress": { 1605 | "version": "2.0.3", 1606 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1607 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1608 | "dev": true 1609 | }, 1610 | "punycode": { 1611 | "version": "2.1.1", 1612 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1613 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1614 | "dev": true 1615 | }, 1616 | "readdirp": { 1617 | "version": "3.2.0", 1618 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.2.0.tgz", 1619 | "integrity": "sha512-crk4Qu3pmXwgxdSgGhgA/eXiJAPQiX4GMOZZMXnqKxHX7TaoL+3gQVo/WeuAiogr07DpnfjIMpXXa+PAIvwPGQ==", 1620 | "dev": true, 1621 | "requires": { 1622 | "picomatch": "^2.0.4" 1623 | } 1624 | }, 1625 | "regexpp": { 1626 | "version": "3.1.0", 1627 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1628 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1629 | "dev": true 1630 | }, 1631 | "require-directory": { 1632 | "version": "2.1.1", 1633 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1634 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1635 | "dev": true 1636 | }, 1637 | "require-main-filename": { 1638 | "version": "2.0.0", 1639 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1640 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 1641 | "dev": true 1642 | }, 1643 | "resolve-from": { 1644 | "version": "4.0.0", 1645 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1646 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1647 | "dev": true 1648 | }, 1649 | "restore-cursor": { 1650 | "version": "3.1.0", 1651 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1652 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1653 | "dev": true, 1654 | "requires": { 1655 | "onetime": "^5.1.0", 1656 | "signal-exit": "^3.0.2" 1657 | } 1658 | }, 1659 | "rimraf": { 1660 | "version": "2.6.3", 1661 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1662 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1663 | "dev": true, 1664 | "requires": { 1665 | "glob": "^7.1.3" 1666 | } 1667 | }, 1668 | "run-async": { 1669 | "version": "2.4.1", 1670 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz", 1671 | "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==", 1672 | "dev": true 1673 | }, 1674 | "rxjs": { 1675 | "version": "6.6.2", 1676 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.2.tgz", 1677 | "integrity": "sha512-BHdBMVoWC2sL26w//BCu3YzKT4s2jip/WhwsGEDmeKYBhKDZeYezVUnHatYB7L85v5xs0BAQmg6BEYJEKxBabg==", 1678 | "dev": true, 1679 | "requires": { 1680 | "tslib": "^1.9.0" 1681 | } 1682 | }, 1683 | "safer-buffer": { 1684 | "version": "2.1.2", 1685 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1686 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1687 | "dev": true 1688 | }, 1689 | "semver": { 1690 | "version": "7.3.2", 1691 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 1692 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 1693 | "dev": true 1694 | }, 1695 | "sentence-case": { 1696 | "version": "3.0.3", 1697 | "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-3.0.3.tgz", 1698 | "integrity": "sha512-ZPr4dgTcNkEfcGOMFQyDdJrTU9uQO1nb1cjf+nuzb6FxgMDgKddZOM29qEsB7jvsZSMruLRcL2KfM4ypKpa0LA==", 1699 | "requires": { 1700 | "no-case": "^3.0.3", 1701 | "tslib": "^1.10.0", 1702 | "upper-case-first": "^2.0.1" 1703 | } 1704 | }, 1705 | "set-blocking": { 1706 | "version": "2.0.0", 1707 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1708 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 1709 | "dev": true 1710 | }, 1711 | "shebang-command": { 1712 | "version": "1.2.0", 1713 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1714 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1715 | "dev": true, 1716 | "requires": { 1717 | "shebang-regex": "^1.0.0" 1718 | } 1719 | }, 1720 | "shebang-regex": { 1721 | "version": "1.0.0", 1722 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1723 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1724 | "dev": true 1725 | }, 1726 | "signal-exit": { 1727 | "version": "3.0.3", 1728 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1729 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 1730 | "dev": true 1731 | }, 1732 | "slice-ansi": { 1733 | "version": "2.1.0", 1734 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1735 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1736 | "dev": true, 1737 | "requires": { 1738 | "ansi-styles": "^3.2.0", 1739 | "astral-regex": "^1.0.0", 1740 | "is-fullwidth-code-point": "^2.0.0" 1741 | }, 1742 | "dependencies": { 1743 | "is-fullwidth-code-point": { 1744 | "version": "2.0.0", 1745 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1746 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1747 | "dev": true 1748 | } 1749 | } 1750 | }, 1751 | "snake-case": { 1752 | "version": "3.0.3", 1753 | "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.3.tgz", 1754 | "integrity": "sha512-WM1sIXEO+rsAHBKjGf/6R1HBBcgbncKS08d2Aqec/mrDSpU80SiOU41hO7ny6DToHSyrlwTYzQBIK1FPSx4Y3Q==", 1755 | "requires": { 1756 | "dot-case": "^3.0.3", 1757 | "tslib": "^1.10.0" 1758 | } 1759 | }, 1760 | "sprintf-js": { 1761 | "version": "1.0.3", 1762 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1763 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1764 | "dev": true 1765 | }, 1766 | "string-width": { 1767 | "version": "4.2.0", 1768 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1769 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1770 | "dev": true, 1771 | "requires": { 1772 | "emoji-regex": "^8.0.0", 1773 | "is-fullwidth-code-point": "^3.0.0", 1774 | "strip-ansi": "^6.0.0" 1775 | }, 1776 | "dependencies": { 1777 | "strip-ansi": { 1778 | "version": "6.0.0", 1779 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1780 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1781 | "dev": true, 1782 | "requires": { 1783 | "ansi-regex": "^5.0.0" 1784 | } 1785 | } 1786 | } 1787 | }, 1788 | "string.prototype.trimend": { 1789 | "version": "1.0.1", 1790 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 1791 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 1792 | "dev": true, 1793 | "requires": { 1794 | "define-properties": "^1.1.3", 1795 | "es-abstract": "^1.17.5" 1796 | } 1797 | }, 1798 | "string.prototype.trimstart": { 1799 | "version": "1.0.1", 1800 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 1801 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 1802 | "dev": true, 1803 | "requires": { 1804 | "define-properties": "^1.1.3", 1805 | "es-abstract": "^1.17.5" 1806 | } 1807 | }, 1808 | "strip-ansi": { 1809 | "version": "5.2.0", 1810 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1811 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1812 | "dev": true, 1813 | "requires": { 1814 | "ansi-regex": "^4.1.0" 1815 | }, 1816 | "dependencies": { 1817 | "ansi-regex": { 1818 | "version": "4.1.0", 1819 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1820 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1821 | "dev": true 1822 | } 1823 | } 1824 | }, 1825 | "strip-json-comments": { 1826 | "version": "3.1.1", 1827 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1828 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1829 | "dev": true 1830 | }, 1831 | "supports-color": { 1832 | "version": "5.5.0", 1833 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1834 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1835 | "dev": true, 1836 | "requires": { 1837 | "has-flag": "^3.0.0" 1838 | } 1839 | }, 1840 | "table": { 1841 | "version": "5.4.6", 1842 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 1843 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 1844 | "dev": true, 1845 | "requires": { 1846 | "ajv": "^6.10.2", 1847 | "lodash": "^4.17.14", 1848 | "slice-ansi": "^2.1.0", 1849 | "string-width": "^3.0.0" 1850 | }, 1851 | "dependencies": { 1852 | "emoji-regex": { 1853 | "version": "7.0.3", 1854 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 1855 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 1856 | "dev": true 1857 | }, 1858 | "is-fullwidth-code-point": { 1859 | "version": "2.0.0", 1860 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1861 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1862 | "dev": true 1863 | }, 1864 | "string-width": { 1865 | "version": "3.1.0", 1866 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1867 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1868 | "dev": true, 1869 | "requires": { 1870 | "emoji-regex": "^7.0.1", 1871 | "is-fullwidth-code-point": "^2.0.0", 1872 | "strip-ansi": "^5.1.0" 1873 | } 1874 | } 1875 | } 1876 | }, 1877 | "text-table": { 1878 | "version": "0.2.0", 1879 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1880 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1881 | "dev": true 1882 | }, 1883 | "through": { 1884 | "version": "2.3.8", 1885 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1886 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1887 | "dev": true 1888 | }, 1889 | "tmp": { 1890 | "version": "0.0.33", 1891 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1892 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1893 | "dev": true, 1894 | "requires": { 1895 | "os-tmpdir": "~1.0.2" 1896 | } 1897 | }, 1898 | "to-regex-range": { 1899 | "version": "5.0.1", 1900 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1901 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1902 | "dev": true, 1903 | "requires": { 1904 | "is-number": "^7.0.0" 1905 | } 1906 | }, 1907 | "tslib": { 1908 | "version": "1.13.0", 1909 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.13.0.tgz", 1910 | "integrity": "sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q==" 1911 | }, 1912 | "tsutils": { 1913 | "version": "3.17.1", 1914 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.17.1.tgz", 1915 | "integrity": "sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g==", 1916 | "dev": true, 1917 | "requires": { 1918 | "tslib": "^1.8.1" 1919 | } 1920 | }, 1921 | "type-check": { 1922 | "version": "0.3.2", 1923 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1924 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1925 | "dev": true, 1926 | "requires": { 1927 | "prelude-ls": "~1.1.2" 1928 | } 1929 | }, 1930 | "type-fest": { 1931 | "version": "0.8.1", 1932 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1933 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1934 | "dev": true 1935 | }, 1936 | "typescript": { 1937 | "version": "3.9.7", 1938 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.7.tgz", 1939 | "integrity": "sha512-BLbiRkiBzAwsjut4x/dsibSTB6yWpwT5qWmC2OfuCg3GgVQCSgMs4vEctYPhsaGtd0AeuuHMkjZ2h2WG8MSzRw==" 1940 | }, 1941 | "upper-case": { 1942 | "version": "2.0.1", 1943 | "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-2.0.1.tgz", 1944 | "integrity": "sha512-laAsbea9SY5osxrv7S99vH9xAaJKrw5Qpdh4ENRLcaxipjKsiaBwiAsxfa8X5mObKNTQPsupSq0J/VIxsSJe3A==", 1945 | "requires": { 1946 | "tslib": "^1.10.0" 1947 | } 1948 | }, 1949 | "upper-case-first": { 1950 | "version": "2.0.1", 1951 | "resolved": "https://registry.npmjs.org/upper-case-first/-/upper-case-first-2.0.1.tgz", 1952 | "integrity": "sha512-105J8XqQ+9RxW3l9gHZtgve5oaiR9TIwvmZAMAIZWRHe00T21cdvewKORTlOJf/zXW6VukuTshM+HXZNWz7N5w==", 1953 | "requires": { 1954 | "tslib": "^1.10.0" 1955 | } 1956 | }, 1957 | "uri-js": { 1958 | "version": "4.2.2", 1959 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1960 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1961 | "dev": true, 1962 | "requires": { 1963 | "punycode": "^2.1.0" 1964 | } 1965 | }, 1966 | "v8-compile-cache": { 1967 | "version": "2.1.1", 1968 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 1969 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 1970 | "dev": true 1971 | }, 1972 | "vscode-test": { 1973 | "version": "1.4.0", 1974 | "resolved": "https://registry.npmjs.org/vscode-test/-/vscode-test-1.4.0.tgz", 1975 | "integrity": "sha512-Jt7HNGvSE0+++Tvtq5wc4hiXLIr2OjDShz/gbAfM/mahQpy4rKBnmOK33D+MR67ATWviQhl+vpmU3p/qwSH/Pg==", 1976 | "dev": true, 1977 | "requires": { 1978 | "http-proxy-agent": "^2.1.0", 1979 | "https-proxy-agent": "^2.2.4", 1980 | "rimraf": "^2.6.3" 1981 | } 1982 | }, 1983 | "which": { 1984 | "version": "1.3.1", 1985 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1986 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1987 | "dev": true, 1988 | "requires": { 1989 | "isexe": "^2.0.0" 1990 | } 1991 | }, 1992 | "which-module": { 1993 | "version": "2.0.0", 1994 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1995 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 1996 | "dev": true 1997 | }, 1998 | "wide-align": { 1999 | "version": "1.1.3", 2000 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 2001 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 2002 | "dev": true, 2003 | "requires": { 2004 | "string-width": "^1.0.2 || 2" 2005 | }, 2006 | "dependencies": { 2007 | "ansi-regex": { 2008 | "version": "3.0.0", 2009 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 2010 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 2011 | "dev": true 2012 | }, 2013 | "is-fullwidth-code-point": { 2014 | "version": "2.0.0", 2015 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2016 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2017 | "dev": true 2018 | }, 2019 | "string-width": { 2020 | "version": "2.1.1", 2021 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2022 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2023 | "dev": true, 2024 | "requires": { 2025 | "is-fullwidth-code-point": "^2.0.0", 2026 | "strip-ansi": "^4.0.0" 2027 | } 2028 | }, 2029 | "strip-ansi": { 2030 | "version": "4.0.0", 2031 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2032 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2033 | "dev": true, 2034 | "requires": { 2035 | "ansi-regex": "^3.0.0" 2036 | } 2037 | } 2038 | } 2039 | }, 2040 | "word-wrap": { 2041 | "version": "1.2.3", 2042 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2043 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2044 | "dev": true 2045 | }, 2046 | "wrap-ansi": { 2047 | "version": "5.1.0", 2048 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 2049 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 2050 | "dev": true, 2051 | "requires": { 2052 | "ansi-styles": "^3.2.0", 2053 | "string-width": "^3.0.0", 2054 | "strip-ansi": "^5.0.0" 2055 | }, 2056 | "dependencies": { 2057 | "emoji-regex": { 2058 | "version": "7.0.3", 2059 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2060 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2061 | "dev": true 2062 | }, 2063 | "is-fullwidth-code-point": { 2064 | "version": "2.0.0", 2065 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2066 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2067 | "dev": true 2068 | }, 2069 | "string-width": { 2070 | "version": "3.1.0", 2071 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2072 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2073 | "dev": true, 2074 | "requires": { 2075 | "emoji-regex": "^7.0.1", 2076 | "is-fullwidth-code-point": "^2.0.0", 2077 | "strip-ansi": "^5.1.0" 2078 | } 2079 | } 2080 | } 2081 | }, 2082 | "wrappy": { 2083 | "version": "1.0.2", 2084 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2085 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2086 | }, 2087 | "write": { 2088 | "version": "1.0.3", 2089 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2090 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2091 | "dev": true, 2092 | "requires": { 2093 | "mkdirp": "^0.5.1" 2094 | }, 2095 | "dependencies": { 2096 | "mkdirp": { 2097 | "version": "0.5.5", 2098 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 2099 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 2100 | "dev": true, 2101 | "requires": { 2102 | "minimist": "^1.2.5" 2103 | } 2104 | } 2105 | } 2106 | }, 2107 | "y18n": { 2108 | "version": "4.0.0", 2109 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 2110 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 2111 | "dev": true 2112 | }, 2113 | "yargs": { 2114 | "version": "13.3.2", 2115 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 2116 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 2117 | "dev": true, 2118 | "requires": { 2119 | "cliui": "^5.0.0", 2120 | "find-up": "^3.0.0", 2121 | "get-caller-file": "^2.0.1", 2122 | "require-directory": "^2.1.1", 2123 | "require-main-filename": "^2.0.0", 2124 | "set-blocking": "^2.0.0", 2125 | "string-width": "^3.0.0", 2126 | "which-module": "^2.0.0", 2127 | "y18n": "^4.0.0", 2128 | "yargs-parser": "^13.1.2" 2129 | }, 2130 | "dependencies": { 2131 | "emoji-regex": { 2132 | "version": "7.0.3", 2133 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2134 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2135 | "dev": true 2136 | }, 2137 | "find-up": { 2138 | "version": "3.0.0", 2139 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 2140 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 2141 | "dev": true, 2142 | "requires": { 2143 | "locate-path": "^3.0.0" 2144 | } 2145 | }, 2146 | "is-fullwidth-code-point": { 2147 | "version": "2.0.0", 2148 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2149 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2150 | "dev": true 2151 | }, 2152 | "locate-path": { 2153 | "version": "3.0.0", 2154 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 2155 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 2156 | "dev": true, 2157 | "requires": { 2158 | "p-locate": "^3.0.0", 2159 | "path-exists": "^3.0.0" 2160 | } 2161 | }, 2162 | "p-locate": { 2163 | "version": "3.0.0", 2164 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 2165 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 2166 | "dev": true, 2167 | "requires": { 2168 | "p-limit": "^2.0.0" 2169 | } 2170 | }, 2171 | "path-exists": { 2172 | "version": "3.0.0", 2173 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2174 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2175 | "dev": true 2176 | }, 2177 | "string-width": { 2178 | "version": "3.1.0", 2179 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2180 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2181 | "dev": true, 2182 | "requires": { 2183 | "emoji-regex": "^7.0.1", 2184 | "is-fullwidth-code-point": "^2.0.0", 2185 | "strip-ansi": "^5.1.0" 2186 | } 2187 | } 2188 | } 2189 | }, 2190 | "yargs-parser": { 2191 | "version": "13.1.2", 2192 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 2193 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 2194 | "dev": true, 2195 | "requires": { 2196 | "camelcase": "^5.0.0", 2197 | "decamelize": "^1.2.0" 2198 | } 2199 | }, 2200 | "yargs-unparser": { 2201 | "version": "1.6.0", 2202 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.0.tgz", 2203 | "integrity": "sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw==", 2204 | "dev": true, 2205 | "requires": { 2206 | "flat": "^4.1.0", 2207 | "lodash": "^4.17.15", 2208 | "yargs": "^13.3.0" 2209 | } 2210 | } 2211 | } 2212 | } 2213 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "arrr", 3 | "displayName": "arrr", 4 | "description": "The extension provides refactoring tools for your Angular codebase", 5 | "version": "0.1.3", 6 | "publisher": "obenjiro", 7 | "engines": { 8 | "vscode": "^1.47.0" 9 | }, 10 | "categories": [ 11 | "Programming Languages" 12 | ], 13 | "keywords": [ 14 | "javascript", 15 | "angular", 16 | "refactoring", 17 | "typescript", 18 | "cleancode" 19 | ], 20 | "activationEvents": [ 21 | "onLanguage:html", 22 | "onCommand:extension.arrr.extract-to-folder" 23 | ], 24 | "main": "./out/extension.js", 25 | "contributes": { 26 | "commands": [ 27 | { 28 | "command": "extension.arrr.extract-to-folder", 29 | "title": "Extract Angular component to folder" 30 | } 31 | ] 32 | }, 33 | "scripts": { 34 | "vscode:prepublish": "npm run compile", 35 | "compile": "tsc -p ./", 36 | "lint": "eslint src --ext ts", 37 | "watch": "tsc -watch -p ./", 38 | "pretest": "npm run compile && npm run lint", 39 | "test": "node ./out/test/runTest.js" 40 | }, 41 | "devDependencies": { 42 | "@types/glob": "^7.1.1", 43 | "@types/mocha": "^7.0.2", 44 | "@types/node": "^13.11.0", 45 | "@types/vscode": "^1.47.0", 46 | "@typescript-eslint/eslint-plugin": "^2.30.0", 47 | "@typescript-eslint/parser": "^2.30.0", 48 | "eslint": "^6.8.0", 49 | "glob": "^7.1.6", 50 | "mocha": "^7.1.2", 51 | "vscode-test": "^1.3.0" 52 | }, 53 | "dependencies": { 54 | "@angular/compiler": "^10.0.7", 55 | "@types/mkdirp": "^1.0.1", 56 | "change-case": "^4.1.1", 57 | "glob": "^7.1.6", 58 | "typescript": "^3.8.3", 59 | "gitignore-to-glob": "^0.3.0", 60 | "mkdirp": "^1.0.4" 61 | }, 62 | "icon": "assets/icon.png", 63 | "repository": { 64 | "type": "git", 65 | "url": "https://github.com/obenjiro/vscode-arrr.git" 66 | } 67 | } 68 | -------------------------------------------------------------------------------- /src/code-actions.ts: -------------------------------------------------------------------------------- 1 | import {activeFileName, openFile, selectedTextStart, selectedTextEnd, showErrorMessage} from "./editor"; 2 | // import { shouldSwitchToTarget } from "./settings"; 3 | import { 4 | replaceTextInFile, 5 | appendTextToFile, 6 | prependTextToFile, 7 | removeContentFromFileAtLineAndColumn 8 | } from "./file-system"; 9 | 10 | export async function switchToDestinationFileIfRequired(destinationFilePath: any) { 11 | // if (shouldSwitchToTarget()) { 12 | if (false) { 13 | await openFile(destinationFilePath); 14 | } 15 | } 16 | 17 | export function replaceSelectionWith(text: string) { 18 | return replaceTextInFile(text, selectedTextStart() as any, selectedTextEnd() as any, activeFileName()); 19 | } 20 | 21 | export const appendSelectedTextToFile = ({ 22 | text: selection 23 | }, destinationPath) => { 24 | let text; 25 | text = selection; 26 | 27 | return appendTextToFile(`${text}`, destinationPath); 28 | }; 29 | -------------------------------------------------------------------------------- /src/directories-picker.ts: -------------------------------------------------------------------------------- 1 | import { 2 | toQuickPick, 3 | currentEditorPath, 4 | workspaceRoot, 5 | extractQuickPickValue, 6 | showQuickPicksList, 7 | toQuickPicksList, 8 | } from './editor'; 9 | import {subfoldersListOf, gitIgnoreFolders} from './file-system'; 10 | 11 | function getWorkspaceFolderStructure(): Promise { 12 | return new Promise((resolveWith, reject) => { 13 | const findDirectories = () => { 14 | try { 15 | resolveWith(subfoldersListOf(workspaceRoot(), gitIgnoreFolders())); 16 | } catch (error) { 17 | reject(error); 18 | } 19 | }; 20 | 21 | const delayToAllowVSCodeToRender = 1; 22 | setTimeout(findDirectories, delayToAllowVSCodeToRender); 23 | }); 24 | } 25 | 26 | const prependQuickpickForCurrentFileFolder = (quickPicksList) => { 27 | return [ 28 | toQuickPick(currentEditorPath(), 'current file directory'), 29 | ...quickPicksList, 30 | ]; 31 | }; 32 | 33 | const getQuickPicksForWorkspaceFolderStructure = () => { 34 | if (!workspaceRoot()) { 35 | return Promise.resolve([]); 36 | } 37 | return getWorkspaceFolderStructure().then(toQuickPicksList); 38 | }; 39 | 40 | export function showDirectoryPicker(): any { 41 | return getQuickPicksForWorkspaceFolderStructure() 42 | .then(prependQuickpickForCurrentFileFolder) 43 | .then((choices) => 44 | showQuickPicksList(choices, 'Pick directory that contains the file') 45 | ) 46 | .then(extractQuickPickValue) 47 | .then(cancelActionIfNeeded); 48 | } 49 | 50 | const cancelActionIfNeeded = (value: any) => 51 | value ? value : Promise.reject(false); 52 | -------------------------------------------------------------------------------- /src/editor.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | import {QuickPickItem} from 'vscode'; 3 | import * as path from 'path'; 4 | 5 | export const workspaceRoot = () => vscode.workspace.rootPath as string; 6 | 7 | export const activeURI = () => 8 | vscode.window.activeTextEditor?.document.uri as vscode.Uri; 9 | export const activeFileName = () => 10 | vscode.window.activeTextEditor?.document.fileName; 11 | 12 | export const selectedTextStart = () => 13 | vscode.window.activeTextEditor?.selection.start; 14 | export const selectedTextEnd = () => 15 | vscode.window.activeTextEditor?.selection.end; 16 | 17 | export const config = () => vscode.workspace.getConfiguration('arrr'); 18 | 19 | export function currentEditorPath(): string { 20 | const activeEditor = vscode.window.activeTextEditor; 21 | if (activeEditor) { 22 | const currentFilePath = path.dirname(activeEditor.document.fileName); 23 | const rootMatcher = new RegExp(`^${workspaceRoot()}`); 24 | return currentFilePath.replace(rootMatcher, ''); 25 | } 26 | return ''; 27 | } 28 | 29 | export function openFile(absolutePath: string): PromiseLike { 30 | return vscode.workspace 31 | .openTextDocument(absolutePath) 32 | .then((textDocument) => { 33 | if (textDocument) { 34 | vscode.window.showTextDocument(textDocument); 35 | return absolutePath; 36 | } else { 37 | throw Error('Could not open document'); 38 | } 39 | }); 40 | } 41 | 42 | export function getSelectedText() { 43 | const editor = vscode.window.activeTextEditor; 44 | if (editor) { 45 | const selection = editor.selection; 46 | return editor.document.getText(selection); 47 | } else { 48 | return null; 49 | } 50 | } 51 | 52 | export function getSelectionOffsetRange() { 53 | const editor = vscode.window.activeTextEditor; 54 | if (editor) { 55 | return { 56 | start: editor.document.offsetAt(editor.selection.start), 57 | end: editor.document.offsetAt(editor.selection.end), 58 | }; 59 | } else { 60 | return {}; 61 | } 62 | } 63 | 64 | export function showInputBox(defaultValue: string, placeHolder: string) { 65 | return vscode.window.showInputBox({ 66 | value: defaultValue, 67 | placeHolder, 68 | }); 69 | } 70 | 71 | export function showQuickPicksList(choices: QuickPickItem[], placeHolder = '') { 72 | // return vscode.window.showInputBox(); 73 | return vscode.window.showQuickPick(choices, { 74 | placeHolder, 75 | }); 76 | } 77 | 78 | export const convertRelativeToFullPath = (relativePath: string) => { 79 | const root = workspaceRoot(); 80 | return root ? path.join(root, relativePath) : relativePath; 81 | }; 82 | 83 | export const extractQuickPickValue = (selection: any) => { 84 | if (!selection) { 85 | return; 86 | } 87 | return selection.label; 88 | }; 89 | 90 | export const toQuickPick = (label: string, description?: string) => ({ 91 | label, 92 | description, 93 | }); 94 | 95 | export const toQuickPicksList = (choices: string[]) => 96 | choices.map((item) => toQuickPick(item)); 97 | 98 | export const showErrorMessage = (message: string) => 99 | vscode.window.showErrorMessage(message); 100 | 101 | export const importMissingDependencies = (targetFile: string) => 102 | vscode.commands.executeCommand( 103 | '_typescript.applyFixAllCodeAction', 104 | targetFile, 105 | {fixId: 'fixMissingImport'} 106 | ); 107 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | // The module 'vscode' contains the VS Code extensibility API 2 | // Import the module and reference it with the alias vscode in your code below 3 | import * as vscode from 'vscode'; 4 | 5 | import {extractToFolder} from './modules/extract-to-folder'; 6 | import {templateParser} from './template-parser'; 7 | import {getSelectedText} from './editor'; 8 | 9 | export class CompleteActionProvider implements vscode.CodeActionProvider { 10 | public provideCodeActions(): vscode.ProviderResult { 11 | const text = getSelectedText(); 12 | 13 | // try parse text with parser 14 | if (text) { 15 | try { 16 | const output = templateParser.parse(text); 17 | if (!output.errors) { 18 | return [ 19 | { 20 | command: 'extension.arrr.extract-to-folder', 21 | title: 'Extract Angular Component', 22 | }, 23 | ]; 24 | } 25 | } catch (err) { 26 | } 27 | } 28 | 29 | return []; 30 | } 31 | } 32 | 33 | // this method is called when your extension is activated 34 | // your extension is activated the very first time the command is executed 35 | export function activate(context: vscode.ExtensionContext) { 36 | context.subscriptions.push( 37 | vscode.commands.registerCommand( 38 | 'extension.arrr.extract-to-folder', 39 | extractToFolder 40 | ) 41 | ); 42 | 43 | context.subscriptions.push( 44 | vscode.languages.registerCodeActionsProvider( 45 | {pattern: '**/*.*'}, 46 | new CompleteActionProvider() 47 | ) 48 | ); 49 | } 50 | 51 | // this method is called when your extension is deactivated 52 | export function deactivate() { 53 | } 54 | -------------------------------------------------------------------------------- /src/file-picker.ts: -------------------------------------------------------------------------------- 1 | import { 2 | convertRelativeToFullPath, 3 | showInputBox 4 | } from './editor'; 5 | import * as vscode from 'vscode'; 6 | 7 | export function promptFileNameInput(directory) { 8 | return showInputBox(directory, 'Filename or relative path to a file').then( 9 | convertRelativeToFullPath as any 10 | ); 11 | } 12 | 13 | const NEW_FILE_OPTION: string = 'Enter Folder Name'; 14 | 15 | export function showFilePicker() { 16 | return ( 17 | vscode.window 18 | .showInputBox({ 19 | placeHolder: NEW_FILE_OPTION 20 | }) 21 | .then(cancelActionIfNeeded) 22 | ); 23 | } 24 | 25 | const cancelActionIfNeeded = (value: any) => 26 | value ? value : Promise.reject(false); 27 | -------------------------------------------------------------------------------- /src/file-system.ts: -------------------------------------------------------------------------------- 1 | import * as fs from 'fs'; 2 | import * as path from 'path'; 3 | import * as mkdirp from 'mkdirp'; 4 | import {sync as globSync} from 'glob'; 5 | import * as gitignoreToGlob from 'gitignore-to-glob'; 6 | import {workspaceRoot, activeURI} from './editor'; 7 | import * as vscode from 'vscode'; 8 | import {Position, Uri} from 'vscode'; 9 | 10 | export function createFileIfDoesntExist(absolutePath: string): string { 11 | let directoryToFile = path.dirname(absolutePath); 12 | if (!fs.existsSync(absolutePath)) { 13 | mkdirp.sync(directoryToFile); 14 | fs.appendFileSync(absolutePath, ''); 15 | } 16 | 17 | return absolutePath; 18 | } 19 | 20 | export function subfoldersListOf(root: string, ignoreList: string[]): string[] { 21 | if (!root) { 22 | return []; 23 | } 24 | 25 | const results = globSync('**', {cwd: root, ignore: ignoreList}) 26 | .filter((f) => fs.statSync(path.join(root, f)).isDirectory()) 27 | .map((f) => '/' + f); 28 | 29 | return results; 30 | } 31 | 32 | export const replaceTextInFile = ( 33 | text, 34 | start: vscode.Position, 35 | end: vscode.Position, 36 | path 37 | ) => (edit) => edit.replace(Uri.file(path), new vscode.Range(start, end), text); 38 | 39 | export async function appendTextToFile(text, absolutePath) { 40 | const edit = new vscode.WorkspaceEdit(); 41 | const linesInFile = await countLineInFile(absolutePath); 42 | 43 | edit.insert(Uri.file(absolutePath), new Position(linesInFile, 0), text); 44 | return vscode.workspace.applyEdit(edit); 45 | } 46 | 47 | export function persistFileSystemChanges(...changes) { 48 | const accumulatedEdit = new vscode.WorkspaceEdit(); 49 | changes.forEach((addChangeTo) => addChangeTo(accumulatedEdit)); 50 | return vscode.workspace.applyEdit(accumulatedEdit); 51 | } 52 | 53 | export function prependTextToFile(text, absolutePath) { 54 | const edit = new vscode.WorkspaceEdit(); 55 | edit.insert(Uri.file(absolutePath), new vscode.Position(0, 0), text); 56 | return vscode.workspace.applyEdit(edit); 57 | } 58 | 59 | const invertGlob = (pattern) => pattern.replace(/^!/, ''); 60 | 61 | export const gitIgnoreFolders = () => { 62 | const pathToLocalGitIgnore = workspaceRoot() + '/.gitignore'; 63 | return fs.existsSync(pathToLocalGitIgnore) 64 | ? gitignoreToGlob(pathToLocalGitIgnore).map(invertGlob) 65 | : []; 66 | }; 67 | 68 | export function removeContentFromFileAtLineAndColumn( 69 | start, 70 | end, 71 | path, 72 | replacement 73 | ) { 74 | let edit = new vscode.WorkspaceEdit(); 75 | edit.delete(activeURI(), new vscode.Range(start, end)); 76 | return vscode.workspace.applyEdit(edit); 77 | } 78 | 79 | function countLineInFile(file): Promise { 80 | return new Promise((resolve) => { 81 | let i; 82 | let count = 0; 83 | fs.createReadStream(file) 84 | .on('data', function (chunk) { 85 | for (i = 0; i < chunk.length; ++i) { 86 | if (chunk[i] === 10) { 87 | count++; 88 | } 89 | } 90 | }) 91 | .on('end', function () { 92 | resolve(count); 93 | }); 94 | }); 95 | } 96 | -------------------------------------------------------------------------------- /src/modules/extract-to-folder-template.ts: -------------------------------------------------------------------------------- 1 | import {pascalCase} from "change-case"; 2 | 3 | export function getSpecText(componentName: string): any { 4 | return `import { async, ComponentFixture, TestBed } from '@angular/core/testing'; 5 | 6 | import { ${pascalCase( 7 | componentName 8 | )}Component } from './${componentName}.component'; 9 | 10 | describe('${pascalCase(componentName)}Component', () => { 11 | let component: ${pascalCase(componentName)}Component; 12 | let fixture: ComponentFixture<${pascalCase(componentName)}Component>; 13 | 14 | beforeEach(async(() => { 15 | TestBed.configureTestingModule({ 16 | declarations: [ ${pascalCase(componentName)}Component ] 17 | }) 18 | .compileComponents(); 19 | })); 20 | 21 | beforeEach(() => { 22 | fixture = TestBed.createComponent(${pascalCase( 23 | componentName 24 | )}Component); 25 | component = fixture.componentInstance; 26 | fixture.detectChanges(); 27 | }); 28 | 29 | it('should be created', () => { 30 | expect(component).toBeTruthy(); 31 | }); 32 | });`; 33 | } 34 | 35 | export function getComponentText(componentName: string, targets: string[], sourceComponentConfig: any): string { 36 | return `import { Component, Input } from '@angular/core'; 37 | 38 | @Component({ 39 | selector: 'app-${componentName}', 40 | templateUrl: './${componentName}.component.html', 41 | styleUrls: ['./${componentName}.component.${sourceComponentConfig.styleExt}'] 42 | }) 43 | export class ${pascalCase(componentName)}Component { 44 | ${targets.map((target) => `@Input() ${target}`).join('\n ')} 45 | constructor () {} 46 | }`; 47 | } 48 | 49 | export function getComponentInstance( 50 | componentName: string, 51 | targets: string[] 52 | ): string { 53 | return ` `[${target}]="${target}"`) 55 | .join(' ')}>`; 56 | } 57 | -------------------------------------------------------------------------------- /src/modules/extract-to-folder.ts: -------------------------------------------------------------------------------- 1 | import * as fs from "fs"; 2 | import * as path from "path"; 3 | import * as vscode from "vscode"; 4 | import { 5 | activeFileName, 6 | getSelectedText, 7 | getSelectionOffsetRange, 8 | importMissingDependencies, 9 | workspaceRoot, 10 | } from "../editor"; 11 | import { getAllTargets } from "../template-parser"; 12 | import { showFilePicker } from "../file-picker"; 13 | import { 14 | createFileIfDoesntExist, 15 | persistFileSystemChanges, 16 | replaceTextInFile, 17 | } from "../file-system"; 18 | import { pascalCase } from "change-case"; 19 | import { 20 | appendSelectedTextToFile, 21 | replaceSelectionWith, 22 | } from "../code-actions"; 23 | import { showDirectoryPicker } from "../directories-picker"; 24 | import { 25 | getComponentInstance, 26 | getComponentText, 27 | getSpecText, 28 | } from "./extract-to-folder-template"; 29 | 30 | export async function extractToFolder() { 31 | const { start, end } = getSelectionOffsetRange(); 32 | 33 | if (start && end) { 34 | try { 35 | const text = getSelectedText() || ""; 36 | const componentText = await getComponentTextFromHtmlFileName( 37 | activeFileName() 38 | ); 39 | const targets = getAllTargets(text); 40 | const sourceComponentConfig = await getCurrentComponentConfig(componentText); 41 | 42 | try { 43 | const rootPath = workspaceRoot(); 44 | const folderPath = await showDirectoryPicker(); 45 | const fileName = (await showFilePicker()) as string; 46 | 47 | let fullPath; 48 | if (folderPath.indexOf(rootPath) > -1) { 49 | fullPath = path.join(folderPath, fileName); 50 | } else { 51 | fullPath = path.join(rootPath || '', folderPath, fileName); 52 | } 53 | 54 | const htmlFilePath = `${fullPath}/${fileName}.component.html`; 55 | const cssFilePath = `${fullPath}/${fileName}.component.${sourceComponentConfig.styleExt}`; 56 | const tsFilePath = `${fullPath}/${fileName}.component.ts`; 57 | const specFilePath = `${fullPath}/${fileName}.component.spec.ts`; 58 | 59 | await createFileIfDoesntExist(htmlFilePath); 60 | await createFileIfDoesntExist(cssFilePath); 61 | await createFileIfDoesntExist(tsFilePath); 62 | await createFileIfDoesntExist(specFilePath); 63 | 64 | await appendSelectedTextToFile({ text }, htmlFilePath); 65 | await appendSelectedTextToFile({ text: `` }, cssFilePath); 66 | await appendSelectedTextToFile( 67 | { text: getComponentText(fileName, targets, sourceComponentConfig) }, 68 | tsFilePath 69 | ); 70 | await appendSelectedTextToFile( 71 | { text: getSpecText(fileName) }, 72 | specFilePath 73 | ); 74 | 75 | const componentInstance = getComponentInstance(fileName, targets); 76 | await persistFileSystemChanges(replaceSelectionWith(componentInstance)); 77 | 78 | const moduleUris = await vscode.workspace.findFiles( 79 | "**/*.module.ts", 80 | "**/node_modules/**" 81 | ); 82 | const moduleDocuments = await Promise.all( 83 | moduleUris.map((uri) => vscode.workspace.openTextDocument(uri)) 84 | ); 85 | 86 | const targetModuleDocuments = moduleDocuments.filter( 87 | (moduleDocument) => { 88 | const allText = moduleDocument.getText(); 89 | return new RegExp(`\\b${sourceComponentConfig.componentName}\\b`).test(allText); 90 | } 91 | ); 92 | 93 | const changes = await Promise.all( 94 | targetModuleDocuments.map((moduleDocument) => { 95 | const allText = moduleDocument.getText(); 96 | const matches = allText.match(/declarations\s*:\s*\[/) || []; 97 | 98 | const idx = matches.index || 0; 99 | const startOffset = idx; 100 | const endOffset = idx + matches[0].length; 101 | 102 | const start = moduleDocument.positionAt(startOffset); 103 | const end = moduleDocument.positionAt(endOffset); 104 | const targetText = `${matches[0]}\n ${pascalCase( 105 | fileName 106 | )}Component,`; 107 | 108 | return replaceTextInFile( 109 | targetText, 110 | start, 111 | end, 112 | moduleDocument.fileName 113 | ); 114 | }) 115 | ); 116 | 117 | await persistFileSystemChanges(...changes); 118 | await Promise.all( 119 | targetModuleDocuments.map((moduleDocument) => { 120 | return importMissingDependencies(moduleDocument.fileName); 121 | }) 122 | ); 123 | } catch (e) { 124 | vscode.window.showErrorMessage(e.message); 125 | } 126 | } catch (err) { 127 | console.error(err); 128 | } 129 | } 130 | } 131 | 132 | async function getComponentTextFromHtmlFileName(filePath): Promise { 133 | const name = path.basename(filePath); 134 | const dir = path.dirname(filePath); 135 | 136 | const tsPath = path.join(dir, name.replace(".html", ".ts")); 137 | const tsContent = fs.readFileSync(tsPath, "utf-8"); 138 | 139 | return tsContent; 140 | } 141 | 142 | async function getCurrentComponentConfig(componentText) { 143 | try { 144 | const ts = require('typescript'); 145 | const node = ts.createSourceFile( 146 | 'x.ts', 147 | componentText, 148 | ts.ScriptTarget.Latest // langugeVersion 149 | ); 150 | 151 | let classDecl; 152 | node.forEachChild(child => { 153 | if ( 154 | ts.SyntaxKind[child.kind] === 'ClassDeclaration' && 155 | child.decorators[0].expression.expression.escapedText === 'Component' 156 | ) { 157 | classDecl = child; 158 | } 159 | }); 160 | // const decoratorName = classDecl.decorators[0].expression.expression.escapedText; 161 | const decoratorParams = 162 | classDecl.decorators[0].expression.arguments.reduce((acc, el) => { 163 | el.properties.forEach( 164 | prop => acc[prop.name.escapedText] = prop.initializer.elements ? prop.initializer.elements.map(e => e.text) : prop.initializer.text 165 | ); 166 | return acc; 167 | }, {}); 168 | 169 | const styleInline = Boolean(decoratorParams.style); 170 | 171 | return { 172 | componentName: classDecl.name.escapedText, 173 | styleInline, 174 | styleExt: styleInline ? 'css': trimChar(path.extname(decoratorParams.styleUrls[0] || 'fail.css'), '.') 175 | }; 176 | 177 | } catch (e) { 178 | 179 | return { 180 | componentName: (componentText.match(/export class\s+([\w_]+)/) || [])[1], 181 | styleInline: false, 182 | styleExt: 'css' 183 | }; 184 | 185 | } 186 | } 187 | 188 | function escapeRegExp(strToEscape) { 189 | // Escape special characters for use in a regular expression 190 | return strToEscape.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&"); 191 | }; 192 | 193 | function trimChar(origString, charToTrim) { 194 | charToTrim = escapeRegExp(charToTrim); 195 | var regEx = new RegExp("^[" + charToTrim + "]+|[" + charToTrim + "]+$", "g"); 196 | return origString.replace(regEx, ""); 197 | }; -------------------------------------------------------------------------------- /src/template-parser.ts: -------------------------------------------------------------------------------- 1 | import * as ng from '@angular/compiler'; 2 | 3 | export const templateParser = { 4 | locationProps: new Set([ 5 | 'span', 6 | 'sourceSpan', 7 | 'startSourceSpan', 8 | 'endSourceSpan', 9 | ]), 10 | typeProps: new Set(['name']), 11 | 12 | parse(code: string, options?: ng.ParseTemplateOptions) { 13 | const ast = ng.parseTemplate(code, 'astexplorer.html', options); 14 | fixSpan(ast, code); 15 | return ast; 16 | }, 17 | 18 | nodeToRange(node: any) { 19 | if (node.startSourceSpan) { 20 | if (node.endSourceSpan) { 21 | return [ 22 | node.startSourceSpan.start.offset, 23 | node.endSourceSpan.end.offset, 24 | ]; 25 | } 26 | return [ 27 | node.startSourceSpan.start.offset, 28 | node.startSourceSpan.end.offset, 29 | ]; 30 | } 31 | if (node.sourceSpan) { 32 | return [node.sourceSpan.start.offset, node.sourceSpan.end.offset]; 33 | } 34 | if (node.span) { 35 | return [node.span.start, node.span.end]; 36 | } 37 | }, 38 | 39 | getNodeName(node: { name: any }) { 40 | let name = getNodeCtor(node); 41 | if (node.name) { 42 | name += `(${node.name})`; 43 | } 44 | return name; 45 | }, 46 | 47 | getDefaultOptions() { 48 | return { 49 | preserveWhitespaces: false, 50 | }; 51 | }, 52 | }; 53 | 54 | export function getNodeCtor(node: { 55 | name?: any; 56 | sourceSpan?: { start: { offset: any } }; 57 | constructor?: any; 58 | }) { 59 | return node.constructor && node.constructor.name; 60 | } 61 | 62 | /** 63 | * Locations from sub AST are counted from that part of string, 64 | * we need to fix them to make autofocus work. 65 | * 66 | * Before: 67 | * 68 | * 69 | * ^^^^^^^^^^ sub AST { start: 0, end: 10 } 70 | * 71 | * After: 72 | * 73 | * 74 | * ^^^^^^^^^^ sub AST { start: 13, end: 23 } 75 | */ 76 | function fixSpan(ast: any, code: string) { 77 | function getBaseStart(parent: { sourceSpan: { start: { offset: any } } }) { 78 | const nodeName = getNodeCtor(parent); 79 | switch (nodeName) { 80 | case 'BoundAttribute': 81 | case 'BoundEvent': { 82 | let offset = parent.sourceSpan.start.offset; 83 | while (code[offset++] !== '=') {} 84 | if (code[offset] === "'" || code[offset] === '"') { 85 | offset++; 86 | } 87 | return offset; 88 | } 89 | case 'BoundText': 90 | return parent.sourceSpan.start.offset; 91 | default: 92 | throw new Error(`Unexpected node ${nodeName}`); 93 | } 94 | } 95 | 96 | visitTarget( 97 | ast, 98 | (value: any) => getNodeCtor(value) === 'ASTWithSource', 99 | (node: any, parent: any) => { 100 | const baseStart = getBaseStart(parent); 101 | visitTarget( 102 | node, 103 | (value: any) => value.span, 104 | (node: any) => { 105 | node.span.start += baseStart; 106 | node.span.end += baseStart; 107 | return KEEP_VISIT; 108 | } 109 | ); 110 | } 111 | ); 112 | } 113 | 114 | export const KEEP_VISIT = 1; 115 | 116 | export function visitTarget( 117 | value: any, 118 | isTarget: Function, 119 | fn: Function, 120 | parent?: any 121 | ) { 122 | if (value !== null && typeof value === 'object') { 123 | if (isTarget(value)) { 124 | if (fn(value, parent) !== KEEP_VISIT) { 125 | return; 126 | } 127 | } 128 | if (Array.isArray(value)) { 129 | value.forEach((subValue) => visitTarget(subValue, isTarget, fn, value)); 130 | } else { 131 | for (const key in value) { 132 | visitTarget(value[key], isTarget, fn, value); 133 | } 134 | } 135 | } 136 | } 137 | 138 | export function getAllTargets(text) { 139 | const output = templateParser.parse(text); 140 | const ast = output.nodes; 141 | const targets: string[] = []; 142 | 143 | visitTarget( 144 | ast, 145 | (value: any) => { 146 | return ( 147 | (getNodeCtor(value) === "PropertyRead" && 148 | getNodeCtor(value.receiver) === "ImplicitReceiver") || 149 | (getNodeCtor(value) === "MethodCall" && 150 | getNodeCtor(value.receiver) === "ImplicitReceiver") 151 | ); 152 | }, 153 | (node: any, parent: any) => { 154 | targets.push(node.name); 155 | return KEEP_VISIT; 156 | } 157 | ); 158 | 159 | // removing variables refrences 160 | visitTarget( 161 | ast, 162 | (value: any) => { 163 | return getNodeCtor(value) === "Variable" || getNodeCtor(value) === "Reference"; 164 | }, 165 | (node: any, parent: any) => { 166 | if (targets.indexOf(node.name) > -1) { 167 | targets.splice(targets.indexOf(node.name)); 168 | } 169 | return KEEP_VISIT; 170 | } 171 | ); 172 | 173 | return [...new Set(targets)]; 174 | } -------------------------------------------------------------------------------- /src/test/runTest.ts: -------------------------------------------------------------------------------- 1 | import * as path from 'path'; 2 | 3 | import { runTests } from 'vscode-test'; 4 | 5 | async function main() { 6 | try { 7 | // The folder containing the Extension Manifest package.json 8 | // Passed to `--extensionDevelopmentPath` 9 | const extensionDevelopmentPath = path.resolve(__dirname, '../../'); 10 | 11 | // The path to test runner 12 | // Passed to --extensionTestsPath 13 | const extensionTestsPath = path.resolve(__dirname, './suite/index'); 14 | 15 | // Download VS Code, unzip it and run the integration test 16 | await runTests({ extensionDevelopmentPath, extensionTestsPath }); 17 | } catch (err) { 18 | console.error('Failed to run tests'); 19 | process.exit(1); 20 | } 21 | } 22 | 23 | main(); 24 | -------------------------------------------------------------------------------- /src/test/suite/extension.test.ts: -------------------------------------------------------------------------------- 1 | import * as assert from 'assert'; 2 | 3 | // You can import and use all API from the 'vscode' module 4 | // as well as import your extension to test it 5 | import * as vscode from 'vscode'; 6 | // import * as myExtension from '../../extension'; 7 | 8 | suite('Extension Test Suite', () => { 9 | vscode.window.showInformationMessage('Start all tests.'); 10 | 11 | test('Sample test', () => { 12 | assert.equal(-1, [1, 2, 3].indexOf(5)); 13 | assert.equal(-1, [1, 2, 3].indexOf(0)); 14 | }); 15 | }); 16 | -------------------------------------------------------------------------------- /src/test/suite/index.ts: -------------------------------------------------------------------------------- 1 | import * as path from 'path'; 2 | import * as Mocha from 'mocha'; 3 | import * as glob from 'glob'; 4 | 5 | export function run(): Promise { 6 | // Create the mocha test 7 | const mocha = new Mocha({ 8 | ui: 'tdd', 9 | color: true 10 | }); 11 | 12 | const testsRoot = path.resolve(__dirname, '..'); 13 | 14 | return new Promise((c, e) => { 15 | glob('**/**.test.js', { cwd: testsRoot }, (err, files) => { 16 | if (err) { 17 | return e(err); 18 | } 19 | 20 | // Add files to the test suite 21 | files.forEach(f => mocha.addFile(path.resolve(testsRoot, f))); 22 | 23 | try { 24 | // Run the mocha test 25 | mocha.run(failures => { 26 | if (failures > 0) { 27 | e(new Error(`${failures} tests failed.`)); 28 | } else { 29 | c(); 30 | } 31 | }); 32 | } catch (err) { 33 | console.error(err); 34 | e(err); 35 | } 36 | }); 37 | }); 38 | } 39 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": [ 7 | "es6" 8 | ], 9 | "sourceMap": true, 10 | "rootDir": "src", 11 | "allowJs": true, 12 | "strict": true, /* enable all strict type-checking options */ 13 | "noImplicitAny": false 14 | /* Additional Checks */ 15 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 16 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 17 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 18 | }, 19 | "exclude": [ 20 | "out", 21 | "node_modules", 22 | ".vscode-test" 23 | ] 24 | } 25 | --------------------------------------------------------------------------------