kitchen-simulator 7.0.9-react-18 → 10.0.0-unique-id

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