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.
- package/README.md +3 -0
- package/build/assets/css/index.css +2 -0
- package/build/assets/img/floor-dark.jpg +0 -0
- package/build/assets/img/floor-white.jpg +0 -0
- package/build/assets/img/grass.jpg +0 -0
- package/build/bundle.js +2 -0
- package/build/components/Application.js +2 -135
- package/build/components/Buttons/FullScreenButton.js +2 -50
- package/build/components/Buttons/TabButton.js +2 -24
- package/build/components/Instructions.js +2 -54
- package/build/components/Loader.js +2 -22
- package/build/components/ModelTab.js +2 -213
- package/build/components/PanoramaTab.js +2 -620
- package/build/components/RotationTab/DefaultView.js +2 -124
- package/build/components/RotationTab/ThreesixtyView.js +2 -45
- package/build/components/RotationTab/index.js +2 -194
- package/build/components/Widget.js +2 -110
- package/build/config/defaultConfig.js +2 -32
- package/build/enums/deviceOrientationStatuses.js +2 -11
- package/build/enums/deviceWidth.js +2 -21
- package/build/enums/imageExtentions.js +2 -16
- package/build/enums/rotationModes.js +2 -11
- package/build/index.css +1 -1
- package/build/index.js +2 -75
- package/build/locale/index.js +2 -71
- package/build/store/apiStore.js +2 -231
- package/build/store/deviceStore.js +2 -60
- package/build/store/fullScreenStore.js +2 -159
- package/build/store/houseStore.js +2 -952
- package/build/store/index.js +2 -124
- package/build/store/modelStore.js +2 -338
- package/build/threesixty/events.js +2 -220
- package/build/threesixty/index.js +2 -264
- package/build/utils/csg/csg-lib.js +2 -472
- package/build/utils/csg/csg-worker.js +2 -84
- package/build/utils/csg/three-csg.js +2 -277
- package/build/utils/helpers.js +2 -12
- package/build/utils/modelHelpers.js +2 -161
- package/build/utils/panoramaHelpers.js +2 -117
- package/package.json +17 -5
- package/build/assets/css/app.css +0 -1
- package/build/assets/css/app.css.map +0 -1
- package/build/assets/img/floor-dark.png +0 -0
- package/build/assets/img/floor-white.png +0 -0
- 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=
|