hart-estate-widget 0.0.66 → 0.0.69

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/README.md +3 -0
  2. package/build/assets/css/index.css +2 -0
  3. package/build/assets/img/floor-dark.jpg +0 -0
  4. package/build/assets/img/floor-white.jpg +0 -0
  5. package/build/assets/img/grass.jpg +0 -0
  6. package/build/bundle.js +2 -0
  7. package/build/components/Application.js +2 -135
  8. package/build/components/Buttons/FullScreenButton.js +2 -50
  9. package/build/components/Buttons/TabButton.js +2 -24
  10. package/build/components/Instructions.js +2 -54
  11. package/build/components/Loader.js +2 -22
  12. package/build/components/ModelTab.js +2 -213
  13. package/build/components/PanoramaTab.js +2 -620
  14. package/build/components/RotationTab/DefaultView.js +2 -124
  15. package/build/components/RotationTab/ThreesixtyView.js +2 -45
  16. package/build/components/RotationTab/index.js +2 -194
  17. package/build/components/Widget.js +2 -110
  18. package/build/config/defaultConfig.js +2 -32
  19. package/build/enums/deviceOrientationStatuses.js +2 -11
  20. package/build/enums/deviceWidth.js +2 -21
  21. package/build/enums/imageExtentions.js +2 -16
  22. package/build/enums/rotationModes.js +2 -11
  23. package/build/index.css +1 -1
  24. package/build/index.js +2 -75
  25. package/build/locale/index.js +2 -71
  26. package/build/store/apiStore.js +2 -231
  27. package/build/store/deviceStore.js +2 -60
  28. package/build/store/fullScreenStore.js +2 -159
  29. package/build/store/houseStore.js +2 -952
  30. package/build/store/index.js +2 -124
  31. package/build/store/modelStore.js +2 -338
  32. package/build/threesixty/events.js +2 -220
  33. package/build/threesixty/index.js +2 -264
  34. package/build/utils/csg/csg-lib.js +2 -472
  35. package/build/utils/csg/csg-worker.js +2 -84
  36. package/build/utils/csg/three-csg.js +2 -277
  37. package/build/utils/helpers.js +2 -12
  38. package/build/utils/modelHelpers.js +2 -161
  39. package/build/utils/panoramaHelpers.js +2 -117
  40. package/package.json +17 -5
  41. package/build/assets/css/app.css +0 -1
  42. package/build/assets/css/app.css.map +0 -1
  43. package/build/assets/img/floor-dark.png +0 -0
  44. package/build/assets/img/floor-white.png +0 -0
  45. package/build/assets/img/grass.png +0 -0
