kitchen-simulator 5.10.2-react.18 → 5.10.4-react.18

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