kitchen-simulator 11.0.0-react.18 → 11.0.0

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 (707) hide show
  1. package/es/AppContext.js +1 -4
  2. package/es/LiteKitchenConfigurator.js +67 -23
  3. package/es/LiteRenderer.js +15 -64
  4. package/es/actions/export.js +25 -12
  5. package/es/actions/items-actions.js +18 -2
  6. package/es/analytics/ga4.js +188 -0
  7. package/es/analytics/posthog.js +60 -0
  8. package/es/assets/Window.hdr +2100 -0
  9. package/es/assets/img/default/maple.jpg +0 -0
  10. package/es/assets/img/default/steel.jpg +0 -0
  11. package/es/assets/img/loading/loading.gif +0 -0
  12. package/es/catalog/cabinet/cabinet-assembly-order.js +36 -0
  13. package/es/catalog/catalog.js +0 -2
  14. package/es/catalog/factories/area-factory-3d.js +1 -5
  15. package/es/catalog/factories/wall-factory.js +1 -1
  16. package/es/catalog/holes/door-double/door_double.png +0 -0
  17. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  18. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  19. package/es/catalog/holes/gate/gate.jpg +0 -0
  20. package/es/catalog/holes/window-clear/texture.png +0 -0
  21. package/es/catalog/holes/window-cross/texture.png +0 -0
  22. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  23. package/es/catalog/holes/window-vertical/texture.png +0 -0
  24. package/es/catalog/utils/exporter.js +4 -0
  25. package/es/catalog/utils/item-loader.js +12 -25
  26. package/es/class/area.js +0 -1
  27. package/es/class/export.js +1 -3
  28. package/es/class/item.js +207 -89
  29. package/es/class/line.js +1 -3
  30. package/es/class/project.js +15 -19
  31. package/es/components/content.js +20 -6
  32. package/es/components/export.js +3 -5
  33. package/es/components/style/export.js +2 -28
  34. package/es/components/style/form-number-input.js +34 -43
  35. package/es/components/viewer2d/group.js +12 -7
  36. package/es/components/viewer2d/item.js +159 -168
  37. package/es/components/viewer2d/line.js +18 -51
  38. package/es/components/viewer2d/rulerX.js +3 -0
  39. package/es/components/viewer2d/rulerY.js +3 -0
  40. package/es/components/viewer2d/scene.js +67 -47
  41. package/es/components/viewer2d/state.js +1 -1
  42. package/es/components/viewer2d/utils.js +0 -6
  43. package/es/components/viewer2d/viewer2d.js +566 -508
  44. package/es/components/viewer3d/front3D.js +1 -2
  45. package/es/components/viewer3d/pointer-lock-navigation.js +0 -90
  46. package/es/components/viewer3d/ruler-utils/layer3D.js +2 -2
  47. package/es/components/viewer3d/scene-creator.js +113 -120
  48. package/es/components/viewer3d/three-memory-cleaner.js +0 -14
  49. package/es/components/viewer3d/viewer3d-first-person.js +132 -134
  50. package/es/components/viewer3d/viewer3d.js +40 -28
  51. package/es/constants/catalog/skinPanel.js +9 -0
  52. package/es/constants.js +19 -8
  53. package/es/{WorkSpaceOriginal.js → devLiteRenderer.js} +241 -173
  54. package/es/events/external/handleExternalEvent.js +141 -0
  55. package/es/events/external/handleExternalEvent.util.js +1099 -0
  56. package/es/events/external/handlers.addItem.js +47 -0
  57. package/es/events/external/handlers.changeDoorStyle.js +140 -0
  58. package/es/events/external/handlers.elementOps.js +8 -0
  59. package/es/events/external/handlers.finishing.js +26 -0
  60. package/es/events/external/handlers.hole.js +4 -0
  61. package/es/events/external/handlers.loadProject.js +128 -0
  62. package/es/events/external/handlers.molding.js +24 -0
  63. package/es/events/external/handlers.projectLifecycle.js +11 -0
  64. package/es/events/external/handlers.projectSettings.js +32 -0
  65. package/es/events/external/handlers.replaceCabinet.js +41 -0
  66. package/es/events/external/handlers.roomShape.js +8 -0
  67. package/es/events/external/handlers.syncScene.js +21 -0
  68. package/es/events/external/handlers.updateSelectedElements.js +11 -0
  69. package/es/events/external/handlers.viewMode.js +11 -0
  70. package/es/events/external/handlers.viewerNavigation.js +108 -0
  71. package/es/events/external/handlers.wall.js +7 -0
  72. package/es/index.js +36 -76
  73. package/es/mappings/external-events/mapExternalEventPayload.js +28 -0
  74. package/es/mappings/external-events/mappers/addItemMapper.js +97 -0
  75. package/es/mappings/external-events/mappers/ccdfMapper.js +100 -0
  76. package/es/mappings/external-events/mappers/ccdfToCDSMapper.js +49 -0
  77. package/es/mappings/external-events/mappers/changeDoorStyleMapper.js +37 -0
  78. package/es/mappings/external-events/mappers/loadProjectMapper.js +62 -0
  79. package/es/mappings/holesToCatalog.js +139 -0
  80. package/es/models.js +16 -1
  81. package/es/plugins/keyboard.js +1 -1
  82. package/es/reducers/export.js +2 -4
  83. package/es/reducers/items-reducer.js +4 -2
  84. package/es/reducers/project-reducer.js +1 -1
  85. package/es/reducers/reducer.js +2 -3
  86. package/es/reducers/viewer2d-reducer.js +0 -2
  87. package/es/shared/domain/cabinet-warning.js +15 -0
  88. package/es/shared/objects/immutable.js +3 -0
  89. package/es/utils/geometry.js +418 -95
  90. package/es/utils/helper.js +41 -35
  91. package/es/utils/history.js +2 -2
  92. package/es/utils/molding.js +12 -241
  93. package/es/utils/name-generator.js +0 -3
  94. package/es/utils/skinPanelEngine.js +522 -0
  95. package/lib/@history.js +11 -0
  96. package/lib/AppContext.js +11 -0
  97. package/lib/LiteKitchenConfigurator.js +527 -0
  98. package/lib/LiteRenderer.js +323 -0
  99. package/lib/actions/area-actions.js +21 -0
  100. package/lib/actions/export.js +36 -0
  101. package/lib/actions/groups-actions.js +107 -0
  102. package/lib/actions/holes-actions.js +140 -0
  103. package/lib/actions/items-actions.js +383 -0
  104. package/lib/actions/lines-actions.js +98 -0
  105. package/lib/actions/project-actions.js +351 -0
  106. package/lib/actions/scene-actions.js +43 -0
  107. package/lib/actions/vertices-actions.js +35 -0
  108. package/lib/actions/viewer2d-actions.js +73 -0
  109. package/lib/actions/viewer3d-actions.js +32 -0
  110. package/lib/analytics/ga4.js +194 -0
  111. package/lib/analytics/posthog.js +68 -0
  112. package/lib/assets/Window.hdr +2100 -0
  113. package/lib/assets/brown_photostudio_02_1k.hdr +0 -0
  114. package/lib/assets/fonts/Rene Bieder Milliard Black Italic.woff +0 -0
  115. package/lib/assets/fonts/Rene Bieder Milliard Black.woff +0 -0
  116. package/lib/assets/fonts/Rene Bieder Milliard Bold Italic.woff +0 -0
  117. package/lib/assets/fonts/Rene Bieder Milliard Bold.woff +0 -0
  118. package/lib/assets/fonts/Rene Bieder Milliard Book Italic.woff +0 -0
  119. package/lib/assets/fonts/Rene Bieder Milliard Book.woff +0 -0
  120. package/lib/assets/fonts/Rene Bieder Milliard ExtraBold Italic.woff +0 -0
  121. package/lib/assets/fonts/Rene Bieder Milliard ExtraBold.woff +0 -0
  122. package/lib/assets/fonts/Rene Bieder Milliard ExtraLight Italic.woff +0 -0
  123. package/lib/assets/fonts/Rene Bieder Milliard ExtraLight.woff +0 -0
  124. package/lib/assets/fonts/Rene Bieder Milliard Hairline Italic.woff +0 -0
  125. package/lib/assets/fonts/Rene Bieder Milliard Hairline.woff +0 -0
  126. package/lib/assets/fonts/Rene Bieder Milliard Heavy Italic.woff +0 -0
  127. package/lib/assets/fonts/Rene Bieder Milliard Heavy.woff +0 -0
  128. package/lib/assets/fonts/Rene Bieder Milliard Light Italic.woff +0 -0
  129. package/lib/assets/fonts/Rene Bieder Milliard Light.woff +0 -0
  130. package/lib/assets/fonts/Rene Bieder Milliard Medium Italic.woff +0 -0
  131. package/lib/assets/fonts/Rene Bieder Milliard Medium.woff +0 -0
  132. package/lib/assets/fonts/Rene Bieder Milliard SemiBold Italic.woff +0 -0
  133. package/lib/assets/fonts/Rene Bieder Milliard SemiBold.woff +0 -0
  134. package/lib/assets/fonts/Rene Bieder Milliard Thin Italic.woff +0 -0
  135. package/lib/assets/fonts/Rene Bieder Milliard Thin.woff +0 -0
  136. package/lib/assets/fonts/style.css +177 -0
  137. package/lib/assets/gltf/door_closet.gltf +1 -0
  138. package/lib/assets/gltf/door_exterior.gltf +1 -0
  139. package/lib/assets/gltf/door_interior.gltf +1 -0
  140. package/lib/assets/gltf/door_sliding.gltf +1 -0
  141. package/lib/assets/gltf/doorway_framed.bin +0 -0
  142. package/lib/assets/gltf/doorway_framed.fbx +0 -0
  143. package/lib/assets/gltf/doorway_framed.gltf +1 -0
  144. package/lib/assets/gltf/window_clear.bin +0 -0
  145. package/lib/assets/gltf/window_clear.fbx +0 -0
  146. package/lib/assets/gltf/window_clear.gltf +1 -0
  147. package/lib/assets/gltf/window_cross.bin +0 -0
  148. package/lib/assets/gltf/window_cross.fbx +0 -0
  149. package/lib/assets/gltf/window_cross.gltf +1 -0
  150. package/lib/assets/gltf/window_double_hung.bin +0 -0
  151. package/lib/assets/gltf/window_double_hung.fbx +0 -0
  152. package/lib/assets/gltf/window_double_hung.gltf +1 -0
  153. package/lib/assets/gltf/window_vertical.bin +0 -0
  154. package/lib/assets/gltf/window_vertical.fbx +0 -0
  155. package/lib/assets/gltf/window_vertical.gltf +1 -0
  156. package/lib/assets/img/TKC_thumbnail.png +0 -0
  157. package/lib/assets/img/Toggle.png +0 -0
  158. package/lib/assets/img/default/maple.jpg +0 -0
  159. package/lib/assets/img/default/steel.jpg +0 -0
  160. package/lib/assets/img/loading/loading.gif +0 -0
  161. package/lib/assets/img/loading/loading_1.svg +11 -0
  162. package/lib/assets/img/loading_large.gif +0 -0
  163. package/lib/assets/img/png/door/closet.png +0 -0
  164. package/lib/assets/img/png/door/doorwaysframed.png +0 -0
  165. package/lib/assets/img/png/door/doorwaysframeles.png +0 -0
  166. package/lib/assets/img/png/door/doorwaysframeless.png +0 -0
  167. package/lib/assets/img/png/door/exterior.png +0 -0
  168. package/lib/assets/img/png/door/interior.png +0 -0
  169. package/lib/assets/img/png/door/sliding.png +0 -0
  170. package/lib/assets/img/png/helper/outcome.png +0 -0
  171. package/lib/assets/img/project_img.png +0 -0
  172. package/lib/assets/img/rta/rta_logo_box_blue.jpg +0 -0
  173. package/lib/assets/img/rta/rta_logo_box_blue_ico.jpg +0 -0
  174. package/lib/assets/img/rta/rta_logo_box_blue_ico.svg +55 -0
  175. package/lib/assets/img/rta/rta_logo_box_darkGray.jpg +0 -0
  176. package/lib/assets/img/rta/rta_logo_box_lightblue.png +0 -0
  177. package/lib/assets/img/rta/rta_logo_box_lightmaroon.png +0 -0
  178. package/lib/assets/img/rta/rta_logo_box_maroon.png +0 -0
  179. package/lib/assets/img/rta/rta_logo_box_white.png +0 -0
  180. package/lib/assets/img/rta_menu.png +0 -0
  181. package/lib/assets/img/step2.jpg +0 -0
  182. package/lib/assets/img/step3.jpg +0 -0
  183. package/lib/assets/img/step4.jpg +0 -0
  184. package/lib/assets/img/step5.jpg +0 -0
  185. package/lib/assets/img/step6.jpg +0 -0
  186. package/lib/assets/img/step7.jpg +0 -0
  187. package/lib/assets/img/step8.jpg +0 -0
  188. package/lib/assets/img/svg/2d_delete_object.svg +33 -0
  189. package/lib/assets/img/svg/2d_delete_object1.svg +33 -0
  190. package/lib/assets/img/svg/2d_lock_object.svg +33 -0
  191. package/lib/assets/img/svg/3d_item_move.svg +106 -0
  192. package/lib/assets/img/svg/3d_item_rotation.svg +76 -0
  193. package/lib/assets/img/svg/3d_item_warning_edit.svg +77 -0
  194. package/lib/assets/img/svg/3d_item_warning_info.svg +81 -0
  195. package/lib/assets/img/svg/accessories.svg +4 -0
  196. package/lib/assets/img/svg/angle_icon.svg +39 -0
  197. package/lib/assets/img/svg/blank_div.svg +14 -0
  198. package/lib/assets/img/svg/bottombar/2d3d_button.svg +3 -0
  199. package/lib/assets/img/svg/bottombar/2d3d_button_active.svg +3 -0
  200. package/lib/assets/img/svg/bottombar/2d3d_toggle.svg +4 -0
  201. package/lib/assets/img/svg/bottombar/2d3d_toggle_active.svg +4 -0
  202. package/lib/assets/img/svg/bottombar/arrow-down.svg +3 -0
  203. package/lib/assets/img/svg/bottombar/arrow-left.svg +3 -0
  204. package/lib/assets/img/svg/bottombar/arrow-minus.svg +3 -0
  205. package/lib/assets/img/svg/bottombar/arrow-plus.svg +11 -0
  206. package/lib/assets/img/svg/bottombar/arrow-right.svg +3 -0
  207. package/lib/assets/img/svg/bottombar/arrow-up.svg +3 -0
  208. package/lib/assets/img/svg/bottombar/collapse.svg +3 -0
  209. package/lib/assets/img/svg/bottombar/elevation-back.svg +6 -0
  210. package/lib/assets/img/svg/bottombar/elevation-front.svg +6 -0
  211. package/lib/assets/img/svg/bottombar/elevation-left.svg +6 -0
  212. package/lib/assets/img/svg/bottombar/elevation-right.svg +7 -0
  213. package/lib/assets/img/svg/bottombar/elevation.svg +13 -0
  214. package/lib/assets/img/svg/bottombar/expand.svg +3 -0
  215. package/lib/assets/img/svg/bottombar/help.svg +72 -0
  216. package/lib/assets/img/svg/bottombar/incm_toggle.svg +39 -0
  217. package/lib/assets/img/svg/bottombar/pan_1.svg +57 -0
  218. package/lib/assets/img/svg/bottombar/pan_2.svg +27 -0
  219. package/lib/assets/img/svg/bottombar/pan_3.svg +27 -0
  220. package/lib/assets/img/svg/bottombar/pan_4.svg +27 -0
  221. package/lib/assets/img/svg/bottombar/pan_5.svg +27 -0
  222. package/lib/assets/img/svg/bottombar/settings.svg +23 -0
  223. package/lib/assets/img/svg/bottombar/spin-down.svg +76 -0
  224. package/lib/assets/img/svg/bottombar/spin-left.svg +75 -0
  225. package/lib/assets/img/svg/bottombar/spin-right.svg +75 -0
  226. package/lib/assets/img/svg/bottombar/spin-up.svg +76 -0
  227. package/lib/assets/img/svg/bottombar/spin_1.svg +48 -0
  228. package/lib/assets/img/svg/bottombar/spin_2.svg +31 -0
  229. package/lib/assets/img/svg/bottombar/spin_3.svg +31 -0
  230. package/lib/assets/img/svg/bottombar/spin_4.svg +31 -0
  231. package/lib/assets/img/svg/bottombar/spin_5.svg +31 -0
  232. package/lib/assets/img/svg/bottombar/zoomin.svg +29 -0
  233. package/lib/assets/img/svg/bottombar/zoomout.svg +26 -0
  234. package/lib/assets/img/svg/check.svg +10 -0
  235. package/lib/assets/img/svg/close.svg +11 -0
  236. package/lib/assets/img/svg/color/Black.svg +3 -0
  237. package/lib/assets/img/svg/color/Blue.svg +3 -0
  238. package/lib/assets/img/svg/color/Cream.svg +3 -0
  239. package/lib/assets/img/svg/color/Gray.svg +3 -0
  240. package/lib/assets/img/svg/color/Green.svg +3 -0
  241. package/lib/assets/img/svg/color/White.svg +3 -0
  242. package/lib/assets/img/svg/color/White.svg.bak +3 -0
  243. package/lib/assets/img/svg/color/stone2.jpg +0 -0
  244. package/lib/assets/img/svg/color/wood2.jpg +0 -0
  245. package/lib/assets/img/svg/copy.svg +11 -0
  246. package/lib/assets/img/svg/delete.svg +3 -0
  247. package/lib/assets/img/svg/detail.svg +77 -0
  248. package/lib/assets/img/svg/disclaimer/background.svg +758 -0
  249. package/lib/assets/img/svg/disclaimer/logo-dots.svg +11 -0
  250. package/lib/assets/img/svg/door/Closet.svg +11 -0
  251. package/lib/assets/img/svg/door/Exterior.svg +5 -0
  252. package/lib/assets/img/svg/door/Framed_dorway.svg +5 -0
  253. package/lib/assets/img/svg/door/Frameless_dorway.svg +5 -0
  254. package/lib/assets/img/svg/door/Interior.svg +7 -0
  255. package/lib/assets/img/svg/door/Sliding.svg +5 -0
  256. package/lib/assets/img/svg/doors_closet.svg +47 -0
  257. package/lib/assets/img/svg/doors_exterior.svg +25 -0
  258. package/lib/assets/img/svg/doors_interior.svg +29 -0
  259. package/lib/assets/img/svg/doors_patio.svg +26 -0
  260. package/lib/assets/img/svg/duplicate.svg +11 -0
  261. package/lib/assets/img/svg/duplicate_object_left.svg +32 -0
  262. package/lib/assets/img/svg/duplicate_object_right.svg +32 -0
  263. package/lib/assets/img/svg/filtersActive.svg +19 -0
  264. package/lib/assets/img/svg/firstsetting/L.svg +3 -0
  265. package/lib/assets/img/svg/firstsetting/L2.svg +3 -0
  266. package/lib/assets/img/svg/firstsetting/Open.svg +3 -0
  267. package/lib/assets/img/svg/firstsetting/Square.svg +3 -0
  268. package/lib/assets/img/svg/firstsetting/bar-active.svg +9 -0
  269. package/lib/assets/img/svg/firstsetting/bar-normal.svg +3 -0
  270. package/lib/assets/img/svg/firstsetting/bullet-current.svg +3 -0
  271. package/lib/assets/img/svg/firstsetting/bullet-done.svg +3 -0
  272. package/lib/assets/img/svg/firstsetting/bullet-not-done.svg +3 -0
  273. package/lib/assets/img/svg/firstsetting/check-active.svg +3 -0
  274. package/lib/assets/img/svg/firstsetting/check-normal.svg +3 -0
  275. package/lib/assets/img/svg/firstsetting/pencil.svg +11 -0
  276. package/lib/assets/img/svg/green_checkmark.svg +27 -0
  277. package/lib/assets/img/svg/headerbar/assist.svg +3 -0
  278. package/lib/assets/img/svg/headerbar/cart.svg +3 -0
  279. package/lib/assets/img/svg/headerbar/check.svg +10 -0
  280. package/lib/assets/img/svg/headerbar/consult_designer.svg +45 -0
  281. package/lib/assets/img/svg/headerbar/edit_name.svg +26 -0
  282. package/lib/assets/img/svg/headerbar/file-dollar.svg +13 -0
  283. package/lib/assets/img/svg/headerbar/hamburger_menu.svg +32 -0
  284. package/lib/assets/img/svg/headerbar/plus.svg +11 -0
  285. package/lib/assets/img/svg/headerbar/review_quote.svg +44 -0
  286. package/lib/assets/img/svg/headerbar/ruler-measure.svg +11 -0
  287. package/lib/assets/img/svg/headerbar/save.svg +3 -0
  288. package/lib/assets/img/svg/headerbar/setting.svg +75 -0
  289. package/lib/assets/img/svg/help/check.svg +10 -0
  290. package/lib/assets/img/svg/help/search.svg +76 -0
  291. package/lib/assets/img/svg/intro/1-start-with-floorplan-whole.svg +27 -0
  292. package/lib/assets/img/svg/intro/1-start-with-floorplan.svg +26 -0
  293. package/lib/assets/img/svg/intro/2-start-from-scratch-whole.svg +28 -0
  294. package/lib/assets/img/svg/intro/2-start-from-scratch.svg +27 -0
  295. package/lib/assets/img/svg/intro/3-retrieve-project-whole.svg +19 -0
  296. package/lib/assets/img/svg/intro/3-retrieve-project.svg +18 -0
  297. package/lib/assets/img/svg/invert.svg +127 -0
  298. package/lib/assets/img/svg/lefttoolbar/appliance-active.svg +13 -0
  299. package/lib/assets/img/svg/lefttoolbar/appliance.svg +13 -0
  300. package/lib/assets/img/svg/lefttoolbar/cabinet-active.svg +10 -0
  301. package/lib/assets/img/svg/lefttoolbar/cabinet-category.svg +3 -0
  302. package/lib/assets/img/svg/lefttoolbar/cabinet-one.svg +3 -0
  303. package/lib/assets/img/svg/lefttoolbar/cabinet.svg +10 -0
  304. package/lib/assets/img/svg/lefttoolbar/disigner_assistance.svg +89 -0
  305. package/lib/assets/img/svg/lefttoolbar/door-style-active.svg +20 -0
  306. package/lib/assets/img/svg/lefttoolbar/door-style.svg +20 -0
  307. package/lib/assets/img/svg/lefttoolbar/door.svg +12 -0
  308. package/lib/assets/img/svg/lefttoolbar/error_icon.svg +81 -0
  309. package/lib/assets/img/svg/lefttoolbar/finishing-active.svg +13 -0
  310. package/lib/assets/img/svg/lefttoolbar/finishing.svg +13 -0
  311. package/lib/assets/img/svg/lefttoolbar/reviewforquote-active.svg +86 -0
  312. package/lib/assets/img/svg/lefttoolbar/reviewforquote.svg +12 -0
  313. package/lib/assets/img/svg/lefttoolbar/room-shape-L.svg +3 -0
  314. package/lib/assets/img/svg/lefttoolbar/room-shape-active.svg +18 -0
  315. package/lib/assets/img/svg/lefttoolbar/room-shape-custom.svg +12 -0
  316. package/lib/assets/img/svg/lefttoolbar/room-shape-irregular.svg +3 -0
  317. package/lib/assets/img/svg/lefttoolbar/room-shape-open.svg +3 -0
  318. package/lib/assets/img/svg/lefttoolbar/room-shape-square.svg +3 -0
  319. package/lib/assets/img/svg/lefttoolbar/room-shape.svg +18 -0
  320. package/lib/assets/img/svg/lefttoolbar/search.svg +76 -0
  321. package/lib/assets/img/svg/lefttoolbar/view_more.svg +86 -0
  322. package/lib/assets/img/svg/lefttoolbar/warning_icon.svg +81 -0
  323. package/lib/assets/img/svg/lefttoolbar/window.svg +12 -0
  324. package/lib/assets/img/svg/logo.svg +11 -0
  325. package/lib/assets/img/svg/logo_with_text.svg +25 -0
  326. package/lib/assets/img/svg/menubar/login.svg +84 -0
  327. package/lib/assets/img/svg/menubar/my_projects.svg +85 -0
  328. package/lib/assets/img/svg/menubar/new_project.svg +110 -0
  329. package/lib/assets/img/svg/menubar/save_project.svg +84 -0
  330. package/lib/assets/img/svg/options.svg +3 -0
  331. package/lib/assets/img/svg/positioning.svg +3 -0
  332. package/lib/assets/img/svg/rotate.png +0 -0
  333. package/lib/assets/img/svg/rotate.svg +17 -0
  334. package/lib/assets/img/svg/rotate_object_clockwise.svg +26 -0
  335. package/lib/assets/img/svg/rotate_object_counterclockwise.svg +26 -0
  336. package/lib/assets/img/svg/toggleFilters.svg +19 -0
  337. package/lib/assets/img/svg/toolbar/add_appliances_active.svg +64 -0
  338. package/lib/assets/img/svg/toolbar/add_appliances_inactive.svg +52 -0
  339. package/lib/assets/img/svg/toolbar/add_button.svg +36 -0
  340. package/lib/assets/img/svg/toolbar/add_cabinets_active.svg +59 -0
  341. package/lib/assets/img/svg/toolbar/add_cabinets_inactive.svg +49 -0
  342. package/lib/assets/img/svg/toolbar/add_items_doors.svg +25 -0
  343. package/lib/assets/img/svg/toolbar/add_items_doorways.svg +24 -0
  344. package/lib/assets/img/svg/toolbar/add_items_refrigerator.svg +32 -0
  345. package/lib/assets/img/svg/toolbar/add_items_windows.svg +28 -0
  346. package/lib/assets/img/svg/toolbar/apply_button.svg +38 -0
  347. package/lib/assets/img/svg/toolbar/arrow-plus.svg +11 -0
  348. package/lib/assets/img/svg/toolbar/backsplash.svg +8 -0
  349. package/lib/assets/img/svg/toolbar/cancel_button.svg +37 -0
  350. package/lib/assets/img/svg/toolbar/consult_a_designer_button.svg +47 -0
  351. package/lib/assets/img/svg/toolbar/countertop.svg +7 -0
  352. package/lib/assets/img/svg/toolbar/dcm.png +0 -0
  353. package/lib/assets/img/svg/toolbar/dcm_off.svg +12 -0
  354. package/lib/assets/img/svg/toolbar/dcm_on.svg +474 -0
  355. package/lib/assets/img/svg/toolbar/delete_button.svg +37 -0
  356. package/lib/assets/img/svg/toolbar/download.svg +77 -0
  357. package/lib/assets/img/svg/toolbar/draw_custom_floor.svg +31 -0
  358. package/lib/assets/img/svg/toolbar/edit_button.svg +75 -0
  359. package/lib/assets/img/svg/toolbar/email_quote_button.svg +44 -0
  360. package/lib/assets/img/svg/toolbar/fbm.png +0 -0
  361. package/lib/assets/img/svg/toolbar/finishing_touches_active.svg +54 -0
  362. package/lib/assets/img/svg/toolbar/finishing_touches_inactive.svg +42 -0
  363. package/lib/assets/img/svg/toolbar/floorstyle.svg +9 -0
  364. package/lib/assets/img/svg/toolbar/fmb.png +0 -0
  365. package/lib/assets/img/svg/toolbar/fmb_off.svg +12 -0
  366. package/lib/assets/img/svg/toolbar/fmb_on.svg +489 -0
  367. package/lib/assets/img/svg/toolbar/furnishings_icon.svg +6 -0
  368. package/lib/assets/img/svg/toolbar/get_started_button.svg +41 -0
  369. package/lib/assets/img/svg/toolbar/handles.svg +5 -0
  370. package/lib/assets/img/svg/toolbar/lighting.svg +7 -0
  371. package/lib/assets/img/svg/toolbar/lrm.png +0 -0
  372. package/lib/assets/img/svg/toolbar/lrm_off.svg +12 -0
  373. package/lib/assets/img/svg/toolbar/lrm_on.svg +470 -0
  374. package/lib/assets/img/svg/toolbar/make_floorplan_active.svg +66 -0
  375. package/lib/assets/img/svg/toolbar/make_floorplan_inactive.svg +52 -0
  376. package/lib/assets/img/svg/toolbar/predefined_room_l_shaped.svg +20 -0
  377. package/lib/assets/img/svg/toolbar/predefined_room_layout.svg +20 -0
  378. package/lib/assets/img/svg/toolbar/predefined_room_long_narrow.svg +20 -0
  379. package/lib/assets/img/svg/toolbar/predefined_room_open_l_shape.svg +20 -0
  380. package/lib/assets/img/svg/toolbar/predefined_room_open_pentagon.svg +20 -0
  381. package/lib/assets/img/svg/toolbar/predefined_room_open_rectangle.svg +20 -0
  382. package/lib/assets/img/svg/toolbar/predefined_room_open_rectangle_2.svg +20 -0
  383. package/lib/assets/img/svg/toolbar/predefined_room_pentagon.svg +20 -0
  384. package/lib/assets/img/svg/toolbar/predefined_room_rectangle.svg +20 -0
  385. package/lib/assets/img/svg/toolbar/predefined_room_rectangle_with_alcove.svg +20 -0
  386. package/lib/assets/img/svg/toolbar/redo_button.svg +75 -0
  387. package/lib/assets/img/svg/toolbar/redo_button1.svg +75 -0
  388. package/lib/assets/img/svg/toolbar/review_quote_active.svg +14 -0
  389. package/lib/assets/img/svg/toolbar/review_quote_inactive.svg +44 -0
  390. package/lib/assets/img/svg/toolbar/save_project_button.svg +44 -0
  391. package/lib/assets/img/svg/toolbar/select_doorstyle_active.svg +67 -0
  392. package/lib/assets/img/svg/toolbar/select_doorstyle_inactive.svg +57 -0
  393. package/lib/assets/img/svg/toolbar/shopping-cart.svg +13 -0
  394. package/lib/assets/img/svg/toolbar/style_change_button.svg +47 -0
  395. package/lib/assets/img/svg/toolbar/take_picture.svg +75 -0
  396. package/lib/assets/img/svg/toolbar/undo_button.svg +76 -0
  397. package/lib/assets/img/svg/toolbar/undo_button1.svg +76 -0
  398. package/lib/assets/img/svg/toolbar/use_button.svg +37 -0
  399. package/lib/assets/img/svg/toolbar/wall_color_icon.svg +6 -0
  400. package/lib/assets/img/svg/topbar/edit_active.svg +10 -0
  401. package/lib/assets/img/svg/topbar/edit_inactive.svg +10 -0
  402. package/lib/assets/img/svg/topbar/redo_active.svg +42 -0
  403. package/lib/assets/img/svg/topbar/redo_inactive.svg +23 -0
  404. package/lib/assets/img/svg/topbar/select_all_active.svg +50 -0
  405. package/lib/assets/img/svg/topbar/select_all_inactive.svg +32 -0
  406. package/lib/assets/img/svg/topbar/take_picture_active.svg +51 -0
  407. package/lib/assets/img/svg/topbar/take_picture_inactive.svg +26 -0
  408. package/lib/assets/img/svg/topbar/undo_active.svg +42 -0
  409. package/lib/assets/img/svg/topbar/undo_inactive.svg +23 -0
  410. package/lib/assets/img/svg/warning_info_2d.svg +81 -0
  411. package/lib/assets/img/svg/window/Clear.svg +3 -0
  412. package/lib/assets/img/svg/window/Cross.svg +5 -0
  413. package/lib/assets/img/svg/window/Double_hung.svg +4 -0
  414. package/lib/assets/img/svg/window/Vertical.svg +4 -0
  415. package/lib/assets/img/svg/windows_clear.svg +23 -0
  416. package/lib/assets/img/svg/windows_cross.svg +28 -0
  417. package/lib/assets/img/svg/windows_double_hung.svg +24 -0
  418. package/lib/assets/img/svg/windows_vertical.svg +24 -0
  419. package/lib/assets/img/svg/wizardstep/Custom.svg +3 -0
  420. package/lib/assets/img/svg/wizardstep/Dashed_line.svg +3 -0
  421. package/lib/assets/img/svg/wizardstep/L.svg +3 -0
  422. package/lib/assets/img/svg/wizardstep/L2.svg +3 -0
  423. package/lib/assets/img/svg/wizardstep/Open.svg +3 -0
  424. package/lib/assets/img/svg/wizardstep/Square.svg +3 -0
  425. package/lib/assets/img/svg/wizardstep/bar-active.svg +9 -0
  426. package/lib/assets/img/svg/wizardstep/bar-normal.svg +3 -0
  427. package/lib/assets/img/svg/wizardstep/bullet-current.svg +3 -0
  428. package/lib/assets/img/svg/wizardstep/bullet-done.svg +3 -0
  429. package/lib/assets/img/svg/wizardstep/bullet-not-done.svg +3 -0
  430. package/lib/assets/img/svg/wizardstep/check-active.svg +3 -0
  431. package/lib/assets/img/svg/wizardstep/check-normal.svg +3 -0
  432. package/lib/assets/img/svg/wizardstep/detail_view.svg +87 -0
  433. package/lib/assets/img/svg/wizardstep/pencil.svg +11 -0
  434. package/lib/assets/img/svg/wizardstep/tile_view.svg +95 -0
  435. package/lib/assets/img/texture/glass.jpg +0 -0
  436. package/lib/assets/img/texture/steel.jpg +0 -0
  437. package/lib/assets/img/texture/white1px.jpg +0 -0
  438. package/lib/assets/img/texture/wood.jpg +0 -0
  439. package/lib/assets/model/DCM.bin +0 -0
  440. package/lib/assets/model/DCM.fbx +0 -0
  441. package/lib/assets/model/DCM.gltf +1 -0
  442. package/lib/assets/model/FBM.bin +0 -0
  443. package/lib/assets/model/FBM.fbx +0 -0
  444. package/lib/assets/model/FBM.gltf +1 -0
  445. package/lib/assets/model/LRM.bin +0 -0
  446. package/lib/assets/model/LRM.fbx +0 -0
  447. package/lib/assets/model/LRM.gltf +1 -0
  448. package/lib/assets/rtastore_logo.png +0 -0
  449. package/lib/catalog/areas/area/planner-element.js +53 -0
  450. package/lib/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  451. package/lib/catalog/areas/area/textures/grass.jpg +0 -0
  452. package/lib/catalog/areas/area/textures/parquet.jpg +0 -0
  453. package/lib/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  454. package/lib/catalog/areas/area/textures/tile1.jpg +0 -0
  455. package/lib/catalog/back.png +0 -0
  456. package/lib/catalog/cabinet/cabinet-assembly-order.js +42 -0
  457. package/lib/catalog/catalog.js +270 -0
  458. package/lib/catalog/doors.png +0 -0
  459. package/lib/catalog/doorways.png +0 -0
  460. package/lib/catalog/envMap/nx.hdr +0 -0
  461. package/lib/catalog/envMap/ny.hdr +0 -0
  462. package/lib/catalog/envMap/nz.hdr +0 -0
  463. package/lib/catalog/envMap/px.hdr +0 -0
  464. package/lib/catalog/envMap/py.hdr +0 -0
  465. package/lib/catalog/envMap/pz.hdr +0 -0
  466. package/lib/catalog/export.js +1 -0
  467. package/lib/catalog/factories/area-factory-3d.js +187 -0
  468. package/lib/catalog/factories/area-factory.js +88 -0
  469. package/lib/catalog/factories/export.js +25 -0
  470. package/lib/catalog/factories/wall-factory-3d.js +212 -0
  471. package/lib/catalog/factories/wall-factory.js +279 -0
  472. package/lib/catalog/holes/door-closet/planner-element.js +232 -0
  473. package/lib/catalog/holes/door-double/door_double.png +0 -0
  474. package/lib/catalog/holes/door-double/planner-element.js +325 -0
  475. package/lib/catalog/holes/door-exterior/planner-element.js +225 -0
  476. package/lib/catalog/holes/door-interior/planner-element.js +237 -0
  477. package/lib/catalog/holes/door-panic/panicDoor.png +0 -0
  478. package/lib/catalog/holes/door-panic/planner-element.js +513 -0
  479. package/lib/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  480. package/lib/catalog/holes/door-panic-double/planner-element.js +473 -0
  481. package/lib/catalog/holes/door-sliding/planner-element.js +235 -0
  482. package/lib/catalog/holes/doorway-framed/planner-element.js +155 -0
  483. package/lib/catalog/holes/doorway-frameless/planner-element.js +114 -0
  484. package/lib/catalog/holes/export.js +97 -0
  485. package/lib/catalog/holes/gate/gate.jpg +0 -0
  486. package/lib/catalog/holes/window-clear/planner-element.js +176 -0
  487. package/lib/catalog/holes/window-clear/texture.png +0 -0
  488. package/lib/catalog/holes/window-cross/planner-element.js +175 -0
  489. package/lib/catalog/holes/window-cross/texture.png +0 -0
  490. package/lib/catalog/holes/window-double-hung/planner-element.js +313 -0
  491. package/lib/catalog/holes/window-double-hung/texture.png +0 -0
  492. package/lib/catalog/holes/window-vertical/planner-element.js +286 -0
  493. package/lib/catalog/holes/window-vertical/texture.png +0 -0
  494. package/lib/catalog/lines/wall/planner-element.js +87 -0
  495. package/lib/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  496. package/lib/catalog/lines/wall/textures/bricks.jpg +0 -0
  497. package/lib/catalog/lines/wall/textures/bricks2.jpg +0 -0
  498. package/lib/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  499. package/lib/catalog/lines/wall/textures/morden.jpg +0 -0
  500. package/lib/catalog/lines/wall/textures/painted.jpg +0 -0
  501. package/lib/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  502. package/lib/catalog/lines/wall/textures/plaster.jpg +0 -0
  503. package/lib/catalog/lines/wall/wall.png +0 -0
  504. package/lib/catalog/molding/molding-dcm/planner-element.js +33 -0
  505. package/lib/catalog/molding/molding-dcm/texture.png +0 -0
  506. package/lib/catalog/molding/molding-fbm/planner-element.js +33 -0
  507. package/lib/catalog/molding/molding-fbm/texture.png +0 -0
  508. package/lib/catalog/molding/molding-lrm/planner-element.js +33 -0
  509. package/lib/catalog/molding/molding-lrm/texture.png +0 -0
  510. package/lib/catalog/utils/exporter.js +173 -0
  511. package/lib/catalog/utils/geom-utils.js +205 -0
  512. package/lib/catalog/utils/item-loader.js +1603 -0
  513. package/lib/catalog/utils/load-obj.js +99 -0
  514. package/lib/catalog/utils/mtl-loader.js +366 -0
  515. package/lib/catalog/utils/obj-loader.js +486 -0
  516. package/lib/catalog/windows.png +0 -0
  517. package/lib/class/area.js +147 -0
  518. package/lib/class/export.js +88 -0
  519. package/lib/class/group.js +438 -0
  520. package/lib/class/guide.js +64 -0
  521. package/lib/class/hole.js +930 -0
  522. package/lib/class/item.js +2009 -0
  523. package/lib/class/layer.js +670 -0
  524. package/lib/class/line.js +1236 -0
  525. package/lib/class/project.js +949 -0
  526. package/lib/class/vertex.js +205 -0
  527. package/lib/components/content.js +160 -0
  528. package/lib/components/export.js +7 -0
  529. package/lib/components/style/export.js +17 -0
  530. package/lib/components/style/form-number-input.js +192 -0
  531. package/lib/components/style/form-submit-button.js +35 -0
  532. package/lib/components/viewer2d/area.js +89 -0
  533. package/lib/components/viewer2d/export.js +121 -0
  534. package/lib/components/viewer2d/grids/grid-horizontal-streak.js +44 -0
  535. package/lib/components/viewer2d/grids/grid-streak.js +44 -0
  536. package/lib/components/viewer2d/grids/grid-vertical-streak.js +44 -0
  537. package/lib/components/viewer2d/grids/grids.js +40 -0
  538. package/lib/components/viewer2d/group.js +63 -0
  539. package/lib/components/viewer2d/item.js +244 -0
  540. package/lib/components/viewer2d/layer.js +172 -0
  541. package/lib/components/viewer2d/line.js +975 -0
  542. package/lib/components/viewer2d/ruler.js +92 -0
  543. package/lib/components/viewer2d/rulerDist.js +110 -0
  544. package/lib/components/viewer2d/rulerX.js +154 -0
  545. package/lib/components/viewer2d/rulerY.js +156 -0
  546. package/lib/components/viewer2d/scene.js +137 -0
  547. package/lib/components/viewer2d/snap.js +84 -0
  548. package/lib/components/viewer2d/state.js +83 -0
  549. package/lib/components/viewer2d/utils.js +200 -0
  550. package/lib/components/viewer2d/vertex.js +76 -0
  551. package/lib/components/viewer2d/viewer2d.js +1472 -0
  552. package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +2591 -0
  553. package/lib/components/viewer3d/dcm.js +408 -0
  554. package/lib/components/viewer3d/fbm.js +421 -0
  555. package/lib/components/viewer3d/front3D.js +71 -0
  556. package/lib/components/viewer3d/grid-creator.js +35 -0
  557. package/lib/components/viewer3d/grids/grid-horizontal-streak.js +45 -0
  558. package/lib/components/viewer3d/grids/grid-streak.js +36 -0
  559. package/lib/components/viewer3d/grids/grid-vertical-streak.js +45 -0
  560. package/lib/components/viewer3d/libs/first-person-controls.js +74 -0
  561. package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +1287 -0
  562. package/lib/components/viewer3d/libs/mtl-loader.js +366 -0
  563. package/lib/components/viewer3d/libs/obj-loader.js +471 -0
  564. package/lib/components/viewer3d/libs/orbit-controls.js +706 -0
  565. package/lib/components/viewer3d/libs/pointer-lock-controls.js +53 -0
  566. package/lib/components/viewer3d/lrm.js +312 -0
  567. package/lib/components/viewer3d/model.js +714 -0
  568. package/lib/components/viewer3d/pointer-lock-navigation.js +32 -0
  569. package/lib/components/viewer3d/ruler-utils/itemRect.js +69 -0
  570. package/lib/components/viewer3d/ruler-utils/layer3D.js +503 -0
  571. package/lib/components/viewer3d/ruler-utils/ruler3D.js +232 -0
  572. package/lib/components/viewer3d/ruler-utils/scene3D.js +67 -0
  573. package/lib/components/viewer3d/ruler-utils/state3D.js +26 -0
  574. package/lib/components/viewer3d/scene-creator.js +3850 -0
  575. package/lib/components/viewer3d/three-memory-cleaner.js +46 -0
  576. package/lib/components/viewer3d/viewer3d-first-person.js +316 -0
  577. package/lib/components/viewer3d/viewer3d.js +2673 -0
  578. package/lib/constants/catalog/skinPanel.js +15 -0
  579. package/lib/constants.js +791 -0
  580. package/lib/devLiteRenderer.js +917 -0
  581. package/lib/events/external/handleExternalEvent.js +148 -0
  582. package/lib/events/external/handleExternalEvent.util.js +1110 -0
  583. package/lib/events/external/handlers.addItem.js +54 -0
  584. package/lib/events/external/handlers.changeDoorStyle.js +147 -0
  585. package/lib/events/external/handlers.elementOps.js +15 -0
  586. package/lib/events/external/handlers.finishing.js +32 -0
  587. package/lib/events/external/handlers.hole.js +10 -0
  588. package/lib/events/external/handlers.loadProject.js +135 -0
  589. package/lib/events/external/handlers.molding.js +31 -0
  590. package/lib/events/external/handlers.projectLifecycle.js +19 -0
  591. package/lib/events/external/handlers.projectSettings.js +38 -0
  592. package/lib/events/external/handlers.replaceCabinet.js +48 -0
  593. package/lib/events/external/handlers.roomShape.js +14 -0
  594. package/lib/events/external/handlers.syncScene.js +27 -0
  595. package/lib/events/external/handlers.updateSelectedElements.js +17 -0
  596. package/lib/events/external/handlers.viewMode.js +19 -0
  597. package/lib/events/external/handlers.viewerNavigation.js +117 -0
  598. package/lib/events/external/handlers.wall.js +13 -0
  599. package/lib/index.js +637 -0
  600. package/lib/mappings/external-events/mapExternalEventPayload.js +33 -0
  601. package/lib/mappings/external-events/mappers/addItemMapper.js +103 -0
  602. package/lib/mappings/external-events/mappers/ccdfMapper.js +107 -0
  603. package/lib/mappings/external-events/mappers/ccdfToCDSMapper.js +55 -0
  604. package/lib/mappings/external-events/mappers/changeDoorStyleMapper.js +44 -0
  605. package/lib/mappings/external-events/mappers/loadProjectMapper.js +70 -0
  606. package/lib/mappings/holesToCatalog.js +148 -0
  607. package/lib/models.js +534 -0
  608. package/lib/plugins/SVGLoader.js +1419 -0
  609. package/lib/plugins/console-debugger.js +42 -0
  610. package/lib/plugins/export.js +25 -0
  611. package/lib/plugins/keyboard.js +117 -0
  612. package/lib/reducers/areas-reducer.js +19 -0
  613. package/lib/reducers/export.js +89 -0
  614. package/lib/reducers/groups-reducer.js +45 -0
  615. package/lib/reducers/holes-reducer.js +69 -0
  616. package/lib/reducers/items-reducer.js +152 -0
  617. package/lib/reducers/lines-reducer.js +52 -0
  618. package/lib/reducers/project-reducer.js +143 -0
  619. package/lib/reducers/reducer.js +25 -0
  620. package/lib/reducers/scene-reducer.js +35 -0
  621. package/lib/reducers/vertices-reducer.js +26 -0
  622. package/lib/reducers/viewer2d-reducer.js +84 -0
  623. package/lib/reducers/viewer3d-reducer.js +65 -0
  624. package/lib/shared/domain/cabinet-warning.js +20 -0
  625. package/lib/shared/objects/immutable.js +9 -0
  626. package/lib/shared-style.js +72 -0
  627. package/lib/translator/en.js +111 -0
  628. package/lib/translator/it.js +86 -0
  629. package/lib/translator/ru.js +86 -0
  630. package/lib/translator/translator.js +87 -0
  631. package/lib/utils/browser.js +40 -0
  632. package/lib/utils/convert-units-lite.js +44 -0
  633. package/lib/utils/email-validator.js +10 -0
  634. package/lib/utils/export.js +56 -0
  635. package/lib/utils/geometry.js +3230 -0
  636. package/lib/utils/get-edges-of-subgraphs.js +33 -0
  637. package/lib/utils/graph-cycles.js +239 -0
  638. package/lib/utils/graph-inner-cycles.js +54 -0
  639. package/lib/utils/graph.js +153 -0
  640. package/lib/utils/helper.js +480 -0
  641. package/lib/utils/history.js +48 -0
  642. package/lib/utils/id-broker.js +22 -0
  643. package/lib/utils/logger.js +14 -0
  644. package/lib/utils/math.js +57 -0
  645. package/lib/utils/molding.js +1146 -0
  646. package/lib/utils/name-generator.js +21 -0
  647. package/lib/utils/objects-utils.js +62 -0
  648. package/lib/utils/phone-validator.js +10 -0
  649. package/lib/utils/process-black-list.js +22 -0
  650. package/lib/utils/react-if.js +25 -0
  651. package/lib/utils/ruler.js +63 -0
  652. package/lib/utils/skinPanelEngine.js +530 -0
  653. package/lib/utils/snap-scene.js +101 -0
  654. package/lib/utils/snap.js +245 -0
  655. package/lib/utils/summarizeCart.js +30 -0
  656. package/lib/utils/threeCSG.es6.js +504 -0
  657. package/lib/version.js +7 -0
  658. package/package.json +29 -24
  659. package/es/WorkSpace.js +0 -30
  660. package/es/WorkSpaceHostMimic.js +0 -132
  661. package/es/assets/gltf/door_closet.bin +0 -0
  662. package/es/assets/gltf/door_closet.fbx +0 -0
  663. package/es/assets/gltf/door_exterior.bin +0 -0
  664. package/es/assets/gltf/door_exterior.fbx +0 -0
  665. package/es/assets/gltf/door_interior.bin +0 -0
  666. package/es/assets/gltf/door_interior.fbx +0 -0
  667. package/es/assets/gltf/door_sliding.bin +0 -0
  668. package/es/assets/gltf/door_sliding.fbx +0 -0
  669. package/es/assets/img/png/helper/video_preview_3d.png +0 -0
  670. package/es/assets/img/png/helper/video_preview_start.png +0 -0
  671. package/es/assets/img/svg/color/Brown.svg +0 -9
  672. package/es/assets/img/svg/color/Dark.svg +0 -9
  673. package/es/assets/img/svg/color/Light.svg +0 -9
  674. package/es/assets/img/svg/color/Medium.svg +0 -9
  675. package/es/assets/img/svg/color/Unfinished.svg +0 -9
  676. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  677. package/es/catalog/properties/export.js +0 -21
  678. package/es/catalog/properties/property-checkbox.js +0 -68
  679. package/es/catalog/properties/property-color.js +0 -39
  680. package/es/catalog/properties/property-enum.js +0 -50
  681. package/es/catalog/properties/property-hidden.js +0 -19
  682. package/es/catalog/properties/property-lenght-measure.js +0 -96
  683. package/es/catalog/properties/property-length-measure.js +0 -80
  684. package/es/catalog/properties/property-length-measure_hole.js +0 -96
  685. package/es/catalog/properties/property-number.js +0 -48
  686. package/es/catalog/properties/property-read-only.js +0 -26
  687. package/es/catalog/properties/property-string.js +0 -48
  688. package/es/catalog/properties/property-toggle.js +0 -39
  689. package/es/catalog/properties/shared-property-style.js +0 -14
  690. package/es/catalog/utils/FuseUtils.js +0 -79
  691. package/es/class/FuseUtils.js +0 -79
  692. package/es/components/style/button.js +0 -106
  693. package/es/components/style/cancel-button.js +0 -21
  694. package/es/components/style/content-container.js +0 -30
  695. package/es/components/style/content-title.js +0 -25
  696. package/es/components/style/delete-button.js +0 -24
  697. package/es/components/style/form-block.js +0 -20
  698. package/es/components/style/form-color-input.js +0 -26
  699. package/es/components/style/form-label.js +0 -22
  700. package/es/components/style/form-number-input_2.js +0 -238
  701. package/es/components/style/form-select.js +0 -19
  702. package/es/components/style/form-slider.js +0 -60
  703. package/es/components/style/form-text-input.js +0 -69
  704. package/es/index.html.ejs +0 -264
  705. package/es/reducers/user-reducer.js +0 -41
  706. package/es/utils/isolate-event-handler.js +0 -1622
  707. /package/{es/catalog/lines/wall/textures/bricks-normal2.jpg → lib/catalog/lines/wall/textures/painted-normal.jpg} +0 -0
