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