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

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 (358) hide show
  1. package/es/@history.js +2 -0
  2. package/es/AppContext.js +3 -0
  3. package/es/KitchenConfigurator.js +645 -0
  4. package/es/KitchenConfiguratorApp.js +480 -0
  5. package/es/actions/area-actions.js +14 -0
  6. package/es/actions/export.js +23 -0
  7. package/es/actions/groups-actions.js +89 -0
  8. package/es/actions/holes-actions.js +119 -0
  9. package/es/actions/items-actions.js +313 -0
  10. package/es/actions/lines-actions.js +81 -0
  11. package/es/actions/project-actions.js +281 -0
  12. package/es/actions/scene-actions.js +33 -0
  13. package/es/actions/vertices-actions.js +27 -0
  14. package/es/actions/viewer2d-actions.js +58 -0
  15. package/es/actions/viewer3d-actions.js +23 -0
  16. package/es/catalog/areas/area/planner-element.js +40 -0
  17. package/es/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  18. package/es/catalog/areas/area/textures/grass.jpg +0 -0
  19. package/es/catalog/areas/area/textures/parquet.jpg +0 -0
  20. package/es/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  21. package/es/catalog/areas/area/textures/tile1.jpg +0 -0
  22. package/es/catalog/catalog.js +277 -0
  23. package/es/catalog/envMap/nx.hdr +0 -0
  24. package/es/catalog/envMap/ny.hdr +0 -0
  25. package/es/catalog/envMap/nz.hdr +0 -0
  26. package/es/catalog/envMap/px.hdr +0 -0
  27. package/es/catalog/envMap/py.hdr +0 -0
  28. package/es/catalog/envMap/pz.hdr +0 -0
  29. package/es/catalog/factories/area-factory-3d.js +181 -0
  30. package/es/catalog/factories/area-factory.js +81 -0
  31. package/es/catalog/factories/export.js +7 -0
  32. package/es/catalog/factories/wall-factory-3d.js +202 -0
  33. package/es/catalog/factories/wall-factory.js +268 -0
  34. package/es/catalog/holes/door-closet/planner-element.js +222 -0
  35. package/es/catalog/holes/door-double/door_double.png +0 -0
  36. package/es/catalog/holes/door-double/planner-element.js +315 -0
  37. package/es/catalog/holes/door-exterior/planner-element.js +215 -0
  38. package/es/catalog/holes/door-interior/planner-element.js +227 -0
  39. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  40. package/es/catalog/holes/door-panic/planner-element.js +503 -0
  41. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  42. package/es/catalog/holes/door-panic-double/planner-element.js +463 -0
  43. package/es/catalog/holes/door-sliding/planner-element.js +225 -0
  44. package/es/catalog/holes/doorway-framed/planner-element.js +145 -0
  45. package/es/catalog/holes/doorway-frameless/planner-element.js +104 -0
  46. package/es/catalog/holes/export.js +13 -0
  47. package/es/catalog/holes/gate/gate.jpg +0 -0
  48. package/es/catalog/holes/window-clear/planner-element.js +166 -0
  49. package/es/catalog/holes/window-clear/texture.png +0 -0
  50. package/es/catalog/holes/window-cross/planner-element.js +165 -0
  51. package/es/catalog/holes/window-cross/texture.png +0 -0
  52. package/es/catalog/holes/window-double-hung/planner-element.js +303 -0
  53. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  54. package/es/catalog/holes/window-vertical/planner-element.js +276 -0
  55. package/es/catalog/holes/window-vertical/texture.png +0 -0
  56. package/es/catalog/lines/wall/planner-element.js +70 -0
  57. package/es/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  58. package/es/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
  59. package/es/catalog/lines/wall/textures/bricks.jpg +0 -0
  60. package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
  61. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  62. package/es/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  63. package/es/catalog/lines/wall/textures/morden.jpg +0 -0
  64. package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
  65. package/es/catalog/lines/wall/textures/painted.jpg +0 -0
  66. package/es/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  67. package/es/catalog/lines/wall/textures/plaster.jpg +0 -0
  68. package/es/catalog/lines/wall/wall.png +0 -0
  69. package/es/catalog/molding/molding-dcm/planner-element.js +28 -0
  70. package/es/catalog/molding/molding-dcm/texture.png +0 -0
  71. package/es/catalog/molding/molding-fbm/planner-element.js +28 -0
  72. package/es/catalog/molding/molding-fbm/texture.png +0 -0
  73. package/es/catalog/molding/molding-lrm/planner-element.js +28 -0
  74. package/es/catalog/molding/molding-lrm/texture.png +0 -0
  75. package/es/catalog/properties/export.js +21 -0
  76. package/es/catalog/properties/property-checkbox.js +116 -0
  77. package/es/catalog/properties/property-color.js +39 -0
  78. package/es/catalog/properties/property-enum.js +97 -0
  79. package/es/catalog/properties/property-hidden.js +19 -0
  80. package/es/catalog/properties/property-lenght-measure.js +101 -0
  81. package/es/catalog/properties/property-length-measure.js +134 -0
  82. package/es/catalog/properties/property-length-measure_hole.js +101 -0
  83. package/es/catalog/properties/property-number.js +48 -0
  84. package/es/catalog/properties/property-read-only.js +26 -0
  85. package/es/catalog/properties/property-string.js +48 -0
  86. package/es/catalog/properties/property-toggle.js +39 -0
  87. package/es/catalog/properties/shared-property-style.js +14 -0
  88. package/es/catalog/utils/FuseUtils.js +82 -0
  89. package/es/catalog/utils/exporter.js +148 -0
  90. package/es/catalog/utils/geom-utils.js +189 -0
  91. package/es/catalog/utils/item-loader.js +1521 -0
  92. package/es/catalog/utils/load-obj.js +91 -0
  93. package/es/catalog/utils/mtl-loader.js +358 -0
  94. package/es/catalog/utils/obj-loader.js +477 -0
  95. package/es/class/FuseUtils.js +82 -0
  96. package/es/class/area.js +145 -0
  97. package/es/class/export.js +24 -0
  98. package/es/class/group.js +440 -0
  99. package/es/class/guide.js +62 -0
  100. package/es/class/hole.js +929 -0
  101. package/es/class/item.js +1883 -0
  102. package/es/class/layer.js +667 -0
  103. package/es/class/line.js +1180 -0
  104. package/es/class/project.js +793 -0
  105. package/es/class/vertex.js +202 -0
  106. package/es/components/content.js +107 -0
  107. package/es/components/disclaimer/disclaimer.js +97 -0
  108. package/es/components/export.js +9 -0
  109. package/es/components/style/button.js +113 -0
  110. package/es/components/style/cancel-button.js +22 -0
  111. package/es/components/style/content-container.js +33 -0
  112. package/es/components/style/content-title.js +29 -0
  113. package/es/components/style/delete-button.js +25 -0
  114. package/es/components/style/export.js +31 -0
  115. package/es/components/style/form-block.js +24 -0
  116. package/es/components/style/form-color-input.js +27 -0
  117. package/es/components/style/form-label.js +26 -0
  118. package/es/components/style/form-number-input.js +213 -0
  119. package/es/components/style/form-number-input_2.js +206 -0
  120. package/es/components/style/form-select.js +68 -0
  121. package/es/components/style/form-slider.js +61 -0
  122. package/es/components/style/form-submit-button.js +26 -0
  123. package/es/components/style/form-text-input.js +95 -0
  124. package/es/components/viewer2d/area.js +81 -0
  125. package/es/components/viewer2d/export.js +31 -0
  126. package/es/components/viewer2d/grids/grid-horizontal-streak.js +37 -0
  127. package/es/components/viewer2d/grids/grid-streak.js +37 -0
  128. package/es/components/viewer2d/grids/grid-vertical-streak.js +37 -0
  129. package/es/components/viewer2d/grids/grids.js +35 -0
  130. package/es/components/viewer2d/group.js +53 -0
  131. package/es/components/viewer2d/item.js +513 -0
  132. package/es/components/viewer2d/layer.js +164 -0
  133. package/es/components/viewer2d/line.js +882 -0
  134. package/es/components/viewer2d/ruler.js +100 -0
  135. package/es/components/viewer2d/rulerDist.js +146 -0
  136. package/es/components/viewer2d/rulerX.js +151 -0
  137. package/es/components/viewer2d/rulerY.js +153 -0
  138. package/es/components/viewer2d/scene.js +140 -0
  139. package/es/components/viewer2d/snap.js +74 -0
  140. package/es/components/viewer2d/state.js +78 -0
  141. package/es/components/viewer2d/utils.js +198 -0
  142. package/es/components/viewer2d/vertex.js +65 -0
  143. package/es/components/viewer2d/viewer2d.js +1398 -0
  144. package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +2592 -0
  145. package/es/components/viewer3d/dcm.js +401 -0
  146. package/es/components/viewer3d/fbm.js +414 -0
  147. package/es/components/viewer3d/front3D.js +66 -0
  148. package/es/components/viewer3d/grid-creator.js +25 -0
  149. package/es/components/viewer3d/grids/grid-horizontal-streak.js +36 -0
  150. package/es/components/viewer3d/grids/grid-streak.js +27 -0
  151. package/es/components/viewer3d/grids/grid-vertical-streak.js +36 -0
  152. package/es/components/viewer3d/libs/first-person-controls.js +67 -0
  153. package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +1281 -0
  154. package/es/components/viewer3d/libs/mtl-loader.js +357 -0
  155. package/es/components/viewer3d/libs/obj-loader.js +462 -0
  156. package/es/components/viewer3d/libs/orbit-controls.js +699 -0
  157. package/es/components/viewer3d/libs/pointer-lock-controls.js +46 -0
  158. package/es/components/viewer3d/lrm.js +305 -0
  159. package/es/components/viewer3d/model.js +708 -0
  160. package/es/components/viewer3d/pointer-lock-navigation.js +115 -0
  161. package/es/components/viewer3d/ruler-utils/itemRect.js +61 -0
  162. package/es/components/viewer3d/ruler-utils/layer3D.js +495 -0
  163. package/es/components/viewer3d/ruler-utils/ruler3D.js +227 -0
  164. package/es/components/viewer3d/ruler-utils/scene3D.js +60 -0
  165. package/es/components/viewer3d/ruler-utils/state3D.js +18 -0
  166. package/es/components/viewer3d/scene-creator.js +3608 -0
  167. package/es/components/viewer3d/three-memory-cleaner.js +51 -0
  168. package/es/components/viewer3d/viewer3d-first-person.js +315 -0
  169. package/es/components/viewer3d/viewer3d.js +2527 -0
  170. package/es/constants.js +636 -0
  171. package/es/index.js +16 -0
  172. package/es/models.js +510 -0
  173. package/es/plugins/SVGLoader.js +1412 -0
  174. package/es/plugins/autosave.js +33 -0
  175. package/es/plugins/console-debugger.js +37 -0
  176. package/es/plugins/export.js +9 -0
  177. package/es/plugins/keyboard.js +101 -0
  178. package/es/reducers/areas-reducer.js +12 -0
  179. package/es/reducers/export.js +25 -0
  180. package/es/reducers/groups-reducer.js +38 -0
  181. package/es/reducers/holes-reducer.js +62 -0
  182. package/es/reducers/items-reducer.js +140 -0
  183. package/es/reducers/lines-reducer.js +45 -0
  184. package/es/reducers/project-reducer.js +129 -0
  185. package/es/reducers/reducer.js +19 -0
  186. package/es/reducers/scene-reducer.js +28 -0
  187. package/es/reducers/user-reducer.js +40 -0
  188. package/es/reducers/vertices-reducer.js +19 -0
  189. package/es/reducers/viewer2d-reducer.js +75 -0
  190. package/es/reducers/viewer3d-reducer.js +56 -0
  191. package/es/shared-style.js +66 -0
  192. package/es/styles/export.js +5 -0
  193. package/es/styles/tabs.css +40 -0
  194. package/es/translator/en.js +104 -0
  195. package/es/translator/it.js +79 -0
  196. package/es/translator/ru.js +79 -0
  197. package/es/translator/translator.js +84 -0
  198. package/es/utils/browser.js +33 -0
  199. package/es/utils/email-validator.js +4 -0
  200. package/es/utils/export.js +25 -0
  201. package/es/utils/geometry.js +2420 -0
  202. package/es/utils/get-edges-of-subgraphs.js +27 -0
  203. package/es/utils/graph-cycles.js +237 -0
  204. package/es/utils/graph-inner-cycles.js +46 -0
  205. package/es/utils/graph.js +150 -0
  206. package/es/utils/helper.js +268 -0
  207. package/es/utils/history.js +29 -0
  208. package/es/utils/id-broker.js +19 -0
  209. package/es/utils/logger.js +8 -0
  210. package/es/utils/math.js +50 -0
  211. package/es/utils/molding.js +871 -0
  212. package/es/utils/name-generator.js +18 -0
  213. package/es/utils/objects-utils.js +50 -0
  214. package/es/utils/phone-validator.js +4 -0
  215. package/es/utils/process-black-list.js +18 -0
  216. package/es/utils/react-if.js +18 -0
  217. package/es/utils/snap-scene.js +99 -0
  218. package/es/utils/snap.js +237 -0
  219. package/es/utils/summarizeCart.js +24 -0
  220. package/es/utils/threeCSG.es6.js +498 -0
  221. package/es/version.js +2 -0
  222. package/lib/catalog/properties/property-string.js +55 -0
  223. package/lib/catalog/properties/property-toggle.js +46 -0
  224. package/lib/catalog/properties/shared-property-style.js +20 -0
  225. package/lib/catalog/utils/FuseUtils.js +88 -0
  226. package/lib/catalog/utils/exporter.js +155 -0
  227. package/lib/catalog/utils/geom-utils.js +205 -0
  228. package/lib/catalog/utils/item-loader.js +1533 -0
  229. package/lib/catalog/utils/load-obj.js +99 -0
  230. package/lib/catalog/utils/mtl-loader.js +363 -0
  231. package/lib/catalog/utils/obj-loader.js +482 -0
  232. package/lib/class/FuseUtils.js +88 -0
  233. package/lib/class/area.js +150 -0
  234. package/lib/class/export.js +96 -0
  235. package/lib/class/group.js +445 -0
  236. package/lib/class/guide.js +67 -0
  237. package/lib/class/hole.js +934 -0
  238. package/lib/class/item.js +1889 -0
  239. package/lib/class/layer.js +672 -0
  240. package/lib/class/line.js +1186 -0
  241. package/lib/class/project.js +799 -0
  242. package/lib/class/vertex.js +207 -0
  243. package/lib/components/content.js +116 -0
  244. package/lib/components/disclaimer/disclaimer.js +105 -0
  245. package/lib/components/export.js +33 -0
  246. package/lib/components/style/button.js +120 -0
  247. package/lib/components/style/cancel-button.js +29 -0
  248. package/lib/components/style/content-container.js +40 -0
  249. package/lib/components/style/content-title.js +37 -0
  250. package/lib/components/style/delete-button.js +34 -0
  251. package/lib/components/style/export.js +121 -0
  252. package/lib/components/style/form-block.js +31 -0
  253. package/lib/components/style/form-color-input.js +34 -0
  254. package/lib/components/style/form-label.js +33 -0
  255. package/lib/components/style/form-number-input.js +220 -0
  256. package/lib/components/style/form-number-input_2.js +213 -0
  257. package/lib/components/style/form-select.js +75 -0
  258. package/lib/components/style/form-slider.js +68 -0
  259. package/lib/components/style/form-submit-button.js +35 -0
  260. package/lib/components/style/form-text-input.js +101 -0
  261. package/lib/components/viewer2d/area.js +88 -0
  262. package/lib/components/viewer2d/export.js +121 -0
  263. package/lib/components/viewer2d/grids/grid-horizontal-streak.js +44 -0
  264. package/lib/components/viewer2d/grids/grid-streak.js +44 -0
  265. package/lib/components/viewer2d/grids/grid-vertical-streak.js +44 -0
  266. package/lib/components/viewer2d/grids/grids.js +44 -0
  267. package/lib/components/viewer2d/group.js +62 -0
  268. package/lib/components/viewer2d/item.js +521 -0
  269. package/lib/components/viewer2d/layer.js +171 -0
  270. package/lib/components/viewer2d/line.js +892 -0
  271. package/lib/components/viewer2d/ruler.js +107 -0
  272. package/lib/components/viewer2d/rulerDist.js +153 -0
  273. package/lib/components/viewer2d/rulerX.js +158 -0
  274. package/lib/components/viewer2d/rulerY.js +160 -0
  275. package/lib/components/viewer2d/scene.js +147 -0
  276. package/lib/components/viewer2d/snap.js +83 -0
  277. package/lib/components/viewer2d/state.js +87 -0
  278. package/lib/components/viewer2d/utils.js +210 -0
  279. package/lib/components/viewer2d/vertex.js +74 -0
  280. package/lib/components/viewer2d/viewer2d.js +1405 -0
  281. package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +2597 -0
  282. package/lib/components/viewer3d/dcm.js +407 -0
  283. package/lib/components/viewer3d/fbm.js +420 -0
  284. package/lib/components/viewer3d/front3D.js +75 -0
  285. package/lib/components/viewer3d/grid-creator.js +34 -0
  286. package/lib/components/viewer3d/grids/grid-horizontal-streak.js +44 -0
  287. package/lib/components/viewer3d/grids/grid-streak.js +35 -0
  288. package/lib/components/viewer3d/grids/grid-vertical-streak.js +44 -0
  289. package/lib/components/viewer3d/libs/first-person-controls.js +74 -0
  290. package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +1287 -0
  291. package/lib/components/viewer3d/libs/mtl-loader.js +363 -0
  292. package/lib/components/viewer3d/libs/obj-loader.js +468 -0
  293. package/lib/components/viewer3d/libs/orbit-controls.js +705 -0
  294. package/lib/components/viewer3d/libs/pointer-lock-controls.js +52 -0
  295. package/lib/components/viewer3d/lrm.js +311 -0
  296. package/lib/components/viewer3d/model.js +714 -0
  297. package/lib/components/viewer3d/pointer-lock-navigation.js +122 -0
  298. package/lib/components/viewer3d/ruler-utils/itemRect.js +68 -0
  299. package/lib/components/viewer3d/ruler-utils/layer3D.js +502 -0
  300. package/lib/components/viewer3d/ruler-utils/ruler3D.js +234 -0
  301. package/lib/components/viewer3d/ruler-utils/scene3D.js +68 -0
  302. package/lib/components/viewer3d/ruler-utils/state3D.js +25 -0
  303. package/lib/components/viewer3d/scene-creator.js +3642 -0
  304. package/lib/components/viewer3d/three-memory-cleaner.js +60 -0
  305. package/lib/components/viewer3d/viewer3d-first-person.js +320 -0
  306. package/lib/components/viewer3d/viewer3d.js +2532 -0
  307. package/lib/constants.js +645 -0
  308. package/lib/index.js +96 -0
  309. package/lib/models.js +517 -0
  310. package/lib/plugins/SVGLoader.js +1417 -0
  311. package/lib/plugins/autosave.js +39 -0
  312. package/lib/plugins/console-debugger.js +44 -0
  313. package/lib/plugins/export.js +33 -0
  314. package/lib/plugins/keyboard.js +107 -0
  315. package/lib/reducers/areas-reducer.js +18 -0
  316. package/lib/reducers/export.js +97 -0
  317. package/lib/reducers/groups-reducer.js +44 -0
  318. package/lib/reducers/holes-reducer.js +68 -0
  319. package/lib/reducers/items-reducer.js +146 -0
  320. package/lib/reducers/lines-reducer.js +51 -0
  321. package/lib/reducers/project-reducer.js +135 -0
  322. package/lib/reducers/reducer.js +26 -0
  323. package/lib/reducers/scene-reducer.js +34 -0
  324. package/lib/reducers/user-reducer.js +46 -0
  325. package/lib/reducers/vertices-reducer.js +25 -0
  326. package/lib/reducers/viewer2d-reducer.js +82 -0
  327. package/lib/reducers/viewer3d-reducer.js +63 -0
  328. package/lib/shared-style.js +72 -0
  329. package/lib/styles/export.js +13 -0
  330. package/lib/translator/en.js +110 -0
  331. package/lib/translator/it.js +85 -0
  332. package/lib/translator/ru.js +85 -0
  333. package/lib/translator/translator.js +90 -0
  334. package/lib/utils/browser.js +40 -0
  335. package/lib/utils/email-validator.js +10 -0
  336. package/lib/utils/export.js +56 -0
  337. package/lib/utils/geometry.js +2516 -0
  338. package/lib/utils/get-edges-of-subgraphs.js +34 -0
  339. package/lib/utils/graph-cycles.js +240 -0
  340. package/lib/utils/graph-inner-cycles.js +54 -0
  341. package/lib/utils/graph.js +157 -0
  342. package/lib/utils/helper.js +291 -0
  343. package/lib/utils/history.js +36 -0
  344. package/lib/utils/id-broker.js +25 -0
  345. package/lib/utils/logger.js +14 -0
  346. package/lib/utils/math.js +57 -0
  347. package/lib/utils/molding.js +895 -0
  348. package/lib/utils/name-generator.js +23 -0
  349. package/lib/utils/objects-utils.js +60 -0
  350. package/lib/utils/phone-validator.js +10 -0
  351. package/lib/utils/process-black-list.js +24 -0
  352. package/lib/utils/react-if.js +24 -0
  353. package/lib/utils/snap-scene.js +105 -0
  354. package/lib/utils/snap.js +249 -0
  355. package/lib/utils/summarizeCart.js +30 -0
  356. package/lib/utils/threeCSG.es6.js +503 -0
  357. package/lib/version.js +8 -0
  358. package/package.json +3 -3
@@ -0,0 +1,1521 @@
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
+ }