kitchen-simulator 1.1.1-test.48 → 1.1.1-test.49

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 (359) hide show
  1. package/lib/KitchenConfiguratorApp.js +3 -0
  2. package/package.json +1 -1
  3. package/es/@history.js +0 -2
  4. package/es/AppContext.js +0 -3
  5. package/es/KitchenConfigurator.js +0 -645
  6. package/es/KitchenConfiguratorApp.js +0 -478
  7. package/es/actions/area-actions.js +0 -14
  8. package/es/actions/export.js +0 -23
  9. package/es/actions/groups-actions.js +0 -89
  10. package/es/actions/holes-actions.js +0 -119
  11. package/es/actions/items-actions.js +0 -313
  12. package/es/actions/lines-actions.js +0 -81
  13. package/es/actions/project-actions.js +0 -281
  14. package/es/actions/scene-actions.js +0 -33
  15. package/es/actions/vertices-actions.js +0 -27
  16. package/es/actions/viewer2d-actions.js +0 -58
  17. package/es/actions/viewer3d-actions.js +0 -23
  18. package/es/catalog/areas/area/planner-element.js +0 -40
  19. package/es/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  20. package/es/catalog/areas/area/textures/grass.jpg +0 -0
  21. package/es/catalog/areas/area/textures/parquet.jpg +0 -0
  22. package/es/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  23. package/es/catalog/areas/area/textures/tile1.jpg +0 -0
  24. package/es/catalog/catalog.js +0 -277
  25. package/es/catalog/envMap/nx.hdr +0 -0
  26. package/es/catalog/envMap/ny.hdr +0 -0
  27. package/es/catalog/envMap/nz.hdr +0 -0
  28. package/es/catalog/envMap/px.hdr +0 -0
  29. package/es/catalog/envMap/py.hdr +0 -0
  30. package/es/catalog/envMap/pz.hdr +0 -0
  31. package/es/catalog/factories/area-factory-3d.js +0 -181
  32. package/es/catalog/factories/area-factory.js +0 -81
  33. package/es/catalog/factories/export.js +0 -7
  34. package/es/catalog/factories/wall-factory-3d.js +0 -202
  35. package/es/catalog/factories/wall-factory.js +0 -268
  36. package/es/catalog/holes/door-closet/planner-element.js +0 -222
  37. package/es/catalog/holes/door-double/door_double.png +0 -0
  38. package/es/catalog/holes/door-double/planner-element.js +0 -315
  39. package/es/catalog/holes/door-exterior/planner-element.js +0 -215
  40. package/es/catalog/holes/door-interior/planner-element.js +0 -227
  41. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  42. package/es/catalog/holes/door-panic/planner-element.js +0 -503
  43. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  44. package/es/catalog/holes/door-panic-double/planner-element.js +0 -463
  45. package/es/catalog/holes/door-sliding/planner-element.js +0 -225
  46. package/es/catalog/holes/doorway-framed/planner-element.js +0 -145
  47. package/es/catalog/holes/doorway-frameless/planner-element.js +0 -104
  48. package/es/catalog/holes/export.js +0 -13
  49. package/es/catalog/holes/gate/gate.jpg +0 -0
  50. package/es/catalog/holes/window-clear/planner-element.js +0 -166
  51. package/es/catalog/holes/window-clear/texture.png +0 -0
  52. package/es/catalog/holes/window-cross/planner-element.js +0 -165
  53. package/es/catalog/holes/window-cross/texture.png +0 -0
  54. package/es/catalog/holes/window-double-hung/planner-element.js +0 -303
  55. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  56. package/es/catalog/holes/window-vertical/planner-element.js +0 -276
  57. package/es/catalog/holes/window-vertical/texture.png +0 -0
  58. package/es/catalog/lines/wall/planner-element.js +0 -70
  59. package/es/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  60. package/es/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
  61. package/es/catalog/lines/wall/textures/bricks.jpg +0 -0
  62. package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
  63. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  64. package/es/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  65. package/es/catalog/lines/wall/textures/morden.jpg +0 -0
  66. package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
  67. package/es/catalog/lines/wall/textures/painted.jpg +0 -0
  68. package/es/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  69. package/es/catalog/lines/wall/textures/plaster.jpg +0 -0
  70. package/es/catalog/lines/wall/wall.png +0 -0
  71. package/es/catalog/molding/molding-dcm/planner-element.js +0 -28
  72. package/es/catalog/molding/molding-dcm/texture.png +0 -0
  73. package/es/catalog/molding/molding-fbm/planner-element.js +0 -28
  74. package/es/catalog/molding/molding-fbm/texture.png +0 -0
  75. package/es/catalog/molding/molding-lrm/planner-element.js +0 -28
  76. package/es/catalog/molding/molding-lrm/texture.png +0 -0
  77. package/es/catalog/properties/export.js +0 -21
  78. package/es/catalog/properties/property-checkbox.js +0 -116
  79. package/es/catalog/properties/property-color.js +0 -39
  80. package/es/catalog/properties/property-enum.js +0 -97
  81. package/es/catalog/properties/property-hidden.js +0 -19
  82. package/es/catalog/properties/property-lenght-measure.js +0 -101
  83. package/es/catalog/properties/property-length-measure.js +0 -134
  84. package/es/catalog/properties/property-length-measure_hole.js +0 -101
  85. package/es/catalog/properties/property-number.js +0 -48
  86. package/es/catalog/properties/property-read-only.js +0 -26
  87. package/es/catalog/properties/property-string.js +0 -48
  88. package/es/catalog/properties/property-toggle.js +0 -39
  89. package/es/catalog/properties/shared-property-style.js +0 -14
  90. package/es/catalog/utils/FuseUtils.js +0 -82
  91. package/es/catalog/utils/exporter.js +0 -148
  92. package/es/catalog/utils/geom-utils.js +0 -189
  93. package/es/catalog/utils/item-loader.js +0 -1521
  94. package/es/catalog/utils/load-obj.js +0 -91
  95. package/es/catalog/utils/mtl-loader.js +0 -358
  96. package/es/catalog/utils/obj-loader.js +0 -477
  97. package/es/class/FuseUtils.js +0 -82
  98. package/es/class/area.js +0 -145
  99. package/es/class/export.js +0 -24
  100. package/es/class/group.js +0 -440
  101. package/es/class/guide.js +0 -62
  102. package/es/class/hole.js +0 -929
  103. package/es/class/item.js +0 -1883
  104. package/es/class/layer.js +0 -667
  105. package/es/class/line.js +0 -1180
  106. package/es/class/project.js +0 -793
  107. package/es/class/vertex.js +0 -202
  108. package/es/components/content.js +0 -107
  109. package/es/components/disclaimer/disclaimer.js +0 -97
  110. package/es/components/export.js +0 -9
  111. package/es/components/style/button.js +0 -113
  112. package/es/components/style/cancel-button.js +0 -22
  113. package/es/components/style/content-container.js +0 -33
  114. package/es/components/style/content-title.js +0 -29
  115. package/es/components/style/delete-button.js +0 -25
  116. package/es/components/style/export.js +0 -31
  117. package/es/components/style/form-block.js +0 -24
  118. package/es/components/style/form-color-input.js +0 -27
  119. package/es/components/style/form-label.js +0 -26
  120. package/es/components/style/form-number-input.js +0 -213
  121. package/es/components/style/form-number-input_2.js +0 -206
  122. package/es/components/style/form-select.js +0 -68
  123. package/es/components/style/form-slider.js +0 -61
  124. package/es/components/style/form-submit-button.js +0 -26
  125. package/es/components/style/form-text-input.js +0 -95
  126. package/es/components/viewer2d/area.js +0 -81
  127. package/es/components/viewer2d/export.js +0 -31
  128. package/es/components/viewer2d/grids/grid-horizontal-streak.js +0 -37
  129. package/es/components/viewer2d/grids/grid-streak.js +0 -37
  130. package/es/components/viewer2d/grids/grid-vertical-streak.js +0 -37
  131. package/es/components/viewer2d/grids/grids.js +0 -35
  132. package/es/components/viewer2d/group.js +0 -53
  133. package/es/components/viewer2d/item.js +0 -513
  134. package/es/components/viewer2d/layer.js +0 -164
  135. package/es/components/viewer2d/line.js +0 -882
  136. package/es/components/viewer2d/ruler.js +0 -100
  137. package/es/components/viewer2d/rulerDist.js +0 -146
  138. package/es/components/viewer2d/rulerX.js +0 -151
  139. package/es/components/viewer2d/rulerY.js +0 -153
  140. package/es/components/viewer2d/scene.js +0 -140
  141. package/es/components/viewer2d/snap.js +0 -74
  142. package/es/components/viewer2d/state.js +0 -78
  143. package/es/components/viewer2d/utils.js +0 -198
  144. package/es/components/viewer2d/vertex.js +0 -65
  145. package/es/components/viewer2d/viewer2d.js +0 -1398
  146. package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +0 -2592
  147. package/es/components/viewer3d/dcm.js +0 -401
  148. package/es/components/viewer3d/fbm.js +0 -414
  149. package/es/components/viewer3d/front3D.js +0 -66
  150. package/es/components/viewer3d/grid-creator.js +0 -25
  151. package/es/components/viewer3d/grids/grid-horizontal-streak.js +0 -36
  152. package/es/components/viewer3d/grids/grid-streak.js +0 -27
  153. package/es/components/viewer3d/grids/grid-vertical-streak.js +0 -36
  154. package/es/components/viewer3d/libs/first-person-controls.js +0 -67
  155. package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +0 -1281
  156. package/es/components/viewer3d/libs/mtl-loader.js +0 -357
  157. package/es/components/viewer3d/libs/obj-loader.js +0 -462
  158. package/es/components/viewer3d/libs/orbit-controls.js +0 -699
  159. package/es/components/viewer3d/libs/pointer-lock-controls.js +0 -46
  160. package/es/components/viewer3d/lrm.js +0 -305
  161. package/es/components/viewer3d/model.js +0 -708
  162. package/es/components/viewer3d/pointer-lock-navigation.js +0 -115
  163. package/es/components/viewer3d/ruler-utils/itemRect.js +0 -61
  164. package/es/components/viewer3d/ruler-utils/layer3D.js +0 -495
  165. package/es/components/viewer3d/ruler-utils/ruler3D.js +0 -227
  166. package/es/components/viewer3d/ruler-utils/scene3D.js +0 -60
  167. package/es/components/viewer3d/ruler-utils/state3D.js +0 -18
  168. package/es/components/viewer3d/scene-creator.js +0 -3608
  169. package/es/components/viewer3d/three-memory-cleaner.js +0 -51
  170. package/es/components/viewer3d/viewer3d-first-person.js +0 -315
  171. package/es/components/viewer3d/viewer3d.js +0 -2527
  172. package/es/constants.js +0 -636
  173. package/es/index.js +0 -16
  174. package/es/models.js +0 -510
  175. package/es/plugins/SVGLoader.js +0 -1412
  176. package/es/plugins/autosave.js +0 -33
  177. package/es/plugins/console-debugger.js +0 -37
  178. package/es/plugins/export.js +0 -9
  179. package/es/plugins/keyboard.js +0 -101
  180. package/es/reducers/areas-reducer.js +0 -12
  181. package/es/reducers/export.js +0 -25
  182. package/es/reducers/groups-reducer.js +0 -38
  183. package/es/reducers/holes-reducer.js +0 -62
  184. package/es/reducers/items-reducer.js +0 -140
  185. package/es/reducers/lines-reducer.js +0 -45
  186. package/es/reducers/project-reducer.js +0 -129
  187. package/es/reducers/reducer.js +0 -19
  188. package/es/reducers/scene-reducer.js +0 -28
  189. package/es/reducers/user-reducer.js +0 -40
  190. package/es/reducers/vertices-reducer.js +0 -19
  191. package/es/reducers/viewer2d-reducer.js +0 -75
  192. package/es/reducers/viewer3d-reducer.js +0 -56
  193. package/es/shared-style.js +0 -66
  194. package/es/styles/export.js +0 -5
  195. package/es/styles/tabs.css +0 -40
  196. package/es/translator/en.js +0 -104
  197. package/es/translator/it.js +0 -79
  198. package/es/translator/ru.js +0 -79
  199. package/es/translator/translator.js +0 -84
  200. package/es/utils/browser.js +0 -33
  201. package/es/utils/email-validator.js +0 -4
  202. package/es/utils/export.js +0 -25
  203. package/es/utils/geometry.js +0 -2420
  204. package/es/utils/get-edges-of-subgraphs.js +0 -27
  205. package/es/utils/graph-cycles.js +0 -237
  206. package/es/utils/graph-inner-cycles.js +0 -46
  207. package/es/utils/graph.js +0 -150
  208. package/es/utils/helper.js +0 -268
  209. package/es/utils/history.js +0 -29
  210. package/es/utils/id-broker.js +0 -19
  211. package/es/utils/logger.js +0 -8
  212. package/es/utils/math.js +0 -50
  213. package/es/utils/molding.js +0 -871
  214. package/es/utils/name-generator.js +0 -18
  215. package/es/utils/objects-utils.js +0 -50
  216. package/es/utils/phone-validator.js +0 -4
  217. package/es/utils/process-black-list.js +0 -18
  218. package/es/utils/react-if.js +0 -18
  219. package/es/utils/snap-scene.js +0 -99
  220. package/es/utils/snap.js +0 -237
  221. package/es/utils/summarizeCart.js +0 -24
  222. package/es/utils/threeCSG.es6.js +0 -498
  223. package/es/version.js +0 -2
  224. package/lib/catalog/properties/property-string.js +0 -55
  225. package/lib/catalog/properties/property-toggle.js +0 -46
  226. package/lib/catalog/properties/shared-property-style.js +0 -20
  227. package/lib/catalog/utils/FuseUtils.js +0 -88
  228. package/lib/catalog/utils/exporter.js +0 -155
  229. package/lib/catalog/utils/geom-utils.js +0 -205
  230. package/lib/catalog/utils/item-loader.js +0 -1533
  231. package/lib/catalog/utils/load-obj.js +0 -99
  232. package/lib/catalog/utils/mtl-loader.js +0 -363
  233. package/lib/catalog/utils/obj-loader.js +0 -482
  234. package/lib/class/FuseUtils.js +0 -88
  235. package/lib/class/area.js +0 -150
  236. package/lib/class/export.js +0 -96
  237. package/lib/class/group.js +0 -445
  238. package/lib/class/guide.js +0 -67
  239. package/lib/class/hole.js +0 -934
  240. package/lib/class/item.js +0 -1889
  241. package/lib/class/layer.js +0 -672
  242. package/lib/class/line.js +0 -1186
  243. package/lib/class/project.js +0 -799
  244. package/lib/class/vertex.js +0 -207
  245. package/lib/components/content.js +0 -116
  246. package/lib/components/disclaimer/disclaimer.js +0 -105
  247. package/lib/components/export.js +0 -33
  248. package/lib/components/style/button.js +0 -120
  249. package/lib/components/style/cancel-button.js +0 -29
  250. package/lib/components/style/content-container.js +0 -40
  251. package/lib/components/style/content-title.js +0 -37
  252. package/lib/components/style/delete-button.js +0 -34
  253. package/lib/components/style/export.js +0 -121
  254. package/lib/components/style/form-block.js +0 -31
  255. package/lib/components/style/form-color-input.js +0 -34
  256. package/lib/components/style/form-label.js +0 -33
  257. package/lib/components/style/form-number-input.js +0 -220
  258. package/lib/components/style/form-number-input_2.js +0 -213
  259. package/lib/components/style/form-select.js +0 -75
  260. package/lib/components/style/form-slider.js +0 -68
  261. package/lib/components/style/form-submit-button.js +0 -35
  262. package/lib/components/style/form-text-input.js +0 -101
  263. package/lib/components/viewer2d/area.js +0 -88
  264. package/lib/components/viewer2d/export.js +0 -121
  265. package/lib/components/viewer2d/grids/grid-horizontal-streak.js +0 -44
  266. package/lib/components/viewer2d/grids/grid-streak.js +0 -44
  267. package/lib/components/viewer2d/grids/grid-vertical-streak.js +0 -44
  268. package/lib/components/viewer2d/grids/grids.js +0 -44
  269. package/lib/components/viewer2d/group.js +0 -62
  270. package/lib/components/viewer2d/item.js +0 -521
  271. package/lib/components/viewer2d/layer.js +0 -171
  272. package/lib/components/viewer2d/line.js +0 -892
  273. package/lib/components/viewer2d/ruler.js +0 -107
  274. package/lib/components/viewer2d/rulerDist.js +0 -153
  275. package/lib/components/viewer2d/rulerX.js +0 -158
  276. package/lib/components/viewer2d/rulerY.js +0 -160
  277. package/lib/components/viewer2d/scene.js +0 -147
  278. package/lib/components/viewer2d/snap.js +0 -83
  279. package/lib/components/viewer2d/state.js +0 -87
  280. package/lib/components/viewer2d/utils.js +0 -210
  281. package/lib/components/viewer2d/vertex.js +0 -74
  282. package/lib/components/viewer2d/viewer2d.js +0 -1405
  283. package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +0 -2597
  284. package/lib/components/viewer3d/dcm.js +0 -407
  285. package/lib/components/viewer3d/fbm.js +0 -420
  286. package/lib/components/viewer3d/front3D.js +0 -75
  287. package/lib/components/viewer3d/grid-creator.js +0 -34
  288. package/lib/components/viewer3d/grids/grid-horizontal-streak.js +0 -44
  289. package/lib/components/viewer3d/grids/grid-streak.js +0 -35
  290. package/lib/components/viewer3d/grids/grid-vertical-streak.js +0 -44
  291. package/lib/components/viewer3d/libs/first-person-controls.js +0 -74
  292. package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +0 -1287
  293. package/lib/components/viewer3d/libs/mtl-loader.js +0 -363
  294. package/lib/components/viewer3d/libs/obj-loader.js +0 -468
  295. package/lib/components/viewer3d/libs/orbit-controls.js +0 -705
  296. package/lib/components/viewer3d/libs/pointer-lock-controls.js +0 -52
  297. package/lib/components/viewer3d/lrm.js +0 -311
  298. package/lib/components/viewer3d/model.js +0 -714
  299. package/lib/components/viewer3d/pointer-lock-navigation.js +0 -122
  300. package/lib/components/viewer3d/ruler-utils/itemRect.js +0 -68
  301. package/lib/components/viewer3d/ruler-utils/layer3D.js +0 -502
  302. package/lib/components/viewer3d/ruler-utils/ruler3D.js +0 -234
  303. package/lib/components/viewer3d/ruler-utils/scene3D.js +0 -68
  304. package/lib/components/viewer3d/ruler-utils/state3D.js +0 -25
  305. package/lib/components/viewer3d/scene-creator.js +0 -3642
  306. package/lib/components/viewer3d/three-memory-cleaner.js +0 -60
  307. package/lib/components/viewer3d/viewer3d-first-person.js +0 -320
  308. package/lib/components/viewer3d/viewer3d.js +0 -2532
  309. package/lib/constants.js +0 -645
  310. package/lib/index.js +0 -96
  311. package/lib/models.js +0 -517
  312. package/lib/plugins/SVGLoader.js +0 -1417
  313. package/lib/plugins/autosave.js +0 -39
  314. package/lib/plugins/console-debugger.js +0 -44
  315. package/lib/plugins/export.js +0 -33
  316. package/lib/plugins/keyboard.js +0 -107
  317. package/lib/reducers/areas-reducer.js +0 -18
  318. package/lib/reducers/export.js +0 -97
  319. package/lib/reducers/groups-reducer.js +0 -44
  320. package/lib/reducers/holes-reducer.js +0 -68
  321. package/lib/reducers/items-reducer.js +0 -146
  322. package/lib/reducers/lines-reducer.js +0 -51
  323. package/lib/reducers/project-reducer.js +0 -135
  324. package/lib/reducers/reducer.js +0 -26
  325. package/lib/reducers/scene-reducer.js +0 -34
  326. package/lib/reducers/user-reducer.js +0 -46
  327. package/lib/reducers/vertices-reducer.js +0 -25
  328. package/lib/reducers/viewer2d-reducer.js +0 -82
  329. package/lib/reducers/viewer3d-reducer.js +0 -63
  330. package/lib/shared-style.js +0 -72
  331. package/lib/styles/export.js +0 -13
  332. package/lib/translator/en.js +0 -110
  333. package/lib/translator/it.js +0 -85
  334. package/lib/translator/ru.js +0 -85
  335. package/lib/translator/translator.js +0 -90
  336. package/lib/utils/browser.js +0 -40
  337. package/lib/utils/email-validator.js +0 -10
  338. package/lib/utils/export.js +0 -56
  339. package/lib/utils/geometry.js +0 -2516
  340. package/lib/utils/get-edges-of-subgraphs.js +0 -34
  341. package/lib/utils/graph-cycles.js +0 -240
  342. package/lib/utils/graph-inner-cycles.js +0 -54
  343. package/lib/utils/graph.js +0 -157
  344. package/lib/utils/helper.js +0 -291
  345. package/lib/utils/history.js +0 -36
  346. package/lib/utils/id-broker.js +0 -25
  347. package/lib/utils/logger.js +0 -14
  348. package/lib/utils/math.js +0 -57
  349. package/lib/utils/molding.js +0 -895
  350. package/lib/utils/name-generator.js +0 -23
  351. package/lib/utils/objects-utils.js +0 -60
  352. package/lib/utils/phone-validator.js +0 -10
  353. package/lib/utils/process-black-list.js +0 -24
  354. package/lib/utils/react-if.js +0 -24
  355. package/lib/utils/snap-scene.js +0 -105
  356. package/lib/utils/snap.js +0 -249
  357. package/lib/utils/summarizeCart.js +0 -30
  358. package/lib/utils/threeCSG.es6.js +0 -503
  359. package/lib/version.js +0 -8