@@ -0,0 +1,2009 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
9
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
12
+ var _convertUnitsLite = require("../utils/convert-units-lite");
13
+ var _export = require("./export");
14
+ var _export2 = require("../utils/export");
15
+ var _immutable = require("immutable");
16
+ var _constants = require("../constants");
17
+ var _helper = require("../utils/helper");
18
+ var _util = require("util");
19
+ var _molding = require("../utils/molding");
20
+ var _utils = require("../components/viewer2d/utils");
21
+ var _history = require("../utils/history");
22
+ var _immutable2 = require("../shared/objects/immutable");
23
+ 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; }
24
+ 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) { (0, _defineProperty2["default"])(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; }
25
+ var allItemRect;
26
+ var allItemSnap;
27
+ var allLines;
28
+ var allLineRects;
29
+ var allLineSnap;
30
+ var allRect;
31
+ var time1;
32
+ var time2;
33
+ var Item = exports["default"] = /*#__PURE__*/function () {
34
+ function Item() {
35
+ (0, _classCallCheck2["default"])(this, Item);
36
+ }
37
+ return (0, _createClass2["default"])(Item, null, [{
38
+ key: "__getDesiredDoorFinishId",
39
+ value: function __getDesiredDoorFinishId(layer) {
40
+ var _layer$doorFinish, _js$id;
41
+ // Transitional naming: prefer future `doorFinish`, fall back to legacy `doorStyle`.
42
+ // IMPORTANT: use `doorStyle.id` as door_finish_id (ignore doorStyle.door_style_id).
43
+ var lf = (_layer$doorFinish = layer === null || layer === void 0 ? void 0 : layer.doorFinish) !== null && _layer$doorFinish !== void 0 ? _layer$doorFinish : layer === null || layer === void 0 ? void 0 : layer.doorStyle;
44
+ var js = (0, _immutable2.toJSIfNeeded)(lf);
45
+ return (_js$id = js === null || js === void 0 ? void 0 : js.id) !== null && _js$id !== void 0 ? _js$id : null;
46
+ }
47
+ }, {
48
+ key: "__pickCCDFForDoorFinish",
49
+ value: function __pickCCDFForDoorFinish(definitionCCDFList, desiredDoorFinishId, itemID) {
50
+ var _match$door_finish_id;
51
+ if (!Array.isArray(definitionCCDFList) || !desiredDoorFinishId) return null;
52
+ // Host ccdf_list entries may NOT include `door_finish_id` (only `cabinet_id`).
53
+ // When missing, we can still pick by cabinet_id and then *stamp* door_finish_id from scene context.
54
+ var match = definitionCCDFList.find(function (c) {
55
+ return itemID == null || (c === null || c === void 0 ? void 0 : c.cabinet_id) == null || (c === null || c === void 0 ? void 0 : c.cabinet_id) === itemID;
56
+ });
57
+ if (!match) return null;
58
+ return _objectSpread(_objectSpread({}, match), {}, {
59
+ door_finish_id: (_match$door_finish_id = match === null || match === void 0 ? void 0 : match.door_finish_id) !== null && _match$door_finish_id !== void 0 ? _match$door_finish_id : desiredDoorFinishId
60
+ });
61
+ }
62
+ }, {
63
+ key: "create",
64
+ value: function create(state, layerID, type, x, y, width, height, rotation, isDuplication) {
65
+ var _item;
66
+ var molding = arguments.length > 9 && arguments[9] !== undefined ? arguments[9] : [];
67
+ var isInitialPos = arguments.length > 10 && arguments[10] !== undefined ? arguments[10] : false;
68
+ var refItem = arguments.length > 11 && arguments[11] !== undefined ? arguments[11] : null;
69
+ var counterTopURI = arguments.length > 12 && arguments[12] !== undefined ? arguments[12] : null;
70
+ var itemID = _export2.IDBroker.acquireID();
71
+ var item = state.catalog.factoryElement(type, {
72
+ id: itemID,
73
+ itemID: state.catalog.getIn(['elements', type, 'itemID']),
74
+ name: _export2.NameGenerator.generateName('items', state.catalog.getIn(['elements', type, 'info', 'title'])),
75
+ long_name: state.catalog.getIn(['elements', type, 'long_name']),
76
+ sizeinfo: state.catalog.getIn(['elements', type, 'info', 'sizeinfo']),
77
+ description: state.catalog.getIn(['elements', type, 'info', 'description']),
78
+ base: state.catalog.getIn(['elements', type, 'info', 'image']),
79
+ shape_svg: state.catalog.getIn(['elements', type, 'info', 'shape_svg']),
80
+ gltf: state.catalog.getIn(['elements', type, 'gltf']),
81
+ is_corner: state.catalog.getIn(['elements', type, 'info', 'is_corner']),
82
+ obj_property: state.catalog.getIn(['elements', type, 'obj']),
83
+ sku_number: state.catalog.getIn(['elements', type, 'obj']).toJS().sku_number,
84
+ outline: state.catalog.getIn(['elements', type, 'info', 'outline']),
85
+ //style: state.catalog.getIn(['elements', type, 'info', 'door']),
86
+ category: state.catalog.getIn(['elements', type, 'type']),
87
+ layoutpos: state.catalog.getIn(['elements', type, 'info', 'layoutpos']),
88
+ cabinet_category: state.catalog.getIn(['elements', type, 'obj']).toJS().cabinet_category,
89
+ type: type,
90
+ height: height,
91
+ width: width,
92
+ x: x,
93
+ y: y,
94
+ rotation: rotation,
95
+ isDuplication: isDuplication,
96
+ isInitialPos: isInitialPos ? isInitialPos : false
97
+ }, null, state);
98
+ // Attach selected ccdf onto the placed instance so SYNC can return it.
99
+ // This does not affect legacy `structure_json/tempPlaceholders` behavior.
100
+ try {
101
+ var _state, _definitions$get$toJS, _definitions$get, _definitions$get$toJS2, _state2;
102
+ var layerForFinish = state.getIn(['scene', 'layers', layerID]);
103
+ var desiredDoorFinishId = this.__getDesiredDoorFinishId(layerForFinish);
104
+ var definitions = (_state = state) === null || _state === void 0 || (_state = _state.catalog) === null || _state === void 0 ? void 0 : _state.getIn(['elements', type]);
105
+ var definitionCCDFList = definitions !== null && definitions !== void 0 && definitions.get ? (_definitions$get$toJS = (_definitions$get = definitions.get('ccdf_list')) === null || _definitions$get === void 0 || (_definitions$get$toJS2 = _definitions$get.toJS) === null || _definitions$get$toJS2 === void 0 ? void 0 : _definitions$get$toJS2.call(_definitions$get)) !== null && _definitions$get$toJS !== void 0 ? _definitions$get$toJS : definitions.get('ccdf_list') : definitions === null || definitions === void 0 ? void 0 : definitions.ccdf_list;
106
+ var picked = this.__pickCCDFForDoorFinish(definitionCCDFList, desiredDoorFinishId, (_state2 = state) === null || _state2 === void 0 || (_state2 = _state2.catalog) === null || _state2 === void 0 ? void 0 : _state2.getIn(['elements', type, 'itemID']));
107
+ if (picked) item = item.merge({
108
+ ccdf: picked
109
+ });
110
+ } catch (e) {
111
+ // best-effort only; never block item creation
112
+ }
113
+ if (item.category === 'cabinet') {
114
+ if (isDuplication && refItem) {
115
+ var _refItem$ccdf, _refItem$get;
116
+ item = item.merge({
117
+ doorStyle: refItem.doorStyle
118
+ });
119
+ // When duplicating, preserve the instance-selected CCDF from the source cabinet.
120
+ var refCcdf = (_refItem$ccdf = refItem === null || refItem === void 0 ? void 0 : refItem.ccdf) !== null && _refItem$ccdf !== void 0 ? _refItem$ccdf : refItem === null || refItem === void 0 || (_refItem$get = refItem.get) === null || _refItem$get === void 0 ? void 0 : _refItem$get.call(refItem, 'ccdf');
121
+ refCcdf = (0, _immutable2.toJSIfNeeded)(refCcdf);
122
+ if (!(0, _utils.isEmpty)(refCcdf)) item = item.merge({
123
+ ccdf: refCcdf
124
+ });
125
+ } else {
126
+ var _layer$doorStyle, _temp, _ref, _temp$doorStyles$cds$, _temp2, _temp3, _state5;
127
+ var layer = state.getIn(['scene', 'layers', layerID]);
128
+ var temp = (_layer$doorStyle = layer === null || layer === void 0 ? void 0 : layer.doorStyle) !== null && _layer$doorStyle !== void 0 ? _layer$doorStyle : state.doorStyle;
129
+ if (!(0, _utils.isEmpty)(temp) && _immutable.Map.isMap(temp)) temp = (_temp = temp) === null || _temp === void 0 ? void 0 : _temp.toJS();
130
+ var cds = (_ref = (_temp$doorStyles$cds$ = (_temp2 = temp) === null || _temp2 === void 0 || (_temp2 = _temp2.doorStyles) === null || _temp2 === void 0 || (_temp2 = _temp2.cds) === null || _temp2 === void 0 ? void 0 : _temp2.find(function (elem) {
131
+ var _state3;
132
+ return elem.itemID === ((_state3 = state) === null || _state3 === void 0 || (_state3 = _state3.catalog) === null || _state3 === void 0 ? void 0 : _state3.getIn(['elements', type, 'itemID']));
133
+ })) !== null && _temp$doorStyles$cds$ !== void 0 ? _temp$doorStyles$cds$ : (_temp3 = temp) === null || _temp3 === void 0 || (_temp3 = _temp3.cds) === null || _temp3 === void 0 ? void 0 : _temp3.find(function (elem) {
134
+ var _state4;
135
+ return elem.itemID === ((_state4 = state) === null || _state4 === void 0 || (_state4 = _state4.catalog) === null || _state4 === void 0 ? void 0 : _state4.getIn(['elements', type, 'itemID']));
136
+ })) !== null && _ref !== void 0 ? _ref : (_state5 = state) === null || _state5 === void 0 || (_state5 = _state5.catalog) === null || _state5 === void 0 ? void 0 : _state5.getIn(['elements', type, 'cds']);
137
+ if (cds) {
138
+ var _temp4;
139
+ var updatedDoorStyles = _objectSpread(_objectSpread({}, (_temp4 = temp) === null || _temp4 === void 0 ? void 0 : _temp4.doorStyles), {}, {
140
+ cds: [cds],
141
+ cabinet_door_style_id: cds.cabinet_door_style_id
142
+ });
143
+ item = item.merge({
144
+ doorStyle: (0, _immutable.fromJS)(_objectSpread(_objectSpread({}, temp), {}, {
145
+ doorStyles: updatedDoorStyles
146
+ }))
147
+ });
148
+ }
149
+ }
150
+ }
151
+ if (item.get('type') === 'cabinet' && item.get('doorStyle').size === 0) {
152
+ return {
153
+ updatedState: state,
154
+ item: null
155
+ };
156
+ }
157
+ var setSizeOfItemByDoorStyle = function setSizeOfItemByDoorStyle() {
158
+ var doorStyle = item.get('doorStyle').toJS();
159
+ var euroCDS = state.catalog.getIn(['elements', type, 'cds']).data.filter(function (element) {
160
+ return element && element.is_euro_cds;
161
+ });
162
+ if (doorStyle.door_style_name === 'Euro & Frameless' && euroCDS.length > 0) {
163
+ var newProperties = item.get('properties').toJS();
164
+ if (newProperties.hasOwnProperty('depth')) {
165
+ if (!newProperties.hasOwnProperty('oldDepth')) {
166
+ newProperties['oldDepth'] = new _immutable.Map({
167
+ length: newProperties.depth.length,
168
+ _length: newProperties.depth._length,
169
+ _unit: newProperties.depth._unit
170
+ });
171
+ }
172
+ newProperties['depth'] = new _immutable.Map({
173
+ length: (0, _convertUnitsLite.convert)(euroCDS[0].euro_length).from('in').to('cm'),
174
+ _length: euroCDS[0].euro_length,
175
+ _unit: 'in'
176
+ });
177
+ }
178
+ if (newProperties.hasOwnProperty('height')) {
179
+ if (!newProperties.hasOwnProperty('oldHeight')) {
180
+ newProperties['oldHeight'] = new _immutable.Map({
181
+ length: newProperties.height.length,
182
+ _length: newProperties.height._length,
183
+ _unit: newProperties.height._unit
184
+ });
185
+ }
186
+ newProperties['height'] = new _immutable.Map({
187
+ length: (0, _convertUnitsLite.convert)(euroCDS[0].euro_height).from('in').to('cm'),
188
+ _length: euroCDS[0].euro_height,
189
+ _unit: 'in'
190
+ });
191
+ }
192
+ if (newProperties.hasOwnProperty('width')) {
193
+ if (!newProperties.hasOwnProperty('oldWidth')) {
194
+ newProperties['oldWidth'] = new _immutable.Map({
195
+ length: newProperties.width.length,
196
+ _length: newProperties.width._length,
197
+ _unit: newProperties.width._unit
198
+ });
199
+ }
200
+ newProperties['width'] = new _immutable.Map({
201
+ length: (0, _convertUnitsLite.convert)(euroCDS[0].euro_width).from('in').to('cm') - 10,
202
+ _length: euroCDS[0].euro_width,
203
+ _unit: 'in'
204
+ });
205
+ }
206
+ item = item.merge({
207
+ properties: (0, _immutable.fromJS)(newProperties)
208
+ });
209
+ } else {
210
+ var properties = item.get('properties').toJS();
211
+ if (properties.hasOwnProperty('oldDepth')) {
212
+ properties['depth'] = new _immutable.Map({
213
+ length: properties.oldDepth.length,
214
+ _length: properties.oldDepth._length,
215
+ _unit: properties.oldDepth._unit
216
+ });
217
+ }
218
+ if (properties.hasOwnProperty('oldHeight')) {
219
+ properties['height'] = new _immutable.Map({
220
+ length: properties.oldHeight.length,
221
+ _length: properties.oldHeight._length,
222
+ _unit: properties.oldHeight._unit
223
+ });
224
+ }
225
+ if (properties.hasOwnProperty('oldWidth')) {
226
+ properties['width'] = new _immutable.Map({
227
+ length: properties.oldWidth.length,
228
+ _length: properties.oldWidth._length,
229
+ _unit: properties.oldWidth._unit
230
+ });
231
+ }
232
+ item = item.merge({
233
+ properties: (0, _immutable.fromJS)(properties)
234
+ });
235
+ }
236
+ };
237
+ item.category === 'cabinet' && setSizeOfItemByDoorStyle();
238
+ if (!(0, _utils.isEmpty)(counterTopURI) && !(0, _utils.isEmpty)((_item = item) === null || _item === void 0 ? void 0 : _item.counterTop)) {
239
+ item.counterTop.uri = counterTopURI;
240
+ }
241
+ item = this.updateDoorHandle(item, state.getIn(['scene', 'layers', layerID]));
242
+ state = state.setIn(['scene', 'layers', layerID, 'items', itemID], item);
243
+ if (item.type.includes('Light')) {
244
+ var ceilHeight = state.getIn(['scene', 'layers', layerID, 'ceilHeight']);
245
+ var ceilUnit = state.getIn(['scene', 'layers', layerID, 'unit']);
246
+ ceilHeight = (0, _convertUnitsLite.convert)(ceilHeight).from(ceilUnit).to('cm');
247
+ var newAltitude = ceilHeight - item.properties.getIn(['height', 'length']);
248
+ newAltitude = (0, _convertUnitsLite.convert)(newAltitude).from('cm').to(ceilUnit);
249
+ item = item.setIn(['properties', 'altitude', '_length'], newAltitude);
250
+ state = state.setIn(['scene', 'layers', layerID, 'items', item.id], item);
251
+ }
252
+ if (item.category === 'cabinet') {
253
+ // If create a copied object, copied object has original object's molding property.And if create a object, it has a layer's molding property.
254
+ var layerMolding = state.getIn(['scene', 'layers', layerID, 'molding']).filter(function (md) {
255
+ return (0, _molding.hasMoldingLayout)(md, item.layoutpos);
256
+ });
257
+ state = state.setIn(['scene', 'layers', layerID, 'items', itemID, 'molding'], layerMolding.length ? layerMolding : molding);
258
+ }
259
+ return {
260
+ updatedState: state,
261
+ item: item
262
+ };
263
+ }
264
+ }, {
265
+ key: "setItemsCCDF",
266
+ value: function setItemsCCDF(state, ccdf_list, applyScope) {
267
+ var targetItemIDs = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];
268
+ var doorFinishId = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : null;
269
+ var layerID = state.getIn(['scene', 'selectedLayer']);
270
+ var layer = state.getIn(['scene', 'layers', layerID]);
271
+ if (!Array.isArray(ccdf_list)) return {
272
+ updatedState: state
273
+ };
274
+
275
+ // resolve which instance IDs to process
276
+ var idSet = null;
277
+ if (applyScope === _constants.DOORSTYLE_SCOPE_SINGLE) {
278
+ var selectedItemIds = state.getIn(['scene', 'layers', layerID, 'selected', 'items']).toJS();
279
+ idSet = new Set(selectedItemIds);
280
+ } else if (applyScope === _constants.DOORSTYLE_SCOPE_MULTIPLE) {
281
+ idSet = new Set(targetItemIDs);
282
+ }
283
+
284
+ // If host returns an empty ccdf_list, remove assets3d of persisted ccdf from affected instances.
285
+ // This keeps SYNC payload from sending stale `items[].ccdf`.
286
+ if (ccdf_list.length === 0) {
287
+ layer.items.forEach(function (it) {
288
+ var _idSet;
289
+ var should = applyScope === _constants.DOORSTYLE_SCOPE_ALL ? true : (_idSet = idSet) === null || _idSet === void 0 ? void 0 : _idSet.has(it.id);
290
+ if (!should) return;
291
+ state = state.deleteIn(['scene', 'layers', layerID, 'items', it.id, 'ccdf', 'assets3d']);
292
+ });
293
+ return {
294
+ updatedState: state
295
+ };
296
+ }
297
+ var desiredDoorFinishId = doorFinishId !== null && doorFinishId !== void 0 ? doorFinishId : this.__getDesiredDoorFinishId(layer);
298
+ if (!desiredDoorFinishId) return {
299
+ updatedState: state
300
+ };
301
+ layer.items.forEach(function (it) {
302
+ var _idSet2, _picked$door_finish_i;
303
+ var should = applyScope === _constants.DOORSTYLE_SCOPE_ALL ? true : (_idSet2 = idSet) === null || _idSet2 === void 0 ? void 0 : _idSet2.has(it.id);
304
+ if (!should) return;
305
+
306
+ // Join key: scene_cabinet_id (instance id).
307
+ var picked = ccdf_list.find(function (c) {
308
+ return (c === null || c === void 0 ? void 0 : c.scene_cabinet_id) && c.scene_cabinet_id === it.id;
309
+ });
310
+ if (!picked) return;
311
+ state = state.setIn(['scene', 'layers', layerID, 'items', it.id, 'ccdf'], _objectSpread(_objectSpread({}, picked), {}, {
312
+ door_finish_id: (_picked$door_finish_i = picked === null || picked === void 0 ? void 0 : picked.door_finish_id) !== null && _picked$door_finish_i !== void 0 ? _picked$door_finish_i : desiredDoorFinishId
313
+ }));
314
+ });
315
+ return {
316
+ updatedState: state
317
+ };
318
+ }
319
+ }, {
320
+ key: "updateDoorHandle",
321
+ value: function updateDoorHandle(item, layer) {
322
+ var doorHandle = layer.get('doorHandle');
323
+ if (doorHandle == '') return item;
324
+ var dataJSON = item.toJS();
325
+ var itemID = dataJSON.id;
326
+ var doorStyle = dataJSON.doorStyle;
327
+ var tmpDS = _objectSpread(_objectSpread({}, doorStyle), {}, {
328
+ handle_gltf: doorHandle,
329
+ metalness: 0.2,
330
+ roughness: 0.1
331
+ });
332
+ var cnt = 0;
333
+ for (var prop in doorStyle.doorStyles) cnt++;
334
+ if (cnt !== 0) {
335
+ for (var i = 1; i < 10; i++) {
336
+ tmpDS['doorStyles']['door_handle_' + i + '_gltf'] = doorHandle;
337
+ tmpDS['doorStyles']['fixed_drawer_door_handle_' + i + '_gltf'] = doorHandle;
338
+ tmpDS['doorStyles']['drawer_door_handle_' + i + '_gltf'] = doorHandle;
339
+ }
340
+ }
341
+ item = item.mergeIn(['doorStyle'], (0, _immutable.fromJS)(tmpDS));
342
+ return item;
343
+ }
344
+ }, {
345
+ key: "select",
346
+ value: function select(state, layerID, itemID) {
347
+ state = _export.Layer.select(state, layerID).updatedState;
348
+ state = _export.Layer.selectElement(state, layerID, 'items', itemID).updatedState;
349
+ state = state.merge({
350
+ replacingSupport: new _immutable.Map({
351
+ layerID: layerID,
352
+ itemID: itemID
353
+ })
354
+ });
355
+ return {
356
+ updatedState: state
357
+ };
358
+ }
359
+ }, {
360
+ key: "selectHole",
361
+ value: function selectHole(state, layerID, holeID) {
362
+ state = _export.Layer.select(state, layerID).updatedState;
363
+ state = _export.Layer.selectElement(state, layerID, 'holes', holeID).updatedState;
364
+ return {
365
+ updatedState: state
366
+ };
367
+ }
368
+ }, {
369
+ key: "editWidth",
370
+ value: function editWidth(state, newWidth, layerID, itemID) {
371
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
372
+ var properties = item.properties;
373
+ if (newWidth === 0) {
374
+ alert('You can not set width to 0');
375
+ return {
376
+ updatedState: state
377
+ };
378
+ }
379
+ var width = new _immutable.Map({
380
+ _length: newWidth,
381
+ _unit: 'in',
382
+ length: (0, _convertUnitsLite.convert)(newWidth).from('in').to('cm')
383
+ });
384
+ properties = properties.set('width', width);
385
+ state = state.mergeIn(['scene', 'layers', layerID, 'items', itemID, 'properties'], properties);
386
+ return {
387
+ updatedState: state
388
+ };
389
+ }
390
+ }, {
391
+ key: "prepareSnap",
392
+ value: function prepareSnap(state, layerID) {
393
+ var layer = state.getIn(['scene', 'layers', layerID]);
394
+ var scene = state.get('scene');
395
+ var catalog = state.catalog.toJS();
396
+ allLines = _export2.GeometryUtils.getAllLines(layer);
397
+ allLineRects = _export2.GeometryUtils.buildRectFromLines(layer, allLines);
398
+ allItemRect = _export2.GeometryUtils.getAllItems(scene, catalog, allLineRects);
399
+ allItemSnap = _export2.GeometryUtils.getAllItemSnap(allItemRect);
400
+ allLineSnap = _export2.GeometryUtils.getAllLineSnap(allLineRects, allItemRect.cur);
401
+ allRect = allItemRect.others.concat(allLineRects);
402
+ allItemSnap = _export2.GeometryUtils.validateSnaps(allItemSnap, allRect);
403
+ allLineSnap = _export2.GeometryUtils.validateSnaps(allLineSnap, allRect);
404
+ }
405
+ }, {
406
+ key: "duplicateSelected",
407
+ value: function duplicateSelected(state, currentObject) {
408
+ var onInternalEvent = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
409
+ var layerID = state.getIn(['scene', 'selectedLayer']);
410
+ var layer = state.getIn(['scene', 'layers', layerID]);
411
+ var objectID = currentObject.id;
412
+ var myObject;
413
+ var x = currentObject.x;
414
+ var y = currentObject.y;
415
+ var sceneComponentType, width, depth, rotRad;
416
+ var duplicatedElement = null;
417
+ switch (currentObject.prototype) {
418
+ case 'items':
419
+ myObject = state.getIn(['scene', 'layers', layerID, 'items', objectID]);
420
+ sceneComponentType = myObject.type;
421
+ width = myObject.properties.getIn(['width', 'length']);
422
+ depth = myObject.properties.getIn(['depth', 'length']);
423
+ rotRad = myObject.rotation * Math.PI / 180;
424
+ this.prepareSnap(state, layerID);
425
+ var val = {
426
+ pos: {
427
+ x: x + width * Math.cos(rotRad),
428
+ y: y + width * Math.sin(rotRad)
429
+ },
430
+ rotRad: rotRad
431
+ };
432
+ val.size = allItemRect.cur.size;
433
+ val.layoutpos = allItemRect.cur.layoutpos;
434
+ val.is_corner = allItemRect.cur.is_corner;
435
+ var isrectSect = _export2.GeometryUtils.validInterSect(allRect, val);
436
+ if (isrectSect) {
437
+ // Duplicated object has a original object's molding property
438
+ var _this$create = this.create(state, layerID, sceneComponentType, x + width * Math.cos(rotRad), y + width * Math.sin(rotRad), 200, 100, rotRad * 180 / Math.PI, true, myObject.molding, false, myObject),
439
+ stateI = _this$create.updatedState,
440
+ item = _this$create.item;
441
+ duplicatedElement = item;
442
+ if (item === null) {
443
+ alert('There are no Door Colors in this cabinet.');
444
+ state = state.merge({
445
+ mode: _constants.MODE_IDLE,
446
+ drawingSupport: new _immutable.Map()
447
+ });
448
+ } else {
449
+ state = Item.select(stateI, layerID, item.id).updatedState;
450
+ state = state.setIn(['drawingSupport', 'currentID'], item.id);
451
+ }
452
+ } else {
453
+ var _val = {
454
+ pos: {
455
+ x: x - width * Math.cos(rotRad),
456
+ y: y - width * Math.sin(rotRad)
457
+ },
458
+ rotRad: rotRad
459
+ };
460
+ _val.size = allItemRect.cur.size;
461
+ _val.layoutpos = allItemRect.cur.layoutpos;
462
+ _val.is_corner = allItemRect.cur.is_corner;
463
+ var isRect = _export2.GeometryUtils.validInterSect(allRect, _val);
464
+ if (isRect) {
465
+ var _this$create2 = this.create(state, layerID, sceneComponentType, x - width * Math.cos(rotRad), y - width * Math.sin(rotRad), 200, 100, rotRad * 180 / Math.PI, true, myObject.molding, false, myObject),
466
+ _stateI = _this$create2.updatedState,
467
+ _item2 = _this$create2.item;
468
+ duplicatedElement = _item2;
469
+ if (_item2 === null) {
470
+ alert('There are no Door Colors in this cabinet.');
471
+ state = state.merge({
472
+ mode: _constants.MODE_IDLE,
473
+ drawingSupport: new _immutable.Map()
474
+ });
475
+ } else {
476
+ state = Item.select(_stateI, layerID, _item2.id).updatedState;
477
+ state = state.setIn(['drawingSupport', 'currentID'], _item2.id);
478
+ }
479
+ } else {
480
+ var _val2 = {
481
+ pos: {
482
+ x: x - depth * Math.sin(rotRad),
483
+ y: y - depth * Math.cos(rotRad)
484
+ },
485
+ rotRad: rotRad
486
+ };
487
+ _val2.size = allItemRect.cur.size;
488
+ _val2.layoutpos = allItemRect.cur.layoutpos;
489
+ _val2.is_corner = allItemRect.cur.is_corner;
490
+ var isRectDown = _export2.GeometryUtils.validInterSect(allRect, _val2);
491
+ if (isRectDown) {
492
+ var _this$create3 = this.create(state, layerID, sceneComponentType, x - depth * Math.sin(rotRad), y - depth * Math.cos(rotRad), 200, 100, rotRad * 180 / Math.PI, true, myObject.molding, false, myObject),
493
+ _stateI2 = _this$create3.updatedState,
494
+ _item3 = _this$create3.item;
495
+ duplicatedElement = _item3;
496
+ if (_item3 === null) {
497
+ alert('There are no Door Colors in this cabinet.');
498
+ state = state.merge({
499
+ mode: _constants.MODE_IDLE,
500
+ drawingSupport: new _immutable.Map()
501
+ });
502
+ } else {
503
+ state = Item.select(_stateI2, layerID, _item3.id).updatedState;
504
+ state = state.setIn(['drawingSupport', 'currentID'], _item3.id);
505
+ }
506
+ } else {
507
+ var _val3 = {
508
+ pos: {
509
+ x: x + depth * Math.sin(rotRad),
510
+ y: y + depth * Math.cos(rotRad)
511
+ },
512
+ rotRad: rotRad
513
+ };
514
+ _val3.size = allItemRect.cur.size;
515
+ _val3.layoutpos = allItemRect.cur.layoutpos;
516
+ _val3.is_corner = allItemRect.cur.is_corner;
517
+ var isRectUp = _export2.GeometryUtils.validInterSect(allRect, _val3);
518
+ if (isRectUp) {
519
+ var _this$create4 = this.create(state, layerID, sceneComponentType, x + depth * Math.sin(rotRad), y + depth * Math.cos(rotRad), 200, 100, rotRad * 180 / Math.PI, true, myObject.molding, false, myObject),
520
+ _stateI3 = _this$create4.updatedState,
521
+ _item4 = _this$create4.item;
522
+ duplicatedElement = _item4;
523
+ if (_item4 === null) {
524
+ alert('There are no Door Colors in this cabinet.');
525
+ state = state.merge({
526
+ mode: _constants.MODE_IDLE,
527
+ drawingSupport: new _immutable.Map()
528
+ });
529
+ } else {
530
+ state = Item.select(_stateI3, layerID, _item4.id).updatedState;
531
+ state = state.setIn(['drawingSupport', 'currentID'], _item4.id);
532
+ }
533
+ } else {
534
+ console.log('there is no space');
535
+ alert('No more space!');
536
+ }
537
+ }
538
+ }
539
+ }
540
+ break;
541
+ case 'holes':
542
+ this.prepareSnap(state, layerID);
543
+ myObject = state.getIn(['scene', 'layers', layerID, 'holes', objectID]);
544
+ var line = state.getIn(['scene', 'layers', layerID, 'lines', myObject.line]);
545
+ sceneComponentType = myObject.type;
546
+ width = myObject.get('properties').get('width').get('length');
547
+ var myOffset = myObject.offset;
548
+ var v0 = layer.getIn(['vertices', line.vertices.get(0)]);
549
+ var v1 = layer.getIn(['vertices', line.vertices.get(1)]);
550
+ var lineLength = _export2.GeometryUtils.pointsDistance(v0.x, v0.y, v1.x, v1.y);
551
+ var delta = width / 2 / lineLength + 0.00001;
552
+ var allHoles = state.getIn(['scene', 'layers', layerID, 'holes']);
553
+ var rightAble = true;
554
+ var leftAble = true;
555
+ if (myOffset + 3 * delta > 1) rightAble = false;else if (myOffset - 3 * delta < 0) leftAble = false;
556
+ if (allHoles.size === 0) {
557
+ var _this$createHole = this.createHole(state, layerID, sceneComponentType, myObject.line, myOffset + delta * 2, myObject.get('properties')),
558
+ stateH = _this$createHole.updatedState,
559
+ hole = _this$createHole.hole;
560
+ state = this.selectHole(stateH, layerID, hole.id).updatedState;
561
+ state = state.setIn(['drawingSupport', 'currentID'], hole.id);
562
+ } else {
563
+ allHoles.forEach(function (hole) {
564
+ if (hole.line === line.id) if (!hole.selected) {
565
+ var newDelta = hole.get('properties').get('width').get('length') / 2 / lineLength;
566
+ if (myOffset < hole.offset) {
567
+ if (myOffset + delta * 3 > hole.offset - newDelta) {
568
+ rightAble = false;
569
+ }
570
+ } else {
571
+ if (myOffset - delta * 3 < hole.offset + newDelta) {
572
+ leftAble = false;
573
+ }
574
+ }
575
+ }
576
+ });
577
+ }
578
+ if (rightAble) {
579
+ var _this$createHole2 = this.createHole(state, layerID, sceneComponentType, myObject.line, myOffset + delta * 2, myObject.get('properties')),
580
+ _stateH = _this$createHole2.updatedState,
581
+ _hole = _this$createHole2.hole;
582
+ state = this.selectHole(_stateH, layerID, _hole.id).updatedState;
583
+ state = state.setIn(['drawingSupport', 'currentID'], _hole.id);
584
+ } else {
585
+ if (leftAble) {
586
+ var _this$createHole3 = this.createHole(state, layerID, sceneComponentType, myObject.line, myOffset - delta * 2, myObject.get('properties')),
587
+ _stateH2 = _this$createHole3.updatedState,
588
+ _hole2 = _this$createHole3.hole;
589
+ state = this.selectHole(_stateH2, layerID, _hole2.id).updatedState;
590
+ state = state.setIn(['drawingSupport', 'currentID'], _hole2.id);
591
+ } else alert('No more space');
592
+ }
593
+ break;
594
+ case 'lines':
595
+ alert('Duplicating lines is not currently supported yet.');
596
+ break;
597
+ default:
598
+ break;
599
+ }
600
+ if (onInternalEvent && duplicatedElement) {
601
+ var jsElement = (0, _helper.updatePayloadOfInternalEvent)(duplicatedElement, layer);
602
+ onInternalEvent({
603
+ type: _constants.INTERNAL_EVENT_DRAW_ELEMENT,
604
+ value: jsElement
605
+ });
606
+ }
607
+ return {
608
+ updatedState: state
609
+ };
610
+ }
611
+ }, {
612
+ key: "storeDistArray",
613
+ value: function storeDistArray(state, layerID, itemID, distArray) {
614
+ if ((0, _utils.isEmpty)(distArray)) return {
615
+ updatedState: state
616
+ };
617
+ var curDistArray = state.getIn(['scene', 'layers', layerID, 'items', itemID, 'distArray']);
618
+ distArray.forEach(function (dist) {
619
+ dist[0] < 0 ? dist[0] = 0 : dist[0];
620
+ });
621
+ var isEqualDist = function isEqualDist(a, b) {
622
+ return a == b;
623
+ };
624
+ if (curDistArray) {
625
+ var equal = curDistArray.every(function (curElement, index) {
626
+ return isEqualDist(curElement[0], distArray[index][0]);
627
+ });
628
+ if (!equal) {
629
+ state = state.setIn(['scene', 'layers', layerID, 'items', itemID, 'distArray'], distArray);
630
+ }
631
+ }
632
+ return {
633
+ updatedState: state
634
+ };
635
+ }
636
+ }, {
637
+ key: "validateItemPositions",
638
+ value: function validateItemPositions(state, layerID) {
639
+ var _this = this;
640
+ var layer = state.getIn(['scene', 'layers', layerID]);
641
+ function isItemInRect(item) {
642
+ var _state$getIn = state.getIn(['scene']),
643
+ width = _state$getIn.width,
644
+ height = _state$getIn.height;
645
+ return item.x >= 0 && item.x <= width && item.y >= 0 && item.y <= height;
646
+ }
647
+ layer.items.forEach(function (item) {
648
+ if (!isItemInRect(item)) state = _this.remove(state, layerID, item.id).updatedState;
649
+ });
650
+ return {
651
+ updatedState: state
652
+ };
653
+ }
654
+ }, {
655
+ key: "remove",
656
+ value: function remove(state, layerID, itemID) {
657
+ state = this.unselect(state, layerID, itemID).updatedState;
658
+ state = _export.Layer.removeElement(state, layerID, 'items', itemID).updatedState;
659
+ state.getIn(['scene', 'groups']).forEach(function (group) {
660
+ return state = _export.Group.removeElement(state, group.id, layerID, 'items', itemID).updatedState;
661
+ });
662
+ return {
663
+ updatedState: state
664
+ };
665
+ }
666
+ }, {
667
+ key: "replaceItem",
668
+ value: function replaceItem(state, selectedPos, currentObject, selectedObject) {
669
+ var _currentObject$counte;
670
+ var counterTopURI = '';
671
+ if (!(0, _utils.isEmpty)(currentObject === null || currentObject === void 0 || (_currentObject$counte = currentObject.counterTop) === null || _currentObject$counte === void 0 ? void 0 : _currentObject$counte.uri)) {
672
+ var _currentObject$counte2;
673
+ counterTopURI = currentObject === null || currentObject === void 0 || (_currentObject$counte2 = currentObject.counterTop) === null || _currentObject$counte2 === void 0 ? void 0 : _currentObject$counte2.uri;
674
+ } else if (!(0, _utils.isEmpty)(state.getIn(['scene', 'layers', 'layer-1', 'counterTop']))) counterTopURI = state.getIn(['scene', 'layers', 'layer-1', 'counterTop']).uri;
675
+ state = this.remove(state, state.scene.selectedLayer, selectedPos.selectedItemId).updatedState;
676
+ state = this.create(state, state.scene.selectedLayer, selectedObject.name, selectedPos.x, selectedPos.y, selectedObject.info.width, selectedObject.info.height, selectedPos.rotation, false, [], false, null, counterTopURI).updatedState;
677
+ // state = this.select(state, state.scene.selectedLayer, selectedPos.selectedItemId).updatedState;
678
+ return {
679
+ updatedState: state
680
+ };
681
+ }
682
+ }, {
683
+ key: "unselect",
684
+ value: function unselect(state, layerID, itemID) {
685
+ state = _export.Layer.unselect(state, layerID, 'items', itemID).updatedState;
686
+ return {
687
+ updatedState: state
688
+ };
689
+ }
690
+ }, {
691
+ key: "selectToolDrawingItem",
692
+ value: function selectToolDrawingItem(state, sceneComponentType) {
693
+ state = state.merge({
694
+ mode: _constants.MODE_DRAWING_ITEM,
695
+ drawingSupport: new _immutable.Map({
696
+ type: sceneComponentType
697
+ })
698
+ });
699
+ return {
700
+ updatedState: state
701
+ };
702
+ }
703
+ }, {
704
+ key: "selectToolDrawingItem3D",
705
+ value: function selectToolDrawingItem3D(state, sceneComponentType) {
706
+ state = state.merge({
707
+ mode: _constants.MODE_DRAWING_ITEM_3D,
708
+ drawingSupport: new _immutable.Map({
709
+ type: sceneComponentType
710
+ })
711
+ });
712
+ state = state.mergeIn(['scene', 'loadFlag'], false);
713
+
714
+ // place the item at random position
715
+ var layerID = state.scene.get('selectedLayer');
716
+ state = this.updateDrawingItem(state, layerID, 0, 0).updatedState;
717
+ return {
718
+ updatedState: state
719
+ };
720
+ }
721
+ }, {
722
+ key: "endCreatingCabinet",
723
+ value: function endCreatingCabinet(state) {
724
+ state = state.merge({
725
+ isOpen: false,
726
+ openedType: 0
727
+ });
728
+ return {
729
+ updatedState: state
730
+ };
731
+ }
732
+ }, {
733
+ key: "updatePopupOpen",
734
+ value: function updatePopupOpen(state, value) {
735
+ state = state.merge({
736
+ openedType: value
737
+ });
738
+ return {
739
+ updatedState: state
740
+ };
741
+ }
742
+ }, {
743
+ key: "updateDrawingItem",
744
+ value: function updateDrawingItem(state, layerID, x, y) {
745
+ var isInitialPos = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
746
+ if (state.hasIn(['drawingSupport', 'currentID'])) {
747
+ var mode = state.get('mode');
748
+ if ([_constants.MODE_DRAWING_ITEM_3D].includes(mode)) {
749
+ state = state.updateIn(['scene', 'layers', layerID, 'items', state.getIn(['drawingSupport', 'currentID'])], function (item) {
750
+ return item && item.merge({
751
+ x: x,
752
+ y: y,
753
+ isInitialPos: isInitialPos ? isInitialPos : false
754
+ });
755
+ });
756
+ state = state.merge({
757
+ mode: _constants.MODE_IDLE_3D
758
+ });
759
+ }
760
+ if ([_constants.MODE_DRAWING_ITEM].includes(mode)) {
761
+ state = state.merge({
762
+ mode: _constants.MODE_IDLE
763
+ });
764
+ state = state.updateIn(['scene', 'layers', layerID, 'items', state.getIn(['drawingSupport', 'currentID'])], function (item) {
765
+ return item && item.merge({
766
+ x: x,
767
+ y: y,
768
+ isInitialPos: isInitialPos ? isInitialPos : false
769
+ });
770
+ });
771
+ }
772
+ } else {
773
+ var _this$create5 = this.create(state, layerID, state.getIn(['drawingSupport', 'type']), x, y, 200, 100, 0, false, [], isInitialPos),
774
+ stateI = _this$create5.updatedState,
775
+ item = _this$create5.item;
776
+ if (item === null) {
777
+ alert('There are no Door Colors in this cabinet.');
778
+ state = state.merge({
779
+ mode: _constants.MODE_IDLE,
780
+ drawingSupport: new _immutable.Map()
781
+ });
782
+ } else {
783
+ state = Item.select(stateI, layerID, item.id).updatedState;
784
+ state = state.setIn(['drawingSupport', 'currentID'], item.id);
785
+ }
786
+ }
787
+ return {
788
+ updatedState: state
789
+ };
790
+ }
791
+ }, {
792
+ key: "updateDraggingItemChanged",
793
+ value: function updateDraggingItemChanged(state, x, y, layerID, itemID) {
794
+ var _state6 = state,
795
+ scene = _state6.scene;
796
+ // let originalX = draggingSupport.get('originalX');
797
+ // let originalY = draggingSupport.get('originalY');
798
+
799
+ // let diffX = x;
800
+ // let diffY = y;
801
+
802
+ var item = scene.getIn(['layers', layerID, 'items', itemID]);
803
+ // let tX = originalX - diffX;
804
+ // let tY = originalY - diffY;
805
+ // tX = tX > 500 ? 500 : tX < 0 ? 0 : tX;
806
+ // tY = tY > 500 ? 500 : tY < 0 ? 0 : tY;
807
+ item = item.merge({
808
+ x: x,
809
+ y: y,
810
+ isInitialPos: false
811
+ });
812
+ state = state.merge({
813
+ scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
814
+ });
815
+ time2 = (0, _helper.debugUtil)();
816
+ false && console.log('FPS:', Math.round(1000 / (time2 - time1)), ' Delta Time:', (time2 - time1) / 1000, '(s)');
817
+ return {
818
+ updatedState: state
819
+ };
820
+ }
821
+ }, {
822
+ key: "endDrawingItem",
823
+ value: function endDrawingItem(state, layerID, x, y) {
824
+ // let catalog = state.catalog;
825
+ state = this.updateDrawingItem(state, layerID, x, y).updatedState;
826
+ state = _export.Layer.unselectAll(state, layerID).updatedState;
827
+ var popup = state.get('popup');
828
+ state = state.merge({
829
+ drawingSupport: (0, _immutable.Map)({
830
+ type: state.drawingSupport.get('type')
831
+ }),
832
+ isOpen: !popup
833
+ });
834
+ state = _export.Layer.unselectAll(state, layerID).updatedState;
835
+ this.updateMolding(state);
836
+ return {
837
+ updatedState: state
838
+ };
839
+ }
840
+ }, {
841
+ key: "beginDraggingItem",
842
+ value: function beginDraggingItem(state, layerID, itemID, x, y) {
843
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
844
+ time1 = (0, _helper.debugUtil)();
845
+ if ((0, _util.isUndefined)(item)) return;
846
+ state = state.merge({
847
+ mode: _constants.MODE_DRAGGING_ITEM,
848
+ draggingSupport: (0, _immutable.Map)({
849
+ layerID: layerID,
850
+ itemID: itemID,
851
+ startPointX: x,
852
+ startPointY: y,
853
+ originalX: item.x,
854
+ originalY: item.y
855
+ })
856
+ });
857
+ return {
858
+ updatedState: state
859
+ };
860
+ }
861
+ }, {
862
+ key: "beginDraggingItem3D",
863
+ value: function beginDraggingItem3D(state, layerID, itemID, x, y) {
864
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
865
+ state = state.setIn(['scene', 'isEndDragging'], false);
866
+ if ((0, _util.isUndefined)(item)) return {
867
+ updatedState: state
868
+ };
869
+ state = state.merge({
870
+ mode: _constants.MODE_DRAGGING_ITEM_3D,
871
+ draggingSupport: (0, _immutable.Map)({
872
+ layerID: layerID,
873
+ itemID: itemID,
874
+ startPointX: x,
875
+ startPointY: y,
876
+ originalX: item.x,
877
+ originalY: item.y
878
+ })
879
+ });
880
+ return {
881
+ updatedState: state
882
+ };
883
+ }
884
+ }, {
885
+ key: "updateDraggingItem",
886
+ value: function updateDraggingItem(state, x, y) {
887
+ var _state7 = state,
888
+ draggingSupport = _state7.draggingSupport,
889
+ scene = _state7.scene;
890
+ var layerID = draggingSupport.get('layerID');
891
+ var itemID = draggingSupport.get('itemID');
892
+ var startPointX = draggingSupport.get('startPointX');
893
+ var startPointY = draggingSupport.get('startPointY');
894
+ var originalX = draggingSupport.get('originalX');
895
+ var originalY = draggingSupport.get('originalY');
896
+ var diffX = startPointX - x;
897
+ var diffY = startPointY - y;
898
+ var item = scene.getIn(['layers', layerID, 'items', itemID]);
899
+ if ((0, _util.isUndefined)(item)) return {
900
+ updatedState: state
901
+ };
902
+ var tX = originalX - diffX;
903
+ var tY = originalY - diffY;
904
+ tX = tX > scene.width ? scene.width : tX < 0 ? 0 : tX;
905
+ tY = tY > scene.height ? scene.height : tY < 0 ? 0 : tY;
906
+ item = item.merge({
907
+ x: tX,
908
+ y: tY,
909
+ isInitialPos: false
910
+ });
911
+ state = state.merge({
912
+ scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
913
+ });
914
+ return {
915
+ updatedState: state
916
+ };
917
+ }
918
+ }, {
919
+ key: "updateDraggingItem3DX",
920
+ value: function updateDraggingItem3DX(state, x) {
921
+ var _state8 = state,
922
+ draggingSupport = _state8.draggingSupport,
923
+ scene = _state8.scene;
924
+ var layerID = draggingSupport.get('layerID');
925
+ var itemID = draggingSupport.get('itemID');
926
+ var startPointX = draggingSupport.get('startPointX');
927
+ var originalX = draggingSupport.get('originalX');
928
+ var diffX = startPointX - x;
929
+ var item = scene.getIn(['layers', layerID, 'items', itemID]);
930
+ item = item.merge({
931
+ x: originalX - diffX
932
+ });
933
+ state = state.merge({
934
+ scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
935
+ });
936
+ return {
937
+ updatedState: state
938
+ };
939
+ }
940
+ }, {
941
+ key: "updateDraggingItem3DY",
942
+ value: function updateDraggingItem3DY(state, y) {
943
+ var _state9 = state,
944
+ draggingSupport = _state9.draggingSupport,
945
+ scene = _state9.scene;
946
+ var layerID = draggingSupport.get('layerID');
947
+ var itemID = draggingSupport.get('itemID');
948
+ var startPointY = draggingSupport.get('startPointY');
949
+ var originalY = draggingSupport.get('originalY');
950
+ var diffY = startPointY - y;
951
+ var item = scene.getIn(['layers', layerID, 'items', itemID]);
952
+ item = item.merge({
953
+ y: originalY - diffY
954
+ });
955
+ state = state.merge({
956
+ scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
957
+ });
958
+ return {
959
+ updatedState: state
960
+ };
961
+ }
962
+ }, {
963
+ key: "endDraggingItem",
964
+ value: function endDraggingItem(state, x, y) {
965
+ state = this.updateDraggingItem(state, x, y).updatedState;
966
+ state = state.merge({
967
+ mode: _constants.MODE_IDLE
968
+ });
969
+ return {
970
+ updatedState: state
971
+ };
972
+ }
973
+ }, {
974
+ key: "endDraggingItem3D",
975
+ value: function endDraggingItem3D(state) {
976
+ // state = this.updateDraggingItem(state, x, y).updatedState;
977
+ state = state.merge({
978
+ mode: _constants.MODE_IDLE_3D
979
+ });
980
+ state = state.setIn(['scene', 'isEndDragging'], true);
981
+ return {
982
+ updatedState: state
983
+ };
984
+ }
985
+ }, {
986
+ key: "beginRotatingItem",
987
+ value: function beginRotatingItem(state, layerID, itemID, x, y) {
988
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
989
+ var originRotation = item.get('rotation');
990
+ state = state.merge({
991
+ mode: _constants.MODE_ROTATING_ITEM,
992
+ rotatingSupport: (0, _immutable.Map)({
993
+ layerID: layerID,
994
+ itemID: itemID,
995
+ x: x,
996
+ y: y,
997
+ originRotation: originRotation
998
+ })
999
+ });
1000
+ return {
1001
+ updatedState: state
1002
+ };
1003
+ }
1004
+ }, {
1005
+ key: "beginRotatingItem3D",
1006
+ value: function beginRotatingItem3D(state, layerID, itemID, x, y) {
1007
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
1008
+ var originRotation = item.get('rotation');
1009
+ state = state.merge({
1010
+ mode: _constants.MODE_ROTATING_ITEM_3D,
1011
+ rotatingSupport: (0, _immutable.Map)({
1012
+ layerID: layerID,
1013
+ itemID: itemID,
1014
+ x: x,
1015
+ y: y,
1016
+ originRotation: originRotation
1017
+ })
1018
+ });
1019
+ return {
1020
+ updatedState: state
1021
+ };
1022
+ }
1023
+ }, {
1024
+ key: "updateRotatingItem",
1025
+ value: function updateRotatingItem(state, x, y) {
1026
+ var _state0 = state,
1027
+ rotatingSupport = _state0.rotatingSupport,
1028
+ scene = _state0.scene;
1029
+ var layerID = rotatingSupport.get('layerID');
1030
+ var itemID = rotatingSupport.get('itemID');
1031
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
1032
+ var origin = {
1033
+ x: rotatingSupport.get('x'),
1034
+ y: rotatingSupport.get('y'),
1035
+ originRotation: rotatingSupport.get('originRotation')
1036
+ };
1037
+ var newRot = Math.atan2(origin.y - item.y, origin.x - item.x) * 180 / Math.PI + 90;
1038
+ var deltaRot = newRot - origin.originRotation;
1039
+ var deltaX = x - item.x;
1040
+ var deltaY = y - item.y;
1041
+ var rotation = Math.atan2(deltaY, deltaX) * 180 / Math.PI + 90;
1042
+ rotation -= deltaRot;
1043
+ if (-5 < rotation && rotation < 5) rotation = 0;
1044
+ if (-95 < rotation && rotation < -85) rotation = -90;
1045
+ if (-185 < rotation && rotation < -175) rotation = -180;
1046
+ if (85 < rotation && rotation < 95) rotation = 90;
1047
+ if (-270 < rotation && rotation < -265) rotation = 90;
1048
+ if (175 < rotation && rotation < 185) rotation = 180;
1049
+ if (265 < rotation && rotation < 275) rotation = -90;
1050
+ item = item.merge({
1051
+ rotation: rotation
1052
+ });
1053
+ state = state.merge({
1054
+ scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
1055
+ });
1056
+ return {
1057
+ updatedState: state
1058
+ };
1059
+ }
1060
+ }, {
1061
+ key: "updateRotatingItemChanged",
1062
+ value: function updateRotatingItemChanged(state, rotation, layerID, itemID) {
1063
+ var scene = state.scene;
1064
+
1065
+ // let originalX = draggingSupport.get('originalX');
1066
+ // let originalY = draggingSupport.get('originalY');
1067
+
1068
+ // let diffX = x;
1069
+ // let diffY = y;
1070
+
1071
+ var item = scene.getIn(['layers', layerID, 'items', itemID]);
1072
+ // let tX = originalX - diffX;
1073
+ // let tY = originalY - diffY;
1074
+ // tX = tX > 500 ? 500 : tX < 0 ? 0 : tX;
1075
+ // tY = tY > 500 ? 500 : tY < 0 ? 0 : tY;
1076
+ item = item.merge({
1077
+ rotation: rotation
1078
+ });
1079
+ state = state.merge({
1080
+ scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
1081
+ });
1082
+ return {
1083
+ updatedState: state
1084
+ };
1085
+ }
1086
+ }, {
1087
+ key: "endRotatingItem",
1088
+ value: function endRotatingItem(state, x, y) {
1089
+ //state = this.updateRotatingItem(state, x, y).updatedState;
1090
+ state = state.merge({
1091
+ mode: _constants.MODE_IDLE
1092
+ });
1093
+ return {
1094
+ updatedState: state
1095
+ };
1096
+ }
1097
+ }, {
1098
+ key: "endRotatingItem3D",
1099
+ value: function endRotatingItem3D(state, x, y) {
1100
+ state = this.updateRotatingItem(state, x, y).updatedState;
1101
+ state = state.merge({
1102
+ mode: _constants.MODE_IDLE_3D
1103
+ });
1104
+ return {
1105
+ updatedState: state
1106
+ };
1107
+ }
1108
+ }, {
1109
+ key: "replaceSubmodule",
1110
+ value: function replaceSubmodule(state, url) {
1111
+ var _state1 = state,
1112
+ replacingSupport = _state1.replacingSupport,
1113
+ scene = _state1.scene;
1114
+ url = 'catalog/texture.png';
1115
+ var urlData = url.split('/');
1116
+ var newURL = '';
1117
+ var addURL = false;
1118
+ for (var i = 0; i < urlData.length; i++) {
1119
+ if (urlData[i] == '') {
1120
+ continue;
1121
+ }
1122
+ newURL += '/' + urlData[i];
1123
+ }
1124
+ var layerID = replacingSupport.get('layerID');
1125
+ var itemID = replacingSupport.get('itemID');
1126
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
1127
+ var submodule = [];
1128
+ var normalMap = [];
1129
+ for (var _i = 0; _i < item.submodule.size; _i++) submodule.push(item.submodule.get(_i));
1130
+ for (var _i2 = 0; _i2 < item.normalMap.size; _i2++) normalMap.push(item.normalMap.get(_i2));
1131
+ //let submodule = state.getIn(['scene', 'layers', layerID, 'items', itemID, 'submodule']);
1132
+ urlData = newURL.split('/');
1133
+ var flag = false;
1134
+ if (urlData[urlData.length - 1].includes('.gltf')) {
1135
+ for (var _i3 = 0; _i3 < submodule.length; _i3++) {
1136
+ var pathData = submodule[_i3].split('/');
1137
+ if (pathData[pathData.length - 2] === urlData[urlData.length - 2]) {
1138
+ submodule[_i3] = newURL;
1139
+ flag = true;
1140
+ }
1141
+ }
1142
+ if (!flag) submodule.push(newURL);
1143
+ item = item.merge({
1144
+ submodule: submodule
1145
+ });
1146
+ } else {
1147
+ for (var _i4 = 0; _i4 < normalMap.length; _i4++) {
1148
+ var _pathData = normalMap[_i4].split('/');
1149
+ if (_pathData[_pathData.length - 2] === urlData[urlData.length - 2]) {
1150
+ normalMap[_i4] = newURL;
1151
+ flag = true;
1152
+ }
1153
+ }
1154
+ if (!flag) normalMap.push(newURL);
1155
+ item = item.merge({
1156
+ normalMap: normalMap
1157
+ });
1158
+ }
1159
+ state = state.merge({
1160
+ scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
1161
+ });
1162
+ state = state.merge({
1163
+ mode: _constants.MODE_IDLE_3D
1164
+ });
1165
+ return {
1166
+ updatedState: state
1167
+ };
1168
+ }
1169
+ }, {
1170
+ key: "setProperties",
1171
+ value: function setProperties(state, layerID, itemID, properties) {
1172
+ state = state.mergeIn(['scene', 'layers', layerID, 'items', itemID, 'properties'], properties);
1173
+ return {
1174
+ updatedState: state
1175
+ };
1176
+ }
1177
+ }, {
1178
+ key: "setJsProperties",
1179
+ value: function setJsProperties(state, layerID, itemID, properties) {
1180
+ return this.setProperties(state, layerID, itemID, (0, _immutable.fromJS)(properties));
1181
+ }
1182
+ }, {
1183
+ key: "updateProperties",
1184
+ value: function updateProperties(state, layerID, itemID, properties) {
1185
+ properties.forEach(function (v, k) {
1186
+ if (state.hasIn(['scene', 'layers', layerID, 'items', itemID, 'properties', k])) state = state.mergeIn(['scene', 'layers', layerID, 'items', itemID, 'properties', k], v);
1187
+ });
1188
+ return {
1189
+ updatedState: state
1190
+ };
1191
+ }
1192
+ }, {
1193
+ key: "updateJsProperties",
1194
+ value: function updateJsProperties(state, layerID, itemID, properties) {
1195
+ return this.updateProperties(state, layerID, itemID, (0, _immutable.fromJS)(properties));
1196
+ }
1197
+ }, {
1198
+ key: "setAttributes",
1199
+ value: function setAttributes(state, layerID, itemID, itemAttributes) {
1200
+ state = state.mergeIn(['scene', 'layers', layerID, 'items', itemID], itemAttributes);
1201
+ return {
1202
+ updatedState: state
1203
+ };
1204
+ }
1205
+ }, {
1206
+ key: "setJsAttributes",
1207
+ value: function setJsAttributes(state, layerID, itemID, itemAttributes) {
1208
+ itemAttributes = (0, _immutable.fromJS)(itemAttributes);
1209
+ return this.setAttributes(state, layerID, itemID, itemAttributes);
1210
+ }
1211
+ }, {
1212
+ key: "animateObject",
1213
+ value: function animateObject(state, value) {
1214
+ var _state10 = state,
1215
+ replacingSupport = _state10.replacingSupport,
1216
+ scene = _state10.scene;
1217
+ var layerID = replacingSupport.get('layerID');
1218
+ var itemID = replacingSupport.get('itemID');
1219
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
1220
+ if (item !== undefined) {
1221
+ var animCount = item.get('animate');
1222
+ item = item.merge({
1223
+ animValue: value,
1224
+ animate: animCount + 1
1225
+ });
1226
+ state = state.merge({
1227
+ scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
1228
+ });
1229
+ state = state.merge({
1230
+ mode: _constants.MODE_IDLE_3D
1231
+ });
1232
+ }
1233
+ return {
1234
+ updatedState: state
1235
+ };
1236
+ }
1237
+ }, {
1238
+ key: "removeReplacingSupport",
1239
+ value: function removeReplacingSupport(state) {
1240
+ state = state.merge({
1241
+ replacingSupport: new _immutable.Map()
1242
+ });
1243
+ return {
1244
+ updatedState: state
1245
+ };
1246
+ }
1247
+ }, {
1248
+ key: "setInitialDoorStyle",
1249
+ value: function setInitialDoorStyle(state, doorStyle) {
1250
+ state = state.merge({
1251
+ doorStyle: doorStyle
1252
+ });
1253
+ var _state11 = state,
1254
+ scene = _state11.scene;
1255
+ var layerID = scene.get('selectedLayer');
1256
+ var layers = scene.layers.get(layerID);
1257
+ var items = layers.items;
1258
+ layers = layers.setIn(['doorStyle'], (0, _immutable.fromJS)(doorStyle));
1259
+ state = state.merge({
1260
+ scene: state.scene.mergeIn(['layers', layerID], layers)
1261
+ });
1262
+ items.forEach(function (data) {
1263
+ {
1264
+ var itemID = data.id;
1265
+ var tmpDS = _objectSpread(_objectSpread({}, data.doorStyle), {}, {
1266
+ doorStyles: _objectSpread(_objectSpread({}, data.doorStyle.doorStyles), {}, {
1267
+ counttop: doorStyle.doorStyles.counttop
1268
+ })
1269
+ });
1270
+ data = data.mergeIn(['doorStyle'], (0, _immutable.fromJS)(tmpDS));
1271
+ layers = layers.mergeIn(['items', itemID], data);
1272
+ state = state.merge({
1273
+ scene: scene.mergeIn(['layers', layerID], layers)
1274
+ });
1275
+ }
1276
+ });
1277
+ return {
1278
+ updatedState: state
1279
+ };
1280
+ }
1281
+ }, {
1282
+ key: "setDoorStyle",
1283
+ value: function setDoorStyle(state, doorStyle, itemCDS, applyScope) {
1284
+ var _this2 = this;
1285
+ var targetItemIDs = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : [];
1286
+ if ((0, _utils.isEmpty)(doorStyle)) return {
1287
+ updatedState: state
1288
+ };
1289
+ var keys = doorStyle.doorStyles ? Object.keys(doorStyle.doorStyles) : [];
1290
+ keys = keys.filter(function (elem) {
1291
+ return !elem.endsWith('_gltf');
1292
+ });
1293
+ var tmp = {};
1294
+ for (var x in keys) {
1295
+ tmp[keys[x]] = doorStyle.doorStyles[keys[x]];
1296
+ }
1297
+ doorStyle.cds = itemCDS;
1298
+ state = state.setIn(['scene', 'layers', state.scene.selectedLayer, 'doorStyle'], doorStyle);
1299
+ state = state.merge({
1300
+ doorStyle: doorStyle
1301
+ });
1302
+ var layerID = state.scene.get('selectedLayer');
1303
+ var temp_layer_molding = state.scene.getIn(['layers', layerID, 'molding']);
1304
+ temp_layer_molding = temp_layer_molding.filter(function (md) {
1305
+ return itemCDS === null || itemCDS === void 0 ? void 0 : itemCDS.some(function (ds) {
1306
+ return md.itemID === ds.itemID;
1307
+ });
1308
+ });
1309
+ state = state.setIn(['scene', 'layers', layerID, 'molding'], temp_layer_molding);
1310
+
1311
+ // 🔥 Determine which items to update
1312
+ var items = state.scene.layers.get(layerID).items;
1313
+ var itemsToProcess = [];
1314
+ var idSet = null;
1315
+ if (applyScope === _constants.DOORSTYLE_SCOPE_SINGLE) {
1316
+ var selectedItemIds = state.scene.layers.getIn([layerID, 'selected', 'items']).toJS();
1317
+ idSet = new Set(selectedItemIds);
1318
+ }
1319
+ if (applyScope === _constants.DOORSTYLE_SCOPE_MULTIPLE) {
1320
+ // targetItemIds contains item.id (instance IDs)
1321
+ idSet = new Set(targetItemIDs);
1322
+ }
1323
+ if (applyScope === _constants.DOORSTYLE_SCOPE_ALL) {
1324
+ items.forEach(function (item) {
1325
+ itemsToProcess.push(item);
1326
+ });
1327
+ } else if (idSet) {
1328
+ items.forEach(function (item) {
1329
+ if (idSet.has(item.id)) {
1330
+ itemsToProcess.push(item);
1331
+ }
1332
+ });
1333
+ }
1334
+ var setDoorStyleOfItem = function setDoorStyleOfItem(data) {
1335
+ var _cds$data;
1336
+ if (data.category !== 'cabinet') return;
1337
+ var itemID = data.id;
1338
+ var curItem = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
1339
+ var layer = state.getIn(['scene', 'layers', layerID]);
1340
+ var tmpMolding = (0, _toConsumableArray2["default"])(curItem.molding);
1341
+ var temp_item_molding = (0, _toConsumableArray2["default"])(curItem.molding);
1342
+ temp_item_molding = temp_item_molding.filter(function (md) {
1343
+ return itemCDS === null || itemCDS === void 0 ? void 0 : itemCDS.some(function (ds) {
1344
+ return ds.itemID === md.itemID;
1345
+ });
1346
+ });
1347
+ tmpMolding.forEach(function (md) {
1348
+ var itemGroup = _export2.MoldingUtils.getItemGroupFromMolding(layer, curItem, md);
1349
+ itemGroup.forEach(function (it) {
1350
+ state = state.setIn(['scene', 'layers', layerID, 'items', it.id, 'molding'], temp_item_molding);
1351
+ });
1352
+ });
1353
+ var cds = itemCDS === null || itemCDS === void 0 ? void 0 : itemCDS.find(function (elem) {
1354
+ return elem.itemID === data.itemID;
1355
+ });
1356
+ var euro_cds = (cds === null || cds === void 0 || (_cds$data = cds.data) === null || _cds$data === void 0 ? void 0 : _cds$data.filter(function (element) {
1357
+ return element && element.is_euro_cds;
1358
+ })) || [];
1359
+ var cds_data = cds ? [cds] : [];
1360
+ if (euro_cds.length > 0) {
1361
+ var newProperties = state.scene.getIn(['layers', layerID, 'items', itemID, 'properties']).toJS();
1362
+ if (newProperties.hasOwnProperty('depth')) {
1363
+ if (!newProperties.hasOwnProperty('oldDepth')) {
1364
+ newProperties['oldDepth'] = new _immutable.Map({
1365
+ length: newProperties.depth.length,
1366
+ _length: newProperties.depth._length,
1367
+ _unit: newProperties.depth._unit
1368
+ });
1369
+ }
1370
+ newProperties['depth'] = new _immutable.Map({
1371
+ length: (0, _convertUnitsLite.convert)(euro_cds[0].euro_length).from('in').to('cm'),
1372
+ _length: euro_cds[0].euro_length,
1373
+ _unit: 'in'
1374
+ });
1375
+ }
1376
+ if (newProperties.hasOwnProperty('height')) {
1377
+ if (!newProperties.hasOwnProperty('oldHeight')) {
1378
+ newProperties['oldHeight'] = new _immutable.Map({
1379
+ length: newProperties.height.length,
1380
+ _length: newProperties.height._length,
1381
+ _unit: newProperties.height._unit
1382
+ });
1383
+ }
1384
+ newProperties['height'] = new _immutable.Map({
1385
+ length: (0, _convertUnitsLite.convert)(euro_cds[0].euro_height).from('in').to('cm'),
1386
+ _length: euro_cds[0].euro_height,
1387
+ _unit: 'in'
1388
+ });
1389
+ }
1390
+ if (newProperties.hasOwnProperty('width')) {
1391
+ if (!newProperties.hasOwnProperty('oldWidth')) {
1392
+ newProperties['oldWidth'] = new _immutable.Map({
1393
+ length: newProperties.width.length,
1394
+ _length: newProperties.width._length,
1395
+ _unit: newProperties.width._unit
1396
+ });
1397
+ }
1398
+ newProperties['width'] = new _immutable.Map({
1399
+ length: (0, _convertUnitsLite.convert)(euro_cds[0].euro_width).from('in').to('cm') - 10,
1400
+ _length: euro_cds[0].euro_width,
1401
+ _unit: 'in'
1402
+ });
1403
+ }
1404
+ state = _this2.setJsProperties(state, layerID, itemID, newProperties).updatedState;
1405
+ } else {
1406
+ var properties = state.scene.getIn(['layers', layerID, 'items', itemID, 'properties']).toJS();
1407
+ if (properties.hasOwnProperty('oldDepth')) {
1408
+ properties['depth'] = new _immutable.Map({
1409
+ length: properties.oldDepth.length,
1410
+ _length: properties.oldDepth._length,
1411
+ _unit: properties.oldDepth._unit
1412
+ });
1413
+ }
1414
+ if (properties.hasOwnProperty('oldHeight')) {
1415
+ properties['height'] = new _immutable.Map({
1416
+ length: properties.oldHeight.length,
1417
+ _length: properties.oldHeight._length,
1418
+ _unit: properties.oldHeight._unit
1419
+ });
1420
+ }
1421
+ if (properties.hasOwnProperty('oldWidth')) {
1422
+ properties['width'] = new _immutable.Map({
1423
+ length: properties.oldWidth.length,
1424
+ _length: properties.oldWidth._length,
1425
+ _unit: properties.oldWidth._unit
1426
+ });
1427
+ }
1428
+ state = _this2.setJsProperties(state, layerID, itemID, properties).updatedState;
1429
+ }
1430
+ var tmpDS = {
1431
+ id: doorStyle.id,
1432
+ brightness: doorStyle.brightness,
1433
+ color: doorStyle.color,
1434
+ glossness: doorStyle.glossness,
1435
+ name: doorStyle.name,
1436
+ door_style_name: doorStyle.door_style_name,
1437
+ door_style_id: doorStyle.door_style_id,
1438
+ texture: doorStyle.texture,
1439
+ thumbnail: doorStyle.thumbnail,
1440
+ type: doorStyle.type,
1441
+ sku: doorStyle.sku,
1442
+ color_sku_alias: doorStyle.color_sku_alias,
1443
+ install: (0, _utils.getInstallationSuffix)(_constants.INSTALLATION_SUFFIX_TYPE.NAME, doorStyle),
1444
+ doorStyles: _objectSpread(_objectSpread({}, tmp), {}, {
1445
+ cds: cds_data
1446
+ })
1447
+ };
1448
+ state = state.mergeIn(['scene', 'layers', layerID, 'items', itemID, 'doorStyle'], (0, _immutable.fromJS)(tmpDS));
1449
+ };
1450
+
1451
+ // 🔥 Apply to resolved items
1452
+ itemsToProcess.forEach(setDoorStyleOfItem);
1453
+ return {
1454
+ updatedState: state
1455
+ };
1456
+ }
1457
+ }, {
1458
+ key: "setCounterTop",
1459
+ value: function setCounterTop(state, counterTop) {
1460
+ var _state12 = state,
1461
+ scene = _state12.scene;
1462
+ var layerID = scene.get('selectedLayer');
1463
+ var layers = scene.layers.get(layerID);
1464
+ layers = layers.mergeIn(['counterTop'], counterTop);
1465
+ state = state.merge({
1466
+ scene: scene.mergeIn(['layers', layerID], layers)
1467
+ });
1468
+ var items = layers.items;
1469
+ items.forEach(function (data) {
1470
+ {
1471
+ var dataJSON = data.toJS();
1472
+ var itemID = dataJSON.id;
1473
+ var newCounter = dataJSON.counterTop;
1474
+ newCounter = _objectSpread(_objectSpread({}, newCounter), counterTop);
1475
+ data = data.mergeIn(['counterTop'], newCounter);
1476
+ layers = layers.mergeIn(['items', itemID], data);
1477
+ state = state.merge({
1478
+ scene: scene.mergeIn(['layers', layerID], layers)
1479
+ });
1480
+ }
1481
+ });
1482
+ return {
1483
+ updatedState: state
1484
+ };
1485
+ }
1486
+ }, {
1487
+ key: "setItemsDoorHandle",
1488
+ value: function setItemsDoorHandle(state, scene, layer, layerID, elements_item) {
1489
+ var _this3 = this;
1490
+ elements_item.forEach(function (data) {
1491
+ var itemID = data.id;
1492
+ var item = _this3.updateDoorHandle(data, layer);
1493
+ layer = layer.mergeIn(['items', itemID], item);
1494
+ state = state.merge({
1495
+ scene: scene.mergeIn(['layers', layerID], layer)
1496
+ });
1497
+ });
1498
+ return {
1499
+ updatedState: state
1500
+ };
1501
+ }
1502
+ }, {
1503
+ key: "setDoorHandle",
1504
+ value: function setDoorHandle(state, doorHandle) {
1505
+ var _state13 = state,
1506
+ scene = _state13.scene;
1507
+ var layerID = scene.get('selectedLayer');
1508
+ var layer = scene.layers.get(layerID);
1509
+ layer = layer.mergeIn(['doorHandle'], doorHandle);
1510
+ state = state.merge({
1511
+ scene: scene.mergeIn(['layers', layerID], layer)
1512
+ });
1513
+ var items = layer.items;
1514
+ var selectedItems = items.filter(function (element) {
1515
+ return element.selected === true;
1516
+ }); // find selected items (default 1 selected)
1517
+
1518
+ if (selectedItems.size === 0) {
1519
+ state = this.setItemsDoorHandle(state, scene, layer, layerID, items).updatedState;
1520
+ } else {
1521
+ state = this.setItemsDoorHandle(state, scene, layer, layerID, selectedItems).updatedState;
1522
+ }
1523
+ return {
1524
+ updatedState: state
1525
+ };
1526
+ }
1527
+ }, {
1528
+ key: "setHandleMaterial",
1529
+ value: function setHandleMaterial(state, material) {
1530
+ var _state14 = state,
1531
+ scene = _state14.scene;
1532
+ var layerID = scene.get('selectedLayer');
1533
+ var layers = scene.layers.get(layerID);
1534
+ var items = layers.items;
1535
+ items.forEach(function (data) {
1536
+ var dataJSON = data.toJS();
1537
+ var itemID = dataJSON.id;
1538
+ var doorStyle = dataJSON.doorStyle;
1539
+ var tmpDS = _objectSpread(_objectSpread({}, doorStyle), {}, {
1540
+ metalness: material.metalness,
1541
+ roughness: material.roughness
1542
+ });
1543
+ data = data.mergeIn(['doorStyle'], (0, _immutable.fromJS)(tmpDS));
1544
+ layers = layers.mergeIn(['items', itemID], data);
1545
+ state = state.merge({
1546
+ scene: scene.mergeIn(['layers', layerID], layers)
1547
+ });
1548
+ });
1549
+ return {
1550
+ updatedState: state
1551
+ };
1552
+ }
1553
+ }, {
1554
+ key: "setWallColor",
1555
+ value: function setWallColor(state, wallColor) {
1556
+ var _state15 = state,
1557
+ scene = _state15.scene;
1558
+ var layerID = scene.get('selectedLayer');
1559
+ var layer = scene.layers.get(layerID);
1560
+ layer = layer.merge({
1561
+ wallColor: wallColor
1562
+ });
1563
+ state = state.merge({
1564
+ scene: scene.mergeIn(['layers', layerID], layer)
1565
+ });
1566
+ var lines = layer.lines;
1567
+ lines.forEach(function (data) {
1568
+ var dataJSON = data.toJS();
1569
+ var lineID = dataJSON.id;
1570
+ data = data.mergeIn(['wallColor'], wallColor);
1571
+ layer = layer.mergeIn(['lines', lineID], data);
1572
+ state = state.merge({
1573
+ scene: scene.mergeIn(['layers', layerID], layer)
1574
+ });
1575
+ });
1576
+ return {
1577
+ updatedState: state
1578
+ };
1579
+ }
1580
+ }, {
1581
+ key: "setBacksplash",
1582
+ value: function setBacksplash(state, backsplash) {
1583
+ var _state16 = state,
1584
+ scene = _state16.scene;
1585
+ var layerID = scene.get('selectedLayer');
1586
+ var layer = scene.layers.get(layerID);
1587
+ var dataJSON = layer.toJS();
1588
+ var newBack = dataJSON.backsplash;
1589
+ var flag = true; // selected or not
1590
+ // if backsplash is already set
1591
+ if (layer.getIn(['backsplash']).uri === backsplash.uri) {
1592
+ // unselect
1593
+ newBack = _objectSpread(_objectSpread({}, newBack), {}, {
1594
+ uri: ''
1595
+ });
1596
+ flag = false;
1597
+ }
1598
+ // else then, set backsplash
1599
+ else newBack = _objectSpread(_objectSpread({}, newBack), backsplash);
1600
+ layer = layer.mergeIn(['backsplash'], newBack);
1601
+ layer = layer.set('backsplashApplied', flag);
1602
+ state = state.merge({
1603
+ scene: scene.mergeIn(['layers', layerID], layer)
1604
+ });
1605
+ return {
1606
+ updatedState: state
1607
+ };
1608
+ }
1609
+ }, {
1610
+ key: "setMolding",
1611
+ value: function setMolding(state, molding, isAll) {
1612
+ var _state17 = state,
1613
+ scene = _state17.scene;
1614
+ var layerID = scene.get('selectedLayer');
1615
+ var layer = scene.layers.get(layerID);
1616
+ if (isAll) {
1617
+ var tempLayerMolding = layer.molding;
1618
+ var flag = tempLayerMolding.some(function (mol) {
1619
+ return mol.name === molding.name;
1620
+ });
1621
+ if (flag) {
1622
+ tempLayerMolding = tempLayerMolding.filter(function (mol) {
1623
+ return mol.name !== molding.name;
1624
+ });
1625
+ } else {
1626
+ if (tempLayerMolding.some(function (mol) {
1627
+ return mol.molding_type === molding.molding_type && mol.location_type === molding.location_type;
1628
+ })) {
1629
+ tempLayerMolding = tempLayerMolding.filter(function (mol) {
1630
+ return mol.molding_type !== molding.molding_type || mol.location_type !== molding.location_type;
1631
+ });
1632
+ }
1633
+ tempLayerMolding = tempLayerMolding.concat(molding);
1634
+ }
1635
+ layer = layer.set('molding', tempLayerMolding);
1636
+ state = state.merge({
1637
+ scene: scene.mergeIn(['layers', layerID], layer)
1638
+ });
1639
+ layer.items.toArray().forEach(function (item) {
1640
+ if (_export2.MoldingUtils.isEnableItemForMolding(layer, item, molding)) {
1641
+ var tempItemMolding = item.molding;
1642
+ if (flag) {
1643
+ if (tempItemMolding.some(function (mol) {
1644
+ return mol.name === molding.name;
1645
+ })) {
1646
+ tempItemMolding = tempItemMolding.filter(function (mol) {
1647
+ return mol.name !== molding.name;
1648
+ });
1649
+ }
1650
+ } else {
1651
+ if (tempItemMolding.some(function (mol) {
1652
+ return mol.molding_type === molding.molding_type && mol.location_type === molding.location_type;
1653
+ })) {
1654
+ tempItemMolding = tempItemMolding.filter(function (mol) {
1655
+ return mol.molding_type !== molding.molding_type || mol.location_type !== molding.location_type;
1656
+ });
1657
+ }
1658
+ tempItemMolding = tempItemMolding.concat(molding);
1659
+ }
1660
+ state = state.setIn(['scene', 'layers', layerID, 'items', item.id, 'molding'], tempItemMolding);
1661
+ }
1662
+ });
1663
+ } else {
1664
+ var selectedItem = layer.getIn(['items', layer.selected.toJS().items[0]]);
1665
+ if (_export2.MoldingUtils.isEnableItemForMolding(layer, selectedItem, molding)) {
1666
+ var moldingGroup = _export2.MoldingUtils.getItemGroupFromMolding(layer, selectedItem, molding);
1667
+ var tempSelItemMolding = selectedItem.molding;
1668
+ var _flag = tempSelItemMolding.some(function (mol) {
1669
+ return mol.name === molding.name;
1670
+ });
1671
+ moldingGroup.forEach(function (item) {
1672
+ var tempItemMolding = item.molding;
1673
+ if (_flag) {
1674
+ if (tempItemMolding.some(function (mol) {
1675
+ return mol.name === molding.name;
1676
+ })) {
1677
+ tempItemMolding = tempItemMolding.filter(function (mol) {
1678
+ return mol.name !== molding.name;
1679
+ });
1680
+ }
1681
+ } else {
1682
+ if (tempItemMolding.some(function (mol) {
1683
+ return mol.molding_type === molding.molding_type && mol.location_type === molding.location_type;
1684
+ })) {
1685
+ tempItemMolding = tempItemMolding.filter(function (mol) {
1686
+ return mol.molding_type !== molding.molding_type || mol.location_type !== molding.location_type;
1687
+ });
1688
+ }
1689
+ tempItemMolding = tempItemMolding.concat(molding);
1690
+ }
1691
+ state = state.setIn(['scene', 'layers', layerID, 'items', item.id, 'molding'], tempItemMolding);
1692
+ });
1693
+ }
1694
+ }
1695
+ state = state.merge({
1696
+ sceneHistory: (0, _history.historyPush)(state.sceneHistory, state.scene)
1697
+ });
1698
+ return {
1699
+ updatedState: state
1700
+ };
1701
+ }
1702
+ }, {
1703
+ key: "updateMolding",
1704
+ value: function updateMolding(state) {
1705
+ var _state18 = state,
1706
+ scene = _state18.scene;
1707
+ var layerID = scene.get('selectedLayer');
1708
+ var layer = scene.layers.get(layerID);
1709
+ var selectedItem = layer.getIn(['items', layer.selected.toJS().items[0]]);
1710
+ var snappedItemGroup = []; // The array that include snapped items with selected item.
1711
+ if (!!selectedItem && selectedItem.category === 'cabinet') {
1712
+ var itemGroups = [];
1713
+ layer.items.toArray().forEach(function (curItem) {
1714
+ if (selectedItem.id !== curItem.id && curItem.category === 'cabinet') {
1715
+ if (_export2.MoldingUtils.isItemSnappedItem(selectedItem, curItem)) {
1716
+ snappedItemGroup.push(curItem); // add the snapped item.
1717
+ // add the snapped item that has same molding location type, layoutpos and height to itemGroups.
1718
+ if (curItem.molding.length) {
1719
+ curItem.molding.forEach(function (md) {
1720
+ // This code check whether the curItem can be grouped with selected Item in molding.
1721
+ if (_export2.MoldingUtils.tryMergeMDItem(layer, selectedItem, curItem, [selectedItem], md)) {
1722
+ itemGroups.push({
1723
+ base_item: curItem,
1724
+ group: _export2.MoldingUtils.getItemGroupFromMolding(layer, curItem, md),
1725
+ molding: md
1726
+ });
1727
+ }
1728
+ });
1729
+ }
1730
+ }
1731
+ }
1732
+ });
1733
+ var updateSelectItemMolding = function updateSelectItemMolding() {
1734
+ var _loop = function _loop() {
1735
+ // check whether snapped item is same as selected item in layoutpos(Wall, Tall, Base)
1736
+ if (_export2.MoldingUtils.isSameMoldingLayoutpos(selectedItem, snappedItemGroup[i])) {
1737
+ // check whether snapped item is same in location(same location type and height).
1738
+ var delMoldings = [];
1739
+ for (var k = 0; k < selectedItem.molding.length; k++) {
1740
+ if (_export2.MoldingUtils.isItemSameItemByLocation(selectedItem, snappedItemGroup[i], selectedItem.molding[k].location_type)) {
1741
+ delMoldings.push(selectedItem.molding[k].itemID);
1742
+ }
1743
+ }
1744
+ var resultMol = [];
1745
+ selectedItem.molding.forEach(function (mol) {
1746
+ if (!delMoldings.some(function (id) {
1747
+ return id === mol.itemID;
1748
+ })) {
1749
+ resultMol.push(mol);
1750
+ }
1751
+ });
1752
+ state = state.setIn(['scene', 'layers', layerID, 'items', selectedItem.id, 'molding'], resultMol);
1753
+ }
1754
+ };
1755
+ for (var i = 0; i < snappedItemGroup.length; i++) {
1756
+ _loop();
1757
+ }
1758
+ };
1759
+ var emptyMoldingArray = function emptyMoldingArray() {
1760
+ var temp_items = [selectedItem];
1761
+ var groupMoldings = [];
1762
+ itemGroups.forEach(function (itGroup) {
1763
+ groupMoldings.push(itGroup.molding);
1764
+ itGroup.group.forEach(function (it) {
1765
+ if (!temp_items.some(function (i) {
1766
+ return i.id === it.id;
1767
+ })) {
1768
+ temp_items.push(it);
1769
+ }
1770
+ });
1771
+ });
1772
+ temp_items.forEach(function (item) {
1773
+ var finalMoldings = [];
1774
+ var tempMoldings = state.getIn(['scene', 'layers', layerID, 'items', item.id, 'molding']);
1775
+ tempMoldings.forEach(function (molding) {
1776
+ if (!groupMoldings.some(function (ml) {
1777
+ return ml.itemID === molding.itemID;
1778
+ })) {
1779
+ finalMoldings.push(molding);
1780
+ }
1781
+ });
1782
+ state = state.setIn(['scene', 'layers', layerID, 'items', item.id, 'molding'], finalMoldings);
1783
+ });
1784
+ updateSelectItemMolding();
1785
+ };
1786
+ var setLocationMolding = function setLocationMolding(location) {
1787
+ var locationMolding = itemGroups.filter(function (it) {
1788
+ return it.molding.location_type === location;
1789
+ }).sort(function (a, b) {
1790
+ if (a.group.length === b.group.length) {
1791
+ return _export2.GeometryUtils.pointsDistance(a.base_item.x, a.base_item.y, selectedItem.x, selectedItem.y) - _export2.GeometryUtils.pointsDistance(b.base_item.x, b.base_item.y, selectedItem.x, selectedItem.y);
1792
+ } else {
1793
+ return a.group.length - b.group.length;
1794
+ }
1795
+ });
1796
+ if (locationMolding.length) {
1797
+ var locationMoldingItems = _export2.MoldingUtils.getItemGroupFromMolding(layer, selectedItem, locationMolding[0].molding);
1798
+ locationMoldingItems.forEach(function (item) {
1799
+ var tempMoldings = state.getIn(['scene', 'layers', layerID, 'items', item.id, 'molding']);
1800
+ if (!tempMoldings.some(function (mol) {
1801
+ return mol.itemID === locationMolding[0].molding.itemID;
1802
+ })) tempMoldings.push(locationMolding[0].molding);
1803
+ state = state.setIn(['scene', 'layers', layerID, 'items', item.id, 'molding'], tempMoldings);
1804
+ });
1805
+ }
1806
+ };
1807
+ if (itemGroups.length && layer.items.some(function (it) {
1808
+ return _export2.MoldingUtils.isItemSnappedItem(selectedItem, it) && it.category === 'cabinet';
1809
+ })) {
1810
+ emptyMoldingArray();
1811
+ for (var i = 0; i < _constants.MOLDING_LOCATIONS.length; i++) {
1812
+ setLocationMolding(_constants.MOLDING_LOCATIONS[i]);
1813
+ }
1814
+ } else if (!itemGroups.length && selectedItem.molding.length) {
1815
+ // Delete the selected Item's molding property if selItem attached the group that has no molding.
1816
+ // If snapped items have no moldings and one item's property is same as selected Item, selected Item's molding should be deleted.
1817
+ updateSelectItemMolding();
1818
+ }
1819
+ }
1820
+ state = state.merge({
1821
+ sceneHistory: (0, _history.historyPush)(state.sceneHistory, state.scene)
1822
+ });
1823
+ return {
1824
+ updatedState: state
1825
+ };
1826
+ }
1827
+ }, {
1828
+ key: "setBacksplashVisible",
1829
+ value: function setBacksplashVisible(state, itemID, backsplashVisible) {
1830
+ var _state19 = state,
1831
+ scene = _state19.scene;
1832
+ var layerID = scene.get('selectedLayer');
1833
+ var layer = scene.layers.get(layerID);
1834
+ layer = layer.mergeIn(['items', itemID, 'backsplashVisible'], backsplashVisible);
1835
+ // let cabinet_category = layer.getIn(["items"], itemID).toJS()[itemID].cabinet_category;
1836
+ // if (cabinet_category && (cabinet_category.search("Sink") !== -1 || cabinet_category.search("End/Angle") !== -1)) {
1837
+ // layer = layer.mergeIn(["items", itemID, "backsplashVisible"], true);
1838
+ // } else {
1839
+ // layer = layer.mergeIn(["items", itemID, "backsplashVisible"], false);
1840
+ // }
1841
+ state = state.merge({
1842
+ scene: scene.mergeIn(['layers', layerID], layer)
1843
+ });
1844
+ return {
1845
+ updatedState: state
1846
+ };
1847
+ }
1848
+ }, {
1849
+ key: "setApplianceMaterial",
1850
+ value: function setApplianceMaterial(state, material) {
1851
+ var _state20 = state,
1852
+ scene = _state20.scene;
1853
+ var layerID = scene.get('selectedLayer');
1854
+ var layers = scene.layers.get(layerID);
1855
+ var items = layers.items;
1856
+ items.forEach(function (data) {
1857
+ var dataJSON = data.toJS();
1858
+ var itemID = dataJSON.id;
1859
+ var newMaterial = {
1860
+ metalness: material.metalness,
1861
+ roughness: material.roughness
1862
+ };
1863
+ data = data.mergeIn(['applianceMaterial'], newMaterial);
1864
+ layers = layers.mergeIn(['items', itemID], data);
1865
+ state = state.merge({
1866
+ scene: scene.mergeIn(['layers', layerID], layers)
1867
+ });
1868
+ });
1869
+ return {
1870
+ updatedState: state
1871
+ };
1872
+ }
1873
+ }, {
1874
+ key: "setModelling",
1875
+ value: function setModelling(state, molding) {
1876
+ var _state21 = state,
1877
+ scene = _state21.scene;
1878
+ var layerID = scene.get('selectedLayer');
1879
+ var layers = scene.layers.get(layerID);
1880
+ var items = layers.items;
1881
+ items.forEach(function (data) {
1882
+ var dataJSON = data.toJS();
1883
+ var itemID = dataJSON.id;
1884
+ });
1885
+ state = state.merge({
1886
+ scene: scene.mergeIn(['layers', layerID], layers)
1887
+ });
1888
+ return {
1889
+ updatedState: state
1890
+ };
1891
+ }
1892
+ }, {
1893
+ key: "updateItemsAltitude",
1894
+ value: function updateItemsAltitude(state, layerID, itemID, value) {
1895
+ var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
1896
+ var properties = item.get('properties');
1897
+ var altitude = properties.get('altitude');
1898
+ var length = altitude.get('length');
1899
+ var _length = altitude.get('_length');
1900
+ var _unit = altitude.get('_unit');
1901
+ length = length - value;
1902
+ switch (_unit) {
1903
+ case 'mm':
1904
+ _length = length * 10;
1905
+ break;
1906
+ case 'm':
1907
+ _length = length * 0.01;
1908
+ break;
1909
+ default:
1910
+ _length = length;
1911
+ }
1912
+ if (length <= 0) {
1913
+ length = 0;
1914
+ _length = 0;
1915
+ }
1916
+ state = state.mergeIn(['scene', 'layers', layerID, 'items', itemID, 'properties', 'altitude'], new _immutable.Map({
1917
+ length: length,
1918
+ _length: _length,
1919
+ _unit: _unit
1920
+ }));
1921
+ return {
1922
+ updatedState: state
1923
+ };
1924
+ }
1925
+ }, {
1926
+ key: "createHole",
1927
+ value: function createHole(state, layerID, type, lineID, offset, properties) {
1928
+ var holeID = _export2.IDBroker.acquireID();
1929
+ var hole = state.catalog.factoryElement(type, {
1930
+ id: holeID,
1931
+ url: state.catalog.getIn(['elements', type, 'info', 'url']),
1932
+ type: type,
1933
+ offset: offset,
1934
+ line: lineID
1935
+ }, properties);
1936
+ state = state.setIn(['scene', 'layers', layerID, 'holes', holeID], hole);
1937
+ state = state.updateIn(['scene', 'layers', layerID, 'lines', lineID, 'holes'], function (holes) {
1938
+ return holes && holes.push(holeID);
1939
+ });
1940
+ // get vertex order/////
1941
+ var element = state.scene.layers.getIn([layerID, 'lines', lineID]);
1942
+ var layer = state.getIn(['scene', 'layers', layerID]);
1943
+ var vetName0 = element.vertices.get(0);
1944
+ var vetName1 = element.vertices.get(1);
1945
+ var verticesArray = [];
1946
+ layer.areas.forEach(function (data) {
1947
+ verticesArray.push(data.vertices.toJS());
1948
+ });
1949
+ for (var i = 0; i < verticesArray.length; i++) {
1950
+ var vertices = verticesArray[i];
1951
+ if (vertices.includes(vetName0) && vertices.includes(vetName1)) {
1952
+ var index0 = vertices.indexOf(vetName0);
1953
+ var index1 = vertices.indexOf(vetName1);
1954
+ // if vertex order chanege//
1955
+ if (index1 + 1 == index0) {
1956
+ return {
1957
+ updatedState: state,
1958
+ hole: hole
1959
+ };
1960
+ }
1961
+ if (index0 == 0 && index1 == vertices.length - 1) {
1962
+ return {
1963
+ updatedState: state,
1964
+ hole: hole
1965
+ };
1966
+ }
1967
+ // ////////////////////////
1968
+ }
1969
+ }
1970
+ // ///////////////////////////
1971
+ properties = hole.properties.toJS();
1972
+ if (properties.hasOwnProperty('flip_orizzontal')) {
1973
+ properties['flip_orizzontal'] = true;
1974
+ }
1975
+ if (properties.hasOwnProperty('flip_horizontal')) {
1976
+ properties['flip_horizontal'] = true;
1977
+ }
1978
+ state = _export.Hole.setJsProperties(state, layerID, holeID, properties).updatedState;
1979
+ return {
1980
+ updatedState: state,
1981
+ hole: hole
1982
+ };
1983
+ }
1984
+ }, {
1985
+ key: "toggleLoadingCabinet",
1986
+ value: function toggleLoadingCabinet(state) {
1987
+ var _state22 = state,
1988
+ scene = _state22.scene;
1989
+ console.log('scene.isLoadingCabinet: ', !scene.isLoadingCabinet);
1990
+ // scene = scene.set('isLoadingCabinet', !scene.isLoadingCabinet);
1991
+ // state = state.set('scene', scene);
1992
+ state = state.setIn(['scene', 'isLoadingCabinet'], !scene.isLoadingCabinet);
1993
+ return {
1994
+ updatedState: state
1995
+ };
1996
+ }
1997
+ }, {
1998
+ key: "endLoading",
1999
+ value: function endLoading(state) {
2000
+ var _state23 = state,
2001
+ scene = _state23.scene;
2002
+ state = state.setIn(['scene', 'loadFlag'], true);
2003
+ return {
2004
+ updatedState: state
2005
+ };
2006
+ }
2007
+ }]);
2008
+ }();
2009
+ module.exports = exports.default;