kitchen-simulator 11.0.0-react.18 → 11.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (707) hide show
  1. package/es/AppContext.js +1 -4
  2. package/es/LiteKitchenConfigurator.js +67 -23
  3. package/es/LiteRenderer.js +15 -64
  4. package/es/actions/export.js +25 -12
  5. package/es/actions/items-actions.js +18 -2
  6. package/es/analytics/ga4.js +188 -0
  7. package/es/analytics/posthog.js +60 -0
  8. package/es/assets/Window.hdr +2100 -0
  9. package/es/assets/img/default/maple.jpg +0 -0
  10. package/es/assets/img/default/steel.jpg +0 -0
  11. package/es/assets/img/loading/loading.gif +0 -0
  12. package/es/catalog/cabinet/cabinet-assembly-order.js +36 -0
  13. package/es/catalog/catalog.js +0 -2
  14. package/es/catalog/factories/area-factory-3d.js +1 -5
  15. package/es/catalog/factories/wall-factory.js +1 -1
  16. package/es/catalog/holes/door-double/door_double.png +0 -0
  17. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  18. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  19. package/es/catalog/holes/gate/gate.jpg +0 -0
  20. package/es/catalog/holes/window-clear/texture.png +0 -0
  21. package/es/catalog/holes/window-cross/texture.png +0 -0
  22. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  23. package/es/catalog/holes/window-vertical/texture.png +0 -0
  24. package/es/catalog/utils/exporter.js +4 -0
  25. package/es/catalog/utils/item-loader.js +12 -25
  26. package/es/class/area.js +0 -1
  27. package/es/class/export.js +1 -3
  28. package/es/class/item.js +207 -89
  29. package/es/class/line.js +1 -3
  30. package/es/class/project.js +15 -19
  31. package/es/components/content.js +20 -6
  32. package/es/components/export.js +3 -5
  33. package/es/components/style/export.js +2 -28
  34. package/es/components/style/form-number-input.js +34 -43
  35. package/es/components/viewer2d/group.js +12 -7
  36. package/es/components/viewer2d/item.js +159 -168
  37. package/es/components/viewer2d/line.js +18 -51
  38. package/es/components/viewer2d/rulerX.js +3 -0
  39. package/es/components/viewer2d/rulerY.js +3 -0
  40. package/es/components/viewer2d/scene.js +67 -47
  41. package/es/components/viewer2d/state.js +1 -1
  42. package/es/components/viewer2d/utils.js +0 -6
  43. package/es/components/viewer2d/viewer2d.js +566 -508
  44. package/es/components/viewer3d/front3D.js +1 -2
  45. package/es/components/viewer3d/pointer-lock-navigation.js +0 -90
  46. package/es/components/viewer3d/ruler-utils/layer3D.js +2 -2
  47. package/es/components/viewer3d/scene-creator.js +113 -120
  48. package/es/components/viewer3d/three-memory-cleaner.js +0 -14
  49. package/es/components/viewer3d/viewer3d-first-person.js +132 -134
  50. package/es/components/viewer3d/viewer3d.js +40 -28
  51. package/es/constants/catalog/skinPanel.js +9 -0
  52. package/es/constants.js +19 -8
  53. package/es/{WorkSpaceOriginal.js → devLiteRenderer.js} +241 -173
  54. package/es/events/external/handleExternalEvent.js +141 -0
  55. package/es/events/external/handleExternalEvent.util.js +1099 -0
  56. package/es/events/external/handlers.addItem.js +47 -0
  57. package/es/events/external/handlers.changeDoorStyle.js +140 -0
  58. package/es/events/external/handlers.elementOps.js +8 -0
  59. package/es/events/external/handlers.finishing.js +26 -0
  60. package/es/events/external/handlers.hole.js +4 -0
  61. package/es/events/external/handlers.loadProject.js +128 -0
  62. package/es/events/external/handlers.molding.js +24 -0
  63. package/es/events/external/handlers.projectLifecycle.js +11 -0
  64. package/es/events/external/handlers.projectSettings.js +32 -0
  65. package/es/events/external/handlers.replaceCabinet.js +41 -0
  66. package/es/events/external/handlers.roomShape.js +8 -0
  67. package/es/events/external/handlers.syncScene.js +21 -0
  68. package/es/events/external/handlers.updateSelectedElements.js +11 -0
  69. package/es/events/external/handlers.viewMode.js +11 -0
  70. package/es/events/external/handlers.viewerNavigation.js +108 -0
  71. package/es/events/external/handlers.wall.js +7 -0
  72. package/es/index.js +36 -76
  73. package/es/mappings/external-events/mapExternalEventPayload.js +28 -0
  74. package/es/mappings/external-events/mappers/addItemMapper.js +97 -0
  75. package/es/mappings/external-events/mappers/ccdfMapper.js +100 -0
  76. package/es/mappings/external-events/mappers/ccdfToCDSMapper.js +49 -0
  77. package/es/mappings/external-events/mappers/changeDoorStyleMapper.js +37 -0
  78. package/es/mappings/external-events/mappers/loadProjectMapper.js +62 -0
  79. package/es/mappings/holesToCatalog.js +139 -0
  80. package/es/models.js +16 -1
  81. package/es/plugins/keyboard.js +1 -1
  82. package/es/reducers/export.js +2 -4
  83. package/es/reducers/items-reducer.js +4 -2
  84. package/es/reducers/project-reducer.js +1 -1
  85. package/es/reducers/reducer.js +2 -3
  86. package/es/reducers/viewer2d-reducer.js +0 -2
  87. package/es/shared/domain/cabinet-warning.js +15 -0
  88. package/es/shared/objects/immutable.js +3 -0
  89. package/es/utils/geometry.js +418 -95
  90. package/es/utils/helper.js +41 -35
  91. package/es/utils/history.js +2 -2
  92. package/es/utils/molding.js +12 -241
  93. package/es/utils/name-generator.js +0 -3
  94. package/es/utils/skinPanelEngine.js +522 -0
  95. package/lib/@history.js +11 -0
  96. package/lib/AppContext.js +11 -0
  97. package/lib/LiteKitchenConfigurator.js +527 -0
  98. package/lib/LiteRenderer.js +323 -0
  99. package/lib/actions/area-actions.js +21 -0
  100. package/lib/actions/export.js +36 -0
  101. package/lib/actions/groups-actions.js +107 -0
  102. package/lib/actions/holes-actions.js +140 -0
  103. package/lib/actions/items-actions.js +383 -0
  104. package/lib/actions/lines-actions.js +98 -0
  105. package/lib/actions/project-actions.js +351 -0
  106. package/lib/actions/scene-actions.js +43 -0
  107. package/lib/actions/vertices-actions.js +35 -0
  108. package/lib/actions/viewer2d-actions.js +73 -0
  109. package/lib/actions/viewer3d-actions.js +32 -0
  110. package/lib/analytics/ga4.js +194 -0
  111. package/lib/analytics/posthog.js +68 -0
  112. package/lib/assets/Window.hdr +2100 -0
  113. package/lib/assets/brown_photostudio_02_1k.hdr +0 -0
  114. package/lib/assets/fonts/Rene Bieder Milliard Black Italic.woff +0 -0
  115. package/lib/assets/fonts/Rene Bieder Milliard Black.woff +0 -0
  116. package/lib/assets/fonts/Rene Bieder Milliard Bold Italic.woff +0 -0
  117. package/lib/assets/fonts/Rene Bieder Milliard Bold.woff +0 -0
  118. package/lib/assets/fonts/Rene Bieder Milliard Book Italic.woff +0 -0
  119. package/lib/assets/fonts/Rene Bieder Milliard Book.woff +0 -0
  120. package/lib/assets/fonts/Rene Bieder Milliard ExtraBold Italic.woff +0 -0
  121. package/lib/assets/fonts/Rene Bieder Milliard ExtraBold.woff +0 -0
  122. package/lib/assets/fonts/Rene Bieder Milliard ExtraLight Italic.woff +0 -0
  123. package/lib/assets/fonts/Rene Bieder Milliard ExtraLight.woff +0 -0
  124. package/lib/assets/fonts/Rene Bieder Milliard Hairline Italic.woff +0 -0
  125. package/lib/assets/fonts/Rene Bieder Milliard Hairline.woff +0 -0
  126. package/lib/assets/fonts/Rene Bieder Milliard Heavy Italic.woff +0 -0
  127. package/lib/assets/fonts/Rene Bieder Milliard Heavy.woff +0 -0
  128. package/lib/assets/fonts/Rene Bieder Milliard Light Italic.woff +0 -0
  129. package/lib/assets/fonts/Rene Bieder Milliard Light.woff +0 -0
  130. package/lib/assets/fonts/Rene Bieder Milliard Medium Italic.woff +0 -0
  131. package/lib/assets/fonts/Rene Bieder Milliard Medium.woff +0 -0
  132. package/lib/assets/fonts/Rene Bieder Milliard SemiBold Italic.woff +0 -0
  133. package/lib/assets/fonts/Rene Bieder Milliard SemiBold.woff +0 -0
  134. package/lib/assets/fonts/Rene Bieder Milliard Thin Italic.woff +0 -0
  135. package/lib/assets/fonts/Rene Bieder Milliard Thin.woff +0 -0
  136. package/lib/assets/fonts/style.css +177 -0
  137. package/lib/assets/gltf/door_closet.gltf +1 -0
  138. package/lib/assets/gltf/door_exterior.gltf +1 -0
  139. package/lib/assets/gltf/door_interior.gltf +1 -0
  140. package/lib/assets/gltf/door_sliding.gltf +1 -0
  141. package/lib/assets/gltf/doorway_framed.bin +0 -0
  142. package/lib/assets/gltf/doorway_framed.fbx +0 -0
  143. package/lib/assets/gltf/doorway_framed.gltf +1 -0
  144. package/lib/assets/gltf/window_clear.bin +0 -0
  145. package/lib/assets/gltf/window_clear.fbx +0 -0
  146. package/lib/assets/gltf/window_clear.gltf +1 -0
  147. package/lib/assets/gltf/window_cross.bin +0 -0
  148. package/lib/assets/gltf/window_cross.fbx +0 -0
  149. package/lib/assets/gltf/window_cross.gltf +1 -0
  150. package/lib/assets/gltf/window_double_hung.bin +0 -0
  151. package/lib/assets/gltf/window_double_hung.fbx +0 -0
  152. package/lib/assets/gltf/window_double_hung.gltf +1 -0
  153. package/lib/assets/gltf/window_vertical.bin +0 -0
  154. package/lib/assets/gltf/window_vertical.fbx +0 -0
  155. package/lib/assets/gltf/window_vertical.gltf +1 -0
  156. package/lib/assets/img/TKC_thumbnail.png +0 -0
  157. package/lib/assets/img/Toggle.png +0 -0
  158. package/lib/assets/img/default/maple.jpg +0 -0
  159. package/lib/assets/img/default/steel.jpg +0 -0
  160. package/lib/assets/img/loading/loading.gif +0 -0
  161. package/lib/assets/img/loading/loading_1.svg +11 -0
  162. package/lib/assets/img/loading_large.gif +0 -0
  163. package/lib/assets/img/png/door/closet.png +0 -0
  164. package/lib/assets/img/png/door/doorwaysframed.png +0 -0
  165. package/lib/assets/img/png/door/doorwaysframeles.png +0 -0
  166. package/lib/assets/img/png/door/doorwaysframeless.png +0 -0
  167. package/lib/assets/img/png/door/exterior.png +0 -0
  168. package/lib/assets/img/png/door/interior.png +0 -0
  169. package/lib/assets/img/png/door/sliding.png +0 -0
  170. package/lib/assets/img/png/helper/outcome.png +0 -0
  171. package/lib/assets/img/project_img.png +0 -0
  172. package/lib/assets/img/rta/rta_logo_box_blue.jpg +0 -0
  173. package/lib/assets/img/rta/rta_logo_box_blue_ico.jpg +0 -0
  174. package/lib/assets/img/rta/rta_logo_box_blue_ico.svg +55 -0
  175. package/lib/assets/img/rta/rta_logo_box_darkGray.jpg +0 -0
  176. package/lib/assets/img/rta/rta_logo_box_lightblue.png +0 -0
  177. package/lib/assets/img/rta/rta_logo_box_lightmaroon.png +0 -0
  178. package/lib/assets/img/rta/rta_logo_box_maroon.png +0 -0
  179. package/lib/assets/img/rta/rta_logo_box_white.png +0 -0
  180. package/lib/assets/img/rta_menu.png +0 -0
  181. package/lib/assets/img/step2.jpg +0 -0
  182. package/lib/assets/img/step3.jpg +0 -0
  183. package/lib/assets/img/step4.jpg +0 -0
  184. package/lib/assets/img/step5.jpg +0 -0
  185. package/lib/assets/img/step6.jpg +0 -0
  186. package/lib/assets/img/step7.jpg +0 -0
  187. package/lib/assets/img/step8.jpg +0 -0
  188. package/lib/assets/img/svg/2d_delete_object.svg +33 -0
  189. package/lib/assets/img/svg/2d_delete_object1.svg +33 -0
  190. package/lib/assets/img/svg/2d_lock_object.svg +33 -0
  191. package/lib/assets/img/svg/3d_item_move.svg +106 -0
  192. package/lib/assets/img/svg/3d_item_rotation.svg +76 -0
  193. package/lib/assets/img/svg/3d_item_warning_edit.svg +77 -0
  194. package/lib/assets/img/svg/3d_item_warning_info.svg +81 -0
  195. package/lib/assets/img/svg/accessories.svg +4 -0
  196. package/lib/assets/img/svg/angle_icon.svg +39 -0
  197. package/lib/assets/img/svg/blank_div.svg +14 -0
  198. package/lib/assets/img/svg/bottombar/2d3d_button.svg +3 -0
  199. package/lib/assets/img/svg/bottombar/2d3d_button_active.svg +3 -0
  200. package/lib/assets/img/svg/bottombar/2d3d_toggle.svg +4 -0
  201. package/lib/assets/img/svg/bottombar/2d3d_toggle_active.svg +4 -0
  202. package/lib/assets/img/svg/bottombar/arrow-down.svg +3 -0
  203. package/lib/assets/img/svg/bottombar/arrow-left.svg +3 -0
  204. package/lib/assets/img/svg/bottombar/arrow-minus.svg +3 -0
  205. package/lib/assets/img/svg/bottombar/arrow-plus.svg +11 -0
  206. package/lib/assets/img/svg/bottombar/arrow-right.svg +3 -0
  207. package/lib/assets/img/svg/bottombar/arrow-up.svg +3 -0
  208. package/lib/assets/img/svg/bottombar/collapse.svg +3 -0
  209. package/lib/assets/img/svg/bottombar/elevation-back.svg +6 -0
  210. package/lib/assets/img/svg/bottombar/elevation-front.svg +6 -0
  211. package/lib/assets/img/svg/bottombar/elevation-left.svg +6 -0
  212. package/lib/assets/img/svg/bottombar/elevation-right.svg +7 -0
  213. package/lib/assets/img/svg/bottombar/elevation.svg +13 -0
  214. package/lib/assets/img/svg/bottombar/expand.svg +3 -0
  215. package/lib/assets/img/svg/bottombar/help.svg +72 -0
  216. package/lib/assets/img/svg/bottombar/incm_toggle.svg +39 -0
  217. package/lib/assets/img/svg/bottombar/pan_1.svg +57 -0
  218. package/lib/assets/img/svg/bottombar/pan_2.svg +27 -0
  219. package/lib/assets/img/svg/bottombar/pan_3.svg +27 -0
  220. package/lib/assets/img/svg/bottombar/pan_4.svg +27 -0
  221. package/lib/assets/img/svg/bottombar/pan_5.svg +27 -0
  222. package/lib/assets/img/svg/bottombar/settings.svg +23 -0
  223. package/lib/assets/img/svg/bottombar/spin-down.svg +76 -0
  224. package/lib/assets/img/svg/bottombar/spin-left.svg +75 -0
  225. package/lib/assets/img/svg/bottombar/spin-right.svg +75 -0
  226. package/lib/assets/img/svg/bottombar/spin-up.svg +76 -0
  227. package/lib/assets/img/svg/bottombar/spin_1.svg +48 -0
  228. package/lib/assets/img/svg/bottombar/spin_2.svg +31 -0
  229. package/lib/assets/img/svg/bottombar/spin_3.svg +31 -0
  230. package/lib/assets/img/svg/bottombar/spin_4.svg +31 -0
  231. package/lib/assets/img/svg/bottombar/spin_5.svg +31 -0
  232. package/lib/assets/img/svg/bottombar/zoomin.svg +29 -0
  233. package/lib/assets/img/svg/bottombar/zoomout.svg +26 -0
  234. package/lib/assets/img/svg/check.svg +10 -0
  235. package/lib/assets/img/svg/close.svg +11 -0
  236. package/lib/assets/img/svg/color/Black.svg +3 -0
  237. package/lib/assets/img/svg/color/Blue.svg +3 -0
  238. package/lib/assets/img/svg/color/Cream.svg +3 -0
  239. package/lib/assets/img/svg/color/Gray.svg +3 -0
  240. package/lib/assets/img/svg/color/Green.svg +3 -0
  241. package/lib/assets/img/svg/color/White.svg +3 -0
  242. package/lib/assets/img/svg/color/White.svg.bak +3 -0
  243. package/lib/assets/img/svg/color/stone2.jpg +0 -0
  244. package/lib/assets/img/svg/color/wood2.jpg +0 -0
  245. package/lib/assets/img/svg/copy.svg +11 -0
  246. package/lib/assets/img/svg/delete.svg +3 -0
  247. package/lib/assets/img/svg/detail.svg +77 -0
  248. package/lib/assets/img/svg/disclaimer/background.svg +758 -0
  249. package/lib/assets/img/svg/disclaimer/logo-dots.svg +11 -0
  250. package/lib/assets/img/svg/door/Closet.svg +11 -0
  251. package/lib/assets/img/svg/door/Exterior.svg +5 -0
  252. package/lib/assets/img/svg/door/Framed_dorway.svg +5 -0
  253. package/lib/assets/img/svg/door/Frameless_dorway.svg +5 -0
  254. package/lib/assets/img/svg/door/Interior.svg +7 -0
  255. package/lib/assets/img/svg/door/Sliding.svg +5 -0
  256. package/lib/assets/img/svg/doors_closet.svg +47 -0
  257. package/lib/assets/img/svg/doors_exterior.svg +25 -0
  258. package/lib/assets/img/svg/doors_interior.svg +29 -0
  259. package/lib/assets/img/svg/doors_patio.svg +26 -0
  260. package/lib/assets/img/svg/duplicate.svg +11 -0
  261. package/lib/assets/img/svg/duplicate_object_left.svg +32 -0
  262. package/lib/assets/img/svg/duplicate_object_right.svg +32 -0
  263. package/lib/assets/img/svg/filtersActive.svg +19 -0
  264. package/lib/assets/img/svg/firstsetting/L.svg +3 -0
  265. package/lib/assets/img/svg/firstsetting/L2.svg +3 -0
  266. package/lib/assets/img/svg/firstsetting/Open.svg +3 -0
  267. package/lib/assets/img/svg/firstsetting/Square.svg +3 -0
  268. package/lib/assets/img/svg/firstsetting/bar-active.svg +9 -0
  269. package/lib/assets/img/svg/firstsetting/bar-normal.svg +3 -0
  270. package/lib/assets/img/svg/firstsetting/bullet-current.svg +3 -0
  271. package/lib/assets/img/svg/firstsetting/bullet-done.svg +3 -0
  272. package/lib/assets/img/svg/firstsetting/bullet-not-done.svg +3 -0
  273. package/lib/assets/img/svg/firstsetting/check-active.svg +3 -0
  274. package/lib/assets/img/svg/firstsetting/check-normal.svg +3 -0
  275. package/lib/assets/img/svg/firstsetting/pencil.svg +11 -0
  276. package/lib/assets/img/svg/green_checkmark.svg +27 -0
  277. package/lib/assets/img/svg/headerbar/assist.svg +3 -0
  278. package/lib/assets/img/svg/headerbar/cart.svg +3 -0
  279. package/lib/assets/img/svg/headerbar/check.svg +10 -0
  280. package/lib/assets/img/svg/headerbar/consult_designer.svg +45 -0
  281. package/lib/assets/img/svg/headerbar/edit_name.svg +26 -0
  282. package/lib/assets/img/svg/headerbar/file-dollar.svg +13 -0
  283. package/lib/assets/img/svg/headerbar/hamburger_menu.svg +32 -0
  284. package/lib/assets/img/svg/headerbar/plus.svg +11 -0
  285. package/lib/assets/img/svg/headerbar/review_quote.svg +44 -0
  286. package/lib/assets/img/svg/headerbar/ruler-measure.svg +11 -0
  287. package/lib/assets/img/svg/headerbar/save.svg +3 -0
  288. package/lib/assets/img/svg/headerbar/setting.svg +75 -0
  289. package/lib/assets/img/svg/help/check.svg +10 -0
  290. package/lib/assets/img/svg/help/search.svg +76 -0
  291. package/lib/assets/img/svg/intro/1-start-with-floorplan-whole.svg +27 -0
  292. package/lib/assets/img/svg/intro/1-start-with-floorplan.svg +26 -0
  293. package/lib/assets/img/svg/intro/2-start-from-scratch-whole.svg +28 -0
  294. package/lib/assets/img/svg/intro/2-start-from-scratch.svg +27 -0
  295. package/lib/assets/img/svg/intro/3-retrieve-project-whole.svg +19 -0
  296. package/lib/assets/img/svg/intro/3-retrieve-project.svg +18 -0
  297. package/lib/assets/img/svg/invert.svg +127 -0
  298. package/lib/assets/img/svg/lefttoolbar/appliance-active.svg +13 -0
  299. package/lib/assets/img/svg/lefttoolbar/appliance.svg +13 -0
  300. package/lib/assets/img/svg/lefttoolbar/cabinet-active.svg +10 -0
  301. package/lib/assets/img/svg/lefttoolbar/cabinet-category.svg +3 -0
  302. package/lib/assets/img/svg/lefttoolbar/cabinet-one.svg +3 -0
  303. package/lib/assets/img/svg/lefttoolbar/cabinet.svg +10 -0
  304. package/lib/assets/img/svg/lefttoolbar/disigner_assistance.svg +89 -0
  305. package/lib/assets/img/svg/lefttoolbar/door-style-active.svg +20 -0
  306. package/lib/assets/img/svg/lefttoolbar/door-style.svg +20 -0
  307. package/lib/assets/img/svg/lefttoolbar/door.svg +12 -0
  308. package/lib/assets/img/svg/lefttoolbar/error_icon.svg +81 -0
  309. package/lib/assets/img/svg/lefttoolbar/finishing-active.svg +13 -0
  310. package/lib/assets/img/svg/lefttoolbar/finishing.svg +13 -0
  311. package/lib/assets/img/svg/lefttoolbar/reviewforquote-active.svg +86 -0
  312. package/lib/assets/img/svg/lefttoolbar/reviewforquote.svg +12 -0
  313. package/lib/assets/img/svg/lefttoolbar/room-shape-L.svg +3 -0
  314. package/lib/assets/img/svg/lefttoolbar/room-shape-active.svg +18 -0
  315. package/lib/assets/img/svg/lefttoolbar/room-shape-custom.svg +12 -0
  316. package/lib/assets/img/svg/lefttoolbar/room-shape-irregular.svg +3 -0
  317. package/lib/assets/img/svg/lefttoolbar/room-shape-open.svg +3 -0
  318. package/lib/assets/img/svg/lefttoolbar/room-shape-square.svg +3 -0
  319. package/lib/assets/img/svg/lefttoolbar/room-shape.svg +18 -0
  320. package/lib/assets/img/svg/lefttoolbar/search.svg +76 -0
  321. package/lib/assets/img/svg/lefttoolbar/view_more.svg +86 -0
  322. package/lib/assets/img/svg/lefttoolbar/warning_icon.svg +81 -0
  323. package/lib/assets/img/svg/lefttoolbar/window.svg +12 -0
  324. package/lib/assets/img/svg/logo.svg +11 -0
  325. package/lib/assets/img/svg/logo_with_text.svg +25 -0
  326. package/lib/assets/img/svg/menubar/login.svg +84 -0
  327. package/lib/assets/img/svg/menubar/my_projects.svg +85 -0
  328. package/lib/assets/img/svg/menubar/new_project.svg +110 -0
  329. package/lib/assets/img/svg/menubar/save_project.svg +84 -0
  330. package/lib/assets/img/svg/options.svg +3 -0
  331. package/lib/assets/img/svg/positioning.svg +3 -0
  332. package/lib/assets/img/svg/rotate.png +0 -0
  333. package/lib/assets/img/svg/rotate.svg +17 -0
  334. package/lib/assets/img/svg/rotate_object_clockwise.svg +26 -0
  335. package/lib/assets/img/svg/rotate_object_counterclockwise.svg +26 -0
  336. package/lib/assets/img/svg/toggleFilters.svg +19 -0
  337. package/lib/assets/img/svg/toolbar/add_appliances_active.svg +64 -0
  338. package/lib/assets/img/svg/toolbar/add_appliances_inactive.svg +52 -0
  339. package/lib/assets/img/svg/toolbar/add_button.svg +36 -0
  340. package/lib/assets/img/svg/toolbar/add_cabinets_active.svg +59 -0
  341. package/lib/assets/img/svg/toolbar/add_cabinets_inactive.svg +49 -0
  342. package/lib/assets/img/svg/toolbar/add_items_doors.svg +25 -0
  343. package/lib/assets/img/svg/toolbar/add_items_doorways.svg +24 -0
  344. package/lib/assets/img/svg/toolbar/add_items_refrigerator.svg +32 -0
  345. package/lib/assets/img/svg/toolbar/add_items_windows.svg +28 -0
  346. package/lib/assets/img/svg/toolbar/apply_button.svg +38 -0
  347. package/lib/assets/img/svg/toolbar/arrow-plus.svg +11 -0
  348. package/lib/assets/img/svg/toolbar/backsplash.svg +8 -0
  349. package/lib/assets/img/svg/toolbar/cancel_button.svg +37 -0
  350. package/lib/assets/img/svg/toolbar/consult_a_designer_button.svg +47 -0
  351. package/lib/assets/img/svg/toolbar/countertop.svg +7 -0
  352. package/lib/assets/img/svg/toolbar/dcm.png +0 -0
  353. package/lib/assets/img/svg/toolbar/dcm_off.svg +12 -0
  354. package/lib/assets/img/svg/toolbar/dcm_on.svg +474 -0
  355. package/lib/assets/img/svg/toolbar/delete_button.svg +37 -0
  356. package/lib/assets/img/svg/toolbar/download.svg +77 -0
  357. package/lib/assets/img/svg/toolbar/draw_custom_floor.svg +31 -0
  358. package/lib/assets/img/svg/toolbar/edit_button.svg +75 -0
  359. package/lib/assets/img/svg/toolbar/email_quote_button.svg +44 -0
  360. package/lib/assets/img/svg/toolbar/fbm.png +0 -0
  361. package/lib/assets/img/svg/toolbar/finishing_touches_active.svg +54 -0
  362. package/lib/assets/img/svg/toolbar/finishing_touches_inactive.svg +42 -0
  363. package/lib/assets/img/svg/toolbar/floorstyle.svg +9 -0
  364. package/lib/assets/img/svg/toolbar/fmb.png +0 -0
  365. package/lib/assets/img/svg/toolbar/fmb_off.svg +12 -0
  366. package/lib/assets/img/svg/toolbar/fmb_on.svg +489 -0
  367. package/lib/assets/img/svg/toolbar/furnishings_icon.svg +6 -0
  368. package/lib/assets/img/svg/toolbar/get_started_button.svg +41 -0
  369. package/lib/assets/img/svg/toolbar/handles.svg +5 -0
  370. package/lib/assets/img/svg/toolbar/lighting.svg +7 -0
  371. package/lib/assets/img/svg/toolbar/lrm.png +0 -0
  372. package/lib/assets/img/svg/toolbar/lrm_off.svg +12 -0
  373. package/lib/assets/img/svg/toolbar/lrm_on.svg +470 -0
  374. package/lib/assets/img/svg/toolbar/make_floorplan_active.svg +66 -0
  375. package/lib/assets/img/svg/toolbar/make_floorplan_inactive.svg +52 -0
  376. package/lib/assets/img/svg/toolbar/predefined_room_l_shaped.svg +20 -0
  377. package/lib/assets/img/svg/toolbar/predefined_room_layout.svg +20 -0
  378. package/lib/assets/img/svg/toolbar/predefined_room_long_narrow.svg +20 -0
  379. package/lib/assets/img/svg/toolbar/predefined_room_open_l_shape.svg +20 -0
  380. package/lib/assets/img/svg/toolbar/predefined_room_open_pentagon.svg +20 -0
  381. package/lib/assets/img/svg/toolbar/predefined_room_open_rectangle.svg +20 -0
  382. package/lib/assets/img/svg/toolbar/predefined_room_open_rectangle_2.svg +20 -0
  383. package/lib/assets/img/svg/toolbar/predefined_room_pentagon.svg +20 -0
  384. package/lib/assets/img/svg/toolbar/predefined_room_rectangle.svg +20 -0
  385. package/lib/assets/img/svg/toolbar/predefined_room_rectangle_with_alcove.svg +20 -0
  386. package/lib/assets/img/svg/toolbar/redo_button.svg +75 -0
  387. package/lib/assets/img/svg/toolbar/redo_button1.svg +75 -0
  388. package/lib/assets/img/svg/toolbar/review_quote_active.svg +14 -0
  389. package/lib/assets/img/svg/toolbar/review_quote_inactive.svg +44 -0
  390. package/lib/assets/img/svg/toolbar/save_project_button.svg +44 -0
  391. package/lib/assets/img/svg/toolbar/select_doorstyle_active.svg +67 -0
  392. package/lib/assets/img/svg/toolbar/select_doorstyle_inactive.svg +57 -0
  393. package/lib/assets/img/svg/toolbar/shopping-cart.svg +13 -0
  394. package/lib/assets/img/svg/toolbar/style_change_button.svg +47 -0
  395. package/lib/assets/img/svg/toolbar/take_picture.svg +75 -0
  396. package/lib/assets/img/svg/toolbar/undo_button.svg +76 -0
  397. package/lib/assets/img/svg/toolbar/undo_button1.svg +76 -0
  398. package/lib/assets/img/svg/toolbar/use_button.svg +37 -0
  399. package/lib/assets/img/svg/toolbar/wall_color_icon.svg +6 -0
  400. package/lib/assets/img/svg/topbar/edit_active.svg +10 -0
  401. package/lib/assets/img/svg/topbar/edit_inactive.svg +10 -0
  402. package/lib/assets/img/svg/topbar/redo_active.svg +42 -0
  403. package/lib/assets/img/svg/topbar/redo_inactive.svg +23 -0
  404. package/lib/assets/img/svg/topbar/select_all_active.svg +50 -0
  405. package/lib/assets/img/svg/topbar/select_all_inactive.svg +32 -0
  406. package/lib/assets/img/svg/topbar/take_picture_active.svg +51 -0
  407. package/lib/assets/img/svg/topbar/take_picture_inactive.svg +26 -0
  408. package/lib/assets/img/svg/topbar/undo_active.svg +42 -0
  409. package/lib/assets/img/svg/topbar/undo_inactive.svg +23 -0
  410. package/lib/assets/img/svg/warning_info_2d.svg +81 -0
  411. package/lib/assets/img/svg/window/Clear.svg +3 -0
  412. package/lib/assets/img/svg/window/Cross.svg +5 -0
  413. package/lib/assets/img/svg/window/Double_hung.svg +4 -0
  414. package/lib/assets/img/svg/window/Vertical.svg +4 -0
  415. package/lib/assets/img/svg/windows_clear.svg +23 -0
  416. package/lib/assets/img/svg/windows_cross.svg +28 -0
  417. package/lib/assets/img/svg/windows_double_hung.svg +24 -0
  418. package/lib/assets/img/svg/windows_vertical.svg +24 -0
  419. package/lib/assets/img/svg/wizardstep/Custom.svg +3 -0
  420. package/lib/assets/img/svg/wizardstep/Dashed_line.svg +3 -0
  421. package/lib/assets/img/svg/wizardstep/L.svg +3 -0
  422. package/lib/assets/img/svg/wizardstep/L2.svg +3 -0
  423. package/lib/assets/img/svg/wizardstep/Open.svg +3 -0
  424. package/lib/assets/img/svg/wizardstep/Square.svg +3 -0
  425. package/lib/assets/img/svg/wizardstep/bar-active.svg +9 -0
  426. package/lib/assets/img/svg/wizardstep/bar-normal.svg +3 -0
  427. package/lib/assets/img/svg/wizardstep/bullet-current.svg +3 -0
  428. package/lib/assets/img/svg/wizardstep/bullet-done.svg +3 -0
  429. package/lib/assets/img/svg/wizardstep/bullet-not-done.svg +3 -0
  430. package/lib/assets/img/svg/wizardstep/check-active.svg +3 -0
  431. package/lib/assets/img/svg/wizardstep/check-normal.svg +3 -0
  432. package/lib/assets/img/svg/wizardstep/detail_view.svg +87 -0
  433. package/lib/assets/img/svg/wizardstep/pencil.svg +11 -0
  434. package/lib/assets/img/svg/wizardstep/tile_view.svg +95 -0
  435. package/lib/assets/img/texture/glass.jpg +0 -0
  436. package/lib/assets/img/texture/steel.jpg +0 -0
  437. package/lib/assets/img/texture/white1px.jpg +0 -0
  438. package/lib/assets/img/texture/wood.jpg +0 -0
  439. package/lib/assets/model/DCM.bin +0 -0
  440. package/lib/assets/model/DCM.fbx +0 -0
  441. package/lib/assets/model/DCM.gltf +1 -0
  442. package/lib/assets/model/FBM.bin +0 -0
  443. package/lib/assets/model/FBM.fbx +0 -0
  444. package/lib/assets/model/FBM.gltf +1 -0
  445. package/lib/assets/model/LRM.bin +0 -0
  446. package/lib/assets/model/LRM.fbx +0 -0
  447. package/lib/assets/model/LRM.gltf +1 -0
  448. package/lib/assets/rtastore_logo.png +0 -0
  449. package/lib/catalog/areas/area/planner-element.js +53 -0
  450. package/lib/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  451. package/lib/catalog/areas/area/textures/grass.jpg +0 -0
  452. package/lib/catalog/areas/area/textures/parquet.jpg +0 -0
  453. package/lib/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  454. package/lib/catalog/areas/area/textures/tile1.jpg +0 -0
  455. package/lib/catalog/back.png +0 -0
  456. package/lib/catalog/cabinet/cabinet-assembly-order.js +42 -0
  457. package/lib/catalog/catalog.js +270 -0
  458. package/lib/catalog/doors.png +0 -0
  459. package/lib/catalog/doorways.png +0 -0
  460. package/lib/catalog/envMap/nx.hdr +0 -0
  461. package/lib/catalog/envMap/ny.hdr +0 -0
  462. package/lib/catalog/envMap/nz.hdr +0 -0
  463. package/lib/catalog/envMap/px.hdr +0 -0
  464. package/lib/catalog/envMap/py.hdr +0 -0
  465. package/lib/catalog/envMap/pz.hdr +0 -0
  466. package/lib/catalog/export.js +1 -0
  467. package/lib/catalog/factories/area-factory-3d.js +187 -0
  468. package/lib/catalog/factories/area-factory.js +88 -0
  469. package/lib/catalog/factories/export.js +25 -0
  470. package/lib/catalog/factories/wall-factory-3d.js +212 -0
  471. package/lib/catalog/factories/wall-factory.js +279 -0
  472. package/lib/catalog/holes/door-closet/planner-element.js +232 -0
  473. package/lib/catalog/holes/door-double/door_double.png +0 -0
  474. package/lib/catalog/holes/door-double/planner-element.js +325 -0
  475. package/lib/catalog/holes/door-exterior/planner-element.js +225 -0
  476. package/lib/catalog/holes/door-interior/planner-element.js +237 -0
  477. package/lib/catalog/holes/door-panic/panicDoor.png +0 -0
  478. package/lib/catalog/holes/door-panic/planner-element.js +513 -0
  479. package/lib/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  480. package/lib/catalog/holes/door-panic-double/planner-element.js +473 -0
  481. package/lib/catalog/holes/door-sliding/planner-element.js +235 -0
  482. package/lib/catalog/holes/doorway-framed/planner-element.js +155 -0
  483. package/lib/catalog/holes/doorway-frameless/planner-element.js +114 -0
  484. package/lib/catalog/holes/export.js +97 -0
  485. package/lib/catalog/holes/gate/gate.jpg +0 -0
  486. package/lib/catalog/holes/window-clear/planner-element.js +176 -0
  487. package/lib/catalog/holes/window-clear/texture.png +0 -0
  488. package/lib/catalog/holes/window-cross/planner-element.js +175 -0
  489. package/lib/catalog/holes/window-cross/texture.png +0 -0
  490. package/lib/catalog/holes/window-double-hung/planner-element.js +313 -0
  491. package/lib/catalog/holes/window-double-hung/texture.png +0 -0
  492. package/lib/catalog/holes/window-vertical/planner-element.js +286 -0
  493. package/lib/catalog/holes/window-vertical/texture.png +0 -0
  494. package/lib/catalog/lines/wall/planner-element.js +87 -0
  495. package/lib/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  496. package/lib/catalog/lines/wall/textures/bricks.jpg +0 -0
  497. package/lib/catalog/lines/wall/textures/bricks2.jpg +0 -0
  498. package/lib/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  499. package/lib/catalog/lines/wall/textures/morden.jpg +0 -0
  500. package/lib/catalog/lines/wall/textures/painted.jpg +0 -0
  501. package/lib/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  502. package/lib/catalog/lines/wall/textures/plaster.jpg +0 -0
  503. package/lib/catalog/lines/wall/wall.png +0 -0
  504. package/lib/catalog/molding/molding-dcm/planner-element.js +33 -0
  505. package/lib/catalog/molding/molding-dcm/texture.png +0 -0
  506. package/lib/catalog/molding/molding-fbm/planner-element.js +33 -0
  507. package/lib/catalog/molding/molding-fbm/texture.png +0 -0
  508. package/lib/catalog/molding/molding-lrm/planner-element.js +33 -0
  509. package/lib/catalog/molding/molding-lrm/texture.png +0 -0
  510. package/lib/catalog/utils/exporter.js +173 -0
  511. package/lib/catalog/utils/geom-utils.js +205 -0
  512. package/lib/catalog/utils/item-loader.js +1603 -0
  513. package/lib/catalog/utils/load-obj.js +99 -0
  514. package/lib/catalog/utils/mtl-loader.js +366 -0
  515. package/lib/catalog/utils/obj-loader.js +486 -0
  516. package/lib/catalog/windows.png +0 -0
  517. package/lib/class/area.js +147 -0
  518. package/lib/class/export.js +88 -0
  519. package/lib/class/group.js +438 -0
  520. package/lib/class/guide.js +64 -0
  521. package/lib/class/hole.js +930 -0
  522. package/lib/class/item.js +2009 -0
  523. package/lib/class/layer.js +670 -0
  524. package/lib/class/line.js +1236 -0
  525. package/lib/class/project.js +949 -0
  526. package/lib/class/vertex.js +205 -0
  527. package/lib/components/content.js +160 -0
  528. package/lib/components/export.js +7 -0
  529. package/lib/components/style/export.js +17 -0
  530. package/lib/components/style/form-number-input.js +192 -0
  531. package/lib/components/style/form-submit-button.js +35 -0
  532. package/lib/components/viewer2d/area.js +89 -0
  533. package/lib/components/viewer2d/export.js +121 -0
  534. package/lib/components/viewer2d/grids/grid-horizontal-streak.js +44 -0
  535. package/lib/components/viewer2d/grids/grid-streak.js +44 -0
  536. package/lib/components/viewer2d/grids/grid-vertical-streak.js +44 -0
  537. package/lib/components/viewer2d/grids/grids.js +40 -0
  538. package/lib/components/viewer2d/group.js +63 -0
  539. package/lib/components/viewer2d/item.js +244 -0
  540. package/lib/components/viewer2d/layer.js +172 -0
  541. package/lib/components/viewer2d/line.js +975 -0
  542. package/lib/components/viewer2d/ruler.js +92 -0
  543. package/lib/components/viewer2d/rulerDist.js +110 -0
  544. package/lib/components/viewer2d/rulerX.js +154 -0
  545. package/lib/components/viewer2d/rulerY.js +156 -0
  546. package/lib/components/viewer2d/scene.js +137 -0
  547. package/lib/components/viewer2d/snap.js +84 -0
  548. package/lib/components/viewer2d/state.js +83 -0
  549. package/lib/components/viewer2d/utils.js +200 -0
  550. package/lib/components/viewer2d/vertex.js +76 -0
  551. package/lib/components/viewer2d/viewer2d.js +1472 -0
  552. package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +2591 -0
  553. package/lib/components/viewer3d/dcm.js +408 -0
  554. package/lib/components/viewer3d/fbm.js +421 -0
  555. package/lib/components/viewer3d/front3D.js +71 -0
  556. package/lib/components/viewer3d/grid-creator.js +35 -0
  557. package/lib/components/viewer3d/grids/grid-horizontal-streak.js +45 -0
  558. package/lib/components/viewer3d/grids/grid-streak.js +36 -0
  559. package/lib/components/viewer3d/grids/grid-vertical-streak.js +45 -0
  560. package/lib/components/viewer3d/libs/first-person-controls.js +74 -0
  561. package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +1287 -0
  562. package/lib/components/viewer3d/libs/mtl-loader.js +366 -0
  563. package/lib/components/viewer3d/libs/obj-loader.js +471 -0
  564. package/lib/components/viewer3d/libs/orbit-controls.js +706 -0
  565. package/lib/components/viewer3d/libs/pointer-lock-controls.js +53 -0
  566. package/lib/components/viewer3d/lrm.js +312 -0
  567. package/lib/components/viewer3d/model.js +714 -0
  568. package/lib/components/viewer3d/pointer-lock-navigation.js +32 -0
  569. package/lib/components/viewer3d/ruler-utils/itemRect.js +69 -0
  570. package/lib/components/viewer3d/ruler-utils/layer3D.js +503 -0
  571. package/lib/components/viewer3d/ruler-utils/ruler3D.js +232 -0
  572. package/lib/components/viewer3d/ruler-utils/scene3D.js +67 -0
  573. package/lib/components/viewer3d/ruler-utils/state3D.js +26 -0
  574. package/lib/components/viewer3d/scene-creator.js +3850 -0
  575. package/lib/components/viewer3d/three-memory-cleaner.js +46 -0
  576. package/lib/components/viewer3d/viewer3d-first-person.js +316 -0
  577. package/lib/components/viewer3d/viewer3d.js +2673 -0
  578. package/lib/constants/catalog/skinPanel.js +15 -0
  579. package/lib/constants.js +791 -0
  580. package/lib/devLiteRenderer.js +917 -0
  581. package/lib/events/external/handleExternalEvent.js +148 -0
  582. package/lib/events/external/handleExternalEvent.util.js +1110 -0
  583. package/lib/events/external/handlers.addItem.js +54 -0
  584. package/lib/events/external/handlers.changeDoorStyle.js +147 -0
  585. package/lib/events/external/handlers.elementOps.js +15 -0
  586. package/lib/events/external/handlers.finishing.js +32 -0
  587. package/lib/events/external/handlers.hole.js +10 -0
  588. package/lib/events/external/handlers.loadProject.js +135 -0
  589. package/lib/events/external/handlers.molding.js +31 -0
  590. package/lib/events/external/handlers.projectLifecycle.js +19 -0
  591. package/lib/events/external/handlers.projectSettings.js +38 -0
  592. package/lib/events/external/handlers.replaceCabinet.js +48 -0
  593. package/lib/events/external/handlers.roomShape.js +14 -0
  594. package/lib/events/external/handlers.syncScene.js +27 -0
  595. package/lib/events/external/handlers.updateSelectedElements.js +17 -0
  596. package/lib/events/external/handlers.viewMode.js +19 -0
  597. package/lib/events/external/handlers.viewerNavigation.js +117 -0
  598. package/lib/events/external/handlers.wall.js +13 -0
  599. package/lib/index.js +637 -0
  600. package/lib/mappings/external-events/mapExternalEventPayload.js +33 -0
  601. package/lib/mappings/external-events/mappers/addItemMapper.js +103 -0
  602. package/lib/mappings/external-events/mappers/ccdfMapper.js +107 -0
  603. package/lib/mappings/external-events/mappers/ccdfToCDSMapper.js +55 -0
  604. package/lib/mappings/external-events/mappers/changeDoorStyleMapper.js +44 -0
  605. package/lib/mappings/external-events/mappers/loadProjectMapper.js +70 -0
  606. package/lib/mappings/holesToCatalog.js +148 -0
  607. package/lib/models.js +534 -0
  608. package/lib/plugins/SVGLoader.js +1419 -0
  609. package/lib/plugins/console-debugger.js +42 -0
  610. package/lib/plugins/export.js +25 -0
  611. package/lib/plugins/keyboard.js +117 -0
  612. package/lib/reducers/areas-reducer.js +19 -0
  613. package/lib/reducers/export.js +89 -0
  614. package/lib/reducers/groups-reducer.js +45 -0
  615. package/lib/reducers/holes-reducer.js +69 -0
  616. package/lib/reducers/items-reducer.js +152 -0
  617. package/lib/reducers/lines-reducer.js +52 -0
  618. package/lib/reducers/project-reducer.js +143 -0
  619. package/lib/reducers/reducer.js +25 -0
  620. package/lib/reducers/scene-reducer.js +35 -0
  621. package/lib/reducers/vertices-reducer.js +26 -0
  622. package/lib/reducers/viewer2d-reducer.js +84 -0
  623. package/lib/reducers/viewer3d-reducer.js +65 -0
  624. package/lib/shared/domain/cabinet-warning.js +20 -0
  625. package/lib/shared/objects/immutable.js +9 -0
  626. package/lib/shared-style.js +72 -0
  627. package/lib/translator/en.js +111 -0
  628. package/lib/translator/it.js +86 -0
  629. package/lib/translator/ru.js +86 -0
  630. package/lib/translator/translator.js +87 -0
  631. package/lib/utils/browser.js +40 -0
  632. package/lib/utils/convert-units-lite.js +44 -0
  633. package/lib/utils/email-validator.js +10 -0
  634. package/lib/utils/export.js +56 -0
  635. package/lib/utils/geometry.js +3230 -0
  636. package/lib/utils/get-edges-of-subgraphs.js +33 -0
  637. package/lib/utils/graph-cycles.js +239 -0
  638. package/lib/utils/graph-inner-cycles.js +54 -0
  639. package/lib/utils/graph.js +153 -0
  640. package/lib/utils/helper.js +480 -0
  641. package/lib/utils/history.js +48 -0
  642. package/lib/utils/id-broker.js +22 -0
  643. package/lib/utils/logger.js +14 -0
  644. package/lib/utils/math.js +57 -0
  645. package/lib/utils/molding.js +1146 -0
  646. package/lib/utils/name-generator.js +21 -0
  647. package/lib/utils/objects-utils.js +62 -0
  648. package/lib/utils/phone-validator.js +10 -0
  649. package/lib/utils/process-black-list.js +22 -0
  650. package/lib/utils/react-if.js +25 -0
  651. package/lib/utils/ruler.js +63 -0
  652. package/lib/utils/skinPanelEngine.js +530 -0
  653. package/lib/utils/snap-scene.js +101 -0
  654. package/lib/utils/snap.js +245 -0
  655. package/lib/utils/summarizeCart.js +30 -0
  656. package/lib/utils/threeCSG.es6.js +504 -0
  657. package/lib/version.js +7 -0
  658. package/package.json +29 -24
  659. package/es/WorkSpace.js +0 -30
  660. package/es/WorkSpaceHostMimic.js +0 -132
  661. package/es/assets/gltf/door_closet.bin +0 -0
  662. package/es/assets/gltf/door_closet.fbx +0 -0
  663. package/es/assets/gltf/door_exterior.bin +0 -0
  664. package/es/assets/gltf/door_exterior.fbx +0 -0
  665. package/es/assets/gltf/door_interior.bin +0 -0
  666. package/es/assets/gltf/door_interior.fbx +0 -0
  667. package/es/assets/gltf/door_sliding.bin +0 -0
  668. package/es/assets/gltf/door_sliding.fbx +0 -0
  669. package/es/assets/img/png/helper/video_preview_3d.png +0 -0
  670. package/es/assets/img/png/helper/video_preview_start.png +0 -0
  671. package/es/assets/img/svg/color/Brown.svg +0 -9
  672. package/es/assets/img/svg/color/Dark.svg +0 -9
  673. package/es/assets/img/svg/color/Light.svg +0 -9
  674. package/es/assets/img/svg/color/Medium.svg +0 -9
  675. package/es/assets/img/svg/color/Unfinished.svg +0 -9
  676. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  677. package/es/catalog/properties/export.js +0 -21
  678. package/es/catalog/properties/property-checkbox.js +0 -68
  679. package/es/catalog/properties/property-color.js +0 -39
  680. package/es/catalog/properties/property-enum.js +0 -50
  681. package/es/catalog/properties/property-hidden.js +0 -19
  682. package/es/catalog/properties/property-lenght-measure.js +0 -96
  683. package/es/catalog/properties/property-length-measure.js +0 -80
  684. package/es/catalog/properties/property-length-measure_hole.js +0 -96
  685. package/es/catalog/properties/property-number.js +0 -48
  686. package/es/catalog/properties/property-read-only.js +0 -26
  687. package/es/catalog/properties/property-string.js +0 -48
  688. package/es/catalog/properties/property-toggle.js +0 -39
  689. package/es/catalog/properties/shared-property-style.js +0 -14
  690. package/es/catalog/utils/FuseUtils.js +0 -79
  691. package/es/class/FuseUtils.js +0 -79
  692. package/es/components/style/button.js +0 -106
  693. package/es/components/style/cancel-button.js +0 -21
  694. package/es/components/style/content-container.js +0 -30
  695. package/es/components/style/content-title.js +0 -25
  696. package/es/components/style/delete-button.js +0 -24
  697. package/es/components/style/form-block.js +0 -20
  698. package/es/components/style/form-color-input.js +0 -26
  699. package/es/components/style/form-label.js +0 -22
  700. package/es/components/style/form-number-input_2.js +0 -238
  701. package/es/components/style/form-select.js +0 -19
  702. package/es/components/style/form-slider.js +0 -60
  703. package/es/components/style/form-text-input.js +0 -69
  704. package/es/index.html.ejs +0 -264
  705. package/es/reducers/user-reducer.js +0 -41
  706. package/es/utils/isolate-event-handler.js +0 -1622
  707. /package/{es/catalog/lines/wall/textures/bricks-normal2.jpg → lib/catalog/lines/wall/textures/painted-normal.jpg} +0 -0
