kitchen-simulator 7.0.10-react-18 → 10.0.0

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