@@ -1,1521 +0,0 @@
1
- function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
5
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
6
- function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
- function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
8
- 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."); }
9
- function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
10
- function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
11
- function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
12
- function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
13
- import convert from 'convert-units';
14
- import { fromJS, Map } from 'immutable';
15
- import React, { useState } from 'react';
16
- import * as Three from 'three';
17
- import * as SceneCreator from "../../components/viewer3d/scene-creator";
18
- import { ARROW_COLOR, BASE_CABINET_LAYOUTPOS, OBJTYPE_GROUP, OBJTYPE_MESH, SHADE_DARK_PURPLE_COLOR, SHAPE_SVG_DEPTH, SHAPE_SVG_PADDING, SHAPE_SVG_WIDTH, STATUS_WARNING_COLOR, STATUS_WARNING_LIGHT_COLOR, TALL_CABINET_LAYOUTPOS, UNIT_CENTIMETER, UNIT_INCH, WALL_CABINET_LAYOUTPOS } from "../../constants";
19
- import { Item } from "../../models";
20
- import * as GeomUtils from "./geom-utils";
21
- import { loadGLTF } from "./load-obj";
22
- import { animateDoor, translateDrawer } from "../../utils/helper";
23
-
24
- // env Map ///////////////
25
- var paramsCounter = {
26
- envMap: 'HDR',
27
- roughness: 0.6,
28
- metalness: 0.3,
29
- exposure: 1
30
- // debug: true
31
- };
32
- var params = {
33
- envMap: 'HDR',
34
- roughness: 0.9,
35
- metalness: 0.1,
36
- metalness_glossy: 0.2,
37
- exposure: 1.0
38
- // debug: false
39
- };
40
- var paramsModel = {
41
- envMap: 'HDR',
42
- roughness: 0.9,
43
- metalness: 0.2,
44
- exposure: 1.0
45
- // debug: false
46
- };
47
-
48
- // /////////////////////////
49
-
50
- var cachedObject = {}; // cached Object for quickly load-3d
51
-
52
- // render 2d function//////
53
- export function render2DItem(element, layer, scene, sizeinfo, layoutpos, is_corner, shape_svg) {
54
- var _useState = useState(false),
55
- _useState2 = _slicedToArray(_useState, 2),
56
- hover = _useState2[0],
57
- setHover = _useState2[1];
58
- var x = element.x,
59
- y = element.y,
60
- rotation = element.rotation;
61
- var el_DSN = 'el_DSN',
62
- doorStylesKeys = [];
63
- var _element = element.toJS();
64
- if (_element.doorStyle !== undefined) {
65
- if (_element.doorStyle.doorStyles !== undefined) {
66
- doorStylesKeys = Object.keys(_element.doorStyle.doorStyles);
67
- }
68
- }
69
- if ((doorStylesKeys.includes('euro_length') || doorStylesKeys.includes('euro_width') || doorStylesKeys.includes('euro_shape_svg')) && _element.doorStyle.doorStyles.is_euro_cds) {
70
- el_DSN = _element.doorStyle.door_style_name;
71
- } else {
72
- el_DSN = 'el_DSN';
73
- }
74
- var width, depth, el_euro_length, el_euro_width, el_euro_length_unit, el_euro_width_unit, el_is_euro_cds, el_euro_shape_svg;
75
- if (doorStylesKeys.length > 0) {
76
- el_euro_length = _element.doorStyle.doorStyles.euro_length;
77
- el_euro_width = _element.doorStyle.doorStyles.euro_width;
78
- el_is_euro_cds = _element.doorStyle.doorStyles.is_euro_cds;
79
- el_euro_shape_svg = _element.doorStyle.doorStyles.euro_shape_svg;
80
- }
81
- if (el_euro_length === undefined && el_euro_width === undefined) {
82
- el_DSN = 'el_DSN';
83
- }
84
- if (el_DSN === 'Euro & Frameless') {
85
- // sizeinfo["depth"] = el_euro_length;
86
- // sizeinfo["width"] = el_euro_width;
87
- }
88
- var tempWidth = element.properties.get('width');
89
- var tempDepth = element.properties.get('depth');
90
- width = tempWidth && {
91
- length: tempWidth.get('_length'),
92
- unit: tempWidth.get('_unit')
93
- };
94
- depth = tempDepth && {
95
- length: tempDepth.get('_length'),
96
- unit: tempDepth.get('_unit')
97
- };
98
- var originalWidth = convert(sizeinfo.width).from('in').to('cm');
99
- var originalDepth = convert(sizeinfo.depth).from('in').to('cm');
100
- var newWidth = convert(width.length).from(width.unit).to('cm');
101
- var newDepth = convert(depth.length).from(depth.unit).to('cm');
102
- var padding = convert(SHAPE_SVG_PADDING).from(UNIT_INCH).to(UNIT_CENTIMETER);
103
- var angle = element.rotation + 90;
104
- var textRotation = 0;
105
- if (Math.sin(angle * Math.PI / 180) < 0) {
106
- textRotation = 180;
107
- }
108
- var color = '#eee';
109
- if (layoutpos == BASE_CABINET_LAYOUTPOS) {
110
- color = '#3f8db3';
111
- }
112
- if (layoutpos == TALL_CABINET_LAYOUTPOS) {
113
- color = '#93b3be';
114
- }
115
- if (layoutpos == WALL_CABINET_LAYOUTPOS) {
116
- color = '#48b08dcc';
117
- }
118
- var splitStr = [];
119
- var txtContent = [];
120
- var lineCount = 0; //parseInt(((newWidth) / 8 - 0.51).toFixed(), 10) - 1;
121
- var rowCount = 0; //parseInt((element.type.length / lineCount - 0.51).toFixed(), 10);
122
-
123
- // Get type
124
- var type = element.type;
125
- var objSKU = this.obj.sku_number;
126
- if (objSKU.length !== 0) {
127
- var dcId,
128
- doorStyle = element.doorStyle;
129
- if (doorStyle instanceof Map) {
130
- dcId = doorStyle.get('id');
131
- } else {
132
- dcId = doorStyle.id;
133
- }
134
- var skuItem = this.obj.skuArray.find(function (el) {
135
- return el.door_color_id === dcId;
136
- });
137
- if (skuItem !== undefined) {
138
- type = skuItem.sku;
139
- }
140
- }
141
- if (rowCount > 0) {
142
- for (var _x = 0; _x < rowCount; _x++) {
143
- splitStr.push(type.slice(lineCount * _x, lineCount * (_x + 1)));
144
- }
145
- }
146
- splitStr.push(type.slice(lineCount * rowCount));
147
- splitStr.forEach(function (el, key) {
148
- txtContent.push(/*#__PURE__*/React.createElement("text", {
149
- key: 'text' + key,
150
- x: "0",
151
- y: newDepth / 2 - 12,
152
- dy: 16 * key,
153
- transform: "translate(".concat(newWidth / 2, ", ").concat(newDepth / 2 + 5, ") scale(1,-1) rotate(").concat(textRotation, ")")
154
- // textLength={newWidth - 10}
155
- // lengthAdjust="spacingAndGlyphs"
156
- ,
157
- style: {
158
- fontWeight: 500,
159
- fontSize: '7px',
160
- textAnchor: 'middle',
161
- fill: '#FFF',
162
- display: 'block'
163
- }
164
- }, el));
165
- });
166
- var style = {
167
- stroke: element.selected ? '#565658' : '#565658',
168
- strokeWidth: '2px',
169
- fill: color
170
- };
171
- // let arrow_style = { stroke: element.selected ? '#0096fd' : null, strokeWidth: "2px", fill: "#84e1ce" };
172
-
173
- var rendered = null;
174
- if (shape_svg || el_euro_shape_svg) {
175
- var svg_url, svg_width, svg_depth;
176
- if (typeof shape_svg == 'string' || typeof el_euro_shape_svg == 'string') {
177
- if (el_DSN === 'Euro & Frameless' && el_is_euro_cds) {
178
- svg_url = el_euro_shape_svg;
179
- svg_width = newWidth;
180
- svg_depth = newDepth;
181
- } else {
182
- svg_url = shape_svg;
183
- svg_width = originalWidth;
184
- svg_depth = originalDepth;
185
- }
186
- } else {
187
- // if (el_DSN === "Euro & Frameless" && el_is_euro_cds) {
188
- // // svg_url = el_euro_shape_svg.url;
189
- // } else {
190
- // }
191
- svg_url = shape_svg.url;
192
- svg_width = convert(SHAPE_SVG_WIDTH).from(UNIT_INCH).to(UNIT_CENTIMETER);
193
- svg_depth = convert(SHAPE_SVG_DEPTH).from(UNIT_INCH).to(UNIT_CENTIMETER);
194
- }
195
- var padding_width = padding * newWidth / svg_width;
196
- var padding_depth = padding * newDepth / svg_depth;
197
- rendered = /*#__PURE__*/React.createElement("g", {
198
- onMouseOver: function onMouseOver(event) {
199
- setHover(true);
200
- },
201
- onMouseOut: function onMouseOut(event) {
202
- setHover(false);
203
- },
204
- transform: "translate(".concat(x, ",").concat(y, ")")
205
- }, /*#__PURE__*/React.createElement("g", {
206
- transform: "rotate(".concat(rotation, ")")
207
- }, /*#__PURE__*/React.createElement("g", {
208
- transform: "translate(".concat(-newWidth / 2 - padding_width, ",").concat(-newDepth / 2 - padding_depth, ")")
209
- }, /*#__PURE__*/React.createElement("image", {
210
- preserveAspectRatio: "none",
211
- style: {
212
- pointerEvents: 'none'
213
- },
214
- href: svg_url,
215
- width: "".concat(newWidth + 2 * padding_width),
216
- height: "".concat(newDepth + 2 * padding_depth),
217
- transform: "scale(1, -1)",
218
- x: "0",
219
- y: "".concat(-newDepth - 2 * padding_depth)
220
- }), /*#__PURE__*/React.createElement("rect", {
221
- x: "".concat(padding_width),
222
- y: "".concat(padding_depth),
223
- width: "".concat(newWidth),
224
- height: "".concat(newDepth),
225
- visibility: element.toJS().doorStyle.doorStyles !== undefined ? element.toJS().doorStyle.doorStyles && element.toJS().doorStyle.doorStyles.cds && element.toJS().doorStyle.doorStyles.cds.length != 0 && element.toJS().doorStyle.doorStyles.cds.filter(function (cd) {
226
- return cd.itemID == element.getIn(['itemID']);
227
- }) ? 'hidden' : 'visible' : 'hidden',
228
- style: {
229
- pointerEvents: 'all',
230
- opacity: 0.7,
231
- postion: 'relative'
232
- },
233
- fill: STATUS_WARNING_LIGHT_COLOR,
234
- stroke: STATUS_WARNING_COLOR,
235
- strokeWidth: "2px"
236
- }), /*#__PURE__*/React.createElement("g", {
237
- transform: "translate(".concat(padding_width, ",").concat(padding_depth, ")")
238
- }, txtContent))));
239
- } else {
240
- rendered = /*#__PURE__*/React.createElement("g", {
241
- onMouseOver: function onMouseOver(event) {
242
- setHover(true);
243
- },
244
- onMouseOut: function onMouseOut(event) {
245
- setHover(false);
246
- },
247
- transform: "translate(".concat(x, ",").concat(y, ")")
248
- }, /*#__PURE__*/React.createElement("g", {
249
- transform: "rotate(".concat(rotation, ")")
250
- }, /*#__PURE__*/React.createElement("g", {
251
- transform: "translate(".concat(-newWidth / 2, ",").concat(-newDepth / 2, ")")
252
- }, newDepth > 15 ? [/*#__PURE__*/React.createElement("rect", {
253
- key: "base",
254
- x: "0",
255
- y: "12",
256
- width: newWidth,
257
- height: newDepth - 12,
258
- style: style
259
- }), /*#__PURE__*/React.createElement("polygon", {
260
- key: "door",
261
- style: style,
262
- points: "0,9 ".concat(newWidth, ",9 ").concat(newWidth, ",6 ").concat(newWidth - 5, ",6 ").concat(newWidth - 5, ",3 ").concat(newWidth - 2, ",3 ").concat(newWidth - 2, " 0 ").concat(newWidth - 10, " 0 ").concat(newWidth - 10, ",3 ").concat(newWidth - 7, ",3 ").concat(newWidth - 7, ",6 0 6")
263
- })] : /*#__PURE__*/React.createElement("rect", {
264
- key: "base",
265
- x: "0",
266
- y: "0",
267
- width: newWidth,
268
- height: newDepth,
269
- style: style
270
- }), txtContent)));
271
- }
272
- return rendered;
273
- }
274
- // end of render 2d function /////////////////////////
275
-
276
- export function loadTexture(url) {
277
- var texture = new Three.TextureLoader().load(url);
278
- texture.colorSpace = Three.SRGBColorSpace;
279
- texture.wrapS = Three.MirroredRepeatWrapping;
280
- texture.wrapT = Three.MirroredRepeatWrapping;
281
- return texture;
282
- }
283
- var applyTexture = function applyTexture(material, texture, length, height) {
284
- if (texture) {
285
- material.map = texture;
286
- material.needsUpdate = true;
287
- material.map.wrapS = Three.RepeatWrapping;
288
- material.map.wrapT = Three.RepeatWrapping;
289
- material.map.repeat.set(length * 0.01, height * 0.01);
290
- if (texture.normal) {
291
- material.normalMap = loadTexture(texture.normal.uri);
292
- material.normalScale = new Vector2(texture.normal.normalScaleX, texture.normal.normalScaleY);
293
- material.normalMap.wrapS = Three.RepeatWrapping;
294
- material.normalMap.wrapT = Three.RepeatWrapping;
295
- material.normalMap.repeat.set(length * texture.normal.lengthRepeatScale, height * texture.normal.heightRepeatScale);
296
- }
297
- }
298
- };
299
- var assignUVs = function assignUVs(geometry) {
300
- geometry.computeBoundingBox();
301
- var _geometry$boundingBox = geometry.boundingBox,
302
- min = _geometry$boundingBox.min,
303
- max = _geometry$boundingBox.max;
304
- var offset = new Three.Vector3(0 - min.x, 0 - min.y, 0 - min.z);
305
- var range = new Three.Vector3(max.x - min.x, max.y - min.y, max.z - min.z);
306
- geometry.faceVertexUvs[0] = geometry.faces.map(function (face) {
307
- var v1 = geometry.vertices[face.a];
308
- var v2 = geometry.vertices[face.b];
309
- var v3 = geometry.vertices[face.c];
310
- return [new Three.Vector3((v1.x + offset.x) / range.x, (v1.y + offset.y) / range.y, (v1.z + offset.z) / range.z), new Three.Vector3((v2.x + offset.x) / range.x, (v2.y + offset.y) / range.y, (v1.z + offset.z) / range.z), new Three.Vector3((v3.x + offset.x) / range.x, (v3.y + offset.y) / range.y, (v1.z + offset.z) / range.z)];
311
- });
312
- geometry.uvsNeedUpdate = true;
313
- };
314
-
315
- /**
316
- * Render 3D Item
317
- * @param {Item} element Rendering item
318
- * @param sizeinfo Dimesion of the item
319
- * @param structure_json Structure of the item such as place holders and meshes, etc
320
- */
321
- export function render3DItem(element, layer, scene, sizeinfo, structure_json, is_corner) {
322
- var mode = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : null;
323
- if (element.doorStyle.constructor !== Map) {
324
- element = element.set('doorStyle', fromJS(element.doorStyle));
325
- }
326
- if (element.doorStyle.toJS().handle_gltf !== '') {
327
- // Check element has doorHandle
328
- for (var i = 1; i < 10; i++) {
329
- element = element.setIn(['doorStyle', 'doorStyles', 'door_handle_' + i + '_gltf'], element.doorStyle.toJS().handle_gltf);
330
- element = element.setIn(['doorStyle', 'doorStyles', 'fixed_drawer_door_handle_' + i + '_gltf'], element.doorStyle.toJS().handle_gltf);
331
- element = element.setIn(['doorStyle', 'doorStyles', 'drawer_door_handle_' + i + '_gltf'], element.doorStyle.toJS().handle_gltf);
332
- }
333
- }
334
- var width = {
335
- length: sizeinfo.width,
336
- unit: 'in'
337
- };
338
- var depth = {
339
- length: sizeinfo.depth,
340
- unit: 'in'
341
- };
342
- var height = {
343
- length: sizeinfo.height,
344
- unit: 'in'
345
- };
346
- var newWidth = convert(width.length).from(width.unit).to('in');
347
- var newDepth = convert(depth.length).from(depth.unit).to('in');
348
- var newHeight = convert(height.length).from(height.unit).to('in');
349
- var mainName = ''; // to get name structure//
350
- if (element.properties.get('width')) newWidth = element.getIn(['properties', 'width', '_length']);
351
- if (element.properties.get('depth')) newDepth = element.getIn(['properties', 'depth', '_length']);
352
- if (element.properties.get('height')) newHeight = element.getIn(['properties', 'height', '_length']);
353
- var structure = structure_json;
354
- // structure.push({name:'model', url: '/assets/model/DCM.gltf'});
355
- structure.model = '/assets/model/DCM.gltf';
356
- var placeholders = structure.placeholders;
357
- var doorStyles = null;
358
- var color = 0xffffff,
359
- glossness = 1,
360
- handleMaterial = {};
361
- var counterTop = element.counterTop;
362
- if (layer.toJS().counterTop.uri) {
363
- counterTop.uri = layer.toJS().counterTop.uri;
364
- }
365
- if ('name' in element.doorStyle) {
366
- doorStyles = new Map(element.doorStyle.doorStyles);
367
- color = element.doorStyle.color;
368
- glossness = element.doorStyle.glossness;
369
- handleMaterial.metalness = element.doorStyle.metalness;
370
- handleMaterial.roughness = element.doorStyle.roughness;
371
- } else if (element.doorStyle != null && element.doorStyle) {
372
- doorStyles = element.doorStyle.get('doorStyles');
373
- color = element.doorStyle.get('color');
374
- glossness = element.doorStyle.get('glossness');
375
- handleMaterial.metalness = element.doorStyle.get('metalness');
376
- handleMaterial.roughness = element.doorStyle.get('roughness');
377
- }
378
- if (color === undefined) color = '#ffffff';
379
- if (glossness === undefined) glossness = 1;
380
- var tempDoorStyles = doorStyles.toJS();
381
- var tempPlaceholders = structure.tempPlaceholders;
382
- var tPlaceholders = tempPlaceholders.find(function (el) {
383
- return el.id === tempDoorStyles.cabinet_door_style_id;
384
- });
385
- if (tPlaceholders !== undefined) {
386
- placeholders = tPlaceholders.placeholders;
387
- var tempStructure = _objectSpread(_objectSpread({}, tPlaceholders.structure), {}, {
388
- animation: structure.animation,
389
- placeholders: structure.placeholders,
390
- tempPlaceholders: structure.tempPlaceholders,
391
- model: structure.model
392
- });
393
- structure = tempStructure;
394
- }
395
- var userData = structure.animation;
396
- // ///////////////////////////
397
- var onLoadItem = function onLoadItem(object) {
398
- var areaMaterial = new Three.MeshStandardMaterial();
399
- areaMaterial.side = Three.DoubleSide;
400
- // areaMaterial.envMap = textureCube;
401
- if (doorStyles != null) if (doorStyles.get('base') != undefined) {
402
- var normalMap = doorStyles.get('base');
403
- var interiortexture = loadTexture(normalMap);
404
- applyTexture(areaMaterial, interiortexture, 100, 100);
405
- }
406
- var object1 = object;
407
- var newAltitude = element.properties.get('altitude').get('_length');
408
- var newUnit = element.properties.get('altitude').get('_unit') || 'in';
409
- newAltitude = convert(newAltitude).from(newUnit).to(scene.unit);
410
- var _element = element.toJS();
411
- if (!_element.doorStyle.doorStyles.is_euro_cds) {
412
- object1.scale.set(100 * newWidth / sizeinfo.width, 100 * newHeight / sizeinfo.height, 100 * newDepth / sizeinfo.depth);
413
- } else {
414
- object1.scale.set(100, 100, 100);
415
- }
416
- // Normalize the origin of the object
417
- var boundingBox = GeomUtils.baseBox3FromObject(object1);
418
- object1.userData = boundingBox;
419
- var door_animate_offset = {};
420
- var matchStr = /\d_(door[^LR1-9]*)(_[LR])?(_[1-9])?$/;
421
- object1.children.forEach(function (child) {
422
- var door_match = child.name.match(matchStr);
423
- if (door_match && door_match.length > 2) {
424
- var _child$children$;
425
- var rotate_match_text = element.properties.toJS().flip_doorhandle ? 'rotate_L' : 'rotate_R';
426
- if (door_match[2] === '_L') {
427
- rotate_match_text = element.properties.toJS().flip_doorhandle ? 'rotate_R' : 'rotate_L';
428
- }
429
- var isDoubleDoor = door_match && door_match[2] !== undefined;
430
- (_child$children$ = child.children[0]) === null || _child$children$ === void 0 || _child$children$.children.forEach(function (it) {
431
- var _it$name, _it$children;
432
- if (it !== null && it !== void 0 && (_it$name = it.name) !== null && _it$name !== void 0 && _it$name.includes('handle') && (_it$children = it.children) !== null && _it$children !== void 0 && _it$children.length && is_corner === 1 && isDoubleDoor) {
433
- var _child$name, _child$name2, _object1$children, _t0$name, _t0$children;
434
- var tname = child !== null && child !== void 0 && (_child$name = child.name) !== null && _child$name !== void 0 && _child$name.endsWith('_L') ? child.name.replace('_L', '_R') : child === null || child === void 0 || (_child$name2 = child.name) === null || _child$name2 === void 0 ? void 0 : _child$name2.replace('_R', '_L');
435
- var tmp = (object1 === null || object1 === void 0 || (_object1$children = object1.children) === null || _object1$children === void 0 ? void 0 : _object1$children.filter(function (item) {
436
- return (item === null || item === void 0 ? void 0 : item.name) === tname;
437
- })) || [];
438
- var t0 = tmp[0];
439
- var filterStr = t0 !== null && t0 !== void 0 && (_t0$name = t0.name) !== null && _t0$name !== void 0 && _t0$name.endsWith('_L') ? 'rotate_L' : 'rotate_R';
440
- var tposArr = (t0 === null || t0 === void 0 || (_t0$children = t0.children) === null || _t0$children === void 0 || (_t0$children = _t0$children[0]) === null || _t0$children === void 0 || (_t0$children = _t0$children.children) === null || _t0$children === void 0 ? void 0 : _t0$children.filter(function (item) {
441
- var _item$name;
442
- return item === null || item === void 0 || (_item$name = item.name) === null || _item$name === void 0 ? void 0 : _item$name.endsWith(filterStr);
443
- })) || [];
444
- var tpos0 = tposArr[0];
445
- if (it.name.includes('base_end')) {
446
- var _it$position$x, _it$position, _it$position$y, _it$position2, _tpos0$position$x, _tpos0$position;
447
- door_animate_offset[child.name] = {
448
- x: -2 * ((_it$position$x = (_it$position = it.position) === null || _it$position === void 0 ? void 0 : _it$position.x) !== null && _it$position$x !== void 0 ? _it$position$x : 0) - 0.12,
449
- y: (_it$position$y = (_it$position2 = it.position) === null || _it$position2 === void 0 ? void 0 : _it$position2.y) !== null && _it$position$y !== void 0 ? _it$position$y : 0,
450
- z: -((_tpos0$position$x = tpos0 === null || tpos0 === void 0 || (_tpos0$position = tpos0.position) === null || _tpos0$position === void 0 ? void 0 : _tpos0$position.x) !== null && _tpos0$position$x !== void 0 ? _tpos0$position$x : 0) + 0.12,
451
- isCorner: true
452
- };
453
- } else {
454
- var _it$position$x2, _it$position3, _it$position$y2, _it$position4, _tpos0$position$x2, _tpos0$position2;
455
- door_animate_offset[child.name] = {
456
- x: -((_it$position$x2 = (_it$position3 = it.position) === null || _it$position3 === void 0 ? void 0 : _it$position3.x) !== null && _it$position$x2 !== void 0 ? _it$position$x2 : 0) - 0.04,
457
- y: (_it$position$y2 = (_it$position4 = it.position) === null || _it$position4 === void 0 ? void 0 : _it$position4.y) !== null && _it$position$y2 !== void 0 ? _it$position$y2 : 0,
458
- z: 2 * ((_tpos0$position$x2 = tpos0 === null || tpos0 === void 0 || (_tpos0$position2 = tpos0.position) === null || _tpos0$position2 === void 0 ? void 0 : _tpos0$position2.x) !== null && _tpos0$position$x2 !== void 0 ? _tpos0$position$x2 : 0) - 0.01,
459
- isCorner: true
460
- };
461
- }
462
- } else if (it.name.endsWith(rotate_match_text) && door_animate_offset[child.name] == undefined) {
463
- door_animate_offset[child.name] = {
464
- x: it.position.x,
465
- y: it.position.y,
466
- z: it.position.z,
467
- isCorner: false
468
- };
469
- }
470
- });
471
- }
472
- });
473
- object1.userData.door_animate_offset = door_animate_offset;
474
- object1.userData.animation = userData;
475
- var center = [(boundingBox.max.x - boundingBox.min.x) / 2 + boundingBox.min.x, (boundingBox.max.y - boundingBox.min.y) / 2 + boundingBox.min.y, (boundingBox.max.z - boundingBox.min.z) / 2 + boundingBox.min.z];
476
- object1.position.x -= center[0];
477
- object1.position.y -= center[1] - (boundingBox.max.y - boundingBox.min.y) / 2;
478
- object1.position.z -= center[2];
479
- object1.position.y += newAltitude;
480
- if (element.selected) {
481
- // if object is selected
482
- // save object transform info///
483
- var scalevec = new Three.Vector3(object1.scale.x, object1.scale.y, object1.scale.z);
484
- var posVec = new Three.Vector3(object1.position.x, object1.position.y, object1.position.z);
485
- object.scale.set(1 * newWidth / sizeinfo.width, 1 * newHeight / sizeinfo.height, 1 * newDepth / sizeinfo.depth);
486
- object1.position.set(0, 0, 0);
487
- object1.rotation.set(0, 0, 0);
488
-
489
- //let box = new Three.BoxHelper(object, 0xffffff);
490
- //box.material.lineWidth = 5;
491
- //box.renderOrder = 1000;
492
- //box.material.depthTest = false;
493
- //object.add(box);
494
- var _boundingBox = GeomUtils.baseBox3FromObject(object);
495
- var max = _boundingBox.max;
496
- var min = _boundingBox.min;
497
- var radius = Math.sqrt((_boundingBox.max.x - _boundingBox.min.x) * (_boundingBox.max.x - _boundingBox.min.x) + (_boundingBox.max.z - _boundingBox.min.z) * (_boundingBox.max.z - _boundingBox.min.z)) / 2;
498
- var moveBox = new Three.BoxGeometry(max.x - min.x, max.y - min.y, max.z - min.z);
499
-
500
- // translate Object
501
- var controlGeom = GeomUtils.controlGeom();
502
-
503
- // rotate Object //////////
504
- var rotGeom = GeomUtils.rotGeoms(radius + 0.05);
505
- // //////////////////////////////////
506
-
507
- // upwards Geometry/////////// Move up Object
508
- var upwardsGeom = GeomUtils.upwardsGeom();
509
-
510
- // vertical line - 4 lines around object//////////////////////////
511
- var vLineGeom = new Three.BufferGeometry();
512
- var vertices = [(max.x - min.x) / 2 + min.x, 0, max.z, (max.x - min.x) / 2 + min.x, 0, max.z + 1.3];
513
- vLineGeom.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices), 3));
514
- var vLineGeom1 = new Three.BufferGeometry();
515
- var vertices1 = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z - 1.3];
516
- vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices1), 3));
517
- var vLineGeom2 = new Three.BufferGeometry();
518
- var vertices2 = [max.x, 0, max.z - (max.z - min.z) / 2, max.x + 1.3, 0, max.z - (max.z - min.z) / 2];
519
- vLineGeom2.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices2), 3));
520
- var vLineGeom3 = new Three.BufferGeometry();
521
- var vertices3 = [min.x, 0, max.z - (max.z - min.z) / 2, min.x - 1.3, 0, max.z - (max.z - min.z) / 2];
522
- vLineGeom3.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices3), 3));
523
- // ///////////////////////////////////////
524
-
525
- // set names of transform object
526
- var rotFillObj = new Three.Mesh(rotGeom.rotFill, new Three.MeshPhongMaterial({
527
- color: new Three.Color(0x000000).convertLinearToSRGB(),
528
- side: Three.DoubleSide,
529
- colorWrite: true
530
- }));
531
- var rotStrokeObj = new Three.Line(rotGeom.rotStroke, new Three.LineBasicMaterial({
532
- color: new Three.Color(0xffffff).convertLinearToSRGB(),
533
- colorWrite: true
534
- }));
535
- rotFillObj.name = 'rotate';
536
- var upObj = new Three.Mesh(upwardsGeom, new Three.MeshBasicMaterial({
537
- color: new Three.Color(0xffffff).convertLinearToSRGB(),
538
- side: Three.DoubleSide
539
- }));
540
- upObj.name = 'transUp';
541
- var mBox = new Three.Mesh(moveBox, new Three.MeshBasicMaterial({
542
- color: new Three.Color(0xdd6699).convertLinearToSRGB(),
543
- side: Three.DoubleSide,
544
- transparent: true,
545
- opacity: 0.4
546
- }));
547
- var _color = new Three.Color(SHADE_DARK_PURPLE_COLOR).convertLinearToSRGB();
548
- var vLine = new Three.Line(vLineGeom, new Three.LineBasicMaterial({
549
- color: _color
550
- }));
551
- var vLine1 = new Three.Line(vLineGeom1, new Three.LineBasicMaterial({
552
- color: _color
553
- }));
554
- var vLine2 = new Three.Line(vLineGeom2, new Three.LineBasicMaterial({
555
- color: _color
556
- }));
557
- var vLine3 = new Three.Line(vLineGeom3, new Three.LineBasicMaterial({
558
- color: _color
559
- }));
560
- vLine.renderOrder = 1;
561
- vLine1.renderOrder = 1;
562
- vLine2.renderOrder = 1;
563
- vLine3.renderOrder = 1;
564
- vLine.material.transparent = true;
565
- vLine1.material.transparent = true;
566
- vLine2.material.transparent = true;
567
- vLine3.material.transparent = true;
568
- vLine.material.depthTest = false;
569
- vLine1.material.depthTest = false;
570
- vLine2.material.depthTest = false;
571
- vLine3.material.depthTest = false;
572
- // translate vector to center of object
573
- var uVec = new Three.Vector3(-posVec.x / scalevec.x, -posVec.y / scalevec.y, -posVec.z / scalevec.z);
574
- vLine.translateY(0.1);
575
- vLine1.translateY(0.1);
576
- vLine2.translateY(0.1);
577
- vLine3.translateY(0.1);
578
-
579
- //rotObj.translateOnAxis(uVec, 1);
580
- upObj.translateOnAxis(uVec, 1);
581
- upObj.translateY(max.y - min.y);
582
- mBox.name = 'TransformBox';
583
- mBox.translateOnAxis(new Three.Vector3(uVec.x, uVec.y + (max.y - min.y) / 2, uVec.z), 1);
584
- mBox.scale.set(1.01, 1.01, 1.01);
585
-
586
- // other side rotate object
587
- var rotFillObj1 = rotFillObj.clone();
588
- var rotStrokeObj1 = rotStrokeObj.clone();
589
- rotFillObj1.rotateY(Math.PI);
590
- rotStrokeObj1.rotateY(Math.PI);
591
- rotFillObj.translateY(0.1);
592
- rotFillObj1.translateY(0.1);
593
- rotStrokeObj.translateY(0.1);
594
- rotStrokeObj1.translateY(0.1);
595
-
596
- // assets Objects group includes rotate objects...
597
- var asrtObj = new Three.Group();
598
- // asrtObj.add(rotFillObj);
599
- // asrtObj.add(rotFillObj1);
600
- // asrtObj.add(rotStrokeObj);
601
- // asrtObj.add(rotStrokeObj1);
602
- //asrtObj.add(upObj);
603
- asrtObj.add(vLine);
604
- asrtObj.add(vLine1);
605
- asrtObj.add(vLine2);
606
- asrtObj.add(vLine3);
607
- mBox.visible = false;
608
- asrtObj.add(mBox);
609
- asrtObj.scale.set(1 / object.scale.x, object.scale.y, 1 / object.scale.z);
610
- //asrtObj.translateY(newAltitude / scalevec.y);
611
- asrtObj.name = 'TransformGizmo';
612
- // add assets Objects Group
613
- object1.add(asrtObj);
614
-
615
- // recover objects transform
616
- object1.position.x = posVec.x;
617
- object1.position.y = posVec.y;
618
- object1.position.z = posVec.z;
619
- object1.scale.set(scalevec.x, scalevec.y, scalevec.z);
620
- setTimeout(function () {
621
- SceneCreator.getDistances(layer);
622
- }, 100);
623
- }
624
- var flip_doorhandle = element.properties.get('flip_doorhandle');
625
- if (flip_doorhandle) {
626
- SceneCreator.updateDoorHandleMesh(element, object1, true);
627
- }
628
- object1.traverse(function (obj) {
629
- if (obj.type === OBJTYPE_MESH) {
630
- var name = obj.name;
631
- if (name.match(/_door_.*_glass_/)) {
632
- var material = new Three.MeshPhysicalMaterial({
633
- roughness: 0,
634
- transmission: 1,
635
- thickness: 0.5,
636
- // Add refraction!
637
- transparency: 0.8
638
- });
639
- obj.material = material;
640
- } else if (name.startsWith('sink_')) {
641
- // texture = loadTexture('/assets/img/texture/steel.jpg');
642
-
643
- var _material;
644
- // Get color from name
645
- if (name.includes('black') || name.includes('white')) {
646
- var _color2;
647
- if (name.includes('black')) {
648
- _color2 = new Three.Color(0x555555).convertLinearToSRGB();
649
- } else {
650
- _color2 = 0xffffff;
651
- }
652
- _material = new Three.MeshPhysicalMaterial({
653
- roughness: 0.5,
654
- metalness: 0,
655
- // transmission: 1,
656
- transparent: true,
657
- opacity: 1,
658
- thickness: 0.5,
659
- // Add refraction!
660
- // transparency: 0.8,
661
- color: _color2,
662
- side: Three.DoubleSide
663
- });
664
- } else {
665
- // if (name.includes('chrome')) {
666
- _material = new Three.MeshPhysicalMaterial({
667
- roughness: 0.2,
668
- metalness: 1,
669
- reflectivity: 0.5,
670
- color: new Three.Color(0xdddddd).convertLinearToSRGB()
671
- });
672
- }
673
- obj.material = _material;
674
- }
675
- }
676
- if (element.toJS().properties.open_doors) {
677
- var open_doors = element.toJS().properties.open_doors;
678
- var object_match = obj.name.match(/\d_(interior_drawer[^LR1-9]*)(_[LR1-9])?$/) || obj.name.match(matchStr);
679
- if (object_match && object_match.length > 2) {
680
- var isDoor = object_match[1] === 'door';
681
- if (isDoor) {
682
- var offsetData = object1.userData.door_animate_offset[obj.name];
683
- // Open Door
684
- animateDoor(offsetData, obj, open_doors, element.toJS(), is_corner, 'Opened2D');
685
- } else {
686
- // Open Drawer
687
- translateDrawer(element.toJS(), obj, open_doors, 'Opened2D');
688
- }
689
- }
690
- }
691
- });
692
- return object1;
693
- };
694
- // keys in structure
695
- var keys = Object.keys(structure);
696
- // if exist in cached Objects
697
- if (element.type + color + 'doorStyle' + JSON.stringify(doorStyles.toJS()) + element.counterTop.uri in cachedObject) {
698
- var _objGroup = cachedObject[element.type + color + 'doorStyle' + JSON.stringify(doorStyles.toJS())].clone();
699
- return Promise.resolve(onLoadItem(_objGroup.clone()));
700
- }
701
-
702
- // base Object/////
703
- var objGroup = null;
704
- var _loadGLTFs = function loadGLTFs(i) {
705
- if (keys[i] === 'animation') {
706
- // if animation info
707
- i++;
708
- return _loadGLTFs(i);
709
- }
710
- if (keys[i] === 'placeholders') {
711
- // if placeholders group
712
- i++;
713
- return _loadGLTFs(i);
714
- }
715
- if (i === keys.length) {
716
- // if end of keys
717
- cachedObject[element.type + color + 'doorStyle' + JSON.stringify(doorStyles.toJS())] = objGroup.clone(); //register to cachedObject
718
- return onLoadItem(cachedObject[element.type + color + 'doorStyle' + JSON.stringify(doorStyles.toJS())].clone());
719
- }
720
- if (keys[i] === 'base') {
721
- // if base Objects
722
- i++;
723
- return _loadGLTFs(i);
724
- }
725
- var phsArray = [];
726
- var placeholderStructure = placeholders[keys[i]];
727
- if (placeholderStructure == undefined || placeholderStructure.length == 0) {
728
- i++;
729
- return _loadGLTFs(i);
730
- }
731
- for (var j = 0; j < placeholderStructure.length; j++) {
732
- var phData = placeholderStructure[j];
733
- var phs = phData.split('/');
734
- var temp = phData.split('/');
735
- // placeholder remake////////////////
736
- for (var k = 0; k < phs.length; k++) {
737
- if (phs[k] in placeholders) {
738
- var placeholderphs = placeholders[phs[k]];
739
- var key = placeholderStructure.length / placeholderphs.length;
740
- phs[k] = placeholderphs[Math.floor(j / key)];
741
- var splitedData = phs[k].split('/');
742
- if (splitedData.length > 1) {
743
- phs[k] = splitedData[splitedData.length - 1];
744
- for (var m = splitedData.length - 2; m >= 0; m--) {
745
- phs.unshift(splitedData[m]);
746
- temp.unshift(splitedData[m]);
747
- }
748
- }
749
- k = -1;
750
- continue;
751
- }
752
- if (phs[k].indexOf('ph') == -1) {
753
- var _url = structure[temp[k - 1]];
754
- if (temp[k - 1] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS()) in structure) {
755
- if (structure[temp[k - 1] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS())] != null) {
756
- _url = structure[temp[k - 1] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS())];
757
- }
758
- }
759
- if (_typeof(_url) == Array) _url = _url[0];
760
- var uData = _url.split('/');
761
- uData = uData[uData.length - 1];
762
- uData = uData.slice(0, -5);
763
- var datas = uData.split('_');
764
- uData = datas[1];
765
- for (var _i = 2; _i < datas.length; _i++) {
766
- uData += '_';
767
- uData += datas[_i];
768
- }
769
- uData = mainName.replace('main', uData);
770
- phs[k] = 'ph_' + uData + '_' + phs[k];
771
- }
772
- }
773
- phsArray.push(phs);
774
- }
775
- var url = structure[keys[i]];
776
- var normalMap = '';
777
- var urlData = url.split('/');
778
- for (var _j = 0; _j < element.submodule.size; _j++) {
779
- var replaceUrlData = element.submodule.get(_j).split('/');
780
- if (urlData.includes(replaceUrlData[replaceUrlData.length - 2])) {
781
- url = element.submodule.get(_j);
782
- break;
783
- }
784
- }
785
- for (var _j2 = 0; _j2 < element.normalMap.size; _j2++) {
786
- var normalMapData = element.normalMap.get(_j2).split('/');
787
- if (urlData.includes(normalMapData[normalMapData.length - 2])) {
788
- normalMap = element.normalMap.get(_j2);
789
- break;
790
- }
791
- }
792
-
793
- // replace submodule gltf file
794
- // if (placeholderTree.length > 0) {
795
- if (phsArray.length > 0) {
796
- // let loadUrl = dirName + url;
797
- var loadUrl = url;
798
- if (doorStyles.get(keys[i] + '_gltf') != undefined) {
799
- loadUrl = doorStyles.get(keys[i] + '_gltf');
800
- structure[keys[i] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS())] = loadUrl;
801
- } else {
802
- structure[keys[i] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS())] = null;
803
- }
804
- return loadGLTF(loadUrl).then(function (object) {
805
- if (normalMap !== '') {
806
- var normalUrl = normalMap.split('.')[0] + '-normal.' + normalMap.split('.')[1];
807
- var t = loadTexture(normalMap);
808
- var _m = loadTexture(normalUrl);
809
- var mat2 = new Three.MeshStandardMaterial({
810
- metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
811
- roughness: glossness || params.roughness
812
- });
813
- mat2.map = t;
814
- mat2.normalMap = _m;
815
- // mat2.envMap = textureCube;
816
- for (var _j3 = 0; _j3 < object.children.length; _j3++) {
817
- if (object.children[_j3].type === OBJTYPE_MESH) {
818
- object.children[_j3].material = mat2;
819
- object.children[_j3].receiveShadow = true;
820
- }
821
- }
822
- }
823
-
824
- // set Door Style////
825
- if (doorStyles != null) if (doorStyles.get(keys[i]) != undefined) {
826
- // let normalMap = "catalog/items/doorstyle/" + doorStyles.get(keys[i]);
827
- var _normalMap = doorStyles.get(keys[i]);
828
- var _mat;
829
- if (_normalMap === '') {
830
- var examplecolor = new Three.Color(parseInt(color.slice(1), 16)).convertLinearToSRGB();
831
- _mat = new Three.MeshStandardMaterial({
832
- color: examplecolor,
833
- metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
834
- roughness: glossness || params.roughness
835
- });
836
- } else {
837
- var _t = loadTexture(_normalMap);
838
- _mat = new Three.MeshStandardMaterial({
839
- // NOTE : this is for cabinets (wood) frontface
840
- metalness: 0.1,
841
- roughness: 0.5
842
- // metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
843
- // roughness: glossness || params.roughness
844
- });
845
- _mat.map = _t;
846
- }
847
- // mat2.envMap = textureCube;
848
- for (var _j4 = 0; _j4 < object.children.length; _j4++) {
849
- if (object.children[_j4].type === OBJTYPE_MESH) {
850
- object.children[_j4].material = _mat;
851
- object.children[_j4].receiveShadow = true;
852
- object.children[_j4].castShadow = true;
853
- !object.children[_j4].name.includes('handle') && addEdgesToMesh(object.children[_j4]);
854
- } else if (!object.children[_j4].name.startsWith('ph_') && object.children[_j4].type === OBJTYPE_GROUP) {
855
- object.children[_j4].traverse(function (prim) {
856
- prim.material = _mat;
857
- prim.receiveShadow = true;
858
- });
859
- }
860
- }
861
- } else {
862
- var _mat2 = new Three.MeshStandardMaterial({
863
- metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
864
- roughness: glossness || params.roughness
865
- });
866
- // mat2.envMap = textureCube;
867
- for (var _j5 = 0; _j5 < object.children.length; _j5++) {
868
- if (object.children[_j5].type === OBJTYPE_MESH) {
869
- object.children[_j5].material = _mat2;
870
- object.children[_j5].receiveShadow = true;
871
- }
872
- }
873
- }
874
- for (var _i2 = 0; _i2 < phsArray.length; _i2++) {
875
- var _phs = phsArray[_i2];
876
- var parent = objGroup;
877
- for (var _j6 = 0; _j6 < _phs.length; _j6++) {
878
- var placeholder = _phs[_j6];
879
- for (var _k = 0; _k < ((_parent = parent) === null || _parent === void 0 ? void 0 : _parent.children.length); _k++) {
880
- var _parent;
881
- if (_j6 != _phs.length - 1) {
882
- if (parent.children[_k].name == placeholder) {
883
- parent = parent.children[_k].children[0];
884
- break;
885
- }
886
- } else {
887
- if (parent.children[_k].name == placeholder) {
888
- var tmp = object.clone();
889
- if (placeholder.includes('drawer_door') && placeholder.includes('_handle')) {
890
- tmp.rotateZ(Math.PI / 2);
891
- }
892
- if (placeholder.includes('_handle') && tmp.children[0].type === OBJTYPE_MESH) {
893
- // NOTE: change metalness of handle
894
- tmp.children[0].material.metalness = 1;
895
- // handleMaterial.metalness || 0.2;
896
- tmp.children[0].material.roughness = handleMaterial.roughness || 0.1;
897
- //tmp.children[0].material.map = loadTexture('catalog/areas/area/textures/grass.jpg');
898
- }
899
- parent.children[_k].add(tmp);
900
- }
901
- }
902
- }
903
- }
904
- }
905
- }, function (reason) {
906
- console.log('loadGLTF failed for reason:', reason);
907
- }).then(function () {
908
- i++;
909
- return _loadGLTFs(i);
910
- });
911
- }
912
- };
913
- return loadGLTF(structure['base']).then(function (object) {
914
- object.name = 'MainObject';
915
- object.receiveShadow = true;
916
- objGroup = object;
917
- if (doorStyles != null) if (doorStyles.get('base') != undefined) {
918
- var normalMap = doorStyles.get('base');
919
- if (counterTop.uri === undefined) {
920
- try {
921
- counterTop = counterTop.toJS();
922
- } catch (error) {
923
- console.log(error);
924
- }
925
- }
926
- if (counterTop.uri === undefined && layer.toJS().counterTop.uri !== undefined) {
927
- counterTop.uri = layer.toJS().counterTop.uri;
928
- }
929
- var countTopMap = counterTop.uri;
930
- var interiorMap = doorStyles.get('interior');
931
- var countT = loadTexture(countTopMap);
932
- countT.wrapS = Three.RepeatWrapping;
933
- countT.wrapT = Three.RepeatWrapping;
934
- countT.repeat.set(1, 1);
935
- var examplecolor = new Three.Color(parseInt(color.slice(1), 16)).convertLinearToSRGB();
936
- var mat2 = null,
937
- mat3 = null,
938
- mat4 = null;
939
- if (normalMap === '') {
940
- mat2 = new Three.MeshStandardMaterial({
941
- color: examplecolor,
942
- metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
943
- roughness: glossness || params.roughness
944
- });
945
- } else {
946
- mat2 = new Three.MeshStandardMaterial({
947
- // TODO: changes in metalness and roughness of base_main (cabinet wood)
948
- metalness: 0.1,
949
- roughness: 0.5
950
- // metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
951
- // roughness: glossness || params.roughness
952
- });
953
- }
954
- // mat2.envMap = textureCube;
955
-
956
- if (normalMap !== '') {
957
- var t = loadTexture(normalMap);
958
- mat2.map = t;
959
- }
960
- if (normalMap === '') {
961
- mat3 = new Three.MeshStandardMaterial({
962
- // color: examplecolor,
963
- metalness: counterTop.metalness,
964
- roughness: counterTop.roughness
965
- });
966
- } else {
967
- mat3 = new Three.MeshStandardMaterial({
968
- // metalness: counterTop.metalness,
969
- // roughness: counterTop.roughness
970
- metalness: 0.3,
971
- roughness: 0.8
972
- });
973
- }
974
- mat3.map = countT;
975
- // mat3.envMap = textureCube;
976
- mat4 = new Three.MeshStandardMaterial({
977
- metalness: params.metalness,
978
- roughness: params.roughness
979
- });
980
- mat4.map = loadTexture(interiorMap);
981
- for (var j = 0; j < object.children.length; j++) {
982
- if (object.children[j].name.includes('main')) {}
983
- if (object.children[j].name.includes('countertop')) {
984
- object.children[j].material = mat3;
985
- object.children[j].receiveShadow = true;
986
- object.children[j].castShadow = true;
987
- addEdgesToMesh(object.children[j]);
988
- } else if (object.children[j].name.includes('_interior_')) {
989
- object.children[j].material = mat4;
990
- } else if (object.children[j].type === OBJTYPE_MESH) {
991
- object.children[j].material = mat2;
992
- object.children[j].receiveShadow = true;
993
- object.children[j].castShadow = true;
994
- }
995
- }
996
- }
997
- }, function (reason) {
998
- console.log('loadGLTF failed for reason:', reason);
999
- objGroup = GeomUtils.emptyBoxHolder(newWidth, newHeight, newDepth);
1000
- }).then(function () {
1001
- return _loadGLTFs(0);
1002
- });
1003
- }
1004
-
1005
- // render 3d appliance function ////////////////////////////////
1006
- export function render3DApplianceItem(element, layer, scene, sizeinfo, structure_json) {
1007
- var mode = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : null;
1008
- var structure = structure_json;
1009
- var applianceMaterial = element.applianceMaterial;
1010
- if (applianceMaterial.metalness == undefined) applianceMaterial = applianceMaterial.toJS();
1011
- var onLoadItem = function onLoadItem(object) {
1012
- var newAltitude = element.properties.get('altitude').get('_length');
1013
- var newUnit = element.properties.get('altitude').get('_unit') || 'in';
1014
- newAltitude = convert(newAltitude).from(newUnit).to(scene.unit);
1015
- var newWidth = element.properties.get('width').get('_length');
1016
- var newWidthUnit = element.properties.get('width').get('_unit') || 'in';
1017
- newWidth = convert(newWidth).from(newWidthUnit).to('in');
1018
- var newHeight = element.properties.get('height').get('_length');
1019
- var newHeightUnit = element.properties.get('height').get('_unit') || 'in';
1020
- newHeight = convert(newHeight).from(newHeightUnit).to('in');
1021
- var newDepth = element.properties.get('depth').get('_length');
1022
- var newDepthUnit = element.properties.get('depth').get('_unit') || 'in';
1023
- newDepth = convert(newDepth).from(newDepthUnit).to('in');
1024
- object.scale.set(100 * newWidth / sizeinfo.width, 100 * newHeight / sizeinfo.height, 100 * newDepth / sizeinfo.depth);
1025
- // Normalize the origin of the object
1026
- var boundingBox = new Three.Box3().setFromObject(object);
1027
- object.userData = boundingBox;
1028
- var center = [(boundingBox.max.x - boundingBox.min.x) / 2 + boundingBox.min.x, (boundingBox.max.y - boundingBox.min.y) / 2 + boundingBox.min.y, (boundingBox.max.z - boundingBox.min.z) / 2 + boundingBox.min.z];
1029
- object.position.x -= center[0];
1030
- object.position.y -= center[1] - (boundingBox.max.y - boundingBox.min.y) / 2;
1031
- object.position.z -= center[2];
1032
- object.position.y += newAltitude;
1033
- object.traverse(function (obj) {
1034
- if (obj.type === OBJTYPE_MESH) {
1035
- var name = obj.name;
1036
- var texture,
1037
- textureLoader = new Three.TextureLoader();
1038
- if (name.includes('_black')) {
1039
- obj.material.roughness = 0.4;
1040
- obj.material.metalness = 1.0;
1041
- obj.material.color = new Three.Color(0, 0, 0);
1042
- obj.castShadow = true;
1043
- obj.receiveShadow = true;
1044
- return object;
1045
- } else if (name.includes('_wood')) {
1046
- texture = loadTexture('/assets/img/texture/wood.jpg');
1047
- } else if (name.includes('_glass')) {
1048
- // texture = loadTexture('/assets/img/texture/glass.jpg');
1049
- var material = new Three.MeshPhysicalMaterial({
1050
- transparent: true,
1051
- opacity: 0.5,
1052
- roughness: 0,
1053
- transmission: 1,
1054
- thickness: 0.5,
1055
- // Add refraction!
1056
- transparency: 0.8
1057
- });
1058
- obj.material = material;
1059
- obj.castShadow = true;
1060
- obj.receiveShadow = true;
1061
- return object;
1062
- } else if (name.includes('_steel')) {
1063
- // texture = loadTexture('/assets/img/texture/steel.jpg');
1064
- var _material2 = new Three.MeshPhysicalMaterial({
1065
- roughness: 0.2,
1066
- metalness: 0.5,
1067
- reflectivity: 0.5,
1068
- color: new Three.Color(0xdddddd).convertLinearToSRGB()
1069
- });
1070
- obj.material = _material2;
1071
- obj.castShadow = true;
1072
- obj.receiveShadow = true;
1073
- return object;
1074
- }
1075
- var mat = new Three.MeshStandardMaterial({
1076
- metalness: 0.1,
1077
- roughness: 0.9,
1078
- map: texture
1079
- });
1080
- obj.material = mat;
1081
- }
1082
- });
1083
- if (element.selected) {
1084
- // if object is selected
1085
- // save object transform info///
1086
- var scalevec = new Three.Vector3(object.scale.x, object.scale.y, object.scale.z);
1087
- var posVec = new Three.Vector3(object.position.x, object.position.y, object.position.z);
1088
- object.scale.set(1 * newWidth / sizeinfo.width, 1 * newHeight / sizeinfo.height, 1 * newDepth / sizeinfo.depth);
1089
- object.position.set(0, 0, 0);
1090
- object.rotation.set(0, 0, 0);
1091
- var _boundingBox2 = new Three.Box3().setFromObject(object);
1092
- var max = _boundingBox2.max;
1093
- var min = _boundingBox2.min;
1094
- var radius = Math.sqrt((_boundingBox2.max.x - _boundingBox2.min.x) * (_boundingBox2.max.x - _boundingBox2.min.x) + (_boundingBox2.max.z - _boundingBox2.min.z) * (_boundingBox2.max.z - _boundingBox2.min.z)) / 2;
1095
- var moveBox = new Three.BoxGeometry(max.x - min.x, max.y - min.y, max.z - min.z);
1096
-
1097
- // translate Object
1098
- var controlGeom = GeomUtils.controlGeom();
1099
- // ////////////////////////
1100
-
1101
- // rotate Object //////////
1102
- var rotGeom = GeomUtils.rotGeoms(radius + 0.05);
1103
- // //////////////////////////////////
1104
-
1105
- // upwards Geometry/////////// Move up Object
1106
- var upwardsGeom = GeomUtils.upwardsGeom();
1107
- // ///////////////////////////////////////
1108
-
1109
- // vertical line - 4 lines around object//////////////////////////
1110
- var vLineGeom = new Three.BufferGeometry();
1111
- var vertices = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z + 1.3];
1112
- vLineGeom.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices), 3));
1113
- var vLineGeom1 = new Three.BufferGeometry();
1114
- var vertices1 = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z - 1.3];
1115
- vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices1), 3));
1116
- var vLineGeom2 = new Three.BufferGeometry();
1117
- var vertices2 = [max.x, 0, max.z - (max.z - min.z) / 2, max.x + 1.3, 0, max.z - (max.z - min.z) / 2];
1118
- vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices2), 3));
1119
- var vLineGeom3 = new Three.BufferGeometry();
1120
- var vertices3 = [min.x, 0, max.z - (max.z - min.z) / 2, min.x - 1.3, 0, max.z - (max.z - min.z) / 2];
1121
- vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices3), 3));
1122
- // ///////////////////////////////////////
1123
-
1124
- // set names of transform object
1125
- var rotFillObj = new Three.Mesh(rotGeom.rotFill, new Three.MeshPhongMaterial({
1126
- color: 0x000000,
1127
- side: Three.DoubleSide,
1128
- colorWrite: true
1129
- }));
1130
- var rotStrokeObj = new Three.Line(rotGeom.rotStroke, new Three.LineBasicMaterial({
1131
- color: 0xffffff,
1132
- colorWrite: true
1133
- }));
1134
- rotFillObj.name = 'rotate';
1135
- var upObj = new Three.Mesh(upwardsGeom, new Three.MeshBasicMaterial({
1136
- color: 0xffffff,
1137
- side: Three.DoubleSide
1138
- }));
1139
- upObj.name = 'transUp';
1140
- var mBox = new Three.Mesh(moveBox, new Three.MeshBasicMaterial({
1141
- color: new Three.Color(0xdd6699).convertLinearToSRGB(),
1142
- side: Three.DoubleSide,
1143
- transparent: true,
1144
- opacity: 0.4
1145
- }));
1146
- var color = new Three.Color(ARROW_COLOR).convertLinearToSRGB();
1147
- var vLine = new Three.Line(vLineGeom, new Three.LineBasicMaterial({
1148
- color: color
1149
- }));
1150
- var vLine1 = new Three.Line(vLineGeom1, new Three.LineBasicMaterial({
1151
- color: color
1152
- }));
1153
- var vLine2 = new Three.Line(vLineGeom2, new Three.LineBasicMaterial({
1154
- color: color
1155
- }));
1156
- var vLine3 = new Three.Line(vLineGeom3, new Three.LineBasicMaterial({
1157
- color: color
1158
- }));
1159
- vLine.renderOrder = 1;
1160
- vLine1.renderOrder = 1;
1161
- vLine2.renderOrder = 1;
1162
- vLine3.renderOrder = 1;
1163
- vLine.material.transparent = true;
1164
- vLine1.material.transparent = true;
1165
- vLine2.material.transparent = true;
1166
- vLine3.material.transparent = true;
1167
- vLine.material.depthTest = false;
1168
- vLine1.material.depthTest = false;
1169
- vLine2.material.depthTest = false;
1170
- vLine3.material.depthTest = false;
1171
- // translate vector to center of object
1172
- var uVec = new Three.Vector3(-posVec.x / scalevec.x, -posVec.y / scalevec.y, -posVec.z / scalevec.z);
1173
- vLine.translateY(0.1);
1174
- vLine1.translateY(0.1);
1175
- vLine2.translateY(0.1);
1176
- vLine3.translateY(0.1);
1177
- upObj.translateOnAxis(uVec, 1);
1178
- upObj.translateY(max.y - min.y + 0.05);
1179
- mBox.name = 'TransformBox';
1180
- mBox.translateOnAxis(new Three.Vector3(uVec.x, uVec.y + (max.y - min.y) / 2, uVec.z), 1);
1181
- mBox.scale.set(1.01, 1.01, 1.01);
1182
-
1183
- // other side rotate object
1184
- var rotFillObj1 = rotFillObj.clone();
1185
- var rotStrokeObj1 = rotStrokeObj.clone();
1186
- rotFillObj1.rotateY(Math.PI);
1187
- rotStrokeObj1.rotateY(Math.PI);
1188
- rotFillObj.translateY(0.1);
1189
- rotFillObj1.translateY(0.1);
1190
- rotStrokeObj.translateY(0.1);
1191
- rotStrokeObj1.translateY(0.1);
1192
-
1193
- // assets Objects group includes rotate objects...
1194
- var asrtObj = new Three.Group();
1195
- // asrtObj.add(rotFillObj);
1196
- // asrtObj.add(rotFillObj1);
1197
- // asrtObj.add(rotStrokeObj);
1198
- // asrtObj.add(rotStrokeObj1);
1199
- asrtObj.add(vLine);
1200
- asrtObj.add(vLine1);
1201
- asrtObj.add(vLine2);
1202
- asrtObj.add(vLine3);
1203
- mBox.visible = false;
1204
- asrtObj.add(mBox);
1205
- asrtObj.scale.set(1 / object.scale.x, object.scale.y, 1 / object.scale.z);
1206
- // asrtObj.translateY(newAltitude / scalevec.y);
1207
- asrtObj.name = 'TransformGizmo';
1208
- // add assets Objects Group
1209
- object.add(asrtObj);
1210
-
1211
- // recover objects transform
1212
- object.position.x = posVec.x;
1213
- object.position.y = posVec.y;
1214
- object.position.z = posVec.z;
1215
- object.scale.set(scalevec.x, scalevec.y, scalevec.z);
1216
- }
1217
- return object;
1218
- };
1219
-
1220
- // keys in structure
1221
- var keys = Object.keys(structure);
1222
-
1223
- // if exist in cached Objects
1224
- if (element.type in cachedObject) {
1225
- var _objGroup2 = cachedObject[element.type].clone();
1226
- return Promise.resolve(onLoadItem(_objGroup2.clone()));
1227
- }
1228
-
1229
- // base Object/////
1230
- var objGroup = null;
1231
- var _loadGLTFs2 = function loadGLTFs(i) {
1232
- if (i === keys.length) {
1233
- // if end of keys
1234
- cachedObject[element.type] = objGroup.clone(); //register to cachedObject
1235
- return onLoadItem(cachedObject[element.type].clone());
1236
- }
1237
- if (keys[i] === 'base') {
1238
- // if base Objects
1239
- i++;
1240
- return _loadGLTFs2(i);
1241
- }
1242
- };
1243
-
1244
- // load base to start //
1245
- // return loadGLTF(dirName + structure["base"])
1246
- return loadGLTF(structure['base']).then(function (object) {
1247
- // let textureURL = `${API_SERVER_URL}/uploads/assets/default/steel.jpg`;
1248
- // let texture = loadTexture(textureURL);
1249
- // texture.wrapS = Three.MirroredRepeatWrapping;
1250
- // texture.wrapT = Three.MirroredRepeatWrapping;
1251
-
1252
- object.name = 'MainObject';
1253
- // NOTE: changed appliance emissive color to black
1254
- var mat2 = new Three.MeshStandardMaterial({
1255
- emissive: new Three.Color(0x0d0d0d).convertLinearToSRGB(),
1256
- metalness: applianceMaterial.metalness,
1257
- roughness: applianceMaterial.roughness
1258
- });
1259
- // mat2.envMap = textureCube;
1260
- object.material = mat2;
1261
- for (var j = 0; j < object.children.length; j++) {
1262
- if (object.children[j].type === OBJTYPE_MESH) {
1263
- object.children[j].material = mat2;
1264
- object.children[j].receiveShadow = true;
1265
- object.children[j].castShadow = true; // change
1266
- }
1267
- }
1268
- objGroup = object;
1269
- }, function (reason) {
1270
- console.log('loadGLTF failed for reason:', reason);
1271
- objGroup = GeomUtils.emptyBoxHolder(newWidth, newHeight, newDepth);
1272
- }).then(function () {
1273
- return _loadGLTFs2(0);
1274
- });
1275
- }
1276
- // render 3d appliance function ////////////////////////////////
1277
- export function render3DLightingItem(element, layer, scene, sizeinfo, structure_json) {
1278
- var mode = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : null;
1279
- var structure = structure_json;
1280
- var onLoadItem = function onLoadItem(object) {
1281
- var width = {
1282
- length: sizeinfo.width,
1283
- unit: 'in'
1284
- };
1285
- var depth = {
1286
- length: sizeinfo.depth,
1287
- unit: 'in'
1288
- };
1289
- var height = {
1290
- length: sizeinfo.height,
1291
- unit: 'in'
1292
- };
1293
- var newWidth = convert(width.length).from(width.unit).to('cm');
1294
- var newDepth = convert(depth.length).from(depth.unit).to('cm');
1295
- var newHeight = convert(height.length).from(height.unit).to('cm');
1296
- var newAltitude = element.properties.get('altitude').get('_length');
1297
- var newUnit = element.properties.get('altitude').get('_unit') || 'in';
1298
- newAltitude = convert(newAltitude).from(newUnit).to(scene.unit);
1299
-
1300
- //object.scale.set(newWidth, newHeight, newDepth);
1301
- object.scale.set(100, 100, 100);
1302
- // Normalize the origin of the object
1303
- var boundingBox = new Three.Box3().setFromObject(object);
1304
- object.userData = boundingBox;
1305
- var objectHeight = boundingBox.max.y - boundingBox.min.y;
1306
- var objectYPos = boundingBox.min.y;
1307
- var center = [(boundingBox.max.x - boundingBox.min.x) / 2 + boundingBox.min.x, (boundingBox.max.y - boundingBox.min.y) / 2 + boundingBox.min.y, (boundingBox.max.z - boundingBox.min.z) / 2 + boundingBox.min.z];
1308
- object.position.x = center[0];
1309
- object.position.y = newHeight + newAltitude - boundingBox.max.y;
1310
- object.position.z = center[2];
1311
- if (element.selected) {
1312
- // if object is selected
1313
- // save object transform info///
1314
- var scalevec = new Three.Vector3(object.scale.x, object.scale.y, object.scale.z);
1315
- var posVec = new Three.Vector3(object.position.x, object.position.y, object.position.z);
1316
- object.scale.set(1, 1, 1);
1317
- object.position.set(0, 0, 0);
1318
- object.rotation.set(0, 0, 0);
1319
-
1320
- //let box = new Three.BoxHelper(object, 0xffffff);
1321
- //box.material.lineWidth = 5;
1322
- //box.renderOrder = 1000;
1323
- //box.material.depthTest = false;
1324
- //object.add(box);
1325
- var _boundingBox3 = new Three.Box3().setFromObject(object);
1326
- var max = _boundingBox3.max;
1327
- var min = _boundingBox3.min;
1328
- var radius = Math.sqrt((_boundingBox3.max.x - _boundingBox3.min.x) * (_boundingBox3.max.x - _boundingBox3.min.x) + (_boundingBox3.max.z - _boundingBox3.min.z) * (_boundingBox3.max.z - _boundingBox3.min.z)) / 2;
1329
- var moveBox = new Three.BoxGeometry(max.x - min.x, max.y - min.y, max.z - min.z);
1330
-
1331
- // translate Object
1332
- var controlGeom = GeomUtils.controlGeom();
1333
-
1334
- // rotate Object //////////
1335
- var rotGeom = GeomUtils.rotGeoms(radius + 0.05);
1336
- // //////////////////////////////////
1337
-
1338
- // upwards Geometry/////////// Move up Object
1339
- var upwardsGeom = GeomUtils.upwardsGeom();
1340
-
1341
- // vertical line - 4 lines around object//////////////////////////
1342
- var vLineGeom = new Three.BufferGeometry();
1343
- var vertices = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z + 1.3];
1344
- vLineGeom.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices), 3));
1345
- var vLineGeom1 = new Three.BufferGeometry();
1346
- var vertices1 = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z - 1.3];
1347
- vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices1), 3));
1348
- var vLineGeom2 = new Three.BufferGeometry();
1349
- var vertices2 = [min.x, 0, max.z - (max.z - min.z) / 2, min.x + 1.3, 0, max.z - (max.z - min.z) / 2];
1350
- vLineGeom2.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices2), 3));
1351
- var vLineGeom3 = new Three.BufferGeometry();
1352
- var vertices3 = [min.x, 0, max.z - (max.z - min.z) / 2, min.x - 1.3, 0, max.z - (max.z - min.z) / 2];
1353
- vLineGeom3.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices3), 3));
1354
- // ///////////////////////////////////////
1355
-
1356
- // set names of transform object
1357
- var rotFillObj = new Three.Mesh(rotGeom.rotFill, new Three.MeshPhongMaterial({
1358
- color: 0x000000,
1359
- side: Three.DoubleSide,
1360
- colorWrite: true
1361
- }));
1362
- var rotStrokeObj = new Three.Line(rotGeom.rotStroke, new Three.LineBasicMaterial({
1363
- color: 0xffffff,
1364
- colorWrite: true
1365
- }));
1366
- rotFillObj.name = 'rotate';
1367
- var upObj = new Three.Mesh(upwardsGeom, new Three.MeshBasicMaterial({
1368
- color: 0xffffff,
1369
- side: Three.DoubleSide
1370
- }));
1371
- upObj.name = 'transUp';
1372
- var mBox = new Three.Mesh(moveBox, new Three.MeshBasicMaterial({
1373
- color: 0xdd6699,
1374
- side: Three.DoubleSide,
1375
- transparent: true,
1376
- opacity: 0.4
1377
- }));
1378
- var color = new Three.Color(ARROW_COLOR).convertLinearToSRGB();
1379
- var vLine = new Three.Line(vLineGeom, new Three.LineBasicMaterial({
1380
- color: color
1381
- }));
1382
- var vLine1 = new Three.Line(vLineGeom1, new Three.LineBasicMaterial({
1383
- color: color
1384
- }));
1385
- var vLine2 = new Three.Line(vLineGeom2, new Three.LineBasicMaterial({
1386
- color: color
1387
- }));
1388
- var vLine3 = new Three.Line(vLineGeom3, new Three.LineBasicMaterial({
1389
- color: color
1390
- }));
1391
- vLine.renderOrder = 1;
1392
- vLine1.renderOrder = 1;
1393
- vLine2.renderOrder = 1;
1394
- vLine3.renderOrder = 1;
1395
- vLine.material.transparent = true;
1396
- vLine1.material.transparent = true;
1397
- vLine2.material.transparent = true;
1398
- vLine3.material.transparent = true;
1399
- vLine.material.depthTest = false;
1400
- vLine1.material.depthTest = false;
1401
- vLine2.material.depthTest = false;
1402
- vLine3.material.depthTest = false;
1403
- // translate vector to center of object
1404
- var uVec = new Three.Vector3(-posVec.x / scalevec.x, -posVec.y / scalevec.y, -posVec.z / scalevec.z);
1405
- vLine.translateY(1.6);
1406
- vLine1.translateY(1.6);
1407
- vLine2.translateY(1.6);
1408
- vLine3.translateY(1.6);
1409
-
1410
- //rotObj.translateOnAxis(uVec, 1);
1411
- upObj.translateOnAxis(uVec, 1);
1412
- upObj.translateY(max.y - min.y);
1413
- mBox.name = 'TransformBox';
1414
- mBox.translateOnAxis(new Three.Vector3(uVec.x, uVec.y + (max.y - min.y) / 2, uVec.z), 1);
1415
- mBox.scale.set(1.01, 1.01, 1.01);
1416
-
1417
- // other side rotate object
1418
- var rotFillObj1 = rotFillObj.clone();
1419
- var rotStrokeObj1 = rotStrokeObj.clone();
1420
- rotFillObj1.rotateY(Math.PI);
1421
- rotStrokeObj1.rotateY(Math.PI);
1422
- rotFillObj.translateY(1.6);
1423
- rotFillObj1.translateY(1.6);
1424
- rotStrokeObj.translateY(1.6);
1425
- rotStrokeObj1.translateY(1.6);
1426
-
1427
- // assets Objects group includes rotate objects...
1428
- var asrtObj = new Three.Group();
1429
- // asrtObj.add(rotFillObj);
1430
- // asrtObj.add(rotFillObj1);
1431
- // asrtObj.add(rotStrokeObj);
1432
- // asrtObj.add(rotStrokeObj1);
1433
- //asrtObj.add(upObj);
1434
- asrtObj.add(vLine);
1435
- asrtObj.add(vLine1);
1436
- asrtObj.add(vLine2);
1437
- asrtObj.add(vLine3);
1438
- mBox.visible = false;
1439
- asrtObj.add(mBox);
1440
- asrtObj.scale.set(1, 1, 1);
1441
- //asrtObj.translateY(newAltitude / scalevec.y);
1442
- asrtObj.name = 'TransformGizmo';
1443
- // add assets Objects Group
1444
- object.add(asrtObj);
1445
-
1446
- // recover objects transform
1447
- object.position.x = posVec.x;
1448
- object.position.y = posVec.y;
1449
- object.position.z = posVec.z;
1450
- object.scale.set(scalevec.x, scalevec.y, scalevec.z);
1451
- setTimeout(function () {
1452
- SceneCreator.getDistances(layer);
1453
- }, 100);
1454
- }
1455
- return object;
1456
- };
1457
-
1458
- // keys in structure
1459
- var keys = Object.keys(structure);
1460
-
1461
- // if exist in cached Objects
1462
- if (element.type in cachedObject) {
1463
- var _objGroup3 = cachedObject[element.type].clone();
1464
- return Promise.resolve(onLoadItem(_objGroup3.clone()));
1465
- }
1466
-
1467
- // base Object/////
1468
- var objGroup = null;
1469
- var _loadGLTFs3 = function loadGLTFs(i) {
1470
- if (i === keys.length) {
1471
- // if end of keys
1472
- cachedObject[element.type] = objGroup.clone(); //register to cachedObject
1473
- return onLoadItem(cachedObject[element.type].clone());
1474
- }
1475
- if (keys[i] === 'base') {
1476
- // if base Objects
1477
- i++;
1478
- return _loadGLTFs3(i);
1479
- }
1480
- };
1481
-
1482
- // load base to start //
1483
- // return loadGLTF(dirName + structure["base"])
1484
- return loadGLTF(structure['base']).then(function (object) {
1485
- // let textureURL = `${API_SERVER_URL}/uploads/assets/default/steel.jpg`;
1486
- // let texture = loadTexture(textureURL);
1487
- // texture.wrapS = Three.MirroredRepeatWrapping;
1488
- // texture.wrapT = Three.MirroredRepeatWrapping;
1489
-
1490
- object.name = 'MainObject';
1491
- var mat2 = new Three.MeshStandardMaterial({
1492
- emissive: new Three.Color(0x666666).convertLinearToSRGB(),
1493
- metalness: 0.7,
1494
- roughness: 0.3
1495
- });
1496
- // mat2.envMap = textureCube;
1497
- object.material = mat2;
1498
- for (var j = 0; j < object.children.length; j++) {
1499
- if (object.children[j].type === OBJTYPE_MESH) {
1500
- object.children[j].material = mat2;
1501
- object.children[j].receiveShadow = true;
1502
- }
1503
- }
1504
- objGroup = object;
1505
- }, function (reason) {
1506
- console.log('loadGLTF failed for reason:', reason);
1507
- objGroup = GeomUtils.emptyBoxHolder(newWidth, newHeight, newDepth);
1508
- }).then(function () {
1509
- return _loadGLTFs3(0);
1510
- });
1511
- }
1512
- export function addEdgesToMesh(inChild) {
1513
- var boxEdge = new Three.EdgesGeometry(inChild.geometry, 10);
1514
- var boxEdgeMaterial = new Three.LineBasicMaterial({
1515
- color: 0x000000,
1516
- transparent: true,
1517
- opacity: 0.09
1518
- });
1519
- var boxEdgeLine = new Three.LineSegments(boxEdge, boxEdgeMaterial);
1520
- // inChild.add(boxEdgeLine);
1521
- }