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,952 +1,2 @@
1
- "use strict";
2
-
3
- function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.default = void 0;
9
-
10
- var _react = _interopRequireDefault(require("react"));
11
-
12
- var _mobx = require("mobx");
13
-
14
- var _apiStore = _interopRequireDefault(require("../store/apiStore"));
15
-
16
- var _store = _interopRequireDefault(require("../store"));
17
-
18
- var THREE = _interopRequireWildcard(require("three"));
19
-
20
- var _FBXLoader = require("three/examples/jsm/loaders/FBXLoader");
21
-
22
- var _modelHelpers = require("../utils/modelHelpers");
23
-
24
- var _threeCsg = _interopRequireDefault(require("../utils/csg/three-csg"));
25
-
26
- var _wallTexture = _interopRequireDefault(require("../assets/img/wall-texture.jpg"));
27
-
28
- var _doorTexture = _interopRequireDefault(require("../assets/img/door-texture.jpeg"));
29
-
30
- var _exteriorWallTexture = _interopRequireDefault(require("../assets/img/exterior-wall-texture.jpeg"));
31
-
32
- var _exteriorWallTextureRoughness = _interopRequireDefault(require("../assets/img/exterior-wall-texture-roughness.jpg"));
33
-
34
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
-
36
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
37
-
38
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
39
-
40
- function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
41
-
42
- function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
43
-
44
- function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
45
-
46
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
47
-
48
- function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
49
-
50
- function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
51
-
52
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
53
-
54
- function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
55
-
56
- function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
57
-
58
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
59
-
60
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
61
-
62
- 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); } }
63
-
64
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
65
-
66
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
67
-
68
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
69
-
70
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
71
-
72
- (0, _mobx.configure)({
73
- useProxies: 'never'
74
- });
75
- var clippedBuildingConstant = 0.4;
76
- var doorMaterialOptions = {
77
- color: '#DADADA',
78
- side: THREE.DoubleSide
79
- };
80
- var modelLoader = new _FBXLoader.FBXLoader();
81
-
82
- var createDefaultMaterial = function createDefaultMaterial(options) {
83
- return new THREE.MeshStandardMaterial(_objectSpread({
84
- roughness: 1,
85
- metalness: 0
86
- }, options));
87
- };
88
-
89
- var HouseStore = /*#__PURE__*/function () {
90
- function HouseStore(modelStore) {
91
- var _this = this;
92
-
93
- _classCallCheck(this, HouseStore);
94
-
95
- _defineProperty(this, "modelStore", null);
96
-
97
- _defineProperty(this, "apiStore", new _apiStore.default(_store.default.config.API_URL));
98
-
99
- _defineProperty(this, "houseGroup", new THREE.Group());
100
-
101
- _defineProperty(this, "wallsGroup", new THREE.Group());
102
-
103
- _defineProperty(this, "doorsGroup", new THREE.Group());
104
-
105
- _defineProperty(this, "doorMaterial", null);
106
-
107
- _defineProperty(this, "wallsMaterial", null);
108
-
109
- _defineProperty(this, "wallsColor", '#FFFFFF');
110
-
111
- _defineProperty(this, "exteriorWallsMaps", {
112
- map: null,
113
- roughnessMap: null
114
- });
115
-
116
- _defineProperty(this, "exteriorWallsMaterial", null);
117
-
118
- _defineProperty(this, "wallsTextures", []);
119
-
120
- _defineProperty(this, "isDoorsVisible", true);
121
-
122
- _defineProperty(this, "isFullBuildingVisible", true);
123
-
124
- _defineProperty(this, "wallsMaterialType", 'texture');
125
-
126
- _defineProperty(this, "globalPlane", null);
127
-
128
- _defineProperty(this, "clippingPlanes", []);
129
-
130
- _defineProperty(this, "furnitureData", []);
131
-
132
- _defineProperty(this, "loadedModels", {});
133
-
134
- _defineProperty(this, "loadedTextures", {});
135
-
136
- _defineProperty(this, "isShadowsVisible", true);
137
-
138
- (0, _mobx.makeAutoObservable)(this);
139
- this.modelStore = modelStore;
140
- this.houseGroup.name = 'House-Group';
141
- this.globalPlane = new THREE.Plane(new THREE.Vector3(0, -this.wallsHeight - 0.5, 0), 1);
142
- this.clippingPlanes = [this.globalPlane];
143
- this.setCenterPosition().loadTextures().then(function () {
144
- _this.createFloors().createSpaceBetweenWalls().createWalls().createDoors();
145
- });
146
- this.apiStore.loadFurnitureData().then(function (resp) {
147
- _this.furnitureData = resp;
148
-
149
- _this.loadFurniture(0);
150
- });
151
- }
152
-
153
- _createClass(HouseStore, [{
154
- key: "textureLoader",
155
- get: function get() {
156
- return this.modelStore.textureLoader;
157
- }
158
- }, {
159
- key: "sceneScale",
160
- get: function get() {
161
- return this.modelStore.sceneScale;
162
- }
163
- }, {
164
- key: "wallsHeight",
165
- get: function get() {
166
- return this.modelStore.wallsHeight;
167
- }
168
- }, {
169
- key: "json",
170
- get: function get() {
171
- return this.modelStore.json;
172
- }
173
- }, {
174
- key: "vertices",
175
- get: function get() {
176
- return this.json.Vertices;
177
- }
178
- }, {
179
- key: "rooms",
180
- get: function get() {
181
- return this.json.Floors[0].Units[0].Rooms;
182
- }
183
- }, {
184
- key: "walls",
185
- get: function get() {
186
- return this.json.Floors[0].Walls;
187
- }
188
- }, {
189
- key: "exteriorWalls",
190
- get: function get() {
191
- return this.json.Floors[0].ExteriorWalls;
192
- }
193
- }, {
194
- key: "doors",
195
- get: function get() {
196
- var _this2 = this;
197
-
198
- return this.json.Floors[0].Doors.map(function (door) {
199
- return _this2.getParsedAperture(door, 'Door');
200
- });
201
- }
202
- }, {
203
- key: "windows",
204
- get: function get() {
205
- var _this3 = this;
206
-
207
- return this.json.Floors[0].Windows.map(function (window) {
208
- return _this3.getParsedAperture(window, 'Window');
209
- });
210
- }
211
- }, {
212
- key: "apertures",
213
- get: function get() {
214
- return [].concat(_toConsumableArray(this.doors), _toConsumableArray(this.windows));
215
- }
216
- }, {
217
- key: "doorsHeight",
218
- get: function get() {
219
- return this.wallsHeight / 2 + this.wallsHeight / 4;
220
- }
221
- }, {
222
- key: "wallMaterialOptions",
223
- get: function get() {
224
- return {
225
- clippingPlanes: this.clippingPlanes,
226
- color: this.wallsColor,
227
- side: THREE.DoubleSide
228
- };
229
- }
230
- }, {
231
- key: "furniture",
232
- get: function get() {
233
- return this.rooms.reduce(function (acc, _ref) {
234
- var Furniture = _ref.Furniture;
235
- if (!Furniture || !Furniture.length) return acc;
236
- return [].concat(_toConsumableArray(acc), _toConsumableArray(Furniture));
237
- }, []);
238
- }
239
- }, {
240
- key: "getVertexById",
241
- value: function getVertexById(vertexId) {
242
- return this.vertices.find(function (_ref2) {
243
- var ID = _ref2.ID;
244
- return ID === vertexId;
245
- });
246
- }
247
- }, {
248
- key: "getWallById",
249
- value: function getWallById(wallId) {
250
- return this.walls.find(function (_ref3) {
251
- var ID = _ref3.ID;
252
- return ID === wallId;
253
- });
254
- }
255
- }, {
256
- key: "getParsedAperture",
257
- value: function getParsedAperture(aperture, type) {
258
- var Location = aperture.Location,
259
- Walls = aperture.Walls;
260
- var position = new THREE.Vector3(Location.X, Location.Y, Location.Z);
261
- var secondWall = this.getParsedWallById(Walls[1], 1);
262
- var line = new THREE.Line3(secondWall.start, secondWall.end);
263
- var positionOnFirstWall = new THREE.Vector3();
264
- line.closestPointToPoint(position, true, positionOnFirstWall);
265
- var lineBetweenWalls = new THREE.Line3(position, positionOnFirstWall);
266
- var distanceBetweenWalls = lineBetweenWalls.distance();
267
- var positionBetweenWalls = lineBetweenWalls.getCenter(positionOnFirstWall);
268
-
269
- var parsedAperture = _objectSpread(_objectSpread({}, aperture), {}, {
270
- Type: type,
271
- Depth: distanceBetweenWalls,
272
- Location: {
273
- X: positionBetweenWalls.x,
274
- Y: positionBetweenWalls.y,
275
- Z: positionBetweenWalls.z
276
- }
277
- });
278
-
279
- return parsedAperture;
280
- }
281
- }, {
282
- key: "getParsedWallById",
283
- value: function getParsedWallById(wallId) {
284
- var _this4 = this;
285
-
286
- var scale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.sceneScale;
287
- var currentWall = this.getWallById(wallId);
288
-
289
- var _currentWall$Vertices = currentWall.Vertices.map(function (vertexId) {
290
- return _this4.getVertexById(vertexId).Location;
291
- }),
292
- _currentWall$Vertices2 = _slicedToArray(_currentWall$Vertices, 2),
293
- coord1 = _currentWall$Vertices2[0],
294
- coord2 = _currentWall$Vertices2[1];
295
-
296
- return {
297
- id: wallId,
298
- start: {
299
- x: coord1.X * scale,
300
- y: coord1.Y * scale,
301
- z: 0
302
- },
303
- end: {
304
- x: coord2.X * scale,
305
- y: coord2.Y * scale,
306
- z: 0
307
- }
308
- };
309
- }
310
- }, {
311
- key: "getVerticesFromParsedWalls",
312
- value: function getVerticesFromParsedWalls(walls) {
313
- return walls.reduce(function (acc, _ref4) {
314
- var start = _ref4.start,
315
- end = _ref4.end;
316
- acc.push(new THREE.Vector2(start.x, start.y), new THREE.Vector2(end.x, end.y));
317
- return acc;
318
- }, []);
319
- }
320
- }, {
321
- key: "createFloors",
322
- value: function createFloors() {
323
- var _this5 = this;
324
-
325
- this.rooms.forEach(function (_ref5) {
326
- var Walls = _ref5.Walls,
327
- Type = _ref5.Type;
328
- var walls = Walls.map(function (wallId) {
329
- return _this5.getParsedWallById(wallId);
330
- });
331
- var params = (0, _modelHelpers.getFloorParams)(Type);
332
-
333
- var vertices = _this5.getVerticesFromParsedWalls(walls);
334
-
335
- var shape = new THREE.Shape(vertices);
336
- var geometry = new THREE.ShapeGeometry(shape);
337
- var material = createDefaultMaterial({
338
- color: params.color,
339
- side: THREE.DoubleSide
340
- });
341
- var mesh = new THREE.Mesh(geometry, material);
342
- mesh.receiveShadow = true;
343
- mesh.castShadow = false;
344
- mesh.name = 'FloorMesh';
345
-
346
- var callback = function callback(texture, roughnessMap) {
347
- var textureMaterial = createDefaultMaterial({
348
- color: params.color,
349
- side: THREE.DoubleSide,
350
- map: texture
351
- });
352
- mesh.material = textureMaterial;
353
- if (roughnessMap) mesh.material.roughnessMap = roughnessMap;
354
-
355
- _this5.houseGroup.add(mesh);
356
- };
357
-
358
- _this5.loadTexture(params.texture, [0.5, 0.5], function (texture) {
359
- if (!params.roughnessMap) {
360
- callback(texture);
361
- return;
362
- }
363
-
364
- _this5.loadTexture(params.roughnessMap, [0.5, 0.5], function (roughnessMap) {
365
- return callback(texture, roughnessMap);
366
- });
367
- });
368
- });
369
- return this;
370
- }
371
- }, {
372
- key: "createSpaceBetweenWalls",
373
- value: function createSpaceBetweenWalls() {
374
- var _this6 = this;
375
-
376
- var walls = this.exteriorWalls.map(function (wallId) {
377
- return _this6.getParsedWallById(wallId);
378
- });
379
- var vertices = this.getVerticesFromParsedWalls(walls);
380
- var clippedDepth = (this.wallsHeight + 0.5) * clippedBuildingConstant + 0.006;
381
- var depth = this.wallsHeight + 0.002;
382
- var shapeWithHoles = new THREE.Shape(vertices);
383
- var shape = new THREE.Shape(vertices);
384
- this.rooms.forEach(function (_ref6) {
385
- var Walls = _ref6.Walls;
386
- var roomWalls = Walls.map(function (wallId) {
387
- return _this6.getParsedWallById(wallId);
388
- });
389
-
390
- var roomVertices = _this6.getVerticesFromParsedWalls(roomWalls);
391
-
392
- shapeWithHoles.holes.push(new THREE.Shape(roomVertices));
393
- });
394
- var clippedGeometry = new THREE.ExtrudeGeometry(shapeWithHoles, {
395
- depth: clippedDepth,
396
- bevelEnabled: false
397
- });
398
- var flatGeometry = new THREE.ExtrudeGeometry(shape, {
399
- depth: 0.001,
400
- bevelEnabled: false
401
- });
402
- var geometry = new THREE.ExtrudeGeometry(shapeWithHoles, {
403
- depth: depth,
404
- bevelEnabled: false
405
- });
406
- var clippedMaterial = createDefaultMaterial({
407
- side: THREE.DoubleSide,
408
- color: '#5C5C5C'
409
- });
410
- var material = createDefaultMaterial(_objectSpread(_objectSpread({}, this.wallMaterialOptions), {}, {
411
- color: '#5C5C5C'
412
- }));
413
- var clippedMesh = new THREE.Mesh(clippedGeometry, clippedMaterial);
414
- var flatMesh = new THREE.Mesh(flatGeometry, material);
415
- var mesh = new THREE.Mesh(geometry, material);
416
- flatMesh.receiveShadow = false;
417
- flatMesh.castShadow = false;
418
- clippedMesh.position.z = -0.005;
419
- flatMesh.position.z = -0.005;
420
- mesh.position.z = -0.001;
421
- var additionalApertureWidth = 0.25;
422
- var clippedMeshWithApertures = this.subtractApertures(clippedMesh, this.apertures, additionalApertureWidth);
423
- var meshWithApertures = this.subtractApertures(mesh, this.apertures, additionalApertureWidth);
424
- clippedMeshWithApertures.name = 'ClippedSpaceBetweenWalls';
425
- meshWithApertures.name = 'SpaceBetweenWalls';
426
- flatMesh.name = 'FlatSpaceBetweenWalls';
427
- clippedMeshWithApertures.receiveShadow = false;
428
- clippedMeshWithApertures.castShadow = false;
429
- meshWithApertures.receiveShadow = false;
430
- meshWithApertures.castShadow = false;
431
- this.houseGroup.add(flatMesh, clippedMeshWithApertures, meshWithApertures);
432
- return this;
433
- }
434
- }, {
435
- key: "createWalls",
436
- value: function createWalls() {
437
- var _this7 = this;
438
-
439
- var createWall = function createWall(wallId, isExterior) {
440
- var _this7$getParsedWallB = _this7.getParsedWallById(wallId),
441
- start = _this7$getParsedWallB.start,
442
- end = _this7$getParsedWallB.end;
443
-
444
- var wallHalfWidth = 0.005;
445
- var wallShape = new THREE.Shape([new THREE.Vector2(start.x + wallHalfWidth, start.y - wallHalfWidth), new THREE.Vector2(end.x + wallHalfWidth, end.y - wallHalfWidth), new THREE.Vector2(end.x - wallHalfWidth, end.y + wallHalfWidth), new THREE.Vector2(start.x - wallHalfWidth, start.y + wallHalfWidth)]);
446
- var wallGeometry = new THREE.ExtrudeGeometry(wallShape, {
447
- depth: _this7.wallsHeight,
448
- bevelEnabled: false
449
- });
450
- var wallPadGeometry = new THREE.ExtrudeGeometry(wallShape, {
451
- depth: 0.001,
452
- bevelEnabled: false
453
- });
454
- var wallMaterial = isExterior ? _this7.exteriorWallsMaterial : _this7.wallsMaterial;
455
- var wallPadMaterial = createDefaultMaterial(_objectSpread(_objectSpread({}, _this7.wallMaterialOptions), {}, {
456
- color: '#5C5C5C'
457
- }));
458
- var wallClippedPadMaterial = createDefaultMaterial({
459
- side: THREE.DoubleSide,
460
- color: '#5C5C5C'
461
- });
462
-
463
- var apertures = _this7.apertures.filter(function (aperture) {
464
- return aperture.Walls.some(function (id) {
465
- return wallId === id;
466
- });
467
- });
468
-
469
- var wallMesh = _this7.subtractApertures(new THREE.Mesh(wallGeometry, wallMaterial), apertures);
470
-
471
- var wallPadMesh = new THREE.Mesh(wallPadGeometry, wallPadMaterial);
472
- var wallClippedPadMesh = new THREE.Mesh(wallPadGeometry, wallClippedPadMaterial);
473
- wallMesh.castShadow = true;
474
- wallMesh.receiveShadow = !isExterior;
475
- wallPadMesh.castShadow = false;
476
- wallPadMesh.receiveShadow = false;
477
- wallClippedPadMesh.castShadow = false;
478
- wallClippedPadMesh.receiveShadow = false;
479
- wallPadMesh.position.z = _this7.wallsHeight;
480
- wallClippedPadMesh.position.z = (_this7.wallsHeight + 0.5) * clippedBuildingConstant + 0.001;
481
-
482
- var wallClippedPadMeshWithApertures = _this7.subtractApertures(wallClippedPadMesh, apertures);
483
-
484
- wallClippedPadMeshWithApertures.visible = false;
485
- wallClippedPadMeshWithApertures.castShadow = false;
486
- wallClippedPadMeshWithApertures.receiveShadow = false;
487
- var wallGroup = new THREE.Group();
488
- wallGroup.name = 'Wall';
489
- wallGroup.buildingId = wallId;
490
- wallGroup.isExterior = isExterior;
491
- wallGroup.add(wallMesh, wallPadMesh, wallClippedPadMeshWithApertures);
492
-
493
- _this7.wallsGroup.add(wallGroup);
494
- };
495
-
496
- this.exteriorWallsMaterial = createDefaultMaterial(_objectSpread(_objectSpread({}, this.wallMaterialOptions), {}, {
497
- map: this.exteriorWallsMaps.map,
498
- roughnessMap: this.exteriorWallsMaps.roughnessMap,
499
- color: '#FFFFFF'
500
- }));
501
- this.rooms.forEach(function (_ref7) {
502
- var Walls = _ref7.Walls;
503
- return Walls.forEach(function (wallId) {
504
- return createWall(wallId, false);
505
- });
506
- });
507
- this.exteriorWalls.forEach(function (wallId) {
508
- return createWall(wallId, true);
509
- });
510
- this.houseGroup.add(this.wallsGroup);
511
- return this;
512
- }
513
- }, {
514
- key: "createDoors",
515
- value: function createDoors() {
516
- var _this8 = this;
517
-
518
- this.doors.forEach(function (_ref8) {
519
- var Width = _ref8.Width,
520
- Location = _ref8.Location,
521
- Rotation = _ref8.Rotation;
522
- var geometry = new THREE.BoxGeometry(Width * _this8.sceneScale, 0.1, _this8.doorsHeight);
523
- var mesh = new THREE.Mesh(geometry, _this8.doorMaterial);
524
- mesh.position.x = Location.X * _this8.sceneScale;
525
- mesh.position.y = Location.Y * _this8.sceneScale;
526
- mesh.position.z = _this8.doorsHeight / 2;
527
- mesh.rotation.z = THREE.Math.degToRad(Rotation.Yaw);
528
- mesh.receiveShadow = true;
529
- mesh.castShadow = true;
530
-
531
- _this8.doorsGroup.add(mesh);
532
- });
533
- this.houseGroup.add(this.doorsGroup);
534
- return this;
535
- }
536
- }, {
537
- key: "subtractApertures",
538
- value: function subtractApertures(mesh, apertures) {
539
- var _this9 = this;
540
-
541
- var additionalWidth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
542
- var resultMesh = mesh;
543
- apertures.forEach(function (_ref9) {
544
- var Width = _ref9.Width,
545
- Depth = _ref9.Depth,
546
- Location = _ref9.Location,
547
- Rotation = _ref9.Rotation,
548
- Type = _ref9.Type;
549
- var isDoor = Type === 'Door';
550
- var apertureGeometry = new THREE.BoxGeometry((Width + additionalWidth) * _this9.sceneScale, Depth * _this9.sceneScale + 1, (isDoor ? _this9.doorsHeight : _this9.wallsHeight / 2) + additionalWidth * _this9.sceneScale);
551
- var apertureMaterial = createDefaultMaterial({
552
- color: '#00B4F7'
553
- });
554
- var apertureMesh = new THREE.Mesh(apertureGeometry, apertureMaterial);
555
- apertureMesh.rotation.z = THREE.Math.degToRad(Rotation.Yaw);
556
- apertureMesh.position.x = Location.X * _this9.sceneScale;
557
- apertureMesh.position.y = Location.Y * _this9.sceneScale;
558
- apertureMesh.position.z = isDoor ? _this9.doorsHeight / 2 : _this9.wallsHeight / 2;
559
- apertureMesh.updateMatrix();
560
- resultMesh.updateMatrix();
561
-
562
- var apertureBSP = _threeCsg.default.fromMesh(apertureMesh);
563
-
564
- var wallBSP = _threeCsg.default.fromMesh(resultMesh);
565
-
566
- var resultBSP = wallBSP.subtract(apertureBSP);
567
- resultMesh = _threeCsg.default.toMesh(resultBSP, mesh.matrix, resultMesh.material);
568
- });
569
- return resultMesh;
570
- }
571
- }, {
572
- key: "setCenterPosition",
573
- value: function setCenterPosition() {
574
- var _this10 = this;
575
-
576
- var walls = this.exteriorWalls.map(function (wallId) {
577
- return _this10.getParsedWallById(wallId);
578
- });
579
-
580
- var _getMinMaxCoordinates = (0, _modelHelpers.getMinMaxCoordinates)(walls),
581
- maxX = _getMinMaxCoordinates.maxX,
582
- minX = _getMinMaxCoordinates.minX,
583
- maxY = _getMinMaxCoordinates.maxY,
584
- minY = _getMinMaxCoordinates.minY;
585
-
586
- var centerX = (maxX + minX) / 2;
587
- var centerY = (maxY + minY) / 2;
588
- var lightsOffset = 25;
589
- this.houseGroup.position.set(-centerX, -centerY);
590
- var lights = [{
591
- x: centerX - lightsOffset,
592
- y: centerY - lightsOffset,
593
- z: this.wallsHeight * 3,
594
- power: 0.4,
595
- castShadow: true
596
- }, {
597
- x: centerX - lightsOffset,
598
- y: centerY - lightsOffset,
599
- z: this.wallsHeight * 2,
600
- power: 1,
601
- castShadow: false
602
- }, {
603
- x: centerX + lightsOffset,
604
- y: centerY + lightsOffset,
605
- z: this.wallsHeight * 2,
606
- power: 1.1,
607
- castShadow: false
608
- }, {
609
- x: centerX,
610
- y: centerY,
611
- z: this.wallsHeight * 5,
612
- power: 0.1,
613
- castShadow: false
614
- }];
615
- var targetObject = new THREE.Object3D();
616
- targetObject.position.set(centerX, centerY, 0);
617
- this.houseGroup.add(targetObject);
618
- lights.forEach(function (_ref10) {
619
- var x = _ref10.x,
620
- y = _ref10.y,
621
- z = _ref10.z,
622
- power = _ref10.power,
623
- castShadow = _ref10.castShadow;
624
- var light = new THREE.DirectionalLight(0xffffff, power);
625
- light.position.set(x, y, z);
626
- light.shadowLight = castShadow;
627
- light.castShadow = castShadow;
628
- light.shadow.camera.left = -centerX * 2;
629
- light.shadow.camera.right = centerX * 2;
630
- light.shadow.camera.top = centerY * 2;
631
- light.shadow.camera.bottom = -centerY * 2;
632
- light.shadow.camera.zoom = 1;
633
- light.shadow.mapSize = new THREE.Vector2(2048, 2048);
634
- light.shadow.normalBias = 1;
635
- light.target = targetObject;
636
-
637
- _this10.houseGroup.add(light);
638
- });
639
- return this;
640
- }
641
- }, {
642
- key: "loadTexture",
643
- value: function loadTexture(img) {
644
- var repeat = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [1, 1];
645
- var callback = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : function () {};
646
- this.textureLoader.load(img, function (texture) {
647
- texture.wrapS = texture.wrapT = THREE.RepeatWrapping;
648
- texture.repeat.set(repeat[0], repeat[1]);
649
- texture.flipY = false;
650
- callback(texture);
651
- });
652
- }
653
- }, {
654
- key: "loadTextures",
655
- value: function loadTextures() {
656
- var _this11 = this;
657
-
658
- var assets = [{
659
- img: _wallTexture.default,
660
- repeat: [0.5, 0.5],
661
- callback: function callback(texture) {
662
- _this11.wallsTextures.push({
663
- image: _wallTexture.default,
664
- texture: texture
665
- });
666
-
667
- _this11.wallsMaterial = createDefaultMaterial(_objectSpread(_objectSpread({}, _this11.wallMaterialOptions), {}, {
668
- map: texture
669
- }));
670
- }
671
- }, {
672
- img: _exteriorWallTexture.default,
673
- repeat: [1, 1],
674
- callback: function callback(texture) {
675
- _this11.wallsTextures.push({
676
- image: _exteriorWallTexture.default,
677
- texture: texture
678
- });
679
-
680
- _this11.exteriorWallsMaps.map = texture;
681
- }
682
- }, {
683
- img: _exteriorWallTextureRoughness.default,
684
- repeat: [1, 1],
685
- callback: function callback(texture) {
686
- _this11.wallsTextures.push({
687
- image: _exteriorWallTextureRoughness.default,
688
- texture: texture
689
- });
690
-
691
- _this11.exteriorWallsMaps.roughnessMap = texture;
692
- }
693
- }, {
694
- img: _doorTexture.default,
695
- repeat: [1, 1],
696
- callback: function callback(texture) {
697
- _this11.doorMaterial = createDefaultMaterial(_objectSpread(_objectSpread({}, doorMaterialOptions), {}, {
698
- map: texture
699
- }));
700
- }
701
- }];
702
- return Promise.all(assets.map(function (_ref11) {
703
- var img = _ref11.img,
704
- repeat = _ref11.repeat,
705
- callback = _ref11.callback;
706
- return new Promise(function (resolve) {
707
- _this11.loadTexture(img, repeat, function (texture) {
708
- callback(texture);
709
- resolve();
710
- });
711
- });
712
- }));
713
- }
714
- }, {
715
- key: "loadFurniture",
716
- value: function loadFurniture(index) {
717
- var _this12 = this;
718
-
719
- var furniture = this.furniture[index];
720
- if (!furniture) return;
721
- var furnitureData = this.furnitureData.find(function (_ref12) {
722
- var name = _ref12.name,
723
- type = _ref12.type;
724
- return name === furniture.Model && type === furniture.Type;
725
- });
726
-
727
- if (!furnitureData) {
728
- this.loadFurniture(index + 1);
729
- return;
730
- }
731
-
732
- var mesh = furnitureData.mesh,
733
- textures = furnitureData.textures;
734
- var modelPath = "".concat(this.apiStore.API_URL, "/storage/furniture/").concat(mesh);
735
- var Location = furniture.Location,
736
- Rotation = furniture.Rotation,
737
- ModelName = furniture.Model;
738
- var X = Location.X,
739
- Y = Location.Y,
740
- Z = Location.Z;
741
- var promises = textures.map(function (url) {
742
- var texturePath = "".concat(_this12.apiStore.API_URL, "/storage/furniture/").concat(url);
743
- return new Promise(function (resolve) {
744
- _this12.textureLoader.load(texturePath, function (texture) {
745
- return resolve(texture);
746
- });
747
- });
748
- });
749
-
750
- var onTexturesLoaded = function onTexturesLoaded(result, model) {
751
- var materialsCount = result.reduce(function (acc, _ref13) {
752
- var image = _ref13.image;
753
- if (!image.currentSrc.includes('_D.') && !image.currentSrc.includes('_DA.')) return acc;
754
- return acc += 1;
755
- }, 0);
756
-
757
- var createMaterial = function createMaterial(num) {
758
- var map = result.find(function (_ref14) {
759
- var image = _ref14.image;
760
- return image.currentSrc.includes("".concat(num, "_D.")) || image.currentSrc.includes("".concat(num, "_DA."));
761
- });
762
- var envMap = result.find(function (_ref15) {
763
- var image = _ref15.image;
764
- return image.currentSrc.includes("".concat(num, "_RMO."));
765
- });
766
- var normalMap = result.find(function (_ref16) {
767
- var image = _ref16.image;
768
- return image.currentSrc.includes("".concat(num, "_N."));
769
- });
770
- var material = new THREE.MeshStandardMaterial({
771
- roughness: 1,
772
- transparent: true
773
- });
774
- material.depthWrite = !(ModelName === 'Flower' && num === '01');
775
- if (map) material.map = map;
776
- if (envMap) material.envMap = envMap;
777
- if (normalMap) material.normalMap = normalMap;
778
- return material;
779
- };
780
-
781
- var materials = new THREE.MeshPhysicalMaterial({
782
- roughness: 1,
783
- clearcoat: 1,
784
- clearcoatRoughness: 1,
785
- reflectivity: 0,
786
- fog: false
787
- });
788
-
789
- if (materialsCount === 1) {
790
- materials = createMaterial('');
791
- }
792
-
793
- if (materialsCount > 1) {
794
- materials = _toConsumableArray(Array(materialsCount).keys()).map(function (i) {
795
- var num = i + 1;
796
- var realNum = num < 10 ? "0".concat(num) : num;
797
- return createMaterial(realNum);
798
- });
799
- }
800
-
801
- model.traverse(function (node) {
802
- if (node.isMesh) {
803
- node.material = materials;
804
- node.receiveShadow = true;
805
- node.castShadow = true;
806
- }
807
- });
808
-
809
- _this12.houseGroup.add(model);
810
-
811
- _this12.loadFurniture(index + 1);
812
- };
813
-
814
- var onModelLoaded = function onModelLoaded(originalModel) {
815
- var model = originalModel.clone();
816
- model.scale.set(_this12.sceneScale, _this12.sceneScale, _this12.sceneScale);
817
- model.position.set(X * _this12.sceneScale, Y * _this12.sceneScale, Z * _this12.sceneScale);
818
- model.rotation.set(Math.PI / 2, THREE.Math.degToRad(Rotation.Yaw), 0);
819
- var loadedTextures = _this12.loadedTextures[ModelName];
820
-
821
- if (loadedTextures) {
822
- onTexturesLoaded(loadedTextures, model);
823
- return;
824
- }
825
-
826
- Promise.all(promises).then(function (result) {
827
- onTexturesLoaded(result, model);
828
- _this12.loadedTextures[ModelName] = result;
829
- });
830
- };
831
-
832
- var loadedModel = this.loadedModels[ModelName];
833
-
834
- if (loadedModel) {
835
- onModelLoaded(loadedModel);
836
- return;
837
- }
838
-
839
- modelLoader.load(modelPath, function (model) {
840
- _this12.loadedModels[ModelName] = model;
841
- onModelLoaded(model);
842
- });
843
- } // Actions
844
-
845
- }, {
846
- key: "setShadowsVisibility",
847
- value: function setShadowsVisibility(value) {
848
- this.isShadowsVisible = value;
849
- this.houseGroup.children.forEach(function (node) {
850
- var isLight = node instanceof THREE.DirectionalLight;
851
- if (!isLight) return;
852
- if (!node.shadowLight) return;
853
- node.castShadow = value;
854
- });
855
- }
856
- }, {
857
- key: "setDoorsVisibility",
858
- value: function setDoorsVisibility(value) {
859
- this.isDoorsVisible = value;
860
- this.doorsGroup.children.forEach(function (door) {
861
- return door.visible = value;
862
- });
863
- }
864
- }, {
865
- key: "setCurrentWallsMaterialType",
866
- value: function setCurrentWallsMaterialType(value) {
867
- var _this13 = this;
868
-
869
- this.wallsMaterialType = value;
870
- this.wallsGroup.children.forEach(function (_ref17) {
871
- var children = _ref17.children,
872
- isExterior = _ref17.isExterior;
873
- var wall = children[0];
874
-
875
- if (value === 'texture') {
876
- wall.material = isExterior ? _this13.exteriorWallsMaterial : _this13.wallsMaterial;
877
- return;
878
- }
879
-
880
- var color = isExterior ? '#FFFFFF' : _this13.wallsColor;
881
- wall.material = createDefaultMaterial(_objectSpread(_objectSpread({}, _this13.wallMaterialOptions), {}, {
882
- color: color
883
- }));
884
- });
885
- this.doorsGroup.children.forEach(function (door) {
886
- if (value === 'texture') {
887
- door.material = _this13.doorMaterial;
888
- return;
889
- }
890
-
891
- door.material = createDefaultMaterial(doorMaterialOptions);
892
- });
893
- }
894
- }, {
895
- key: "setCurrentWallColor",
896
- value: function setCurrentWallColor(color) {
897
- this.wallsColor = color;
898
- this.wallsMaterial.color.set(color);
899
- this.wallsGroup.children.forEach(function (_ref18) {
900
- var children = _ref18.children,
901
- isExterior = _ref18.isExterior;
902
- if (isExterior) return;
903
- var wall = children[0];
904
- wall.material.color.set(color);
905
- });
906
- }
907
- }, {
908
- key: "setCurrentWallTexture",
909
- value: function setCurrentWallTexture(texture) {
910
- this.wallsMaterial = createDefaultMaterial(_objectSpread(_objectSpread({}, this.wallMaterialOptions), {}, {
911
- map: texture
912
- }));
913
- this.setCurrentWallsMaterialType('texture');
914
- }
915
- }, {
916
- key: "addWallTexture",
917
- value: function addWallTexture(image) {
918
- var _this14 = this;
919
-
920
- this.loadTexture(image, [0.5, 0.5], function (texture) {
921
- _this14.wallsTextures.push({
922
- image: image,
923
- texture: texture
924
- });
925
-
926
- _this14.setCurrentWallTexture(texture);
927
- });
928
- }
929
- }, {
930
- key: "setFullBuildingVisibility",
931
- value: function setFullBuildingVisibility(value) {
932
- this.isFullBuildingVisible = value;
933
- this.globalPlane.constant = this.isFullBuildingVisible ? 1 : clippedBuildingConstant;
934
- this.wallsGroup.children.forEach(function (_ref19) {
935
- var children = _ref19.children;
936
- return children[2].visible = !value;
937
- });
938
- }
939
- }, {
940
- key: "setPlanMode",
941
- value: function setPlanMode() {
942
- this.setDoorsVisibility(false);
943
- this.setFullBuildingVisibility(false);
944
- this.setCurrentWallsMaterialType('color');
945
- }
946
- }]);
947
-
948
- return HouseStore;
949
- }();
950
-
951
- var _default = HouseStore;
952
- exports.default = _default;
1
+ "use strict";function _typeof(e){return(_typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _react=_interopRequireDefault(require("react")),_mobx=require("mobx"),_apiStore=_interopRequireDefault(require("../store/apiStore")),_store=_interopRequireDefault(require("../store")),THREE=_interopRequireWildcard(require("three")),_FBXLoader=require("three/examples/jsm/loaders/FBXLoader"),_modelHelpers=require("../utils/modelHelpers"),_threeCsg=_interopRequireDefault(require("../utils/csg/three-csg")),_wallTexture=_interopRequireDefault(require("../assets/img/wall-texture.jpg")),_doorTexture=_interopRequireDefault(require("../assets/img/door-texture.jpeg")),_exteriorWallTexture=_interopRequireDefault(require("../assets/img/exterior-wall-texture.jpeg")),_exteriorWallTextureRoughness=_interopRequireDefault(require("../assets/img/exterior-wall-texture-roughness.jpg"));function _getRequireWildcardCache(e){if("function"!=typeof WeakMap)return null;var t=new WeakMap,r=new WeakMap;return(_getRequireWildcardCache=function(e){return e?r:t})(e)}function _interopRequireWildcard(e,t){if(!t&&e&&e.__esModule)return e;if(null===e||"object"!==_typeof(e)&&"function"!=typeof e)return{default:e};t=_getRequireWildcardCache(t);if(t&&t.has(e))return t.get(e);var r,a,o={},i=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(r in e)"default"!==r&&Object.prototype.hasOwnProperty.call(e,r)&&((a=i?Object.getOwnPropertyDescriptor(e,r):null)&&(a.get||a.set)?Object.defineProperty(o,r,a):o[r]=e[r]);return o.default=e,t&&t.set(e,o),o}function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}function _slicedToArray(e,t){return _arrayWithHoles(e)||_iterableToArrayLimit(e,t)||_unsupportedIterableToArray(e,t)||_nonIterableRest()}function _nonIterableRest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _iterableToArrayLimit(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var a,o,i=[],n=!0,l=!1;try{for(r=r.call(e);!(n=(a=r.next()).done)&&(i.push(a.value),!t||i.length!==t);n=!0);}catch(e){l=!0,o=e}finally{try{n||null==r.return||r.return()}finally{if(l)throw o}}return i}}function _arrayWithHoles(e){if(Array.isArray(e))return e}function _toConsumableArray(e){return _arrayWithoutHoles(e)||_iterableToArray(e)||_unsupportedIterableToArray(e)||_nonIterableSpread()}function _nonIterableSpread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(e,t){if(e){if("string"==typeof e)return _arrayLikeToArray(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);return"Map"===(r="Object"===r&&e.constructor?e.constructor.name:r)||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?_arrayLikeToArray(e,t):void 0}}function _iterableToArray(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function _arrayWithoutHoles(e){if(Array.isArray(e))return _arrayLikeToArray(e)}function _arrayLikeToArray(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,a=new Array(t);r<t;r++)a[r]=e[r];return a}function _classCallCheck(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function _defineProperties(e,t){for(var r=0;r<t.length;r++){var a=t[r];a.enumerable=a.enumerable||!1,a.configurable=!0,"value"in a&&(a.writable=!0),Object.defineProperty(e,a.key,a)}}function _createClass(e,t,r){return t&&_defineProperties(e.prototype,t),r&&_defineProperties(e,r),Object.defineProperty(e,"prototype",{writable:!1}),e}function ownKeys(t,e){var r,a=Object.keys(t);return Object.getOwnPropertySymbols&&(r=Object.getOwnPropertySymbols(t),e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),a.push.apply(a,r)),a}function _objectSpread(t){for(var e=1;e<arguments.length;e++){var r=null!=arguments[e]?arguments[e]:{};e%2?ownKeys(Object(r),!0).forEach(function(e){_defineProperty(t,e,r[e])}):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(r)):ownKeys(Object(r)).forEach(function(e){Object.defineProperty(t,e,Object.getOwnPropertyDescriptor(r,e))})}return t}function _defineProperty(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}(0,_mobx.configure)({useProxies:"never"});var clippedBuildingConstant=.4,doorMaterialOptions={color:"#DADADA",side:THREE.DoubleSide},modelLoader=new _FBXLoader.FBXLoader,createDefaultMaterial=function(e){return new THREE.MeshStandardMaterial(_objectSpread({roughness:1,metalness:0},e))},HouseStore=function(){function r(e){var t=this;_classCallCheck(this,r),_defineProperty(this,"modelStore",null),_defineProperty(this,"apiStore",new _apiStore.default(_store.default.config.API_URL)),_defineProperty(this,"houseGroup",new THREE.Group),_defineProperty(this,"wallsGroup",new THREE.Group),_defineProperty(this,"doorsGroup",new THREE.Group),_defineProperty(this,"doorMaterial",null),_defineProperty(this,"wallsMaterial",null),_defineProperty(this,"wallsColor","#FFFFFF"),_defineProperty(this,"exteriorWallsMaps",{map:null,roughnessMap:null}),_defineProperty(this,"exteriorWallsMaterial",null),_defineProperty(this,"wallsTextures",[]),_defineProperty(this,"isDoorsVisible",!0),_defineProperty(this,"isFullBuildingVisible",!0),_defineProperty(this,"wallsMaterialType","texture"),_defineProperty(this,"globalPlane",null),_defineProperty(this,"clippingPlanes",[]),_defineProperty(this,"furnitureData",[]),_defineProperty(this,"loadedModels",{}),_defineProperty(this,"loadedTextures",{}),_defineProperty(this,"isShadowsVisible",!0),(0,_mobx.makeAutoObservable)(this),this.modelStore=e,this.houseGroup.name="House-Group",this.globalPlane=new THREE.Plane(new THREE.Vector3(0,-this.wallsHeight-.5,0),1),this.clippingPlanes=[this.globalPlane],this.setCenterPosition().loadTextures().then(function(){t.createFloors().createSpaceBetweenWalls().createWalls().createDoors()}),this.apiStore.loadFurnitureData().then(function(e){t.furnitureData=e,t.loadFurniture(0)})}return _createClass(r,[{key:"textureLoader",get:function(){return this.modelStore.textureLoader}},{key:"sceneScale",get:function(){return this.modelStore.sceneScale}},{key:"wallsHeight",get:function(){return this.modelStore.wallsHeight}},{key:"json",get:function(){return this.modelStore.json}},{key:"vertices",get:function(){return this.json.Vertices}},{key:"rooms",get:function(){return this.json.Floors[0].Units[0].Rooms}},{key:"walls",get:function(){return this.json.Floors[0].Walls}},{key:"exteriorWalls",get:function(){return this.json.Floors[0].ExteriorWalls}},{key:"doors",get:function(){var t=this;return this.json.Floors[0].Doors.map(function(e){return t.getParsedAperture(e,"Door")})}},{key:"windows",get:function(){var t=this;return this.json.Floors[0].Windows.map(function(e){return t.getParsedAperture(e,"Window")})}},{key:"apertures",get:function(){return[].concat(_toConsumableArray(this.doors),_toConsumableArray(this.windows))}},{key:"doorsHeight",get:function(){return this.wallsHeight/2+this.wallsHeight/4}},{key:"wallMaterialOptions",get:function(){return{clippingPlanes:this.clippingPlanes,color:this.wallsColor,side:THREE.DoubleSide}}},{key:"furniture",get:function(){return this.rooms.reduce(function(e,t){t=t.Furniture;return t&&t.length?[].concat(_toConsumableArray(e),_toConsumableArray(t)):e},[])}},{key:"getVertexById",value:function(t){return this.vertices.find(function(e){return e.ID===t})}},{key:"getWallById",value:function(t){return this.walls.find(function(e){return e.ID===t})}},{key:"getParsedAperture",value:function(e,t){var r=e.Location,a=e.Walls,r=new THREE.Vector3(r.X,r.Y,r.Z),a=this.getParsedWallById(a[1],1),a=new THREE.Line3(a.start,a.end),o=new THREE.Vector3,a=(a.closestPointToPoint(r,!0,o),new THREE.Line3(r,o)),r=a.distance(),a=a.getCenter(o);return _objectSpread(_objectSpread({},e),{},{Type:t,Depth:r,Location:{X:a.x,Y:a.y,Z:a.z}})}},{key:"getParsedWallById",value:function(e){var t=this,r=1<arguments.length&&void 0!==arguments[1]?arguments[1]:this.sceneScale,a=_slicedToArray(this.getWallById(e).Vertices.map(function(e){return t.getVertexById(e).Location}),2),o=a[0],a=a[1];return{id:e,start:{x:o.X*r,y:o.Y*r,z:0},end:{x:a.X*r,y:a.Y*r,z:0}}}},{key:"getVerticesFromParsedWalls",value:function(e){return e.reduce(function(e,t){var r=t.start,t=t.end;return e.push(new THREE.Vector2(r.x,r.y),new THREE.Vector2(t.x,t.y)),e},[])}},{key:"createFloors",value:function(){var i=this;return this.rooms.forEach(function(e){function r(e,t){e=createDefaultMaterial({color:a.color,side:THREE.DoubleSide,map:e}),o.material=e,t&&(o.material.roughnessMap=t),i.houseGroup.add(o)}var t=e.Walls,e=e.Type,t=t.map(function(e){return i.getParsedWallById(e)}),a=(0,_modelHelpers.getFloorParams)(e),e=i.getVerticesFromParsedWalls(t),t=new THREE.Shape(e),e=new THREE.ShapeGeometry(t),t=createDefaultMaterial({color:a.color,side:THREE.DoubleSide}),o=new THREE.Mesh(e,t);o.receiveShadow=!0,o.castShadow=!1,o.name="FloorMesh";i.loadTexture(a.texture,[.5,.5],function(t){a.roughnessMap?i.loadTexture(a.roughnessMap,[.5,.5],function(e){return r(t,e)}):r(t)})}),this}},{key:"createSpaceBetweenWalls",value:function(){var t=this,e=this.exteriorWalls.map(function(e){return t.getParsedWallById(e)}),e=this.getVerticesFromParsedWalls(e),r=(this.wallsHeight+.5)*clippedBuildingConstant+.006,a=this.wallsHeight+.002,o=new THREE.Shape(e),e=new THREE.Shape(e),r=(this.rooms.forEach(function(e){e=e.Walls.map(function(e){return t.getParsedWallById(e)}),e=t.getVerticesFromParsedWalls(e);o.holes.push(new THREE.Shape(e))}),new THREE.ExtrudeGeometry(o,{depth:r,bevelEnabled:!1})),e=new THREE.ExtrudeGeometry(e,{depth:.001,bevelEnabled:!1}),a=new THREE.ExtrudeGeometry(o,{depth:a,bevelEnabled:!1}),i=createDefaultMaterial({side:THREE.DoubleSide,color:"#5C5C5C"}),n=createDefaultMaterial(_objectSpread(_objectSpread({},this.wallMaterialOptions),{},{color:"#5C5C5C"})),r=new THREE.Mesh(r,i),i=new THREE.Mesh(e,n),e=new THREE.Mesh(a,n),a=(i.receiveShadow=!1,i.castShadow=!1,r.position.z=-.005,i.position.z=-.005,e.position.z=-.001,this.subtractApertures(r,this.apertures,.25)),n=this.subtractApertures(e,this.apertures,.25);return a.name="ClippedSpaceBetweenWalls",n.name="SpaceBetweenWalls",i.name="FlatSpaceBetweenWalls",a.receiveShadow=!1,a.castShadow=!1,n.receiveShadow=!1,n.castShadow=!1,this.houseGroup.add(i,a,n),this}},{key:"createWalls",value:function(){function t(t,e){var r=(a=s.getParsedWallById(t)).start,a=a.end,o=.005,a=new THREE.Shape([new THREE.Vector2(r.x+o,r.y-o),new THREE.Vector2(a.x+o,a.y-o),new THREE.Vector2(a.x-o,a.y+o),new THREE.Vector2(r.x-o,r.y+o)]),r=new THREE.ExtrudeGeometry(a,{depth:s.wallsHeight,bevelEnabled:!1}),o=new THREE.ExtrudeGeometry(a,{depth:.001,bevelEnabled:!1}),a=e?s.exteriorWallsMaterial:s.wallsMaterial,i=createDefaultMaterial(_objectSpread(_objectSpread({},s.wallMaterialOptions),{},{color:"#5C5C5C"})),n=createDefaultMaterial({side:THREE.DoubleSide,color:"#5C5C5C"}),l=s.apertures.filter(function(e){return e.Walls.some(function(e){return t===e})}),r=s.subtractApertures(new THREE.Mesh(r,a),l),a=new THREE.Mesh(o,i),i=new THREE.Mesh(o,n);r.castShadow=!0,r.receiveShadow=!e,a.castShadow=!1,a.receiveShadow=!1,i.castShadow=!1,i.receiveShadow=!1,a.position.z=s.wallsHeight,i.position.z=(s.wallsHeight+.5)*clippedBuildingConstant+.001,(o=s.subtractApertures(i,l)).visible=!1,o.castShadow=!1,o.receiveShadow=!1,(n=new THREE.Group).name="Wall",n.buildingId=t,n.isExterior=e,n.add(r,a,o),s.wallsGroup.add(n)}var s=this;return this.exteriorWallsMaterial=createDefaultMaterial(_objectSpread(_objectSpread({},this.wallMaterialOptions),{},{map:this.exteriorWallsMaps.map,roughnessMap:this.exteriorWallsMaps.roughnessMap,color:"#FFFFFF"})),this.rooms.forEach(function(e){return e.Walls.forEach(function(e){return t(e,!1)})}),this.exteriorWalls.forEach(function(e){return t(e,!0)}),this.houseGroup.add(this.wallsGroup),this}},{key:"createDoors",value:function(){var a=this;return this.doors.forEach(function(e){var t=e.Width,r=e.Location,e=e.Rotation,t=new THREE.BoxGeometry(t*a.sceneScale,.1,a.doorsHeight),t=new THREE.Mesh(t,a.doorMaterial);t.position.x=r.X*a.sceneScale,t.position.y=r.Y*a.sceneScale,t.position.z=a.doorsHeight/2,t.rotation.z=THREE.Math.degToRad(e.Yaw),t.receiveShadow=!0,t.castShadow=!0,a.doorsGroup.add(t)}),this.houseGroup.add(this.doorsGroup),this}},{key:"subtractApertures",value:function(i,e){var n=this,l=2<arguments.length&&void 0!==arguments[2]?arguments[2]:0,s=i;return e.forEach(function(e){var t=e.Width,r=e.Depth,a=e.Location,o=e.Rotation,e="Door"===e.Type,t=new THREE.BoxGeometry((t+l)*n.sceneScale,r*n.sceneScale+1,(e?n.doorsHeight:n.wallsHeight/2)+l*n.sceneScale),r=createDefaultMaterial({color:"#00B4F7"}),t=new THREE.Mesh(t,r),r=(t.rotation.z=THREE.Math.degToRad(o.Yaw),t.position.x=a.X*n.sceneScale,t.position.y=a.Y*n.sceneScale,t.position.z=e?n.doorsHeight/2:n.wallsHeight/2,t.updateMatrix(),s.updateMatrix(),_threeCsg.default.fromMesh(t)),o=_threeCsg.default.fromMesh(s).subtract(r);s=_threeCsg.default.toMesh(o,i.matrix,s.material)}),s}},{key:"setCenterPosition",value:function(){var i=this,e=this.exteriorWalls.map(function(e){return i.getParsedWallById(e)}),e=(0,_modelHelpers.getMinMaxCoordinates)(e),t=e.maxX,r=e.minX,a=e.maxY,e=e.minY,n=(t+r)/2,l=(a+e)/2,t=(this.houseGroup.position.set(-n,-l),[{x:n-25,y:l-25,z:3*this.wallsHeight,power:.4,castShadow:!0},{x:n-25,y:l-25,z:2*this.wallsHeight,power:1,castShadow:!1},{x:25+n,y:25+l,z:2*this.wallsHeight,power:1.1,castShadow:!1},{x:n,y:l,z:5*this.wallsHeight,power:.1,castShadow:!1}]),s=new THREE.Object3D;return s.position.set(n,l,0),this.houseGroup.add(s),t.forEach(function(e){var t=e.x,r=e.y,a=e.z,o=e.power,e=e.castShadow,o=new THREE.DirectionalLight(16777215,o);o.position.set(t,r,a),o.shadowLight=e,o.castShadow=e,o.shadow.camera.left=2*-n,o.shadow.camera.right=2*n,o.shadow.camera.top=2*l,o.shadow.camera.bottom=2*-l,o.shadow.camera.zoom=1,o.shadow.mapSize=new THREE.Vector2(2048,2048),o.shadow.normalBias=1,o.target=s,i.houseGroup.add(o)}),this}},{key:"loadTexture",value:function(e){var t=1<arguments.length&&void 0!==arguments[1]?arguments[1]:[1,1],r=2<arguments.length&&void 0!==arguments[2]?arguments[2]:function(){};this.textureLoader.load(e,function(e){e.wrapS=e.wrapT=THREE.RepeatWrapping,e.repeat.set(t[0],t[1]),e.flipY=!1,r(e)})}},{key:"loadTextures",value:function(){var i=this,e=[{img:_wallTexture.default,repeat:[.5,.5],callback:function(e){i.wallsTextures.push({image:_wallTexture.default,texture:e}),i.wallsMaterial=createDefaultMaterial(_objectSpread(_objectSpread({},i.wallMaterialOptions),{},{map:e}))}},{img:_exteriorWallTexture.default,repeat:[1,1],callback:function(e){i.wallsTextures.push({image:_exteriorWallTexture.default,texture:e}),i.exteriorWallsMaps.map=e}},{img:_exteriorWallTextureRoughness.default,repeat:[1,1],callback:function(e){i.wallsTextures.push({image:_exteriorWallTextureRoughness.default,texture:e}),i.exteriorWallsMaps.roughnessMap=e}},{img:_doorTexture.default,repeat:[1,1],callback:function(e){i.doorMaterial=createDefaultMaterial(_objectSpread(_objectSpread({},doorMaterialOptions),{},{map:e}))}}];return Promise.all(e.map(function(e){var r=e.img,a=e.repeat,o=e.callback;return new Promise(function(t){i.loadTexture(r,a,function(e){o(e),t()})})}))}},{key:"loadFurniture",value:function(o){var e,t,r,n,a,i,l,s,u,c,d,h=this,p=this.furniture[o];p&&((e=this.furnitureData.find(function(e){var t=e.name,e=e.type;return t===p.Model&&e===p.Type}))?(t=e.mesh,e=e.textures,t="".concat(this.apiStore.API_URL,"/storage/furniture/").concat(t),d=p.Location,r=p.Rotation,n=p.Model,a=d.X,i=d.Y,l=d.Z,s=e.map(function(e){var r="".concat(h.apiStore.API_URL,"/storage/furniture/").concat(e);return new Promise(function(t){h.textureLoader.load(r,function(e){return t(e)})})}),u=function(i,e){function t(t){var e=i.find(function(e){e=e.image;return e.currentSrc.includes("".concat(t,"_D."))||e.currentSrc.includes("".concat(t,"_DA."))}),r=i.find(function(e){return e.image.currentSrc.includes("".concat(t,"_RMO."))}),a=i.find(function(e){return e.image.currentSrc.includes("".concat(t,"_N."))}),o=new THREE.MeshStandardMaterial({roughness:1,transparent:!0});return o.depthWrite=!("Flower"===n&&"01"===t),e&&(o.map=e),r&&(o.envMap=r),a&&(o.normalMap=a),o}var r=i.reduce(function(e,t){t=t.image;return t.currentSrc.includes("_D.")||t.currentSrc.includes("_DA.")?e+1:e},0),a=new THREE.MeshPhysicalMaterial({roughness:1,clearcoat:1,clearcoatRoughness:1,reflectivity:0,fog:!1});1===r&&(a=t("")),1<r&&(a=_toConsumableArray(Array(r).keys()).map(function(e){e+=1,e=e<10?"0".concat(e):e;return t(e)})),e.traverse(function(e){e.isMesh&&(e.material=a,e.receiveShadow=!0,e.castShadow=!0)}),h.houseGroup.add(e),h.loadFurniture(o+1)},c=function(e){var t=e.clone(),e=(t.scale.set(h.sceneScale,h.sceneScale,h.sceneScale),t.position.set(a*h.sceneScale,i*h.sceneScale,l*h.sceneScale),t.rotation.set(Math.PI/2,THREE.Math.degToRad(r.Yaw),0),h.loadedTextures[n]);e?u(e,t):Promise.all(s).then(function(e){u(e,t),h.loadedTextures[n]=e})},(d=this.loadedModels[n])?c(d):modelLoader.load(t,function(e){h.loadedModels[n]=e,c(e)})):this.loadFurniture(o+1))}},{key:"setShadowsVisibility",value:function(t){this.isShadowsVisible=t,this.houseGroup.children.forEach(function(e){e instanceof THREE.DirectionalLight&&e.shadowLight&&(e.castShadow=t)})}},{key:"setDoorsVisibility",value:function(t){this.isDoorsVisible=t,this.doorsGroup.children.forEach(function(e){return e.visible=t})}},{key:"setCurrentWallsMaterialType",value:function(r){var a=this;this.wallsMaterialType=r,this.wallsGroup.children.forEach(function(e){var t=e.children,e=e.isExterior,t=t[0];"texture"===r?t.material=e?a.exteriorWallsMaterial:a.wallsMaterial:(e=e?"#FFFFFF":a.wallsColor,t.material=createDefaultMaterial(_objectSpread(_objectSpread({},a.wallMaterialOptions),{},{color:e})))}),this.doorsGroup.children.forEach(function(e){e.material="texture"===r?a.doorMaterial:createDefaultMaterial(doorMaterialOptions)})}},{key:"setCurrentWallColor",value:function(r){this.wallsColor=r,this.wallsMaterial.color.set(r),this.wallsGroup.children.forEach(function(e){var t=e.children;e.isExterior||t[0].material.color.set(r)})}},{key:"setCurrentWallTexture",value:function(e){this.wallsMaterial=createDefaultMaterial(_objectSpread(_objectSpread({},this.wallMaterialOptions),{},{map:e})),this.setCurrentWallsMaterialType("texture")}},{key:"addWallTexture",value:function(t){var r=this;this.loadTexture(t,[.5,.5],function(e){r.wallsTextures.push({image:t,texture:e}),r.setCurrentWallTexture(e)})}},{key:"setFullBuildingVisibility",value:function(t){this.isFullBuildingVisible=t,this.globalPlane.constant=this.isFullBuildingVisible?1:clippedBuildingConstant,this.wallsGroup.children.forEach(function(e){return e.children[2].visible=!t})}},{key:"setPlanMode",value:function(){this.setDoorsVisibility(!1),this.setFullBuildingVisibility(!1),this.setCurrentWallsMaterialType("color")}}]),r}(),_default=HouseStore;exports.default=_default;
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["store/houseStore.js"],"names":["_react","_interopRequireDefault","require","_mobx","_apiStore","_store","THREE","_interopRequireWildcard","_FBXLoader","_modelHelpers","_threeCsg","_wallTexture","_doorTexture","_exteriorWallTexture","_exteriorWallTextureRoughness","configure","useProxies","clippedBuildingConstant","doorMaterialOptions","color","side","DoubleSide","modelLoader","FBXLoader","createDefaultMaterial","options","MeshStandardMaterial","_objectSpread","roughness","metalness","HouseStore","modelStore","_this","this","_classCallCheck","_defineProperty","ApiStore","store","config","API_URL","Group","map","roughnessMap","makeAutoObservable","houseGroup","name","globalPlane","Plane","Vector3","wallsHeight","clippingPlanes","setCenterPosition","loadTextures","then","createFloors","createSpaceBetweenWalls","createWalls","createDoors","resp","loadFurniture","textureLoader","json","Vertices","Floors","Units","Rooms","Walls","ExteriorWalls","_this2","Doors","door","getParsedAperture","_this3","Windows","window","concat","_toConsumableArray","doors","windows","wallsColor","rooms","reduce","acc","_ref","Furniture","length","find","_ref2","vertexId","wallId","apiStore","loadFurnitureData","type","Location","aperture","position","X","Y","Z","secondWall","getParsedWallById","line","Line3","start","end","positionOnFirstWall","lineBetweenWalls","closestPointToPoint","distanceBetweenWalls","distance","positionBetweenWalls","getCenter","Type","Depth","x","y","z","_this4","scale","arguments","undefined","sceneScale","_currentWall$Vertices2","_slicedToArray","getVertexById","coord1","coord2","id","walls","_ref4","push","Vector2","_this5","forEach","_ref5","callback","texture","textureMaterial","params","mesh","material","add","getFloorParams","vertices","shape","Shape","geometry","ShapeGeometry","Mesh","receiveShadow","castShadow","loadTexture","_this6","exteriorWalls","getVerticesFromParsedWalls","clippedDepth","clippedGeometry","_ref6","roomWalls","roomVertices","shapeWithHoles","ExtrudeGeometry","bevelEnabled","flatGeometry","depth","clippedMaterial","wallMaterialOptions","clippedMesh","ID","flatMesh","clippedMeshWithApertures","subtractApertures","apertures","meshWithApertures","isExterior","_this7$getParsedWallB","wallHalfWidth","wallShape","parsedAperture","wallGeometry","_this7","wallPadGeometry","wallMaterial","exteriorWallsMaterial","wallsMaterial","wallPadMaterial","filter","some","wallMesh","wallPadMesh","wallClippedPadMesh","wallClippedPadMaterial","wallClippedPadMeshWithApertures","visible","wallGroup","buildingId","wallsGroup","exteriorWallsMaps","_ref7","createWall","_this8","_ref8","Width","BoxGeometry","doorsHeight","doorMaterial","doorsGroup","_this9","additionalWidth","resultMesh","_ref9","Rotation","isDoor","apertureGeometry","apertureMaterial","apertureMesh","apertureBSP","rotation","Math","degToRad","Yaw","updateMatrix","CSG","fromMesh","resultBSP","subtract","toMesh","matrix","_this10","_getMinMaxCoordinates","minX","centerX","centerY","maxY","lights","power","Object3D","targetObject","set","_ref10","light","DirectionalLight","shadow","camera","left","right","bottom","zoom","mapSize","normalBias","target","repeat","additionalApertureWidth","assets","img","WallTextureImg","_this11","wallsTextures","image","ExteriorWallTextureImg","ExteriorWallTextureRoughnessImg","DoorTexture","Promise","_ref11","resolve","index","textures","ModelName","loadedModel","_ref12","furniture","Model","furnitureData","_this12","url","createMaterial","num","currentSrc","includes","envMap","_ref15","normalMap","result","_ref16","transparent","depthWrite","_ref13","materials","clearcoat","clearcoatRoughness","materialsCount","keys","i","realNum","model","traverse","node","originalModel","clone","onTexturesLoaded","loadedTextures","all","promises","wallBSP","loadedModels","onModelLoaded","load","modelPath","maxX","isShadowsVisible","minY","lightsOffset","value","isDoorsVisible","children","_this13","wallsMaterialType","_ref17","wall","shadowLight","_ref18","_this14","setCurrentWallTexture","isFullBuildingVisible","constant","wrapT","_ref19","setDoorsVisibility","setFullBuildingVisibility","setCurrentWallsMaterialType"],"mappings":"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","file":"store/houseStore.js","sourcesContent":["import React from 'react';\nimport { configure, makeAutoObservable } from 'mobx';\nimport ApiStore from '../store/apiStore';\nimport store from '../store';\nimport * as THREE from 'three';\nimport { FBXLoader } from 'three/examples/jsm/loaders/FBXLoader';\nimport { getFloorParams, getMinMaxCoordinates } from '../utils/modelHelpers';\nimport CSG from '../utils/csg/three-csg';\n\nimport WallTextureImg from '../assets/img/wall-texture.jpg';\nimport DoorTexture from '../assets/img/door-texture.jpeg';\nimport ExteriorWallTextureImg from '../assets/img/exterior-wall-texture.jpeg';\nimport ExteriorWallTextureRoughnessImg from '../assets/img/exterior-wall-texture-roughness.jpg';\n\nconfigure({ useProxies: 'never' });\n\nconst clippedBuildingConstant = 0.4;\n\nconst doorMaterialOptions = { color: '#DADADA', side: THREE.DoubleSide };\n\nconst modelLoader = new FBXLoader();\n\nconst createDefaultMaterial = (options) => new THREE.MeshStandardMaterial({\n  roughness: 1,\n  metalness: 0,\n  ...options,\n});\n\nclass HouseStore {\n  modelStore = null;\n  apiStore = new ApiStore(store.config.API_URL);\n\n  houseGroup = new THREE.Group();\n  wallsGroup = new THREE.Group();\n  doorsGroup = new THREE.Group();\n\n  doorMaterial = null;\n  wallsMaterial = null;\n  wallsColor = '#FFFFFF';\n  exteriorWallsMaps = { map: null, roughnessMap: null };\n  exteriorWallsMaterial = null;\n\n  wallsTextures = [];\n\n  isDoorsVisible = true;\n  isFullBuildingVisible = true;\n  wallsMaterialType = 'texture';\n\n  globalPlane = null;\n  clippingPlanes = [];\n\n  furnitureData = [];\n  loadedModels = {};\n  loadedTextures = {};\n\n  isShadowsVisible = true;\n\n  constructor(modelStore) {\n    makeAutoObservable(this);\n\n    this.modelStore = modelStore;\n\n    this.houseGroup.name = 'House-Group';\n\n    this.globalPlane = new THREE.Plane(new THREE.Vector3(0, -this.wallsHeight - 0.5, 0), 1);\n    this.clippingPlanes = [this.globalPlane];\n\n    this.setCenterPosition().loadTextures().then(() => {\n      this.createFloors().createSpaceBetweenWalls().createWalls().createDoors();\n    });\n\n    this.apiStore.loadFurnitureData().then((resp) => {\n      this.furnitureData = resp;\n      this.loadFurniture(0);\n    });\n  }\n\n  get textureLoader() {\n    return this.modelStore.textureLoader;\n  }\n\n  get sceneScale() {\n    return this.modelStore.sceneScale;\n  }\n\n  get wallsHeight() {\n    return this.modelStore.wallsHeight;\n  }\n\n  get json() {\n    return this.modelStore.json;\n  }\n\n  get vertices() {\n    return this.json.Vertices;\n  }\n\n  get rooms() {\n    return this.json.Floors[0].Units[0].Rooms;\n  }\n\n  get walls() {\n    return this.json.Floors[0].Walls;\n  }\n\n  get exteriorWalls() {\n    return this.json.Floors[0].ExteriorWalls;\n  }\n\n  get doors() {\n    return this.json.Floors[0].Doors.map((door) => this.getParsedAperture(door, 'Door'));\n  }\n\n  get windows() {\n    return this.json.Floors[0].Windows.map((window) => this.getParsedAperture(window, 'Window'));\n  }\n\n  get apertures() {\n    return [...this.doors, ...this.windows];\n  }\n\n  get doorsHeight() {\n    return (this.wallsHeight / 2) + (this.wallsHeight / 4);\n  }\n\n  get wallMaterialOptions() {\n    return {\n      clippingPlanes: this.clippingPlanes,\n      color: this.wallsColor,\n      side: THREE.DoubleSide,\n    };\n  }\n\n  get furniture() {\n    return this.rooms.reduce((acc, { Furniture }) => {\n      if (!Furniture || !Furniture.length) return acc;\n      return [...acc, ...Furniture];\n    }, []);\n  }\n\n  getVertexById(vertexId) {\n    return this.vertices.find(({ ID }) => ID === vertexId);\n  }\n\n  getWallById(wallId) {\n    return this.walls.find(({ ID }) => ID === wallId);\n  }\n\n  getParsedAperture(aperture, type) {\n    const { Location, Walls } = aperture;\n    const position = new THREE.Vector3(Location.X, Location.Y, Location.Z);\n    const secondWall = this.getParsedWallById(Walls[1], 1);\n    const line = new THREE.Line3(secondWall.start, secondWall.end);\n    const positionOnFirstWall = new THREE.Vector3();\n    line.closestPointToPoint(position, true, positionOnFirstWall);\n    const lineBetweenWalls = new THREE.Line3(position, positionOnFirstWall);\n    const distanceBetweenWalls = lineBetweenWalls.distance();\n    const positionBetweenWalls = lineBetweenWalls.getCenter(positionOnFirstWall);\n\n    const parsedAperture = {\n      ...aperture,\n      Type: type,\n      Depth: distanceBetweenWalls,\n      Location: { X: positionBetweenWalls.x, Y: positionBetweenWalls.y, Z: positionBetweenWalls.z },\n    };\n\n    return parsedAperture;\n  }\n\n  getParsedWallById(wallId, scale = this.sceneScale) {\n    const currentWall = this.getWallById(wallId);\n    const [coord1, coord2] = currentWall.Vertices.map((vertexId) => this.getVertexById(vertexId).Location);\n    return {\n      id: wallId,\n      start: { x: coord1.X * scale, y: coord1.Y * scale, z: 0 },\n      end: { x: coord2.X * scale, y: coord2.Y * scale, z: 0 },\n    };\n  }\n\n  getVerticesFromParsedWalls(walls) {\n    return walls.reduce((acc, { start, end }) => {\n      acc.push(new THREE.Vector2(start.x, start.y), new THREE.Vector2(end.x, end.y));\n      return acc;\n    }, []);\n  }\n\n  createFloors() {\n    this.rooms.forEach(({ Walls, Type }) => {\n      const walls = Walls.map((wallId) => this.getParsedWallById(wallId));\n      const params = getFloorParams(Type);\n      const vertices = this.getVerticesFromParsedWalls(walls);\n\n      const shape = new THREE.Shape(vertices);\n      const geometry = new THREE.ShapeGeometry(shape);\n      const material = createDefaultMaterial({ color: params.color, side: THREE.DoubleSide });\n      const mesh = new THREE.Mesh(geometry, material);\n      mesh.receiveShadow = true;\n      mesh.castShadow = false;\n      mesh.name = 'FloorMesh';\n\n      const callback = (texture, roughnessMap) => {\n        const textureMaterial = createDefaultMaterial({ color: params.color, side: THREE.DoubleSide, map: texture });\n        mesh.material = textureMaterial;\n        if (roughnessMap) mesh.material.roughnessMap = roughnessMap;\n\n        this.houseGroup.add(mesh);\n      };\n\n      this.loadTexture(params.texture, [0.5, 0.5], (texture) => {\n        if (!params.roughnessMap) {\n          callback(texture);\n          return;\n        }\n        this.loadTexture(params.roughnessMap, [0.5, 0.5], (roughnessMap) => callback(texture, roughnessMap));\n      });\n    });\n\n    return this;\n  }\n\n  createSpaceBetweenWalls() {\n    const walls = this.exteriorWalls.map((wallId) => this.getParsedWallById(wallId));\n    const vertices = this.getVerticesFromParsedWalls(walls);\n    const clippedDepth = ((this.wallsHeight + 0.5) * clippedBuildingConstant) + 0.006;\n    const depth = this.wallsHeight + 0.002;\n\n    const shapeWithHoles = new THREE.Shape(vertices);\n    const shape = new THREE.Shape(vertices);\n\n    this.rooms.forEach(({ Walls }) => {\n      const roomWalls = Walls.map((wallId) => this.getParsedWallById(wallId));\n      const roomVertices = this.getVerticesFromParsedWalls(roomWalls);\n      shapeWithHoles.holes.push(new THREE.Shape(roomVertices));\n    });\n\n    const clippedGeometry = new THREE.ExtrudeGeometry(shapeWithHoles, { depth: clippedDepth, bevelEnabled: false });\n    const flatGeometry = new THREE.ExtrudeGeometry(shape, { depth: 0.001, bevelEnabled: false });\n    const geometry = new THREE.ExtrudeGeometry(shapeWithHoles, { depth, bevelEnabled: false });\n\n    const clippedMaterial = createDefaultMaterial({ side: THREE.DoubleSide, color: '#5C5C5C' });\n    const material = createDefaultMaterial({ ...this.wallMaterialOptions, color: '#5C5C5C' });\n\n    const clippedMesh = new THREE.Mesh(clippedGeometry, clippedMaterial);\n    const flatMesh = new THREE.Mesh(flatGeometry, material);\n    const mesh = new THREE.Mesh(geometry, material);\n\n    flatMesh.receiveShadow = false;\n    flatMesh.castShadow = false;\n\n    clippedMesh.position.z = -0.005;\n    flatMesh.position.z = -0.005;\n    mesh.position.z = -0.001;\n\n    const additionalApertureWidth = 0.25;\n    const clippedMeshWithApertures = this.subtractApertures(clippedMesh, this.apertures, additionalApertureWidth);\n    const meshWithApertures = this.subtractApertures(mesh, this.apertures, additionalApertureWidth);\n    clippedMeshWithApertures.name = 'ClippedSpaceBetweenWalls';\n    meshWithApertures.name = 'SpaceBetweenWalls';\n    flatMesh.name = 'FlatSpaceBetweenWalls';\n\n    clippedMeshWithApertures.receiveShadow = false;\n    clippedMeshWithApertures.castShadow = false;\n    meshWithApertures.receiveShadow = false;\n    meshWithApertures.castShadow = false;\n\n    this.houseGroup.add(flatMesh, clippedMeshWithApertures, meshWithApertures);\n\n    return this;\n  }\n\n  createWalls() {\n    const createWall = (wallId, isExterior) => {\n      const { start, end } = this.getParsedWallById(wallId);\n      const wallHalfWidth = 0.005;\n      const wallShape = new THREE.Shape([\n        new THREE.Vector2(start.x + wallHalfWidth, start.y - wallHalfWidth),\n        new THREE.Vector2(end.x + wallHalfWidth, end.y - wallHalfWidth),\n        new THREE.Vector2(end.x - wallHalfWidth, end.y + wallHalfWidth),\n        new THREE.Vector2(start.x - wallHalfWidth, start.y + wallHalfWidth),\n      ]);\n      const wallGeometry = new THREE.ExtrudeGeometry(wallShape, { depth: this.wallsHeight, bevelEnabled: false });\n      const wallPadGeometry = new THREE.ExtrudeGeometry(wallShape, { depth: 0.001, bevelEnabled: false });\n\n      const wallMaterial = isExterior ? this.exteriorWallsMaterial : this.wallsMaterial;\n      const wallPadMaterial = createDefaultMaterial({ ...this.wallMaterialOptions, color: '#5C5C5C' });\n      const wallClippedPadMaterial = createDefaultMaterial({ side: THREE.DoubleSide, color: '#5C5C5C' });\n\n      const apertures = this.apertures.filter((aperture) => aperture.Walls.some((id) => wallId === id));\n      const wallMesh = this.subtractApertures(new THREE.Mesh(wallGeometry, wallMaterial), apertures);\n      const wallPadMesh = new THREE.Mesh(wallPadGeometry, wallPadMaterial);\n      const wallClippedPadMesh = new THREE.Mesh(wallPadGeometry, wallClippedPadMaterial);\n      wallMesh.castShadow = true;\n      wallMesh.receiveShadow = !isExterior;\n      wallPadMesh.castShadow = false;\n      wallPadMesh.receiveShadow = false;\n      wallClippedPadMesh.castShadow = false;\n      wallClippedPadMesh.receiveShadow = false;\n\n      wallPadMesh.position.z = this.wallsHeight;\n      wallClippedPadMesh.position.z = ((this.wallsHeight + 0.5) * clippedBuildingConstant) + 0.001;\n\n      const wallClippedPadMeshWithApertures = this.subtractApertures(wallClippedPadMesh, apertures);\n      wallClippedPadMeshWithApertures.visible = false;\n      wallClippedPadMeshWithApertures.castShadow = false;\n      wallClippedPadMeshWithApertures.receiveShadow = false;\n\n      const wallGroup = new THREE.Group();\n      wallGroup.name = 'Wall';\n      wallGroup.buildingId = wallId;\n      wallGroup.isExterior = isExterior;\n      wallGroup.add(wallMesh, wallPadMesh, wallClippedPadMeshWithApertures);\n\n      this.wallsGroup.add(wallGroup);\n    };\n\n    this.exteriorWallsMaterial = createDefaultMaterial({\n      ...this.wallMaterialOptions,\n      map: this.exteriorWallsMaps.map,\n      roughnessMap: this.exteriorWallsMaps.roughnessMap,\n      color: '#FFFFFF',\n    });\n\n    this.rooms.forEach(({ Walls }) => Walls.forEach((wallId) => createWall(wallId, false)));\n\n    this.exteriorWalls.forEach((wallId) => createWall(wallId, true));\n\n    this.houseGroup.add(this.wallsGroup);\n\n    return this;\n  }\n\n  createDoors() {\n    this.doors.forEach(({ Width, Location, Rotation }) => {\n      const geometry = new THREE.BoxGeometry(Width * this.sceneScale, 0.1, this.doorsHeight);\n      let mesh = new THREE.Mesh(geometry, this.doorMaterial);\n      mesh.position.x = Location.X * this.sceneScale;\n      mesh.position.y = Location.Y * this.sceneScale;\n      mesh.position.z = this.doorsHeight / 2;\n      mesh.rotation.z = THREE.Math.degToRad(Rotation.Yaw);\n      mesh.receiveShadow = true;\n      mesh.castShadow = true;\n      \n      this.doorsGroup.add(mesh);\n    });\n\n    this.houseGroup.add(this.doorsGroup);\n\n    return this;\n  }\n\n  subtractApertures(mesh, apertures, additionalWidth = 0) {\n    let resultMesh = mesh;\n\n    apertures.forEach(({ Width, Depth, Location, Rotation, Type }) => {\n      const isDoor = Type === 'Door';\n      const apertureGeometry = new THREE.BoxGeometry(\n        (Width + additionalWidth) * this.sceneScale,\n        Depth * this.sceneScale + 1,\n        (isDoor ? this.doorsHeight : this.wallsHeight / 2) + (additionalWidth * this.sceneScale),\n      );\n      const apertureMaterial = createDefaultMaterial({ color: '#00B4F7' });\n      const apertureMesh = new THREE.Mesh(apertureGeometry, apertureMaterial);\n      apertureMesh.rotation.z = THREE.Math.degToRad(Rotation.Yaw);\n      apertureMesh.position.x = Location.X * this.sceneScale;\n      apertureMesh.position.y = Location.Y * this.sceneScale;\n      apertureMesh.position.z = isDoor ? this.doorsHeight / 2 : this.wallsHeight / 2;\n\n      apertureMesh.updateMatrix();\n      resultMesh.updateMatrix();\n\n      const apertureBSP = CSG.fromMesh(apertureMesh);\n      const wallBSP = CSG.fromMesh(resultMesh);\n\n      const resultBSP = wallBSP.subtract(apertureBSP);\n      resultMesh = CSG.toMesh(resultBSP, mesh.matrix, resultMesh.material);\n    });\n\n    return resultMesh;\n  }\n\n  setCenterPosition() {\n    const walls = this.exteriorWalls.map((wallId) => this.getParsedWallById(wallId));\n    const { maxX, minX, maxY, minY } = getMinMaxCoordinates(walls);\n    const centerX = (maxX + minX) / 2;\n    const centerY = (maxY + minY) / 2;\n    const lightsOffset = 25;\n    this.houseGroup.position.set(-centerX, -centerY);\n\n    const lights = [\n      { x: centerX - lightsOffset, y: centerY - lightsOffset, z: this.wallsHeight * 3, power: 0.4, castShadow: true },\n      { x: centerX - lightsOffset, y: centerY - lightsOffset, z: this.wallsHeight * 2, power: 1, castShadow: false },\n      { x: centerX + lightsOffset, y: centerY + lightsOffset, z: this.wallsHeight * 2, power: 1.1, castShadow: false },\n      { x: centerX, y: centerY, z: this.wallsHeight * 5, power: 0.1, castShadow: false },\n    ];\n\n    const targetObject = new THREE.Object3D();\n    targetObject.position.set(centerX, centerY, 0);\n    this.houseGroup.add(targetObject);\n\n    lights.forEach(({ x, y, z, power, castShadow }) => {\n      const light = new THREE.DirectionalLight(0xffffff, power);\n      light.position.set(x, y, z);\n      light.shadowLight = castShadow;\n      light.castShadow = castShadow;\n      light.shadow.camera.left = -centerX * 2;\n      light.shadow.camera.right = centerX * 2;\n      light.shadow.camera.top = centerY * 2;\n      light.shadow.camera.bottom = -centerY * 2;\n      light.shadow.camera.zoom = 1;\n      light.shadow.mapSize = new THREE.Vector2(2048, 2048);\n      light.shadow.normalBias = 1;\n      light.target = targetObject;\n\n      this.houseGroup.add(light);\n    });\n\n    return this;\n  }\n\n  loadTexture(img, repeat = [1, 1], callback = () => {}) {\n    this.textureLoader.load(img, (texture) => {\n      texture.wrapS = texture.wrapT = THREE.RepeatWrapping;\n      texture.repeat.set(repeat[0], repeat[1]);\n      texture.flipY = false;\n\n      callback(texture);\n    });\n  }\n\n  loadTextures() {\n    const assets = [\n      {\n        img: WallTextureImg,\n        repeat: [0.5, 0.5],\n        callback: (texture) => {\n          this.wallsTextures.push({ image: WallTextureImg, texture: texture });\n          this.wallsMaterial = createDefaultMaterial({ ...this.wallMaterialOptions, map: texture });\n        },\n      },\n      {\n        img: ExteriorWallTextureImg,\n        repeat: [1, 1],\n        callback: (texture) => {\n          this.wallsTextures.push({ image: ExteriorWallTextureImg, texture: texture });\n          this.exteriorWallsMaps.map = texture;\n        },\n      },\n      {\n        img: ExteriorWallTextureRoughnessImg,\n        repeat: [1, 1],\n        callback: (texture) => {\n          this.wallsTextures.push({ image: ExteriorWallTextureRoughnessImg, texture: texture });\n          this.exteriorWallsMaps.roughnessMap = texture;\n        },\n      },\n      {\n        img: DoorTexture,\n        repeat: [1, 1],\n        callback: (texture) => {\n          this.doorMaterial = createDefaultMaterial({ ...doorMaterialOptions, map: texture });\n        },\n      },\n    ];\n\n    return Promise.all(assets.map(({ img, repeat, callback }) => new Promise((resolve) => {\n      this.loadTexture(img, repeat, (texture) => {\n        callback(texture);\n        resolve();\n      });\n    })));\n  }\n\n  loadFurniture(index) {\n    const furniture = this.furniture[index];\n    if (!furniture) return;\n\n    const furnitureData = this.furnitureData.find(({ name, type }) => (name === furniture.Model && type === furniture.Type));\n    if (!furnitureData) {\n      this.loadFurniture(index + 1);\n      return;\n    }\n\n    const { mesh, textures } = furnitureData;\n    const modelPath = `${this.apiStore.API_URL}/storage/furniture/${mesh}`;\n\n    const { Location, Rotation, Model: ModelName } = furniture;\n    const { X, Y, Z } = Location;\n\n    const promises = textures.map((url) => {\n      const texturePath = `${this.apiStore.API_URL}/storage/furniture/${url}`;\n\n      return new Promise((resolve) => {\n        this.textureLoader.load(texturePath, (texture) => resolve(texture));\n      });\n    });\n\n    const onTexturesLoaded = (result, model) => {\n      const materialsCount = result.reduce((acc, { image }) => {\n        if (!image.currentSrc.includes('_D.') && !image.currentSrc.includes('_DA.')) return acc;\n        return acc += 1;\n      }, 0);\n\n      const createMaterial = (num) => {\n        const map = result.find(({ image }) => (\n          image.currentSrc.includes(`${num}_D.`) ||\n          image.currentSrc.includes(`${num}_DA.`)\n        ));\n        const envMap = result.find(({ image }) => image.currentSrc.includes(`${num}_RMO.`));\n        const normalMap = result.find(({ image }) => image.currentSrc.includes(`${num}_N.`));\n        const material = new THREE.MeshStandardMaterial({ roughness: 1, transparent: true });\n        material.depthWrite = !(ModelName === 'Flower' && num === '01');\n\n        if (map) material.map = map;\n        if (envMap) material.envMap = envMap;\n        if (normalMap) material.normalMap = normalMap;\n\n        return material;\n      };\n\n      let materials = new THREE.MeshPhysicalMaterial({\n        roughness: 1,\n        clearcoat: 1,\n        clearcoatRoughness: 1,\n        reflectivity: 0,\n        fog: false,\n      });\n\n      if (materialsCount === 1) {\n        materials = createMaterial('');\n      }\n\n      if (materialsCount > 1) {\n        materials = [...Array(materialsCount).keys()].map((i) => {\n          const num = i + 1;\n          const realNum = num < 10 ? `0${num}` : num;\n          return createMaterial(realNum);\n        });\n      }\n\n      model.traverse((node) => {\n        if (node.isMesh) {\n          node.material = materials;\n          node.receiveShadow = true;\n          node.castShadow = true;\n        }\n      });\n\n      this.houseGroup.add(model);\n      this.loadFurniture(index + 1);\n    };\n\n    const onModelLoaded = (originalModel) => {\n      const model = originalModel.clone();\n      model.scale.set(this.sceneScale, this.sceneScale, this.sceneScale);\n      model.position.set(X * this.sceneScale, Y * this.sceneScale, Z * this.sceneScale);\n      model.rotation.set(Math.PI / 2, THREE.Math.degToRad(Rotation.Yaw), 0);\n\n      const loadedTextures = this.loadedTextures[ModelName];\n\n      if (loadedTextures) {\n        onTexturesLoaded(loadedTextures, model);\n        return;\n      }\n\n      Promise.all(promises).then((result) => {\n        onTexturesLoaded(result, model);\n        this.loadedTextures[ModelName] = result;\n      });\n    };\n\n    const loadedModel = this.loadedModels[ModelName];\n\n    if (loadedModel) {\n      onModelLoaded(loadedModel);\n      return;\n    }\n\n    modelLoader.load(modelPath, (model) => {\n      this.loadedModels[ModelName] = model;\n      onModelLoaded(model);\n    });\n  }\n\n  // Actions\n\n  setShadowsVisibility(value) {\n    this.isShadowsVisible = value;\n    this.houseGroup.children.forEach((node) => {\n      const isLight = node instanceof THREE.DirectionalLight;\n      if (!isLight) return;\n      if (!node.shadowLight) return;\n      node.castShadow = value;\n    });\n  }\n\n  setDoorsVisibility(value) {\n    this.isDoorsVisible = value;\n    this.doorsGroup.children.forEach((door) => door.visible = value);\n  }\n\n  setCurrentWallsMaterialType(value) {\n    this.wallsMaterialType = value;\n\n    this.wallsGroup.children.forEach(({ children, isExterior }) => {\n      const wall = children[0];\n      if (value === 'texture') {\n        wall.material = isExterior ? this.exteriorWallsMaterial : this.wallsMaterial;\n        return;\n      }\n      const color = isExterior ? '#FFFFFF' : this.wallsColor;\n      wall.material = createDefaultMaterial({ ...this.wallMaterialOptions, color });\n    });\n\n    this.doorsGroup.children.forEach((door) => {\n      if (value === 'texture') {\n        door.material = this.doorMaterial;\n        return;\n      }\n      door.material = createDefaultMaterial(doorMaterialOptions);\n    });\n  }\n\n  setCurrentWallColor(color) {\n    this.wallsColor = color;\n    this.wallsMaterial.color.set(color);\n    this.wallsGroup.children.forEach(({ children, isExterior }) => {\n      if (isExterior) return;\n      const wall = children[0];\n      wall.material.color.set(color);\n    });\n  }\n\n  setCurrentWallTexture(texture) {\n    this.wallsMaterial = createDefaultMaterial({ ...this.wallMaterialOptions, map: texture });\n    this.setCurrentWallsMaterialType('texture');\n  }\n\n  addWallTexture(image) {\n    this.loadTexture(image, [0.5, 0.5], (texture) => {\n      this.wallsTextures.push({ image, texture });\n      this.setCurrentWallTexture(texture);\n    });\n  }\n\n  setFullBuildingVisibility(value) {\n    this.isFullBuildingVisible = value;\n    this.globalPlane.constant = this.isFullBuildingVisible ? 1 : clippedBuildingConstant;\n    this.wallsGroup.children.forEach(({ children }) => children[2].visible = !value);\n  }\n\n  setPlanMode() {\n    this.setDoorsVisibility(false);\n    this.setFullBuildingVisibility(false);\n    this.setCurrentWallsMaterialType('color');\n  }\n}\n\nexport default HouseStore;\n"]}