├── .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 | 
8 |
9 | and then furnish it automatically.
10 |
11 | 
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 | }
--------------------------------------------------------------------------------