@@ -1,472 +1,2 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.Vertex = exports.Vector = exports.Polygon = exports.Plane = exports.CSG = void 0;
7
-
8
- var _react = _interopRequireDefault(require("react"));
9
-
10
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
-
12
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
13
-
14
- function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
15
-
16
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
17
-
18
- var CSG = /*#__PURE__*/function () {
19
- function CSG() {
20
- _classCallCheck(this, CSG);
21
-
22
- this.polygons = [];
23
- }
24
-
25
- _createClass(CSG, [{
26
- key: "clone",
27
- value: function clone() {
28
- var csg = new CSG();
29
- csg.polygons = this.polygons.map(function (p) {
30
- return p.clone();
31
- });
32
- return csg;
33
- }
34
- }, {
35
- key: "toPolygons",
36
- value: function toPolygons() {
37
- return this.polygons;
38
- }
39
- }, {
40
- key: "union",
41
- value: function union(csg) {
42
- var a = new Node(this.clone().polygons);
43
- var b = new Node(csg.clone().polygons);
44
- a.clipTo(b);
45
- b.clipTo(a);
46
- b.invert();
47
- b.clipTo(a);
48
- b.invert();
49
- a.build(b.allPolygons());
50
- return CSG.fromPolygons(a.allPolygons());
51
- }
52
- }, {
53
- key: "subtract",
54
- value: function subtract(csg) {
55
- var a = new Node(this.clone().polygons);
56
- var b = new Node(csg.clone().polygons);
57
- a.invert();
58
- a.clipTo(b);
59
- b.clipTo(a);
60
- b.invert();
61
- b.clipTo(a);
62
- b.invert();
63
- a.build(b.allPolygons());
64
- a.invert();
65
- return CSG.fromPolygons(a.allPolygons());
66
- }
67
- }, {
68
- key: "intersect",
69
- value: function intersect(csg) {
70
- var a = new Node(this.clone().polygons);
71
- var b = new Node(csg.clone().polygons);
72
- a.invert();
73
- b.clipTo(a);
74
- b.invert();
75
- a.clipTo(b);
76
- b.clipTo(a);
77
- a.build(b.allPolygons());
78
- a.invert();
79
- return CSG.fromPolygons(a.allPolygons());
80
- } // Return a new CSG solid with solid and empty space switched. This solid is
81
- // not modified.
82
-
83
- }, {
84
- key: "inverse",
85
- value: function inverse() {
86
- var csg = this.clone();
87
- csg.polygons.forEach(function (p) {
88
- return p.flip();
89
- });
90
- return csg;
91
- }
92
- }]);
93
-
94
- return CSG;
95
- }();
96
-
97
- exports.CSG = CSG;
98
-
99
- CSG.fromPolygons = function (polygons) {
100
- var csg = new CSG();
101
- csg.polygons = polygons;
102
- return csg;
103
- };
104
-
105
- var Vector = /*#__PURE__*/function () {
106
- function Vector() {
107
- var x = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
108
- var y = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
109
- var z = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
110
-
111
- _classCallCheck(this, Vector);
112
-
113
- this.x = x;
114
- this.y = y;
115
- this.z = z;
116
- }
117
-
118
- _createClass(Vector, [{
119
- key: "copy",
120
- value: function copy(v) {
121
- this.x = v.x;
122
- this.y = v.y;
123
- this.z = v.z;
124
- return this;
125
- }
126
- }, {
127
- key: "clone",
128
- value: function clone() {
129
- return new Vector(this.x, this.y, this.z);
130
- }
131
- }, {
132
- key: "negate",
133
- value: function negate() {
134
- this.x *= -1;
135
- this.y *= -1;
136
- this.z *= -1;
137
- return this;
138
- }
139
- }, {
140
- key: "add",
141
- value: function add(a) {
142
- this.x += a.x;
143
- this.y += a.y;
144
- this.z += a.z;
145
- return this;
146
- }
147
- }, {
148
- key: "sub",
149
- value: function sub(a) {
150
- this.x -= a.x;
151
- this.y -= a.y;
152
- this.z -= a.z;
153
- return this;
154
- }
155
- }, {
156
- key: "times",
157
- value: function times(a) {
158
- this.x *= a;
159
- this.y *= a;
160
- this.z *= a;
161
- return this;
162
- }
163
- }, {
164
- key: "dividedBy",
165
- value: function dividedBy(a) {
166
- this.x /= a;
167
- this.y /= a;
168
- this.z /= a;
169
- return this;
170
- }
171
- }, {
172
- key: "lerp",
173
- value: function lerp(a, t) {
174
- return this.add(tv0.copy(a).sub(this).times(t));
175
- }
176
- }, {
177
- key: "unit",
178
- value: function unit() {
179
- return this.dividedBy(this.length());
180
- }
181
- }, {
182
- key: "length",
183
- value: function length() {
184
- return Math.sqrt(Math.pow(this.x, 2) + Math.pow(this.y, 2) + Math.pow(this.z, 2));
185
- }
186
- }, {
187
- key: "normalize",
188
- value: function normalize() {
189
- return this.unit();
190
- }
191
- }, {
192
- key: "cross",
193
- value: function cross(b) {
194
- var a = this;
195
- var ax = a.x,
196
- ay = a.y,
197
- az = a.z;
198
- var bx = b.x,
199
- by = b.y,
200
- bz = b.z;
201
- this.x = ay * bz - az * by;
202
- this.y = az * bx - ax * bz;
203
- this.z = ax * by - ay * bx;
204
- return this;
205
- }
206
- }, {
207
- key: "dot",
208
- value: function dot(b) {
209
- return this.x * b.x + this.y * b.y + this.z * b.z;
210
- }
211
- }]);
212
-
213
- return Vector;
214
- }();
215
-
216
- exports.Vector = Vector;
217
- var tv0 = new Vector();
218
- var tv1 = new Vector();
219
-
220
- var Vertex = /*#__PURE__*/function () {
221
- function Vertex(pos, normal, uv, color) {
222
- _classCallCheck(this, Vertex);
223
-
224
- this.pos = new Vector().copy(pos);
225
- this.normal = new Vector().copy(normal);
226
- uv && (this.uv = new Vector().copy(uv)) && (this.uv.z = 0);
227
- color && (this.color = new Vector().copy(color));
228
- }
229
-
230
- _createClass(Vertex, [{
231
- key: "clone",
232
- value: function clone() {
233
- return new Vertex(this.pos, this.normal, this.uv, this.color);
234
- }
235
- }, {
236
- key: "flip",
237
- value: function flip() {
238
- this.normal.negate();
239
- }
240
- }, {
241
- key: "interpolate",
242
- value: function interpolate(other, t) {
243
- return new Vertex(this.pos.clone().lerp(other.pos, t), this.normal.clone().lerp(other.normal, t), this.uv && other.uv && this.uv.clone().lerp(other.uv, t), this.color && other.color && this.color.clone().lerp(other.color, t));
244
- }
245
- }]);
246
-
247
- return Vertex;
248
- }();
249
-
250
- exports.Vertex = Vertex;
251
-
252
- var Plane = /*#__PURE__*/function () {
253
- function Plane(normal, w) {
254
- _classCallCheck(this, Plane);
255
-
256
- this.normal = normal;
257
- this.w = w;
258
- }
259
-
260
- _createClass(Plane, [{
261
- key: "clone",
262
- value: function clone() {
263
- return new Plane(this.normal.clone(), this.w);
264
- }
265
- }, {
266
- key: "flip",
267
- value: function flip() {
268
- this.normal.negate();
269
- this.w = -this.w;
270
- }
271
- }, {
272
- key: "splitPolygon",
273
- value: function splitPolygon(polygon, coplanarFront, coplanarBack, front, back) {
274
- var COPLANAR = 0;
275
- var FRONT = 1;
276
- var BACK = 2;
277
- var SPANNING = 3;
278
- var polygonType = 0;
279
- var types = [];
280
-
281
- for (var i = 0; i < polygon.vertices.length; i++) {
282
- var t = this.normal.dot(polygon.vertices[i].pos) - this.w;
283
- var type = t < -Plane.EPSILON ? BACK : t > Plane.EPSILON ? FRONT : COPLANAR;
284
- polygonType |= type;
285
- types.push(type);
286
- }
287
-
288
- switch (polygonType) {
289
- case COPLANAR:
290
- (this.normal.dot(polygon.plane.normal) > 0 ? coplanarFront : coplanarBack).push(polygon);
291
- break;
292
-
293
- case FRONT:
294
- front.push(polygon);
295
- break;
296
-
297
- case BACK:
298
- back.push(polygon);
299
- break;
300
-
301
- case SPANNING:
302
- var f = [];
303
- var b = [];
304
-
305
- for (var _i = 0; _i < polygon.vertices.length; _i++) {
306
- var j = (_i + 1) % polygon.vertices.length;
307
- var ti = types[_i],
308
- tj = types[j];
309
- var vi = polygon.vertices[_i],
310
- vj = polygon.vertices[j];
311
- if (ti != BACK) f.push(vi);
312
- if (ti != FRONT) b.push(ti != BACK ? vi.clone() : vi);
313
-
314
- if ((ti | tj) == SPANNING) {
315
- var _t = (this.w - this.normal.dot(vi.pos)) / this.normal.dot(tv0.copy(vj.pos).sub(vi.pos));
316
-
317
- var v = vi.interpolate(vj, _t);
318
- f.push(v);
319
- b.push(v.clone());
320
- }
321
- }
322
-
323
- if (f.length >= 3) front.push(new Polygon(f, polygon.shared));
324
- if (b.length >= 3) back.push(new Polygon(b, polygon.shared));
325
- break;
326
- }
327
- }
328
- }]);
329
-
330
- return Plane;
331
- }();
332
-
333
- exports.Plane = Plane;
334
- Plane.EPSILON = 1e-5;
335
-
336
- Plane.fromPoints = function (a, b, c) {
337
- var n = tv0.copy(b).sub(a).cross(tv1.copy(c).sub(a)).normalize();
338
- return new Plane(n.clone(), n.dot(a));
339
- };
340
-
341
- var Polygon = /*#__PURE__*/function () {
342
- function Polygon(vertices, shared) {
343
- _classCallCheck(this, Polygon);
344
-
345
- this.vertices = vertices;
346
- this.shared = shared;
347
- this.plane = Plane.fromPoints(vertices[0].pos, vertices[1].pos, vertices[2].pos);
348
- }
349
-
350
- _createClass(Polygon, [{
351
- key: "clone",
352
- value: function clone() {
353
- return new Polygon(this.vertices.map(function (v) {
354
- return v.clone();
355
- }), this.shared);
356
- }
357
- }, {
358
- key: "flip",
359
- value: function flip() {
360
- this.vertices.reverse().forEach(function (v) {
361
- return v.flip();
362
- });
363
- this.plane.flip();
364
- }
365
- }]);
366
-
367
- return Polygon;
368
- }();
369
-
370
- exports.Polygon = Polygon;
371
-
372
- var Node = /*#__PURE__*/function () {
373
- function Node(polygons) {
374
- _classCallCheck(this, Node);
375
-
376
- this.plane = null;
377
- this.front = null;
378
- this.back = null;
379
- this.polygons = [];
380
- if (polygons) this.build(polygons);
381
- }
382
-
383
- _createClass(Node, [{
384
- key: "clone",
385
- value: function clone() {
386
- var node = new Node();
387
- node.plane = this.plane && this.plane.clone();
388
- node.front = this.front && this.front.clone();
389
- node.back = this.back && this.back.clone();
390
- node.polygons = this.polygons.map(function (p) {
391
- return p.clone();
392
- });
393
- return node;
394
- }
395
- }, {
396
- key: "invert",
397
- value: function invert() {
398
- for (var i = 0; i < this.polygons.length; i++) {
399
- this.polygons[i].flip();
400
- }
401
-
402
- this.plane && this.plane.flip();
403
- this.front && this.front.invert();
404
- this.back && this.back.invert();
405
- var temp = this.front;
406
- this.front = this.back;
407
- this.back = temp;
408
- }
409
- }, {
410
- key: "clipPolygons",
411
- value: function clipPolygons(polygons) {
412
- if (!this.plane) return polygons.slice();
413
- var front = [],
414
- back = [];
415
-
416
- for (var i = 0; i < polygons.length; i++) {
417
- this.plane.splitPolygon(polygons[i], front, back, front, back);
418
- }
419
-
420
- if (this.front) front = this.front.clipPolygons(front);
421
- if (this.back) back = this.back.clipPolygons(back);else back = [];
422
- return front.concat(back);
423
- }
424
- }, {
425
- key: "clipTo",
426
- value: function clipTo(bsp) {
427
- this.polygons = bsp.clipPolygons(this.polygons);
428
- if (this.front) this.front.clipTo(bsp);
429
- if (this.back) this.back.clipTo(bsp);
430
- }
431
- }, {
432
- key: "allPolygons",
433
- value: function allPolygons() {
434
- var polygons = this.polygons.slice();
435
- if (this.front) polygons = polygons.concat(this.front.allPolygons());
436
- if (this.back) polygons = polygons.concat(this.back.allPolygons());
437
- return polygons;
438
- }
439
- }, {
440
- key: "build",
441
- value: function build(polygons) {
442
- if (!polygons.length) return;
443
- if (!this.plane) this.plane = polygons[0].plane.clone();
444
- var front = [],
445
- back = [];
446
-
447
- for (var i = 0; i < polygons.length; i++) {
448
- this.plane.splitPolygon(polygons[i], this.polygons, this.polygons, front, back);
449
- }
450
-
451
- if (front.length) {
452
- if (!this.front) this.front = new Node();
453
- this.front.build(front);
454
- }
455
-
456
- if (back.length) {
457
- if (!this.back) this.back = new Node();
458
- this.back.build(back);
459
- }
460
- }
461
- }]);
462
-
463
- return Node;
464
- }();
465
-
466
- CSG.fromJSON = function (json) {
467
- return CSG.fromPolygons(json.polygons.map(function (p) {
468
- return new Polygon(p.vertices.map(function (v) {
469
- return new Vertex(v.pos, v.normal, v.uv);
470
- }), p.shared);
471
- }));
472
- };
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.Vertex=exports.Vector=exports.Polygon=exports.Plane=exports.CSG=void 0;var _react=_interopRequireDefault(require("react"));function _interopRequireDefault(t){return t&&t.__esModule?t:{default:t}}function _classCallCheck(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function _defineProperties(t,e){for(var n=0;n<e.length;n++){var o=e[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}function _createClass(t,e,n){return e&&_defineProperties(t.prototype,e),n&&_defineProperties(t,n),Object.defineProperty(t,"prototype",{writable:!1}),t}var CSG=function(){function n(){_classCallCheck(this,n),this.polygons=[]}return _createClass(n,[{key:"clone",value:function(){var t=new n;return t.polygons=this.polygons.map(function(t){return t.clone()}),t}},{key:"toPolygons",value:function(){return this.polygons}},{key:"union",value:function(t){var e=new Node(this.clone().polygons),t=new Node(t.clone().polygons);return e.clipTo(t),t.clipTo(e),t.invert(),t.clipTo(e),t.invert(),e.build(t.allPolygons()),n.fromPolygons(e.allPolygons())}},{key:"subtract",value:function(t){var e=new Node(this.clone().polygons),t=new Node(t.clone().polygons);return e.invert(),e.clipTo(t),t.clipTo(e),t.invert(),t.clipTo(e),t.invert(),e.build(t.allPolygons()),e.invert(),n.fromPolygons(e.allPolygons())}},{key:"intersect",value:function(t){var e=new Node(this.clone().polygons),t=new Node(t.clone().polygons);return e.invert(),t.clipTo(e),t.invert(),e.clipTo(t),t.clipTo(e),e.build(t.allPolygons()),e.invert(),n.fromPolygons(e.allPolygons())}},{key:"inverse",value:function(){var t=this.clone();return t.polygons.forEach(function(t){return t.flip()}),t}}]),n}(),Vector=((exports.CSG=CSG).fromPolygons=function(t){var e=new CSG;return e.polygons=t,e},function(){function o(){var t=0<arguments.length&&void 0!==arguments[0]?arguments[0]:0,e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:0,n=2<arguments.length&&void 0!==arguments[2]?arguments[2]:0;_classCallCheck(this,o),this.x=t,this.y=e,this.z=n}return _createClass(o,[{key:"copy",value:function(t){return this.x=t.x,this.y=t.y,this.z=t.z,this}},{key:"clone",value:function(){return new o(this.x,this.y,this.z)}},{key:"negate",value:function(){return this.x*=-1,this.y*=-1,this.z*=-1,this}},{key:"add",value:function(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this}},{key:"sub",value:function(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this}},{key:"times",value:function(t){return this.x*=t,this.y*=t,this.z*=t,this}},{key:"dividedBy",value:function(t){return this.x/=t,this.y/=t,this.z/=t,this}},{key:"lerp",value:function(t,e){return this.add(tv0.copy(t).sub(this).times(e))}},{key:"unit",value:function(){return this.dividedBy(this.length())}},{key:"length",value:function(){return Math.sqrt(Math.pow(this.x,2)+Math.pow(this.y,2)+Math.pow(this.z,2))}},{key:"normalize",value:function(){return this.unit()}},{key:"cross",value:function(t){var e=this.x,n=this.y,o=this.z,i=t.x,s=t.y,t=t.z;return this.x=n*t-o*s,this.y=o*i-e*t,this.z=e*s-n*i,this}},{key:"dot",value:function(t){return this.x*t.x+this.y*t.y+this.z*t.z}}]),o}()),tv0=new(exports.Vector=Vector),tv1=new Vector,Vertex=function(){function i(t,e,n,o){_classCallCheck(this,i),this.pos=(new Vector).copy(t),this.normal=(new Vector).copy(e),n&&(this.uv=(new Vector).copy(n))&&(this.uv.z=0),o&&(this.color=(new Vector).copy(o))}return _createClass(i,[{key:"clone",value:function(){return new i(this.pos,this.normal,this.uv,this.color)}},{key:"flip",value:function(){this.normal.negate()}},{key:"interpolate",value:function(t,e){return new i(this.pos.clone().lerp(t.pos,e),this.normal.clone().lerp(t.normal,e),this.uv&&t.uv&&this.uv.clone().lerp(t.uv,e),this.color&&t.color&&this.color.clone().lerp(t.color,e))}}]),i}(),Plane=(exports.Vertex=Vertex,function(){function g(t,e){_classCallCheck(this,g),this.normal=t,this.w=e}return _createClass(g,[{key:"clone",value:function(){return new g(this.normal.clone(),this.w)}},{key:"flip",value:function(){this.normal.negate(),this.w=-this.w}},{key:"splitPolygon",value:function(t,e,n,o,i){for(var s=0,l=[],r=0;r<t.vertices.length;r++){var c=this.normal.dot(t.vertices[r].pos)-this.w,c=c<-g.EPSILON?2:g.EPSILON<c?1:0;s|=c,l.push(c)}switch(s){case 0:(0<this.normal.dot(t.plane.normal)?e:n).push(t);break;case 1:o.push(t);break;case 2:i.push(t);break;case 3:for(var a=[],h=[],u=0;u<t.vertices.length;u++){var p=(u+1)%t.vertices.length,y=l[u],f=l[p],v=t.vertices[u],p=t.vertices[p];2!=y&&a.push(v),1!=y&&h.push(2!=y?v.clone():v),3==(y|f)&&(y=(this.w-this.normal.dot(v.pos))/this.normal.dot(tv0.copy(p.pos).sub(v.pos)),f=v.interpolate(p,y),a.push(f),h.push(f.clone()))}3<=a.length&&o.push(new Polygon(a,t.shared)),3<=h.length&&i.push(new Polygon(h,t.shared))}}}]),g}()),Polygon=((exports.Plane=Plane).EPSILON=1e-5,Plane.fromPoints=function(t,e,n){e=tv0.copy(e).sub(t).cross(tv1.copy(n).sub(t)).normalize();return new Plane(e.clone(),e.dot(t))},function(){function n(t,e){_classCallCheck(this,n),this.vertices=t,this.shared=e,this.plane=Plane.fromPoints(t[0].pos,t[1].pos,t[2].pos)}return _createClass(n,[{key:"clone",value:function(){return new n(this.vertices.map(function(t){return t.clone()}),this.shared)}},{key:"flip",value:function(){this.vertices.reverse().forEach(function(t){return t.flip()}),this.plane.flip()}}]),n}()),Node=(exports.Polygon=Polygon,function(){function i(t){_classCallCheck(this,i),this.plane=null,this.front=null,this.back=null,this.polygons=[],t&&this.build(t)}return _createClass(i,[{key:"clone",value:function(){var t=new i;return t.plane=this.plane&&this.plane.clone(),t.front=this.front&&this.front.clone(),t.back=this.back&&this.back.clone(),t.polygons=this.polygons.map(function(t){return t.clone()}),t}},{key:"invert",value:function(){for(var t=0;t<this.polygons.length;t++)this.polygons[t].flip();this.plane&&this.plane.flip(),this.front&&this.front.invert(),this.back&&this.back.invert();var e=this.front;this.front=this.back,this.back=e}},{key:"clipPolygons",value:function(t){if(!this.plane)return t.slice();for(var e=[],n=[],o=0;o<t.length;o++)this.plane.splitPolygon(t[o],e,n,e,n);return this.front&&(e=this.front.clipPolygons(e)),n=this.back?this.back.clipPolygons(n):[],e.concat(n)}},{key:"clipTo",value:function(t){this.polygons=t.clipPolygons(this.polygons),this.front&&this.front.clipTo(t),this.back&&this.back.clipTo(t)}},{key:"allPolygons",value:function(){var t=this.polygons.slice();return this.front&&(t=t.concat(this.front.allPolygons())),t=this.back?t.concat(this.back.allPolygons()):t}},{key:"build",value:function(t){if(t.length){this.plane||(this.plane=t[0].plane.clone());for(var e=[],n=[],o=0;o<t.length;o++)this.plane.splitPolygon(t[o],this.polygons,this.polygons,e,n);e.length&&(this.front||(this.front=new i),this.front.build(e)),n.length&&(this.back||(this.back=new i),this.back.build(n))}}}]),i}());CSG.fromJSON=function(t){return CSG.fromPolygons(t.polygons.map(function(t){return new Polygon(t.vertices.map(function(t){return new Vertex(t.pos,t.normal,t.uv)}),t.shared)}))};
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["utils/csg/csg-lib.js"],"names":["_react","_interopRequireDefault","require","CSG","_classCallCheck","this","polygons","csg","map","p","clone","a","Node","b","clipTo","invert","build","allPolygons","fromPolygons","forEach","flip","Vector","x","arguments","length","undefined","y","z","v","t","add","tv0","copy","sub","times","dividedBy","sqrt","Math","pow","unit","ax","ay","az","bx","by","bz","tv1","Vertex","pos","normal","uv","color","negate","other","lerp","Plane","w","polygon","coplanarFront","coplanarBack","front","back","polygonType","types","i","vertices","dot","type","EPSILON","push","plane","f","j","ti","tj","vi","vj","Polygon","shared","fromPoints","c","n","cross","normalize","node","COPLANAR","FRONT","temp","slice","splitPolygon","clipPolygons","SPANNING","concat","bsp","BACK","interpolate","fromJSON","json"],"mappings":"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","file":"utils/csg/csg-lib.js","sourcesContent":["import React from 'react';\n\nclass CSG {\n    constructor() {\n        this.polygons = [];\n    }\n    clone() {\n        let csg = new CSG();\n        csg.polygons = this.polygons.map(p=>p.clone());\n        return csg;\n    }\n\n    toPolygons() {\n        return this.polygons;\n    }\n\n    union(csg) {\n        let a = new Node(this.clone().polygons);\n        let b = new Node(csg.clone().polygons);\n        a.clipTo(b);\n        b.clipTo(a);\n        b.invert();\n        b.clipTo(a);\n        b.invert();\n        a.build(b.allPolygons());\n        return CSG.fromPolygons(a.allPolygons());\n    }\n\n    subtract(csg) {\n        let a = new Node(this.clone().polygons);\n        let b = new Node(csg.clone().polygons);\n        a.invert();\n        a.clipTo(b);\n        b.clipTo(a);\n        b.invert();\n        b.clipTo(a);\n        b.invert();\n        a.build(b.allPolygons());\n        a.invert();\n        return CSG.fromPolygons(a.allPolygons());\n    }\n\n    intersect(csg) {\n        let a = new Node(this.clone().polygons);\n        let b = new Node(csg.clone().polygons);\n        a.invert();\n        b.clipTo(a);\n        b.invert();\n        a.clipTo(b);\n        b.clipTo(a);\n        a.build(b.allPolygons());\n        a.invert();\n        return CSG.fromPolygons(a.allPolygons());\n    }\n\n    // Return a new CSG solid with solid and empty space switched. This solid is\n    // not modified.\n    inverse() {\n        let csg = this.clone();\n        csg.polygons.forEach(p=>p.flip());\n        return csg;\n    }\n}\n\nCSG.fromPolygons=function(polygons) {\n    let csg = new CSG();\n    csg.polygons = polygons;\n    return csg;\n};\n\nclass Vector {\n    constructor(x=0, y=0, z=0) {\n        this.x=x;\n        this.y=y;\n        this.z=z;\n    }\n    copy(v){\n        this.x=v.x;\n        this.y=v.y;\n        this.z=v.z;\n        return this;\n    }\n    clone() {\n        return new Vector(this.x,this.y,this.z);\n    }\n    negate() {\n        this.x*=-1;\n        this.y*=-1;\n        this.z*=-1;\n        return this;\n    }\n    add(a) {\n        this.x+=a.x;\n        this.y+=a.y;\n        this.z+=a.z;\n        return this;\n    }\n    sub(a) {\n        this.x-=a.x;\n        this.y-=a.y;\n        this.z-=a.z;\n        return this;\n    }\n    times(a) {\n        this.x*=a;\n        this.y*=a;\n        this.z*=a;\n        return this;\n    }\n    dividedBy(a) {\n        this.x/=a;\n        this.y/=a;\n        this.z/=a;\n        return this;\n    }\n    lerp(a, t) {\n        return this.add(tv0.copy(a).sub(this).times(t));\n    }\n    unit() {\n        return this.dividedBy(this.length());\n    }\n    length(){\n        return Math.sqrt((this.x**2)+(this.y**2)+(this.z**2));\n    }\n    normalize(){\n        return this.unit();\n    }\n    cross(b) {\n        let a = this;\n\t\tconst ax = a.x, ay = a.y, az = a.z;\n\t\tconst bx = b.x, by = b.y, bz = b.z;\n\n\t\tthis.x = ay * bz - az * by;\n\t\tthis.y = az * bx - ax * bz;\n\t\tthis.z = ax * by - ay * bx;\n\n\t\treturn this;\n    }\n    dot(b){\n        return (this.x*b.x)+(this.y*b.y)+(this.z*b.z);\n    }\n}\n\nlet tv0=new Vector();\nlet tv1=new Vector();\n\nclass Vertex {\n\n    constructor(pos, normal, uv, color) {\n        this.pos = new Vector().copy(pos);\n        this.normal = new Vector().copy(normal);\n        uv && (this.uv = new Vector().copy(uv)) && (this.uv.z=0);\n        color && (this.color = new Vector().copy(color));\n    }\n\n    clone() {\n        return new Vertex(this.pos,this.normal,this.uv,this.color);\n    }\n\n    flip() {\n        this.normal.negate();\n    }\n\n    interpolate(other, t) {\n        return new Vertex(this.pos.clone().lerp(other.pos, t),this.normal.clone().lerp(other.normal, t),this.uv&&other.uv&&this.uv.clone().lerp(other.uv, t), this.color&&other.color&&this.color.clone().lerp(other.color,t));\n    }\n}\n\nclass Plane {\n    constructor(normal, w) {\n        this.normal = normal;\n        this.w = w;\n    }\n\n    clone() {\n        return new Plane(this.normal.clone(),this.w);\n    }\n\n    flip() {\n        this.normal.negate();\n        this.w = -this.w;\n    }\n\n    splitPolygon(polygon, coplanarFront, coplanarBack, front, back) {\n        const COPLANAR = 0;\n        const FRONT = 1;\n        const BACK = 2;\n        const SPANNING = 3;\n\n        let polygonType = 0;\n        let types = [];\n        for (let i = 0; i < polygon.vertices.length; i++) {\n            let t = this.normal.dot(polygon.vertices[i].pos) - this.w;\n            let type = (t < -Plane.EPSILON) ? BACK : (t > Plane.EPSILON) ? FRONT : COPLANAR;\n            polygonType |= type;\n            types.push(type);\n        }\n\n        switch (polygonType) {\n            case COPLANAR:\n                (this.normal.dot(polygon.plane.normal) > 0 ? coplanarFront : coplanarBack).push(polygon);\n                break;\n            case FRONT:\n                front.push(polygon);\n                break;\n            case BACK:\n                back.push(polygon);\n                break;\n            case SPANNING:\n                let f = [];\n                let b = [];\n                for (let i = 0; i < polygon.vertices.length; i++) {\n                    let j = (i + 1) % polygon.vertices.length;\n                    let ti = types[i]\n                    , tj = types[j];\n                    let vi = polygon.vertices[i]\n                    , vj = polygon.vertices[j];\n                    if (ti != BACK)\n                        f.push(vi);\n                    if (ti != FRONT)\n                        b.push(ti != BACK ? vi.clone() : vi);\n                    if ((ti | tj) == SPANNING) {\n                        let t = (this.w - this.normal.dot(vi.pos)) / this.normal.dot(tv0.copy(vj.pos).sub(vi.pos));\n                        let v = vi.interpolate(vj, t);\n                        f.push(v);\n                        b.push(v.clone());\n                    }\n                }\n                if (f.length >= 3)\n                    front.push(new Polygon(f,polygon.shared));\n                if (b.length >= 3)\n                    back.push(new Polygon(b,polygon.shared));\n                break;\n        }\n    }\n\n}\n\nPlane.EPSILON = 1e-5;\n\nPlane.fromPoints = function(a, b, c) {\n    let n = tv0.copy(b).sub(a).cross(tv1.copy(c).sub(a)).normalize();\n    return new Plane(n.clone(),n.dot(a));\n};\n\nclass Polygon {\n    constructor(vertices, shared) {\n        this.vertices = vertices;\n        this.shared = shared;\n        this.plane = Plane.fromPoints(vertices[0].pos, vertices[1].pos, vertices[2].pos);\n    }\n    clone() {\n        return new Polygon(this.vertices.map(v=>v.clone()),this.shared);\n    }\n    flip() {\n        this.vertices.reverse().forEach(v=>v.flip());\n        this.plane.flip();\n    }\n}\n\nclass Node {\n    constructor(polygons) {\n        this.plane = null;\n        this.front = null;\n        this.back = null;\n        this.polygons = [];\n        if (polygons)\n            this.build(polygons);\n    }\n    clone() {\n        let node = new Node();\n        node.plane = this.plane && this.plane.clone();\n        node.front = this.front && this.front.clone();\n        node.back = this.back && this.back.clone();\n        node.polygons = this.polygons.map(p=>p.clone());\n        return node;\n    }\n\n    invert() {\n        for (let i = 0; i < this.polygons.length; i++)\n            this.polygons[i].flip();\n        \n        this.plane && this.plane.flip();\n        this.front && this.front.invert();\n        this.back && this.back.invert();\n        let temp = this.front;\n        this.front = this.back;\n        this.back = temp;\n    }\n\n    clipPolygons(polygons) {\n        if (!this.plane)\n            return polygons.slice();\n        let front = []\n          , back = [];\n        for (let i = 0; i < polygons.length; i++) {\n            this.plane.splitPolygon(polygons[i], front, back, front, back);\n        }\n        if (this.front)\n            front = this.front.clipPolygons(front);\n        if (this.back)\n            back = this.back.clipPolygons(back);\n        else \n            back = [];\n        return front.concat(back);\n    }\n\n    clipTo(bsp) {\n        this.polygons = bsp.clipPolygons(this.polygons);\n        if (this.front)\n            this.front.clipTo(bsp);\n        if (this.back)\n            this.back.clipTo(bsp);\n    }\n\n    allPolygons() {\n        let polygons = this.polygons.slice();\n        if (this.front)\n            polygons = polygons.concat(this.front.allPolygons());\n        if (this.back)\n            polygons = polygons.concat(this.back.allPolygons());\n        return polygons;\n    }\n\n    build(polygons) {\n        if (!polygons.length)\n            return;\n        if (!this.plane)\n            this.plane = polygons[0].plane.clone();\n        let front = []\n          , back = [];\n        for (let i = 0; i < polygons.length; i++) {\n            this.plane.splitPolygon(polygons[i], this.polygons, this.polygons, front, back);\n        }\n        if (front.length) {\n            if (!this.front)\n                this.front = new Node();\n            this.front.build(front);\n        }\n        if (back.length) {\n            if (!this.back)\n                this.back = new Node();\n            this.back.build(back);\n        }\n    }\n}\n\nCSG.fromJSON=function(json){\n    return CSG.fromPolygons(json.polygons.map(p=>new Polygon(p.vertices.map(v=> new Vertex(v.pos,v.normal,v.uv)),p.shared)));\n};\n\nexport { CSG, Vertex, Vector, Polygon, Plane };\n"]}
@@ -1,84 +1,2 @@
1
- "use strict";
2
-
3
- var _react = _interopRequireDefault(require("react"));
4
-
5
- var _csgLib = require("./csg-lib.js");
6
-
7
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
8
-
9
- var gWorkersStarted = false;
10
- var gWorker;
11
- var gWorkerUrl;
12
- var taskId = 0;
13
- var tasks = {};
14
-
15
- var spawnWorker = function spawnWorker() {
16
- var worker = new Worker(gWorkerUrl);
17
-
18
- worker.onmessage = function (e) {
19
- var rslt = JSON.parse(e.data);
20
- var task = tasks[rslt.taskId];
21
- delete tasks[rslt.taskId];
22
- task.resolve(_csgLib.CSG.fromJSON(rslt.result)); //console.log('Message received from worker');
23
-
24
- gWorker.busy = false;
25
- };
26
-
27
- return gWorker = {
28
- worker: worker,
29
- busy: false
30
- };
31
- };
32
-
33
- var getWorker = function getWorker() {
34
- if (!gWorkersStarted) {
35
- gWorkersStarted = true;
36
- return fetch('../csg-lib.js').then(function (response) {
37
- return response.text().then(function (text) {
38
- text = text.slice(0, text.lastIndexOf('export'));
39
- var code = text + "\n self.onmessage=(message)=>{\n let task = JSON.parse(message.data)\n //console.log(\"Got task:\"+task.op+' '+task.taskId)\n postMessage(JSON.stringify({\n taskId:task.taskId,\n result : CSG.fromJSON(task.a)[task.op](CSG.fromJSON(task.b))\n }))\n }\n console.log('CSG worker started!')";
40
- var blob = new Blob([code], {
41
- type: 'application/javascript'
42
- });
43
- gWorkerUrl = URL.createObjectURL(blob);
44
- }).then(function () {
45
- return spawnWorker();
46
- });
47
- });
48
- }
49
-
50
- if (gWorker && !gWorker.busy) {
51
- gWorker.busy = true;
52
- return {
53
- then: function then(fn) {
54
- return fn(gWorker);
55
- }
56
- };
57
- }
58
-
59
- return {
60
- then: function then() {
61
- return this;
62
- }
63
- };
64
- };
65
-
66
- _csgLib.CSG.doAsync = function (a, op, b) {
67
- return getWorker().then(function (worker) {
68
- var task = {
69
- a: a,
70
- op: op,
71
- b: b,
72
- taskId: taskId
73
- };
74
- tasks[taskId] = task;
75
- taskId++;
76
- task.result = new Promise(function (resolve, reject) {
77
- task.resolve = resolve; //console.log("posting to worker:")
78
-
79
- worker.busy = true;
80
- worker.worker.postMessage(JSON.stringify(task));
81
- });
82
- return task.result;
83
- });
84
- };
1
+ "use strict";var _react=_interopRequireDefault(require("react")),_csgLib=require("./csg-lib.js");function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}var gWorker,gWorkerUrl,gWorkersStarted=!1,taskId=0,tasks={},spawnWorker=function(){var e=new Worker(gWorkerUrl);return e.onmessage=function(e){var e=JSON.parse(e.data),r=tasks[e.taskId];delete tasks[e.taskId],r.resolve(_csgLib.CSG.fromJSON(e.result)),gWorker.busy=!1},gWorker={worker:e,busy:!1}},getWorker=function(){return gWorkersStarted?gWorker&&!gWorker.busy?(gWorker.busy=!0,{then:function(e){return e(gWorker)}}):{then:function(){return this}}:(gWorkersStarted=!0,fetch("../csg-lib.js").then(function(e){return e.text().then(function(e){e=e.slice(0,e.lastIndexOf("export"));e=new Blob([e+"\n self.onmessage=(message)=>{\n let task = JSON.parse(message.data)\n //console.log(\"Got task:\"+task.op+' '+task.taskId)\n postMessage(JSON.stringify({\n taskId:task.taskId,\n result : CSG.fromJSON(task.a)[task.op](CSG.fromJSON(task.b))\n }))\n }\n console.log('CSG worker started!')"],{type:"application/javascript"});gWorkerUrl=URL.createObjectURL(e)}).then(function(){return spawnWorker()})}))};_csgLib.CSG.doAsync=function(e,r,n){return getWorker().then(function(t){var s={a:e,op:r,b:n,taskId:taskId};return tasks[taskId]=s,taskId++,s.result=new Promise(function(e,r){s.resolve=e,t.busy=!0,t.worker.postMessage(JSON.stringify(s))}),s.result})};
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInV0aWxzL2NzZy9jc2ctd29ya2VyLmpzIl0sIm5hbWVzIjpbIl9yZWFjdCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX2NzZ0xpYiIsImdXb3JrZXIiLCJnV29ya2VyVXJsIiwiZ1dvcmtlcnNTdGFydGVkIiwidGFza0lkIiwiV29ya2VyIiwidGFza3MiLCJvbm1lc3NhZ2UiLCJlIiwicnNsdCIsIkpTT04iLCJwYXJzZSIsImRhdGEiLCJzcGF3bldvcmtlciIsInRhc2siLCJyZXNvbHZlIiwiQ1NHIiwiZnJvbUpTT04iLCJyZXN1bHQiLCJidXN5IiwiZm4iLCJ0aGVuIiwidGhpcyIsInJlc3BvbnNlIiwid29ya2VyIiwidGV4dCIsInNsaWNlIiwibGFzdEluZGV4T2YiLCJibG9iIiwiY29kZSIsIkJsb2IiLCJ0eXBlIiwiY3JlYXRlT2JqZWN0VVJMIiwiZG9Bc3luYyIsImEiLCJvcCIsImIiLCJnZXRXb3JrZXIiLCJQcm9taXNlIiwicmVqZWN0IiwicG9zdE1lc3NhZ2UiLCJzdHJpbmdpZnkiXSwibWFwcGluZ3MiOiJhQUFBLElBQUFBLE9BQUFDLHVCQUFBQyxRQUFBLFVBQ0FDLFFBQUFELFFBQUEsZ0Isd0VBRUEsSUFGQUUsUUFJSUMsV0FGQUMsaUJBQWtCLEVBSWxCQyxPQUFTLEVBSlRELE1BQUFBLEdBQ0FGLFlBQUosV0FDSUMsSUFBQUEsRUFBSixJQUFBRyxPQUFBSCxZQVVPLE9BUEhJLEVBQUtDLFVBQVQsU0FBQUMsR0FLTyxJQUFJQyxFQUFPQyxLQUFLQyxNQUFNSCxFQUFFSSxNQUozQkMsRUFBWVAsTUFBQUcsRUFBWkksZUFDWVAsTUFBT0QsRUFBSkQsUUFNWlUsRUFBS0MsUUFBUUMsUUFBQUEsSUFBSUMsU0FBU1IsRUFBS1MsU0FIL0JqQixRQUFXUyxNQUFLQyxHQUVUTCxRQUFVLENBQUNGLE9BQUFBLEVBQWxCZSxNQUFBLElBR0FsQixVQUFRa0IsV0FOWCxPQUFBaEIsZ0JBdUNJRixVQUFlQSxRQUFma0IsTUFFQWxCLFFBQU9rQixNQUFBLEVBQW9CQyxDQUFBQSxLQUFHbkIsU0FBQUEsR0FBVixPQUFBbUIsRUFBQW5CLFlBQXBCLENBQ0hvQixLQUFBLFdBQUEsT0FBQUMsUUE3QkduQixpQkFBa0IsRUFMZkYsTUFBVSxpQkFBQW9CLEtBQUEsU0FBQUUsR0FBQ0MsT0FBREQsRUFBQUUsT0FBQUosS0FBQSxTQUFBSSxHQUFhQSxFQUFBQSxFQUFBQyxNQUFBLEVBQUFELEVBQUFFLFlBQUEsV0FtQkxDLEVBQVVDLElBQURDLEtBQU8sQ0FuQnpDTCxFQUFBLDZjQW1CeUMsQ0FDbkJNLEtBQUEsMkJBRVY3QixXQUFpQjhCLElBQUFBLGdCQUFqQkosS0FmSlAsS0FBQSxXQURKLE9BQUFSLG9CQWtDUkcsUUFBQUEsSUFBSWlCLFFBSm9CLFNBQU9DLEVBQUFDLEVBQVBDLEdBQWEsT0FBQUMsWUFBQWhCLEtBQUEsU0FBQUcsR0FEakMsSUFBQVYsRUFBQSxDQUFBb0IsRUFBQUEsRUFBQUMsR0FBQUEsRUFBQUMsRUFBQUEsRUFBQWhDLE9BQUFBLFFBT3FCQSxPQXZDekJFLE1BQUFGLFFBQUFVLEVBeUNRVixTQUpSWSxFQUFJaUIsT0FBUSxJQUFBSyxRQUFBLFNBQUdILEVBQU9JLEdBQ1hGLEVBQUFBLFFBQWlCdEIsRUFDWFMsRUFBQUwsTUFBQSxFQUFBSyxFQUFBQSxPQUFBZ0IsWUFBQTlCLEtBQUErQixVQUFBM0IsTUFBUVYsRUFBQUEiLCJmaWxlIjoidXRpbHMvY3NnL2NzZy13b3JrZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQ1NHIH0gZnJvbSAnLi9jc2ctbGliLmpzJztcblxubGV0IGdXb3JrZXJzU3RhcnRlZCA9IGZhbHNlO1xubGV0IGdXb3JrZXI7XG5sZXQgZ1dvcmtlclVybDtcblxubGV0IHRhc2tJZCA9IDA7XG5sZXQgdGFza3M9e307XG5sZXQgc3Bhd25Xb3JrZXI9KCk9PntcbiAgICBjb25zdCB3b3JrZXIgPSBuZXcgV29ya2VyKGdXb3JrZXJVcmwpO1xuXG4gICAgd29ya2VyLm9ubWVzc2FnZSA9IGZ1bmN0aW9uKGUpIHtcbiAgICAgICBsZXQgcnNsdCA9IEpTT04ucGFyc2UoZS5kYXRhKTtcbiAgICAgICBsZXQgdGFzayA9IHRhc2tzW3JzbHQudGFza0lkXTtcbiAgICAgICBkZWxldGUgdGFza3NbcnNsdC50YXNrSWRdO1xuICAgICAgIHRhc2sucmVzb2x2ZShDU0cuZnJvbUpTT04ocnNsdC5yZXN1bHQpKTtcbiAgICAgICAvL2NvbnNvbGUubG9nKCdNZXNzYWdlIHJlY2VpdmVkIGZyb20gd29ya2VyJyk7XG4gICAgICAgZ1dvcmtlci5idXN5ID0gZmFsc2U7XG4gICAgfTtcbiAgICByZXR1cm4gZ1dvcmtlciA9IHt3b3JrZXIsYnVzeTpmYWxzZX07XG59O1xuXG5sZXQgZ2V0V29ya2VyPSgpPT57XG4gICAgaWYoIWdXb3JrZXJzU3RhcnRlZCl7XG4gICAgICAgIGdXb3JrZXJzU3RhcnRlZCA9IHRydWU7XG4gICAgICAgIHJldHVybiBmZXRjaCgnLi4vY3NnLWxpYi5qcycpLnRoZW4oZnVuY3Rpb24ocmVzcG9uc2UpIHtcbiAgICAgICAgICAgIHJldHVybiByZXNwb25zZS50ZXh0KCkudGhlbihmdW5jdGlvbih0ZXh0KSB7XG4gICAgICAgICAgICAgICAgdGV4dCA9IHRleHQuc2xpY2UoMCwgdGV4dC5sYXN0SW5kZXhPZignZXhwb3J0JykpO1xuICAgICAgICAgICAgICAgIGNvbnN0IGNvZGUgPSB0ZXh0ICsgYFxuICAgICAgICAgICAgICAgICAgICBzZWxmLm9ubWVzc2FnZT0obWVzc2FnZSk9PntcbiAgICAgICAgICAgICAgICAgICAgbGV0IHRhc2sgPSBKU09OLnBhcnNlKG1lc3NhZ2UuZGF0YSlcbiAgICAgICAgICAgICAgICAgICAgLy9jb25zb2xlLmxvZyhcIkdvdCB0YXNrOlwiK3Rhc2sub3ArJyAnK3Rhc2sudGFza0lkKVxuICAgICAgICAgICAgICAgICAgICBwb3N0TWVzc2FnZShKU09OLnN0cmluZ2lmeSh7XG4gICAgICAgICAgICAgICAgICAgICAgICB0YXNrSWQ6dGFzay50YXNrSWQsXG4gICAgICAgICAgICAgICAgICAgICAgICByZXN1bHQgOiBDU0cuZnJvbUpTT04odGFzay5hKVt0YXNrLm9wXShDU0cuZnJvbUpTT04odGFzay5iKSlcbiAgICAgICAgICAgICAgICAgICAgfSkpXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGNvbnNvbGUubG9nKCdDU0cgd29ya2VyIHN0YXJ0ZWQhJylgO1xuICAgICAgICAgICAgICAgIGNvbnN0IGJsb2IgPSBuZXcgQmxvYihbY29kZV0se1xuICAgICAgICAgICAgICAgICAgICB0eXBlOiAnYXBwbGljYXRpb24vamF2YXNjcmlwdCdcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICBnV29ya2VyVXJsID0gVVJMLmNyZWF0ZU9iamVjdFVSTChibG9iKTtcblxuXG4gICAgICAgICAgICB9KS50aGVuKCgpPT57XG4gICAgICAgICAgICAgICAgcmV0dXJuIHNwYXduV29ya2VyKCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfSk7XG4gICAgfVxuICAgIGlmKGdXb3JrZXIgJiYgKCFnV29ya2VyLmJ1c3kpKXtcbiAgICAgICAgZ1dvcmtlci5idXN5ID0gdHJ1ZTtcblxuICAgICAgICByZXR1cm4ge3RoZW46KGZuKT0+e3JldHVybiBmbihnV29ya2VyKTt9fTtcbiAgICB9XG4gICAgcmV0dXJue1xuICAgICAgICB0aGVuOmZ1bmN0aW9uKCl7cmV0dXJuIHRoaXM7fVxuICAgIH07XG59O1xuXG5DU0cuZG9Bc3luYz0oYSxvcCxiKT0+e1xuICAgIHJldHVybiBnZXRXb3JrZXIoKS50aGVuKCh3b3JrZXIpPT57XG4gICAgICAgIGxldCB0YXNrPXthLG9wLGIsdGFza0lkfTtcbiAgICAgICAgdGFza3NbdGFza0lkXT10YXNrO1xuICAgICAgICB0YXNrSWQrKztcbiAgICAgICAgdGFzay5yZXN1bHQgPSBuZXcgUHJvbWlzZSgocmVzb2x2ZSxyZWplY3QpPT57XG4gICAgICAgICAgICB0YXNrLnJlc29sdmUgPSByZXNvbHZlO1xuICAgICAgICAgICAgLy9jb25zb2xlLmxvZyhcInBvc3RpbmcgdG8gd29ya2VyOlwiKVxuICAgICAgICAgICAgd29ya2VyLmJ1c3kgPSB0cnVlO1xuICAgICAgICAgICAgd29ya2VyLndvcmtlci5wb3N0TWVzc2FnZShKU09OLnN0cmluZ2lmeSh0YXNrKSk7XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gdGFzay5yZXN1bHQ7ICAgICAgICBcbiAgICB9KTtcbn07XG4iXX0=