├── .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 | [](https://marketplace.visualstudio.com/items?itemName=obenjiro.arrr&wt.mc_id=angular_essentials-github-jopapa) [](https://marketplace.visualstudio.com/items?itemName=obenjiro.arrr) [](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 | 
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 |
--------------------------------------------------------------------------------