├── .gitignore ├── LICENSE ├── README.md ├── index.html ├── package-lock.json ├── package.json └── src ├── css └── style.css └── js ├── app.js ├── cursor-3d.js ├── line-element.js └── utils.js /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | 8 | # Runtime data 9 | pids 10 | *.pid 11 | *.seed 12 | *.pid.lock 13 | 14 | # Directory for instrumented libs generated by jscoverage/JSCover 15 | lib-cov 16 | 17 | # Coverage directory used by tools like istanbul 18 | coverage 19 | 20 | # nyc test coverage 21 | .nyc_output 22 | 23 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 24 | .grunt 25 | 26 | # Bower dependency directory (https://bower.io/) 27 | bower_components 28 | 29 | # node-waf configuration 30 | .lock-wscript 31 | 32 | # Compiled binary addons (http://nodejs.org/api/addons.html) 33 | build/Release 34 | 35 | # Dependency directories 36 | node_modules/ 37 | jspm_packages/ 38 | 39 | # Typescript v1 declaration files 40 | typings/ 41 | 42 | # Optional npm cache directory 43 | .npm 44 | 45 | # Optional eslint cache 46 | .eslintcache 47 | 48 | # Optional REPL history 49 | .node_repl_history 50 | 51 | # Output of 'npm pack' 52 | *.tgz 53 | 54 | # Yarn Integrity file 55 | .yarn-integrity 56 | 57 | # dotenv environment variables file 58 | .env 59 | 60 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2018 archilogic.com 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # WebXR Home staging AI Demo 2 | 3 | try it out via https://archilogic-com.github.io/web-xr-homestaging-ai/ 4 | 5 | This demo let's you draw a floor plan in AR 6 | 7 | ![](https://storage.3d.io/535e624259ee6b0200000484/2017-09-13_11-56-39_wW7wLF/draw-plan.gif) 8 | 9 | and then furnish it automatically. 10 | 11 | ![](https://storage.3d.io/535e624259ee6b0200000484/2017-09-13_11-42-23_XUM61N/home-staging-ai.gif) 12 | 13 | 14 | ## WebXR phone 15 | 16 | You'll need an WebXR enabled device
17 | Currently this limits your choices to: 18 | * Google Pixel 19 | * Samsung S8 20 | * iPhone with iOS 11 21 | 22 | Get started here to install WebARonARCore / WebARonARKit Browser: 23 | * Android: https://github.com/google-ar/WebARonARCore 24 | * iOS: https://github.com/google-ar/WebARonARKit 25 | 26 | ## Run the demo 27 | 28 | 1. Remix the repo 29 | 2. Get an publishable API Key from https://3d.io 30 | 3. Set it in app.js 31 | 32 | ## dependencies 33 | 34 | * [A-Frame](https://aframe.io) 35 | * [three.ar.js](https://github.com/google-ar/three.ar.js) 36 | * [aframe-ar](https://github.com/chenzlabs/aframe-ar) 37 | * [3dio.js](https://3d.io) 38 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | homeStaging demo 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 26 | 27 | 28 |
29 |
30 | 31 | 32 | 33 | 34 |
35 |
36 | 37 |
38 | 39 | 40 | 41 | 42 |
43 |

