├── .eslintrc.json ├── .gitignore ├── .vscode ├── extensions.json └── settings.json ├── LICENSE ├── README.md ├── default.project.json ├── package-lock.json ├── package.json ├── src ├── App │ ├── counter.tsx │ └── index.tsx ├── Components │ ├── Close.tsx │ ├── Dynamic │ │ ├── ScrollingFrame.tsx │ │ └── TextLabel.tsx │ ├── Item.tsx │ ├── Panel.tsx │ ├── Tab.tsx │ └── Toggle.tsx ├── Context.tsx ├── Main.client.tsx ├── Pages │ ├── Inventory │ │ ├── index.tsx │ │ └── owned.tsx │ └── Shop │ │ ├── gamepass.tsx │ │ ├── index.tsx │ │ └── money.tsx ├── Router.tsx ├── Stories │ ├── App.story.tsx │ ├── Inventory.story.tsx │ ├── Main.story.tsx │ └── Shop.story.tsx └── Toggles.tsx └── tsconfig.json /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "parser": "@typescript-eslint/parser", 3 | "parserOptions": { 4 | "jsx": true, 5 | "useJSXTextNode": true, 6 | "ecmaVersion": 2018, 7 | "sourceType": "module", 8 | "project": "./tsconfig.json" 9 | }, 10 | "plugins": [ 11 | "@typescript-eslint", 12 | "roblox-ts", 13 | "prettier" 14 | ], 15 | "extends": [ 16 | "plugin:@typescript-eslint/recommended", 17 | "plugin:roblox-ts/recommended", 18 | "prettier/@typescript-eslint", 19 | "plugin:prettier/recommended" 20 | ], 21 | "rules": { 22 | "prettier/prettier": [ 23 | "warn", 24 | { 25 | "semi": true, 26 | "trailingComma": "all", 27 | "singleQuote": false, 28 | "printWidth": 120, 29 | "tabWidth": 4, 30 | "useTabs": true 31 | } 32 | ] 33 | } 34 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | /out 3 | /include 4 | *.tsbuildinfo 5 | -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | "recommendations": [ 3 | "roblox-ts.vscode-roblox-ts", 4 | "dbaeumer.vscode-eslint" 5 | ] 6 | } -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | { 2 | "[typescript]": { 3 | "editor.defaultFormatter": "dbaeumer.vscode-eslint", 4 | "editor.formatOnSave": true 5 | }, 6 | "[typescriptreact]": { 7 | "editor.defaultFormatter": "dbaeumer.vscode-eslint", 8 | "editor.formatOnSave": true 9 | }, 10 | "eslint.run": "onType", 11 | "eslint.format.enable": true, 12 | "typescript.tsdk": "node_modules/typescript/lib" 13 | } -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | This is free and unencumbered software released into the public domain. 2 | 3 | Anyone is free to copy, modify, publish, use, compile, sell, or 4 | distribute this software, either in source code form or as a compiled 5 | binary, for any purpose, commercial or non-commercial, and by any 6 | means. 7 | 8 | In jurisdictions that recognize copyright laws, the author or authors 9 | of this software dedicate any and all copyright interest in the 10 | software to the public domain. We make this dedication for the benefit 11 | of the public at large and to the detriment of our heirs and 12 | successors. We intend this dedication to be an overt act of 13 | relinquishment in perpetuity of all present and future rights to this 14 | software under copyright law. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR 20 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 21 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 22 | OTHER DEALINGS IN THE SOFTWARE. 23 | 24 | For more information, please refer to 25 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |
2 |

Components