@@ -0,0 +1,1472 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = Viewer2D;
9
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _propTypes = _interopRequireDefault(require("prop-types"));
13
+ var _reactSvgPanZoom = require("react-svg-pan-zoom");
14
+ var _constants = _interopRequireWildcard(require("../../constants"));
15
+ var constants = _constants;
16
+ var _state = _interopRequireDefault(require("./state"));
17
+ var SharedStyle = _interopRequireWildcard(require("../../shared-style"));
18
+ var _export = require("./export");
19
+ var _export2 = require("../../utils/export");
20
+ var _formNumberInput = _interopRequireDefault(require("../style/form-number-input"));
21
+ var _convertUnitsLite = require("../../utils/convert-units-lite");
22
+ var _immutable = require("immutable");
23
+ var _math = require("../../utils/math");
24
+ var _helper = require("../../utils/helper");
25
+ var _cabinetWarning = require("../../shared/domain/cabinet-warning");
26
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
27
+ 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; }
28
+ 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; } // variables
29
+ // variables
30
+ var pinFlag = false;
31
+ var sFlag = false; //for all object move
32
+ var sPoint = {}; //for all object move
33
+ var mouseDownPoint = {}; // mouse clicked point
34
+ var endPoint = {};
35
+ var current_sel_obj_id = null;
36
+ var allItemRect;
37
+ var allItemSnap;
38
+ var allLines;
39
+ var allLineRects;
40
+ var allLineSnap;
41
+ var allRect;
42
+ var allArea;
43
+
44
+ // /////////
45
+ function mode2Tool(mode) {
46
+ if (pinFlag) {
47
+ return _reactSvgPanZoom.TOOL_NONE;
48
+ }
49
+ switch (mode) {
50
+ case constants.MODE_2D_PAN:
51
+ return _reactSvgPanZoom.TOOL_PAN;
52
+ case constants.MODE_2D_ZOOM_IN:
53
+ return _reactSvgPanZoom.TOOL_ZOOM_IN;
54
+ case constants.MODE_2D_ZOOM_OUT:
55
+ return _reactSvgPanZoom.TOOL_ZOOM_OUT;
56
+ case constants.MODE_IDLE:
57
+ return _reactSvgPanZoom.TOOL_AUTO;
58
+ default:
59
+ return _reactSvgPanZoom.TOOL_NONE;
60
+ }
61
+ }
62
+ function mode2PointerEvents(mode) {
63
+ switch (mode) {
64
+ case constants.MODE_DRAWING_LINE:
65
+ case constants.MODE_DRAWING_HOLE:
66
+ case constants.MODE_DRAWING_ITEM:
67
+ case constants.MODE_DRAGGING_HOLE:
68
+ case constants.MODE_DRAGGING_ITEM:
69
+ case constants.MODE_DRAGGING_LINE:
70
+ case constants.MODE_DRAGGING_VERTEX:
71
+ return {
72
+ pointerEvents: 'none'
73
+ };
74
+ default:
75
+ return {};
76
+ }
77
+ }
78
+ function mode2Cursor(mode) {
79
+ switch (mode) {
80
+ case constants.MODE_DRAGGING_HOLE:
81
+ case constants.MODE_DRAGGING_LINE:
82
+ case constants.MODE_DRAGGING_VERTEX:
83
+ case constants.MODE_DRAGGING_ITEM:
84
+ return {
85
+ cursor: 'move'
86
+ };
87
+ case constants.MODE_ROTATING_ITEM:
88
+ return {
89
+ cursor: 'ew-resize'
90
+ };
91
+ case constants.MODE_WAITING_DRAWING_LINE:
92
+ case constants.MODE_DRAWING_LINE:
93
+ return {
94
+ cursor: 'crosshair'
95
+ };
96
+ default:
97
+ return {
98
+ cursor: 'default'
99
+ };
100
+ }
101
+ }
102
+ function mode2DetectAutopan(mode) {
103
+ switch (mode) {
104
+ case constants.MODE_DRAWING_LINE:
105
+ case constants.MODE_DRAGGING_LINE:
106
+ case constants.MODE_DRAGGING_VERTEX:
107
+ case constants.MODE_DRAGGING_HOLE:
108
+ case constants.MODE_DRAGGING_ITEM:
109
+ case constants.MODE_DRAWING_HOLE:
110
+ case constants.MODE_DRAWING_ITEM:
111
+ return true;
112
+ default:
113
+ return false;
114
+ }
115
+ }
116
+ function extractElementData(node) {
117
+ while (!node.attributes.getNamedItem('data-element-root') && node.tagName !== 'svg') {
118
+ node = node.parentNode;
119
+ }
120
+ if (node.tagName === 'svg') return null;
121
+ return {
122
+ length: node.attributes.getNamedItem('data-length') ? parseFloat(node.attributes.getNamedItem('data-length').value) : 0,
123
+ part: node.attributes.getNamedItem('data-part') ? node.attributes.getNamedItem('data-part').value : undefined,
124
+ layer: node.attributes.getNamedItem('data-layer').value,
125
+ prototype: node.attributes.getNamedItem('data-prototype').value,
126
+ selected: node.attributes.getNamedItem('data-selected').value === 'true',
127
+ id: node.attributes.getNamedItem('data-id').value,
128
+ direct: node.attributes.getNamedItem('data-direct') ? node.attributes.getNamedItem('data-direct').value : 0
129
+ };
130
+ }
131
+ function Viewer2D(_ref, _ref2) {
132
+ var state = _ref.state,
133
+ width = _ref.width,
134
+ height = _ref.height,
135
+ setToolbar = _ref.setToolbar,
136
+ replaceCabinet = _ref.replaceCabinet,
137
+ onInternalEvent = _ref.onInternalEvent;
138
+ var viewer2DActions = _ref2.viewer2DActions,
139
+ linesActions = _ref2.linesActions,
140
+ holesActions = _ref2.holesActions,
141
+ verticesActions = _ref2.verticesActions,
142
+ itemsActions = _ref2.itemsActions,
143
+ areaActions = _ref2.areaActions,
144
+ projectActions = _ref2.projectActions,
145
+ catalog = _ref2.catalog;
146
+ var _useState = (0, _react.useState)(null),
147
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
148
+ rulerEdit = _useState2[0],
149
+ setRulerEdit = _useState2[1];
150
+ var _useState3 = (0, _react.useState)(null),
151
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
152
+ rulerEditID = _useState4[0],
153
+ setRulerEditID = _useState4[1];
154
+ var Viewer = (0, _react.useRef)(null);
155
+ var viewer2D = state.viewer2D,
156
+ mode = state.mode,
157
+ scene = state.scene;
158
+
159
+ // let relatedLines = [];
160
+ var _useState5 = (0, _react.useState)([]),
161
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
162
+ relatedLines = _useState6[0],
163
+ setRelatedLines = _useState6[1];
164
+ var _useState7 = (0, _react.useState)(false),
165
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
166
+ drawStart = _useState8[0],
167
+ setdrawStart = _useState8[1];
168
+ (0, _react.useEffect)(function () {
169
+ // move viewer point to center
170
+ var selectedLayer = state.scene.layers.get(state.scene.selectedLayer);
171
+ var vertices = selectedLayer.vertices;
172
+ if (vertices.isEmpty()) {
173
+ return;
174
+ }
175
+ var bottomX = 0,
176
+ bottomY = 100000,
177
+ topX = 100000,
178
+ topY = 0;
179
+ vertices.forEach(function (vertex) {
180
+ if (bottomX < vertex.x) bottomX = vertex.x;
181
+ if (bottomY > vertex.y) bottomY = vertex.y;
182
+ if (topX > vertex.x) topX = vertex.x;
183
+ if (topY < vertex.y) topY = vertex.y;
184
+ });
185
+ var moveX = topX + (bottomX - topX) / 2;
186
+ var moveY = 2000 - (bottomY + (topY - bottomY) / 2);
187
+ Viewer.current.setPointOnViewerCenter(moveX, moveY, viewer2D.get('a'));
188
+ }, []);
189
+ var layerID = scene.selectedLayer;
190
+ var wall_thickness = _constants.LINE_THICKNESS / 2;
191
+ var layer = scene.getIn(['layers', layerID]);
192
+ var mapCursorPosition = function mapCursorPosition(_ref3) {
193
+ var x = _ref3.x,
194
+ y = _ref3.y;
195
+ return {
196
+ x: x,
197
+ y: -y + scene.height
198
+ };
199
+ };
200
+ // let pinBackColor = pinFlag ? "#4488ff" : "black";
201
+ // let topRightImg = state.mode == MODE_IDLE || state.mode == MODE_2D_PAN ? "/assets/img/svg/topbar/edit_inactive.svg" : "/assets/img/svg/topbar/edit_active.svg";
202
+ // let topBtnAction = state.mode == MODE_IDLE || state.mode == MODE_2D_PAN ? () => linesActions.selectToolDrawingLine("wall") : () => projectActions.setMode(MODE_IDLE);
203
+
204
+ var prepareSnap = function prepareSnap() {
205
+ var layerID = scene.selectedLayer;
206
+ var layer = scene.layers.get(layerID);
207
+ allLines = _export2.GeometryUtils.getAllLines(layer);
208
+ allLineRects = _export2.GeometryUtils.buildRectFromLines(layer, allLines);
209
+ allItemRect = _export2.GeometryUtils.getAllItems(scene, catalog, allLineRects);
210
+ allItemSnap = _export2.GeometryUtils.getAllItemSnap(allItemRect);
211
+ allLineSnap = _export2.GeometryUtils.getAllLineSnap(allLineRects, allItemRect.cur);
212
+ allRect = allItemRect.others.concat(allLineRects);
213
+ allItemSnap = _export2.GeometryUtils.validateSnaps(allItemSnap, allRect);
214
+ allLineSnap = _export2.GeometryUtils.validateSnaps(allLineSnap, allRect);
215
+ allArea = _export2.GeometryUtils.getAllArea(layer);
216
+ };
217
+ var updateRulerDistAttribute = function updateRulerDistAttribute(elementData, value) {
218
+ var newVal = value.get('length');
219
+ var oldVal = elementData.length;
220
+ var direct = elementData.direct;
221
+ var thisItem = scene.getIn(['layers', elementData.layer, 'items', elementData.id]).toJS();
222
+ var oldX = thisItem.x;
223
+ var oldY = thisItem.y;
224
+ var oldRotRad = thisItem.rotation / 180 * Math.PI;
225
+ var rotRad = oldRotRad + direct / 180 * Math.PI;
226
+ var delta = oldVal - newVal;
227
+ var newX = oldX + delta * Math.cos(rotRad);
228
+ var newY = oldY + delta * Math.sin(rotRad);
229
+ itemsActions.updateDraggingItemChanged(newX, newY, elementData.layer, elementData.id);
230
+ setRulerEdit(null);
231
+ };
232
+ var updateangleChangeAttribute = function updateangleChangeAttribute(elementData, value) {
233
+ var verArr = elementData.id.split(',');
234
+ var oldAngle = elementData.length;
235
+ var newAngle = value.getIn(['_length']);
236
+ var cenId = verArr[0];
237
+ var verId = verArr[1];
238
+ var x0 = state.scene.getIn(['layers', layerID, 'vertices', verArr[0], 'x']);
239
+ var y0 = state.scene.getIn(['layers', layerID, 'vertices', verArr[0], 'y']);
240
+ var x1 = state.scene.getIn(['layers', layerID, 'vertices', verArr[1], 'x']);
241
+ var y1 = state.scene.getIn(['layers', layerID, 'vertices', verArr[1], 'y']);
242
+ var x, y, delta;
243
+ delta = newAngle - oldAngle;
244
+ if (verArr[2] === 'true') {
245
+ delta = -delta;
246
+ }
247
+ x = (x1 - x0) * Math.cos(delta * Math.PI / 180) - (y1 - y0) * Math.sin(delta * Math.PI / 180) + x0;
248
+ y = (x1 - x0) * Math.sin(delta * Math.PI / 180) + (y1 - y0) * Math.cos(delta * Math.PI / 180) + y0;
249
+ setRulerEdit(null);
250
+ verticesActions.beginDraggingVertex(elementData.layer, verArr[1], x, y, state.snapMask);
251
+ verticesActions.updateDraggingVertex(x, y, state.snapMask);
252
+ verticesActions.endDraggingVertex(x, y, state.snapMask);
253
+ };
254
+ var updateRulerAttribute = function updateRulerAttribute(elementData, value) {
255
+ var selectedLine = scene.getIn(['layers', elementData.layer, 'lines', elementData.id]).toJS();
256
+ var v_0 = scene.getIn(['layers', elementData.layer, 'vertices', selectedLine.vertices[0]]);
257
+ var v_1 = scene.getIn(['layers', elementData.layer, 'vertices', selectedLine.vertices[1]]);
258
+ var _GeometryUtils$orderV = _export2.GeometryUtils.orderVertices([v_0, v_1]),
259
+ _GeometryUtils$orderV2 = (0, _slicedToArray2["default"])(_GeometryUtils$orderV, 2),
260
+ v_a = _GeometryUtils$orderV2[0],
261
+ v_b = _GeometryUtils$orderV2[1];
262
+ var v_b_new = _export2.GeometryUtils.extendLine(v_a.x, v_a.y, v_b.x, v_b.y, value.get('length'), 2);
263
+
264
+ // Blocked function that as wall changed, opposite wall should changed together.
265
+ // let layer = scene.getIn(['layers', elementData.layer]);
266
+ // let allLines = layer.lines.toArray()
267
+ // let relatedLine = allLines.filter(line => { return line.vertices.toArray().includes(v_b.id) && line.id != selectedLine.id })[0];
268
+ // let relatedVertexID = relatedLine && (relatedLine.vertices.toArray()[0] == v_b.id ? relatedLine.vertices.toArray()[1] : relatedLine.vertices.toArray()[0]);
269
+ // let v_d = relatedVertexID && layer.getIn(['vertices', relatedVertexID]);
270
+ // let delta = {
271
+ // x : v_b_new.x - v_b.x,
272
+ // y : v_b_new.y - v_b.y
273
+ // };
274
+ // let newPosition = {
275
+ // x : v_d.x + delta.x,
276
+ // y : v_d.y + delta.y
277
+ // }
278
+
279
+ var attributesData = {
280
+ // (v_0 === v_a ? 'vertexTwo' : 'vertexOne') : v_b.merge(v_b_new)),
281
+ lineLength: value
282
+ };
283
+ if (v_0 === v_a) {
284
+ attributesData = _objectSpread(_objectSpread({}, attributesData), {}, {
285
+ vertexTwo: v_b.merge(v_b_new),
286
+ vertexOne: v_a
287
+ });
288
+ } else {
289
+ attributesData = _objectSpread(_objectSpread({}, attributesData), {}, {
290
+ vertexOne: v_b.merge(v_b_new),
291
+ vertexTwo: v_a
292
+ });
293
+ }
294
+ var attributesFormData = new _immutable.Map(_objectSpread({}, attributesData));
295
+ setRulerEdit(null);
296
+ projectActions.setLinesAttributes(attributesFormData, true, {
297
+ layerID: elementData.layer,
298
+ lineID: elementData.id
299
+ });
300
+
301
+ // Blocked function that as wall changed, opposite wall should changed together.
302
+ // verticesActions.beginDraggingVertex(elementData.layer, relatedVertexID, newPosition.x, newPosition.y, state.snapMask);
303
+ // verticesActions.updateDraggingVertex(newPosition.x, newPosition.y, state.snapMask);
304
+ // verticesActions.endDraggingVertex(newPosition.x, newPosition.y, state.snapMask);
305
+ };
306
+ var updateTwoHoleRulerAttribute = function updateTwoHoleRulerAttribute(elementData, value) {
307
+ var elementIds = elementData.id.split(',');
308
+ elementData.id = elementIds[1];
309
+ elementData.length /= 2;
310
+ updateLeftHoleRulerAttribute(elementData, value);
311
+ elementData.id = elementIds[0];
312
+ updateRightHoleRulerAttribute(elementData, value);
313
+ };
314
+ var updateLeftHoleRulerAttribute = function updateLeftHoleRulerAttribute(elementData, value) {
315
+ var newVal = value.get('length');
316
+ var oldVal = elementData.length;
317
+ var thisItem = scene.getIn(['layers', elementData.layer, 'holes', elementData.id]).toJS();
318
+ var oldX = thisItem.x;
319
+ var oldY = thisItem.y;
320
+ var oldRotRad = thisItem.rotation;
321
+ var delta = oldVal - newVal;
322
+ var newX = oldX - delta * Math.cos(oldRotRad);
323
+ var newY = oldY - delta * Math.sin(oldRotRad);
324
+ holesActions.beginDraggingHole(elementData.layer, elementData.id, newX, newY);
325
+ holesActions.updateDraggingHoleChanged(newX, newY, elementData.layer, elementData.id);
326
+ holesActions.endDraggingHole(newX, newY);
327
+ setRulerEdit(null);
328
+ };
329
+ var updateHoleRulerAttribute = function updateHoleRulerAttribute(elementData, value) {
330
+ var newVal = value.get('length');
331
+ var thisItem = scene.getIn(['layers', elementData.layer, 'holes', elementData.id]).toJS();
332
+ var oldX = thisItem.x;
333
+ var oldY = thisItem.y;
334
+ holesActions.beginDraggingHole(elementData.layer, elementData.id, oldX, oldY);
335
+ holesActions.updateDraggingHoleRulerChanged(newVal, elementData.layer, elementData.id);
336
+ holesActions.endDraggingHole(oldX, oldY);
337
+ setRulerEdit(null);
338
+ };
339
+ var updateRightHoleRulerAttribute = function updateRightHoleRulerAttribute(elementData, value) {
340
+ var newVal = value.get('length');
341
+ var oldVal = elementData.length;
342
+ var thisItem = scene.getIn(['layers', elementData.layer, 'holes', elementData.id]).toJS();
343
+ var oldX = thisItem.x;
344
+ var oldY = thisItem.y;
345
+ var oldRotRad = thisItem.rotation;
346
+ var delta = oldVal - newVal;
347
+ var newX = oldX + delta * Math.cos(oldRotRad);
348
+ var newY = oldY + delta * Math.sin(oldRotRad);
349
+ holesActions.beginDraggingHole(elementData.layer, elementData.id, newX, newY);
350
+ holesActions.updateDraggingHoleChanged(newX, newY, elementData.layer, elementData.id);
351
+ holesActions.endDraggingHole(newX, newY);
352
+ setRulerEdit(null);
353
+ };
354
+ var getRelatedLines = function getRelatedLines(tlines, drawingLine, vertices, lines) {
355
+ var _loop = function _loop() {
356
+ var vertex = vertices[drawingLine.vertices[i]];
357
+ var _loop2 = function _loop2(j) {
358
+ if (vertex.lines[j] !== drawingLine.id) {
359
+ if (!tlines.some(function (line) {
360
+ return line.id === lines[vertex.lines[j]].id;
361
+ })) {
362
+ tlines.push(lines[vertex.lines[j]]);
363
+ }
364
+ }
365
+ };
366
+ for (var j = 0; j < vertex.lines.length; j++) {
367
+ _loop2(j);
368
+ }
369
+ };
370
+ // if (drawingLine.vertices[0] !== drawingLine.vertices[1]) {
371
+ for (var i = 0; i < drawingLine.vertices.length; i++) {
372
+ _loop();
373
+ }
374
+ // }
375
+ };
376
+ var getEndPoint = function getEndPoint(vertices, x, y, mode) {
377
+ var selLineID = state.getIn(['scene', 'layers', layerID, 'selected', 'lines']).first();
378
+ if ((0, _helper.isEmpty)(selLineID)) {
379
+ return {
380
+ isEndDrag: true,
381
+ x: x,
382
+ y: y
383
+ };
384
+ }
385
+ var draggingLine = state.getIn(['scene', 'layers', layerID, 'lines', selLineID]).toJS();
386
+ var allLines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
387
+ var dragVertexId = state.getIn(['draggingSupport', 'vertexID']);
388
+ dragVertexId = !(0, _helper.isEmpty)(dragVertexId) ? dragVertexId : draggingLine.vertices[1];
389
+ var vtx, vty;
390
+ var stepUnit = false;
391
+ vtx = vertices[dragVertexId].x;
392
+ vty = vertices[dragVertexId].y;
393
+ if (!vertices[dragVertexId].lines.some(function (line) {
394
+ return line !== draggingLine.id;
395
+ })) {
396
+ stepUnit = true;
397
+ }
398
+ var endDrag = [];
399
+ if (!(0, _helper.isEmpty)(relatedLines) && mode !== 'DRAGGING_LINE') {
400
+ vertices[dragVertexId].x = x;
401
+ vertices[dragVertexId].y = y;
402
+ }
403
+ var absAngle, lineAngle;
404
+ var angles = [];
405
+ if (draggingLine.vertices[0] !== draggingLine.vertices[1]) {
406
+ if ((0, _helper.isEmpty)(relatedLines) && mode !== 'DRAGGING_LINE') {
407
+ endDrag.push(true);
408
+ var originVerIndex = draggingLine.vertices.findIndex(function (vertice) {
409
+ return vertice !== dragVertexId;
410
+ });
411
+ var originVerId = originVerIndex < 0 ? draggingLine.vertices[0] : draggingLine.vertices[originVerIndex];
412
+ var ox = vertices[originVerId].x;
413
+ var oy = vertices[originVerId].y;
414
+ lineAngle = _export2.GeometryUtils.angleBetweenTwoPointsAndOrigin(ox, oy, x, y);
415
+ absAngle = Math.abs(lineAngle);
416
+ }
417
+ for (var i = 0; i < relatedLines.length; i++) {
418
+ var line = relatedLines[i];
419
+ lineAngle = _export2.GeometryUtils.angleBetweenTwoLines(line, draggingLine, vertices);
420
+ absAngle = Math.abs(lineAngle);
421
+ var tmpRelated = [];
422
+ _export2.GeometryUtils.getRelatedLines(tmpRelated, line, vertices, allLines, draggingLine.id);
423
+ angles.push(lineAngle);
424
+ for (var j = 0; j < tmpRelated.length; j++) {
425
+ var tmpAngle = Math.abs(_export2.GeometryUtils.angleBetweenTwoLines(tmpRelated[j], line, vertices));
426
+ if (tmpAngle < _constants.MIN_ANGLE_DISALLOW_DRAW_WALL || tmpAngle > 360 - _constants.MIN_ANGLE_DISALLOW_DRAW_WALL) {
427
+ endDrag.push(false);
428
+ } else endDrag.push(true);
429
+ }
430
+ if (absAngle < _constants.MIN_ANGLE_DISALLOW_DRAW_WALL || absAngle > 360 - _constants.MIN_ANGLE_DISALLOW_DRAW_WALL) {
431
+ endDrag.push(false);
432
+ } else endDrag.push(true);
433
+ }
434
+ }
435
+ if (!endDrag.some(function (flag) {
436
+ return flag === false;
437
+ })) {
438
+ vtx = x;
439
+ vty = y;
440
+ } else {
441
+ // the origin point of rotation(snapping)
442
+ var _originVerId = draggingLine.vertices.findIndex(function (vertice) {
443
+ return vertice !== dragVertexId;
444
+ });
445
+ _originVerId = _originVerId < 0 ? draggingLine.vertices[0] : draggingLine.vertices[_originVerId];
446
+ if (stepUnit) {
447
+ var _ox = vertices[_originVerId].x;
448
+ var _oy = vertices[_originVerId].y;
449
+ angles.forEach(function (angle, index) {
450
+ if (Math.abs(angle) < _constants.MIN_ANGLE_DISALLOW_DRAW_WALL || Math.abs(angle) > 360 - _constants.MIN_ANGLE_DISALLOW_DRAW_WALL) {
451
+ var absVal = Math.abs(angle);
452
+ var rest = _constants.MIN_ANGLE_DISALLOW_DRAW_WALL - absVal;
453
+ if (absVal > 360 - _constants.MIN_ANGLE_DISALLOW_DRAW_WALL) {
454
+ absVal = 360 - absVal;
455
+ rest = -(_constants.MIN_ANGLE_DISALLOW_DRAW_WALL - absVal);
456
+ }
457
+ // determine the direction of rotation.
458
+ rest = angle > 0 ? -rest : rest;
459
+ // rotate the current point to last point around the first point of drawing line.
460
+ var res = _export2.GeometryUtils.rotatePointAroundPoint(x, y, _ox, _oy, rest);
461
+ vtx = res.x;
462
+ vty = res.y;
463
+ }
464
+ });
465
+ }
466
+ }
467
+
468
+ // angle snapping as a value of UNIT_ANGLE
469
+ if (!endDrag.some(function (flag) {
470
+ return flag === false;
471
+ }) && !(0, _helper.isEmpty)(absAngle) && absAngle % _constants.UNIT_ANGLE !== 0 && stepUnit) {
472
+ var _result = _export2.GeometryUtils.snapAngleByUnit(lineAngle, vertices, draggingLine, vtx, vty, dragVertexId);
473
+ vtx = _result.x;
474
+ vty = _result.y;
475
+ }
476
+ var result = {
477
+ isEndDrag: endDrag,
478
+ x: vtx,
479
+ y: vty
480
+ };
481
+ return result;
482
+ };
483
+ var getProperties = function getProperties(item, property) {
484
+ var _item$properties;
485
+ if (!(item !== null && item !== void 0 && (_item$properties = item.properties) !== null && _item$properties !== void 0 && _item$properties.getIn)) return 0;
486
+ var length = item.properties.getIn([property, '_length']);
487
+ var unit = item.properties.getIn([property, '_unit']);
488
+ return length && unit ? (0, _convertUnitsLite.convert)(length).from(unit).to('cm') : 0;
489
+ };
490
+ var point = function point(x, y) {
491
+ return {
492
+ x: x,
493
+ y: y
494
+ };
495
+ };
496
+ var getDistant = function getDistant(x, y, rotRad, curItemInfo, allRect) {
497
+ var center_h = 3 * height / 8;
498
+ var center_x1 = x - center_h * Math.sin(rotRad);
499
+ var center_y1 = y + center_h * Math.cos(rotRad);
500
+ var pointArray = [];
501
+ curItemInfo.rectCenterPoint.forEach(function (centerpoint) {
502
+ if (!Array.isArray(centerpoint) || centerpoint.length < 2) return;
503
+ var _centerpoint = (0, _slicedToArray2["default"])(centerpoint, 2),
504
+ pt = _centerpoint[0],
505
+ angle = _centerpoint[1];
506
+ if (!pt) return;
507
+
508
+ // line through centerpoint and reference center
509
+ var rectLine = angle === 180 || angle === 0 ? _export2.GeometryUtils.linePassingThroughTwoPoints(pt.x, pt.y, center_x1, center_y1) : _export2.GeometryUtils.linePassingThroughTwoPoints(pt.x, pt.y, x, y);
510
+ if (!rectLine) return;
511
+ var minDist;
512
+ allRect.forEach(function (linerect) {
513
+ if (!(linerect !== null && linerect !== void 0 && linerect.rect) || linerect.rect.length < 4) return;
514
+ var p0 = _export2.GeometryUtils.clone_point(linerect.rect[2]);
515
+ var p1 = _export2.GeometryUtils.clone_point(linerect.rect[3]);
516
+ if (!p0 || !p1 || p0.x === p1.x && p0.y === p1.y) return;
517
+ var lineFn = _export2.GeometryUtils.linePassingThroughTwoPoints(p0.x, p0.y, p1.x, p1.y);
518
+ if (!lineFn) return;
519
+ var ip = _export2.GeometryUtils.twoLinesIntersection(lineFn.a, lineFn.b, lineFn.c, rectLine.a, rectLine.b, rectLine.c);
520
+ if (!ip) return;
521
+
522
+ // intersection must lie within line segment
523
+ var segLen = _export2.GeometryUtils.pointsDistance(p0.x, p0.y, p1.x, p1.y);
524
+ if (segLen <= _export2.GeometryUtils.pointsDistance(p0.x, p0.y, ip.x, ip.y) || segLen <= _export2.GeometryUtils.pointsDistance(p1.x, p1.y, ip.x, ip.y)) return;
525
+
526
+ // ensure intersection is farther than pt→center
527
+ var distToCenter = _export2.GeometryUtils.pointsDistance(ip.x, ip.y, x, y);
528
+ var baseDist = _export2.GeometryUtils.pointsDistance(pt.x, pt.y, ip.x, ip.y);
529
+ if (distToCenter <= baseDist) return;
530
+ var candidate = baseDist;
531
+ minDist = minDist !== undefined ? Math.min(minDist, candidate) : candidate;
532
+ });
533
+ pointArray.push([minDist !== null && minDist !== void 0 ? minDist : 0, angle]);
534
+ });
535
+ return pointArray;
536
+ };
537
+ var getCalcRectFromItem = function getCalcRectFromItem(item) {
538
+ if (!(item !== null && item !== void 0 && item.pos) || !(item !== null && item !== void 0 && item.size)) return {
539
+ rectCenterPoint: []
540
+ };
541
+ var _item$pos = item.pos,
542
+ x = _item$pos.x,
543
+ y = _item$pos.y;
544
+ var w = item.size.width / 2;
545
+ var h = item.size.height / 2;
546
+ var rotRad = item.rotRad;
547
+ var mh = 3 * h / 4;
548
+ var mx = x - w * Math.cos(rotRad) - mh * Math.sin(rotRad);
549
+ var my = y - w * Math.sin(rotRad) + mh * Math.cos(rotRad);
550
+ var m2x = x + w * Math.cos(rotRad) - mh * Math.sin(rotRad);
551
+ var m2y = y + w * Math.sin(rotRad) + mh * Math.cos(rotRad);
552
+ var m3x = x - h * Math.sin(rotRad);
553
+ var m3y = y + h * Math.cos(rotRad);
554
+ var m1x = x + h * Math.sin(rotRad);
555
+ var m1y = y - h * Math.cos(rotRad);
556
+ return {
557
+ rectCenterPoint: [[point(mx, my), 180], [point(m1x, m1y), -90], [point(m2x, m2y), 0], [point(m3x, m3y), 90]]
558
+ };
559
+ };
560
+ var getConnectedLines = function getConnectedLines() {
561
+ var _state$getIn;
562
+ var vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
563
+ var lines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
564
+ var lineID = state.getIn(['scene', 'layers', layerID, 'selected', 'lines']).first();
565
+ var drawingLine = (_state$getIn = state.getIn(['scene', 'layers', layerID, 'lines', lineID])) === null || _state$getIn === void 0 ? void 0 : _state$getIn.toJS();
566
+ // get the lines that have same points with drawing line.
567
+ if (!(0, _helper.isEmpty)(drawingLine)) {
568
+ var tlines = [];
569
+ getRelatedLines(tlines, drawingLine, vertices, lines);
570
+ setRelatedLines(tlines);
571
+ }
572
+ };
573
+ var onMouseMove = function onMouseMove(viewerEvent) {
574
+ //workaround that allow imageful component to work
575
+
576
+ // let evt = new Event('mousemove-planner-event');
577
+ // evt.viewerEvent = viewerEvent;
578
+ // document.dispatchEvent(evt);
579
+ var _mapCursorPosition = mapCursorPosition(viewerEvent),
580
+ x = _mapCursorPosition.x,
581
+ y = _mapCursorPosition.y;
582
+ projectActions.updateMouseCoord({
583
+ x: x,
584
+ y: y
585
+ });
586
+ if (sFlag) {
587
+ var differs = {
588
+ x: x - sPoint.x,
589
+ y: y - sPoint.y
590
+ };
591
+ projectActions.selectAll(differs);
592
+ } else {
593
+ switch (mode) {
594
+ case constants.MODE_DRAWING_LINE:
595
+ // check whether the drawing line is started.
596
+ var lineID = state.getIn(['scene', 'layers', layerID, 'selected', 'lines']).first();
597
+ var lines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
598
+ var drawingLine = state.getIn(['scene', 'layers', layerID, 'lines', lineID]).toJS();
599
+ var tlines = [];
600
+ if (drawStart || state.getIn(['scene', 'setLineAttributes'])) {
601
+ var _vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
602
+ setdrawStart(false);
603
+ // get the lines that have same points with drawing line.
604
+ getRelatedLines(tlines, drawingLine, _vertices, lines);
605
+ setRelatedLines(tlines);
606
+ linesActions.updateDrawingLine(x, y, tlines, state.snapMask);
607
+ } else {
608
+ linesActions.updateDrawingLine(x, y, relatedLines, state.snapMask);
609
+ }
610
+
611
+ // Blocked 90 degree snap.
612
+ // let prevVertexID = state.getIn(['scene', 'layers', layerID, 'selected', 'vertices']).toJS()[0];
613
+ // let prevVertex = state.getIn(['scene', 'layers', layerID, 'vertices', prevVertexID]);
614
+ // let dx = Math.abs(x - prevVertex.x);
615
+ // let dy = Math.abs(y - prevVertex.y);
616
+ // if (dx > dy) y = prevVertex.y
617
+ // else x = prevVertex.x;
618
+ break;
619
+ case constants.MODE_DRAWING_HOLE:
620
+ holesActions.updateDrawingHole(layerID, x, y);
621
+ break;
622
+ case constants.MODE_DRAWING_ITEM:
623
+ var _layer = scene.layers.get(layerID);
624
+ var flag = false;
625
+ _layer.items.some(function (item) {
626
+ if (item.selected) {
627
+ item.counterTop.uri = _layer.counterTop.uri;
628
+ current_sel_obj_id = item.id;
629
+ flag = true;
630
+ }
631
+ });
632
+ if (current_sel_obj_id === null || !flag) {
633
+ itemsActions.updateDrawingItem(layerID, x, y);
634
+ endPoint.x = x;
635
+ endPoint.y = y;
636
+ } else {
637
+ prepareSnap();
638
+ var _GeometryUtils$calcSn = _export2.GeometryUtils.calcSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, x, y, allArea),
639
+ nx = _GeometryUtils$calcSn.nx,
640
+ ny = _GeometryUtils$calcSn.ny,
641
+ rot = _GeometryUtils$calcSn.rot,
642
+ rotRad = _GeometryUtils$calcSn.rotRad;
643
+ var _val = {
644
+ pos: {
645
+ x: x,
646
+ y: y
647
+ },
648
+ rotRad: rotRad,
649
+ size: allItemRect.cur && allItemRect.cur.size,
650
+ layoutpos: allItemRect.cur && allItemRect.cur.layoutpos,
651
+ is_corner: allItemRect.cur && allItemRect.cur.is_corner
652
+ };
653
+ var _GeometryUtils$getAll = _export2.GeometryUtils.getAllHoleRect(scene, _val),
654
+ _isSect = _GeometryUtils$getAll.isSect,
655
+ _snap = _GeometryUtils$getAll.snap;
656
+ if (!(0, _helper.isEmpty)(_snap) && _isSect) {
657
+ if (_snap.length == 1) _val.pos = {
658
+ x: _snap[0].x,
659
+ y: _snap[0].y
660
+ };else {
661
+ if ((_snap[0].x - x) * (_snap[0].x - x) + (_snap[0].y - y) * (_snap[0].y - y) < (_snap[1].x - x) * (_snap[1].x - x) + (_snap[1].y - y) * (_snap[1].y - y)) _val.pos = {
662
+ x: _snap[0].x,
663
+ y: _snap[0].y
664
+ };else _val.pos = {
665
+ x: _snap[1].x,
666
+ y: _snap[1].y
667
+ };
668
+ }
669
+ var interSect = _export2.GeometryUtils.validInterSect(allItemRect.others, _val);
670
+ if (interSect) {
671
+ nx = _val.pos.x;
672
+ ny = _val.pos.y;
673
+ }
674
+ }
675
+ _val.pos = {
676
+ x: nx,
677
+ y: ny
678
+ };
679
+ var _isrectSect = _export2.GeometryUtils.validInterSect(allItemRect.others, _val);
680
+ if (_isrectSect && _isSect) {
681
+ itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
682
+ itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
683
+ endPoint.x = nx;
684
+ endPoint.y = ny;
685
+ }
686
+ if (allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cook Top') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('cabinet')) {
687
+ itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
688
+ itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
689
+ endPoint.x = nx;
690
+ endPoint.y = ny;
691
+ }
692
+ if (allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Hood') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Range') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cook Top')) {
693
+ itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
694
+ itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
695
+ endPoint.x = nx;
696
+ endPoint.y = ny;
697
+ }
698
+ }
699
+ break;
700
+ case constants.MODE_DRAGGING_HOLE:
701
+ holesActions.updateDraggingHole(x, y);
702
+ break;
703
+ case constants.MODE_DRAGGING_LINE:
704
+ linesActions.updateDraggingLine(x, y, relatedLines, state.snapMask);
705
+ break;
706
+ case constants.MODE_DRAGGING_VERTEX:
707
+ var vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
708
+ getConnectedLines();
709
+ var result = getEndPoint(vertices, x, y, 'DRAGGING_VERTEX');
710
+ verticesActions.updateDraggingVertex(result.x, result.y, state.snapMask);
711
+ break;
712
+ case constants.MODE_DRAGGING_ITEM:
713
+ prepareSnap();
714
+ var _GeometryUtils$calcSn2 = _export2.GeometryUtils.calcSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, x, y, allArea),
715
+ nx = _GeometryUtils$calcSn2.nx,
716
+ ny = _GeometryUtils$calcSn2.ny,
717
+ rot = _GeometryUtils$calcSn2.rot,
718
+ rotRad = _GeometryUtils$calcSn2.rotRad;
719
+ var val = {
720
+ pos: {
721
+ x: x,
722
+ y: y
723
+ },
724
+ rotRad: rotRad,
725
+ size: allItemRect.cur && allItemRect.cur.size,
726
+ layoutpos: allItemRect.cur && allItemRect.cur.layoutpos,
727
+ is_corner: allItemRect.cur && allItemRect.cur.is_corner
728
+ };
729
+ var _GeometryUtils$getAll2 = _export2.GeometryUtils.getAllHoleRect(scene, val),
730
+ isSect = _GeometryUtils$getAll2.isSect,
731
+ snap = _GeometryUtils$getAll2.snap;
732
+ if (!(0, _helper.isEmpty)(snap) && isSect) {
733
+ if (snap.length == 1) val.pos = {
734
+ x: snap[0].x,
735
+ y: snap[0].y
736
+ };else if (snap.length == 2) {
737
+ if ((snap[0].x - x) * (snap[0].x - x) + (snap[0].y - y) * (snap[0].y - y) < (snap[1].x - x) * (snap[1].x - x) + (snap[1].y - y) * (snap[1].y - y)) val.pos = {
738
+ x: snap[0].x,
739
+ y: snap[0].y
740
+ };else val.pos = {
741
+ x: snap[1].x,
742
+ y: snap[1].y
743
+ };
744
+ }
745
+ var _interSect = _export2.GeometryUtils.validInterSect(allItemRect.others, val);
746
+ if (_interSect) {
747
+ nx = val.pos.x;
748
+ ny = val.pos.y;
749
+ }
750
+ }
751
+ val.pos = {
752
+ x: nx,
753
+ y: ny
754
+ };
755
+ var isrectSect = _export2.GeometryUtils.validInterSect(allItemRect.others, val);
756
+ if (isrectSect && isSect) {
757
+ itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
758
+ itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
759
+ }
760
+ if (allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cook Top') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cabinet')) {
761
+ itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
762
+ itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
763
+ }
764
+ if (allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Hood') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Range') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cook Top')) {
765
+ itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
766
+ itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
767
+ }
768
+ break;
769
+ case constants.MODE_ROTATING_ITEM:
770
+ itemsActions.updateRotatingItem(x, y);
771
+ break;
772
+ }
773
+ }
774
+ viewerEvent.originalEvent.stopPropagation();
775
+ };
776
+ var onMouseDown = function onMouseDown(viewerEvent) {
777
+ var event = viewerEvent.originalEvent;
778
+ //workaround that allow imageful component to work
779
+ // let evt = new Event('mousedown-planner-event');
780
+ // evt.viewerEvent = viewerEvent;
781
+ // document.dispatchEvent(evt);
782
+ var _mapCursorPosition2 = mapCursorPosition(viewerEvent),
783
+ x = _mapCursorPosition2.x,
784
+ y = _mapCursorPosition2.y;
785
+ var layer = state.scene.getIn(['layers', state.scene.selectedLayer]);
786
+ var sCount = layer.selected.areas.size + layer.selected.holes.size + layer.selected.items.size + layer.selected.lines.size;
787
+ if (mode === constants.MODE_DRAWING_LINE) {
788
+ if (event.nativeEvent.which === 3) {
789
+ projectActions.rollback();
790
+ event.stopPropagation();
791
+ return;
792
+ }
793
+ }
794
+ mouseDownPoint = {
795
+ x: x,
796
+ y: y
797
+ };
798
+ if (mode === constants.MODE_IDLE) {
799
+ var elementData = extractElementData(event.target);
800
+ if (!elementData) return;
801
+ if (sCount < 2) {
802
+ switch (elementData.prototype) {
803
+ case 'lines':
804
+ if (elementData.selected) {
805
+ if (elementData.part === 'remove') break;else if (elementData.part === 'elevation') break;
806
+ linesActions.beginDraggingLine(elementData.layer, elementData.id, x, y, state.snapMask);
807
+ }
808
+ break;
809
+ case 'vertices':
810
+ verticesActions.beginDraggingVertex(elementData.layer, elementData.id, x, y, state.snapMask);
811
+ break;
812
+ case 'items':
813
+ setToolbar('');
814
+ current_sel_obj_id = elementData.id;
815
+ if (elementData.part === 'rotation-anchor') itemsActions.beginRotatingItem(elementData.layer, elementData.id, x, y);else if (elementData.part === 'remove') break;else if (elementData.part === 'duplicate') break;else if (elementData.part === 'warning_edit') break;else {
816
+ // closes the setting dialog
817
+ if (document.getElementById('setting_dialog')) {
818
+ document.getElementById('setting_dialog').style.display = 'none';
819
+ }
820
+ itemsActions.selectItem(elementData.layer, elementData.id);
821
+ // projectActions.setMode(constants.MODE_DRAGGING_ITEM);
822
+ itemsActions.beginDraggingItem(elementData.layer, elementData.id, x, y);
823
+ replaceCabinet(false);
824
+ }
825
+ break;
826
+ case 'holes':
827
+ if (elementData.selected) holesActions.beginDraggingHole(elementData.layer, elementData.id, x, y);
828
+ break;
829
+ default:
830
+ break;
831
+ }
832
+ } else {
833
+ sPoint.x = x;
834
+ sPoint.y = y;
835
+ sFlag = true;
836
+ }
837
+ }
838
+ event.stopPropagation();
839
+ };
840
+ var onMouseUp = function onMouseUp(viewerEvent) {
841
+ //set move all flag false
842
+ sFlag = false;
843
+ var event = viewerEvent.originalEvent;
844
+ var parent = document.querySelector('#kitchen-simulator-container');
845
+ var targetRect = event.target.getBoundingClientRect();
846
+ var left = targetRect.left;
847
+ var top = targetRect.top;
848
+ if (!(0, _helper.isEmpty)(parent)) {
849
+ var parentRect = parent.getBoundingClientRect();
850
+ left = targetRect.left - parentRect.left;
851
+ top = targetRect.top - parentRect.top;
852
+ left = left - (200 - targetRect.width) / 2;
853
+ top = top - (50 - targetRect.height) / 2;
854
+ }
855
+ if (!mode.includes('ING')) {
856
+ setToolbar('');
857
+ }
858
+ if (event.target.tagName === 'rect') {
859
+ if (event.target.id) {
860
+ setRulerEditID(event.target.id);
861
+ }
862
+ }
863
+ setRulerEdit(null);
864
+ // let evt = new Event('mouseup-planner-event');
865
+ // evt.viewerEvent = viewerEvent;
866
+ // document.dispatchEvent(evt);
867
+
868
+ var _mapCursorPosition3 = mapCursorPosition(viewerEvent),
869
+ x = _mapCursorPosition3.x,
870
+ y = _mapCursorPosition3.y;
871
+ var draggingDistance = Math.sqrt((x - mouseDownPoint.x) * (x - mouseDownPoint.x) + (y - mouseDownPoint.y) * (y - mouseDownPoint.y));
872
+ var vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
873
+ var lines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
874
+ var elementData = extractElementData(event.target);
875
+ var selectedLayer = scene.getIn(['layers', layerID]);
876
+ var elementPrototype = null;
877
+ var internalType = null;
878
+ switch (mode) {
879
+ case constants.MODE_DRAWING_LINE:
880
+ elementPrototype = 'lines';
881
+ internalType = _constants.INTERNAL_EVENT_DRAW_ELEMENT;
882
+ break;
883
+ case constants.MODE_DRAWING_HOLE:
884
+ elementPrototype = 'holes';
885
+ internalType = _constants.INTERNAL_EVENT_DRAW_ELEMENT;
886
+ break;
887
+ case constants.MODE_DRAWING_ITEM:
888
+ elementPrototype = 'items';
889
+ internalType = _constants.INTERNAL_EVENT_DRAW_ELEMENT;
890
+ break;
891
+ case constants.MODE_DRAGGING_LINE:
892
+ elementPrototype = 'lines';
893
+ internalType = _constants.INTERNAL_EVENT_DRAG_ELEMENT;
894
+ break;
895
+ case constants.MODE_DRAGGING_HOLE:
896
+ elementPrototype = 'holes';
897
+ internalType = _constants.INTERNAL_EVENT_DRAG_ELEMENT;
898
+ break;
899
+ case constants.MODE_DRAGGING_VERTEX:
900
+ elementPrototype = 'lines';
901
+ internalType = _constants.INTERNAL_EVENT_DRAG_ELEMENT;
902
+ break;
903
+ case constants.MODE_ROTATING_ITEM:
904
+ elementPrototype = 'items';
905
+ internalType = _constants.INTERNAL_EVENT_ROTATE_ELEMENT;
906
+ break;
907
+
908
+ // item selection be came from dragging mode
909
+ case constants.MODE_DRAGGING_ITEM:
910
+ elementPrototype = 'items';
911
+ internalType = _constants.INTERNAL_EVENT_SELECT_ELEMENT;
912
+ break;
913
+ case constants.MODE_IDLE:
914
+ switch (elementData === null || elementData === void 0 ? void 0 : elementData.prototype) {
915
+ case 'areas':
916
+ case 'lines':
917
+ case 'holes':
918
+ if ((0, _helper.isEmpty)(elementData === null || elementData === void 0 ? void 0 : elementData.part)) {
919
+ elementPrototype = elementData === null || elementData === void 0 ? void 0 : elementData.prototype;
920
+ internalType = _constants.INTERNAL_EVENT_SELECT_ELEMENT;
921
+ }
922
+ break;
923
+ }
924
+ break;
925
+ }
926
+ switch (mode) {
927
+ case constants.MODE_IDLE:
928
+ switch (elementData ? elementData.prototype : 'none') {
929
+ case 'areas':
930
+ if (document.getElementById('setting_dialog')) {
931
+ document.getElementById('setting_dialog').style.display = 'none';
932
+ }
933
+ areaActions.selectArea(elementData.layer, elementData.id);
934
+ break;
935
+ case 'lines':
936
+ if (document.getElementById('setting_dialog')) {
937
+ document.getElementById('setting_dialog').style.display = 'none';
938
+ }
939
+ if (elementData.part === 'remove') {
940
+ projectActions.remove();
941
+ break;
942
+ } else if (elementData.part === 'elevation') {
943
+ // handle action when click elevation about selected line
944
+ var _mode = _constants.MODE_ELEVATION_VIEW;
945
+ projectActions.setMode(_mode);
946
+ internalType = constants.INTERNAL_EVENT_TOGGLE_TO_ELEVATION;
947
+ break;
948
+ } else {
949
+ var tlines = [];
950
+ var drawingLine = state.getIn(['scene', 'layers', layerID, 'lines', elementData.id]).toJS();
951
+ getRelatedLines(tlines, drawingLine, vertices, lines);
952
+ setRelatedLines(tlines);
953
+ linesActions.selectLine(elementData.layer, elementData.id);
954
+ break;
955
+ }
956
+ case 'holes':
957
+ if (document.getElementById('setting_dialog')) {
958
+ document.getElementById('setting_dialog').style.display = 'none';
959
+ }
960
+ holesActions.selectHole(elementData.layer, elementData.id);
961
+ break;
962
+ case 'items':
963
+ if (elementData.part === 'duplicate') {
964
+ var currentObject = state.getIn(['scene', 'layers', layerID, 'items', elementData.id]);
965
+ if (!(0, _cabinetWarning.isWarningCabinet)(currentObject)) itemsActions.duplicateSelected(currentObject, onInternalEvent); // send draw internal event when duplicating
966
+ break;
967
+ } else if (elementData.part === 'remove') {
968
+ projectActions.remove();
969
+ break;
970
+ } else if (elementData.part === 'warning_edit') {
971
+ // closes the setting dialog
972
+ if (document.getElementById('setting_dialog')) {
973
+ document.getElementById('setting_dialog').style.display = 'none';
974
+ }
975
+ internalType = constants.INTERNAL_EVENT_REPLACE_CABINET;
976
+ itemsActions.selectItem(elementData.layer, elementData.id);
977
+ replaceCabinet(true);
978
+ break;
979
+ } else {
980
+ projectActions.unselectAll();
981
+ break;
982
+ }
983
+ case 'rulerDist':
984
+ var _length1 = (0, _convertUnitsLite.convert)(elementData.length).from(scene.unit).to(scene.rulerUnit);
985
+ var distanceText1 = "".concat((0, _math.formatNumber)(_length1, _constants.DECIMAL_PLACES_2));
986
+ var numberInput1 = /*#__PURE__*/_react["default"].createElement("div", {
987
+ id: "ruler_numberInput",
988
+ style: {
989
+ position: 'absolute',
990
+ left: left,
991
+ top: top,
992
+ zIndex: 1000
993
+ }
994
+ }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
995
+ style: {
996
+ textAlign: 'center',
997
+ paddingRight: 10,
998
+ fontSize: '16px',
999
+ lineHeight: '22px',
1000
+ fontWeight: 600
1001
+ },
1002
+ value: distanceText1,
1003
+ onChange: function onChange(event) {
1004
+ var value = new _immutable.Map({
1005
+ length: (0, _convertUnitsLite.convert)(event.target.value).from(scene.rulerUnit).to(scene.unit),
1006
+ _length: event.target.value,
1007
+ _unit: scene.rulerUnit
1008
+ });
1009
+ updateRulerDistAttribute(elementData, value);
1010
+ },
1011
+ precision: 2
1012
+ }));
1013
+ setRulerEdit(numberInput1);
1014
+ projectActions.unselectAll();
1015
+ break;
1016
+ case 'ruler':
1017
+ var _length = (0, _convertUnitsLite.convert)(elementData.length).from(scene.unit).to(selectedLayer.unit);
1018
+ var numberInput = /*#__PURE__*/_react["default"].createElement("div", {
1019
+ id: "ruler_numberInput",
1020
+ style: {
1021
+ position: 'absolute',
1022
+ left: left,
1023
+ top: top,
1024
+ zIndex: 1000
1025
+ }
1026
+ }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1027
+ style: {
1028
+ textAlign: 'center',
1029
+ paddingRight: 10,
1030
+ fontSize: '16px',
1031
+ lineHeight: '22px',
1032
+ fontWeight: 600
1033
+ },
1034
+ value: (0, _math.formatNumber)(_length, _constants.DECIMAL_PLACES_2),
1035
+ onChange: function onChange(event) {
1036
+ var value = new _immutable.Map({
1037
+ length: (0, _convertUnitsLite.convert)(event.target.value).from(selectedLayer.unit).to(scene.unit),
1038
+ _length: event.target.value,
1039
+ _unit: selectedLayer.unit
1040
+ });
1041
+ updateRulerAttribute(elementData, value);
1042
+ },
1043
+ precision: 2
1044
+ }));
1045
+ setRulerEdit(numberInput);
1046
+ projectActions.unselectAll();
1047
+ break;
1048
+ case 'twoHoleRuler':
1049
+ var _lengthTwoHoleRuler = (0, _convertUnitsLite.convert)(elementData.length).from(scene.unit).to(scene.rulerUnit);
1050
+ var distanceTextTwoHoleRuler = "".concat((0, _math.formatNumber)(_lengthTwoHoleRuler, _constants.DECIMAL_PLACES_2));
1051
+ var numberInputTwoHoleRuler = /*#__PURE__*/_react["default"].createElement("div", {
1052
+ id: "ruler_numberInput",
1053
+ style: {
1054
+ position: 'absolute',
1055
+ left: left,
1056
+ top: top,
1057
+ zIndex: 1000
1058
+ }
1059
+ }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1060
+ style: {
1061
+ textAlign: 'center',
1062
+ padding: 'auto',
1063
+ fontSize: '16px',
1064
+ lineHeight: '22px',
1065
+ fontWeight: 600
1066
+ },
1067
+ value: distanceTextTwoHoleRuler,
1068
+ onChange: function onChange(event) {
1069
+ var value = new _immutable.Map({
1070
+ length: (0, _convertUnitsLite.convert)(event.target.value / 2).from(scene.rulerUnit).to(scene.unit),
1071
+ _length: event.target.value / 2,
1072
+ _unit: scene.rulerUnit
1073
+ });
1074
+ updateTwoHoleRulerAttribute(elementData, value);
1075
+ },
1076
+ precision: 2
1077
+ }));
1078
+ setRulerEdit(numberInputTwoHoleRuler);
1079
+ projectActions.unselectAll();
1080
+ break;
1081
+ case 'leftHoleRuler':
1082
+ var _lengthLeftHoleRuler = (0, _convertUnitsLite.convert)(elementData.length).from(scene.unit).to(scene.rulerUnit);
1083
+ var distanceTextLeftHoleRuler = "".concat(_lengthLeftHoleRuler.toFixed(2));
1084
+ var numberInputLeftHoleRuler = /*#__PURE__*/_react["default"].createElement("div", {
1085
+ id: "ruler_numberInput",
1086
+ style: {
1087
+ position: 'absolute',
1088
+ left: left,
1089
+ top: top,
1090
+ zIndex: 1000
1091
+ }
1092
+ }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1093
+ style: {
1094
+ textAlign: 'center',
1095
+ paddingRight: 10,
1096
+ fontSize: '16px',
1097
+ lineHeight: '22px',
1098
+ fontWeight: 600
1099
+ },
1100
+ value: distanceTextLeftHoleRuler,
1101
+ onChange: function onChange(event) {
1102
+ var value = new _immutable.Map({
1103
+ length: (0, _convertUnitsLite.convert)(event.target.value).from(scene.rulerUnit).to(scene.unit),
1104
+ _length: event.target.value,
1105
+ _unit: scene.rulerUnit
1106
+ });
1107
+ updateLeftHoleRulerAttribute(elementData, value);
1108
+ },
1109
+ precision: 2
1110
+ }));
1111
+ setRulerEdit(numberInputLeftHoleRuler);
1112
+ projectActions.unselectAll();
1113
+ break;
1114
+ case 'rulerHole':
1115
+ var _lengthRulerHole = (0, _convertUnitsLite.convert)(elementData.length).from(scene.unit).to(scene.rulerUnit);
1116
+ var distanceTextRulerHole = "".concat((0, _math.formatNumber)(_lengthRulerHole, _constants.DECIMAL_PLACES_2));
1117
+ var numberInputRulerHole = /*#__PURE__*/_react["default"].createElement("div", {
1118
+ id: "ruler_numberInput",
1119
+ style: {
1120
+ position: 'absolute',
1121
+ left: left,
1122
+ top: top,
1123
+ zIndex: 1000
1124
+ }
1125
+ }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1126
+ style: {
1127
+ textAlign: 'center',
1128
+ paddingRight: 10,
1129
+ fontSize: '16px',
1130
+ lineHeight: '22px',
1131
+ fontWeight: 600
1132
+ },
1133
+ value: distanceTextRulerHole,
1134
+ onChange: function onChange(event) {
1135
+ var value = new _immutable.Map({
1136
+ length: (0, _convertUnitsLite.convert)(event.target.value).from(scene.rulerUnit).to(scene.unit),
1137
+ _length: event.target.value,
1138
+ _unit: scene.rulerUnit
1139
+ });
1140
+ updateHoleRulerAttribute(elementData, value);
1141
+ },
1142
+ precision: 2
1143
+ }));
1144
+ setRulerEdit(numberInputRulerHole);
1145
+ projectActions.unselectAll();
1146
+ break;
1147
+ case 'rightHoleRuler':
1148
+ var _lengthRightHoleRuler = (0, _convertUnitsLite.convert)(elementData.length).from(scene.unit).to(scene.rulerUnit);
1149
+ var distanceTextRightHoleRuler = "".concat(_lengthRightHoleRuler.toFixed(2));
1150
+ var numberInputRightHoleRuler = /*#__PURE__*/_react["default"].createElement("div", {
1151
+ id: "ruler_numberInput",
1152
+ style: {
1153
+ position: 'absolute',
1154
+ left: left,
1155
+ top: top,
1156
+ zIndex: 1000
1157
+ }
1158
+ }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1159
+ style: {
1160
+ textAlign: 'center',
1161
+ paddingRight: 10,
1162
+ fontSize: '16px',
1163
+ lineHeight: '22px',
1164
+ fontWeight: 600
1165
+ },
1166
+ value: distanceTextRightHoleRuler,
1167
+ onChange: function onChange(event) {
1168
+ var value = new _immutable.Map({
1169
+ length: (0, _convertUnitsLite.convert)(event.target.value).from(scene.rulerUnit).to(scene.unit),
1170
+ _length: event.target.value,
1171
+ _unit: scene.rulerUnit
1172
+ });
1173
+ updateRightHoleRulerAttribute(elementData, value);
1174
+ },
1175
+ precision: 2
1176
+ }));
1177
+ setRulerEdit(numberInputRightHoleRuler);
1178
+ projectActions.unselectAll();
1179
+ break;
1180
+ case 'angleChange':
1181
+ var _length2 = elementData.length;
1182
+ var numberInput2 = /*#__PURE__*/_react["default"].createElement("div", {
1183
+ id: "ruler_numberInput",
1184
+ style: {
1185
+ position: 'absolute',
1186
+ left: left,
1187
+ top: top,
1188
+ zIndex: 1000
1189
+ }
1190
+ }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1191
+ style: {
1192
+ width: 50,
1193
+ height: 50
1194
+ },
1195
+ value: _length2,
1196
+ onChange: function onChange(event) {
1197
+ var value = new _immutable.Map({
1198
+ length: (0, _convertUnitsLite.convert)(event.target.value).from(scene.rulerUnit).to(scene.unit),
1199
+ _length: event.target.value,
1200
+ _unit: scene.rulerUnit
1201
+ });
1202
+ updateangleChangeAttribute(elementData, value);
1203
+ },
1204
+ precision: 2
1205
+ }));
1206
+ setRulerEdit(numberInput2);
1207
+ projectActions.unselectAll();
1208
+ break;
1209
+ case 'none':
1210
+ projectActions.unselectAll();
1211
+ break;
1212
+ }
1213
+ break;
1214
+ case constants.MODE_WAITING_DRAWING_LINE:
1215
+ setdrawStart(true);
1216
+ linesActions.beginDrawingLine(layerID, x, y, state.snapMask, onInternalEvent);
1217
+ break;
1218
+ case constants.MODE_DRAWING_LINE:
1219
+ // Blocked 90 degree snap.
1220
+ // let prevVertexID = state.getIn(['scene', 'layers', layerID, 'selected', 'vertices']).toJS()[0];
1221
+ // let prevVertex = state.getIn(['scene', 'layers', layerID, 'vertices', prevVertexID]);
1222
+ // let dx = Math.abs(x - prevVertex.x);
1223
+ // let dy = Math.abs(y - prevVertex.y);
1224
+ // if (dx > dy) y = prevVertex.y
1225
+ // else x = prevVertex.x;
1226
+ setdrawStart(true);
1227
+ getConnectedLines();
1228
+ var endInfor = getEndPoint(vertices, x, y, 'END_DRAWIN_LINE');
1229
+ linesActions.endDrawingLine(endInfor.x, endInfor.y, state.snapMask);
1230
+ linesActions.beginDrawingLine(layerID, endInfor.x, endInfor.y, state.snapMask, onInternalEvent);
1231
+ break;
1232
+ case constants.MODE_DRAWING_HOLE:
1233
+ holesActions.endDrawingHole(layerID, x, y);
1234
+ break;
1235
+ case constants.MODE_DRAWING_ITEM:
1236
+ {
1237
+ var itemData = state.getIn(['scene', 'layers', layerID, elementData === null || elementData === void 0 ? void 0 : elementData.prototype, elementData === null || elementData === void 0 ? void 0 : elementData.id]);
1238
+ itemsActions.endDrawingItem(layerID, itemData.isInitialPos ? itemData.x : endPoint.x, itemData.isInitialPos ? itemData.y : endPoint.y);
1239
+ }
1240
+ break;
1241
+ case constants.MODE_DRAGGING_LINE:
1242
+ linesActions.endDraggingLine(x, y, relatedLines, state.snapMask);
1243
+ break;
1244
+ case constants.MODE_DRAGGING_VERTEX:
1245
+ getConnectedLines();
1246
+ var result = getEndPoint(vertices, x, y, 'DRAGGING_VERTEX');
1247
+ verticesActions.endDraggingVertex(result.x, result.y, state.snapMask);
1248
+ break;
1249
+ case constants.MODE_DRAGGING_ITEM:
1250
+ itemsActions.updateMolding();
1251
+ projectActions.setMode(_constants.MODE_IDLE);
1252
+ break;
1253
+ case constants.MODE_DRAGGING_HOLE:
1254
+ holesActions.endDraggingHole(x, y);
1255
+ break;
1256
+ case constants.MODE_ROTATING_ITEM:
1257
+ itemsActions.endRotatingItem(x, y);
1258
+ break;
1259
+ }
1260
+ if (internalType) {
1261
+ var _currentObject2;
1262
+ var _currentObject = state.getIn(['scene', 'layers', layerID, elementData === null || elementData === void 0 ? void 0 : elementData.prototype, elementData === null || elementData === void 0 ? void 0 : elementData.id]);
1263
+ if (internalType === _constants.INTERNAL_EVENT_SELECT_ELEMENT && ((_currentObject2 = _currentObject) === null || _currentObject2 === void 0 ? void 0 : _currentObject2.prototype) === 'items' && draggingDistance > constants.EPSILON) internalType = _constants.INTERNAL_EVENT_DRAG_ELEMENT;else if (internalType === _constants.INTERNAL_EVENT_DRAW_ELEMENT || draggingDistance > constants.EPSILON) {
1264
+ var elementID = state.getIn(['scene', 'layers', layerID, 'selected', elementPrototype]).first();
1265
+ _currentObject = state.getIn(['scene', 'layers', layerID, elementPrototype, elementID]);
1266
+ }
1267
+ if (_currentObject) {
1268
+ var payload = (0, _helper.updatePayloadOfInternalEvent)(_currentObject, layer);
1269
+
1270
+ // send selection event befor replace event
1271
+ if (internalType === constants.INTERNAL_EVENT_REPLACE_CABINET) {
1272
+ onInternalEvent === null || onInternalEvent === void 0 || onInternalEvent({
1273
+ type: _constants.INTERNAL_EVENT_SELECT_ELEMENT,
1274
+ value: payload
1275
+ });
1276
+ }
1277
+ onInternalEvent === null || onInternalEvent === void 0 || onInternalEvent({
1278
+ type: internalType,
1279
+ value: payload
1280
+ });
1281
+ }
1282
+ }
1283
+ event.stopPropagation();
1284
+ };
1285
+ var onChangeValue = function onChangeValue(value) {
1286
+ if (sFlag) return;
1287
+ var _zoomValue = parseInt((value.a - 0.5) / constants.ZOOM_VARIABLE);
1288
+ if (_zoomValue > constants.MAX_ZOOM_IN_SCALE) return;
1289
+ if (_zoomValue < 0 || Number.isNaN(_zoomValue)) return;
1290
+ if (rulerEdit !== null && value.startX && value.startY || value.lastAction === 'zoom') {
1291
+ var _rulerEdit = document.getElementById('ruler_numberInput') && document.getElementById('ruler_numberInput'),
1292
+ _rect;
1293
+ if (rulerEditID !== null) {
1294
+ _rect = document.getElementById(rulerEditID) && document.getElementById(rulerEditID);
1295
+ }
1296
+ var bbox;
1297
+ if (_rect && _rulerEdit) {
1298
+ bbox = _rect.getBoundingClientRect();
1299
+ _rulerEdit.style.left = "".concat(bbox.left - (150 - bbox.width) / 2, "px");
1300
+ _rulerEdit.style.top = "".concat(bbox.top - (50 - bbox.height) / 2, "px");
1301
+ }
1302
+ }
1303
+ if (value.e <= 10 && value.e + value.a * value.SVGWidth + 10 >= value.viewerWidth && value.f <= 80 && value.f + value.d * value.SVGHeight + 10 >= value.viewerHeight) {
1304
+ /*let val = Object.assign({}, value);
1305
+ if (refresh === 2) {
1306
+ val.a += 0.4; val.d += 0.4;
1307
+ val.e -= (val.SVGWidth * val.a - val.SVGWidth * (val.a - 0.4)) / 2;
1308
+ val.f -= (val.SVGHeight * val.d - val.SVGHeight * (val.d - 0.4)) / 2;
1309
+ console.log('----', val)
1310
+ }*/
1311
+ projectActions.updateZoomScale(value.a);
1312
+ return viewer2DActions.updateCameraView(value);
1313
+ }
1314
+ };
1315
+ var onChangeTool = function onChangeTool(tool) {
1316
+ switch (tool) {
1317
+ case _reactSvgPanZoom.TOOL_NONE:
1318
+ projectActions.selectToolEdit();
1319
+ break;
1320
+ case _reactSvgPanZoom.TOOL_PAN:
1321
+ viewer2DActions.selectToolPan();
1322
+ break;
1323
+ case _reactSvgPanZoom.TOOL_ZOOM_IN:
1324
+ viewer2DActions.selectToolZoomIn();
1325
+ break;
1326
+ case _reactSvgPanZoom.TOOL_ZOOM_OUT:
1327
+ viewer2DActions.selectToolZoomOut();
1328
+ break;
1329
+ }
1330
+ };
1331
+ var onZoom = function onZoom(value) {
1332
+ // var nextValue = viewer2D.toJS();
1333
+ // nextValue = zoom(nextValue, 0, 0, value.a / nextValue.a)
1334
+ // projectActions.updateZoomScale(nextValue.a);
1335
+ // return viewer2DActions.updateCameraView(nextValue)
1336
+ };
1337
+ var _state$get$toJS = state.get('viewer2D').toJS(),
1338
+ e = _state$get$toJS.e,
1339
+ f = _state$get$toJS.f,
1340
+ SVGWidth = _state$get$toJS.SVGWidth,
1341
+ SVGHeight = _state$get$toJS.SVGHeight;
1342
+ var rulerSize = 0; //px
1343
+ var rulerUnitPixelSize = 100;
1344
+ var rulerBgColor = SharedStyle.PRIMARY_COLOR.main;
1345
+ var rulerFnColor = SharedStyle.COLORS.white;
1346
+ var rulerMkColor = SharedStyle.SECONDARY_COLOR.main;
1347
+ var sceneWidth = SVGWidth || state.getIn(['scene', 'width']);
1348
+ var sceneHeight = SVGHeight || state.getIn(['scene', 'height']);
1349
+ var sceneZoom = state.zoom || 1;
1350
+ var rulerXElements = Math.ceil(sceneWidth / rulerUnitPixelSize) + 1;
1351
+ var rulerYElements = Math.ceil(sceneHeight / rulerUnitPixelSize) + 1;
1352
+ return /*#__PURE__*/_react["default"].createElement("div", null, rulerEdit, /*#__PURE__*/_react["default"].createElement("div", {
1353
+ style: {
1354
+ margin: 0,
1355
+ padding: 0,
1356
+ display: 'grid',
1357
+ gridRowGap: '0',
1358
+ gridColumnGap: '0',
1359
+ gridTemplateColumns: "".concat(rulerSize, "px ").concat(width - rulerSize, "px"),
1360
+ gridTemplateRows: "".concat(rulerSize, "px ").concat(height - rulerSize, "px"),
1361
+ position: 'relative'
1362
+ }
1363
+ }, /*#__PURE__*/_react["default"].createElement("div", {
1364
+ style: {
1365
+ gridColumn: 1,
1366
+ gridRow: 1,
1367
+ backgroundColor: rulerBgColor
1368
+ }
1369
+ }), /*#__PURE__*/_react["default"].createElement("div", {
1370
+ style: {
1371
+ gridRow: 1,
1372
+ gridColumn: 2,
1373
+ position: 'relative',
1374
+ overflow: 'hidden'
1375
+ },
1376
+ id: "rulerX"
1377
+ }, sceneWidth ? /*#__PURE__*/_react["default"].createElement(_export.RulerX, {
1378
+ unitPixelSize: rulerUnitPixelSize,
1379
+ zoom: sceneZoom,
1380
+ mouseX: state.mouse.get('x'),
1381
+ width: width - rulerSize,
1382
+ zeroLeftPosition: e || 0,
1383
+ backgroundColor: rulerBgColor,
1384
+ fontColor: rulerFnColor,
1385
+ markerColor: rulerMkColor,
1386
+ positiveUnitsNumber: rulerXElements,
1387
+ negativeUnitsNumber: 0
1388
+ }) : null), /*#__PURE__*/_react["default"].createElement("div", {
1389
+ style: {
1390
+ gridColumn: 1,
1391
+ gridRow: 2,
1392
+ position: 'relative',
1393
+ overflow: 'hidden'
1394
+ },
1395
+ id: "rulerY"
1396
+ }, sceneHeight ? /*#__PURE__*/_react["default"].createElement(_export.RulerY, {
1397
+ unitPixelSize: rulerUnitPixelSize,
1398
+ zoom: sceneZoom,
1399
+ mouseY: state.mouse.get('y'),
1400
+ height: height - rulerSize,
1401
+ zeroTopPosition: sceneHeight * sceneZoom + f || 0,
1402
+ backgroundColor: rulerBgColor,
1403
+ fontColor: rulerFnColor,
1404
+ markerColor: rulerMkColor,
1405
+ positiveUnitsNumber: rulerYElements,
1406
+ negativeUnitsNumber: 0
1407
+ }) : null), /*#__PURE__*/_react["default"].createElement(_reactSvgPanZoom.ReactSVGPanZoom, {
1408
+ style: {
1409
+ gridColumn: 2,
1410
+ gridRow: 2
1411
+ },
1412
+ width: width - rulerSize,
1413
+ height: height - rulerSize,
1414
+ value: viewer2D.isEmpty() ? null : viewer2D.toJS(),
1415
+ onChangeValue: onChangeValue,
1416
+ tool: mode2Tool(mode),
1417
+ onChangeTool: onChangeTool,
1418
+ detectAutoPan: mode2DetectAutopan(mode),
1419
+ onMouseDown: onMouseDown,
1420
+ onMouseMove: onMouseMove,
1421
+ onMouseUp: onMouseUp,
1422
+ miniaturePosition: "none",
1423
+ toolbarPosition: "none",
1424
+ detectPinchGesture: false,
1425
+ disableDoubleClickZoomWithToolAuto: true,
1426
+ ref: Viewer
1427
+ }, /*#__PURE__*/_react["default"].createElement("svg", {
1428
+ width: scene.width,
1429
+ height: scene.height
1430
+ }, /*#__PURE__*/_react["default"].createElement("defs", null, /*#__PURE__*/_react["default"].createElement("pattern", {
1431
+ id: "diagonalFill",
1432
+ patternUnits: "userSpaceOnUse",
1433
+ width: "4",
1434
+ height: "4",
1435
+ fill: "#FFF"
1436
+ }, /*#__PURE__*/_react["default"].createElement("rect", {
1437
+ x: "0",
1438
+ y: "0",
1439
+ width: "4",
1440
+ height: "4",
1441
+ fill: "#FFF"
1442
+ }), /*#__PURE__*/_react["default"].createElement("path", {
1443
+ d: "M-1,1 l2,-2 M0,4 l4,-4 M3,5 l2,-2",
1444
+ style: {
1445
+ stroke: '#8E9BA2',
1446
+ strokeWidth: 1
1447
+ }
1448
+ }))), /*#__PURE__*/_react["default"].createElement("g", {
1449
+ style: Object.assign(mode2Cursor(mode), mode2PointerEvents(mode))
1450
+ }, /*#__PURE__*/_react["default"].createElement(_state["default"], {
1451
+ state: state,
1452
+ catalog: catalog,
1453
+ viewer2DActions: viewer2DActions,
1454
+ relatedLines: relatedLines
1455
+ }))))));
1456
+ }
1457
+ Viewer2D.propTypes = {
1458
+ state: _propTypes["default"].object.isRequired,
1459
+ width: _propTypes["default"].number.isRequired,
1460
+ height: _propTypes["default"].number.isRequired
1461
+ };
1462
+ Viewer2D.contextTypes = {
1463
+ viewer2DActions: _propTypes["default"].object.isRequired,
1464
+ linesActions: _propTypes["default"].object.isRequired,
1465
+ holesActions: _propTypes["default"].object.isRequired,
1466
+ verticesActions: _propTypes["default"].object.isRequired,
1467
+ itemsActions: _propTypes["default"].object.isRequired,
1468
+ areaActions: _propTypes["default"].object.isRequired,
1469
+ projectActions: _propTypes["default"].object.isRequired,
1470
+ catalog: _propTypes["default"].object.isRequired
1471
+ };
1472
+ module.exports = exports.default;