44 | 45 | 46 | 47 |
48 |
49 |
50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 69 | 70 | 71 | 72 | 73 | 74 | 75 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "homestaging-ai-web-xr", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "accepts": { 8 | "version": "1.3.5", 9 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz", 10 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", 11 | "dev": true, 12 | "requires": { 13 | "mime-types": "2.1.19", 14 | "negotiator": "0.6.1" 15 | } 16 | }, 17 | "after": { 18 | "version": "0.8.2", 19 | "resolved": "https://registry.npmjs.org/after/-/after-0.8.2.tgz", 20 | "integrity": "sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8=", 21 | "dev": true 22 | }, 23 | "ansi-regex": { 24 | "version": "2.1.1", 25 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 26 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 27 | "dev": true 28 | }, 29 | "ansi-styles": { 30 | "version": "2.2.1", 31 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 32 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 33 | "dev": true 34 | }, 35 | "anymatch": { 36 | "version": "1.3.2", 37 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz", 38 | "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==", 39 | "dev": true, 40 | "requires": { 41 | "micromatch": "2.3.11", 42 | "normalize-path": "2.1.1" 43 | } 44 | }, 45 | "arr-diff": { 46 | "version": "2.0.0", 47 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", 48 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", 49 | "dev": true, 50 | "requires": { 51 | "arr-flatten": "1.1.0" 52 | } 53 | }, 54 | "arr-flatten": { 55 | "version": "1.1.0", 56 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 57 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 58 | "dev": true 59 | }, 60 | "array-unique": { 61 | "version": "0.2.1", 62 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 63 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", 64 | "dev": true 65 | }, 66 | "arraybuffer.slice": { 67 | "version": "0.0.7", 68 | "resolved": "https://registry.npmjs.org/arraybuffer.slice/-/arraybuffer.slice-0.0.7.tgz", 69 | "integrity": "sha512-wGUIVQXuehL5TCqQun8OW81jGzAWycqzFF8lFp+GOM5BXLYj3bKNsYC4daB7n6XjCqxQA/qgTJ+8ANR3acjrog==", 70 | "dev": true 71 | }, 72 | "async": { 73 | "version": "1.5.2", 74 | "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", 75 | "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=", 76 | "dev": true 77 | }, 78 | "async-each": { 79 | "version": "1.0.1", 80 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", 81 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", 82 | "dev": true 83 | }, 84 | "async-each-series": { 85 | "version": "0.1.1", 86 | "resolved": "https://registry.npmjs.org/async-each-series/-/async-each-series-0.1.1.tgz", 87 | "integrity": "sha1-dhfBkXQB/Yykooqtzj266Yr+tDI=", 88 | "dev": true 89 | }, 90 | "async-limiter": { 91 | "version": "1.0.0", 92 | "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz", 93 | "integrity": "sha512-jp/uFnooOiO+L211eZOoSyzpOITMXx1rBITauYykG3BRYPu8h0UcxsPNB04RR5vo4Tyz3+ay17tR6JVf9qzYWg==", 94 | "dev": true 95 | }, 96 | "axios": { 97 | "version": "0.17.1", 98 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.17.1.tgz", 99 | "integrity": "sha1-LY4+XQvb1zJ/kbyBT1xXZg+Bgk0=", 100 | "dev": true, 101 | "requires": { 102 | "follow-redirects": "1.5.5", 103 | "is-buffer": "1.1.6" 104 | } 105 | }, 106 | "backo2": { 107 | "version": "1.0.2", 108 | "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz", 109 | "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc=", 110 | "dev": true 111 | }, 112 | "balanced-match": { 113 | "version": "1.0.0", 114 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 115 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 116 | "dev": true 117 | }, 118 | "base64-arraybuffer": { 119 | "version": "0.1.5", 120 | "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-0.1.5.tgz", 121 | "integrity": "sha1-c5JncZI7Whl0etZmqlzUv5xunOg=", 122 | "dev": true 123 | }, 124 | "base64id": { 125 | "version": "1.0.0", 126 | "resolved": "https://registry.npmjs.org/base64id/-/base64id-1.0.0.tgz", 127 | "integrity": "sha1-R2iMuZu2gE8OBtPnY7HDLlfY5rY=", 128 | "dev": true 129 | }, 130 | "batch": { 131 | "version": "0.6.1", 132 | "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz", 133 | "integrity": "sha1-3DQxT05nkxgJP8dgJyUl+UvyXBY=", 134 | "dev": true 135 | }, 136 | "better-assert": { 137 | "version": "1.0.2", 138 | "resolved": "https://registry.npmjs.org/better-assert/-/better-assert-1.0.2.tgz", 139 | "integrity": "sha1-QIZrnhueC1W0gYlDEeaPr/rrxSI=", 140 | "dev": true, 141 | "requires": { 142 | "callsite": "1.0.0" 143 | } 144 | }, 145 | "binary-extensions": { 146 | "version": "1.11.0", 147 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.11.0.tgz", 148 | "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=", 149 | "dev": true 150 | }, 151 | "blob": { 152 | "version": "0.0.4", 153 | "resolved": "https://registry.npmjs.org/blob/-/blob-0.0.4.tgz", 154 | "integrity": "sha1-vPEwUspURj8w+fx+lbmkdjCpSSE=", 155 | "dev": true 156 | }, 157 | "brace-expansion": { 158 | "version": "1.1.11", 159 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 160 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 161 | "dev": true, 162 | "requires": { 163 | "balanced-match": "1.0.0", 164 | "concat-map": "0.0.1" 165 | } 166 | }, 167 | "braces": { 168 | "version": "1.8.5", 169 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 170 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 171 | "dev": true, 172 | "requires": { 173 | "expand-range": "1.8.2", 174 | "preserve": "0.2.0", 175 | "repeat-element": "1.1.2" 176 | } 177 | }, 178 | "browser-sync": { 179 | "version": "2.24.6", 180 | "resolved": "https://registry.npmjs.org/browser-sync/-/browser-sync-2.24.6.tgz", 181 | "integrity": "sha512-3cVW8Ft3sPQ1t9gqZXBDZhTyRce8NW4wf5KzpCYcg6fWjPbyt+vZLvEo+sTq7c7eNQhi8lInQWbjIFEpoM2f7Q==", 182 | "dev": true, 183 | "requires": { 184 | "browser-sync-ui": "1.0.1", 185 | "bs-recipes": "1.3.4", 186 | "chokidar": "1.7.0", 187 | "connect": "3.6.6", 188 | "connect-history-api-fallback": "1.5.0", 189 | "dev-ip": "1.0.1", 190 | "easy-extender": "2.3.2", 191 | "eazy-logger": "3.0.2", 192 | "etag": "1.8.1", 193 | "fresh": "0.5.2", 194 | "fs-extra": "3.0.1", 195 | "http-proxy": "1.15.2", 196 | "immutable": "3.8.2", 197 | "localtunnel": "1.9.0", 198 | "micromatch": "2.3.11", 199 | "opn": "4.0.2", 200 | "portscanner": "2.1.1", 201 | "qs": "6.2.3", 202 | "raw-body": "2.3.3", 203 | "resp-modifier": "6.0.2", 204 | "rx": "4.1.0", 205 | "serve-index": "1.9.1", 206 | "serve-static": "1.13.2", 207 | "server-destroy": "1.0.1", 208 | "socket.io": "2.1.1", 209 | "ua-parser-js": "0.7.17", 210 | "yargs": "6.4.0" 211 | } 212 | }, 213 | "browser-sync-ui": { 214 | "version": "1.0.1", 215 | "resolved": "https://registry.npmjs.org/browser-sync-ui/-/browser-sync-ui-1.0.1.tgz", 216 | "integrity": "sha512-RIxmwVVcUFhRd1zxp7m2FfLnXHf59x4Gtj8HFwTA//3VgYI3AKkaQAuDL8KDJnE59XqCshxZa13JYuIWtZlKQg==", 217 | "dev": true, 218 | "requires": { 219 | "async-each-series": "0.1.1", 220 | "connect-history-api-fallback": "1.5.0", 221 | "immutable": "3.8.2", 222 | "server-destroy": "1.0.1", 223 | "socket.io-client": "2.0.4", 224 | "stream-throttle": "0.1.3" 225 | } 226 | }, 227 | "bs-recipes": { 228 | "version": "1.3.4", 229 | "resolved": "https://registry.npmjs.org/bs-recipes/-/bs-recipes-1.3.4.tgz", 230 | "integrity": "sha1-DS1NSKcYyMBEdp/cT4lZLci2lYU=", 231 | "dev": true 232 | }, 233 | "builtin-modules": { 234 | "version": "1.1.1", 235 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 236 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 237 | "dev": true 238 | }, 239 | "bytes": { 240 | "version": "3.0.0", 241 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 242 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=", 243 | "dev": true 244 | }, 245 | "callsite": { 246 | "version": "1.0.0", 247 | "resolved": "https://registry.npmjs.org/callsite/-/callsite-1.0.0.tgz", 248 | "integrity": "sha1-KAOY5dZkvXQDi28JBRU+borxvCA=", 249 | "dev": true 250 | }, 251 | "camelcase": { 252 | "version": "3.0.0", 253 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", 254 | "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=", 255 | "dev": true 256 | }, 257 | "chalk": { 258 | "version": "1.1.3", 259 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 260 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 261 | "dev": true, 262 | "requires": { 263 | "ansi-styles": "2.2.1", 264 | "escape-string-regexp": "1.0.5", 265 | "has-ansi": "2.0.0", 266 | "strip-ansi": "3.0.1", 267 | "supports-color": "2.0.0" 268 | } 269 | }, 270 | "chokidar": { 271 | "version": "1.7.0", 272 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", 273 | "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", 274 | "dev": true, 275 | "requires": { 276 | "anymatch": "1.3.2", 277 | "async-each": "1.0.1", 278 | "fsevents": "1.2.4", 279 | "glob-parent": "2.0.0", 280 | "inherits": "2.0.3", 281 | "is-binary-path": "1.0.1", 282 | "is-glob": "2.0.1", 283 | "path-is-absolute": "1.0.1", 284 | "readdirp": "2.1.0" 285 | } 286 | }, 287 | "cliui": { 288 | "version": "3.2.0", 289 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", 290 | "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", 291 | "dev": true, 292 | "requires": { 293 | "string-width": "1.0.2", 294 | "strip-ansi": "3.0.1", 295 | "wrap-ansi": "2.1.0" 296 | } 297 | }, 298 | "code-point-at": { 299 | "version": "1.1.0", 300 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 301 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", 302 | "dev": true 303 | }, 304 | "commander": { 305 | "version": "2.2.0", 306 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.2.0.tgz", 307 | "integrity": "sha1-F1rUuTF/P/YV8gHB5XIk9Vo+kd8=", 308 | "dev": true 309 | }, 310 | "component-bind": { 311 | "version": "1.0.0", 312 | "resolved": "https://registry.npmjs.org/component-bind/-/component-bind-1.0.0.tgz", 313 | "integrity": "sha1-AMYIq33Nk4l8AAllGx06jh5zu9E=", 314 | "dev": true 315 | }, 316 | "component-emitter": { 317 | "version": "1.2.1", 318 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", 319 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", 320 | "dev": true 321 | }, 322 | "component-inherit": { 323 | "version": "0.0.3", 324 | "resolved": "https://registry.npmjs.org/component-inherit/-/component-inherit-0.0.3.tgz", 325 | "integrity": "sha1-ZF/ErfWLcrZJ1crmUTVhnbJv8UM=", 326 | "dev": true 327 | }, 328 | "concat-map": { 329 | "version": "0.0.1", 330 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 331 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 332 | "dev": true 333 | }, 334 | "connect": { 335 | "version": "3.6.6", 336 | "resolved": "https://registry.npmjs.org/connect/-/connect-3.6.6.tgz", 337 | "integrity": "sha1-Ce/2xVr3I24TcTWnJXSFi2eG9SQ=", 338 | "dev": true, 339 | "requires": { 340 | "debug": "2.6.9", 341 | "finalhandler": "1.1.0", 342 | "parseurl": "1.3.2", 343 | "utils-merge": "1.0.1" 344 | } 345 | }, 346 | "connect-history-api-fallback": { 347 | "version": "1.5.0", 348 | "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-1.5.0.tgz", 349 | "integrity": "sha1-sGhzk0vF40T+9hGhlqb6rgruAVo=", 350 | "dev": true 351 | }, 352 | "connect-logger": { 353 | "version": "0.0.1", 354 | "resolved": "https://registry.npmjs.org/connect-logger/-/connect-logger-0.0.1.tgz", 355 | "integrity": "sha1-TZmZeKHSC7RgjnzUNNdBZSJVF0s=", 356 | "dev": true, 357 | "requires": { 358 | "moment": "2.22.2" 359 | } 360 | }, 361 | "cookie": { 362 | "version": "0.3.1", 363 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 364 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=", 365 | "dev": true 366 | }, 367 | "core-util-is": { 368 | "version": "1.0.2", 369 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 370 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 371 | "dev": true 372 | }, 373 | "debug": { 374 | "version": "2.6.9", 375 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 376 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 377 | "dev": true, 378 | "requires": { 379 | "ms": "2.0.0" 380 | } 381 | }, 382 | "decamelize": { 383 | "version": "1.2.0", 384 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 385 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 386 | "dev": true 387 | }, 388 | "depd": { 389 | "version": "1.1.2", 390 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 391 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 392 | "dev": true 393 | }, 394 | "destroy": { 395 | "version": "1.0.4", 396 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 397 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", 398 | "dev": true 399 | }, 400 | "dev-ip": { 401 | "version": "1.0.1", 402 | "resolved": "https://registry.npmjs.org/dev-ip/-/dev-ip-1.0.1.tgz", 403 | "integrity": "sha1-p2o+0YVb56ASu4rBbLgPPADcKPA=", 404 | "dev": true 405 | }, 406 | "easy-extender": { 407 | "version": "2.3.2", 408 | "resolved": "https://registry.npmjs.org/easy-extender/-/easy-extender-2.3.2.tgz", 409 | "integrity": "sha1-PTJI/r4rFZYHMW2PnPSRwWZIIh0=", 410 | "dev": true, 411 | "requires": { 412 | "lodash": "3.10.1" 413 | }, 414 | "dependencies": { 415 | "lodash": { 416 | "version": "3.10.1", 417 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-3.10.1.tgz", 418 | "integrity": "sha1-W/Rejkm6QYnhfUgnid/RW9FAt7Y=", 419 | "dev": true 420 | } 421 | } 422 | }, 423 | "eazy-logger": { 424 | "version": "3.0.2", 425 | "resolved": "https://registry.npmjs.org/eazy-logger/-/eazy-logger-3.0.2.tgz", 426 | "integrity": "sha1-oyWqXlPROiIliJsqxBE7K5Y29Pw=", 427 | "dev": true, 428 | "requires": { 429 | "tfunk": "3.1.0" 430 | } 431 | }, 432 | "ee-first": { 433 | "version": "1.1.1", 434 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 435 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", 436 | "dev": true 437 | }, 438 | "encodeurl": { 439 | "version": "1.0.2", 440 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 441 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", 442 | "dev": true 443 | }, 444 | "engine.io": { 445 | "version": "3.2.0", 446 | "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-3.2.0.tgz", 447 | "integrity": "sha512-mRbgmAtQ4GAlKwuPnnAvXXwdPhEx+jkc0OBCLrXuD/CRvwNK3AxRSnqK4FSqmAMRRHryVJP8TopOvmEaA64fKw==", 448 | "dev": true, 449 | "requires": { 450 | "accepts": "1.3.5", 451 | "base64id": "1.0.0", 452 | "cookie": "0.3.1", 453 | "debug": "3.1.0", 454 | "engine.io-parser": "2.1.2", 455 | "ws": "3.3.3" 456 | }, 457 | "dependencies": { 458 | "debug": { 459 | "version": "3.1.0", 460 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 461 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 462 | "dev": true, 463 | "requires": { 464 | "ms": "2.0.0" 465 | } 466 | } 467 | } 468 | }, 469 | "engine.io-client": { 470 | "version": "3.1.6", 471 | "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-3.1.6.tgz", 472 | "integrity": "sha512-hnuHsFluXnsKOndS4Hv6SvUrgdYx1pk2NqfaDMW+GWdgfU3+/V25Cj7I8a0x92idSpa5PIhJRKxPvp9mnoLsfg==", 473 | "dev": true, 474 | "requires": { 475 | "component-emitter": "1.2.1", 476 | "component-inherit": "0.0.3", 477 | "debug": "3.1.0", 478 | "engine.io-parser": "2.1.2", 479 | "has-cors": "1.1.0", 480 | "indexof": "0.0.1", 481 | "parseqs": "0.0.5", 482 | "parseuri": "0.0.5", 483 | "ws": "3.3.3", 484 | "xmlhttprequest-ssl": "1.5.5", 485 | "yeast": "0.1.2" 486 | }, 487 | "dependencies": { 488 | "debug": { 489 | "version": "3.1.0", 490 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 491 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 492 | "dev": true, 493 | "requires": { 494 | "ms": "2.0.0" 495 | } 496 | } 497 | } 498 | }, 499 | "engine.io-parser": { 500 | "version": "2.1.2", 501 | "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-2.1.2.tgz", 502 | "integrity": "sha512-dInLFzr80RijZ1rGpx1+56/uFoH7/7InhH3kZt+Ms6hT8tNx3NGW/WNSA/f8As1WkOfkuyb3tnRyuXGxusclMw==", 503 | "dev": true, 504 | "requires": { 505 | "after": "0.8.2", 506 | "arraybuffer.slice": "0.0.7", 507 | "base64-arraybuffer": "0.1.5", 508 | "blob": "0.0.4", 509 | "has-binary2": "1.0.3" 510 | } 511 | }, 512 | "error-ex": { 513 | "version": "1.3.2", 514 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 515 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 516 | "dev": true, 517 | "requires": { 518 | "is-arrayish": "0.2.1" 519 | } 520 | }, 521 | "escape-html": { 522 | "version": "1.0.3", 523 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 524 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", 525 | "dev": true 526 | }, 527 | "escape-string-regexp": { 528 | "version": "1.0.5", 529 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 530 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 531 | "dev": true 532 | }, 533 | "etag": { 534 | "version": "1.8.1", 535 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 536 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", 537 | "dev": true 538 | }, 539 | "eventemitter3": { 540 | "version": "1.2.0", 541 | "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-1.2.0.tgz", 542 | "integrity": "sha1-HIaZHYFq0eUEdQ5zh0Ik7PO+xQg=", 543 | "dev": true 544 | }, 545 | "expand-brackets": { 546 | "version": "0.1.5", 547 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 548 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 549 | "dev": true, 550 | "requires": { 551 | "is-posix-bracket": "0.1.1" 552 | } 553 | }, 554 | "expand-range": { 555 | "version": "1.8.2", 556 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 557 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 558 | "dev": true, 559 | "requires": { 560 | "fill-range": "2.2.4" 561 | }, 562 | "dependencies": { 563 | "fill-range": { 564 | "version": "2.2.4", 565 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.4.tgz", 566 | "integrity": "sha512-cnrcCbj01+j2gTG921VZPnHbjmdAf8oQV/iGeV2kZxGSyfYjjTyY79ErsK1WJWMpw6DaApEX72binqJE+/d+5Q==", 567 | "dev": true, 568 | "requires": { 569 | "is-number": "2.1.0", 570 | "isobject": "2.1.0", 571 | "randomatic": "3.1.0", 572 | "repeat-element": "1.1.2", 573 | "repeat-string": "1.6.1" 574 | } 575 | }, 576 | "is-number": { 577 | "version": "2.1.0", 578 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 579 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 580 | "dev": true, 581 | "requires": { 582 | "kind-of": "3.2.2" 583 | } 584 | }, 585 | "isobject": { 586 | "version": "2.1.0", 587 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 588 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 589 | "dev": true, 590 | "requires": { 591 | "isarray": "1.0.0" 592 | } 593 | }, 594 | "kind-of": { 595 | "version": "3.2.2", 596 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 597 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 598 | "dev": true, 599 | "requires": { 600 | "is-buffer": "1.1.6" 601 | } 602 | } 603 | } 604 | }, 605 | "extglob": { 606 | "version": "0.3.2", 607 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 608 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 609 | "dev": true, 610 | "requires": { 611 | "is-extglob": "1.0.0" 612 | } 613 | }, 614 | "filename-regex": { 615 | "version": "2.0.1", 616 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 617 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", 618 | "dev": true 619 | }, 620 | "finalhandler": { 621 | "version": "1.1.0", 622 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.0.tgz", 623 | "integrity": "sha1-zgtoVbRYU+eRsvzGgARtiCU91/U=", 624 | "dev": true, 625 | "requires": { 626 | "debug": "2.6.9", 627 | "encodeurl": "1.0.2", 628 | "escape-html": "1.0.3", 629 | "on-finished": "2.3.0", 630 | "parseurl": "1.3.2", 631 | "statuses": "1.3.1", 632 | "unpipe": "1.0.0" 633 | } 634 | }, 635 | "follow-redirects": { 636 | "version": "1.5.5", 637 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.5.5.tgz", 638 | "integrity": "sha512-GHjtHDlY/ehslqv0Gr5N0PUJppgg/q0rOBvX0na1s7y1A3LWxPqCYU76s3Z1bM4+UZB4QF0usaXLT5wFpof5PA==", 639 | "dev": true, 640 | "requires": { 641 | "debug": "3.1.0" 642 | }, 643 | "dependencies": { 644 | "debug": { 645 | "version": "3.1.0", 646 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 647 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 648 | "dev": true, 649 | "requires": { 650 | "ms": "2.0.0" 651 | } 652 | } 653 | } 654 | }, 655 | "for-in": { 656 | "version": "1.0.2", 657 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 658 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 659 | "dev": true 660 | }, 661 | "for-own": { 662 | "version": "0.1.5", 663 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 664 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 665 | "dev": true, 666 | "requires": { 667 | "for-in": "1.0.2" 668 | } 669 | }, 670 | "fresh": { 671 | "version": "0.5.2", 672 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 673 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", 674 | "dev": true 675 | }, 676 | "fs-extra": { 677 | "version": "3.0.1", 678 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-3.0.1.tgz", 679 | "integrity": "sha1-N5TzeMWLNC6n27sjCVEJxLO2IpE=", 680 | "dev": true, 681 | "requires": { 682 | "graceful-fs": "4.1.11", 683 | "jsonfile": "3.0.1", 684 | "universalify": "0.1.2" 685 | } 686 | }, 687 | "fsevents": { 688 | "version": "1.2.4", 689 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.4.tgz", 690 | "integrity": "sha512-z8H8/diyk76B7q5wg+Ud0+CqzcAF3mBBI/bA5ne5zrRUUIvNkJY//D3BqyH571KuAC4Nr7Rw7CjWX4r0y9DvNg==", 691 | "dev": true, 692 | "optional": true, 693 | "requires": { 694 | "nan": "2.10.0", 695 | "node-pre-gyp": "0.10.0" 696 | }, 697 | "dependencies": { 698 | "abbrev": { 699 | "version": "1.1.1", 700 | "bundled": true, 701 | "dev": true, 702 | "optional": true 703 | }, 704 | "ansi-regex": { 705 | "version": "2.1.1", 706 | "bundled": true, 707 | "dev": true 708 | }, 709 | "aproba": { 710 | "version": "1.2.0", 711 | "bundled": true, 712 | "dev": true, 713 | "optional": true 714 | }, 715 | "are-we-there-yet": { 716 | "version": "1.1.4", 717 | "bundled": true, 718 | "dev": true, 719 | "optional": true, 720 | "requires": { 721 | "delegates": "1.0.0", 722 | "readable-stream": "2.3.6" 723 | } 724 | }, 725 | "balanced-match": { 726 | "version": "1.0.0", 727 | "bundled": true, 728 | "dev": true 729 | }, 730 | "brace-expansion": { 731 | "version": "1.1.11", 732 | "bundled": true, 733 | "dev": true, 734 | "requires": { 735 | "balanced-match": "1.0.0", 736 | "concat-map": "0.0.1" 737 | } 738 | }, 739 | "chownr": { 740 | "version": "1.0.1", 741 | "bundled": true, 742 | "dev": true, 743 | "optional": true 744 | }, 745 | "code-point-at": { 746 | "version": "1.1.0", 747 | "bundled": true, 748 | "dev": true 749 | }, 750 | "concat-map": { 751 | "version": "0.0.1", 752 | "bundled": true, 753 | "dev": true 754 | }, 755 | "console-control-strings": { 756 | "version": "1.1.0", 757 | "bundled": true, 758 | "dev": true 759 | }, 760 | "core-util-is": { 761 | "version": "1.0.2", 762 | "bundled": true, 763 | "dev": true, 764 | "optional": true 765 | }, 766 | "debug": { 767 | "version": "2.6.9", 768 | "bundled": true, 769 | "dev": true, 770 | "optional": true, 771 | "requires": { 772 | "ms": "2.0.0" 773 | } 774 | }, 775 | "deep-extend": { 776 | "version": "0.5.1", 777 | "bundled": true, 778 | "dev": true, 779 | "optional": true 780 | }, 781 | "delegates": { 782 | "version": "1.0.0", 783 | "bundled": true, 784 | "dev": true, 785 | "optional": true 786 | }, 787 | "detect-libc": { 788 | "version": "1.0.3", 789 | "bundled": true, 790 | "dev": true, 791 | "optional": true 792 | }, 793 | "fs-minipass": { 794 | "version": "1.2.5", 795 | "bundled": true, 796 | "dev": true, 797 | "optional": true, 798 | "requires": { 799 | "minipass": "2.2.4" 800 | } 801 | }, 802 | "fs.realpath": { 803 | "version": "1.0.0", 804 | "bundled": true, 805 | "dev": true, 806 | "optional": true 807 | }, 808 | "gauge": { 809 | "version": "2.7.4", 810 | "bundled": true, 811 | "dev": true, 812 | "optional": true, 813 | "requires": { 814 | "aproba": "1.2.0", 815 | "console-control-strings": "1.1.0", 816 | "has-unicode": "2.0.1", 817 | "object-assign": "4.1.1", 818 | "signal-exit": "3.0.2", 819 | "string-width": "1.0.2", 820 | "strip-ansi": "3.0.1", 821 | "wide-align": "1.1.2" 822 | } 823 | }, 824 | "glob": { 825 | "version": "7.1.2", 826 | "bundled": true, 827 | "dev": true, 828 | "optional": true, 829 | "requires": { 830 | "fs.realpath": "1.0.0", 831 | "inflight": "1.0.6", 832 | "inherits": "2.0.3", 833 | "minimatch": "3.0.4", 834 | "once": "1.4.0", 835 | "path-is-absolute": "1.0.1" 836 | } 837 | }, 838 | "has-unicode": { 839 | "version": "2.0.1", 840 | "bundled": true, 841 | "dev": true, 842 | "optional": true 843 | }, 844 | "iconv-lite": { 845 | "version": "0.4.21", 846 | "bundled": true, 847 | "dev": true, 848 | "optional": true, 849 | "requires": { 850 | "safer-buffer": "2.1.2" 851 | } 852 | }, 853 | "ignore-walk": { 854 | "version": "3.0.1", 855 | "bundled": true, 856 | "dev": true, 857 | "optional": true, 858 | "requires": { 859 | "minimatch": "3.0.4" 860 | } 861 | }, 862 | "inflight": { 863 | "version": "1.0.6", 864 | "bundled": true, 865 | "dev": true, 866 | "optional": true, 867 | "requires": { 868 | "once": "1.4.0", 869 | "wrappy": "1.0.2" 870 | } 871 | }, 872 | "inherits": { 873 | "version": "2.0.3", 874 | "bundled": true, 875 | "dev": true 876 | }, 877 | "ini": { 878 | "version": "1.3.5", 879 | "bundled": true, 880 | "dev": true, 881 | "optional": true 882 | }, 883 | "is-fullwidth-code-point": { 884 | "version": "1.0.0", 885 | "bundled": true, 886 | "dev": true, 887 | "requires": { 888 | "number-is-nan": "1.0.1" 889 | } 890 | }, 891 | "isarray": { 892 | "version": "1.0.0", 893 | "bundled": true, 894 | "dev": true, 895 | "optional": true 896 | }, 897 | "minimatch": { 898 | "version": "3.0.4", 899 | "bundled": true, 900 | "dev": true, 901 | "requires": { 902 | "brace-expansion": "1.1.11" 903 | } 904 | }, 905 | "minimist": { 906 | "version": "0.0.8", 907 | "bundled": true, 908 | "dev": true 909 | }, 910 | "minipass": { 911 | "version": "2.2.4", 912 | "bundled": true, 913 | "dev": true, 914 | "requires": { 915 | "safe-buffer": "5.1.1", 916 | "yallist": "3.0.2" 917 | } 918 | }, 919 | "minizlib": { 920 | "version": "1.1.0", 921 | "bundled": true, 922 | "dev": true, 923 | "optional": true, 924 | "requires": { 925 | "minipass": "2.2.4" 926 | } 927 | }, 928 | "mkdirp": { 929 | "version": "0.5.1", 930 | "bundled": true, 931 | "dev": true, 932 | "requires": { 933 | "minimist": "0.0.8" 934 | } 935 | }, 936 | "ms": { 937 | "version": "2.0.0", 938 | "bundled": true, 939 | "dev": true, 940 | "optional": true 941 | }, 942 | "needle": { 943 | "version": "2.2.0", 944 | "bundled": true, 945 | "dev": true, 946 | "optional": true, 947 | "requires": { 948 | "debug": "2.6.9", 949 | "iconv-lite": "0.4.21", 950 | "sax": "1.2.4" 951 | } 952 | }, 953 | "node-pre-gyp": { 954 | "version": "0.10.0", 955 | "bundled": true, 956 | "dev": true, 957 | "optional": true, 958 | "requires": { 959 | "detect-libc": "1.0.3", 960 | "mkdirp": "0.5.1", 961 | "needle": "2.2.0", 962 | "nopt": "4.0.1", 963 | "npm-packlist": "1.1.10", 964 | "npmlog": "4.1.2", 965 | "rc": "1.2.7", 966 | "rimraf": "2.6.2", 967 | "semver": "5.5.0", 968 | "tar": "4.4.1" 969 | } 970 | }, 971 | "nopt": { 972 | "version": "4.0.1", 973 | "bundled": true, 974 | "dev": true, 975 | "optional": true, 976 | "requires": { 977 | "abbrev": "1.1.1", 978 | "osenv": "0.1.5" 979 | } 980 | }, 981 | "npm-bundled": { 982 | "version": "1.0.3", 983 | "bundled": true, 984 | "dev": true, 985 | "optional": true 986 | }, 987 | "npm-packlist": { 988 | "version": "1.1.10", 989 | "bundled": true, 990 | "dev": true, 991 | "optional": true, 992 | "requires": { 993 | "ignore-walk": "3.0.1", 994 | "npm-bundled": "1.0.3" 995 | } 996 | }, 997 | "npmlog": { 998 | "version": "4.1.2", 999 | "bundled": true, 1000 | "dev": true, 1001 | "optional": true, 1002 | "requires": { 1003 | "are-we-there-yet": "1.1.4", 1004 | "console-control-strings": "1.1.0", 1005 | "gauge": "2.7.4", 1006 | "set-blocking": "2.0.0" 1007 | } 1008 | }, 1009 | "number-is-nan": { 1010 | "version": "1.0.1", 1011 | "bundled": true, 1012 | "dev": true 1013 | }, 1014 | "object-assign": { 1015 | "version": "4.1.1", 1016 | "bundled": true, 1017 | "dev": true, 1018 | "optional": true 1019 | }, 1020 | "once": { 1021 | "version": "1.4.0", 1022 | "bundled": true, 1023 | "dev": true, 1024 | "requires": { 1025 | "wrappy": "1.0.2" 1026 | } 1027 | }, 1028 | "os-homedir": { 1029 | "version": "1.0.2", 1030 | "bundled": true, 1031 | "dev": true, 1032 | "optional": true 1033 | }, 1034 | "os-tmpdir": { 1035 | "version": "1.0.2", 1036 | "bundled": true, 1037 | "dev": true, 1038 | "optional": true 1039 | }, 1040 | "osenv": { 1041 | "version": "0.1.5", 1042 | "bundled": true, 1043 | "dev": true, 1044 | "optional": true, 1045 | "requires": { 1046 | "os-homedir": "1.0.2", 1047 | "os-tmpdir": "1.0.2" 1048 | } 1049 | }, 1050 | "path-is-absolute": { 1051 | "version": "1.0.1", 1052 | "bundled": true, 1053 | "dev": true, 1054 | "optional": true 1055 | }, 1056 | "process-nextick-args": { 1057 | "version": "2.0.0", 1058 | "bundled": true, 1059 | "dev": true, 1060 | "optional": true 1061 | }, 1062 | "rc": { 1063 | "version": "1.2.7", 1064 | "bundled": true, 1065 | "dev": true, 1066 | "optional": true, 1067 | "requires": { 1068 | "deep-extend": "0.5.1", 1069 | "ini": "1.3.5", 1070 | "minimist": "1.2.0", 1071 | "strip-json-comments": "2.0.1" 1072 | }, 1073 | "dependencies": { 1074 | "minimist": { 1075 | "version": "1.2.0", 1076 | "bundled": true, 1077 | "dev": true, 1078 | "optional": true 1079 | } 1080 | } 1081 | }, 1082 | "readable-stream": { 1083 | "version": "2.3.6", 1084 | "bundled": true, 1085 | "dev": true, 1086 | "optional": true, 1087 | "requires": { 1088 | "core-util-is": "1.0.2", 1089 | "inherits": "2.0.3", 1090 | "isarray": "1.0.0", 1091 | "process-nextick-args": "2.0.0", 1092 | "safe-buffer": "5.1.1", 1093 | "string_decoder": "1.1.1", 1094 | "util-deprecate": "1.0.2" 1095 | } 1096 | }, 1097 | "rimraf": { 1098 | "version": "2.6.2", 1099 | "bundled": true, 1100 | "dev": true, 1101 | "optional": true, 1102 | "requires": { 1103 | "glob": "7.1.2" 1104 | } 1105 | }, 1106 | "safe-buffer": { 1107 | "version": "5.1.1", 1108 | "bundled": true, 1109 | "dev": true 1110 | }, 1111 | "safer-buffer": { 1112 | "version": "2.1.2", 1113 | "bundled": true, 1114 | "dev": true, 1115 | "optional": true 1116 | }, 1117 | "sax": { 1118 | "version": "1.2.4", 1119 | "bundled": true, 1120 | "dev": true, 1121 | "optional": true 1122 | }, 1123 | "semver": { 1124 | "version": "5.5.0", 1125 | "bundled": true, 1126 | "dev": true, 1127 | "optional": true 1128 | }, 1129 | "set-blocking": { 1130 | "version": "2.0.0", 1131 | "bundled": true, 1132 | "dev": true, 1133 | "optional": true 1134 | }, 1135 | "signal-exit": { 1136 | "version": "3.0.2", 1137 | "bundled": true, 1138 | "dev": true, 1139 | "optional": true 1140 | }, 1141 | "string-width": { 1142 | "version": "1.0.2", 1143 | "bundled": true, 1144 | "dev": true, 1145 | "requires": { 1146 | "code-point-at": "1.1.0", 1147 | "is-fullwidth-code-point": "1.0.0", 1148 | "strip-ansi": "3.0.1" 1149 | } 1150 | }, 1151 | "string_decoder": { 1152 | "version": "1.1.1", 1153 | "bundled": true, 1154 | "dev": true, 1155 | "optional": true, 1156 | "requires": { 1157 | "safe-buffer": "5.1.1" 1158 | } 1159 | }, 1160 | "strip-ansi": { 1161 | "version": "3.0.1", 1162 | "bundled": true, 1163 | "dev": true, 1164 | "requires": { 1165 | "ansi-regex": "2.1.1" 1166 | } 1167 | }, 1168 | "strip-json-comments": { 1169 | "version": "2.0.1", 1170 | "bundled": true, 1171 | "dev": true, 1172 | "optional": true 1173 | }, 1174 | "tar": { 1175 | "version": "4.4.1", 1176 | "bundled": true, 1177 | "dev": true, 1178 | "optional": true, 1179 | "requires": { 1180 | "chownr": "1.0.1", 1181 | "fs-minipass": "1.2.5", 1182 | "minipass": "2.2.4", 1183 | "minizlib": "1.1.0", 1184 | "mkdirp": "0.5.1", 1185 | "safe-buffer": "5.1.1", 1186 | "yallist": "3.0.2" 1187 | } 1188 | }, 1189 | "util-deprecate": { 1190 | "version": "1.0.2", 1191 | "bundled": true, 1192 | "dev": true, 1193 | "optional": true 1194 | }, 1195 | "wide-align": { 1196 | "version": "1.1.2", 1197 | "bundled": true, 1198 | "dev": true, 1199 | "optional": true, 1200 | "requires": { 1201 | "string-width": "1.0.2" 1202 | } 1203 | }, 1204 | "wrappy": { 1205 | "version": "1.0.2", 1206 | "bundled": true, 1207 | "dev": true 1208 | }, 1209 | "yallist": { 1210 | "version": "3.0.2", 1211 | "bundled": true, 1212 | "dev": true 1213 | } 1214 | } 1215 | }, 1216 | "get-caller-file": { 1217 | "version": "1.0.3", 1218 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", 1219 | "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==", 1220 | "dev": true 1221 | }, 1222 | "glob-base": { 1223 | "version": "0.3.0", 1224 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 1225 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 1226 | "dev": true, 1227 | "requires": { 1228 | "glob-parent": "2.0.0", 1229 | "is-glob": "2.0.1" 1230 | }, 1231 | "dependencies": { 1232 | "glob-parent": { 1233 | "version": "2.0.0", 1234 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 1235 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 1236 | "dev": true, 1237 | "requires": { 1238 | "is-glob": "2.0.1" 1239 | } 1240 | }, 1241 | "is-extglob": { 1242 | "version": "1.0.0", 1243 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1244 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 1245 | "dev": true 1246 | }, 1247 | "is-glob": { 1248 | "version": "2.0.1", 1249 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1250 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1251 | "dev": true, 1252 | "requires": { 1253 | "is-extglob": "1.0.0" 1254 | } 1255 | } 1256 | } 1257 | }, 1258 | "glob-parent": { 1259 | "version": "2.0.0", 1260 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 1261 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 1262 | "dev": true, 1263 | "requires": { 1264 | "is-glob": "2.0.1" 1265 | } 1266 | }, 1267 | "graceful-fs": { 1268 | "version": "4.1.11", 1269 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 1270 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 1271 | "dev": true 1272 | }, 1273 | "has-ansi": { 1274 | "version": "2.0.0", 1275 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 1276 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 1277 | "dev": true, 1278 | "requires": { 1279 | "ansi-regex": "2.1.1" 1280 | } 1281 | }, 1282 | "has-binary2": { 1283 | "version": "1.0.3", 1284 | "resolved": "https://registry.npmjs.org/has-binary2/-/has-binary2-1.0.3.tgz", 1285 | "integrity": "sha512-G1LWKhDSvhGeAQ8mPVQlqNcOB2sJdwATtZKl2pDKKHfpf/rYj24lkinxf69blJbnsvtqqNU+L3SL50vzZhXOnw==", 1286 | "dev": true, 1287 | "requires": { 1288 | "isarray": "2.0.1" 1289 | }, 1290 | "dependencies": { 1291 | "isarray": { 1292 | "version": "2.0.1", 1293 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz", 1294 | "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4=", 1295 | "dev": true 1296 | } 1297 | } 1298 | }, 1299 | "has-cors": { 1300 | "version": "1.1.0", 1301 | "resolved": "https://registry.npmjs.org/has-cors/-/has-cors-1.1.0.tgz", 1302 | "integrity": "sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk=", 1303 | "dev": true 1304 | }, 1305 | "hosted-git-info": { 1306 | "version": "2.7.1", 1307 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 1308 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 1309 | "dev": true 1310 | }, 1311 | "http-errors": { 1312 | "version": "1.6.3", 1313 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", 1314 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", 1315 | "dev": true, 1316 | "requires": { 1317 | "depd": "1.1.2", 1318 | "inherits": "2.0.3", 1319 | "setprototypeof": "1.1.0", 1320 | "statuses": "1.5.0" 1321 | }, 1322 | "dependencies": { 1323 | "statuses": { 1324 | "version": "1.5.0", 1325 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1326 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 1327 | "dev": true 1328 | } 1329 | } 1330 | }, 1331 | "http-proxy": { 1332 | "version": "1.15.2", 1333 | "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.15.2.tgz", 1334 | "integrity": "sha1-ZC/cr/5S00SNK9o7AHnpQJBk2jE=", 1335 | "dev": true, 1336 | "requires": { 1337 | "eventemitter3": "1.2.0", 1338 | "requires-port": "1.0.0" 1339 | } 1340 | }, 1341 | "immutable": { 1342 | "version": "3.8.2", 1343 | "resolved": "https://registry.npmjs.org/immutable/-/immutable-3.8.2.tgz", 1344 | "integrity": "sha1-wkOZUUVbs5kT2vKBN28VMOEErfM=", 1345 | "dev": true 1346 | }, 1347 | "indexof": { 1348 | "version": "0.0.1", 1349 | "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz", 1350 | "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=", 1351 | "dev": true 1352 | }, 1353 | "inherits": { 1354 | "version": "2.0.3", 1355 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1356 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 1357 | "dev": true 1358 | }, 1359 | "invert-kv": { 1360 | "version": "1.0.0", 1361 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", 1362 | "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=", 1363 | "dev": true 1364 | }, 1365 | "is-arrayish": { 1366 | "version": "0.2.1", 1367 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1368 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1369 | "dev": true 1370 | }, 1371 | "is-binary-path": { 1372 | "version": "1.0.1", 1373 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 1374 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 1375 | "dev": true, 1376 | "requires": { 1377 | "binary-extensions": "1.11.0" 1378 | } 1379 | }, 1380 | "is-buffer": { 1381 | "version": "1.1.6", 1382 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1383 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1384 | "dev": true 1385 | }, 1386 | "is-builtin-module": { 1387 | "version": "1.0.0", 1388 | "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 1389 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 1390 | "dev": true, 1391 | "requires": { 1392 | "builtin-modules": "1.1.1" 1393 | } 1394 | }, 1395 | "is-dotfile": { 1396 | "version": "1.0.3", 1397 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 1398 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", 1399 | "dev": true 1400 | }, 1401 | "is-equal-shallow": { 1402 | "version": "0.1.3", 1403 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 1404 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 1405 | "dev": true, 1406 | "requires": { 1407 | "is-primitive": "2.0.0" 1408 | } 1409 | }, 1410 | "is-extendable": { 1411 | "version": "0.1.1", 1412 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1413 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 1414 | "dev": true 1415 | }, 1416 | "is-extglob": { 1417 | "version": "1.0.0", 1418 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1419 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 1420 | "dev": true 1421 | }, 1422 | "is-fullwidth-code-point": { 1423 | "version": "1.0.0", 1424 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1425 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1426 | "dev": true, 1427 | "requires": { 1428 | "number-is-nan": "1.0.1" 1429 | } 1430 | }, 1431 | "is-glob": { 1432 | "version": "2.0.1", 1433 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1434 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1435 | "dev": true, 1436 | "requires": { 1437 | "is-extglob": "1.0.0" 1438 | } 1439 | }, 1440 | "is-number-like": { 1441 | "version": "1.0.8", 1442 | "resolved": "https://registry.npmjs.org/is-number-like/-/is-number-like-1.0.8.tgz", 1443 | "integrity": "sha512-6rZi3ezCyFcn5L71ywzz2bS5b2Igl1En3eTlZlvKjpz1n3IZLAYMbKYAIQgFmEu0GENg92ziU/faEOA/aixjbA==", 1444 | "dev": true, 1445 | "requires": { 1446 | "lodash.isfinite": "3.3.2" 1447 | } 1448 | }, 1449 | "is-posix-bracket": { 1450 | "version": "0.1.1", 1451 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 1452 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", 1453 | "dev": true 1454 | }, 1455 | "is-primitive": { 1456 | "version": "2.0.0", 1457 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 1458 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", 1459 | "dev": true 1460 | }, 1461 | "is-utf8": { 1462 | "version": "0.2.1", 1463 | "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", 1464 | "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", 1465 | "dev": true 1466 | }, 1467 | "isarray": { 1468 | "version": "1.0.0", 1469 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1470 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1471 | "dev": true 1472 | }, 1473 | "jsonfile": { 1474 | "version": "3.0.1", 1475 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-3.0.1.tgz", 1476 | "integrity": "sha1-pezG9l9T9mLEQVx2daAzHQmS7GY=", 1477 | "dev": true, 1478 | "requires": { 1479 | "graceful-fs": "4.1.11" 1480 | } 1481 | }, 1482 | "kind-of": { 1483 | "version": "6.0.2", 1484 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 1485 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", 1486 | "dev": true 1487 | }, 1488 | "lcid": { 1489 | "version": "1.0.0", 1490 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", 1491 | "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", 1492 | "dev": true, 1493 | "requires": { 1494 | "invert-kv": "1.0.0" 1495 | } 1496 | }, 1497 | "limiter": { 1498 | "version": "1.1.3", 1499 | "resolved": "https://registry.npmjs.org/limiter/-/limiter-1.1.3.tgz", 1500 | "integrity": "sha512-zrycnIMsLw/3ZxTbW7HCez56rcFGecWTx5OZNplzcXUUmJLmoYArC6qdJzmAN5BWiNXGcpjhF9RQ1HSv5zebEw==", 1501 | "dev": true 1502 | }, 1503 | "lite-server": { 1504 | "version": "2.4.0", 1505 | "resolved": "https://registry.npmjs.org/lite-server/-/lite-server-2.4.0.tgz", 1506 | "integrity": "sha512-Vo06tHpXrqm37i6T7tVdq5PSbrFmvQRw64+dlFXdh1tltv6KCvpE+xzXz2+x6KWJ8ja+GgwSy4P13GUWyhaDHQ==", 1507 | "dev": true, 1508 | "requires": { 1509 | "browser-sync": "2.24.6", 1510 | "connect-history-api-fallback": "1.5.0", 1511 | "connect-logger": "0.0.1", 1512 | "lodash": "4.17.10", 1513 | "minimist": "1.2.0" 1514 | }, 1515 | "dependencies": { 1516 | "minimist": { 1517 | "version": "1.2.0", 1518 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1519 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1520 | "dev": true 1521 | } 1522 | } 1523 | }, 1524 | "load-json-file": { 1525 | "version": "1.1.0", 1526 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", 1527 | "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=", 1528 | "dev": true, 1529 | "requires": { 1530 | "graceful-fs": "4.1.11", 1531 | "parse-json": "2.2.0", 1532 | "pify": "2.3.0", 1533 | "pinkie-promise": "2.0.1", 1534 | "strip-bom": "2.0.0" 1535 | }, 1536 | "dependencies": { 1537 | "pify": { 1538 | "version": "2.3.0", 1539 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1540 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1541 | "dev": true 1542 | } 1543 | } 1544 | }, 1545 | "localtunnel": { 1546 | "version": "1.9.0", 1547 | "resolved": "https://registry.npmjs.org/localtunnel/-/localtunnel-1.9.0.tgz", 1548 | "integrity": "sha512-wCIiIHJ8kKIcWkTQE3m1VRABvsH2ZuOkiOpZUofUCf6Q42v3VIZ+Q0YfX1Z4sYDRj0muiKL1bLvz1FeoxsPO0w==", 1549 | "dev": true, 1550 | "requires": { 1551 | "axios": "0.17.1", 1552 | "debug": "2.6.8", 1553 | "openurl": "1.1.1", 1554 | "yargs": "6.6.0" 1555 | }, 1556 | "dependencies": { 1557 | "debug": { 1558 | "version": "2.6.8", 1559 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", 1560 | "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", 1561 | "dev": true, 1562 | "requires": { 1563 | "ms": "2.0.0" 1564 | } 1565 | }, 1566 | "yargs": { 1567 | "version": "6.6.0", 1568 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-6.6.0.tgz", 1569 | "integrity": "sha1-eC7CHvQDNF+DCoCMo9UTr1YGUgg=", 1570 | "dev": true, 1571 | "requires": { 1572 | "camelcase": "3.0.0", 1573 | "cliui": "3.2.0", 1574 | "decamelize": "1.2.0", 1575 | "get-caller-file": "1.0.3", 1576 | "os-locale": "1.4.0", 1577 | "read-pkg-up": "1.0.1", 1578 | "require-directory": "2.1.1", 1579 | "require-main-filename": "1.0.1", 1580 | "set-blocking": "2.0.0", 1581 | "string-width": "1.0.2", 1582 | "which-module": "1.0.0", 1583 | "y18n": "3.2.1", 1584 | "yargs-parser": "4.2.1" 1585 | } 1586 | } 1587 | } 1588 | }, 1589 | "lodash": { 1590 | "version": "4.17.10", 1591 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.10.tgz", 1592 | "integrity": "sha512-UejweD1pDoXu+AD825lWwp4ZGtSwgnpZxb3JDViD7StjQz+Nb/6l093lx4OQ0foGWNRoc19mWy7BzL+UAK2iVg==", 1593 | "dev": true 1594 | }, 1595 | "lodash.isfinite": { 1596 | "version": "3.3.2", 1597 | "resolved": "https://registry.npmjs.org/lodash.isfinite/-/lodash.isfinite-3.3.2.tgz", 1598 | "integrity": "sha1-+4m2WpqAKBgz8LdHizpRBPiY67M=", 1599 | "dev": true 1600 | }, 1601 | "math-random": { 1602 | "version": "1.0.1", 1603 | "resolved": "https://registry.npmjs.org/math-random/-/math-random-1.0.1.tgz", 1604 | "integrity": "sha1-izqsWIuKZuSXXjzepn97sylgH6w=", 1605 | "dev": true 1606 | }, 1607 | "micromatch": { 1608 | "version": "2.3.11", 1609 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 1610 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 1611 | "dev": true, 1612 | "requires": { 1613 | "arr-diff": "2.0.0", 1614 | "array-unique": "0.2.1", 1615 | "braces": "1.8.5", 1616 | "expand-brackets": "0.1.5", 1617 | "extglob": "0.3.2", 1618 | "filename-regex": "2.0.1", 1619 | "is-extglob": "1.0.0", 1620 | "is-glob": "2.0.1", 1621 | "kind-of": "3.2.2", 1622 | "normalize-path": "2.1.1", 1623 | "object.omit": "2.0.1", 1624 | "parse-glob": "3.0.4", 1625 | "regex-cache": "0.4.4" 1626 | }, 1627 | "dependencies": { 1628 | "kind-of": { 1629 | "version": "3.2.2", 1630 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1631 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1632 | "dev": true, 1633 | "requires": { 1634 | "is-buffer": "1.1.6" 1635 | } 1636 | } 1637 | } 1638 | }, 1639 | "mime": { 1640 | "version": "1.4.1", 1641 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 1642 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==", 1643 | "dev": true 1644 | }, 1645 | "mime-db": { 1646 | "version": "1.35.0", 1647 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.35.0.tgz", 1648 | "integrity": "sha512-JWT/IcCTsB0Io3AhWUMjRqucrHSPsSf2xKLaRldJVULioggvkJvggZ3VXNNSRkCddE6D+BUI4HEIZIA2OjwIvg==", 1649 | "dev": true 1650 | }, 1651 | "mime-types": { 1652 | "version": "2.1.19", 1653 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.19.tgz", 1654 | "integrity": "sha512-P1tKYHVSZ6uFo26mtnve4HQFE3koh1UWVkp8YUC+ESBHe945xWSoXuHHiGarDqcEZ+whpCDnlNw5LON0kLo+sw==", 1655 | "dev": true, 1656 | "requires": { 1657 | "mime-db": "1.35.0" 1658 | } 1659 | }, 1660 | "minimatch": { 1661 | "version": "3.0.4", 1662 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1663 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1664 | "dev": true, 1665 | "requires": { 1666 | "brace-expansion": "1.1.11" 1667 | } 1668 | }, 1669 | "moment": { 1670 | "version": "2.22.2", 1671 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.22.2.tgz", 1672 | "integrity": "sha1-PCV/mDn8DpP/UxSWMiOeuQeD/2Y=", 1673 | "dev": true 1674 | }, 1675 | "ms": { 1676 | "version": "2.0.0", 1677 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1678 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1679 | "dev": true 1680 | }, 1681 | "nan": { 1682 | "version": "2.10.0", 1683 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz", 1684 | "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==", 1685 | "dev": true, 1686 | "optional": true 1687 | }, 1688 | "negotiator": { 1689 | "version": "0.6.1", 1690 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 1691 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=", 1692 | "dev": true 1693 | }, 1694 | "normalize-package-data": { 1695 | "version": "2.4.0", 1696 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 1697 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 1698 | "dev": true, 1699 | "requires": { 1700 | "hosted-git-info": "2.7.1", 1701 | "is-builtin-module": "1.0.0", 1702 | "semver": "5.5.0", 1703 | "validate-npm-package-license": "3.0.4" 1704 | } 1705 | }, 1706 | "normalize-path": { 1707 | "version": "2.1.1", 1708 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 1709 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 1710 | "dev": true, 1711 | "requires": { 1712 | "remove-trailing-separator": "1.1.0" 1713 | } 1714 | }, 1715 | "number-is-nan": { 1716 | "version": "1.0.1", 1717 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1718 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 1719 | "dev": true 1720 | }, 1721 | "object-assign": { 1722 | "version": "4.1.1", 1723 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1724 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1725 | "dev": true 1726 | }, 1727 | "object-component": { 1728 | "version": "0.0.3", 1729 | "resolved": "https://registry.npmjs.org/object-component/-/object-component-0.0.3.tgz", 1730 | "integrity": "sha1-8MaapQ78lbhmwYb0AKM3acsvEpE=", 1731 | "dev": true 1732 | }, 1733 | "object-path": { 1734 | "version": "0.9.2", 1735 | "resolved": "https://registry.npmjs.org/object-path/-/object-path-0.9.2.tgz", 1736 | "integrity": "sha1-D9mnT8X60a45aLWGvaXGMr1sBaU=", 1737 | "dev": true 1738 | }, 1739 | "object.omit": { 1740 | "version": "2.0.1", 1741 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 1742 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 1743 | "dev": true, 1744 | "requires": { 1745 | "for-own": "0.1.5", 1746 | "is-extendable": "0.1.1" 1747 | } 1748 | }, 1749 | "on-finished": { 1750 | "version": "2.3.0", 1751 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1752 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1753 | "dev": true, 1754 | "requires": { 1755 | "ee-first": "1.1.1" 1756 | } 1757 | }, 1758 | "openurl": { 1759 | "version": "1.1.1", 1760 | "resolved": "https://registry.npmjs.org/openurl/-/openurl-1.1.1.tgz", 1761 | "integrity": "sha1-OHW0sO96UsFW8NtB1GCduw+Us4c=", 1762 | "dev": true 1763 | }, 1764 | "opn": { 1765 | "version": "4.0.2", 1766 | "resolved": "https://registry.npmjs.org/opn/-/opn-4.0.2.tgz", 1767 | "integrity": "sha1-erwi5kTf9jsKltWrfyeQwPAavJU=", 1768 | "dev": true, 1769 | "requires": { 1770 | "object-assign": "4.1.1", 1771 | "pinkie-promise": "2.0.1" 1772 | } 1773 | }, 1774 | "os-locale": { 1775 | "version": "1.4.0", 1776 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", 1777 | "integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=", 1778 | "dev": true, 1779 | "requires": { 1780 | "lcid": "1.0.0" 1781 | } 1782 | }, 1783 | "parse-glob": { 1784 | "version": "3.0.4", 1785 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 1786 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 1787 | "dev": true, 1788 | "requires": { 1789 | "glob-base": "0.3.0", 1790 | "is-dotfile": "1.0.3", 1791 | "is-extglob": "1.0.0", 1792 | "is-glob": "2.0.1" 1793 | }, 1794 | "dependencies": { 1795 | "is-extglob": { 1796 | "version": "1.0.0", 1797 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1798 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 1799 | "dev": true 1800 | }, 1801 | "is-glob": { 1802 | "version": "2.0.1", 1803 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1804 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1805 | "dev": true, 1806 | "requires": { 1807 | "is-extglob": "1.0.0" 1808 | } 1809 | } 1810 | } 1811 | }, 1812 | "parse-json": { 1813 | "version": "2.2.0", 1814 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1815 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1816 | "dev": true, 1817 | "requires": { 1818 | "error-ex": "1.3.2" 1819 | } 1820 | }, 1821 | "parseqs": { 1822 | "version": "0.0.5", 1823 | "resolved": "https://registry.npmjs.org/parseqs/-/parseqs-0.0.5.tgz", 1824 | "integrity": "sha1-1SCKNzjkZ2bikbouoXNoSSGouJ0=", 1825 | "dev": true, 1826 | "requires": { 1827 | "better-assert": "1.0.2" 1828 | } 1829 | }, 1830 | "parseuri": { 1831 | "version": "0.0.5", 1832 | "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.5.tgz", 1833 | "integrity": "sha1-gCBKUNTbt3m/3G6+J3jZDkvOMgo=", 1834 | "dev": true, 1835 | "requires": { 1836 | "better-assert": "1.0.2" 1837 | } 1838 | }, 1839 | "parseurl": { 1840 | "version": "1.3.2", 1841 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 1842 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=", 1843 | "dev": true 1844 | }, 1845 | "path-is-absolute": { 1846 | "version": "1.0.1", 1847 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1848 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1849 | "dev": true 1850 | }, 1851 | "path-type": { 1852 | "version": "1.1.0", 1853 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", 1854 | "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=", 1855 | "dev": true, 1856 | "requires": { 1857 | "graceful-fs": "4.1.11", 1858 | "pify": "2.3.0", 1859 | "pinkie-promise": "2.0.1" 1860 | }, 1861 | "dependencies": { 1862 | "pify": { 1863 | "version": "2.3.0", 1864 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1865 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1866 | "dev": true 1867 | } 1868 | } 1869 | }, 1870 | "pinkie": { 1871 | "version": "2.0.4", 1872 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 1873 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 1874 | "dev": true 1875 | }, 1876 | "pinkie-promise": { 1877 | "version": "2.0.1", 1878 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 1879 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 1880 | "dev": true, 1881 | "requires": { 1882 | "pinkie": "2.0.4" 1883 | } 1884 | }, 1885 | "portscanner": { 1886 | "version": "2.1.1", 1887 | "resolved": "https://registry.npmjs.org/portscanner/-/portscanner-2.1.1.tgz", 1888 | "integrity": "sha1-6rtAnk3iSVD1oqUW01rnaTQ/u5Y=", 1889 | "dev": true, 1890 | "requires": { 1891 | "async": "1.5.2", 1892 | "is-number-like": "1.0.8" 1893 | } 1894 | }, 1895 | "preserve": { 1896 | "version": "0.2.0", 1897 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 1898 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", 1899 | "dev": true 1900 | }, 1901 | "process-nextick-args": { 1902 | "version": "2.0.0", 1903 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1904 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 1905 | "dev": true 1906 | }, 1907 | "qs": { 1908 | "version": "6.2.3", 1909 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.2.3.tgz", 1910 | "integrity": "sha1-HPyyXBCpsrSDBT/zn138kjOQjP4=", 1911 | "dev": true 1912 | }, 1913 | "randomatic": { 1914 | "version": "3.1.0", 1915 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-3.1.0.tgz", 1916 | "integrity": "sha512-KnGPVE0lo2WoXxIZ7cPR8YBpiol4gsSuOwDSg410oHh80ZMp5EiypNqL2K4Z77vJn6lB5rap7IkAmcUlalcnBQ==", 1917 | "dev": true, 1918 | "requires": { 1919 | "is-number": "4.0.0", 1920 | "kind-of": "6.0.2", 1921 | "math-random": "1.0.1" 1922 | }, 1923 | "dependencies": { 1924 | "is-number": { 1925 | "version": "4.0.0", 1926 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", 1927 | "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==", 1928 | "dev": true 1929 | } 1930 | } 1931 | }, 1932 | "range-parser": { 1933 | "version": "1.2.0", 1934 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 1935 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=", 1936 | "dev": true 1937 | }, 1938 | "raw-body": { 1939 | "version": "2.3.3", 1940 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz", 1941 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==", 1942 | "dev": true, 1943 | "requires": { 1944 | "bytes": "3.0.0", 1945 | "http-errors": "1.6.3", 1946 | "iconv-lite": "0.4.23", 1947 | "unpipe": "1.0.0" 1948 | }, 1949 | "dependencies": { 1950 | "iconv-lite": { 1951 | "version": "0.4.23", 1952 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", 1953 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", 1954 | "dev": true, 1955 | "requires": { 1956 | "safer-buffer": "2.1.2" 1957 | } 1958 | } 1959 | } 1960 | }, 1961 | "read-pkg": { 1962 | "version": "1.1.0", 1963 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", 1964 | "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=", 1965 | "dev": true, 1966 | "requires": { 1967 | "load-json-file": "1.1.0", 1968 | "normalize-package-data": "2.4.0", 1969 | "path-type": "1.1.0" 1970 | } 1971 | }, 1972 | "read-pkg-up": { 1973 | "version": "1.0.1", 1974 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz", 1975 | "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=", 1976 | "dev": true, 1977 | "requires": { 1978 | "find-up": "1.1.2", 1979 | "read-pkg": "1.1.0" 1980 | }, 1981 | "dependencies": { 1982 | "find-up": { 1983 | "version": "1.1.2", 1984 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 1985 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 1986 | "dev": true, 1987 | "requires": { 1988 | "path-exists": "2.1.0", 1989 | "pinkie-promise": "2.0.1" 1990 | } 1991 | }, 1992 | "path-exists": { 1993 | "version": "2.1.0", 1994 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 1995 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 1996 | "dev": true, 1997 | "requires": { 1998 | "pinkie-promise": "2.0.1" 1999 | } 2000 | } 2001 | } 2002 | }, 2003 | "readable-stream": { 2004 | "version": "2.3.6", 2005 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 2006 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 2007 | "dev": true, 2008 | "requires": { 2009 | "core-util-is": "1.0.2", 2010 | "inherits": "2.0.3", 2011 | "isarray": "1.0.0", 2012 | "process-nextick-args": "2.0.0", 2013 | "safe-buffer": "5.1.2", 2014 | "string_decoder": "1.1.1", 2015 | "util-deprecate": "1.0.2" 2016 | } 2017 | }, 2018 | "readdirp": { 2019 | "version": "2.1.0", 2020 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", 2021 | "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", 2022 | "dev": true, 2023 | "requires": { 2024 | "graceful-fs": "4.1.11", 2025 | "minimatch": "3.0.4", 2026 | "readable-stream": "2.3.6", 2027 | "set-immediate-shim": "1.0.1" 2028 | } 2029 | }, 2030 | "regex-cache": { 2031 | "version": "0.4.4", 2032 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 2033 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 2034 | "dev": true, 2035 | "requires": { 2036 | "is-equal-shallow": "0.1.3" 2037 | } 2038 | }, 2039 | "remove-trailing-separator": { 2040 | "version": "1.1.0", 2041 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2042 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 2043 | "dev": true 2044 | }, 2045 | "repeat-element": { 2046 | "version": "1.1.2", 2047 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", 2048 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", 2049 | "dev": true 2050 | }, 2051 | "repeat-string": { 2052 | "version": "1.6.1", 2053 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2054 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 2055 | "dev": true 2056 | }, 2057 | "require-directory": { 2058 | "version": "2.1.1", 2059 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2060 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2061 | "dev": true 2062 | }, 2063 | "require-main-filename": { 2064 | "version": "1.0.1", 2065 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", 2066 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=", 2067 | "dev": true 2068 | }, 2069 | "requires-port": { 2070 | "version": "1.0.0", 2071 | "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", 2072 | "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", 2073 | "dev": true 2074 | }, 2075 | "resp-modifier": { 2076 | "version": "6.0.2", 2077 | "resolved": "https://registry.npmjs.org/resp-modifier/-/resp-modifier-6.0.2.tgz", 2078 | "integrity": "sha1-sSTeXE+6/LpUH0j/pzlw9KpFa08=", 2079 | "dev": true, 2080 | "requires": { 2081 | "debug": "2.6.9", 2082 | "minimatch": "3.0.4" 2083 | } 2084 | }, 2085 | "rx": { 2086 | "version": "4.1.0", 2087 | "resolved": "https://registry.npmjs.org/rx/-/rx-4.1.0.tgz", 2088 | "integrity": "sha1-pfE/957zt0D+MKqAP7CfmIBdR4I=", 2089 | "dev": true 2090 | }, 2091 | "safe-buffer": { 2092 | "version": "5.1.2", 2093 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2094 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2095 | "dev": true 2096 | }, 2097 | "safer-buffer": { 2098 | "version": "2.1.2", 2099 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2100 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2101 | "dev": true 2102 | }, 2103 | "semver": { 2104 | "version": "5.5.0", 2105 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz", 2106 | "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==", 2107 | "dev": true 2108 | }, 2109 | "send": { 2110 | "version": "0.16.2", 2111 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz", 2112 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", 2113 | "dev": true, 2114 | "requires": { 2115 | "debug": "2.6.9", 2116 | "depd": "1.1.2", 2117 | "destroy": "1.0.4", 2118 | "encodeurl": "1.0.2", 2119 | "escape-html": "1.0.3", 2120 | "etag": "1.8.1", 2121 | "fresh": "0.5.2", 2122 | "http-errors": "1.6.3", 2123 | "mime": "1.4.1", 2124 | "ms": "2.0.0", 2125 | "on-finished": "2.3.0", 2126 | "range-parser": "1.2.0", 2127 | "statuses": "1.4.0" 2128 | }, 2129 | "dependencies": { 2130 | "statuses": { 2131 | "version": "1.4.0", 2132 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 2133 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==", 2134 | "dev": true 2135 | } 2136 | } 2137 | }, 2138 | "serve-index": { 2139 | "version": "1.9.1", 2140 | "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz", 2141 | "integrity": "sha1-03aNabHn2C5c4FD/9bRTvqEqkjk=", 2142 | "dev": true, 2143 | "requires": { 2144 | "accepts": "1.3.5", 2145 | "batch": "0.6.1", 2146 | "debug": "2.6.9", 2147 | "escape-html": "1.0.3", 2148 | "http-errors": "1.6.3", 2149 | "mime-types": "2.1.19", 2150 | "parseurl": "1.3.2" 2151 | } 2152 | }, 2153 | "serve-static": { 2154 | "version": "1.13.2", 2155 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz", 2156 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", 2157 | "dev": true, 2158 | "requires": { 2159 | "encodeurl": "1.0.2", 2160 | "escape-html": "1.0.3", 2161 | "parseurl": "1.3.2", 2162 | "send": "0.16.2" 2163 | } 2164 | }, 2165 | "server-destroy": { 2166 | "version": "1.0.1", 2167 | "resolved": "https://registry.npmjs.org/server-destroy/-/server-destroy-1.0.1.tgz", 2168 | "integrity": "sha1-8Tv5KOQrnD55OD5hzDmYtdFObN0=", 2169 | "dev": true 2170 | }, 2171 | "set-blocking": { 2172 | "version": "2.0.0", 2173 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2174 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 2175 | "dev": true 2176 | }, 2177 | "set-immediate-shim": { 2178 | "version": "1.0.1", 2179 | "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", 2180 | "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", 2181 | "dev": true 2182 | }, 2183 | "setprototypeof": { 2184 | "version": "1.1.0", 2185 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 2186 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", 2187 | "dev": true 2188 | }, 2189 | "socket.io": { 2190 | "version": "2.1.1", 2191 | "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-2.1.1.tgz", 2192 | "integrity": "sha512-rORqq9c+7W0DAK3cleWNSyfv/qKXV99hV4tZe+gGLfBECw3XEhBy7x85F3wypA9688LKjtwO9pX9L33/xQI8yA==", 2193 | "dev": true, 2194 | "requires": { 2195 | "debug": "3.1.0", 2196 | "engine.io": "3.2.0", 2197 | "has-binary2": "1.0.3", 2198 | "socket.io-adapter": "1.1.1", 2199 | "socket.io-client": "2.1.1", 2200 | "socket.io-parser": "3.2.0" 2201 | }, 2202 | "dependencies": { 2203 | "debug": { 2204 | "version": "3.1.0", 2205 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2206 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2207 | "dev": true, 2208 | "requires": { 2209 | "ms": "2.0.0" 2210 | } 2211 | }, 2212 | "engine.io-client": { 2213 | "version": "3.2.1", 2214 | "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-3.2.1.tgz", 2215 | "integrity": "sha512-y5AbkytWeM4jQr7m/koQLc5AxpRKC1hEVUb/s1FUAWEJq5AzJJ4NLvzuKPuxtDi5Mq755WuDvZ6Iv2rXj4PTzw==", 2216 | "dev": true, 2217 | "requires": { 2218 | "component-emitter": "1.2.1", 2219 | "component-inherit": "0.0.3", 2220 | "debug": "3.1.0", 2221 | "engine.io-parser": "2.1.2", 2222 | "has-cors": "1.1.0", 2223 | "indexof": "0.0.1", 2224 | "parseqs": "0.0.5", 2225 | "parseuri": "0.0.5", 2226 | "ws": "3.3.3", 2227 | "xmlhttprequest-ssl": "1.5.5", 2228 | "yeast": "0.1.2" 2229 | } 2230 | }, 2231 | "isarray": { 2232 | "version": "2.0.1", 2233 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz", 2234 | "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4=", 2235 | "dev": true 2236 | }, 2237 | "socket.io-client": { 2238 | "version": "2.1.1", 2239 | "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-2.1.1.tgz", 2240 | "integrity": "sha512-jxnFyhAuFxYfjqIgduQlhzqTcOEQSn+OHKVfAxWaNWa7ecP7xSNk2Dx/3UEsDcY7NcFafxvNvKPmmO7HTwTxGQ==", 2241 | "dev": true, 2242 | "requires": { 2243 | "backo2": "1.0.2", 2244 | "base64-arraybuffer": "0.1.5", 2245 | "component-bind": "1.0.0", 2246 | "component-emitter": "1.2.1", 2247 | "debug": "3.1.0", 2248 | "engine.io-client": "3.2.1", 2249 | "has-binary2": "1.0.3", 2250 | "has-cors": "1.1.0", 2251 | "indexof": "0.0.1", 2252 | "object-component": "0.0.3", 2253 | "parseqs": "0.0.5", 2254 | "parseuri": "0.0.5", 2255 | "socket.io-parser": "3.2.0", 2256 | "to-array": "0.1.4" 2257 | } 2258 | }, 2259 | "socket.io-parser": { 2260 | "version": "3.2.0", 2261 | "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-3.2.0.tgz", 2262 | "integrity": "sha512-FYiBx7rc/KORMJlgsXysflWx/RIvtqZbyGLlHZvjfmPTPeuD/I8MaW7cfFrj5tRltICJdgwflhfZ3NVVbVLFQA==", 2263 | "dev": true, 2264 | "requires": { 2265 | "component-emitter": "1.2.1", 2266 | "debug": "3.1.0", 2267 | "isarray": "2.0.1" 2268 | } 2269 | } 2270 | } 2271 | }, 2272 | "socket.io-adapter": { 2273 | "version": "1.1.1", 2274 | "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-1.1.1.tgz", 2275 | "integrity": "sha1-KoBeihTWNyEk3ZFZrUUC+MsH8Gs=", 2276 | "dev": true 2277 | }, 2278 | "socket.io-client": { 2279 | "version": "2.0.4", 2280 | "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-2.0.4.tgz", 2281 | "integrity": "sha1-CRilUkBtxeVAs4Dc2Xr8SmQzL44=", 2282 | "dev": true, 2283 | "requires": { 2284 | "backo2": "1.0.2", 2285 | "base64-arraybuffer": "0.1.5", 2286 | "component-bind": "1.0.0", 2287 | "component-emitter": "1.2.1", 2288 | "debug": "2.6.9", 2289 | "engine.io-client": "3.1.6", 2290 | "has-cors": "1.1.0", 2291 | "indexof": "0.0.1", 2292 | "object-component": "0.0.3", 2293 | "parseqs": "0.0.5", 2294 | "parseuri": "0.0.5", 2295 | "socket.io-parser": "3.1.3", 2296 | "to-array": "0.1.4" 2297 | } 2298 | }, 2299 | "socket.io-parser": { 2300 | "version": "3.1.3", 2301 | "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-3.1.3.tgz", 2302 | "integrity": "sha512-g0a2HPqLguqAczs3dMECuA1RgoGFPyvDqcbaDEdCWY9g59kdUAz3YRmaJBNKXflrHNwB7Q12Gkf/0CZXfdHR7g==", 2303 | "dev": true, 2304 | "requires": { 2305 | "component-emitter": "1.2.1", 2306 | "debug": "3.1.0", 2307 | "has-binary2": "1.0.3", 2308 | "isarray": "2.0.1" 2309 | }, 2310 | "dependencies": { 2311 | "debug": { 2312 | "version": "3.1.0", 2313 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2314 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2315 | "dev": true, 2316 | "requires": { 2317 | "ms": "2.0.0" 2318 | } 2319 | }, 2320 | "isarray": { 2321 | "version": "2.0.1", 2322 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz", 2323 | "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4=", 2324 | "dev": true 2325 | } 2326 | } 2327 | }, 2328 | "spdx-correct": { 2329 | "version": "3.0.0", 2330 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.0.0.tgz", 2331 | "integrity": "sha512-N19o9z5cEyc8yQQPukRCZ9EUmb4HUpnrmaL/fxS2pBo2jbfcFRVuFZ/oFC+vZz0MNNk0h80iMn5/S6qGZOL5+g==", 2332 | "dev": true, 2333 | "requires": { 2334 | "spdx-expression-parse": "3.0.0", 2335 | "spdx-license-ids": "3.0.0" 2336 | } 2337 | }, 2338 | "spdx-exceptions": { 2339 | "version": "2.1.0", 2340 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.1.0.tgz", 2341 | "integrity": "sha512-4K1NsmrlCU1JJgUrtgEeTVyfx8VaYea9J9LvARxhbHtVtohPs/gFGG5yy49beySjlIMhhXZ4QqujIZEfS4l6Cg==", 2342 | "dev": true 2343 | }, 2344 | "spdx-expression-parse": { 2345 | "version": "3.0.0", 2346 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 2347 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 2348 | "dev": true, 2349 | "requires": { 2350 | "spdx-exceptions": "2.1.0", 2351 | "spdx-license-ids": "3.0.0" 2352 | } 2353 | }, 2354 | "spdx-license-ids": { 2355 | "version": "3.0.0", 2356 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.0.tgz", 2357 | "integrity": "sha512-2+EPwgbnmOIl8HjGBXXMd9NAu02vLjOO1nWw4kmeRDFyHn+M/ETfHxQUK0oXg8ctgVnl9t3rosNVsZ1jG61nDA==", 2358 | "dev": true 2359 | }, 2360 | "statuses": { 2361 | "version": "1.3.1", 2362 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 2363 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=", 2364 | "dev": true 2365 | }, 2366 | "stream-throttle": { 2367 | "version": "0.1.3", 2368 | "resolved": "https://registry.npmjs.org/stream-throttle/-/stream-throttle-0.1.3.tgz", 2369 | "integrity": "sha1-rdV8jXzHOoFjDTHNVdOWHPr7qcM=", 2370 | "dev": true, 2371 | "requires": { 2372 | "commander": "2.2.0", 2373 | "limiter": "1.1.3" 2374 | } 2375 | }, 2376 | "string-width": { 2377 | "version": "1.0.2", 2378 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 2379 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 2380 | "dev": true, 2381 | "requires": { 2382 | "code-point-at": "1.1.0", 2383 | "is-fullwidth-code-point": "1.0.0", 2384 | "strip-ansi": "3.0.1" 2385 | } 2386 | }, 2387 | "string_decoder": { 2388 | "version": "1.1.1", 2389 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2390 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2391 | "dev": true, 2392 | "requires": { 2393 | "safe-buffer": "5.1.2" 2394 | } 2395 | }, 2396 | "strip-ansi": { 2397 | "version": "3.0.1", 2398 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2399 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2400 | "dev": true, 2401 | "requires": { 2402 | "ansi-regex": "2.1.1" 2403 | } 2404 | }, 2405 | "strip-bom": { 2406 | "version": "2.0.0", 2407 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", 2408 | "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", 2409 | "dev": true, 2410 | "requires": { 2411 | "is-utf8": "0.2.1" 2412 | } 2413 | }, 2414 | "supports-color": { 2415 | "version": "2.0.0", 2416 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 2417 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 2418 | "dev": true 2419 | }, 2420 | "tfunk": { 2421 | "version": "3.1.0", 2422 | "resolved": "https://registry.npmjs.org/tfunk/-/tfunk-3.1.0.tgz", 2423 | "integrity": "sha1-OORBT8ZJd9h6/apy+sttKfgve1s=", 2424 | "dev": true, 2425 | "requires": { 2426 | "chalk": "1.1.3", 2427 | "object-path": "0.9.2" 2428 | } 2429 | }, 2430 | "to-array": { 2431 | "version": "0.1.4", 2432 | "resolved": "https://registry.npmjs.org/to-array/-/to-array-0.1.4.tgz", 2433 | "integrity": "sha1-F+bBH3PdTz10zaek/zI46a2b+JA=", 2434 | "dev": true 2435 | }, 2436 | "ua-parser-js": { 2437 | "version": "0.7.17", 2438 | "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.17.tgz", 2439 | "integrity": "sha512-uRdSdu1oA1rncCQL7sCj8vSyZkgtL7faaw9Tc9rZ3mGgraQ7+Pdx7w5mnOSF3gw9ZNG6oc+KXfkon3bKuROm0g==", 2440 | "dev": true 2441 | }, 2442 | "ultron": { 2443 | "version": "1.1.1", 2444 | "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.1.1.tgz", 2445 | "integrity": "sha512-UIEXBNeYmKptWH6z8ZnqTeS8fV74zG0/eRU9VGkpzz+LIJNs8W/zM/L+7ctCkRrgbNnnR0xxw4bKOr0cW0N0Og==", 2446 | "dev": true 2447 | }, 2448 | "universalify": { 2449 | "version": "0.1.2", 2450 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 2451 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 2452 | "dev": true 2453 | }, 2454 | "unpipe": { 2455 | "version": "1.0.0", 2456 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2457 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 2458 | "dev": true 2459 | }, 2460 | "util-deprecate": { 2461 | "version": "1.0.2", 2462 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2463 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2464 | "dev": true 2465 | }, 2466 | "utils-merge": { 2467 | "version": "1.0.1", 2468 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2469 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 2470 | "dev": true 2471 | }, 2472 | "validate-npm-package-license": { 2473 | "version": "3.0.4", 2474 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2475 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2476 | "dev": true, 2477 | "requires": { 2478 | "spdx-correct": "3.0.0", 2479 | "spdx-expression-parse": "3.0.0" 2480 | } 2481 | }, 2482 | "which-module": { 2483 | "version": "1.0.0", 2484 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-1.0.0.tgz", 2485 | "integrity": "sha1-u6Y8qGGUiZT/MHc2CJ47lgJsKk8=", 2486 | "dev": true 2487 | }, 2488 | "window-size": { 2489 | "version": "0.2.0", 2490 | "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.2.0.tgz", 2491 | "integrity": "sha1-tDFbtCFKPXBY6+7okuE/ok2YsHU=", 2492 | "dev": true 2493 | }, 2494 | "wrap-ansi": { 2495 | "version": "2.1.0", 2496 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", 2497 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", 2498 | "dev": true, 2499 | "requires": { 2500 | "string-width": "1.0.2", 2501 | "strip-ansi": "3.0.1" 2502 | } 2503 | }, 2504 | "ws": { 2505 | "version": "3.3.3", 2506 | "resolved": "https://registry.npmjs.org/ws/-/ws-3.3.3.tgz", 2507 | "integrity": "sha512-nnWLa/NwZSt4KQJu51MYlCcSQ5g7INpOrOMt4XV8j4dqTXdmlUmSHQ8/oLC069ckre0fRsgfvsKwbTdtKLCDkA==", 2508 | "dev": true, 2509 | "requires": { 2510 | "async-limiter": "1.0.0", 2511 | "safe-buffer": "5.1.2", 2512 | "ultron": "1.1.1" 2513 | } 2514 | }, 2515 | "xmlhttprequest-ssl": { 2516 | "version": "1.5.5", 2517 | "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.5.tgz", 2518 | "integrity": "sha1-wodrBhaKrcQOV9l+gRkayPQ5iz4=", 2519 | "dev": true 2520 | }, 2521 | "y18n": { 2522 | "version": "3.2.1", 2523 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", 2524 | "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=", 2525 | "dev": true 2526 | }, 2527 | "yargs": { 2528 | "version": "6.4.0", 2529 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-6.4.0.tgz", 2530 | "integrity": "sha1-gW4ahm1VmMzzTlWW3c4i2S2kkNQ=", 2531 | "dev": true, 2532 | "requires": { 2533 | "camelcase": "3.0.0", 2534 | "cliui": "3.2.0", 2535 | "decamelize": "1.2.0", 2536 | "get-caller-file": "1.0.3", 2537 | "os-locale": "1.4.0", 2538 | "read-pkg-up": "1.0.1", 2539 | "require-directory": "2.1.1", 2540 | "require-main-filename": "1.0.1", 2541 | "set-blocking": "2.0.0", 2542 | "string-width": "1.0.2", 2543 | "which-module": "1.0.0", 2544 | "window-size": "0.2.0", 2545 | "y18n": "3.2.1", 2546 | "yargs-parser": "4.2.1" 2547 | } 2548 | }, 2549 | "yargs-parser": { 2550 | "version": "4.2.1", 2551 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-4.2.1.tgz", 2552 | "integrity": "sha1-KczqwNxPA8bIe0qfIX3RjJ90hxw=", 2553 | "dev": true, 2554 | "requires": { 2555 | "camelcase": "3.0.0" 2556 | } 2557 | }, 2558 | "yeast": { 2559 | "version": "0.1.2", 2560 | "resolved": "https://registry.npmjs.org/yeast/-/yeast-0.1.2.tgz", 2561 | "integrity": "sha1-AI4G2AlDIMNy28L47XagymyKxBk=", 2562 | "dev": true 2563 | } 2564 | } 2565 | } 2566 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "homestaging-ai-web-xr", 3 | "version": "1.0.0", 4 | "description": "try it out via https://archilogic-com.github.io/web-xr-homestaging-ai/", 5 | "author": "frederic-schwarz", 6 | "license": "MIT", 7 | "devDependencies": { 8 | "lite-server": "^2.4.0" 9 | }, 10 | "scripts": { 11 | "dev": "node_modules/.bin/lite-server", 12 | "test": "echo \"Error: no test specified\" && exit 1" 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /src/css/style.css: -------------------------------------------------------------------------------- 1 | .controls { 2 | position: absolute; 3 | top: 10px; 4 | left: 10px; 5 | width: 100px; 6 | z-index: 1000; 7 | display: none; 8 | } 9 | button { 10 | display: inline-block; 11 | border: solid 2px #2de5b7; 12 | outline: none; 13 | background: rgba(255,255,255,0.2); 14 | color: #2de5b7; 15 | font-weight: bold; 16 | font-size: 16px; 17 | letter-spacing: 1px; 18 | margin: 0 0 6px 0; 19 | padding: 3px 10px; 20 | width: 90px; 21 | border-radius: 3px; 22 | cursor: pointer; 23 | } 24 | button:hover, button.active { 25 | background: #2de5b7; 26 | color: white; 27 | } 28 | .btn-tool { 29 | border: solid 2px #ff5630; 30 | color: #ff5630; 31 | } 32 | .btn-tool:hover, .btn-tool.active { 33 | background: #ff5630; 34 | color: white; 35 | } 36 | #furnish, .btn-style { 37 | border: solid 2px #4164f2; 38 | color: #4164f2; 39 | } 40 | #furnish:hover, #hover.active, .btn-style:hover, .btn-style.active { 41 | background: #4164f2; 42 | color: white; 43 | } 44 | #styles { 45 | display: none; 46 | } 47 | #svg-container { 48 | display: none; 49 | position: absolute; 50 | top: 0; 51 | left: 0; 52 | width: 100%; 53 | height: 100vh; 54 | z-index: 500; 55 | background: white; 56 | } -------------------------------------------------------------------------------- /src/js/app.js: -------------------------------------------------------------------------------- 1 | // set api keys 2 | io3d.config({ 3 | // home staging need api keys 4 | // get yours from https://3d.io 5 | publishableApiKey: 'acb76899-5870-481f-ad52-856fc4d08103' 6 | }) 7 | 8 | // UI elements 9 | var toolButtons = document.querySelectorAll('.btn-tool') 10 | var styleButtons = document.querySelectorAll('.btn-style') 11 | var btnFurnishEl = document.querySelector('#furnish'); 12 | var btnBuildEl = document.querySelector('#build'); 13 | var btnFloorPlanEl = document.querySelector('#floorplan'); 14 | var btnRestartEl = document.querySelector('#restart'); 15 | var controlsEl = document.querySelector('.controls'); 16 | var toolsEl = document.querySelector('#tools'); 17 | var stylesEl = document.querySelector('#styles'); 18 | 19 | // aframe elements 20 | var rayCasterEl = document.querySelector('#raycaster'); 21 | var arRaycasterEl = document.querySelector('#ar-raycaster'); 22 | var planeEl = document.querySelector('a-plane'); 23 | var furnishingEl = document.querySelector('#furnishings'); 24 | var structureEl = document.querySelector('#structure'); 25 | var drawingEl = document.querySelector('#drawing'); 26 | var cursor3dEl = document.querySelector('#cursor-3d'); 27 | var canvasEl 28 | 29 | // inital settings 30 | var isMobile = AFRAME.utils.device.isMobile() 31 | if (isMobile) { 32 | rayCasterEl.setAttribute('cursor', {rayOrigin: 'entity', fuse: false}) 33 | // rayCasterEl.setAttribute('geometry', {primitive: 'sphere', radius: 0.01}) 34 | // add shadow material to plane 35 | planeEl.setAttribute('shadow-material', true) 36 | // wait for aframe to load to get the canvas 37 | document.querySelector('a-scene').addEventListener('loaded', initTracking) 38 | } else { 39 | document.querySelector('a-scene').addEventListener('loaded', function() { 40 | io3d.utils.ui.message('click on the floor to draw a wall') 41 | initDrawing() 42 | switchMode({srcElement: document.querySelector('#wall')}) 43 | }) 44 | } 45 | 46 | // internals 47 | var points = [] 48 | var drawMode = null 49 | var sceneStructure 50 | var addedItems = [] 51 | var initMsg 52 | 53 | // bind events 54 | toolButtons.forEach(btn => { 55 | btn.addEventListener('click', switchMode) 56 | }) 57 | styleButtons.forEach(btn => { 58 | btn.addEventListener('click', changeStyle) 59 | }) 60 | rayCasterEl.addEventListener('click', addPoint) 61 | btnFurnishEl.addEventListener('click', getFurnishing) 62 | btnBuildEl.addEventListener('click', buildStructure) 63 | btnFloorPlanEl.addEventListener('click', getFloorPlan) 64 | btnRestartEl.addEventListener('click', restart) 65 | 66 | // workaround to get the initial plane position 67 | function initTracking() { 68 | initMsg = io3d.utils.ui.message('tap on a floor to initialize') 69 | canvasEl = document.querySelector('canvas'); 70 | canvasEl.addEventListener('touchstart', hitTest, false); 71 | } 72 | 73 | function initDrawing() { 74 | rayCasterEl.setAttribute('visible', true) 75 | controlsEl.style.display = 'block' 76 | } 77 | 78 | function addPoint(e) { 79 | // get data from 3d cursor 80 | const hitWall = cursor3dEl.components['cursor-3d'].hitWall 81 | const position = cursor3dEl.getAttribute('position') //components['cursor-3d'].position 82 | if (drawMode === 'wall' || drawMode === 'window' || drawMode === 'door') points.push(position) 83 | // position.y += 0.025 84 | if (drawMode === 'wall' && points.length >= 2) { 85 | var i = points.length - 1 86 | // add a wall 87 | addLine({start: points[i - 1], end: points[i], color: '#222'}) 88 | if (hitWall) points = [] 89 | } else if (hitWall && drawMode && points.length === 2) { 90 | let i = points.length - 1 91 | let color = drawMode === 'window' ? '#ddd' : '#f0f0f0' 92 | let type = drawMode === 'window' ? 'window' : 'door' 93 | let pW = hitWall.getAttribute('position') 94 | // verify that points are in the correct order 95 | let flipPoints = distance(points[i - 1], pW) < distance(points[1], pW) 96 | let p1 = {x: distance(points[i - 1], pW), y:0.01, z:0} 97 | let p2 = {x: distance(points[1], pW), y:0.01, z:0} 98 | let start = flipPoints ? p1 : p2 99 | let end = flipPoints ? p2 : p1 100 | // add a window or door to the corresponding wall 101 | addLine({start, end, color, type, parent: hitWall}) 102 | points = [] 103 | } 104 | } 105 | 106 | function addLine(args) { 107 | var 108 | start = args.start, 109 | end = args.end, 110 | type = args.type, 111 | color = args.color || 'white', 112 | parent = args.parent || drawingEl, 113 | box = document.createElement('a-entity'), 114 | l = distance(start, end), 115 | angle = pointAngle(start, end), 116 | w = 0.1, 117 | h = 0.005 118 | 119 | box.setAttribute('position', AFRAME.utils.coordinates.stringify(start)) 120 | box.setAttribute('rotation', `0 ${angle} 0`) 121 | box.setAttribute('line-element', { 122 | type: type, 123 | l, 124 | w, 125 | h, 126 | color: color 127 | }) 128 | box.setAttribute('class', 'collidable') 129 | parent.appendChild(box) 130 | } 131 | 132 | function getFurnishing() { 133 | 134 | // convert drawn aframe elements into scene structure 135 | getSceneStructure() 136 | // send sceneStructure to home staging ai 137 | // optional set space label: io3d.staging.getFurnishings(result, {label: bedroom}) 138 | .then(result => { 139 | var messages = [ 140 | 'looking for furniture in the apartment', 141 | 'buying furniture from nearby store', 142 | 'calling an interior designer', 143 | 'there is a chair, there is a sofa ... ', 144 | 'You said you want furniture?', 145 | 'How about something that goes really well with the floor?' 146 | ] 147 | var space = result.find(el => el.type === 'polyfloor') 148 | var area = space && getPolygonArea(space.polygon) 149 | var label = 'dining_living' 150 | if (area && area < 15) { 151 | io3d.utils.ui.message('That is a tiny tiny room') 152 | label = 'dining' 153 | } 154 | io3d.utils.ui.message(messages[Math.floor(Math.random() * messages.length)]) 155 | console.log(area, label) 156 | return io3d.staging.getFurnishings(result, {spaceId: space.id, label: label}) 157 | }) 158 | // update sceneStructure for later use 159 | .then(result => { 160 | // let's hide the drawing on mobile 161 | if (isMobile) drawingEl.setAttribute('visible', false) 162 | cursor3dEl.setAttribute('visible', false) 163 | toolsEl.style.display = 'none' 164 | stylesEl.style.display = 'block' 165 | rayCasterEl.removeEventListener('click', addPoint) 166 | sceneStructure = result 167 | return result 168 | }) 169 | .then(placeFurniture) 170 | .catch(err => { 171 | io3d.utils.ui.message.error('nothing found - room too small?') 172 | console.log(err) 173 | }) 174 | } 175 | 176 | function changeStyle(e) { 177 | var style = e.srcElement.id 178 | if (!sceneStructure) return 179 | io3d.staging.replaceFurniture(sceneStructure, {query: style}) 180 | .then(placeFurniture) 181 | .catch(err => { 182 | console.log(err) 183 | }) 184 | } 185 | 186 | function placeFurniture(input) { 187 | // convert sceneStructure to aframe Html so we can place it in the scene 188 | var elements = io3d.scene.getAframeElementsFromSceneStructure(input) 189 | // check for previously added elements and remove them 190 | addedItems.forEach(el => { 191 | el.parentNode.removeChild(el) 192 | }) 193 | // add elements to the scene 194 | elements.forEach(el => { 195 | furnishingEl.appendChild(el) 196 | }) 197 | // store added elements for later removal 198 | addedItems = elements 199 | } 200 | 201 | function getSceneStructure() { 202 | console.log('getting sceneStructure') 203 | let _sceneStructure = [] 204 | const elements = document.querySelectorAll('a-entity[line-element]') 205 | elements.forEach(el => { 206 | let data = getElement3d(el) 207 | if (data.type === 'wall') { 208 | data.children = [] 209 | const children = el.childNodes 210 | children.forEach(c => { 211 | data.children.push(getElement3d(c)) 212 | }) 213 | _sceneStructure.push(data) 214 | } 215 | }) 216 | // snap walls 217 | _sceneStructure = io3d.scene.snapWalls(_sceneStructure) 218 | _sceneStructure = JSON.parse(JSON.stringify(_sceneStructure)) 219 | // FIXME: workaround for offline support 220 | // return Promise.resolve(sceneStructure) 221 | // get polygonal floor 222 | return io3d.utils.services.call('Recognizer.recognizeFloors', { 223 | walls: _sceneStructure.filter(el3d => el3d.type === 'wall') 224 | }) 225 | .then(floors => { 226 | if (floors.length === 0 ) { 227 | io3d.utils.ui.message.error('walls are not closed - try again', { expire: 2000 }) 228 | } 229 | return Promise.resolve(_sceneStructure.concat(floors)) 230 | }) 231 | // normalize scene structure ( add default values and uuids ) 232 | .then(io3d.scene.normalizeSceneStructure) 233 | } 234 | 235 | function buildStructure() { 236 | const visible = structureEl.getAttribute('visible') 237 | if (visible) { 238 | planeEl.setAttribute('visible', true) 239 | structureEl.setAttribute('visible', false) 240 | return 241 | } else { 242 | structureEl.setAttribute('visible', true) 243 | planeEl.setAttribute('visible', false) 244 | } 245 | while (structureEl.firstChild) { 246 | structureEl.removeChild(structureEl.firstChild) 247 | } 248 | getSceneStructure() 249 | .then(result => { 250 | const elements = io3d.scene.getAframeElementsFromSceneStructure(result) 251 | elements.forEach(el => { 252 | structureEl.appendChild(el) 253 | }) 254 | }) 255 | .catch(console.error) 256 | } 257 | 258 | function getFloorPlan() { 259 | console.log('get floorplan') 260 | const svgEl = document.querySelector('#svg-container') 261 | if (svgEl.style.display === 'block') { 262 | svgEl.style.display = 'none' 263 | svgEl.innerHTML = '' 264 | toolsEl.style.display = 'block' 265 | btnFurnishEl.style.display = 'block' 266 | btnBuildEl.style.display = 'block' 267 | return 268 | } 269 | getSceneStructure() 270 | .then(result => { 271 | var space = result.find(el => el.type === 'polyfloor') 272 | if (!space) { 273 | io3d.utils.ui.message.error('try to close the room first') 274 | return 275 | } 276 | toolsEl.style.display = 'none' 277 | btnFurnishEl.style.display = 'none' 278 | btnBuildEl.style.display = 'none' 279 | 280 | var message = { 281 | method: 'Scene.exportSvg', 282 | params: { sceneStructure: result, options: {style: 'lines'} }, 283 | jsonrpc: '2.0', 284 | id: Math.round(Math.random()*1e20) 285 | } 286 | 287 | return fetch('https://tasks.3d.io/', { 288 | method: 'POST', body: JSON.stringify( message ) 289 | }).then(function(response){ 290 | return response.json() 291 | }).then(function(body){ 292 | return body.result 293 | }).catch(console.error) 294 | }) 295 | .then(result => { 296 | const svgStr = result.content 297 | svgEl.style.display = 'block' 298 | svgEl.innerHTML = svgStr 299 | }) 300 | .catch(console.error) 301 | } 302 | 303 | function switchMode(e) { 304 | var el = e.srcElement 305 | points = [] 306 | if (el.id === drawMode) { 307 | drawMode = null 308 | el.classList.remove('active') 309 | } else { 310 | drawMode = el.id 311 | el.classList.add('active') 312 | toolButtons.forEach(btn => { 313 | if (btn.id !== el.id) btn.classList.remove('active') 314 | }) 315 | } 316 | console.log(el.id, drawMode) 317 | } 318 | 319 | function hitTest(e) { 320 | console.log('click') 321 | if (!e.touches[0]) { 322 | return; 323 | } 324 | var x = e.touches[0].pageX / window.innerWidth; 325 | var y = e.touches[0].pageY / window.innerHeight; 326 | console.log(x, y) 327 | var arRaycaster = arRaycasterEl.components['ar-raycaster']; 328 | var hits = arRaycaster.hitAR(x, y); 329 | if (hits && hits.length) getPosFromHit(hits); 330 | else io3d.utils.ui.message.error('try again - ideally standing', { expire: 2000 }) 331 | } 332 | 333 | function getPosFromHit(hits) { 334 | // lets choose the last one which is most likely the floor 335 | console.log(hits.length, 'hits') 336 | var hit = hits[hits.length - 1] 337 | if (!hit || !hit.point) { 338 | throw new Error('placeObjectAtHit requires a VRHit object'); 339 | } 340 | planeEl.setAttribute('position', AFRAME.utils.coordinates.stringify(hit.point)) 341 | furnishingEl.setAttribute('position', `0 ${hit.point.y} 0`) 342 | structureEl.setAttribute('position', `0 ${hit.point.y} 0`) 343 | canvasEl.removeEventListener('touchstart', hitTest, false); 344 | initMsg.close() 345 | io3d.utils.ui.message.success('floor detected - start', { expire: 1000 }) 346 | 347 | // show drawing menu and cursor 348 | setTimeout(function() { 349 | initDrawing() 350 | }, 1000) 351 | } 352 | 353 | function restart() { 354 | drawingEl.setAttribute('visible', true) 355 | cursor3dEl.setAttribute('visible', true) 356 | toolsEl.style.display = 'block' 357 | stylesEl.style.display = 'none' 358 | rayCasterEl.addEventListener('click', addPoint) 359 | const svgEl = document.querySelector('#svg-container') 360 | sceneStructure = null 361 | addedItems.forEach(el => { 362 | if (el.parentNode) el.parentNode.removeChild(el) 363 | }) 364 | addedItems = [] 365 | const elements = document.querySelectorAll('a-entity[line-element]') 366 | const walls = document.querySelectorAll('[io3d-wall]') 367 | const floors = document.querySelectorAll('[io3d-polyfloor]') 368 | elements.forEach(el => { 369 | if (el.parentNode) el.parentNode.removeChild(el) 370 | }) 371 | walls.forEach(el => { 372 | if (el.parentNode) el.parentNode.removeChild(el) 373 | }) 374 | floors.forEach(el => { 375 | if (el.parentNode) el.parentNode.removeChild(el) 376 | }) 377 | svgEl.style.display = 'none' 378 | } 379 | 380 | // helper functions 381 | 382 | function pointAngle(u, v) { 383 | if (!u) u = {x: 0, z:0} 384 | return round((Math.atan2(-v.z + u.z, v.x - u.x)) * 180 / Math.PI); 385 | } 386 | 387 | function distance(a, b) { 388 | var dist = Math.sqrt(Math.pow((b.x-a.x),2) + Math.pow((b.y-a.y),2) + Math.pow((b.z-a.z),2)) 389 | return dist 390 | } 391 | 392 | function round(a, factor) { 393 | if (!factor) factor = 1e2 394 | return Math.round(a * factor) / factor 395 | } -------------------------------------------------------------------------------- /src/js/cursor-3d.js: -------------------------------------------------------------------------------- 1 | AFRAME.registerComponent('cursor-3d', { 2 | init: function () { 3 | var rayCasterEl = document.querySelector('#raycaster'); 4 | rayCasterEl.addEventListener('raycaster-intersection', getPos) 5 | this.walls = document.querySelectorAll('a-entity[line-element]') 6 | this.wallData = [] 7 | var self = this 8 | function getPos(e) { 9 | self.position = e.detail.intersections && e.detail.intersections[0].point 10 | } 11 | }, 12 | tick: function (time, timeDiff) { 13 | const snapDistance = 0.3 14 | 15 | // query drawn elements in scene 16 | let _walls = document.querySelectorAll('a-entity[line-element]') 17 | if (_walls.length && _walls.length !== this.walls.length) { 18 | this.wallData = [] 19 | _walls.forEach(wall => { 20 | let el3d = getElement3d(wall, true) 21 | if (el3d.type === 'wall') this.wallData.push({el3d, wall}) 22 | }) 23 | } 24 | // compute intersections 25 | this.wallData.forEach((data, i) => { 26 | if (drawMode !== 'wall') intPoint = pointOnWall(this.position, data.el3d) 27 | else intPoint = pointOnWall(this.position, data.el3d, 'snapToPoint') 28 | this.wallData[i].intPoint = intPoint 29 | }) 30 | 31 | // get closest intersection 32 | this.wallData.sort((a, b) => { 33 | let distA = distance(this.position, a.intPoint) 34 | let distB = distance(this.position, b.intPoint) 35 | return distA < distB ? -1 : 1 36 | }) 37 | 38 | // original position is set by raycaster 39 | // position is changed here if snapping is needed 40 | if (drawMode !== 'wall' && this.wallData.length) { 41 | // doors and windows always snap to walls 42 | this.position.x = this.wallData[0].intPoint.x 43 | this.position.z = this.wallData[0].intPoint.z 44 | this.hitWall = this.wallData[0].wall 45 | } else if (drawMode === 'wall' && this.wallData.length) { 46 | // check if were close to another wall end 47 | let doSnap = distance(this.position, this.wallData[0].intPoint) < snapDistance 48 | if (doSnap) { 49 | this.position.x = this.wallData[0].intPoint.x 50 | this.position.z = this.wallData[0].intPoint.z 51 | this.hitWall = this.wallData[0].wall 52 | } else this.hitWall = null 53 | } else this.hitWall = null 54 | 55 | this.el.setAttribute('position', this.position) 56 | } 57 | }); -------------------------------------------------------------------------------- /src/js/line-element.js: -------------------------------------------------------------------------------- 1 | AFRAME.registerComponent('line-element', { 2 | schema: { 3 | l: {type: 'number', default: 1}, 4 | h: {type: 'number', default: 1}, 5 | w: {type: 'number', default: 1}, 6 | color: {type: 'color', default: '#AAA'}, 7 | type: {type: 'string', default: 'wall'} 8 | }, 9 | init: function () { 10 | var data = this.data; 11 | var el = this.el; 12 | this.geometry = new THREE.BoxBufferGeometry(data.l, data.h, data.w); 13 | this.material = new THREE.MeshBasicMaterial({color: data.color}); 14 | this.mesh = new THREE.Mesh(this.geometry, this.material); 15 | var direction = new THREE.Vector3(data.l / 2, 0, 0); 16 | this.mesh.position.add(direction); // add to position 17 | el.setObject3D('mesh', this.mesh); 18 | }, 19 | /** 20 | * Update the mesh in response to property updates. 21 | */ 22 | update: function (oldData) { 23 | var data = this.data; 24 | var el = this.el; 25 | // If `oldData` is empty, then this means we're in the initialization process. 26 | // No need to update. 27 | if (Object.keys(oldData).length === 0) { return; } 28 | // Geometry-related properties changed. Update the geometry. 29 | if (data.l !== oldData.l || 30 | data.h !== oldData.h || 31 | data.w !== oldData.w) { 32 | el.getObject3D('mesh').geometry = new THREE.BoxBufferGeometry(data.l, data.h, data.w); 33 | } 34 | // Material-related properties changed. Update the material. 35 | if (data.color !== oldData.color) { 36 | el.getObject3D('mesh').material.color = data.color; 37 | } 38 | } 39 | }); -------------------------------------------------------------------------------- /src/js/utils.js: -------------------------------------------------------------------------------- 1 | function getElement3d (el, center) { 2 | let data = el.getAttribute('line-element') 3 | delete data.color 4 | let pos = el.getAttribute('position') 5 | let rot = el.getAttribute('rotation') 6 | data.x = round(pos.x) 7 | data.y = round(pos.y) 8 | data.z = round(pos.z) 9 | data.ry = round(rot.y) 10 | // clean up data 11 | if (data.type === 'wall') { 12 | var w = { 13 | x: -data.w * Math.cos(data.ry * Math.PI / 180 + Math.PI / 2), 14 | z: data.w * Math.sin(data.ry * Math.PI / 180 + Math.PI / 2) 15 | } 16 | if (!center) { 17 | data.x -= w.x / 2 18 | data.z -= w.z / 2 19 | } 20 | data.h = 2.4 21 | data.y = 0 22 | } else if (data.type === 'door') { 23 | data.h = 2 24 | data.y = 0 25 | } else if (data.type === 'window') { 26 | data.h = 1.2 27 | data.y = 0.8 28 | } 29 | return data 30 | } 31 | 32 | // get wall points + vectors 33 | function getWallData (wall) { 34 | var 35 | wallAngle = wall.ry / 180 * Math.PI, 36 | // width vector 37 | w = { 38 | x: -wall.w * Math.cos(wallAngle + Math.PI / 2), 39 | z: wall.w * Math.sin(wallAngle + Math.PI / 2) 40 | }, 41 | // Base Line Points 42 | p1 = { 43 | x: wall.x, 44 | z: wall.z 45 | }, 46 | p2 = { 47 | x: wall.x + wall.l * Math.cos(wallAngle), 48 | z: wall.z - wall.l * Math.sin(wallAngle) 49 | } 50 | return {wallAngle: wallAngle, p1: p1, p2: p2, w: w} 51 | } 52 | 53 | function pointOnWall (p, wall, snapToPoint) { 54 | const data = getWallData(wall) 55 | // get intersection point 56 | const _p = intersection(p, {x: p.x + data.w.x, z: p.z + data.w.z}, data.p1, data.p2) 57 | // see if intersection is on the wall 58 | const d1 = distance(_p, data.p1) 59 | const d2 = distance(_p, data.p2) 60 | const dl = distance(data.p1, data.p2) 61 | // return closest wall point if asked for 62 | if (snapToPoint) { 63 | return (d1 > d2) ? data.p2 : data.p1 64 | } 65 | else if (d1 > dl) return data.p2 66 | else if (d2 > dl) return data.p1 67 | else return _p 68 | } 69 | 70 | function getPolygonArea(polygon) { 71 | var numPoints = polygon.length 72 | var area = 0 // Accumulates area in the loop 73 | var j = numPoints - 1 // The last vertex is the 'previous' one to the first 74 | for (var i = 0; i < numPoints; i++) { 75 | area = area + (polygon[ j ][ 0 ] + polygon[ i ][ 0 ]) * (polygon[ j ][ 1 ] - polygon[ i ][ 1 ]) 76 | j = i //j is previous vertex to i 77 | } 78 | area = Math.round(Math.abs(area / 2)*100)/100 79 | return area 80 | } 81 | 82 | // intersections line p and q 83 | function intersection (p1, p2, q1, q2) { 84 | return { 85 | x: ((q2.x - q1.x) * (p2.x * p1.z - p1.x * p2.z) - (p2.x - p1.x) * (q2.x * q1.z - q1.x * q2.z)) / ((q2.z - q1.z) * (p2.x - p1.x) - (p2.z - p1.z) * (q2.x - q1.x)), 86 | z: ((p1.z - p2.z) * (q2.x * q1.z - q1.x * q2.z) - (q1.z - q2.z) * (p2.x * p1.z - p1.x * p2.z)) / ((q2.z - q1.z) * (p2.x - p1.x) - (p2.z - p1.z) * (q2.x - q1.x)), 87 | } 88 | } 89 | 90 | // distance between points 91 | function distance (p, q) { 92 | return Math.sqrt(Math.pow((p.x - q.x), 2) + Math.pow((p.z - q.z), 2)) 93 | } 94 | 95 | function rnd (a) { 96 | return Math.round(a * 100) / 100 97 | } --------------------------------------------------------------------------------