├── .eslintignore ├── .eslintrc.js ├── .gitignore ├── LICENSE ├── package-lock.json ├── package.json ├── public └── assets │ ├── tank_blue.png │ ├── tank_green.png │ └── tank_red.png ├── readme.md ├── src ├── components │ ├── CPU.ts │ ├── Input.ts │ ├── Player.ts │ ├── Position.ts │ ├── Rotation.ts │ ├── Sprite.ts │ └── Velocity.ts ├── index.html ├── main.ts ├── scenes │ └── Game.ts └── systems │ ├── cpu.ts │ ├── movement.ts │ ├── player.ts │ └── sprite.ts └── tsconfig.json /.eslintignore: -------------------------------------------------------------------------------- 1 | # don't ever lint node_modules 2 | node_modules 3 | # don't lint build output (make sure it's set to your correct build folder name) 4 | dist 5 | -------------------------------------------------------------------------------- /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | root: true, 3 | parser: '@typescript-eslint/parser', 4 | plugins: [ 5 | '@typescript-eslint' 6 | ], 7 | extends: [ 8 | 'eslint:recommended', 9 | 'plugin:@typescript-eslint/eslint-recommended', 10 | 'plugin:@typescript-eslint/recommended' 11 | ], 12 | rules: { 13 | '@typescript-eslint/explicit-function-return-type': 0, 14 | '@typescript-eslint/ban-ts-ignore': 0, 15 | '@typescript-eslint/no-namespace': { 'allowDeclarations': true }, 16 | '@typescript-eslint/member-delimiter-style': 0, 17 | '@typescript-eslint/no-explicit-any': 0 18 | } 19 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | /.cache 2 | /dist 3 | /node_modules 4 | /.DS_Store 5 | .DS_Store 6 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 ourcade 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "phaser3-parcel-template", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.8.3", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.3.tgz", 10 | "integrity": "sha512-a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.8.3" 14 | } 15 | }, 16 | "@babel/helper-validator-identifier": { 17 | "version": "7.9.5", 18 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.9.5.tgz", 19 | "integrity": "sha512-/8arLKUFq882w4tWGj9JYzRpAlZgiWUJ+dtteNTDqrRBz9Iguck9Rn3ykuBDoUwh2TO4tSAJlrxDUOXWklJe4g==", 20 | "dev": true 21 | }, 22 | "@babel/highlight": { 23 | "version": "7.9.0", 24 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.9.0.tgz", 25 | "integrity": "sha512-lJZPilxX7Op3Nv/2cvFdnlepPXDxi29wxteT57Q965oc5R9v86ztx0jfxVrTcBk8C2kcPkkDa2Z4T3ZsPPVWsQ==", 26 | "dev": true, 27 | "requires": { 28 | "@babel/helper-validator-identifier": "^7.9.0", 29 | "chalk": "^2.0.0", 30 | "js-tokens": "^4.0.0" 31 | } 32 | }, 33 | "@types/color-name": { 34 | "version": "1.1.1", 35 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 36 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 37 | "dev": true 38 | }, 39 | "@types/eslint-visitor-keys": { 40 | "version": "1.0.0", 41 | "resolved": "https://registry.npmjs.org/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 42 | "integrity": "sha512-OCutwjDZ4aFS6PB1UZ988C4YgwlBHJd6wCeQqaLdmadZ/7e+w79+hbMUFC1QXDNCmdyoRfAFdm0RypzwR+Qpag==", 43 | "dev": true 44 | }, 45 | "@types/json-schema": { 46 | "version": "7.0.4", 47 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.4.tgz", 48 | "integrity": "sha512-8+KAKzEvSUdeo+kmqnKrqgeE+LcA0tjYWFY7RPProVYwnqDjukzO+3b6dLD56rYX5TdWejnEOLJYOIeh4CXKuA==", 49 | "dev": true 50 | }, 51 | "@typescript-eslint/eslint-plugin": { 52 | "version": "2.29.0", 53 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-2.29.0.tgz", 54 | "integrity": "sha512-X/YAY7azKirENm4QRpT7OVmzok02cSkqeIcLmdz6gXUQG4Hk0Fi9oBAynSAyNXeGdMRuZvjBa0c1Lu0dn/u6VA==", 55 | "dev": true, 56 | "requires": { 57 | "@typescript-eslint/experimental-utils": "2.29.0", 58 | "functional-red-black-tree": "^1.0.1", 59 | "regexpp": "^3.0.0", 60 | "tsutils": "^3.17.1" 61 | } 62 | }, 63 | "@typescript-eslint/experimental-utils": { 64 | "version": "2.29.0", 65 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-2.29.0.tgz", 66 | "integrity": "sha512-H/6VJr6eWYstyqjWXBP2Nn1hQJyvJoFdDtsHxGiD+lEP7piGnGpb/ZQd+z1ZSB1F7dN+WsxUDh8+S4LwI+f3jw==", 67 | "dev": true, 68 | "requires": { 69 | "@types/json-schema": "^7.0.3", 70 | "@typescript-eslint/typescript-estree": "2.29.0", 71 | "eslint-scope": "^5.0.0", 72 | "eslint-utils": "^2.0.0" 73 | } 74 | }, 75 | "@typescript-eslint/parser": { 76 | "version": "2.29.0", 77 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-2.29.0.tgz", 78 | "integrity": "sha512-H78M+jcu5Tf6m/5N8iiFblUUv+HJDguMSdFfzwa6vSg9lKR8Mk9BsgeSjO8l2EshKnJKcbv0e8IDDOvSNjl0EA==", 79 | "dev": true, 80 | "requires": { 81 | "@types/eslint-visitor-keys": "^1.0.0", 82 | "@typescript-eslint/experimental-utils": "2.29.0", 83 | "@typescript-eslint/typescript-estree": "2.29.0", 84 | "eslint-visitor-keys": "^1.1.0" 85 | } 86 | }, 87 | "@typescript-eslint/typescript-estree": { 88 | "version": "2.29.0", 89 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-2.29.0.tgz", 90 | "integrity": "sha512-3YGbtnWy4az16Egy5Fj5CckkVlpIh0MADtAQza+jiMADRSKkjdpzZp/5WuvwK/Qib3Z0HtzrDFeWanS99dNhnA==", 91 | "dev": true, 92 | "requires": { 93 | "debug": "^4.1.1", 94 | "eslint-visitor-keys": "^1.1.0", 95 | "glob": "^7.1.6", 96 | "is-glob": "^4.0.1", 97 | "lodash": "^4.17.15", 98 | "semver": "^6.3.0", 99 | "tsutils": "^3.17.1" 100 | } 101 | }, 102 | "acorn": { 103 | "version": "7.1.1", 104 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.1.tgz", 105 | "integrity": "sha512-add7dgA5ppRPxCFJoAGfMDi7PIBXq1RtGo7BhbLaxwrXPOmw8gq48Y9ozT01hUKy9byMjlR20EJhu5zlkErEkg==", 106 | "dev": true 107 | }, 108 | "acorn-jsx": { 109 | "version": "5.2.0", 110 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.2.0.tgz", 111 | "integrity": "sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ==", 112 | "dev": true 113 | }, 114 | "ajv": { 115 | "version": "6.12.2", 116 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.2.tgz", 117 | "integrity": "sha512-k+V+hzjm5q/Mr8ef/1Y9goCmlsK4I6Sm74teeyGvFk1XrOsbsKLjEdrvny42CZ+a8sXbk8KWpY/bDwS+FLL2UQ==", 118 | "dev": true, 119 | "requires": { 120 | "fast-deep-equal": "^3.1.1", 121 | "fast-json-stable-stringify": "^2.0.0", 122 | "json-schema-traverse": "^0.4.1", 123 | "uri-js": "^4.2.2" 124 | } 125 | }, 126 | "ansi-escapes": { 127 | "version": "4.3.1", 128 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 129 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 130 | "dev": true, 131 | "requires": { 132 | "type-fest": "^0.11.0" 133 | }, 134 | "dependencies": { 135 | "type-fest": { 136 | "version": "0.11.0", 137 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 138 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 139 | "dev": true 140 | } 141 | } 142 | }, 143 | "ansi-regex": { 144 | "version": "5.0.0", 145 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 146 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 147 | "dev": true 148 | }, 149 | "ansi-styles": { 150 | "version": "3.2.1", 151 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 152 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 153 | "dev": true, 154 | "requires": { 155 | "color-convert": "^1.9.0" 156 | } 157 | }, 158 | "argparse": { 159 | "version": "1.0.10", 160 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 161 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 162 | "dev": true, 163 | "requires": { 164 | "sprintf-js": "~1.0.2" 165 | } 166 | }, 167 | "astral-regex": { 168 | "version": "1.0.0", 169 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 170 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 171 | "dev": true 172 | }, 173 | "balanced-match": { 174 | "version": "1.0.0", 175 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 176 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 177 | "dev": true 178 | }, 179 | "bitecs": { 180 | "version": "0.3.10-3", 181 | "resolved": "https://registry.npmjs.org/bitecs/-/bitecs-0.3.10-3.tgz", 182 | "integrity": "sha512-2fxB5wRThzqYxJtcFRzd9j0UkHeDI1xDgQ9RLR9TxE6TZ5M6lDBJTWzXrqbfK6cQYtJjYCtE8tI/T+pMGOygiA==" 183 | }, 184 | "brace-expansion": { 185 | "version": "1.1.11", 186 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 187 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 188 | "dev": true, 189 | "requires": { 190 | "balanced-match": "^1.0.0", 191 | "concat-map": "0.0.1" 192 | } 193 | }, 194 | "callsites": { 195 | "version": "3.1.0", 196 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 197 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 198 | "dev": true 199 | }, 200 | "chalk": { 201 | "version": "2.4.2", 202 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 203 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 204 | "dev": true, 205 | "requires": { 206 | "ansi-styles": "^3.2.1", 207 | "escape-string-regexp": "^1.0.5", 208 | "supports-color": "^5.3.0" 209 | } 210 | }, 211 | "chardet": { 212 | "version": "0.7.0", 213 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 214 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 215 | "dev": true 216 | }, 217 | "cli-cursor": { 218 | "version": "3.1.0", 219 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 220 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 221 | "dev": true, 222 | "requires": { 223 | "restore-cursor": "^3.1.0" 224 | } 225 | }, 226 | "cli-width": { 227 | "version": "2.2.1", 228 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.1.tgz", 229 | "integrity": "sha512-GRMWDxpOB6Dgk2E5Uo+3eEBvtOOlimMmpbFiKuLFnQzYDavtLFY3K5ona41jgN/WdRZtG7utuVSVTL4HbZHGkw==", 230 | "dev": true 231 | }, 232 | "color-convert": { 233 | "version": "1.9.3", 234 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 235 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 236 | "dev": true, 237 | "requires": { 238 | "color-name": "1.1.3" 239 | } 240 | }, 241 | "color-name": { 242 | "version": "1.1.3", 243 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 244 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 245 | "dev": true 246 | }, 247 | "concat-map": { 248 | "version": "0.0.1", 249 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 250 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 251 | "dev": true 252 | }, 253 | "cross-spawn": { 254 | "version": "6.0.5", 255 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 256 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 257 | "dev": true, 258 | "requires": { 259 | "nice-try": "^1.0.4", 260 | "path-key": "^2.0.1", 261 | "semver": "^5.5.0", 262 | "shebang-command": "^1.2.0", 263 | "which": "^1.2.9" 264 | }, 265 | "dependencies": { 266 | "semver": { 267 | "version": "5.7.1", 268 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 269 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 270 | "dev": true 271 | } 272 | } 273 | }, 274 | "debug": { 275 | "version": "4.1.1", 276 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 277 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 278 | "dev": true, 279 | "requires": { 280 | "ms": "^2.1.1" 281 | } 282 | }, 283 | "deep-is": { 284 | "version": "0.1.3", 285 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 286 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 287 | "dev": true 288 | }, 289 | "doctrine": { 290 | "version": "3.0.0", 291 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 292 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 293 | "dev": true, 294 | "requires": { 295 | "esutils": "^2.0.2" 296 | } 297 | }, 298 | "emoji-regex": { 299 | "version": "8.0.0", 300 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 301 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 302 | "dev": true 303 | }, 304 | "escape-string-regexp": { 305 | "version": "1.0.5", 306 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 307 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 308 | "dev": true 309 | }, 310 | "eslint": { 311 | "version": "6.8.0", 312 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", 313 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", 314 | "dev": true, 315 | "requires": { 316 | "@babel/code-frame": "^7.0.0", 317 | "ajv": "^6.10.0", 318 | "chalk": "^2.1.0", 319 | "cross-spawn": "^6.0.5", 320 | "debug": "^4.0.1", 321 | "doctrine": "^3.0.0", 322 | "eslint-scope": "^5.0.0", 323 | "eslint-utils": "^1.4.3", 324 | "eslint-visitor-keys": "^1.1.0", 325 | "espree": "^6.1.2", 326 | "esquery": "^1.0.1", 327 | "esutils": "^2.0.2", 328 | "file-entry-cache": "^5.0.1", 329 | "functional-red-black-tree": "^1.0.1", 330 | "glob-parent": "^5.0.0", 331 | "globals": "^12.1.0", 332 | "ignore": "^4.0.6", 333 | "import-fresh": "^3.0.0", 334 | "imurmurhash": "^0.1.4", 335 | "inquirer": "^7.0.0", 336 | "is-glob": "^4.0.0", 337 | "js-yaml": "^3.13.1", 338 | "json-stable-stringify-without-jsonify": "^1.0.1", 339 | "levn": "^0.3.0", 340 | "lodash": "^4.17.14", 341 | "minimatch": "^3.0.4", 342 | "mkdirp": "^0.5.1", 343 | "natural-compare": "^1.4.0", 344 | "optionator": "^0.8.3", 345 | "progress": "^2.0.0", 346 | "regexpp": "^2.0.1", 347 | "semver": "^6.1.2", 348 | "strip-ansi": "^5.2.0", 349 | "strip-json-comments": "^3.0.1", 350 | "table": "^5.2.3", 351 | "text-table": "^0.2.0", 352 | "v8-compile-cache": "^2.0.3" 353 | }, 354 | "dependencies": { 355 | "eslint-utils": { 356 | "version": "1.4.3", 357 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 358 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 359 | "dev": true, 360 | "requires": { 361 | "eslint-visitor-keys": "^1.1.0" 362 | } 363 | }, 364 | "regexpp": { 365 | "version": "2.0.1", 366 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 367 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 368 | "dev": true 369 | } 370 | } 371 | }, 372 | "eslint-scope": { 373 | "version": "5.0.0", 374 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", 375 | "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", 376 | "dev": true, 377 | "requires": { 378 | "esrecurse": "^4.1.0", 379 | "estraverse": "^4.1.1" 380 | } 381 | }, 382 | "eslint-utils": { 383 | "version": "2.0.0", 384 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.0.0.tgz", 385 | "integrity": "sha512-0HCPuJv+7Wv1bACm8y5/ECVfYdfsAm9xmVb7saeFlxjPYALefjhbYoCkBjPdPzGH8wWyTpAez82Fh3VKYEZ8OA==", 386 | "dev": true, 387 | "requires": { 388 | "eslint-visitor-keys": "^1.1.0" 389 | } 390 | }, 391 | "eslint-visitor-keys": { 392 | "version": "1.1.0", 393 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 394 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", 395 | "dev": true 396 | }, 397 | "espree": { 398 | "version": "6.2.1", 399 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz", 400 | "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==", 401 | "dev": true, 402 | "requires": { 403 | "acorn": "^7.1.1", 404 | "acorn-jsx": "^5.2.0", 405 | "eslint-visitor-keys": "^1.1.0" 406 | } 407 | }, 408 | "esprima": { 409 | "version": "4.0.1", 410 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 411 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 412 | "dev": true 413 | }, 414 | "esquery": { 415 | "version": "1.3.1", 416 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 417 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 418 | "dev": true, 419 | "requires": { 420 | "estraverse": "^5.1.0" 421 | }, 422 | "dependencies": { 423 | "estraverse": { 424 | "version": "5.1.0", 425 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.1.0.tgz", 426 | "integrity": "sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw==", 427 | "dev": true 428 | } 429 | } 430 | }, 431 | "esrecurse": { 432 | "version": "4.2.1", 433 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 434 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 435 | "dev": true, 436 | "requires": { 437 | "estraverse": "^4.1.0" 438 | } 439 | }, 440 | "estraverse": { 441 | "version": "4.3.0", 442 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 443 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 444 | "dev": true 445 | }, 446 | "esutils": { 447 | "version": "2.0.3", 448 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 449 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 450 | "dev": true 451 | }, 452 | "eventemitter3": { 453 | "version": "4.0.7", 454 | "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", 455 | "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==" 456 | }, 457 | "external-editor": { 458 | "version": "3.1.0", 459 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 460 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 461 | "dev": true, 462 | "requires": { 463 | "chardet": "^0.7.0", 464 | "iconv-lite": "^0.4.24", 465 | "tmp": "^0.0.33" 466 | } 467 | }, 468 | "fast-deep-equal": { 469 | "version": "3.1.1", 470 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz", 471 | "integrity": "sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA==", 472 | "dev": true 473 | }, 474 | "fast-json-stable-stringify": { 475 | "version": "2.1.0", 476 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 477 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 478 | "dev": true 479 | }, 480 | "fast-levenshtein": { 481 | "version": "2.0.6", 482 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 483 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 484 | "dev": true 485 | }, 486 | "figures": { 487 | "version": "3.2.0", 488 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 489 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 490 | "dev": true, 491 | "requires": { 492 | "escape-string-regexp": "^1.0.5" 493 | } 494 | }, 495 | "file-entry-cache": { 496 | "version": "5.0.1", 497 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 498 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 499 | "dev": true, 500 | "requires": { 501 | "flat-cache": "^2.0.1" 502 | } 503 | }, 504 | "flat-cache": { 505 | "version": "2.0.1", 506 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 507 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 508 | "dev": true, 509 | "requires": { 510 | "flatted": "^2.0.0", 511 | "rimraf": "2.6.3", 512 | "write": "1.0.3" 513 | }, 514 | "dependencies": { 515 | "rimraf": { 516 | "version": "2.6.3", 517 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 518 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 519 | "dev": true, 520 | "requires": { 521 | "glob": "^7.1.3" 522 | } 523 | } 524 | } 525 | }, 526 | "flatted": { 527 | "version": "2.0.2", 528 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 529 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 530 | "dev": true 531 | }, 532 | "fs.realpath": { 533 | "version": "1.0.0", 534 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 535 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 536 | "dev": true 537 | }, 538 | "functional-red-black-tree": { 539 | "version": "1.0.1", 540 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 541 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 542 | "dev": true 543 | }, 544 | "glob": { 545 | "version": "7.1.6", 546 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 547 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 548 | "dev": true, 549 | "requires": { 550 | "fs.realpath": "^1.0.0", 551 | "inflight": "^1.0.4", 552 | "inherits": "2", 553 | "minimatch": "^3.0.4", 554 | "once": "^1.3.0", 555 | "path-is-absolute": "^1.0.0" 556 | } 557 | }, 558 | "glob-parent": { 559 | "version": "5.1.1", 560 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 561 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 562 | "dev": true, 563 | "requires": { 564 | "is-glob": "^4.0.1" 565 | } 566 | }, 567 | "globals": { 568 | "version": "12.4.0", 569 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 570 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 571 | "dev": true, 572 | "requires": { 573 | "type-fest": "^0.8.1" 574 | } 575 | }, 576 | "has-flag": { 577 | "version": "3.0.0", 578 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 579 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 580 | "dev": true 581 | }, 582 | "iconv-lite": { 583 | "version": "0.4.24", 584 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 585 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 586 | "dev": true, 587 | "requires": { 588 | "safer-buffer": ">= 2.1.2 < 3" 589 | } 590 | }, 591 | "ignore": { 592 | "version": "4.0.6", 593 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 594 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 595 | "dev": true 596 | }, 597 | "import-fresh": { 598 | "version": "3.2.1", 599 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 600 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 601 | "dev": true, 602 | "requires": { 603 | "parent-module": "^1.0.0", 604 | "resolve-from": "^4.0.0" 605 | } 606 | }, 607 | "imurmurhash": { 608 | "version": "0.1.4", 609 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 610 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 611 | "dev": true 612 | }, 613 | "inflight": { 614 | "version": "1.0.6", 615 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 616 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 617 | "dev": true, 618 | "requires": { 619 | "once": "^1.3.0", 620 | "wrappy": "1" 621 | } 622 | }, 623 | "inherits": { 624 | "version": "2.0.3", 625 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 626 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 627 | }, 628 | "inquirer": { 629 | "version": "7.1.0", 630 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.1.0.tgz", 631 | "integrity": "sha512-5fJMWEmikSYu0nv/flMc475MhGbB7TSPd/2IpFV4I4rMklboCH2rQjYY5kKiYGHqUF9gvaambupcJFFG9dvReg==", 632 | "dev": true, 633 | "requires": { 634 | "ansi-escapes": "^4.2.1", 635 | "chalk": "^3.0.0", 636 | "cli-cursor": "^3.1.0", 637 | "cli-width": "^2.0.0", 638 | "external-editor": "^3.0.3", 639 | "figures": "^3.0.0", 640 | "lodash": "^4.17.15", 641 | "mute-stream": "0.0.8", 642 | "run-async": "^2.4.0", 643 | "rxjs": "^6.5.3", 644 | "string-width": "^4.1.0", 645 | "strip-ansi": "^6.0.0", 646 | "through": "^2.3.6" 647 | }, 648 | "dependencies": { 649 | "ansi-styles": { 650 | "version": "4.2.1", 651 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 652 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 653 | "dev": true, 654 | "requires": { 655 | "@types/color-name": "^1.1.1", 656 | "color-convert": "^2.0.1" 657 | } 658 | }, 659 | "chalk": { 660 | "version": "3.0.0", 661 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 662 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 663 | "dev": true, 664 | "requires": { 665 | "ansi-styles": "^4.1.0", 666 | "supports-color": "^7.1.0" 667 | } 668 | }, 669 | "color-convert": { 670 | "version": "2.0.1", 671 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 672 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 673 | "dev": true, 674 | "requires": { 675 | "color-name": "~1.1.4" 676 | } 677 | }, 678 | "color-name": { 679 | "version": "1.1.4", 680 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 681 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 682 | "dev": true 683 | }, 684 | "has-flag": { 685 | "version": "4.0.0", 686 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 687 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 688 | "dev": true 689 | }, 690 | "strip-ansi": { 691 | "version": "6.0.0", 692 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 693 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 694 | "dev": true, 695 | "requires": { 696 | "ansi-regex": "^5.0.0" 697 | } 698 | }, 699 | "supports-color": { 700 | "version": "7.1.0", 701 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 702 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 703 | "dev": true, 704 | "requires": { 705 | "has-flag": "^4.0.0" 706 | } 707 | } 708 | } 709 | }, 710 | "is-extglob": { 711 | "version": "2.1.1", 712 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 713 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 714 | "dev": true 715 | }, 716 | "is-fullwidth-code-point": { 717 | "version": "3.0.0", 718 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 719 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 720 | "dev": true 721 | }, 722 | "is-glob": { 723 | "version": "4.0.1", 724 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 725 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 726 | "dev": true, 727 | "requires": { 728 | "is-extglob": "^2.1.1" 729 | } 730 | }, 731 | "is-promise": { 732 | "version": "2.1.0", 733 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 734 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 735 | "dev": true 736 | }, 737 | "isexe": { 738 | "version": "2.0.0", 739 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 740 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 741 | "dev": true 742 | }, 743 | "js-tokens": { 744 | "version": "4.0.0", 745 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 746 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 747 | "dev": true 748 | }, 749 | "js-yaml": { 750 | "version": "3.13.1", 751 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 752 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 753 | "dev": true, 754 | "requires": { 755 | "argparse": "^1.0.7", 756 | "esprima": "^4.0.0" 757 | } 758 | }, 759 | "json-schema-traverse": { 760 | "version": "0.4.1", 761 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 762 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 763 | "dev": true 764 | }, 765 | "json-stable-stringify-without-jsonify": { 766 | "version": "1.0.1", 767 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 768 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 769 | "dev": true 770 | }, 771 | "levn": { 772 | "version": "0.3.0", 773 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 774 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 775 | "dev": true, 776 | "requires": { 777 | "prelude-ls": "~1.1.2", 778 | "type-check": "~0.3.2" 779 | } 780 | }, 781 | "lodash": { 782 | "version": "4.17.21", 783 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 784 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 785 | "dev": true 786 | }, 787 | "mimic-fn": { 788 | "version": "2.1.0", 789 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 790 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 791 | "dev": true 792 | }, 793 | "minimatch": { 794 | "version": "3.0.4", 795 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 796 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 797 | "dev": true, 798 | "requires": { 799 | "brace-expansion": "^1.1.7" 800 | } 801 | }, 802 | "minimist": { 803 | "version": "1.2.5", 804 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 805 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 806 | "dev": true 807 | }, 808 | "mkdirp": { 809 | "version": "0.5.5", 810 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 811 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 812 | "dev": true, 813 | "requires": { 814 | "minimist": "^1.2.5" 815 | } 816 | }, 817 | "ms": { 818 | "version": "2.1.2", 819 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 820 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 821 | "dev": true 822 | }, 823 | "mute-stream": { 824 | "version": "0.0.8", 825 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 826 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 827 | "dev": true 828 | }, 829 | "natural-compare": { 830 | "version": "1.4.0", 831 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 832 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 833 | "dev": true 834 | }, 835 | "nice-try": { 836 | "version": "1.0.5", 837 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 838 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 839 | "dev": true 840 | }, 841 | "once": { 842 | "version": "1.4.0", 843 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 844 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 845 | "dev": true, 846 | "requires": { 847 | "wrappy": "1" 848 | } 849 | }, 850 | "onetime": { 851 | "version": "5.1.0", 852 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 853 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 854 | "dev": true, 855 | "requires": { 856 | "mimic-fn": "^2.1.0" 857 | } 858 | }, 859 | "optionator": { 860 | "version": "0.8.3", 861 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 862 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 863 | "dev": true, 864 | "requires": { 865 | "deep-is": "~0.1.3", 866 | "fast-levenshtein": "~2.0.6", 867 | "levn": "~0.3.0", 868 | "prelude-ls": "~1.1.2", 869 | "type-check": "~0.3.2", 870 | "word-wrap": "~1.2.3" 871 | } 872 | }, 873 | "os-tmpdir": { 874 | "version": "1.0.2", 875 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 876 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 877 | "dev": true 878 | }, 879 | "parcel-plugin-clean-easy": { 880 | "version": "1.0.2", 881 | "resolved": "https://registry.npmjs.org/parcel-plugin-clean-easy/-/parcel-plugin-clean-easy-1.0.2.tgz", 882 | "integrity": "sha512-k20c17ff+HpN/GwIkDK0UivZxttVci6qM6uQTjTDHnsZoOyvKd8UReUHuksJdBsDrlPjYE3W6vJW4k4nbmhJYA==", 883 | "dev": true, 884 | "requires": { 885 | "rimraf": "^2.6.2" 886 | } 887 | }, 888 | "parcel-plugin-static-files-copy": { 889 | "version": "2.4.3", 890 | "resolved": "https://registry.npmjs.org/parcel-plugin-static-files-copy/-/parcel-plugin-static-files-copy-2.4.3.tgz", 891 | "integrity": "sha512-tUZn54XsZIZ9hhhNQkyaWaHLvjOj2wra8pp4yPjp1b5p1frQ+YEwG6eaNtaQVyA+UvORsZg+Wni7n9gIOBE8eA==", 892 | "dev": true, 893 | "requires": { 894 | "minimatch": "3.0.4", 895 | "path": "0.12.7" 896 | } 897 | }, 898 | "parent-module": { 899 | "version": "1.0.1", 900 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 901 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 902 | "dev": true, 903 | "requires": { 904 | "callsites": "^3.0.0" 905 | } 906 | }, 907 | "path": { 908 | "version": "0.12.7", 909 | "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz", 910 | "integrity": "sha1-1NwqUGxM4hl+tIHr/NWzbAFAsQ8=", 911 | "requires": { 912 | "process": "^0.11.1", 913 | "util": "^0.10.3" 914 | } 915 | }, 916 | "path-is-absolute": { 917 | "version": "1.0.1", 918 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 919 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 920 | "dev": true 921 | }, 922 | "path-key": { 923 | "version": "2.0.1", 924 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 925 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 926 | "dev": true 927 | }, 928 | "phaser": { 929 | "version": "3.55.2", 930 | "resolved": "https://registry.npmjs.org/phaser/-/phaser-3.55.2.tgz", 931 | "integrity": "sha512-amKXsbb2Ht29dGPKvt1edq3yGGYKtq8373GpJYGKPNPnneYY6MtVTOgjHDuZwtmUyK4v86FugkT3hzW/N4tjxQ==", 932 | "requires": { 933 | "eventemitter3": "^4.0.7", 934 | "path": "^0.12.7" 935 | } 936 | }, 937 | "prelude-ls": { 938 | "version": "1.1.2", 939 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 940 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 941 | "dev": true 942 | }, 943 | "process": { 944 | "version": "0.11.10", 945 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", 946 | "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=" 947 | }, 948 | "progress": { 949 | "version": "2.0.3", 950 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 951 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 952 | "dev": true 953 | }, 954 | "punycode": { 955 | "version": "2.1.1", 956 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 957 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 958 | "dev": true 959 | }, 960 | "regexpp": { 961 | "version": "3.1.0", 962 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 963 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 964 | "dev": true 965 | }, 966 | "resolve-from": { 967 | "version": "4.0.0", 968 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 969 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 970 | "dev": true 971 | }, 972 | "restore-cursor": { 973 | "version": "3.1.0", 974 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 975 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 976 | "dev": true, 977 | "requires": { 978 | "onetime": "^5.1.0", 979 | "signal-exit": "^3.0.2" 980 | } 981 | }, 982 | "rimraf": { 983 | "version": "2.7.1", 984 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 985 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 986 | "dev": true, 987 | "requires": { 988 | "glob": "^7.1.3" 989 | } 990 | }, 991 | "run-async": { 992 | "version": "2.4.0", 993 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.0.tgz", 994 | "integrity": "sha512-xJTbh/d7Lm7SBhc1tNvTpeCHaEzoyxPrqNlvSdMfBTYwaY++UJFyXUOxAtsRUXjlqOfj8luNaR9vjCh4KeV+pg==", 995 | "dev": true, 996 | "requires": { 997 | "is-promise": "^2.1.0" 998 | } 999 | }, 1000 | "rxjs": { 1001 | "version": "6.5.5", 1002 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.5.tgz", 1003 | "integrity": "sha512-WfQI+1gohdf0Dai/Bbmk5L5ItH5tYqm3ki2c5GdWhKjalzjg93N3avFjVStyZZz+A2Em+ZxKH5bNghw9UeylGQ==", 1004 | "dev": true, 1005 | "requires": { 1006 | "tslib": "^1.9.0" 1007 | } 1008 | }, 1009 | "safer-buffer": { 1010 | "version": "2.1.2", 1011 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1012 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1013 | "dev": true 1014 | }, 1015 | "semver": { 1016 | "version": "6.3.0", 1017 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1018 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1019 | "dev": true 1020 | }, 1021 | "shebang-command": { 1022 | "version": "1.2.0", 1023 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1024 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1025 | "dev": true, 1026 | "requires": { 1027 | "shebang-regex": "^1.0.0" 1028 | } 1029 | }, 1030 | "shebang-regex": { 1031 | "version": "1.0.0", 1032 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1033 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1034 | "dev": true 1035 | }, 1036 | "signal-exit": { 1037 | "version": "3.0.3", 1038 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1039 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 1040 | "dev": true 1041 | }, 1042 | "slice-ansi": { 1043 | "version": "2.1.0", 1044 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1045 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1046 | "dev": true, 1047 | "requires": { 1048 | "ansi-styles": "^3.2.0", 1049 | "astral-regex": "^1.0.0", 1050 | "is-fullwidth-code-point": "^2.0.0" 1051 | }, 1052 | "dependencies": { 1053 | "is-fullwidth-code-point": { 1054 | "version": "2.0.0", 1055 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1056 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1057 | "dev": true 1058 | } 1059 | } 1060 | }, 1061 | "sprintf-js": { 1062 | "version": "1.0.3", 1063 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1064 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1065 | "dev": true 1066 | }, 1067 | "string-width": { 1068 | "version": "4.2.0", 1069 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1070 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1071 | "dev": true, 1072 | "requires": { 1073 | "emoji-regex": "^8.0.0", 1074 | "is-fullwidth-code-point": "^3.0.0", 1075 | "strip-ansi": "^6.0.0" 1076 | }, 1077 | "dependencies": { 1078 | "strip-ansi": { 1079 | "version": "6.0.0", 1080 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1081 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1082 | "dev": true, 1083 | "requires": { 1084 | "ansi-regex": "^5.0.0" 1085 | } 1086 | } 1087 | } 1088 | }, 1089 | "strip-ansi": { 1090 | "version": "5.2.0", 1091 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1092 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1093 | "dev": true, 1094 | "requires": { 1095 | "ansi-regex": "^4.1.0" 1096 | }, 1097 | "dependencies": { 1098 | "ansi-regex": { 1099 | "version": "4.1.0", 1100 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1101 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1102 | "dev": true 1103 | } 1104 | } 1105 | }, 1106 | "strip-json-comments": { 1107 | "version": "3.1.0", 1108 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.0.tgz", 1109 | "integrity": "sha512-e6/d0eBu7gHtdCqFt0xJr642LdToM5/cN4Qb9DbHjVx1CP5RyeM+zH7pbecEmDv/lBqb0QH+6Uqq75rxFPkM0w==", 1110 | "dev": true 1111 | }, 1112 | "supports-color": { 1113 | "version": "5.5.0", 1114 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1115 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1116 | "dev": true, 1117 | "requires": { 1118 | "has-flag": "^3.0.0" 1119 | } 1120 | }, 1121 | "table": { 1122 | "version": "5.4.6", 1123 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 1124 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 1125 | "dev": true, 1126 | "requires": { 1127 | "ajv": "^6.10.2", 1128 | "lodash": "^4.17.14", 1129 | "slice-ansi": "^2.1.0", 1130 | "string-width": "^3.0.0" 1131 | }, 1132 | "dependencies": { 1133 | "emoji-regex": { 1134 | "version": "7.0.3", 1135 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 1136 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 1137 | "dev": true 1138 | }, 1139 | "is-fullwidth-code-point": { 1140 | "version": "2.0.0", 1141 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1142 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1143 | "dev": true 1144 | }, 1145 | "string-width": { 1146 | "version": "3.1.0", 1147 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1148 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1149 | "dev": true, 1150 | "requires": { 1151 | "emoji-regex": "^7.0.1", 1152 | "is-fullwidth-code-point": "^2.0.0", 1153 | "strip-ansi": "^5.1.0" 1154 | } 1155 | } 1156 | } 1157 | }, 1158 | "text-table": { 1159 | "version": "0.2.0", 1160 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1161 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1162 | "dev": true 1163 | }, 1164 | "through": { 1165 | "version": "2.3.8", 1166 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1167 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1168 | "dev": true 1169 | }, 1170 | "tmp": { 1171 | "version": "0.0.33", 1172 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1173 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1174 | "dev": true, 1175 | "requires": { 1176 | "os-tmpdir": "~1.0.2" 1177 | } 1178 | }, 1179 | "tslib": { 1180 | "version": "1.11.1", 1181 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", 1182 | "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==", 1183 | "dev": true 1184 | }, 1185 | "tsutils": { 1186 | "version": "3.17.1", 1187 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.17.1.tgz", 1188 | "integrity": "sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g==", 1189 | "dev": true, 1190 | "requires": { 1191 | "tslib": "^1.8.1" 1192 | } 1193 | }, 1194 | "type-check": { 1195 | "version": "0.3.2", 1196 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1197 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1198 | "dev": true, 1199 | "requires": { 1200 | "prelude-ls": "~1.1.2" 1201 | } 1202 | }, 1203 | "type-fest": { 1204 | "version": "0.8.1", 1205 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1206 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1207 | "dev": true 1208 | }, 1209 | "typescript": { 1210 | "version": "3.8.3", 1211 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.8.3.tgz", 1212 | "integrity": "sha512-MYlEfn5VrLNsgudQTVJeNaQFUAI7DkhnOjdpAp4T+ku1TfQClewlbSuTVHiA+8skNBgaf02TL/kLOvig4y3G8w==", 1213 | "dev": true 1214 | }, 1215 | "uri-js": { 1216 | "version": "4.2.2", 1217 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1218 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1219 | "dev": true, 1220 | "requires": { 1221 | "punycode": "^2.1.0" 1222 | } 1223 | }, 1224 | "util": { 1225 | "version": "0.10.4", 1226 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz", 1227 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", 1228 | "requires": { 1229 | "inherits": "2.0.3" 1230 | } 1231 | }, 1232 | "v8-compile-cache": { 1233 | "version": "2.1.0", 1234 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", 1235 | "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==", 1236 | "dev": true 1237 | }, 1238 | "which": { 1239 | "version": "1.3.1", 1240 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1241 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1242 | "dev": true, 1243 | "requires": { 1244 | "isexe": "^2.0.0" 1245 | } 1246 | }, 1247 | "word-wrap": { 1248 | "version": "1.2.3", 1249 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1250 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1251 | "dev": true 1252 | }, 1253 | "wrappy": { 1254 | "version": "1.0.2", 1255 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1256 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1257 | "dev": true 1258 | }, 1259 | "write": { 1260 | "version": "1.0.3", 1261 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 1262 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 1263 | "dev": true, 1264 | "requires": { 1265 | "mkdirp": "^0.5.1" 1266 | } 1267 | } 1268 | } 1269 | } 1270 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "phaser3-parcel-template", 3 | "version": "1.0.0", 4 | "description": "A typescript template project for Phaser 3 using Parceljs", 5 | "scripts": { 6 | "start": "parcel src/index.html -p 8000", 7 | "build": "parcel build src/index.html --out-dir dist", 8 | "test": "echo \"Error: no test specified\" && exit 1", 9 | "lint": "eslint ./src --ext .js,.jsx,.ts,.tsx" 10 | }, 11 | "author": "supertommy", 12 | "license": "MIT", 13 | "repository": { 14 | "type": "git", 15 | "url": "https://github.com/ourcade/phaser3-parcel-template.git" 16 | }, 17 | "homepage": "https://github.com/ourcade/phaser3-parcel-template", 18 | "devDependencies": { 19 | "@typescript-eslint/eslint-plugin": "^2.29.0", 20 | "@typescript-eslint/parser": "^2.29.0", 21 | "eslint": "^6.8.0", 22 | "minimist": ">=1.2.2", 23 | "parcel-plugin-clean-easy": "^1.0.2", 24 | "parcel-plugin-static-files-copy": "^2.4.3", 25 | "typescript": "^3.8.3" 26 | }, 27 | "dependencies": { 28 | "bitecs": "^0.3.10-3", 29 | "phaser": "^3.55.2" 30 | }, 31 | "parcelCleanPaths": [ 32 | "dist" 33 | ], 34 | "staticFiles": { 35 | "staticPath": "public", 36 | "watcherGlob": "**" 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /public/assets/tank_blue.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ourcade/phaser3-bitecs-getting-started/43f0373cb6c0a4d18357d25fc37b82ac22f3713b/public/assets/tank_blue.png -------------------------------------------------------------------------------- /public/assets/tank_green.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ourcade/phaser3-bitecs-getting-started/43f0373cb6c0a4d18357d25fc37b82ac22f3713b/public/assets/tank_green.png -------------------------------------------------------------------------------- /public/assets/tank_red.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ourcade/phaser3-bitecs-getting-started/43f0373cb6c0a4d18357d25fc37b82ac22f3713b/public/assets/tank_red.png -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | # Entity Component System with Phaser 3 and bitECS 2 | > Example code for getting started with ECS in Phaser 3 3 | 4 | ![License](https://img.shields.io/badge/license-MIT-green) 5 | 6 | ## Overview 7 | 8 | This is the example code for getting started with using ECS (Entity Component System) with the bitECS library in Phaser 3. 9 | 10 | [It corresponds to a 4 part series on YouTube going over the code!](https://www.youtube.com/playlist?list=PLNwtXgWIx3rhz72-UxKLdCDdqFsnwNc_u) 11 | 12 | ## Getting Started 13 | 14 | Clone this repository with git and run: 15 | 16 | ``` 17 | npm install 18 | npm run start 19 | ``` 20 | 21 | Then go to http://localhost:8000 22 | 23 | ## License 24 | 25 | [MIT License](https://github.com/ourcade/phaser3-bitecs-getting-started/blob/master/LICENSE) 26 | -------------------------------------------------------------------------------- /src/components/CPU.ts: -------------------------------------------------------------------------------- 1 | import { defineComponent, Types } from 'bitecs' 2 | 3 | export const CPU = defineComponent({ 4 | timeBetweenActions: Types.ui32, 5 | accumulatedTime: Types.ui32 6 | }) 7 | 8 | export default CPU 9 | -------------------------------------------------------------------------------- /src/components/Input.ts: -------------------------------------------------------------------------------- 1 | import { defineComponent, Types } from 'bitecs' 2 | 3 | export const Input = defineComponent({ 4 | direction: Types.ui8, 5 | speed: Types.ui8 6 | }) 7 | 8 | export enum Direction 9 | { 10 | None, 11 | Left, 12 | Right, 13 | Up, 14 | Down 15 | } 16 | 17 | export default Input -------------------------------------------------------------------------------- /src/components/Player.ts: -------------------------------------------------------------------------------- 1 | import { defineComponent, Types } from 'bitecs' 2 | 3 | export const Player = defineComponent() 4 | 5 | export default Player 6 | -------------------------------------------------------------------------------- /src/components/Position.ts: -------------------------------------------------------------------------------- 1 | import { defineComponent, Types } from 'bitecs' 2 | 3 | export const Position = defineComponent({ 4 | x: Types.f32, 5 | y: Types.f32 6 | }) 7 | 8 | export default Position 9 | -------------------------------------------------------------------------------- /src/components/Rotation.ts: -------------------------------------------------------------------------------- 1 | import { defineComponent, Types } from 'bitecs' 2 | 3 | export const Rotation = defineComponent({ 4 | angle: Types.f32 5 | }) 6 | 7 | export default Rotation 8 | -------------------------------------------------------------------------------- /src/components/Sprite.ts: -------------------------------------------------------------------------------- 1 | import { defineComponent, Types } from 'bitecs' 2 | 3 | export const Sprite = defineComponent({ 4 | texture: Types.ui8 5 | }) 6 | 7 | export default Sprite 8 | -------------------------------------------------------------------------------- /src/components/Velocity.ts: -------------------------------------------------------------------------------- 1 | import { defineComponent, Types } from 'bitecs' 2 | 3 | export const Velocity = defineComponent({ 4 | x: Types.f32, 5 | y: Types.f32 6 | }) 7 | 8 | export default Velocity 9 | -------------------------------------------------------------------------------- /src/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | Phaser3 + Parceljs Template 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /src/main.ts: -------------------------------------------------------------------------------- 1 | import Phaser from 'phaser' 2 | 3 | import Game from './scenes/Game' 4 | 5 | const config: Phaser.Types.Core.GameConfig = { 6 | type: Phaser.AUTO, 7 | width: 800, 8 | height: 600, 9 | physics: { 10 | default: 'arcade', 11 | arcade: { 12 | gravity: { y: 200 } 13 | } 14 | }, 15 | scene: [Game] 16 | } 17 | 18 | export default new Phaser.Game(config) 19 | -------------------------------------------------------------------------------- /src/scenes/Game.ts: -------------------------------------------------------------------------------- 1 | import Phaser from 'phaser' 2 | import { 3 | createWorld, 4 | addEntity, 5 | addComponent, 6 | } from 'bitecs' 7 | 8 | import type { 9 | IWorld, 10 | System 11 | } from 'bitecs' 12 | 13 | import Position from '../components/Position' 14 | import Velocity from '../components/Velocity' 15 | import Sprite from '../components/Sprite' 16 | import Rotation from '../components/Rotation' 17 | import Player from '../components/Player' 18 | import CPU from '../components/CPU' 19 | import Input from '../components/Input' 20 | 21 | import createMovementSystem from '../systems/movement' 22 | import createSpriteSystem from '../systems/sprite' 23 | import createPlayerSystem from '../systems/player' 24 | import createCPUSystem from '../systems/cpu' 25 | 26 | enum Textures 27 | { 28 | TankBlue, 29 | TankGreen, 30 | TankRed 31 | } 32 | 33 | export default class Game extends Phaser.Scene 34 | { 35 | private cursors!: Phaser.Types.Input.Keyboard.CursorKeys 36 | 37 | private world!: IWorld 38 | private playerSystem!: System 39 | private cpuSystem!: System 40 | private movementSystem!: System 41 | private spriteSystem!: System 42 | 43 | constructor() 44 | { 45 | super('game') 46 | } 47 | 48 | init() 49 | { 50 | this.cursors = this.input.keyboard.createCursorKeys() 51 | } 52 | 53 | preload() 54 | { 55 | this.load.image('tank-blue', 'assets/tank_blue.png') 56 | this.load.image('tank-green', 'assets/tank_green.png') 57 | this.load.image('tank-red', 'assets/tank_red.png') 58 | } 59 | 60 | create() 61 | { 62 | const { width, height } = this.scale 63 | 64 | this.world = createWorld() 65 | 66 | // create the player tank 67 | const blueTank = addEntity(this.world) 68 | 69 | addComponent(this.world, Position, blueTank) 70 | addComponent(this.world, Velocity, blueTank) 71 | addComponent(this.world, Rotation, blueTank) 72 | addComponent(this.world, Sprite, blueTank) 73 | addComponent(this.world, Player, blueTank) 74 | addComponent(this.world, Input, blueTank) 75 | 76 | Position.x[blueTank] = 100 77 | Position.y[blueTank] = 100 78 | Sprite.texture[blueTank] = Textures.TankBlue 79 | Input.speed[blueTank] = 10 80 | 81 | // create random cpu tanks 82 | for (let i = 0; i < 10; ++i) 83 | { 84 | const tank = addEntity(this.world) 85 | 86 | addComponent(this.world, Position, tank) 87 | Position.x[tank] = Phaser.Math.Between(width * 0.25, width * 0.75) 88 | Position.y[tank] = Phaser.Math.Between(height * 0.25, height * 0.75) 89 | 90 | addComponent(this.world, Velocity, tank) 91 | addComponent(this.world, Rotation, tank) 92 | 93 | addComponent(this.world, Sprite, tank) 94 | Sprite.texture[tank] = Phaser.Math.Between(1, 2) 95 | 96 | addComponent(this.world, CPU, tank) 97 | CPU.timeBetweenActions[tank] = Phaser.Math.Between(0, 500) 98 | 99 | addComponent(this.world, Input, tank) 100 | Input.speed[tank] = 10 101 | } 102 | 103 | // create the systems 104 | this.playerSystem = createPlayerSystem(this.cursors) 105 | this.cpuSystem = createCPUSystem(this) 106 | this.movementSystem = createMovementSystem() 107 | this.spriteSystem = createSpriteSystem(this, ['tank-blue', 'tank-green', 'tank-red']) 108 | } 109 | 110 | update(t: number, dt: number) { 111 | // run each system in desired order 112 | this.playerSystem(this.world) 113 | this.cpuSystem(this.world) 114 | 115 | this.movementSystem(this.world) 116 | 117 | this.spriteSystem(this.world) 118 | } 119 | } 120 | -------------------------------------------------------------------------------- /src/systems/cpu.ts: -------------------------------------------------------------------------------- 1 | import Phaser from 'phaser' 2 | import { 3 | defineSystem, 4 | defineQuery, 5 | } from 'bitecs' 6 | 7 | import CPU from '../components/CPU' 8 | import Velocity from '../components/Velocity' 9 | import Rotation from '../components/Rotation' 10 | import Input, { Direction} from '../components/Input' 11 | 12 | export default function createCPUSystem(scene: Phaser.Scene) { 13 | const cpuQuery = defineQuery([CPU, Velocity, Rotation, Input]) 14 | 15 | return defineSystem((world) => { 16 | const entities = cpuQuery(world) 17 | 18 | const dt = scene.game.loop.delta 19 | for (let i = 0; i < entities.length; ++i) 20 | { 21 | const id = entities[i] 22 | 23 | CPU.accumulatedTime[id] += dt 24 | 25 | if (CPU.accumulatedTime[id] < CPU.timeBetweenActions[id]) 26 | { 27 | continue 28 | } 29 | 30 | CPU.accumulatedTime[id] = 0 31 | 32 | switch (Phaser.Math.Between(0, 20)) 33 | { 34 | // left 35 | case 0: 36 | { 37 | Input.direction[id] = Direction.Left 38 | break 39 | } 40 | 41 | // right 42 | case 1: 43 | { 44 | Input.direction[id] = Direction.Right 45 | break 46 | } 47 | 48 | // up 49 | case 2: 50 | { 51 | Input.direction[id] = Direction.Up 52 | break 53 | } 54 | 55 | // down 56 | case 3: 57 | { 58 | Input.direction[id] = Direction.Down 59 | break 60 | } 61 | 62 | default: 63 | { 64 | Input.direction[id] = Direction.None 65 | break 66 | } 67 | } 68 | } 69 | 70 | return world 71 | }) 72 | } 73 | -------------------------------------------------------------------------------- /src/systems/movement.ts: -------------------------------------------------------------------------------- 1 | import { 2 | defineSystem, 3 | defineQuery, 4 | } from 'bitecs' 5 | 6 | import Position from '../components/Position' 7 | import Velocity from '../components/Velocity' 8 | import Rotation from '../components/Rotation' 9 | import Input, { Direction } from '../components/Input' 10 | 11 | export default function createMovementSystem() { 12 | const movementQuery = defineQuery([Position, Velocity, Input, Rotation]) 13 | 14 | return defineSystem((world) => { 15 | const entities = movementQuery(world) 16 | 17 | for (let i = 0; i < entities.length; ++i) 18 | { 19 | const id = entities[i] 20 | 21 | const direction = Input.direction[id] 22 | const speed = Input.speed[id] 23 | 24 | switch (direction) 25 | { 26 | case Direction.None: 27 | Velocity.x[id] = 0 28 | Velocity.y[id] = 0 29 | break 30 | 31 | case Direction.Left: 32 | Velocity.x[id] = -speed 33 | Velocity.y[id] = 0 34 | Rotation.angle[id] = 180 35 | break 36 | 37 | case Direction.Right: 38 | Velocity.x[id] = speed 39 | Velocity.y[id] = 0 40 | Rotation.angle[id] = 0 41 | break 42 | 43 | case Direction.Up: 44 | Velocity.x[id] = 0 45 | Velocity.y[id] = -speed 46 | Rotation.angle[id] = 270 47 | break 48 | 49 | case Direction.Down: 50 | Velocity.x[id] = 0 51 | Velocity.y[id] = speed 52 | Rotation.angle[id] = 90 53 | break 54 | } 55 | 56 | Position.x[id] += Velocity.x[id] 57 | Position.y[id] += Velocity.y[id] 58 | } 59 | 60 | return world 61 | }) 62 | } 63 | -------------------------------------------------------------------------------- /src/systems/player.ts: -------------------------------------------------------------------------------- 1 | import Phaser from 'phaser' 2 | import { 3 | defineSystem, 4 | defineQuery, 5 | } from 'bitecs' 6 | 7 | import Velocity from '../components/Velocity' 8 | import Rotation from '../components/Rotation' 9 | import Player from '../components/Player' 10 | import Input, { Direction } from '../components/Input' 11 | 12 | export default function createPlayerSystem(cursors: Phaser.Types.Input.Keyboard.CursorKeys) { 13 | const playerQuery = defineQuery([Player, Velocity, Rotation, Input]) 14 | 15 | return defineSystem((world) => { 16 | const entities = playerQuery(world) 17 | 18 | for (let i = 0; i < entities.length; ++i) 19 | { 20 | const id = entities[i] 21 | if (cursors.left.isDown) 22 | { 23 | Input.direction[id] = Direction.Left 24 | } 25 | else if (cursors.right.isDown) 26 | { 27 | Input.direction[id] = Direction.Right 28 | } 29 | else if (cursors.up.isDown) 30 | { 31 | Input.direction[id] = Direction.Up 32 | } 33 | else if (cursors.down.isDown) 34 | { 35 | Input.direction[id] = Direction.Down 36 | } 37 | else 38 | { 39 | Input.direction[id] = Direction.None 40 | } 41 | } 42 | 43 | return world 44 | }) 45 | } 46 | -------------------------------------------------------------------------------- /src/systems/sprite.ts: -------------------------------------------------------------------------------- 1 | import Phaser from 'phaser' 2 | import { 3 | defineSystem, 4 | defineQuery, 5 | enterQuery, 6 | exitQuery 7 | } from 'bitecs' 8 | 9 | import Position from '../components/Position' 10 | import Sprite from '../components/Sprite' 11 | import Rotation from '../components/Rotation' 12 | 13 | export default function createSpriteSystem(scene: Phaser.Scene, textures: string[]) { 14 | const spritesById = new Map() 15 | 16 | const spriteQuery = defineQuery([Position, Rotation, Sprite]) 17 | 18 | const spriteQueryEnter = enterQuery(spriteQuery) 19 | const spriteQueryExit = exitQuery(spriteQuery) 20 | 21 | return defineSystem((world) => { 22 | const entitiesEntered = spriteQueryEnter(world) 23 | for (let i = 0; i < entitiesEntered.length; ++i) 24 | { 25 | const id = entitiesEntered[i] 26 | const texId = Sprite.texture[id] 27 | const texture = textures[texId] 28 | 29 | spritesById.set(id, scene.add.sprite(0, 0, texture)) 30 | } 31 | 32 | const entities = spriteQuery(world) 33 | for (let i = 0; i < entities.length; ++i) 34 | { 35 | const id = entities[i] 36 | 37 | const sprite = spritesById.get(id) 38 | if (!sprite) 39 | { 40 | // log an error 41 | continue 42 | } 43 | 44 | sprite.x = Position.x[id] 45 | sprite.y = Position.y[id] 46 | sprite.angle = Rotation.angle[id] 47 | } 48 | 49 | const entitiesExited = spriteQueryExit(world) 50 | for (let i = 0; i < entitiesExited.length; ++i) 51 | { 52 | const id = entitiesEntered[i] 53 | spritesById.delete(id) 54 | } 55 | 56 | return world 57 | }) 58 | } 59 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2016", 4 | "module": "es6", 5 | "strict": true, 6 | "noImplicitAny": false, 7 | "noEmit": true, 8 | "allowJs": true, 9 | "jsx": "preserve", 10 | "importHelpers": true, 11 | "moduleResolution": "node", 12 | "experimentalDecorators": true, 13 | "esModuleInterop": true, 14 | "allowSyntheticDefaultImports": true, 15 | "sourceMap": true, 16 | "baseUrl": "./src", 17 | "paths": { 18 | "~/*": ["./*"] 19 | }, 20 | "typeRoots": [ 21 | "node_modules/@types", 22 | "node_module/phaser/types" 23 | ], 24 | "types": [ 25 | "phaser" 26 | ] 27 | }, 28 | "include": [ 29 | "src/**/*" 30 | ] 31 | } 32 | --------------------------------------------------------------------------------