3 | 4 | [![twitter](https://img.shields.io/badge/follow-twitter-red?style=flat-square)](https://twitter.com/Mullets_Gavin) 5 | [![twitter](https://img.shields.io/badge/visit-portfolio-blueviolet?style=flat-square)](https://mullets.xyz) 6 | [![support](https://img.shields.io/badge/support-mullets-blue?style=flat-square)](https://www.buymeacoffee.com/mullets) 7 | 8 | *An open source UI project written in Roblox TypeScript utilizing TSX.* 9 |
10 | 11 | ## About 12 | 13 | Components was created to help provide an open source project to help educate and improve your skills with [Roblox-TS](https://roblox-ts.com) using TSX. You can read more about TSX [here](https://roblox-ts.com/docs/guides/roact-jsx). This project contains a basic outline for a shop, inventory, and money counter. While this is a template for designing UI, you should use this project to learn from and create your own design and system. 14 | 15 | ## Installation 16 | 17 | Prerequisites: 18 | - Roact [🔗](https://roblox.github.io/roact/) 19 | - Roblox-TS [🔗](https://roblox-ts.com/docs/) 20 | - NPM [🔗](https://nodejs.org/en/) 21 | - VSCode [🔗](https://code.visualstudio.com/) 22 | 23 | Tooling: 24 | - Hoarcekat [🔗](https://github.com/Kampfkarren/hoarcekat) 25 | - Rojo [🔗](https://rojo.space/docs/installation/) 26 | 27 | Instructions: 28 | - Git clone this repository 29 | - Open up the command line and run `npm install` 30 | - Using the command line, run `rbxtsc -w` to compile the TypeScript 31 | - Run `Rojo: Start server` and sync to a Roblox place 32 | - That's it! View the UI live with Hoarcekat utilizing the stories or jump into a play session 33 | 34 | ## Demo 35 | 36 | ![components demo](https://media.giphy.com/media/HbYNtbGlnwfNLF9Y2S/giphy.gif) 37 | 38 | ## License 39 | 40 | This project is licensed under the Unlicense. See [LICENSE](https://github.com/Mullets-Gavin/Components/blob/master/LICENSE) for details. 41 | -------------------------------------------------------------------------------- /default.project.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "roact-tsx", 3 | "tree": { 4 | "$className": "DataModel", 5 | "ReplicatedStorage": { 6 | "$className": "ReplicatedStorage", 7 | "rbxts_include": { 8 | "$path": "include", 9 | "node_modules": { 10 | "$path": "node_modules/@rbxts" 11 | } 12 | } 13 | }, 14 | "StarterPlayer": { 15 | "$className": "StarterPlayer", 16 | "StarterPlayerScripts": { 17 | "$className": "StarterPlayerScripts", 18 | "$path": "out" 19 | } 20 | } 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "learning-tsx", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "version": "1.0.0", 9 | "license": "ISC", 10 | "dependencies": { 11 | "@rbxts/roact": "^1.3.0-ts.10", 12 | "@rbxts/services": "^1.1.2" 13 | }, 14 | "devDependencies": { 15 | "@rbxts/compiler-types": "^1.0.0-beta.15.0", 16 | "@rbxts/types": "^1.0.441", 17 | "@typescript-eslint/eslint-plugin": "^4.14.0", 18 | "@typescript-eslint/parser": "^4.14.0", 19 | "eslint": "^7.18.0", 20 | "eslint-config-prettier": "^7.2.0", 21 | "eslint-plugin-prettier": "^3.3.1", 22 | "eslint-plugin-roblox-ts": "^0.0.24", 23 | "prettier": "^2.2.1", 24 | "typescript": "^4.1.3" 25 | } 26 | }, 27 | "node_modules/@babel/code-frame": { 28 | "version": "7.12.11", 29 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 30 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 31 | "dev": true, 32 | "dependencies": { 33 | "@babel/highlight": "^7.10.4" 34 | } 35 | }, 36 | "node_modules/@babel/helper-validator-identifier": { 37 | "version": "7.12.11", 38 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", 39 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", 40 | "dev": true 41 | }, 42 | "node_modules/@babel/highlight": { 43 | "version": "7.10.4", 44 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 45 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 46 | "dev": true, 47 | "dependencies": { 48 | "@babel/helper-validator-identifier": "^7.10.4", 49 | "chalk": "^2.0.0", 50 | "js-tokens": "^4.0.0" 51 | } 52 | }, 53 | "node_modules/@babel/highlight/node_modules/ansi-styles": { 54 | "version": "3.2.1", 55 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 56 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 57 | "dev": true, 58 | "dependencies": { 59 | "color-convert": "^1.9.0" 60 | }, 61 | "engines": { 62 | "node": ">=4" 63 | } 64 | }, 65 | "node_modules/@babel/highlight/node_modules/chalk": { 66 | "version": "2.4.2", 67 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 68 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 69 | "dev": true, 70 | "dependencies": { 71 | "ansi-styles": "^3.2.1", 72 | "escape-string-regexp": "^1.0.5", 73 | "supports-color": "^5.3.0" 74 | }, 75 | "engines": { 76 | "node": ">=4" 77 | } 78 | }, 79 | "node_modules/@babel/highlight/node_modules/color-convert": { 80 | "version": "1.9.3", 81 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 82 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 83 | "dev": true, 84 | "dependencies": { 85 | "color-name": "1.1.3" 86 | } 87 | }, 88 | "node_modules/@babel/highlight/node_modules/color-name": { 89 | "version": "1.1.3", 90 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 91 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 92 | "dev": true 93 | }, 94 | "node_modules/@babel/highlight/node_modules/has-flag": { 95 | "version": "3.0.0", 96 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 97 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 98 | "dev": true, 99 | "engines": { 100 | "node": ">=4" 101 | } 102 | }, 103 | "node_modules/@babel/highlight/node_modules/supports-color": { 104 | "version": "5.5.0", 105 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 106 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 107 | "dev": true, 108 | "dependencies": { 109 | "has-flag": "^3.0.0" 110 | }, 111 | "engines": { 112 | "node": ">=4" 113 | } 114 | }, 115 | "node_modules/@eslint/eslintrc": { 116 | "version": "0.3.0", 117 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.3.0.tgz", 118 | "integrity": "sha512-1JTKgrOKAHVivSvOYw+sJOunkBjUOvjqWk1DPja7ZFhIS2mX/4EgTT8M7eTK9jrKhL/FvXXEbQwIs3pg1xp3dg==", 119 | "dev": true, 120 | "dependencies": { 121 | "ajv": "^6.12.4", 122 | "debug": "^4.1.1", 123 | "espree": "^7.3.0", 124 | "globals": "^12.1.0", 125 | "ignore": "^4.0.6", 126 | "import-fresh": "^3.2.1", 127 | "js-yaml": "^3.13.1", 128 | "lodash": "^4.17.20", 129 | "minimatch": "^3.0.4", 130 | "strip-json-comments": "^3.1.1" 131 | }, 132 | "engines": { 133 | "node": "^10.12.0 || >=12.0.0" 134 | } 135 | }, 136 | "node_modules/@nodelib/fs.scandir": { 137 | "version": "2.1.4", 138 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.4.tgz", 139 | "integrity": "sha512-33g3pMJk3bg5nXbL/+CY6I2eJDzZAni49PfJnL5fghPTggPvBd/pFNSgJsdAgWptuFu7qq/ERvOYFlhvsLTCKA==", 140 | "dev": true, 141 | "dependencies": { 142 | "@nodelib/fs.stat": "2.0.4", 143 | "run-parallel": "^1.1.9" 144 | }, 145 | "engines": { 146 | "node": ">= 8" 147 | } 148 | }, 149 | "node_modules/@nodelib/fs.stat": { 150 | "version": "2.0.4", 151 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.4.tgz", 152 | "integrity": "sha512-IYlHJA0clt2+Vg7bccq+TzRdJvv19c2INqBSsoOLp1je7xjtr7J26+WXR72MCdvU9q1qTzIWDfhMf+DRvQJK4Q==", 153 | "dev": true, 154 | "engines": { 155 | "node": ">= 8" 156 | } 157 | }, 158 | "node_modules/@nodelib/fs.walk": { 159 | "version": "1.2.6", 160 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.6.tgz", 161 | "integrity": "sha512-8Broas6vTtW4GIXTAHDoE32hnN2M5ykgCpWGbuXHQ15vEMqr23pB76e/GZcYsZCHALv50ktd24qhEyKr6wBtow==", 162 | "dev": true, 163 | "dependencies": { 164 | "@nodelib/fs.scandir": "2.1.4", 165 | "fastq": "^1.6.0" 166 | }, 167 | "engines": { 168 | "node": ">= 8" 169 | } 170 | }, 171 | "node_modules/@rbxts/compiler-types": { 172 | "version": "1.0.0-beta.15.0", 173 | "resolved": "https://registry.npmjs.org/@rbxts/compiler-types/-/compiler-types-1.0.0-beta.15.0.tgz", 174 | "integrity": "sha512-Tutr3dkD2bUOCeMIxHXHPYda0blPTZJ1KDRSj0TJ942QKSjxP4Pf09G/ZzySpX094uWLNndgGO9W9UmtmrvP6g==", 175 | "dev": true 176 | }, 177 | "node_modules/@rbxts/roact": { 178 | "version": "1.3.0-ts.10", 179 | "resolved": "https://registry.npmjs.org/@rbxts/roact/-/roact-1.3.0-ts.10.tgz", 180 | "integrity": "sha512-hLrSMsbFtfjzN+G2IYXYzzoJrmrk2CrszpmcrwCQhcZhlwbQXpZNaN55NSpde6B1QGuW6MoS5Q7Q/PAouNOGKQ==" 181 | }, 182 | "node_modules/@rbxts/services": { 183 | "version": "1.1.2", 184 | "resolved": "https://registry.npmjs.org/@rbxts/services/-/services-1.1.2.tgz", 185 | "integrity": "sha512-vxlo00Q/F1Yq3yGa5jisI1lkWuByJzLs2rfidA4e0wkLCBR0Od+BG55TBMzptCVUZjHUSefif4Mtl3d3a6IxyA==" 186 | }, 187 | "node_modules/@rbxts/types": { 188 | "version": "1.0.441", 189 | "resolved": "https://registry.npmjs.org/@rbxts/types/-/types-1.0.441.tgz", 190 | "integrity": "sha512-uPjojU10lXfbWeT2oh4NUbgcQfL13Tme/AO0VruRkDKSAObvspeA8rUe538awng+Ut3bpuxFVTXBXwYoMeqGtA==", 191 | "dev": true 192 | }, 193 | "node_modules/@types/json-schema": { 194 | "version": "7.0.7", 195 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.7.tgz", 196 | "integrity": "sha512-cxWFQVseBm6O9Gbw1IWb8r6OS4OhSt3hPZLkFApLjM8TEXROBuQGLAH2i2gZpcXdLBIrpXuTDhH7Vbm1iXmNGA==", 197 | "dev": true 198 | }, 199 | "node_modules/@types/node": { 200 | "version": "14.14.22", 201 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.22.tgz", 202 | "integrity": "sha512-g+f/qj/cNcqKkc3tFqlXOYjrmZA+jNBiDzbP3kH+B+otKFqAdPgVTGP1IeKRdMml/aE69as5S4FqtxAbl+LaMw==", 203 | "dev": true 204 | }, 205 | "node_modules/@typescript-eslint/eslint-plugin": { 206 | "version": "4.14.0", 207 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-4.14.0.tgz", 208 | "integrity": "sha512-IJ5e2W7uFNfg4qh9eHkHRUCbgZ8VKtGwD07kannJvM5t/GU8P8+24NX8gi3Hf5jST5oWPY8kyV1s/WtfiZ4+Ww==", 209 | "dev": true, 210 | "dependencies": { 211 | "@typescript-eslint/experimental-utils": "4.14.0", 212 | "@typescript-eslint/scope-manager": "4.14.0", 213 | "debug": "^4.1.1", 214 | "functional-red-black-tree": "^1.0.1", 215 | "lodash": "^4.17.15", 216 | "regexpp": "^3.0.0", 217 | "semver": "^7.3.2", 218 | "tsutils": "^3.17.1" 219 | }, 220 | "engines": { 221 | "node": "^10.12.0 || >=12.0.0" 222 | }, 223 | "funding": { 224 | "type": "opencollective", 225 | "url": "https://opencollective.com/typescript-eslint" 226 | }, 227 | "peerDependencies": { 228 | "@typescript-eslint/parser": "^4.0.0", 229 | "eslint": "^5.0.0 || ^6.0.0 || ^7.0.0" 230 | }, 231 | "peerDependenciesMeta": { 232 | "typescript": { 233 | "optional": true 234 | } 235 | } 236 | }, 237 | "node_modules/@typescript-eslint/experimental-utils": { 238 | "version": "4.14.0", 239 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-4.14.0.tgz", 240 | "integrity": "sha512-6i6eAoiPlXMKRbXzvoQD5Yn9L7k9ezzGRvzC/x1V3650rUk3c3AOjQyGYyF9BDxQQDK2ElmKOZRD0CbtdkMzQQ==", 241 | "dev": true, 242 | "dependencies": { 243 | "@types/json-schema": "^7.0.3", 244 | "@typescript-eslint/scope-manager": "4.14.0", 245 | "@typescript-eslint/types": "4.14.0", 246 | "@typescript-eslint/typescript-estree": "4.14.0", 247 | "eslint-scope": "^5.0.0", 248 | "eslint-utils": "^2.0.0" 249 | }, 250 | "engines": { 251 | "node": "^10.12.0 || >=12.0.0" 252 | }, 253 | "funding": { 254 | "type": "opencollective", 255 | "url": "https://opencollective.com/typescript-eslint" 256 | }, 257 | "peerDependencies": { 258 | "eslint": "*" 259 | } 260 | }, 261 | "node_modules/@typescript-eslint/parser": { 262 | "version": "4.14.0", 263 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-4.14.0.tgz", 264 | "integrity": "sha512-sUDeuCjBU+ZF3Lzw0hphTyScmDDJ5QVkyE21pRoBo8iDl7WBtVFS+WDN3blY1CH3SBt7EmYCw6wfmJjF0l/uYg==", 265 | "dev": true, 266 | "dependencies": { 267 | "@typescript-eslint/scope-manager": "4.14.0", 268 | "@typescript-eslint/types": "4.14.0", 269 | "@typescript-eslint/typescript-estree": "4.14.0", 270 | "debug": "^4.1.1" 271 | }, 272 | "engines": { 273 | "node": "^10.12.0 || >=12.0.0" 274 | }, 275 | "funding": { 276 | "type": "opencollective", 277 | "url": "https://opencollective.com/typescript-eslint" 278 | }, 279 | "peerDependencies": { 280 | "eslint": "^5.0.0 || ^6.0.0 || ^7.0.0" 281 | }, 282 | "peerDependenciesMeta": { 283 | "typescript": { 284 | "optional": true 285 | } 286 | } 287 | }, 288 | "node_modules/@typescript-eslint/scope-manager": { 289 | "version": "4.14.0", 290 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-4.14.0.tgz", 291 | "integrity": "sha512-/J+LlRMdbPh4RdL4hfP1eCwHN5bAhFAGOTsvE6SxsrM/47XQiPSgF5MDgLyp/i9kbZV9Lx80DW0OpPkzL+uf8Q==", 292 | "dev": true, 293 | "dependencies": { 294 | "@typescript-eslint/types": "4.14.0", 295 | "@typescript-eslint/visitor-keys": "4.14.0" 296 | }, 297 | "engines": { 298 | "node": "^8.10.0 || ^10.13.0 || >=11.10.1" 299 | }, 300 | "funding": { 301 | "type": "opencollective", 302 | "url": "https://opencollective.com/typescript-eslint" 303 | } 304 | }, 305 | "node_modules/@typescript-eslint/types": { 306 | "version": "4.14.0", 307 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-4.14.0.tgz", 308 | "integrity": "sha512-VsQE4VvpldHrTFuVPY1ZnHn/Txw6cZGjL48e+iBxTi2ksa9DmebKjAeFmTVAYoSkTk7gjA7UqJ7pIsyifTsI4A==", 309 | "dev": true, 310 | "engines": { 311 | "node": "^8.10.0 || ^10.13.0 || >=11.10.1" 312 | }, 313 | "funding": { 314 | "type": "opencollective", 315 | "url": "https://opencollective.com/typescript-eslint" 316 | } 317 | }, 318 | "node_modules/@typescript-eslint/typescript-estree": { 319 | "version": "4.14.0", 320 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-4.14.0.tgz", 321 | "integrity": "sha512-wRjZ5qLao+bvS2F7pX4qi2oLcOONIB+ru8RGBieDptq/SudYwshveORwCVU4/yMAd4GK7Fsf8Uq1tjV838erag==", 322 | "dev": true, 323 | "dependencies": { 324 | "@typescript-eslint/types": "4.14.0", 325 | "@typescript-eslint/visitor-keys": "4.14.0", 326 | "debug": "^4.1.1", 327 | "globby": "^11.0.1", 328 | "is-glob": "^4.0.1", 329 | "lodash": "^4.17.15", 330 | "semver": "^7.3.2", 331 | "tsutils": "^3.17.1" 332 | }, 333 | "engines": { 334 | "node": "^10.12.0 || >=12.0.0" 335 | }, 336 | "funding": { 337 | "type": "opencollective", 338 | "url": "https://opencollective.com/typescript-eslint" 339 | }, 340 | "peerDependenciesMeta": { 341 | "typescript": { 342 | "optional": true 343 | } 344 | } 345 | }, 346 | "node_modules/@typescript-eslint/visitor-keys": { 347 | "version": "4.14.0", 348 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-4.14.0.tgz", 349 | "integrity": "sha512-MeHHzUyRI50DuiPgV9+LxcM52FCJFYjJiWHtXlbyC27b80mfOwKeiKI+MHOTEpcpfmoPFm/vvQS88bYIx6PZTA==", 350 | "dev": true, 351 | "dependencies": { 352 | "@typescript-eslint/types": "4.14.0", 353 | "eslint-visitor-keys": "^2.0.0" 354 | }, 355 | "engines": { 356 | "node": "^8.10.0 || ^10.13.0 || >=11.10.1" 357 | }, 358 | "funding": { 359 | "type": "opencollective", 360 | "url": "https://opencollective.com/typescript-eslint" 361 | } 362 | }, 363 | "node_modules/acorn": { 364 | "version": "7.4.1", 365 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 366 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 367 | "dev": true, 368 | "bin": { 369 | "acorn": "bin/acorn" 370 | }, 371 | "engines": { 372 | "node": ">=0.4.0" 373 | } 374 | }, 375 | "node_modules/acorn-jsx": { 376 | "version": "5.3.1", 377 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 378 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 379 | "dev": true, 380 | "peerDependencies": { 381 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 382 | } 383 | }, 384 | "node_modules/ajv": { 385 | "version": "6.12.6", 386 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 387 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 388 | "dev": true, 389 | "dependencies": { 390 | "fast-deep-equal": "^3.1.1", 391 | "fast-json-stable-stringify": "^2.0.0", 392 | "json-schema-traverse": "^0.4.1", 393 | "uri-js": "^4.2.2" 394 | }, 395 | "funding": { 396 | "type": "github", 397 | "url": "https://github.com/sponsors/epoberezkin" 398 | } 399 | }, 400 | "node_modules/ansi-colors": { 401 | "version": "4.1.1", 402 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 403 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 404 | "dev": true, 405 | "engines": { 406 | "node": ">=6" 407 | } 408 | }, 409 | "node_modules/ansi-regex": { 410 | "version": "5.0.0", 411 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 412 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 413 | "dev": true, 414 | "engines": { 415 | "node": ">=8" 416 | } 417 | }, 418 | "node_modules/ansi-styles": { 419 | "version": "4.3.0", 420 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 421 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 422 | "dev": true, 423 | "dependencies": { 424 | "color-convert": "^2.0.1" 425 | }, 426 | "engines": { 427 | "node": ">=8" 428 | }, 429 | "funding": { 430 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 431 | } 432 | }, 433 | "node_modules/argparse": { 434 | "version": "1.0.10", 435 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 436 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 437 | "dev": true, 438 | "dependencies": { 439 | "sprintf-js": "~1.0.2" 440 | } 441 | }, 442 | "node_modules/array-union": { 443 | "version": "2.1.0", 444 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 445 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 446 | "dev": true, 447 | "engines": { 448 | "node": ">=8" 449 | } 450 | }, 451 | "node_modules/astral-regex": { 452 | "version": "2.0.0", 453 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 454 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 455 | "dev": true, 456 | "engines": { 457 | "node": ">=8" 458 | } 459 | }, 460 | "node_modules/balanced-match": { 461 | "version": "1.0.0", 462 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 463 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 464 | "dev": true 465 | }, 466 | "node_modules/brace-expansion": { 467 | "version": "1.1.11", 468 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 469 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 470 | "dev": true, 471 | "dependencies": { 472 | "balanced-match": "^1.0.0", 473 | "concat-map": "0.0.1" 474 | } 475 | }, 476 | "node_modules/braces": { 477 | "version": "3.0.2", 478 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 479 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 480 | "dev": true, 481 | "dependencies": { 482 | "fill-range": "^7.0.1" 483 | }, 484 | "engines": { 485 | "node": ">=8" 486 | } 487 | }, 488 | "node_modules/callsites": { 489 | "version": "3.1.0", 490 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 491 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 492 | "dev": true, 493 | "engines": { 494 | "node": ">=6" 495 | } 496 | }, 497 | "node_modules/chalk": { 498 | "version": "4.1.0", 499 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 500 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 501 | "dev": true, 502 | "dependencies": { 503 | "ansi-styles": "^4.1.0", 504 | "supports-color": "^7.1.0" 505 | }, 506 | "engines": { 507 | "node": ">=10" 508 | }, 509 | "funding": { 510 | "url": "https://github.com/chalk/chalk?sponsor=1" 511 | } 512 | }, 513 | "node_modules/color-convert": { 514 | "version": "2.0.1", 515 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 516 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 517 | "dev": true, 518 | "dependencies": { 519 | "color-name": "~1.1.4" 520 | }, 521 | "engines": { 522 | "node": ">=7.0.0" 523 | } 524 | }, 525 | "node_modules/color-name": { 526 | "version": "1.1.4", 527 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 528 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 529 | "dev": true 530 | }, 531 | "node_modules/concat-map": { 532 | "version": "0.0.1", 533 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 534 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 535 | "dev": true 536 | }, 537 | "node_modules/cross-spawn": { 538 | "version": "7.0.3", 539 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 540 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 541 | "dev": true, 542 | "dependencies": { 543 | "path-key": "^3.1.0", 544 | "shebang-command": "^2.0.0", 545 | "which": "^2.0.1" 546 | }, 547 | "engines": { 548 | "node": ">= 8" 549 | } 550 | }, 551 | "node_modules/debug": { 552 | "version": "4.3.1", 553 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 554 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 555 | "dev": true, 556 | "dependencies": { 557 | "ms": "2.1.2" 558 | }, 559 | "engines": { 560 | "node": ">=6.0" 561 | }, 562 | "peerDependenciesMeta": { 563 | "supports-color": { 564 | "optional": true 565 | } 566 | } 567 | }, 568 | "node_modules/deep-is": { 569 | "version": "0.1.3", 570 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 571 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 572 | "dev": true 573 | }, 574 | "node_modules/dir-glob": { 575 | "version": "3.0.1", 576 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 577 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 578 | "dev": true, 579 | "dependencies": { 580 | "path-type": "^4.0.0" 581 | }, 582 | "engines": { 583 | "node": ">=8" 584 | } 585 | }, 586 | "node_modules/doctrine": { 587 | "version": "3.0.0", 588 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 589 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 590 | "dev": true, 591 | "dependencies": { 592 | "esutils": "^2.0.2" 593 | }, 594 | "engines": { 595 | "node": ">=6.0.0" 596 | } 597 | }, 598 | "node_modules/emoji-regex": { 599 | "version": "8.0.0", 600 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 601 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 602 | "dev": true 603 | }, 604 | "node_modules/enquirer": { 605 | "version": "2.3.6", 606 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 607 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 608 | "dev": true, 609 | "dependencies": { 610 | "ansi-colors": "^4.1.1" 611 | }, 612 | "engines": { 613 | "node": ">=8.6" 614 | } 615 | }, 616 | "node_modules/escape-string-regexp": { 617 | "version": "1.0.5", 618 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 619 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 620 | "dev": true, 621 | "engines": { 622 | "node": ">=0.8.0" 623 | } 624 | }, 625 | "node_modules/eslint": { 626 | "version": "7.18.0", 627 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.18.0.tgz", 628 | "integrity": "sha512-fbgTiE8BfUJZuBeq2Yi7J3RB3WGUQ9PNuNbmgi6jt9Iv8qrkxfy19Ds3OpL1Pm7zg3BtTVhvcUZbIRQ0wmSjAQ==", 629 | "dev": true, 630 | "dependencies": { 631 | "@babel/code-frame": "^7.0.0", 632 | "@eslint/eslintrc": "^0.3.0", 633 | "ajv": "^6.10.0", 634 | "chalk": "^4.0.0", 635 | "cross-spawn": "^7.0.2", 636 | "debug": "^4.0.1", 637 | "doctrine": "^3.0.0", 638 | "enquirer": "^2.3.5", 639 | "eslint-scope": "^5.1.1", 640 | "eslint-utils": "^2.1.0", 641 | "eslint-visitor-keys": "^2.0.0", 642 | "espree": "^7.3.1", 643 | "esquery": "^1.2.0", 644 | "esutils": "^2.0.2", 645 | "file-entry-cache": "^6.0.0", 646 | "functional-red-black-tree": "^1.0.1", 647 | "glob-parent": "^5.0.0", 648 | "globals": "^12.1.0", 649 | "ignore": "^4.0.6", 650 | "import-fresh": "^3.0.0", 651 | "imurmurhash": "^0.1.4", 652 | "is-glob": "^4.0.0", 653 | "js-yaml": "^3.13.1", 654 | "json-stable-stringify-without-jsonify": "^1.0.1", 655 | "levn": "^0.4.1", 656 | "lodash": "^4.17.20", 657 | "minimatch": "^3.0.4", 658 | "natural-compare": "^1.4.0", 659 | "optionator": "^0.9.1", 660 | "progress": "^2.0.0", 661 | "regexpp": "^3.1.0", 662 | "semver": "^7.2.1", 663 | "strip-ansi": "^6.0.0", 664 | "strip-json-comments": "^3.1.0", 665 | "table": "^6.0.4", 666 | "text-table": "^0.2.0", 667 | "v8-compile-cache": "^2.0.3" 668 | }, 669 | "bin": { 670 | "eslint": "bin/eslint.js" 671 | }, 672 | "engines": { 673 | "node": "^10.12.0 || >=12.0.0" 674 | }, 675 | "funding": { 676 | "url": "https://opencollective.com/eslint" 677 | } 678 | }, 679 | "node_modules/eslint-config-prettier": { 680 | "version": "7.2.0", 681 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-7.2.0.tgz", 682 | "integrity": "sha512-rV4Qu0C3nfJKPOAhFujFxB7RMP+URFyQqqOZW9DMRD7ZDTFyjaIlETU3xzHELt++4ugC0+Jm084HQYkkJe+Ivg==", 683 | "dev": true, 684 | "bin": { 685 | "eslint-config-prettier": "bin/cli.js" 686 | }, 687 | "peerDependencies": { 688 | "eslint": ">=7.0.0" 689 | } 690 | }, 691 | "node_modules/eslint-plugin-prettier": { 692 | "version": "3.3.1", 693 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.3.1.tgz", 694 | "integrity": "sha512-Rq3jkcFY8RYeQLgk2cCwuc0P7SEFwDravPhsJZOQ5N4YI4DSg50NyqJ/9gdZHzQlHf8MvafSesbNJCcP/FF6pQ==", 695 | "dev": true, 696 | "dependencies": { 697 | "prettier-linter-helpers": "^1.0.0" 698 | }, 699 | "engines": { 700 | "node": ">=6.0.0" 701 | }, 702 | "peerDependencies": { 703 | "eslint": ">=5.0.0", 704 | "prettier": ">=1.13.0" 705 | }, 706 | "peerDependenciesMeta": { 707 | "eslint-config-prettier": { 708 | "optional": true 709 | } 710 | } 711 | }, 712 | "node_modules/eslint-plugin-roblox-ts": { 713 | "version": "0.0.24", 714 | "resolved": "https://registry.npmjs.org/eslint-plugin-roblox-ts/-/eslint-plugin-roblox-ts-0.0.24.tgz", 715 | "integrity": "sha512-KwYUT8fdlS8gG6IfFnmyTwoWldR+4L5wCEk5NifKQ1L8OX1frrG61o6LkuyQvX0MtOeEj2CKo3qZyvfOuDb3Aw==", 716 | "dev": true, 717 | "dependencies": { 718 | "@types/node": "^14.11.8", 719 | "@typescript-eslint/experimental-utils": "^4.4.1", 720 | "typescript": "^4.0.3" 721 | }, 722 | "engines": { 723 | "node": ">=0.10.0" 724 | } 725 | }, 726 | "node_modules/eslint-scope": { 727 | "version": "5.1.1", 728 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 729 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 730 | "dev": true, 731 | "dependencies": { 732 | "esrecurse": "^4.3.0", 733 | "estraverse": "^4.1.1" 734 | }, 735 | "engines": { 736 | "node": ">=8.0.0" 737 | } 738 | }, 739 | "node_modules/eslint-utils": { 740 | "version": "2.1.0", 741 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 742 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 743 | "dev": true, 744 | "dependencies": { 745 | "eslint-visitor-keys": "^1.1.0" 746 | }, 747 | "engines": { 748 | "node": ">=6" 749 | }, 750 | "funding": { 751 | "url": "https://github.com/sponsors/mysticatea" 752 | } 753 | }, 754 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 755 | "version": "1.3.0", 756 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 757 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 758 | "dev": true, 759 | "engines": { 760 | "node": ">=4" 761 | } 762 | }, 763 | "node_modules/eslint-visitor-keys": { 764 | "version": "2.0.0", 765 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 766 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 767 | "dev": true, 768 | "engines": { 769 | "node": ">=10" 770 | } 771 | }, 772 | "node_modules/espree": { 773 | "version": "7.3.1", 774 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 775 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 776 | "dev": true, 777 | "dependencies": { 778 | "acorn": "^7.4.0", 779 | "acorn-jsx": "^5.3.1", 780 | "eslint-visitor-keys": "^1.3.0" 781 | }, 782 | "engines": { 783 | "node": "^10.12.0 || >=12.0.0" 784 | } 785 | }, 786 | "node_modules/espree/node_modules/eslint-visitor-keys": { 787 | "version": "1.3.0", 788 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 789 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 790 | "dev": true, 791 | "engines": { 792 | "node": ">=4" 793 | } 794 | }, 795 | "node_modules/esprima": { 796 | "version": "4.0.1", 797 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 798 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 799 | "dev": true, 800 | "bin": { 801 | "esparse": "bin/esparse.js", 802 | "esvalidate": "bin/esvalidate.js" 803 | }, 804 | "engines": { 805 | "node": ">=4" 806 | } 807 | }, 808 | "node_modules/esquery": { 809 | "version": "1.3.1", 810 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 811 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 812 | "dev": true, 813 | "dependencies": { 814 | "estraverse": "^5.1.0" 815 | }, 816 | "engines": { 817 | "node": ">=0.10" 818 | } 819 | }, 820 | "node_modules/esquery/node_modules/estraverse": { 821 | "version": "5.2.0", 822 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 823 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 824 | "dev": true, 825 | "engines": { 826 | "node": ">=4.0" 827 | } 828 | }, 829 | "node_modules/esrecurse": { 830 | "version": "4.3.0", 831 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 832 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 833 | "dev": true, 834 | "dependencies": { 835 | "estraverse": "^5.2.0" 836 | }, 837 | "engines": { 838 | "node": ">=4.0" 839 | } 840 | }, 841 | "node_modules/esrecurse/node_modules/estraverse": { 842 | "version": "5.2.0", 843 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 844 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 845 | "dev": true, 846 | "engines": { 847 | "node": ">=4.0" 848 | } 849 | }, 850 | "node_modules/estraverse": { 851 | "version": "4.3.0", 852 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 853 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 854 | "dev": true, 855 | "engines": { 856 | "node": ">=4.0" 857 | } 858 | }, 859 | "node_modules/esutils": { 860 | "version": "2.0.3", 861 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 862 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 863 | "dev": true, 864 | "engines": { 865 | "node": ">=0.10.0" 866 | } 867 | }, 868 | "node_modules/fast-deep-equal": { 869 | "version": "3.1.3", 870 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 871 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 872 | "dev": true 873 | }, 874 | "node_modules/fast-diff": { 875 | "version": "1.2.0", 876 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 877 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 878 | "dev": true 879 | }, 880 | "node_modules/fast-glob": { 881 | "version": "3.2.5", 882 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.5.tgz", 883 | "integrity": "sha512-2DtFcgT68wiTTiwZ2hNdJfcHNke9XOfnwmBRWXhmeKM8rF0TGwmC/Qto3S7RoZKp5cilZbxzO5iTNTQsJ+EeDg==", 884 | "dev": true, 885 | "dependencies": { 886 | "@nodelib/fs.stat": "^2.0.2", 887 | "@nodelib/fs.walk": "^1.2.3", 888 | "glob-parent": "^5.1.0", 889 | "merge2": "^1.3.0", 890 | "micromatch": "^4.0.2", 891 | "picomatch": "^2.2.1" 892 | }, 893 | "engines": { 894 | "node": ">=8" 895 | } 896 | }, 897 | "node_modules/fast-json-stable-stringify": { 898 | "version": "2.1.0", 899 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 900 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 901 | "dev": true 902 | }, 903 | "node_modules/fast-levenshtein": { 904 | "version": "2.0.6", 905 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 906 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 907 | "dev": true 908 | }, 909 | "node_modules/fastq": { 910 | "version": "1.10.0", 911 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.10.0.tgz", 912 | "integrity": "sha512-NL2Qc5L3iQEsyYzweq7qfgy5OtXCmGzGvhElGEd/SoFWEMOEczNh5s5ocaF01HDetxz+p8ecjNPA6cZxxIHmzA==", 913 | "dev": true, 914 | "dependencies": { 915 | "reusify": "^1.0.4" 916 | } 917 | }, 918 | "node_modules/file-entry-cache": { 919 | "version": "6.0.0", 920 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.0.tgz", 921 | "integrity": "sha512-fqoO76jZ3ZnYrXLDRxBR1YvOvc0k844kcOg40bgsPrE25LAb/PDqTY+ho64Xh2c8ZXgIKldchCFHczG2UVRcWA==", 922 | "dev": true, 923 | "dependencies": { 924 | "flat-cache": "^3.0.4" 925 | }, 926 | "engines": { 927 | "node": "^10.12.0 || >=12.0.0" 928 | } 929 | }, 930 | "node_modules/fill-range": { 931 | "version": "7.0.1", 932 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 933 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 934 | "dev": true, 935 | "dependencies": { 936 | "to-regex-range": "^5.0.1" 937 | }, 938 | "engines": { 939 | "node": ">=8" 940 | } 941 | }, 942 | "node_modules/flat-cache": { 943 | "version": "3.0.4", 944 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 945 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 946 | "dev": true, 947 | "dependencies": { 948 | "flatted": "^3.1.0", 949 | "rimraf": "^3.0.2" 950 | }, 951 | "engines": { 952 | "node": "^10.12.0 || >=12.0.0" 953 | } 954 | }, 955 | "node_modules/flatted": { 956 | "version": "3.1.1", 957 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 958 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 959 | "dev": true 960 | }, 961 | "node_modules/fs.realpath": { 962 | "version": "1.0.0", 963 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 964 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 965 | "dev": true 966 | }, 967 | "node_modules/functional-red-black-tree": { 968 | "version": "1.0.1", 969 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 970 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 971 | "dev": true 972 | }, 973 | "node_modules/glob": { 974 | "version": "7.1.6", 975 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 976 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 977 | "dev": true, 978 | "dependencies": { 979 | "fs.realpath": "^1.0.0", 980 | "inflight": "^1.0.4", 981 | "inherits": "2", 982 | "minimatch": "^3.0.4", 983 | "once": "^1.3.0", 984 | "path-is-absolute": "^1.0.0" 985 | }, 986 | "engines": { 987 | "node": "*" 988 | }, 989 | "funding": { 990 | "url": "https://github.com/sponsors/isaacs" 991 | } 992 | }, 993 | "node_modules/glob-parent": { 994 | "version": "5.1.1", 995 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 996 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 997 | "dev": true, 998 | "dependencies": { 999 | "is-glob": "^4.0.1" 1000 | }, 1001 | "engines": { 1002 | "node": ">= 6" 1003 | } 1004 | }, 1005 | "node_modules/globals": { 1006 | "version": "12.4.0", 1007 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 1008 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 1009 | "dev": true, 1010 | "dependencies": { 1011 | "type-fest": "^0.8.1" 1012 | }, 1013 | "engines": { 1014 | "node": ">=8" 1015 | }, 1016 | "funding": { 1017 | "url": "https://github.com/sponsors/sindresorhus" 1018 | } 1019 | }, 1020 | "node_modules/globby": { 1021 | "version": "11.0.2", 1022 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.0.2.tgz", 1023 | "integrity": "sha512-2ZThXDvvV8fYFRVIxnrMQBipZQDr7MxKAmQK1vujaj9/7eF0efG7BPUKJ7jP7G5SLF37xKDXvO4S/KKLj/Z0og==", 1024 | "dev": true, 1025 | "dependencies": { 1026 | "array-union": "^2.1.0", 1027 | "dir-glob": "^3.0.1", 1028 | "fast-glob": "^3.1.1", 1029 | "ignore": "^5.1.4", 1030 | "merge2": "^1.3.0", 1031 | "slash": "^3.0.0" 1032 | }, 1033 | "engines": { 1034 | "node": ">=10" 1035 | }, 1036 | "funding": { 1037 | "url": "https://github.com/sponsors/sindresorhus" 1038 | } 1039 | }, 1040 | "node_modules/globby/node_modules/ignore": { 1041 | "version": "5.1.8", 1042 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.8.tgz", 1043 | "integrity": "sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw==", 1044 | "dev": true, 1045 | "engines": { 1046 | "node": ">= 4" 1047 | } 1048 | }, 1049 | "node_modules/has-flag": { 1050 | "version": "4.0.0", 1051 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1052 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1053 | "dev": true, 1054 | "engines": { 1055 | "node": ">=8" 1056 | } 1057 | }, 1058 | "node_modules/ignore": { 1059 | "version": "4.0.6", 1060 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1061 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1062 | "dev": true, 1063 | "engines": { 1064 | "node": ">= 4" 1065 | } 1066 | }, 1067 | "node_modules/import-fresh": { 1068 | "version": "3.3.0", 1069 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1070 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1071 | "dev": true, 1072 | "dependencies": { 1073 | "parent-module": "^1.0.0", 1074 | "resolve-from": "^4.0.0" 1075 | }, 1076 | "engines": { 1077 | "node": ">=6" 1078 | }, 1079 | "funding": { 1080 | "url": "https://github.com/sponsors/sindresorhus" 1081 | } 1082 | }, 1083 | "node_modules/imurmurhash": { 1084 | "version": "0.1.4", 1085 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1086 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1087 | "dev": true, 1088 | "engines": { 1089 | "node": ">=0.8.19" 1090 | } 1091 | }, 1092 | "node_modules/inflight": { 1093 | "version": "1.0.6", 1094 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1095 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1096 | "dev": true, 1097 | "dependencies": { 1098 | "once": "^1.3.0", 1099 | "wrappy": "1" 1100 | } 1101 | }, 1102 | "node_modules/inherits": { 1103 | "version": "2.0.4", 1104 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1105 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1106 | "dev": true 1107 | }, 1108 | "node_modules/is-extglob": { 1109 | "version": "2.1.1", 1110 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1111 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1112 | "dev": true, 1113 | "engines": { 1114 | "node": ">=0.10.0" 1115 | } 1116 | }, 1117 | "node_modules/is-fullwidth-code-point": { 1118 | "version": "3.0.0", 1119 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1120 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1121 | "dev": true, 1122 | "engines": { 1123 | "node": ">=8" 1124 | } 1125 | }, 1126 | "node_modules/is-glob": { 1127 | "version": "4.0.1", 1128 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1129 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1130 | "dev": true, 1131 | "dependencies": { 1132 | "is-extglob": "^2.1.1" 1133 | }, 1134 | "engines": { 1135 | "node": ">=0.10.0" 1136 | } 1137 | }, 1138 | "node_modules/is-number": { 1139 | "version": "7.0.0", 1140 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1141 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1142 | "dev": true, 1143 | "engines": { 1144 | "node": ">=0.12.0" 1145 | } 1146 | }, 1147 | "node_modules/isexe": { 1148 | "version": "2.0.0", 1149 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1150 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1151 | "dev": true 1152 | }, 1153 | "node_modules/js-tokens": { 1154 | "version": "4.0.0", 1155 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1156 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1157 | "dev": true 1158 | }, 1159 | "node_modules/js-yaml": { 1160 | "version": "3.14.1", 1161 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 1162 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 1163 | "dev": true, 1164 | "dependencies": { 1165 | "argparse": "^1.0.7", 1166 | "esprima": "^4.0.0" 1167 | }, 1168 | "bin": { 1169 | "js-yaml": "bin/js-yaml.js" 1170 | } 1171 | }, 1172 | "node_modules/json-schema-traverse": { 1173 | "version": "0.4.1", 1174 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1175 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1176 | "dev": true 1177 | }, 1178 | "node_modules/json-stable-stringify-without-jsonify": { 1179 | "version": "1.0.1", 1180 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1181 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1182 | "dev": true 1183 | }, 1184 | "node_modules/levn": { 1185 | "version": "0.4.1", 1186 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1187 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1188 | "dev": true, 1189 | "dependencies": { 1190 | "prelude-ls": "^1.2.1", 1191 | "type-check": "~0.4.0" 1192 | }, 1193 | "engines": { 1194 | "node": ">= 0.8.0" 1195 | } 1196 | }, 1197 | "node_modules/lodash": { 1198 | "version": "4.17.20", 1199 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz", 1200 | "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==", 1201 | "dev": true 1202 | }, 1203 | "node_modules/lru-cache": { 1204 | "version": "6.0.0", 1205 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1206 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1207 | "dev": true, 1208 | "dependencies": { 1209 | "yallist": "^4.0.0" 1210 | }, 1211 | "engines": { 1212 | "node": ">=10" 1213 | } 1214 | }, 1215 | "node_modules/merge2": { 1216 | "version": "1.4.1", 1217 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1218 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1219 | "dev": true, 1220 | "engines": { 1221 | "node": ">= 8" 1222 | } 1223 | }, 1224 | "node_modules/micromatch": { 1225 | "version": "4.0.2", 1226 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz", 1227 | "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==", 1228 | "dev": true, 1229 | "dependencies": { 1230 | "braces": "^3.0.1", 1231 | "picomatch": "^2.0.5" 1232 | }, 1233 | "engines": { 1234 | "node": ">=8" 1235 | } 1236 | }, 1237 | "node_modules/minimatch": { 1238 | "version": "3.0.4", 1239 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1240 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1241 | "dev": true, 1242 | "dependencies": { 1243 | "brace-expansion": "^1.1.7" 1244 | }, 1245 | "engines": { 1246 | "node": "*" 1247 | } 1248 | }, 1249 | "node_modules/ms": { 1250 | "version": "2.1.2", 1251 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1252 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1253 | "dev": true 1254 | }, 1255 | "node_modules/natural-compare": { 1256 | "version": "1.4.0", 1257 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1258 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1259 | "dev": true 1260 | }, 1261 | "node_modules/once": { 1262 | "version": "1.4.0", 1263 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1264 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1265 | "dev": true, 1266 | "dependencies": { 1267 | "wrappy": "1" 1268 | } 1269 | }, 1270 | "node_modules/optionator": { 1271 | "version": "0.9.1", 1272 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1273 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1274 | "dev": true, 1275 | "dependencies": { 1276 | "deep-is": "^0.1.3", 1277 | "fast-levenshtein": "^2.0.6", 1278 | "levn": "^0.4.1", 1279 | "prelude-ls": "^1.2.1", 1280 | "type-check": "^0.4.0", 1281 | "word-wrap": "^1.2.3" 1282 | }, 1283 | "engines": { 1284 | "node": ">= 0.8.0" 1285 | } 1286 | }, 1287 | "node_modules/parent-module": { 1288 | "version": "1.0.1", 1289 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1290 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1291 | "dev": true, 1292 | "dependencies": { 1293 | "callsites": "^3.0.0" 1294 | }, 1295 | "engines": { 1296 | "node": ">=6" 1297 | } 1298 | }, 1299 | "node_modules/path-is-absolute": { 1300 | "version": "1.0.1", 1301 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1302 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1303 | "dev": true, 1304 | "engines": { 1305 | "node": ">=0.10.0" 1306 | } 1307 | }, 1308 | "node_modules/path-key": { 1309 | "version": "3.1.1", 1310 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1311 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1312 | "dev": true, 1313 | "engines": { 1314 | "node": ">=8" 1315 | } 1316 | }, 1317 | "node_modules/path-type": { 1318 | "version": "4.0.0", 1319 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1320 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1321 | "dev": true, 1322 | "engines": { 1323 | "node": ">=8" 1324 | } 1325 | }, 1326 | "node_modules/picomatch": { 1327 | "version": "2.2.2", 1328 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 1329 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 1330 | "dev": true, 1331 | "engines": { 1332 | "node": ">=8.6" 1333 | }, 1334 | "funding": { 1335 | "url": "https://github.com/sponsors/jonschlinkert" 1336 | } 1337 | }, 1338 | "node_modules/prelude-ls": { 1339 | "version": "1.2.1", 1340 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1341 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1342 | "dev": true, 1343 | "engines": { 1344 | "node": ">= 0.8.0" 1345 | } 1346 | }, 1347 | "node_modules/prettier": { 1348 | "version": "2.2.1", 1349 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.2.1.tgz", 1350 | "integrity": "sha512-PqyhM2yCjg/oKkFPtTGUojv7gnZAoG80ttl45O6x2Ug/rMJw4wcc9k6aaf2hibP7BGVCCM33gZoGjyvt9mm16Q==", 1351 | "dev": true, 1352 | "bin": { 1353 | "prettier": "bin-prettier.js" 1354 | }, 1355 | "engines": { 1356 | "node": ">=10.13.0" 1357 | } 1358 | }, 1359 | "node_modules/prettier-linter-helpers": { 1360 | "version": "1.0.0", 1361 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 1362 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 1363 | "dev": true, 1364 | "dependencies": { 1365 | "fast-diff": "^1.1.2" 1366 | }, 1367 | "engines": { 1368 | "node": ">=6.0.0" 1369 | } 1370 | }, 1371 | "node_modules/progress": { 1372 | "version": "2.0.3", 1373 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1374 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1375 | "dev": true, 1376 | "engines": { 1377 | "node": ">=0.4.0" 1378 | } 1379 | }, 1380 | "node_modules/punycode": { 1381 | "version": "2.1.1", 1382 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1383 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1384 | "dev": true, 1385 | "engines": { 1386 | "node": ">=6" 1387 | } 1388 | }, 1389 | "node_modules/regexpp": { 1390 | "version": "3.1.0", 1391 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1392 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1393 | "dev": true, 1394 | "engines": { 1395 | "node": ">=8" 1396 | }, 1397 | "funding": { 1398 | "url": "https://github.com/sponsors/mysticatea" 1399 | } 1400 | }, 1401 | "node_modules/require-from-string": { 1402 | "version": "2.0.2", 1403 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 1404 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 1405 | "dev": true, 1406 | "engines": { 1407 | "node": ">=0.10.0" 1408 | } 1409 | }, 1410 | "node_modules/resolve-from": { 1411 | "version": "4.0.0", 1412 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1413 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1414 | "dev": true, 1415 | "engines": { 1416 | "node": ">=4" 1417 | } 1418 | }, 1419 | "node_modules/reusify": { 1420 | "version": "1.0.4", 1421 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1422 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1423 | "dev": true, 1424 | "engines": { 1425 | "iojs": ">=1.0.0", 1426 | "node": ">=0.10.0" 1427 | } 1428 | }, 1429 | "node_modules/rimraf": { 1430 | "version": "3.0.2", 1431 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1432 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1433 | "dev": true, 1434 | "dependencies": { 1435 | "glob": "^7.1.3" 1436 | }, 1437 | "bin": { 1438 | "rimraf": "bin.js" 1439 | }, 1440 | "funding": { 1441 | "url": "https://github.com/sponsors/isaacs" 1442 | } 1443 | }, 1444 | "node_modules/run-parallel": { 1445 | "version": "1.1.10", 1446 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.1.10.tgz", 1447 | "integrity": "sha512-zb/1OuZ6flOlH6tQyMPUrE3x3Ulxjlo9WIVXR4yVYi4H9UXQaeIsPbLn2R3O3vQCnDKkAl2qHiuocKKX4Tz/Sw==", 1448 | "dev": true, 1449 | "funding": [ 1450 | { 1451 | "type": "github", 1452 | "url": "https://github.com/sponsors/feross" 1453 | }, 1454 | { 1455 | "type": "patreon", 1456 | "url": "https://www.patreon.com/feross" 1457 | }, 1458 | { 1459 | "type": "consulting", 1460 | "url": "https://feross.org/support" 1461 | } 1462 | ] 1463 | }, 1464 | "node_modules/semver": { 1465 | "version": "7.3.4", 1466 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", 1467 | "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", 1468 | "dev": true, 1469 | "dependencies": { 1470 | "lru-cache": "^6.0.0" 1471 | }, 1472 | "bin": { 1473 | "semver": "bin/semver.js" 1474 | }, 1475 | "engines": { 1476 | "node": ">=10" 1477 | } 1478 | }, 1479 | "node_modules/shebang-command": { 1480 | "version": "2.0.0", 1481 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1482 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1483 | "dev": true, 1484 | "dependencies": { 1485 | "shebang-regex": "^3.0.0" 1486 | }, 1487 | "engines": { 1488 | "node": ">=8" 1489 | } 1490 | }, 1491 | "node_modules/shebang-regex": { 1492 | "version": "3.0.0", 1493 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1494 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1495 | "dev": true, 1496 | "engines": { 1497 | "node": ">=8" 1498 | } 1499 | }, 1500 | "node_modules/slash": { 1501 | "version": "3.0.0", 1502 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 1503 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 1504 | "dev": true, 1505 | "engines": { 1506 | "node": ">=8" 1507 | } 1508 | }, 1509 | "node_modules/slice-ansi": { 1510 | "version": "4.0.0", 1511 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1512 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1513 | "dev": true, 1514 | "dependencies": { 1515 | "ansi-styles": "^4.0.0", 1516 | "astral-regex": "^2.0.0", 1517 | "is-fullwidth-code-point": "^3.0.0" 1518 | }, 1519 | "engines": { 1520 | "node": ">=10" 1521 | }, 1522 | "funding": { 1523 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1524 | } 1525 | }, 1526 | "node_modules/sprintf-js": { 1527 | "version": "1.0.3", 1528 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1529 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1530 | "dev": true 1531 | }, 1532 | "node_modules/string-width": { 1533 | "version": "4.2.0", 1534 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1535 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1536 | "dev": true, 1537 | "dependencies": { 1538 | "emoji-regex": "^8.0.0", 1539 | "is-fullwidth-code-point": "^3.0.0", 1540 | "strip-ansi": "^6.0.0" 1541 | }, 1542 | "engines": { 1543 | "node": ">=8" 1544 | } 1545 | }, 1546 | "node_modules/strip-ansi": { 1547 | "version": "6.0.0", 1548 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1549 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1550 | "dev": true, 1551 | "dependencies": { 1552 | "ansi-regex": "^5.0.0" 1553 | }, 1554 | "engines": { 1555 | "node": ">=8" 1556 | } 1557 | }, 1558 | "node_modules/strip-json-comments": { 1559 | "version": "3.1.1", 1560 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1561 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1562 | "dev": true, 1563 | "engines": { 1564 | "node": ">=8" 1565 | }, 1566 | "funding": { 1567 | "url": "https://github.com/sponsors/sindresorhus" 1568 | } 1569 | }, 1570 | "node_modules/supports-color": { 1571 | "version": "7.2.0", 1572 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1573 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1574 | "dev": true, 1575 | "dependencies": { 1576 | "has-flag": "^4.0.0" 1577 | }, 1578 | "engines": { 1579 | "node": ">=8" 1580 | } 1581 | }, 1582 | "node_modules/table": { 1583 | "version": "6.0.7", 1584 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.7.tgz", 1585 | "integrity": "sha512-rxZevLGTUzWna/qBLObOe16kB2RTnnbhciwgPbMMlazz1yZGVEgnZK762xyVdVznhqxrfCeBMmMkgOOaPwjH7g==", 1586 | "dev": true, 1587 | "dependencies": { 1588 | "ajv": "^7.0.2", 1589 | "lodash": "^4.17.20", 1590 | "slice-ansi": "^4.0.0", 1591 | "string-width": "^4.2.0" 1592 | }, 1593 | "engines": { 1594 | "node": ">=10.0.0" 1595 | } 1596 | }, 1597 | "node_modules/table/node_modules/ajv": { 1598 | "version": "7.0.3", 1599 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-7.0.3.tgz", 1600 | "integrity": "sha512-R50QRlXSxqXcQP5SvKUrw8VZeypvo12i2IX0EeR5PiZ7bEKeHWgzgo264LDadUsCU42lTJVhFikTqJwNeH34gQ==", 1601 | "dev": true, 1602 | "dependencies": { 1603 | "fast-deep-equal": "^3.1.1", 1604 | "json-schema-traverse": "^1.0.0", 1605 | "require-from-string": "^2.0.2", 1606 | "uri-js": "^4.2.2" 1607 | }, 1608 | "funding": { 1609 | "type": "github", 1610 | "url": "https://github.com/sponsors/epoberezkin" 1611 | } 1612 | }, 1613 | "node_modules/table/node_modules/json-schema-traverse": { 1614 | "version": "1.0.0", 1615 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 1616 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 1617 | "dev": true 1618 | }, 1619 | "node_modules/text-table": { 1620 | "version": "0.2.0", 1621 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1622 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1623 | "dev": true 1624 | }, 1625 | "node_modules/to-regex-range": { 1626 | "version": "5.0.1", 1627 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1628 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1629 | "dev": true, 1630 | "dependencies": { 1631 | "is-number": "^7.0.0" 1632 | }, 1633 | "engines": { 1634 | "node": ">=8.0" 1635 | } 1636 | }, 1637 | "node_modules/tslib": { 1638 | "version": "1.14.1", 1639 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 1640 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 1641 | "dev": true 1642 | }, 1643 | "node_modules/tsutils": { 1644 | "version": "3.19.1", 1645 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.19.1.tgz", 1646 | "integrity": "sha512-GEdoBf5XI324lu7ycad7s6laADfnAqCw6wLGI+knxvw9vsIYBaJfYdmeCEG3FMMUiSm3OGgNb+m6utsWf5h9Vw==", 1647 | "dev": true, 1648 | "dependencies": { 1649 | "tslib": "^1.8.1" 1650 | }, 1651 | "engines": { 1652 | "node": ">= 6" 1653 | }, 1654 | "peerDependencies": { 1655 | "typescript": ">=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta" 1656 | } 1657 | }, 1658 | "node_modules/type-check": { 1659 | "version": "0.4.0", 1660 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1661 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1662 | "dev": true, 1663 | "dependencies": { 1664 | "prelude-ls": "^1.2.1" 1665 | }, 1666 | "engines": { 1667 | "node": ">= 0.8.0" 1668 | } 1669 | }, 1670 | "node_modules/type-fest": { 1671 | "version": "0.8.1", 1672 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1673 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1674 | "dev": true, 1675 | "engines": { 1676 | "node": ">=8" 1677 | } 1678 | }, 1679 | "node_modules/typescript": { 1680 | "version": "4.1.3", 1681 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.1.3.tgz", 1682 | "integrity": "sha512-B3ZIOf1IKeH2ixgHhj6la6xdwR9QrLC5d1VKeCSY4tvkqhF2eqd9O7txNlS0PO3GrBAFIdr3L1ndNwteUbZLYg==", 1683 | "dev": true, 1684 | "bin": { 1685 | "tsc": "bin/tsc", 1686 | "tsserver": "bin/tsserver" 1687 | }, 1688 | "engines": { 1689 | "node": ">=4.2.0" 1690 | } 1691 | }, 1692 | "node_modules/uri-js": { 1693 | "version": "4.4.1", 1694 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1695 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1696 | "dev": true, 1697 | "dependencies": { 1698 | "punycode": "^2.1.0" 1699 | } 1700 | }, 1701 | "node_modules/v8-compile-cache": { 1702 | "version": "2.2.0", 1703 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.2.0.tgz", 1704 | "integrity": "sha512-gTpR5XQNKFwOd4clxfnhaqvfqMpqEwr4tOtCyz4MtYZX2JYhfr1JvBFKdS+7K/9rfpZR3VLX+YWBbKoxCgS43Q==", 1705 | "dev": true 1706 | }, 1707 | "node_modules/which": { 1708 | "version": "2.0.2", 1709 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1710 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1711 | "dev": true, 1712 | "dependencies": { 1713 | "isexe": "^2.0.0" 1714 | }, 1715 | "bin": { 1716 | "node-which": "bin/node-which" 1717 | }, 1718 | "engines": { 1719 | "node": ">= 8" 1720 | } 1721 | }, 1722 | "node_modules/word-wrap": { 1723 | "version": "1.2.3", 1724 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1725 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1726 | "dev": true, 1727 | "engines": { 1728 | "node": ">=0.10.0" 1729 | } 1730 | }, 1731 | "node_modules/wrappy": { 1732 | "version": "1.0.2", 1733 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1734 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1735 | "dev": true 1736 | }, 1737 | "node_modules/yallist": { 1738 | "version": "4.0.0", 1739 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1740 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1741 | "dev": true 1742 | } 1743 | }, 1744 | "dependencies": { 1745 | "@babel/code-frame": { 1746 | "version": "7.12.11", 1747 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 1748 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 1749 | "dev": true, 1750 | "requires": { 1751 | "@babel/highlight": "^7.10.4" 1752 | } 1753 | }, 1754 | "@babel/helper-validator-identifier": { 1755 | "version": "7.12.11", 1756 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", 1757 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", 1758 | "dev": true 1759 | }, 1760 | "@babel/highlight": { 1761 | "version": "7.10.4", 1762 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 1763 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 1764 | "dev": true, 1765 | "requires": { 1766 | "@babel/helper-validator-identifier": "^7.10.4", 1767 | "chalk": "^2.0.0", 1768 | "js-tokens": "^4.0.0" 1769 | }, 1770 | "dependencies": { 1771 | "ansi-styles": { 1772 | "version": "3.2.1", 1773 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1774 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1775 | "dev": true, 1776 | "requires": { 1777 | "color-convert": "^1.9.0" 1778 | } 1779 | }, 1780 | "chalk": { 1781 | "version": "2.4.2", 1782 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1783 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1784 | "dev": true, 1785 | "requires": { 1786 | "ansi-styles": "^3.2.1", 1787 | "escape-string-regexp": "^1.0.5", 1788 | "supports-color": "^5.3.0" 1789 | } 1790 | }, 1791 | "color-convert": { 1792 | "version": "1.9.3", 1793 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1794 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1795 | "dev": true, 1796 | "requires": { 1797 | "color-name": "1.1.3" 1798 | } 1799 | }, 1800 | "color-name": { 1801 | "version": "1.1.3", 1802 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1803 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 1804 | "dev": true 1805 | }, 1806 | "has-flag": { 1807 | "version": "3.0.0", 1808 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1809 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1810 | "dev": true 1811 | }, 1812 | "supports-color": { 1813 | "version": "5.5.0", 1814 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1815 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1816 | "dev": true, 1817 | "requires": { 1818 | "has-flag": "^3.0.0" 1819 | } 1820 | } 1821 | } 1822 | }, 1823 | "@eslint/eslintrc": { 1824 | "version": "0.3.0", 1825 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.3.0.tgz", 1826 | "integrity": "sha512-1JTKgrOKAHVivSvOYw+sJOunkBjUOvjqWk1DPja7ZFhIS2mX/4EgTT8M7eTK9jrKhL/FvXXEbQwIs3pg1xp3dg==", 1827 | "dev": true, 1828 | "requires": { 1829 | "ajv": "^6.12.4", 1830 | "debug": "^4.1.1", 1831 | "espree": "^7.3.0", 1832 | "globals": "^12.1.0", 1833 | "ignore": "^4.0.6", 1834 | "import-fresh": "^3.2.1", 1835 | "js-yaml": "^3.13.1", 1836 | "lodash": "^4.17.20", 1837 | "minimatch": "^3.0.4", 1838 | "strip-json-comments": "^3.1.1" 1839 | } 1840 | }, 1841 | "@nodelib/fs.scandir": { 1842 | "version": "2.1.4", 1843 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.4.tgz", 1844 | "integrity": "sha512-33g3pMJk3bg5nXbL/+CY6I2eJDzZAni49PfJnL5fghPTggPvBd/pFNSgJsdAgWptuFu7qq/ERvOYFlhvsLTCKA==", 1845 | "dev": true, 1846 | "requires": { 1847 | "@nodelib/fs.stat": "2.0.4", 1848 | "run-parallel": "^1.1.9" 1849 | } 1850 | }, 1851 | "@nodelib/fs.stat": { 1852 | "version": "2.0.4", 1853 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.4.tgz", 1854 | "integrity": "sha512-IYlHJA0clt2+Vg7bccq+TzRdJvv19c2INqBSsoOLp1je7xjtr7J26+WXR72MCdvU9q1qTzIWDfhMf+DRvQJK4Q==", 1855 | "dev": true 1856 | }, 1857 | "@nodelib/fs.walk": { 1858 | "version": "1.2.6", 1859 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.6.tgz", 1860 | "integrity": "sha512-8Broas6vTtW4GIXTAHDoE32hnN2M5ykgCpWGbuXHQ15vEMqr23pB76e/GZcYsZCHALv50ktd24qhEyKr6wBtow==", 1861 | "dev": true, 1862 | "requires": { 1863 | "@nodelib/fs.scandir": "2.1.4", 1864 | "fastq": "^1.6.0" 1865 | } 1866 | }, 1867 | "@rbxts/compiler-types": { 1868 | "version": "1.0.0-beta.15.0", 1869 | "resolved": "https://registry.npmjs.org/@rbxts/compiler-types/-/compiler-types-1.0.0-beta.15.0.tgz", 1870 | "integrity": "sha512-Tutr3dkD2bUOCeMIxHXHPYda0blPTZJ1KDRSj0TJ942QKSjxP4Pf09G/ZzySpX094uWLNndgGO9W9UmtmrvP6g==", 1871 | "dev": true 1872 | }, 1873 | "@rbxts/roact": { 1874 | "version": "1.3.0-ts.10", 1875 | "resolved": "https://registry.npmjs.org/@rbxts/roact/-/roact-1.3.0-ts.10.tgz", 1876 | "integrity": "sha512-hLrSMsbFtfjzN+G2IYXYzzoJrmrk2CrszpmcrwCQhcZhlwbQXpZNaN55NSpde6B1QGuW6MoS5Q7Q/PAouNOGKQ==" 1877 | }, 1878 | "@rbxts/services": { 1879 | "version": "1.1.2", 1880 | "resolved": "https://registry.npmjs.org/@rbxts/services/-/services-1.1.2.tgz", 1881 | "integrity": "sha512-vxlo00Q/F1Yq3yGa5jisI1lkWuByJzLs2rfidA4e0wkLCBR0Od+BG55TBMzptCVUZjHUSefif4Mtl3d3a6IxyA==" 1882 | }, 1883 | "@rbxts/types": { 1884 | "version": "1.0.441", 1885 | "resolved": "https://registry.npmjs.org/@rbxts/types/-/types-1.0.441.tgz", 1886 | "integrity": "sha512-uPjojU10lXfbWeT2oh4NUbgcQfL13Tme/AO0VruRkDKSAObvspeA8rUe538awng+Ut3bpuxFVTXBXwYoMeqGtA==", 1887 | "dev": true 1888 | }, 1889 | "@types/json-schema": { 1890 | "version": "7.0.7", 1891 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.7.tgz", 1892 | "integrity": "sha512-cxWFQVseBm6O9Gbw1IWb8r6OS4OhSt3hPZLkFApLjM8TEXROBuQGLAH2i2gZpcXdLBIrpXuTDhH7Vbm1iXmNGA==", 1893 | "dev": true 1894 | }, 1895 | "@types/node": { 1896 | "version": "14.14.22", 1897 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.22.tgz", 1898 | "integrity": "sha512-g+f/qj/cNcqKkc3tFqlXOYjrmZA+jNBiDzbP3kH+B+otKFqAdPgVTGP1IeKRdMml/aE69as5S4FqtxAbl+LaMw==", 1899 | "dev": true 1900 | }, 1901 | "@typescript-eslint/eslint-plugin": { 1902 | "version": "4.14.0", 1903 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-4.14.0.tgz", 1904 | "integrity": "sha512-IJ5e2W7uFNfg4qh9eHkHRUCbgZ8VKtGwD07kannJvM5t/GU8P8+24NX8gi3Hf5jST5oWPY8kyV1s/WtfiZ4+Ww==", 1905 | "dev": true, 1906 | "requires": { 1907 | "@typescript-eslint/experimental-utils": "4.14.0", 1908 | "@typescript-eslint/scope-manager": "4.14.0", 1909 | "debug": "^4.1.1", 1910 | "functional-red-black-tree": "^1.0.1", 1911 | "lodash": "^4.17.15", 1912 | "regexpp": "^3.0.0", 1913 | "semver": "^7.3.2", 1914 | "tsutils": "^3.17.1" 1915 | } 1916 | }, 1917 | "@typescript-eslint/experimental-utils": { 1918 | "version": "4.14.0", 1919 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-4.14.0.tgz", 1920 | "integrity": "sha512-6i6eAoiPlXMKRbXzvoQD5Yn9L7k9ezzGRvzC/x1V3650rUk3c3AOjQyGYyF9BDxQQDK2ElmKOZRD0CbtdkMzQQ==", 1921 | "dev": true, 1922 | "requires": { 1923 | "@types/json-schema": "^7.0.3", 1924 | "@typescript-eslint/scope-manager": "4.14.0", 1925 | "@typescript-eslint/types": "4.14.0", 1926 | "@typescript-eslint/typescript-estree": "4.14.0", 1927 | "eslint-scope": "^5.0.0", 1928 | "eslint-utils": "^2.0.0" 1929 | } 1930 | }, 1931 | "@typescript-eslint/parser": { 1932 | "version": "4.14.0", 1933 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-4.14.0.tgz", 1934 | "integrity": "sha512-sUDeuCjBU+ZF3Lzw0hphTyScmDDJ5QVkyE21pRoBo8iDl7WBtVFS+WDN3blY1CH3SBt7EmYCw6wfmJjF0l/uYg==", 1935 | "dev": true, 1936 | "requires": { 1937 | "@typescript-eslint/scope-manager": "4.14.0", 1938 | "@typescript-eslint/types": "4.14.0", 1939 | "@typescript-eslint/typescript-estree": "4.14.0", 1940 | "debug": "^4.1.1" 1941 | } 1942 | }, 1943 | "@typescript-eslint/scope-manager": { 1944 | "version": "4.14.0", 1945 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-4.14.0.tgz", 1946 | "integrity": "sha512-/J+LlRMdbPh4RdL4hfP1eCwHN5bAhFAGOTsvE6SxsrM/47XQiPSgF5MDgLyp/i9kbZV9Lx80DW0OpPkzL+uf8Q==", 1947 | "dev": true, 1948 | "requires": { 1949 | "@typescript-eslint/types": "4.14.0", 1950 | "@typescript-eslint/visitor-keys": "4.14.0" 1951 | } 1952 | }, 1953 | "@typescript-eslint/types": { 1954 | "version": "4.14.0", 1955 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-4.14.0.tgz", 1956 | "integrity": "sha512-VsQE4VvpldHrTFuVPY1ZnHn/Txw6cZGjL48e+iBxTi2ksa9DmebKjAeFmTVAYoSkTk7gjA7UqJ7pIsyifTsI4A==", 1957 | "dev": true 1958 | }, 1959 | "@typescript-eslint/typescript-estree": { 1960 | "version": "4.14.0", 1961 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-4.14.0.tgz", 1962 | "integrity": "sha512-wRjZ5qLao+bvS2F7pX4qi2oLcOONIB+ru8RGBieDptq/SudYwshveORwCVU4/yMAd4GK7Fsf8Uq1tjV838erag==", 1963 | "dev": true, 1964 | "requires": { 1965 | "@typescript-eslint/types": "4.14.0", 1966 | "@typescript-eslint/visitor-keys": "4.14.0", 1967 | "debug": "^4.1.1", 1968 | "globby": "^11.0.1", 1969 | "is-glob": "^4.0.1", 1970 | "lodash": "^4.17.15", 1971 | "semver": "^7.3.2", 1972 | "tsutils": "^3.17.1" 1973 | } 1974 | }, 1975 | "@typescript-eslint/visitor-keys": { 1976 | "version": "4.14.0", 1977 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-4.14.0.tgz", 1978 | "integrity": "sha512-MeHHzUyRI50DuiPgV9+LxcM52FCJFYjJiWHtXlbyC27b80mfOwKeiKI+MHOTEpcpfmoPFm/vvQS88bYIx6PZTA==", 1979 | "dev": true, 1980 | "requires": { 1981 | "@typescript-eslint/types": "4.14.0", 1982 | "eslint-visitor-keys": "^2.0.0" 1983 | } 1984 | }, 1985 | "acorn": { 1986 | "version": "7.4.1", 1987 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 1988 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 1989 | "dev": true 1990 | }, 1991 | "acorn-jsx": { 1992 | "version": "5.3.1", 1993 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 1994 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 1995 | "dev": true, 1996 | "requires": {} 1997 | }, 1998 | "ajv": { 1999 | "version": "6.12.6", 2000 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2001 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2002 | "dev": true, 2003 | "requires": { 2004 | "fast-deep-equal": "^3.1.1", 2005 | "fast-json-stable-stringify": "^2.0.0", 2006 | "json-schema-traverse": "^0.4.1", 2007 | "uri-js": "^4.2.2" 2008 | } 2009 | }, 2010 | "ansi-colors": { 2011 | "version": "4.1.1", 2012 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 2013 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 2014 | "dev": true 2015 | }, 2016 | "ansi-regex": { 2017 | "version": "5.0.0", 2018 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 2019 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 2020 | "dev": true 2021 | }, 2022 | "ansi-styles": { 2023 | "version": "4.3.0", 2024 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2025 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2026 | "dev": true, 2027 | "requires": { 2028 | "color-convert": "^2.0.1" 2029 | } 2030 | }, 2031 | "argparse": { 2032 | "version": "1.0.10", 2033 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 2034 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 2035 | "dev": true, 2036 | "requires": { 2037 | "sprintf-js": "~1.0.2" 2038 | } 2039 | }, 2040 | "array-union": { 2041 | "version": "2.1.0", 2042 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 2043 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 2044 | "dev": true 2045 | }, 2046 | "astral-regex": { 2047 | "version": "2.0.0", 2048 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 2049 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 2050 | "dev": true 2051 | }, 2052 | "balanced-match": { 2053 | "version": "1.0.0", 2054 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 2055 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 2056 | "dev": true 2057 | }, 2058 | "brace-expansion": { 2059 | "version": "1.1.11", 2060 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2061 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2062 | "dev": true, 2063 | "requires": { 2064 | "balanced-match": "^1.0.0", 2065 | "concat-map": "0.0.1" 2066 | } 2067 | }, 2068 | "braces": { 2069 | "version": "3.0.2", 2070 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2071 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2072 | "dev": true, 2073 | "requires": { 2074 | "fill-range": "^7.0.1" 2075 | } 2076 | }, 2077 | "callsites": { 2078 | "version": "3.1.0", 2079 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2080 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2081 | "dev": true 2082 | }, 2083 | "chalk": { 2084 | "version": "4.1.0", 2085 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 2086 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 2087 | "dev": true, 2088 | "requires": { 2089 | "ansi-styles": "^4.1.0", 2090 | "supports-color": "^7.1.0" 2091 | } 2092 | }, 2093 | "color-convert": { 2094 | "version": "2.0.1", 2095 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2096 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2097 | "dev": true, 2098 | "requires": { 2099 | "color-name": "~1.1.4" 2100 | } 2101 | }, 2102 | "color-name": { 2103 | "version": "1.1.4", 2104 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2105 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2106 | "dev": true 2107 | }, 2108 | "concat-map": { 2109 | "version": "0.0.1", 2110 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2111 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 2112 | "dev": true 2113 | }, 2114 | "cross-spawn": { 2115 | "version": "7.0.3", 2116 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2117 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2118 | "dev": true, 2119 | "requires": { 2120 | "path-key": "^3.1.0", 2121 | "shebang-command": "^2.0.0", 2122 | "which": "^2.0.1" 2123 | } 2124 | }, 2125 | "debug": { 2126 | "version": "4.3.1", 2127 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2128 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2129 | "dev": true, 2130 | "requires": { 2131 | "ms": "2.1.2" 2132 | } 2133 | }, 2134 | "deep-is": { 2135 | "version": "0.1.3", 2136 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 2137 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 2138 | "dev": true 2139 | }, 2140 | "dir-glob": { 2141 | "version": "3.0.1", 2142 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 2143 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 2144 | "dev": true, 2145 | "requires": { 2146 | "path-type": "^4.0.0" 2147 | } 2148 | }, 2149 | "doctrine": { 2150 | "version": "3.0.0", 2151 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2152 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2153 | "dev": true, 2154 | "requires": { 2155 | "esutils": "^2.0.2" 2156 | } 2157 | }, 2158 | "emoji-regex": { 2159 | "version": "8.0.0", 2160 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2161 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2162 | "dev": true 2163 | }, 2164 | "enquirer": { 2165 | "version": "2.3.6", 2166 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 2167 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 2168 | "dev": true, 2169 | "requires": { 2170 | "ansi-colors": "^4.1.1" 2171 | } 2172 | }, 2173 | "escape-string-regexp": { 2174 | "version": "1.0.5", 2175 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2176 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 2177 | "dev": true 2178 | }, 2179 | "eslint": { 2180 | "version": "7.18.0", 2181 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.18.0.tgz", 2182 | "integrity": "sha512-fbgTiE8BfUJZuBeq2Yi7J3RB3WGUQ9PNuNbmgi6jt9Iv8qrkxfy19Ds3OpL1Pm7zg3BtTVhvcUZbIRQ0wmSjAQ==", 2183 | "dev": true, 2184 | "requires": { 2185 | "@babel/code-frame": "^7.0.0", 2186 | "@eslint/eslintrc": "^0.3.0", 2187 | "ajv": "^6.10.0", 2188 | "chalk": "^4.0.0", 2189 | "cross-spawn": "^7.0.2", 2190 | "debug": "^4.0.1", 2191 | "doctrine": "^3.0.0", 2192 | "enquirer": "^2.3.5", 2193 | "eslint-scope": "^5.1.1", 2194 | "eslint-utils": "^2.1.0", 2195 | "eslint-visitor-keys": "^2.0.0", 2196 | "espree": "^7.3.1", 2197 | "esquery": "^1.2.0", 2198 | "esutils": "^2.0.2", 2199 | "file-entry-cache": "^6.0.0", 2200 | "functional-red-black-tree": "^1.0.1", 2201 | "glob-parent": "^5.0.0", 2202 | "globals": "^12.1.0", 2203 | "ignore": "^4.0.6", 2204 | "import-fresh": "^3.0.0", 2205 | "imurmurhash": "^0.1.4", 2206 | "is-glob": "^4.0.0", 2207 | "js-yaml": "^3.13.1", 2208 | "json-stable-stringify-without-jsonify": "^1.0.1", 2209 | "levn": "^0.4.1", 2210 | "lodash": "^4.17.20", 2211 | "minimatch": "^3.0.4", 2212 | "natural-compare": "^1.4.0", 2213 | "optionator": "^0.9.1", 2214 | "progress": "^2.0.0", 2215 | "regexpp": "^3.1.0", 2216 | "semver": "^7.2.1", 2217 | "strip-ansi": "^6.0.0", 2218 | "strip-json-comments": "^3.1.0", 2219 | "table": "^6.0.4", 2220 | "text-table": "^0.2.0", 2221 | "v8-compile-cache": "^2.0.3" 2222 | } 2223 | }, 2224 | "eslint-config-prettier": { 2225 | "version": "7.2.0", 2226 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-7.2.0.tgz", 2227 | "integrity": "sha512-rV4Qu0C3nfJKPOAhFujFxB7RMP+URFyQqqOZW9DMRD7ZDTFyjaIlETU3xzHELt++4ugC0+Jm084HQYkkJe+Ivg==", 2228 | "dev": true, 2229 | "requires": {} 2230 | }, 2231 | "eslint-plugin-prettier": { 2232 | "version": "3.3.1", 2233 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.3.1.tgz", 2234 | "integrity": "sha512-Rq3jkcFY8RYeQLgk2cCwuc0P7SEFwDravPhsJZOQ5N4YI4DSg50NyqJ/9gdZHzQlHf8MvafSesbNJCcP/FF6pQ==", 2235 | "dev": true, 2236 | "requires": { 2237 | "prettier-linter-helpers": "^1.0.0" 2238 | } 2239 | }, 2240 | "eslint-plugin-roblox-ts": { 2241 | "version": "0.0.24", 2242 | "resolved": "https://registry.npmjs.org/eslint-plugin-roblox-ts/-/eslint-plugin-roblox-ts-0.0.24.tgz", 2243 | "integrity": "sha512-KwYUT8fdlS8gG6IfFnmyTwoWldR+4L5wCEk5NifKQ1L8OX1frrG61o6LkuyQvX0MtOeEj2CKo3qZyvfOuDb3Aw==", 2244 | "dev": true, 2245 | "requires": { 2246 | "@types/node": "^14.11.8", 2247 | "@typescript-eslint/experimental-utils": "^4.4.1", 2248 | "typescript": "^4.0.3" 2249 | } 2250 | }, 2251 | "eslint-scope": { 2252 | "version": "5.1.1", 2253 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 2254 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 2255 | "dev": true, 2256 | "requires": { 2257 | "esrecurse": "^4.3.0", 2258 | "estraverse": "^4.1.1" 2259 | } 2260 | }, 2261 | "eslint-utils": { 2262 | "version": "2.1.0", 2263 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 2264 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 2265 | "dev": true, 2266 | "requires": { 2267 | "eslint-visitor-keys": "^1.1.0" 2268 | }, 2269 | "dependencies": { 2270 | "eslint-visitor-keys": { 2271 | "version": "1.3.0", 2272 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 2273 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 2274 | "dev": true 2275 | } 2276 | } 2277 | }, 2278 | "eslint-visitor-keys": { 2279 | "version": "2.0.0", 2280 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 2281 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 2282 | "dev": true 2283 | }, 2284 | "espree": { 2285 | "version": "7.3.1", 2286 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 2287 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 2288 | "dev": true, 2289 | "requires": { 2290 | "acorn": "^7.4.0", 2291 | "acorn-jsx": "^5.3.1", 2292 | "eslint-visitor-keys": "^1.3.0" 2293 | }, 2294 | "dependencies": { 2295 | "eslint-visitor-keys": { 2296 | "version": "1.3.0", 2297 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 2298 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 2299 | "dev": true 2300 | } 2301 | } 2302 | }, 2303 | "esprima": { 2304 | "version": "4.0.1", 2305 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 2306 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 2307 | "dev": true 2308 | }, 2309 | "esquery": { 2310 | "version": "1.3.1", 2311 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 2312 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 2313 | "dev": true, 2314 | "requires": { 2315 | "estraverse": "^5.1.0" 2316 | }, 2317 | "dependencies": { 2318 | "estraverse": { 2319 | "version": "5.2.0", 2320 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 2321 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 2322 | "dev": true 2323 | } 2324 | } 2325 | }, 2326 | "esrecurse": { 2327 | "version": "4.3.0", 2328 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2329 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2330 | "dev": true, 2331 | "requires": { 2332 | "estraverse": "^5.2.0" 2333 | }, 2334 | "dependencies": { 2335 | "estraverse": { 2336 | "version": "5.2.0", 2337 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 2338 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 2339 | "dev": true 2340 | } 2341 | } 2342 | }, 2343 | "estraverse": { 2344 | "version": "4.3.0", 2345 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 2346 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 2347 | "dev": true 2348 | }, 2349 | "esutils": { 2350 | "version": "2.0.3", 2351 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2352 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2353 | "dev": true 2354 | }, 2355 | "fast-deep-equal": { 2356 | "version": "3.1.3", 2357 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2358 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2359 | "dev": true 2360 | }, 2361 | "fast-diff": { 2362 | "version": "1.2.0", 2363 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 2364 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 2365 | "dev": true 2366 | }, 2367 | "fast-glob": { 2368 | "version": "3.2.5", 2369 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.5.tgz", 2370 | "integrity": "sha512-2DtFcgT68wiTTiwZ2hNdJfcHNke9XOfnwmBRWXhmeKM8rF0TGwmC/Qto3S7RoZKp5cilZbxzO5iTNTQsJ+EeDg==", 2371 | "dev": true, 2372 | "requires": { 2373 | "@nodelib/fs.stat": "^2.0.2", 2374 | "@nodelib/fs.walk": "^1.2.3", 2375 | "glob-parent": "^5.1.0", 2376 | "merge2": "^1.3.0", 2377 | "micromatch": "^4.0.2", 2378 | "picomatch": "^2.2.1" 2379 | } 2380 | }, 2381 | "fast-json-stable-stringify": { 2382 | "version": "2.1.0", 2383 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2384 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2385 | "dev": true 2386 | }, 2387 | "fast-levenshtein": { 2388 | "version": "2.0.6", 2389 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2390 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 2391 | "dev": true 2392 | }, 2393 | "fastq": { 2394 | "version": "1.10.0", 2395 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.10.0.tgz", 2396 | "integrity": "sha512-NL2Qc5L3iQEsyYzweq7qfgy5OtXCmGzGvhElGEd/SoFWEMOEczNh5s5ocaF01HDetxz+p8ecjNPA6cZxxIHmzA==", 2397 | "dev": true, 2398 | "requires": { 2399 | "reusify": "^1.0.4" 2400 | } 2401 | }, 2402 | "file-entry-cache": { 2403 | "version": "6.0.0", 2404 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.0.tgz", 2405 | "integrity": "sha512-fqoO76jZ3ZnYrXLDRxBR1YvOvc0k844kcOg40bgsPrE25LAb/PDqTY+ho64Xh2c8ZXgIKldchCFHczG2UVRcWA==", 2406 | "dev": true, 2407 | "requires": { 2408 | "flat-cache": "^3.0.4" 2409 | } 2410 | }, 2411 | "fill-range": { 2412 | "version": "7.0.1", 2413 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2414 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2415 | "dev": true, 2416 | "requires": { 2417 | "to-regex-range": "^5.0.1" 2418 | } 2419 | }, 2420 | "flat-cache": { 2421 | "version": "3.0.4", 2422 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 2423 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 2424 | "dev": true, 2425 | "requires": { 2426 | "flatted": "^3.1.0", 2427 | "rimraf": "^3.0.2" 2428 | } 2429 | }, 2430 | "flatted": { 2431 | "version": "3.1.1", 2432 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 2433 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 2434 | "dev": true 2435 | }, 2436 | "fs.realpath": { 2437 | "version": "1.0.0", 2438 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2439 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2440 | "dev": true 2441 | }, 2442 | "functional-red-black-tree": { 2443 | "version": "1.0.1", 2444 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 2445 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 2446 | "dev": true 2447 | }, 2448 | "glob": { 2449 | "version": "7.1.6", 2450 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 2451 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 2452 | "dev": true, 2453 | "requires": { 2454 | "fs.realpath": "^1.0.0", 2455 | "inflight": "^1.0.4", 2456 | "inherits": "2", 2457 | "minimatch": "^3.0.4", 2458 | "once": "^1.3.0", 2459 | "path-is-absolute": "^1.0.0" 2460 | } 2461 | }, 2462 | "glob-parent": { 2463 | "version": "5.1.1", 2464 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 2465 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 2466 | "dev": true, 2467 | "requires": { 2468 | "is-glob": "^4.0.1" 2469 | } 2470 | }, 2471 | "globals": { 2472 | "version": "12.4.0", 2473 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 2474 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 2475 | "dev": true, 2476 | "requires": { 2477 | "type-fest": "^0.8.1" 2478 | } 2479 | }, 2480 | "globby": { 2481 | "version": "11.0.2", 2482 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.0.2.tgz", 2483 | "integrity": "sha512-2ZThXDvvV8fYFRVIxnrMQBipZQDr7MxKAmQK1vujaj9/7eF0efG7BPUKJ7jP7G5SLF37xKDXvO4S/KKLj/Z0og==", 2484 | "dev": true, 2485 | "requires": { 2486 | "array-union": "^2.1.0", 2487 | "dir-glob": "^3.0.1", 2488 | "fast-glob": "^3.1.1", 2489 | "ignore": "^5.1.4", 2490 | "merge2": "^1.3.0", 2491 | "slash": "^3.0.0" 2492 | }, 2493 | "dependencies": { 2494 | "ignore": { 2495 | "version": "5.1.8", 2496 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.8.tgz", 2497 | "integrity": "sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw==", 2498 | "dev": true 2499 | } 2500 | } 2501 | }, 2502 | "has-flag": { 2503 | "version": "4.0.0", 2504 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2505 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2506 | "dev": true 2507 | }, 2508 | "ignore": { 2509 | "version": "4.0.6", 2510 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 2511 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 2512 | "dev": true 2513 | }, 2514 | "import-fresh": { 2515 | "version": "3.3.0", 2516 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2517 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2518 | "dev": true, 2519 | "requires": { 2520 | "parent-module": "^1.0.0", 2521 | "resolve-from": "^4.0.0" 2522 | } 2523 | }, 2524 | "imurmurhash": { 2525 | "version": "0.1.4", 2526 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2527 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2528 | "dev": true 2529 | }, 2530 | "inflight": { 2531 | "version": "1.0.6", 2532 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2533 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2534 | "dev": true, 2535 | "requires": { 2536 | "once": "^1.3.0", 2537 | "wrappy": "1" 2538 | } 2539 | }, 2540 | "inherits": { 2541 | "version": "2.0.4", 2542 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2543 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2544 | "dev": true 2545 | }, 2546 | "is-extglob": { 2547 | "version": "2.1.1", 2548 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2549 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 2550 | "dev": true 2551 | }, 2552 | "is-fullwidth-code-point": { 2553 | "version": "3.0.0", 2554 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2555 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2556 | "dev": true 2557 | }, 2558 | "is-glob": { 2559 | "version": "4.0.1", 2560 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 2561 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 2562 | "dev": true, 2563 | "requires": { 2564 | "is-extglob": "^2.1.1" 2565 | } 2566 | }, 2567 | "is-number": { 2568 | "version": "7.0.0", 2569 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2570 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2571 | "dev": true 2572 | }, 2573 | "isexe": { 2574 | "version": "2.0.0", 2575 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2576 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2577 | "dev": true 2578 | }, 2579 | "js-tokens": { 2580 | "version": "4.0.0", 2581 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2582 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2583 | "dev": true 2584 | }, 2585 | "js-yaml": { 2586 | "version": "3.14.1", 2587 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2588 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2589 | "dev": true, 2590 | "requires": { 2591 | "argparse": "^1.0.7", 2592 | "esprima": "^4.0.0" 2593 | } 2594 | }, 2595 | "json-schema-traverse": { 2596 | "version": "0.4.1", 2597 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2598 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2599 | "dev": true 2600 | }, 2601 | "json-stable-stringify-without-jsonify": { 2602 | "version": "1.0.1", 2603 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2604 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2605 | "dev": true 2606 | }, 2607 | "levn": { 2608 | "version": "0.4.1", 2609 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2610 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2611 | "dev": true, 2612 | "requires": { 2613 | "prelude-ls": "^1.2.1", 2614 | "type-check": "~0.4.0" 2615 | } 2616 | }, 2617 | "lodash": { 2618 | "version": "4.17.20", 2619 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz", 2620 | "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==", 2621 | "dev": true 2622 | }, 2623 | "lru-cache": { 2624 | "version": "6.0.0", 2625 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2626 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2627 | "dev": true, 2628 | "requires": { 2629 | "yallist": "^4.0.0" 2630 | } 2631 | }, 2632 | "merge2": { 2633 | "version": "1.4.1", 2634 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2635 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2636 | "dev": true 2637 | }, 2638 | "micromatch": { 2639 | "version": "4.0.2", 2640 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz", 2641 | "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==", 2642 | "dev": true, 2643 | "requires": { 2644 | "braces": "^3.0.1", 2645 | "picomatch": "^2.0.5" 2646 | } 2647 | }, 2648 | "minimatch": { 2649 | "version": "3.0.4", 2650 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2651 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2652 | "dev": true, 2653 | "requires": { 2654 | "brace-expansion": "^1.1.7" 2655 | } 2656 | }, 2657 | "ms": { 2658 | "version": "2.1.2", 2659 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2660 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2661 | "dev": true 2662 | }, 2663 | "natural-compare": { 2664 | "version": "1.4.0", 2665 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2666 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2667 | "dev": true 2668 | }, 2669 | "once": { 2670 | "version": "1.4.0", 2671 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2672 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2673 | "dev": true, 2674 | "requires": { 2675 | "wrappy": "1" 2676 | } 2677 | }, 2678 | "optionator": { 2679 | "version": "0.9.1", 2680 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2681 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2682 | "dev": true, 2683 | "requires": { 2684 | "deep-is": "^0.1.3", 2685 | "fast-levenshtein": "^2.0.6", 2686 | "levn": "^0.4.1", 2687 | "prelude-ls": "^1.2.1", 2688 | "type-check": "^0.4.0", 2689 | "word-wrap": "^1.2.3" 2690 | } 2691 | }, 2692 | "parent-module": { 2693 | "version": "1.0.1", 2694 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2695 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2696 | "dev": true, 2697 | "requires": { 2698 | "callsites": "^3.0.0" 2699 | } 2700 | }, 2701 | "path-is-absolute": { 2702 | "version": "1.0.1", 2703 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2704 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2705 | "dev": true 2706 | }, 2707 | "path-key": { 2708 | "version": "3.1.1", 2709 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2710 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2711 | "dev": true 2712 | }, 2713 | "path-type": { 2714 | "version": "4.0.0", 2715 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2716 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2717 | "dev": true 2718 | }, 2719 | "picomatch": { 2720 | "version": "2.2.2", 2721 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 2722 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 2723 | "dev": true 2724 | }, 2725 | "prelude-ls": { 2726 | "version": "1.2.1", 2727 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2728 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2729 | "dev": true 2730 | }, 2731 | "prettier": { 2732 | "version": "2.2.1", 2733 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.2.1.tgz", 2734 | "integrity": "sha512-PqyhM2yCjg/oKkFPtTGUojv7gnZAoG80ttl45O6x2Ug/rMJw4wcc9k6aaf2hibP7BGVCCM33gZoGjyvt9mm16Q==", 2735 | "dev": true 2736 | }, 2737 | "prettier-linter-helpers": { 2738 | "version": "1.0.0", 2739 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 2740 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 2741 | "dev": true, 2742 | "requires": { 2743 | "fast-diff": "^1.1.2" 2744 | } 2745 | }, 2746 | "progress": { 2747 | "version": "2.0.3", 2748 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2749 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2750 | "dev": true 2751 | }, 2752 | "punycode": { 2753 | "version": "2.1.1", 2754 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2755 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2756 | "dev": true 2757 | }, 2758 | "regexpp": { 2759 | "version": "3.1.0", 2760 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 2761 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 2762 | "dev": true 2763 | }, 2764 | "require-from-string": { 2765 | "version": "2.0.2", 2766 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 2767 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 2768 | "dev": true 2769 | }, 2770 | "resolve-from": { 2771 | "version": "4.0.0", 2772 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2773 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2774 | "dev": true 2775 | }, 2776 | "reusify": { 2777 | "version": "1.0.4", 2778 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2779 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2780 | "dev": true 2781 | }, 2782 | "rimraf": { 2783 | "version": "3.0.2", 2784 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2785 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2786 | "dev": true, 2787 | "requires": { 2788 | "glob": "^7.1.3" 2789 | } 2790 | }, 2791 | "run-parallel": { 2792 | "version": "1.1.10", 2793 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.1.10.tgz", 2794 | "integrity": "sha512-zb/1OuZ6flOlH6tQyMPUrE3x3Ulxjlo9WIVXR4yVYi4H9UXQaeIsPbLn2R3O3vQCnDKkAl2qHiuocKKX4Tz/Sw==", 2795 | "dev": true 2796 | }, 2797 | "semver": { 2798 | "version": "7.3.4", 2799 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", 2800 | "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", 2801 | "dev": true, 2802 | "requires": { 2803 | "lru-cache": "^6.0.0" 2804 | } 2805 | }, 2806 | "shebang-command": { 2807 | "version": "2.0.0", 2808 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2809 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2810 | "dev": true, 2811 | "requires": { 2812 | "shebang-regex": "^3.0.0" 2813 | } 2814 | }, 2815 | "shebang-regex": { 2816 | "version": "3.0.0", 2817 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2818 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2819 | "dev": true 2820 | }, 2821 | "slash": { 2822 | "version": "3.0.0", 2823 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2824 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2825 | "dev": true 2826 | }, 2827 | "slice-ansi": { 2828 | "version": "4.0.0", 2829 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 2830 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 2831 | "dev": true, 2832 | "requires": { 2833 | "ansi-styles": "^4.0.0", 2834 | "astral-regex": "^2.0.0", 2835 | "is-fullwidth-code-point": "^3.0.0" 2836 | } 2837 | }, 2838 | "sprintf-js": { 2839 | "version": "1.0.3", 2840 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2841 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2842 | "dev": true 2843 | }, 2844 | "string-width": { 2845 | "version": "4.2.0", 2846 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 2847 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 2848 | "dev": true, 2849 | "requires": { 2850 | "emoji-regex": "^8.0.0", 2851 | "is-fullwidth-code-point": "^3.0.0", 2852 | "strip-ansi": "^6.0.0" 2853 | } 2854 | }, 2855 | "strip-ansi": { 2856 | "version": "6.0.0", 2857 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2858 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2859 | "dev": true, 2860 | "requires": { 2861 | "ansi-regex": "^5.0.0" 2862 | } 2863 | }, 2864 | "strip-json-comments": { 2865 | "version": "3.1.1", 2866 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2867 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2868 | "dev": true 2869 | }, 2870 | "supports-color": { 2871 | "version": "7.2.0", 2872 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2873 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2874 | "dev": true, 2875 | "requires": { 2876 | "has-flag": "^4.0.0" 2877 | } 2878 | }, 2879 | "table": { 2880 | "version": "6.0.7", 2881 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.7.tgz", 2882 | "integrity": "sha512-rxZevLGTUzWna/qBLObOe16kB2RTnnbhciwgPbMMlazz1yZGVEgnZK762xyVdVznhqxrfCeBMmMkgOOaPwjH7g==", 2883 | "dev": true, 2884 | "requires": { 2885 | "ajv": "^7.0.2", 2886 | "lodash": "^4.17.20", 2887 | "slice-ansi": "^4.0.0", 2888 | "string-width": "^4.2.0" 2889 | }, 2890 | "dependencies": { 2891 | "ajv": { 2892 | "version": "7.0.3", 2893 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-7.0.3.tgz", 2894 | "integrity": "sha512-R50QRlXSxqXcQP5SvKUrw8VZeypvo12i2IX0EeR5PiZ7bEKeHWgzgo264LDadUsCU42lTJVhFikTqJwNeH34gQ==", 2895 | "dev": true, 2896 | "requires": { 2897 | "fast-deep-equal": "^3.1.1", 2898 | "json-schema-traverse": "^1.0.0", 2899 | "require-from-string": "^2.0.2", 2900 | "uri-js": "^4.2.2" 2901 | } 2902 | }, 2903 | "json-schema-traverse": { 2904 | "version": "1.0.0", 2905 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 2906 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 2907 | "dev": true 2908 | } 2909 | } 2910 | }, 2911 | "text-table": { 2912 | "version": "0.2.0", 2913 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2914 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2915 | "dev": true 2916 | }, 2917 | "to-regex-range": { 2918 | "version": "5.0.1", 2919 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2920 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2921 | "dev": true, 2922 | "requires": { 2923 | "is-number": "^7.0.0" 2924 | } 2925 | }, 2926 | "tslib": { 2927 | "version": "1.14.1", 2928 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2929 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2930 | "dev": true 2931 | }, 2932 | "tsutils": { 2933 | "version": "3.19.1", 2934 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.19.1.tgz", 2935 | "integrity": "sha512-GEdoBf5XI324lu7ycad7s6laADfnAqCw6wLGI+knxvw9vsIYBaJfYdmeCEG3FMMUiSm3OGgNb+m6utsWf5h9Vw==", 2936 | "dev": true, 2937 | "requires": { 2938 | "tslib": "^1.8.1" 2939 | } 2940 | }, 2941 | "type-check": { 2942 | "version": "0.4.0", 2943 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2944 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2945 | "dev": true, 2946 | "requires": { 2947 | "prelude-ls": "^1.2.1" 2948 | } 2949 | }, 2950 | "type-fest": { 2951 | "version": "0.8.1", 2952 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2953 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2954 | "dev": true 2955 | }, 2956 | "typescript": { 2957 | "version": "4.1.3", 2958 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.1.3.tgz", 2959 | "integrity": "sha512-B3ZIOf1IKeH2ixgHhj6la6xdwR9QrLC5d1VKeCSY4tvkqhF2eqd9O7txNlS0PO3GrBAFIdr3L1ndNwteUbZLYg==", 2960 | "dev": true 2961 | }, 2962 | "uri-js": { 2963 | "version": "4.4.1", 2964 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2965 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2966 | "dev": true, 2967 | "requires": { 2968 | "punycode": "^2.1.0" 2969 | } 2970 | }, 2971 | "v8-compile-cache": { 2972 | "version": "2.2.0", 2973 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.2.0.tgz", 2974 | "integrity": "sha512-gTpR5XQNKFwOd4clxfnhaqvfqMpqEwr4tOtCyz4MtYZX2JYhfr1JvBFKdS+7K/9rfpZR3VLX+YWBbKoxCgS43Q==", 2975 | "dev": true 2976 | }, 2977 | "which": { 2978 | "version": "2.0.2", 2979 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2980 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2981 | "dev": true, 2982 | "requires": { 2983 | "isexe": "^2.0.0" 2984 | } 2985 | }, 2986 | "word-wrap": { 2987 | "version": "1.2.3", 2988 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2989 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2990 | "dev": true 2991 | }, 2992 | "wrappy": { 2993 | "version": "1.0.2", 2994 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2995 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2996 | "dev": true 2997 | }, 2998 | "yallist": { 2999 | "version": "4.0.0", 3000 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3001 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3002 | "dev": true 3003 | } 3004 | } 3005 | } 3006 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "learning-tsx", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "ISC", 12 | "devDependencies": { 13 | "@rbxts/compiler-types": "^1.0.0-beta.15.0", 14 | "@rbxts/types": "^1.0.441", 15 | "@typescript-eslint/eslint-plugin": "^4.14.0", 16 | "@typescript-eslint/parser": "^4.14.0", 17 | "eslint": "^7.18.0", 18 | "eslint-config-prettier": "^7.2.0", 19 | "eslint-plugin-prettier": "^3.3.1", 20 | "eslint-plugin-roblox-ts": "^0.0.24", 21 | "prettier": "^2.2.1", 22 | "typescript": "^4.1.3" 23 | }, 24 | "dependencies": { 25 | "@rbxts/roact": "^1.3.0-ts.10", 26 | "@rbxts/services": "^1.1.2" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /src/App/counter.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { AutoTextLabel } from "../Components/Dynamic/TextLabel"; 3 | 4 | interface counterState { 5 | currency: number; 6 | } 7 | interface counterProps {} 8 | 9 | // Counter component which gets displayed at the top of the screen 10 | export class Counter extends Roact.Component { 11 | constructor(props: counterProps) { 12 | super(props); 13 | 14 | this.setState({ currency: 0 }); 15 | } 16 | 17 | render() { 18 | return ( 19 | 25 | 26 | 32 | 33 | 40 | 41 | 42 | 49 | 50 | ); 51 | } 52 | } 53 | -------------------------------------------------------------------------------- /src/App/index.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Counter } from "./counter"; 3 | 4 | interface appState {} 5 | interface appProps {} 6 | 7 | // Generic app component for HUD interface 8 | export class App extends Roact.Component { 9 | render() { 10 | return ( 11 | 12 | ); 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /src/Components/Close.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Context, Pages } from "../Context"; 3 | 4 | interface CloseState {} 5 | interface CloseProps {} 6 | 7 | // Close the page with this button, sets the value to 0 (0 = none) 8 | export class Close extends Roact.Component { 9 | constructor(props: CloseProps) { 10 | super(props); 11 | } 12 | 13 | render(): Roact.Element { 14 | return ( 15 | void }) => { 17 | return ( 18 | value.setPage(Pages.none), 26 | }} 27 | > 28 | 29 | 35 | 43 | 44 | ); 45 | }} 46 | > 47 | ); 48 | } 49 | } 50 | -------------------------------------------------------------------------------- /src/Components/Dynamic/ScrollingFrame.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | 3 | // A function that updates the size of the scrolling frame 4 | function updateContentSize(scrollingFrame: ScrollingFrame) { 5 | const gridLayout = scrollingFrame.FindFirstChildWhichIsA("UIGridStyleLayout")!; 6 | if (!gridLayout) throw `No UIGridStyleLayout was found in ${scrollingFrame.GetFullName()}`; 7 | 8 | function resizeCanvas() { 9 | scrollingFrame.CanvasSize = UDim2.fromOffset( 10 | gridLayout.AbsoluteContentSize.X, 11 | gridLayout.AbsoluteContentSize.Y, 12 | ); 13 | } 14 | 15 | gridLayout.GetPropertyChangedSignal("AbsoluteContentSize").Connect(resizeCanvas); 16 | resizeCanvas(); 17 | } 18 | 19 | interface frameState {} 20 | interface frameProps extends Partial {} 21 | 22 | // Rescaling scrolling frame written by Overhash 23 | export class AutoScrollingFrame extends Roact.Component { 24 | ref: Roact.Ref; 25 | 26 | constructor(props: frameProps) { 27 | super(props); 28 | 29 | this.ref = Roact.createRef(); 30 | } 31 | 32 | didMount() { 33 | updateContentSize(this.ref.getValue()!); 34 | } 35 | 36 | render() { 37 | return ; 38 | } 39 | } 40 | -------------------------------------------------------------------------------- /src/Components/Dynamic/TextLabel.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { TextService } from "@rbxts/services"; 3 | 4 | // A function that updates the size of a text label 5 | function updateContentSize(textLabel: TextLabel) { 6 | function resizeLabel() { 7 | const labelSize = TextService.GetTextSize( 8 | textLabel.Text, 9 | textLabel.TextSize, 10 | textLabel.Font, 11 | new Vector2(500, textLabel.AbsoluteSize.Y), 12 | ); 13 | 14 | textLabel.Size = UDim2.fromOffset(labelSize.X, textLabel.AbsoluteSize.Y); 15 | } 16 | 17 | textLabel.GetPropertyChangedSignal("Text").Connect(resizeLabel); 18 | resizeLabel(); 19 | } 20 | 21 | interface labelState {} 22 | interface labelProps extends Partial {} 23 | 24 | // A dynamic text label which resizes to fit text 25 | export class AutoTextLabel extends Roact.Component { 26 | ref: Roact.Ref; 27 | 28 | constructor(props: labelProps) { 29 | super(props); 30 | 31 | this.ref = Roact.createRef(); 32 | } 33 | 34 | didMount() { 35 | updateContentSize(this.ref.getValue()!); 36 | } 37 | 38 | render() { 39 | return ; 40 | } 41 | } 42 | -------------------------------------------------------------------------------- /src/Components/Item.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | 3 | interface itemState { 4 | promptVisible: boolean; 5 | } 6 | interface itemProps { 7 | title: string; 8 | desc?: string; 9 | color?: Color3; 10 | layoutOrder?: number; 11 | } 12 | 13 | // Generic item component that gets reused in all of the pages 14 | export class Item extends Roact.Component { 15 | constructor(props: itemProps) { 16 | super(props); 17 | 18 | this.setState({ promptVisible: false }); 19 | } 20 | 21 | render() { 22 | return ( 23 | this.setState({ promptVisible: true }), 30 | MouseLeave: () => this.setState({ promptVisible: false }), 31 | }} 32 | > 33 | 34 | 40 | 49 | 63 | 72 | 73 | 74 | 75 | ); 76 | } 77 | } 78 | -------------------------------------------------------------------------------- /src/Components/Panel.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Context } from "../Context"; 3 | 4 | interface panelState { 5 | panelVisible: boolean; 6 | } 7 | interface panelProps { 8 | index: number; 9 | visible?: boolean; 10 | } 11 | 12 | // Panel is a full-screen size frame that allows you to toggle visibility 13 | // for your toggles 14 | export class Panel extends Roact.Component { 15 | constructor(props: panelProps) { 16 | super(props); 17 | 18 | this.setState({ 19 | panelVisible: false, 20 | }); 21 | } 22 | 23 | render(): Roact.Element { 24 | return ( 25 | void }) => { 27 | if (this.state.panelVisible === true && value.viewIndex !== this.props.index) { 28 | this.setState({ panelVisible: false }); 29 | } else if (this.state.panelVisible === false && value.viewIndex === this.props.index) { 30 | this.setState({ panelVisible: true }); 31 | } 32 | 33 | return ( 34 | 44 | {this.props[Roact.Children]} 45 | 46 | ); 47 | }} 48 | > 49 | ); 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /src/Components/Tab.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | 3 | interface tabState {} 4 | interface tabProps { 5 | onClick: (page: string) => void; 6 | page: string; 7 | text: string; 8 | } 9 | 10 | // Tab component used for swapping tabs in pages 11 | export class Tab extends Roact.Component { 12 | constructor(props: tabProps) { 13 | super(props); 14 | } 15 | 16 | render() { 17 | return ( 18 | { 27 | this.props.onClick(this.props.page); 28 | }, 29 | }} 30 | > 31 | 32 | 33 | ); 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /src/Components/Toggle.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | 3 | interface toggleState {} 4 | interface toggleProps { 5 | onClick: () => void; 6 | text: string; 7 | layout: number; 8 | image: string; 9 | } 10 | 11 | // A generic toggle on the side of the screen used to open an associated panel 12 | export class Toggle extends Roact.Component { 13 | constructor(props: toggleProps) { 14 | super(props); 15 | } 16 | 17 | render() { 18 | return ( 19 | this.props.onClick(), 27 | }} 28 | > 29 | 30 | 31 | 37 | 45 | 46 | ); 47 | } 48 | } 49 | -------------------------------------------------------------------------------- /src/Context.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | 3 | // A map of the pages to have consistency 4 | export const Pages = { 5 | none: 0, 6 | shop: 1, 7 | inventory: 2, 8 | }; 9 | 10 | // The context used for page swapping 11 | export const Context = Roact.createContext({ 12 | viewIndex: 0, 13 | setPage: (index: number) => {}, 14 | }); 15 | -------------------------------------------------------------------------------- /src/Main.client.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Players } from "@rbxts/services"; 3 | import { Router } from "./Router"; 4 | 5 | const Player = Players.LocalPlayer; 6 | const PlayerGui = Player.WaitForChild("PlayerGui"); 7 | 8 | // Initialize and mount Roact on runtime 9 | Roact.mount( 10 | 11 | 12 | , 13 | PlayerGui, 14 | ); 15 | -------------------------------------------------------------------------------- /src/Pages/Inventory/index.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Pages } from "../../Context"; 3 | import { Panel } from "../../Components/Panel"; 4 | import { Close } from "../../Components/Close"; 5 | import { Owned } from "./owned"; 6 | import { Tab } from "../../Components/Tab"; 7 | 8 | interface inventoryState { 9 | data: Array; 10 | pageVisible: string; 11 | } 12 | interface inventoryProps { 13 | visible?: boolean; 14 | } 15 | 16 | // This is a demo array, remove this and replace with your array of data 17 | const Tbl = [ 18 | { 19 | name: "arm", 20 | color: Color3.fromRGB(8, 48, 17), 21 | desc: "this is a description, short and cute", 22 | }, 23 | { 24 | name: "arm", 25 | color: Color3.fromRGB(8, 48, 17), 26 | }, 27 | { 28 | name: "arm", 29 | color: Color3.fromRGB(8, 48, 17), 30 | }, 31 | { 32 | name: "arm", 33 | color: Color3.fromRGB(8, 48, 17), 34 | }, 35 | { 36 | name: "arm", 37 | color: Color3.fromRGB(8, 48, 17), 38 | }, 39 | { 40 | name: "arm", 41 | color: Color3.fromRGB(8, 48, 17), 42 | }, 43 | { 44 | name: "arm", 45 | color: Color3.fromRGB(8, 48, 17), 46 | }, 47 | ]; 48 | 49 | export interface Data { 50 | name: string; 51 | color: Color3; 52 | desc?: string; 53 | } 54 | 55 | // Inventory component page which corresponds to the toggles and context 56 | export class Inventory extends Roact.Component { 57 | constructor(props: inventoryProps) { 58 | super(props); 59 | 60 | this.setState({ data: Tbl, pageVisible: "owned" }); 61 | } 62 | 63 | render() { 64 | return ( 65 | 66 | 74 | 75 | 81 | 82 | 83 | 84 | this.setState({ pageVisible: page })} /> 85 | 86 | 87 | 88 | 89 | ); 90 | } 91 | } 92 | -------------------------------------------------------------------------------- /src/Pages/Inventory/owned.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Item } from "../../Components/Item"; 3 | import { AutoScrollingFrame } from "../../Components/Dynamic/ScrollingFrame"; 4 | import { Data } from "./index"; 5 | 6 | interface pageState {} 7 | interface pageProps { 8 | data: Array; 9 | visible: string; 10 | } 11 | 12 | // Create the owned page inside the main component 13 | export class Owned extends Roact.Component { 14 | constructor(props: pageProps) { 15 | super(props); 16 | } 17 | 18 | render() { 19 | return ( 20 | 29 | 35 | 36 | {this.props.data.map((info) => ( 37 | 38 | ))} 39 | 40 | 41 | ); 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /src/Pages/Shop/gamepass.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Item } from "../../Components/Item"; 3 | import { AutoScrollingFrame } from "../../Components/Dynamic/ScrollingFrame"; 4 | import { Data } from "./index"; 5 | 6 | interface pageState {} 7 | interface pageProps { 8 | data: Array; 9 | visible: string; 10 | } 11 | 12 | // Create the gamepass page inside the main component 13 | export class Gamepass extends Roact.Component { 14 | constructor(props: pageProps) { 15 | super(props); 16 | } 17 | 18 | render() { 19 | return ( 20 | 29 | 35 | 36 | {this.props.data.map((info) => ( 37 | 38 | ))} 39 | 40 | 41 | ); 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /src/Pages/Shop/index.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Pages } from "../../Context"; 3 | import { Panel } from "../../Components/Panel"; 4 | import { Close } from "../../Components/Close"; 5 | import { Gamepass } from "./gamepass"; 6 | import { Money } from "./money"; 7 | import { Tab } from "../../Components/Tab"; 8 | 9 | interface shopState { 10 | data: Array; 11 | pageVisible: string; 12 | } 13 | interface shopProps { 14 | visible?: boolean; 15 | } 16 | 17 | // This is a demo array, remove this and replace with your array of data 18 | const Tbl = [ 19 | { 20 | name: "arm", 21 | color: Color3.fromRGB(8, 48, 17), 22 | desc: "this is a description, short and cute", 23 | }, 24 | { 25 | name: "arm", 26 | color: Color3.fromRGB(8, 48, 17), 27 | }, 28 | { 29 | name: "arm", 30 | color: Color3.fromRGB(8, 48, 17), 31 | }, 32 | { 33 | name: "arm", 34 | color: Color3.fromRGB(8, 48, 17), 35 | }, 36 | { 37 | name: "arm", 38 | color: Color3.fromRGB(8, 48, 17), 39 | }, 40 | { 41 | name: "arm", 42 | color: Color3.fromRGB(8, 48, 17), 43 | }, 44 | { 45 | name: "arm", 46 | color: Color3.fromRGB(8, 48, 17), 47 | }, 48 | ]; 49 | 50 | export interface Data { 51 | name: string; 52 | color: Color3; 53 | desc?: string; 54 | } 55 | 56 | // Shop component page which corresponds to the toggles and context 57 | export class Shop extends Roact.Component { 58 | constructor(props: shopProps) { 59 | super(props); 60 | 61 | this.setState({ data: Tbl, pageVisible: "gamepass" }); 62 | } 63 | 64 | render() { 65 | return ( 66 | 67 | 75 | 76 | 82 | 83 | 84 | 85 | this.setState({ pageVisible: page })} /> 86 | this.setState({ pageVisible: page })} /> 87 | 88 | 89 | 90 | 91 | 92 | ); 93 | } 94 | } 95 | -------------------------------------------------------------------------------- /src/Pages/Shop/money.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Data } from "./index"; 3 | import { Item } from "../../Components/Item"; 4 | 5 | interface pageState {} 6 | interface pageProps { 7 | data: Array; 8 | visible: string; 9 | } 10 | 11 | // Create the money page inside the main component 12 | export class Money extends Roact.Component { 13 | constructor(props: pageProps) { 14 | super(props); 15 | } 16 | 17 | render() { 18 | return ( 19 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | ); 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /src/Router.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Context } from "./Context"; 3 | import { Inventory } from "./Pages/Inventory"; 4 | import { Shop } from "./Pages/Shop"; 5 | import { Toggles } from "./Toggles"; 6 | import { App } from "./App"; 7 | 8 | interface routerProps {} 9 | interface routerState { 10 | viewIndex: number; 11 | setPage: (index: number) => void; 12 | } 13 | 14 | // Create a context router for opening pages 15 | export class Router extends Roact.Component { 16 | constructor(props: {}) { 17 | super(props); 18 | this.setState({ 19 | viewIndex: 0, 20 | }); 21 | } 22 | 23 | setPage(index: number) { 24 | this.setState({ 25 | viewIndex: index, 26 | }); 27 | } 28 | 29 | render(): Roact.Element { 30 | return ( 31 | this.setPage(index), 35 | }} 36 | > 37 | 38 | 39 | 40 | 41 | 42 | ); 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /src/Stories/App.story.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { App } from "../App"; 3 | 4 | // App story for Hoarcekat 5 | export = (target: Frame): (() => void) => { 6 | const app = ; 7 | const mount = Roact.mount(app, target); 8 | 9 | return () => { 10 | Roact.unmount(mount); 11 | }; 12 | }; 13 | -------------------------------------------------------------------------------- /src/Stories/Inventory.story.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Inventory } from "../Pages/Inventory"; 3 | 4 | // Inventory story for Hoarcekat 5 | export = (target: Frame): (() => void) => { 6 | const app = ; 7 | const mount = Roact.mount(app, target); 8 | 9 | return () => { 10 | Roact.unmount(mount); 11 | }; 12 | }; 13 | -------------------------------------------------------------------------------- /src/Stories/Main.story.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Router } from "../Router"; 3 | 4 | // Main story for Hoarcekat 5 | export = (target: Frame): (() => void) => { 6 | const app = ; 7 | const mount = Roact.mount(app, target); 8 | 9 | return () => { 10 | Roact.unmount(mount); 11 | }; 12 | }; 13 | -------------------------------------------------------------------------------- /src/Stories/Shop.story.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Shop } from "../Pages/Shop"; 3 | 4 | // Shop story for Hoarcekat 5 | export = (target: Frame): (() => void) => { 6 | const app = ; 7 | const mount = Roact.mount(app, target); 8 | 9 | return () => { 10 | Roact.unmount(mount); 11 | }; 12 | }; 13 | -------------------------------------------------------------------------------- /src/Toggles.tsx: -------------------------------------------------------------------------------- 1 | import Roact from "@rbxts/roact"; 2 | import { Context, Pages } from "./Context"; 3 | import { Toggle } from "./Components/Toggle"; 4 | 5 | // List of toggles that enable associated panels 6 | export class Toggles extends Roact.Component { 7 | public render(): Roact.Element { 8 | return ( 9 | void }) => { 11 | return ( 12 | 19 | 26 | { 29 | const index = Pages.shop; 30 | if (value.viewIndex === index) { 31 | value.setPage(0); 32 | } else { 33 | value.setPage(index); 34 | } 35 | }} 36 | text={"Shop"} 37 | layout={Pages.shop} 38 | image={"http://www.roblox.com/asset/?id=3143448393"} 39 | /> 40 | { 43 | const index = Pages.inventory; 44 | if (value.viewIndex === index) { 45 | value.setPage(0); 46 | } else { 47 | value.setPage(index); 48 | } 49 | }} 50 | text={"Inventory"} 51 | layout={Pages.inventory} 52 | image={"http://www.roblox.com/asset/?id=3143448393"} 53 | /> 54 | 55 | ); 56 | }} 57 | > 58 | ); 59 | } 60 | } 61 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | // required 4 | "allowSyntheticDefaultImports": true, 5 | "downlevelIteration": true, 6 | "jsx": "react", 7 | "jsxFactory": "Roact.createElement", 8 | "jsxFragmentFactory": "Roact.Fragment", 9 | "module": "commonjs", 10 | "moduleResolution": "Node", 11 | "noLib": true, 12 | "resolveJsonModule": true, 13 | "strict": true, 14 | "target": "ESNext", 15 | "typeRoots": ["node_modules/@rbxts"], 16 | 17 | // configurable 18 | "rootDir": "src", 19 | "outDir": "out", 20 | "baseUrl": "src", 21 | "incremental": true, 22 | "tsBuildInfoFile": "out/tsconfig.tsbuildinfo" 23 | } 24 | } 25 | --------------------------------------------------------------------------------