kitchen-simulator 5.10.1-react.18 → 5.10.2-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/index.js +3 -627
  2. package/es/index.js.LICENSE.txt +45 -0
  3. package/es/index.js.map +1 -0
  4. package/package.json +9 -5
  5. package/es/@history.js +0 -2
  6. package/es/AppContext.js +0 -6
  7. package/es/LiteKitchenConfigurator.js +0 -474
  8. package/es/LiteRenderer.js +0 -363
  9. package/es/WorkSpace.js +0 -851
  10. package/es/actions/area-actions.js +0 -14
  11. package/es/actions/export.js +0 -23
  12. package/es/actions/groups-actions.js +0 -89
  13. package/es/actions/holes-actions.js +0 -119
  14. package/es/actions/items-actions.js +0 -316
  15. package/es/actions/lines-actions.js +0 -83
  16. package/es/actions/project-actions.js +0 -298
  17. package/es/actions/scene-actions.js +0 -33
  18. package/es/actions/vertices-actions.js +0 -27
  19. package/es/actions/viewer2d-actions.js +0 -58
  20. package/es/actions/viewer3d-actions.js +0 -23
  21. package/es/assets/brown_photostudio_02_1k.hdr +0 -0
  22. package/es/assets/fonts/Rene Bieder Milliard Black Italic.woff +0 -0
  23. package/es/assets/fonts/Rene Bieder Milliard Black.woff +0 -0
  24. package/es/assets/fonts/Rene Bieder Milliard Bold Italic.woff +0 -0
  25. package/es/assets/fonts/Rene Bieder Milliard Bold.woff +0 -0
  26. package/es/assets/fonts/Rene Bieder Milliard Book Italic.woff +0 -0
  27. package/es/assets/fonts/Rene Bieder Milliard Book.woff +0 -0
  28. package/es/assets/fonts/Rene Bieder Milliard ExtraBold Italic.woff +0 -0
  29. package/es/assets/fonts/Rene Bieder Milliard ExtraBold.woff +0 -0
  30. package/es/assets/fonts/Rene Bieder Milliard ExtraLight Italic.woff +0 -0
  31. package/es/assets/fonts/Rene Bieder Milliard ExtraLight.woff +0 -0
  32. package/es/assets/fonts/Rene Bieder Milliard Hairline Italic.woff +0 -0
  33. package/es/assets/fonts/Rene Bieder Milliard Hairline.woff +0 -0
  34. package/es/assets/fonts/Rene Bieder Milliard Heavy Italic.woff +0 -0
  35. package/es/assets/fonts/Rene Bieder Milliard Heavy.woff +0 -0
  36. package/es/assets/fonts/Rene Bieder Milliard Light Italic.woff +0 -0
  37. package/es/assets/fonts/Rene Bieder Milliard Light.woff +0 -0
  38. package/es/assets/fonts/Rene Bieder Milliard Medium Italic.woff +0 -0
  39. package/es/assets/fonts/Rene Bieder Milliard Medium.woff +0 -0
  40. package/es/assets/fonts/Rene Bieder Milliard SemiBold Italic.woff +0 -0
  41. package/es/assets/fonts/Rene Bieder Milliard SemiBold.woff +0 -0
  42. package/es/assets/fonts/Rene Bieder Milliard Thin Italic.woff +0 -0
  43. package/es/assets/fonts/Rene Bieder Milliard Thin.woff +0 -0
  44. package/es/assets/fonts/style.css +0 -177
  45. package/es/assets/gltf/door_closet.bin +0 -0
  46. package/es/assets/gltf/door_closet.fbx +0 -0
  47. package/es/assets/gltf/door_closet.gltf +0 -1
  48. package/es/assets/gltf/door_exterior.bin +0 -0
  49. package/es/assets/gltf/door_exterior.fbx +0 -0
  50. package/es/assets/gltf/door_exterior.gltf +0 -1
  51. package/es/assets/gltf/door_interior.bin +0 -0
  52. package/es/assets/gltf/door_interior.fbx +0 -0
  53. package/es/assets/gltf/door_interior.gltf +0 -1
  54. package/es/assets/gltf/door_sliding.bin +0 -0
  55. package/es/assets/gltf/door_sliding.fbx +0 -0
  56. package/es/assets/gltf/door_sliding.gltf +0 -1
  57. package/es/assets/gltf/doorway_framed.bin +0 -0
  58. package/es/assets/gltf/doorway_framed.fbx +0 -0
  59. package/es/assets/gltf/doorway_framed.gltf +0 -1
  60. package/es/assets/gltf/window_clear.bin +0 -0
  61. package/es/assets/gltf/window_clear.fbx +0 -0
  62. package/es/assets/gltf/window_clear.gltf +0 -1
  63. package/es/assets/gltf/window_cross.bin +0 -0
  64. package/es/assets/gltf/window_cross.fbx +0 -0
  65. package/es/assets/gltf/window_cross.gltf +0 -1
  66. package/es/assets/gltf/window_double_hung.bin +0 -0
  67. package/es/assets/gltf/window_double_hung.fbx +0 -0
  68. package/es/assets/gltf/window_double_hung.gltf +0 -1
  69. package/es/assets/gltf/window_vertical.bin +0 -0
  70. package/es/assets/gltf/window_vertical.fbx +0 -0
  71. package/es/assets/gltf/window_vertical.gltf +0 -1
  72. package/es/assets/img/TKC_thumbnail.png +0 -0
  73. package/es/assets/img/Toggle.png +0 -0
  74. package/es/assets/img/loading/loading.gif +0 -0
  75. package/es/assets/img/loading/loading_1.svg +0 -11
  76. package/es/assets/img/loading_large.gif +0 -0
  77. package/es/assets/img/png/door/closet.png +0 -0
  78. package/es/assets/img/png/door/doorwaysframed.png +0 -0
  79. package/es/assets/img/png/door/doorwaysframeles.png +0 -0
  80. package/es/assets/img/png/door/doorwaysframeless.png +0 -0
  81. package/es/assets/img/png/door/exterior.png +0 -0
  82. package/es/assets/img/png/door/interior.png +0 -0
  83. package/es/assets/img/png/door/sliding.png +0 -0
  84. package/es/assets/img/png/helper/outcome.png +0 -0
  85. package/es/assets/img/png/helper/video_preview_3d.png +0 -0
  86. package/es/assets/img/png/helper/video_preview_start.png +0 -0
  87. package/es/assets/img/project_img.png +0 -0
  88. package/es/assets/img/rta/rta_logo_box_blue.jpg +0 -0
  89. package/es/assets/img/rta/rta_logo_box_blue_ico.jpg +0 -0
  90. package/es/assets/img/rta/rta_logo_box_blue_ico.svg +0 -55
  91. package/es/assets/img/rta/rta_logo_box_darkGray.jpg +0 -0
  92. package/es/assets/img/rta/rta_logo_box_lightblue.png +0 -0
  93. package/es/assets/img/rta/rta_logo_box_lightmaroon.png +0 -0
  94. package/es/assets/img/rta/rta_logo_box_maroon.png +0 -0
  95. package/es/assets/img/rta/rta_logo_box_white.png +0 -0
  96. package/es/assets/img/rta_menu.png +0 -0
  97. package/es/assets/img/step2.jpg +0 -0
  98. package/es/assets/img/step3.jpg +0 -0
  99. package/es/assets/img/step4.jpg +0 -0
  100. package/es/assets/img/step5.jpg +0 -0
  101. package/es/assets/img/step6.jpg +0 -0
  102. package/es/assets/img/step7.jpg +0 -0
  103. package/es/assets/img/step8.jpg +0 -0
  104. package/es/assets/img/svg/2d_delete_object.svg +0 -33
  105. package/es/assets/img/svg/2d_delete_object1.svg +0 -33
  106. package/es/assets/img/svg/2d_lock_object.svg +0 -33
  107. package/es/assets/img/svg/3d_item_move.svg +0 -106
  108. package/es/assets/img/svg/3d_item_rotation.svg +0 -76
  109. package/es/assets/img/svg/3d_item_warning_edit.svg +0 -77
  110. package/es/assets/img/svg/3d_item_warning_info.svg +0 -81
  111. package/es/assets/img/svg/accessories.svg +0 -4
  112. package/es/assets/img/svg/angle_icon.svg +0 -39
  113. package/es/assets/img/svg/blank_div.svg +0 -14
  114. package/es/assets/img/svg/bottombar/2d3d_button.svg +0 -3
  115. package/es/assets/img/svg/bottombar/2d3d_button_active.svg +0 -3
  116. package/es/assets/img/svg/bottombar/2d3d_toggle.svg +0 -4
  117. package/es/assets/img/svg/bottombar/2d3d_toggle_active.svg +0 -4
  118. package/es/assets/img/svg/bottombar/arrow-down.svg +0 -3
  119. package/es/assets/img/svg/bottombar/arrow-left.svg +0 -3
  120. package/es/assets/img/svg/bottombar/arrow-minus.svg +0 -3
  121. package/es/assets/img/svg/bottombar/arrow-plus.svg +0 -11
  122. package/es/assets/img/svg/bottombar/arrow-right.svg +0 -3
  123. package/es/assets/img/svg/bottombar/arrow-up.svg +0 -3
  124. package/es/assets/img/svg/bottombar/collapse.svg +0 -3
  125. package/es/assets/img/svg/bottombar/elevation-back.svg +0 -6
  126. package/es/assets/img/svg/bottombar/elevation-front.svg +0 -6
  127. package/es/assets/img/svg/bottombar/elevation-left.svg +0 -6
  128. package/es/assets/img/svg/bottombar/elevation-right.svg +0 -7
  129. package/es/assets/img/svg/bottombar/elevation.svg +0 -13
  130. package/es/assets/img/svg/bottombar/expand.svg +0 -3
  131. package/es/assets/img/svg/bottombar/help.svg +0 -72
  132. package/es/assets/img/svg/bottombar/incm_toggle.svg +0 -39
  133. package/es/assets/img/svg/bottombar/pan_1.svg +0 -57
  134. package/es/assets/img/svg/bottombar/pan_2.svg +0 -27
  135. package/es/assets/img/svg/bottombar/pan_3.svg +0 -27
  136. package/es/assets/img/svg/bottombar/pan_4.svg +0 -27
  137. package/es/assets/img/svg/bottombar/pan_5.svg +0 -27
  138. package/es/assets/img/svg/bottombar/settings.svg +0 -23
  139. package/es/assets/img/svg/bottombar/spin-down.svg +0 -76
  140. package/es/assets/img/svg/bottombar/spin-left.svg +0 -75
  141. package/es/assets/img/svg/bottombar/spin-right.svg +0 -75
  142. package/es/assets/img/svg/bottombar/spin-up.svg +0 -76
  143. package/es/assets/img/svg/bottombar/spin_1.svg +0 -48
  144. package/es/assets/img/svg/bottombar/spin_2.svg +0 -31
  145. package/es/assets/img/svg/bottombar/spin_3.svg +0 -31
  146. package/es/assets/img/svg/bottombar/spin_4.svg +0 -31
  147. package/es/assets/img/svg/bottombar/spin_5.svg +0 -31
  148. package/es/assets/img/svg/bottombar/zoomin.svg +0 -29
  149. package/es/assets/img/svg/bottombar/zoomout.svg +0 -26
  150. package/es/assets/img/svg/check.svg +0 -10
  151. package/es/assets/img/svg/close.svg +0 -11
  152. package/es/assets/img/svg/color/Black.svg +0 -3
  153. package/es/assets/img/svg/color/Blue.svg +0 -3
  154. package/es/assets/img/svg/color/Brown.svg +0 -9
  155. package/es/assets/img/svg/color/Cream.svg +0 -3
  156. package/es/assets/img/svg/color/Dark.svg +0 -9
  157. package/es/assets/img/svg/color/Gray.svg +0 -3
  158. package/es/assets/img/svg/color/Green.svg +0 -3
  159. package/es/assets/img/svg/color/Light.svg +0 -9
  160. package/es/assets/img/svg/color/Medium.svg +0 -9
  161. package/es/assets/img/svg/color/Unfinished.svg +0 -9
  162. package/es/assets/img/svg/color/White.svg +0 -3
  163. package/es/assets/img/svg/color/White.svg.bak +0 -3
  164. package/es/assets/img/svg/color/stone2.jpg +0 -0
  165. package/es/assets/img/svg/color/wood2.jpg +0 -0
  166. package/es/assets/img/svg/copy.svg +0 -11
  167. package/es/assets/img/svg/delete.svg +0 -3
  168. package/es/assets/img/svg/detail.svg +0 -77
  169. package/es/assets/img/svg/disclaimer/background.svg +0 -758
  170. package/es/assets/img/svg/disclaimer/logo-dots.svg +0 -11
  171. package/es/assets/img/svg/door/Closet.svg +0 -11
  172. package/es/assets/img/svg/door/Exterior.svg +0 -5
  173. package/es/assets/img/svg/door/Framed_dorway.svg +0 -5
  174. package/es/assets/img/svg/door/Frameless_dorway.svg +0 -5
  175. package/es/assets/img/svg/door/Interior.svg +0 -7
  176. package/es/assets/img/svg/door/Sliding.svg +0 -5
  177. package/es/assets/img/svg/doors_closet.svg +0 -47
  178. package/es/assets/img/svg/doors_exterior.svg +0 -25
  179. package/es/assets/img/svg/doors_interior.svg +0 -29
  180. package/es/assets/img/svg/doors_patio.svg +0 -26
  181. package/es/assets/img/svg/duplicate.svg +0 -11
  182. package/es/assets/img/svg/duplicate_object_left.svg +0 -32
  183. package/es/assets/img/svg/duplicate_object_right.svg +0 -32
  184. package/es/assets/img/svg/filtersActive.svg +0 -19
  185. package/es/assets/img/svg/firstsetting/L.svg +0 -3
  186. package/es/assets/img/svg/firstsetting/L2.svg +0 -3
  187. package/es/assets/img/svg/firstsetting/Open.svg +0 -3
  188. package/es/assets/img/svg/firstsetting/Square.svg +0 -3
  189. package/es/assets/img/svg/firstsetting/bar-active.svg +0 -9
  190. package/es/assets/img/svg/firstsetting/bar-normal.svg +0 -3
  191. package/es/assets/img/svg/firstsetting/bullet-current.svg +0 -3
  192. package/es/assets/img/svg/firstsetting/bullet-done.svg +0 -3
  193. package/es/assets/img/svg/firstsetting/bullet-not-done.svg +0 -3
  194. package/es/assets/img/svg/firstsetting/check-active.svg +0 -3
  195. package/es/assets/img/svg/firstsetting/check-normal.svg +0 -3
  196. package/es/assets/img/svg/firstsetting/pencil.svg +0 -11
  197. package/es/assets/img/svg/green_checkmark.svg +0 -27
  198. package/es/assets/img/svg/headerbar/assist.svg +0 -3
  199. package/es/assets/img/svg/headerbar/cart.svg +0 -3
  200. package/es/assets/img/svg/headerbar/check.svg +0 -10
  201. package/es/assets/img/svg/headerbar/consult_designer.svg +0 -45
  202. package/es/assets/img/svg/headerbar/edit_name.svg +0 -26
  203. package/es/assets/img/svg/headerbar/file-dollar.svg +0 -13
  204. package/es/assets/img/svg/headerbar/hamburger_menu.svg +0 -32
  205. package/es/assets/img/svg/headerbar/plus.svg +0 -11
  206. package/es/assets/img/svg/headerbar/review_quote.svg +0 -44
  207. package/es/assets/img/svg/headerbar/ruler-measure.svg +0 -11
  208. package/es/assets/img/svg/headerbar/save.svg +0 -3
  209. package/es/assets/img/svg/headerbar/setting.svg +0 -75
  210. package/es/assets/img/svg/help/check.svg +0 -10
  211. package/es/assets/img/svg/help/search.svg +0 -76
  212. package/es/assets/img/svg/intro/1-start-with-floorplan-whole.svg +0 -27
  213. package/es/assets/img/svg/intro/1-start-with-floorplan.svg +0 -26
  214. package/es/assets/img/svg/intro/2-start-from-scratch-whole.svg +0 -28
  215. package/es/assets/img/svg/intro/2-start-from-scratch.svg +0 -27
  216. package/es/assets/img/svg/intro/3-retrieve-project-whole.svg +0 -19
  217. package/es/assets/img/svg/intro/3-retrieve-project.svg +0 -18
  218. package/es/assets/img/svg/invert.svg +0 -127
  219. package/es/assets/img/svg/lefttoolbar/appliance-active.svg +0 -13
  220. package/es/assets/img/svg/lefttoolbar/appliance.svg +0 -13
  221. package/es/assets/img/svg/lefttoolbar/cabinet-active.svg +0 -10
  222. package/es/assets/img/svg/lefttoolbar/cabinet-category.svg +0 -3
  223. package/es/assets/img/svg/lefttoolbar/cabinet-one.svg +0 -3
  224. package/es/assets/img/svg/lefttoolbar/cabinet.svg +0 -10
  225. package/es/assets/img/svg/lefttoolbar/disigner_assistance.svg +0 -89
  226. package/es/assets/img/svg/lefttoolbar/door-style-active.svg +0 -20
  227. package/es/assets/img/svg/lefttoolbar/door-style.svg +0 -20
  228. package/es/assets/img/svg/lefttoolbar/door.svg +0 -12
  229. package/es/assets/img/svg/lefttoolbar/error_icon.svg +0 -81
  230. package/es/assets/img/svg/lefttoolbar/finishing-active.svg +0 -13
  231. package/es/assets/img/svg/lefttoolbar/finishing.svg +0 -13
  232. package/es/assets/img/svg/lefttoolbar/reviewforquote-active.svg +0 -86
  233. package/es/assets/img/svg/lefttoolbar/reviewforquote.svg +0 -12
  234. package/es/assets/img/svg/lefttoolbar/room-shape-L.svg +0 -3
  235. package/es/assets/img/svg/lefttoolbar/room-shape-active.svg +0 -18
  236. package/es/assets/img/svg/lefttoolbar/room-shape-custom.svg +0 -12
  237. package/es/assets/img/svg/lefttoolbar/room-shape-irregular.svg +0 -3
  238. package/es/assets/img/svg/lefttoolbar/room-shape-open.svg +0 -3
  239. package/es/assets/img/svg/lefttoolbar/room-shape-square.svg +0 -3
  240. package/es/assets/img/svg/lefttoolbar/room-shape.svg +0 -18
  241. package/es/assets/img/svg/lefttoolbar/search.svg +0 -76
  242. package/es/assets/img/svg/lefttoolbar/view_more.svg +0 -86
  243. package/es/assets/img/svg/lefttoolbar/warning_icon.svg +0 -81
  244. package/es/assets/img/svg/lefttoolbar/window.svg +0 -12
  245. package/es/assets/img/svg/logo.svg +0 -11
  246. package/es/assets/img/svg/logo_with_text.svg +0 -25
  247. package/es/assets/img/svg/menubar/login.svg +0 -84
  248. package/es/assets/img/svg/menubar/my_projects.svg +0 -85
  249. package/es/assets/img/svg/menubar/new_project.svg +0 -110
  250. package/es/assets/img/svg/menubar/save_project.svg +0 -84
  251. package/es/assets/img/svg/options.svg +0 -3
  252. package/es/assets/img/svg/positioning.svg +0 -3
  253. package/es/assets/img/svg/rotate.png +0 -0
  254. package/es/assets/img/svg/rotate.svg +0 -17
  255. package/es/assets/img/svg/rotate_object_clockwise.svg +0 -26
  256. package/es/assets/img/svg/rotate_object_counterclockwise.svg +0 -26
  257. package/es/assets/img/svg/toggleFilters.svg +0 -19
  258. package/es/assets/img/svg/toolbar/add_appliances_active.svg +0 -64
  259. package/es/assets/img/svg/toolbar/add_appliances_inactive.svg +0 -52
  260. package/es/assets/img/svg/toolbar/add_button.svg +0 -36
  261. package/es/assets/img/svg/toolbar/add_cabinets_active.svg +0 -59
  262. package/es/assets/img/svg/toolbar/add_cabinets_inactive.svg +0 -49
  263. package/es/assets/img/svg/toolbar/add_items_doors.svg +0 -25
  264. package/es/assets/img/svg/toolbar/add_items_doorways.svg +0 -24
  265. package/es/assets/img/svg/toolbar/add_items_refrigerator.svg +0 -32
  266. package/es/assets/img/svg/toolbar/add_items_windows.svg +0 -28
  267. package/es/assets/img/svg/toolbar/apply_button.svg +0 -38
  268. package/es/assets/img/svg/toolbar/arrow-plus.svg +0 -11
  269. package/es/assets/img/svg/toolbar/backsplash.svg +0 -8
  270. package/es/assets/img/svg/toolbar/cancel_button.svg +0 -37
  271. package/es/assets/img/svg/toolbar/consult_a_designer_button.svg +0 -47
  272. package/es/assets/img/svg/toolbar/countertop.svg +0 -7
  273. package/es/assets/img/svg/toolbar/dcm.png +0 -0
  274. package/es/assets/img/svg/toolbar/dcm_off.svg +0 -12
  275. package/es/assets/img/svg/toolbar/dcm_on.svg +0 -474
  276. package/es/assets/img/svg/toolbar/delete_button.svg +0 -37
  277. package/es/assets/img/svg/toolbar/download.svg +0 -77
  278. package/es/assets/img/svg/toolbar/draw_custom_floor.svg +0 -31
  279. package/es/assets/img/svg/toolbar/edit_button.svg +0 -75
  280. package/es/assets/img/svg/toolbar/email_quote_button.svg +0 -44
  281. package/es/assets/img/svg/toolbar/fbm.png +0 -0
  282. package/es/assets/img/svg/toolbar/finishing_touches_active.svg +0 -54
  283. package/es/assets/img/svg/toolbar/finishing_touches_inactive.svg +0 -42
  284. package/es/assets/img/svg/toolbar/floorstyle.svg +0 -9
  285. package/es/assets/img/svg/toolbar/fmb.png +0 -0
  286. package/es/assets/img/svg/toolbar/fmb_off.svg +0 -12
  287. package/es/assets/img/svg/toolbar/fmb_on.svg +0 -489
  288. package/es/assets/img/svg/toolbar/furnishings_icon.svg +0 -6
  289. package/es/assets/img/svg/toolbar/get_started_button.svg +0 -41
  290. package/es/assets/img/svg/toolbar/handles.svg +0 -5
  291. package/es/assets/img/svg/toolbar/lighting.svg +0 -7
  292. package/es/assets/img/svg/toolbar/lrm.png +0 -0
  293. package/es/assets/img/svg/toolbar/lrm_off.svg +0 -12
  294. package/es/assets/img/svg/toolbar/lrm_on.svg +0 -470
  295. package/es/assets/img/svg/toolbar/make_floorplan_active.svg +0 -66
  296. package/es/assets/img/svg/toolbar/make_floorplan_inactive.svg +0 -52
  297. package/es/assets/img/svg/toolbar/predefined_room_l_shaped.svg +0 -20
  298. package/es/assets/img/svg/toolbar/predefined_room_layout.svg +0 -20
  299. package/es/assets/img/svg/toolbar/predefined_room_long_narrow.svg +0 -20
  300. package/es/assets/img/svg/toolbar/predefined_room_open_l_shape.svg +0 -20
  301. package/es/assets/img/svg/toolbar/predefined_room_open_pentagon.svg +0 -20
  302. package/es/assets/img/svg/toolbar/predefined_room_open_rectangle.svg +0 -20
  303. package/es/assets/img/svg/toolbar/predefined_room_open_rectangle_2.svg +0 -20
  304. package/es/assets/img/svg/toolbar/predefined_room_pentagon.svg +0 -20
  305. package/es/assets/img/svg/toolbar/predefined_room_rectangle.svg +0 -20
  306. package/es/assets/img/svg/toolbar/predefined_room_rectangle_with_alcove.svg +0 -20
  307. package/es/assets/img/svg/toolbar/redo_button.svg +0 -75
  308. package/es/assets/img/svg/toolbar/redo_button1.svg +0 -75
  309. package/es/assets/img/svg/toolbar/review_quote_active.svg +0 -14
  310. package/es/assets/img/svg/toolbar/review_quote_inactive.svg +0 -44
  311. package/es/assets/img/svg/toolbar/save_project_button.svg +0 -44
  312. package/es/assets/img/svg/toolbar/select_doorstyle_active.svg +0 -67
  313. package/es/assets/img/svg/toolbar/select_doorstyle_inactive.svg +0 -57
  314. package/es/assets/img/svg/toolbar/shopping-cart.svg +0 -13
  315. package/es/assets/img/svg/toolbar/style_change_button.svg +0 -47
  316. package/es/assets/img/svg/toolbar/take_picture.svg +0 -75
  317. package/es/assets/img/svg/toolbar/undo_button.svg +0 -76
  318. package/es/assets/img/svg/toolbar/undo_button1.svg +0 -76
  319. package/es/assets/img/svg/toolbar/use_button.svg +0 -37
  320. package/es/assets/img/svg/toolbar/wall_color_icon.svg +0 -6
  321. package/es/assets/img/svg/topbar/edit_active.svg +0 -10
  322. package/es/assets/img/svg/topbar/edit_inactive.svg +0 -10
  323. package/es/assets/img/svg/topbar/redo_active.svg +0 -42
  324. package/es/assets/img/svg/topbar/redo_inactive.svg +0 -23
  325. package/es/assets/img/svg/topbar/select_all_active.svg +0 -50
  326. package/es/assets/img/svg/topbar/select_all_inactive.svg +0 -32
  327. package/es/assets/img/svg/topbar/take_picture_active.svg +0 -51
  328. package/es/assets/img/svg/topbar/take_picture_inactive.svg +0 -26
  329. package/es/assets/img/svg/topbar/undo_active.svg +0 -42
  330. package/es/assets/img/svg/topbar/undo_inactive.svg +0 -23
  331. package/es/assets/img/svg/warning_info_2d.svg +0 -81
  332. package/es/assets/img/svg/window/Clear.svg +0 -3
  333. package/es/assets/img/svg/window/Cross.svg +0 -5
  334. package/es/assets/img/svg/window/Double_hung.svg +0 -4
  335. package/es/assets/img/svg/window/Vertical.svg +0 -4
  336. package/es/assets/img/svg/windows_clear.svg +0 -23
  337. package/es/assets/img/svg/windows_cross.svg +0 -28
  338. package/es/assets/img/svg/windows_double_hung.svg +0 -24
  339. package/es/assets/img/svg/windows_vertical.svg +0 -24
  340. package/es/assets/img/svg/wizardstep/Custom.svg +0 -3
  341. package/es/assets/img/svg/wizardstep/Dashed_line.svg +0 -3
  342. package/es/assets/img/svg/wizardstep/L.svg +0 -3
  343. package/es/assets/img/svg/wizardstep/L2.svg +0 -3
  344. package/es/assets/img/svg/wizardstep/Open.svg +0 -3
  345. package/es/assets/img/svg/wizardstep/Square.svg +0 -3
  346. package/es/assets/img/svg/wizardstep/bar-active.svg +0 -9
  347. package/es/assets/img/svg/wizardstep/bar-normal.svg +0 -3
  348. package/es/assets/img/svg/wizardstep/bullet-current.svg +0 -3
  349. package/es/assets/img/svg/wizardstep/bullet-done.svg +0 -3
  350. package/es/assets/img/svg/wizardstep/bullet-not-done.svg +0 -3
  351. package/es/assets/img/svg/wizardstep/check-active.svg +0 -3
  352. package/es/assets/img/svg/wizardstep/check-normal.svg +0 -3
  353. package/es/assets/img/svg/wizardstep/detail_view.svg +0 -87
  354. package/es/assets/img/svg/wizardstep/pencil.svg +0 -11
  355. package/es/assets/img/svg/wizardstep/tile_view.svg +0 -95
  356. package/es/assets/img/texture/glass.jpg +0 -0
  357. package/es/assets/img/texture/steel.jpg +0 -0
  358. package/es/assets/img/texture/white1px.jpg +0 -0
  359. package/es/assets/img/texture/wood.jpg +0 -0
  360. package/es/assets/model/DCM.bin +0 -0
  361. package/es/assets/model/DCM.fbx +0 -0
  362. package/es/assets/model/DCM.gltf +0 -1
  363. package/es/assets/model/FBM.bin +0 -0
  364. package/es/assets/model/FBM.fbx +0 -0
  365. package/es/assets/model/FBM.gltf +0 -1
  366. package/es/assets/model/LRM.bin +0 -0
  367. package/es/assets/model/LRM.fbx +0 -0
  368. package/es/assets/model/LRM.gltf +0 -1
  369. package/es/assets/rtastore_logo.png +0 -0
  370. package/es/catalog/areas/area/planner-element.js +0 -45
  371. package/es/catalog/back.png +0 -0
  372. package/es/catalog/catalog.js +0 -265
  373. package/es/catalog/doors.png +0 -0
  374. package/es/catalog/doorways.png +0 -0
  375. package/es/catalog/envMap/nx.hdr +0 -0
  376. package/es/catalog/envMap/ny.hdr +0 -0
  377. package/es/catalog/envMap/nz.hdr +0 -0
  378. package/es/catalog/envMap/px.hdr +0 -0
  379. package/es/catalog/envMap/py.hdr +0 -0
  380. package/es/catalog/envMap/pz.hdr +0 -0
  381. package/es/catalog/export.js +0 -0
  382. package/es/catalog/factories/area-factory-3d.js +0 -182
  383. package/es/catalog/factories/area-factory.js +0 -78
  384. package/es/catalog/factories/export.js +0 -7
  385. package/es/catalog/factories/wall-factory-3d.js +0 -202
  386. package/es/catalog/factories/wall-factory.js +0 -267
  387. package/es/catalog/holes/door-closet/planner-element.js +0 -222
  388. package/es/catalog/holes/door-double/door_double.png +0 -0
  389. package/es/catalog/holes/door-double/planner-element.js +0 -315
  390. package/es/catalog/holes/door-exterior/planner-element.js +0 -215
  391. package/es/catalog/holes/door-interior/planner-element.js +0 -227
  392. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  393. package/es/catalog/holes/door-panic/planner-element.js +0 -503
  394. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  395. package/es/catalog/holes/door-panic-double/planner-element.js +0 -463
  396. package/es/catalog/holes/door-sliding/planner-element.js +0 -225
  397. package/es/catalog/holes/doorway-framed/planner-element.js +0 -145
  398. package/es/catalog/holes/doorway-frameless/planner-element.js +0 -104
  399. package/es/catalog/holes/export.js +0 -13
  400. package/es/catalog/holes/gate/gate.jpg +0 -0
  401. package/es/catalog/holes/window-clear/planner-element.js +0 -166
  402. package/es/catalog/holes/window-clear/texture.png +0 -0
  403. package/es/catalog/holes/window-cross/planner-element.js +0 -165
  404. package/es/catalog/holes/window-cross/texture.png +0 -0
  405. package/es/catalog/holes/window-double-hung/planner-element.js +0 -303
  406. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  407. package/es/catalog/holes/window-vertical/planner-element.js +0 -276
  408. package/es/catalog/holes/window-vertical/texture.png +0 -0
  409. package/es/catalog/lines/wall/planner-element.js +0 -79
  410. package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
  411. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  412. package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
  413. package/es/catalog/molding/molding-dcm/planner-element.js +0 -26
  414. package/es/catalog/molding/molding-dcm/texture.png +0 -0
  415. package/es/catalog/molding/molding-fbm/planner-element.js +0 -26
  416. package/es/catalog/molding/molding-fbm/texture.png +0 -0
  417. package/es/catalog/molding/molding-lrm/planner-element.js +0 -26
  418. package/es/catalog/molding/molding-lrm/texture.png +0 -0
  419. package/es/catalog/properties/export.js +0 -21
  420. package/es/catalog/properties/property-checkbox.js +0 -68
  421. package/es/catalog/properties/property-color.js +0 -39
  422. package/es/catalog/properties/property-enum.js +0 -50
  423. package/es/catalog/properties/property-hidden.js +0 -19
  424. package/es/catalog/properties/property-lenght-measure.js +0 -96
  425. package/es/catalog/properties/property-length-measure.js +0 -80
  426. package/es/catalog/properties/property-length-measure_hole.js +0 -96
  427. package/es/catalog/properties/property-number.js +0 -48
  428. package/es/catalog/properties/property-read-only.js +0 -26
  429. package/es/catalog/properties/property-string.js +0 -48
  430. package/es/catalog/properties/property-toggle.js +0 -39
  431. package/es/catalog/properties/shared-property-style.js +0 -14
  432. package/es/catalog/utils/FuseUtils.js +0 -79
  433. package/es/catalog/utils/exporter.js +0 -161
  434. package/es/catalog/utils/geom-utils.js +0 -189
  435. package/es/catalog/utils/item-loader.js +0 -1602
  436. package/es/catalog/utils/load-obj.js +0 -91
  437. package/es/catalog/utils/mtl-loader.js +0 -357
  438. package/es/catalog/utils/obj-loader.js +0 -476
  439. package/es/catalog/windows.png +0 -0
  440. package/es/class/FuseUtils.js +0 -79
  441. package/es/class/area.js +0 -141
  442. package/es/class/export.js +0 -24
  443. package/es/class/group.js +0 -431
  444. package/es/class/guide.js +0 -58
  445. package/es/class/hole.js +0 -924
  446. package/es/class/item.js +0 -1884
  447. package/es/class/layer.js +0 -663
  448. package/es/class/line.js +0 -1229
  449. package/es/class/project.js +0 -937
  450. package/es/class/vertex.js +0 -198
  451. package/es/components/content.js +0 -135
  452. package/es/components/export.js +0 -9
  453. package/es/components/style/button.js +0 -106
  454. package/es/components/style/cancel-button.js +0 -21
  455. package/es/components/style/content-container.js +0 -30
  456. package/es/components/style/content-title.js +0 -25
  457. package/es/components/style/delete-button.js +0 -24
  458. package/es/components/style/export.js +0 -31
  459. package/es/components/style/form-block.js +0 -20
  460. package/es/components/style/form-color-input.js +0 -26
  461. package/es/components/style/form-label.js +0 -22
  462. package/es/components/style/form-number-input.js +0 -192
  463. package/es/components/style/form-number-input_2.js +0 -238
  464. package/es/components/style/form-select.js +0 -19
  465. package/es/components/style/form-slider.js +0 -60
  466. package/es/components/style/form-submit-button.js +0 -25
  467. package/es/components/style/form-text-input.js +0 -69
  468. package/es/components/viewer2d/area.js +0 -81
  469. package/es/components/viewer2d/export.js +0 -31
  470. package/es/components/viewer2d/grids/grid-horizontal-streak.js +0 -36
  471. package/es/components/viewer2d/grids/grid-streak.js +0 -36
  472. package/es/components/viewer2d/grids/grid-vertical-streak.js +0 -36
  473. package/es/components/viewer2d/grids/grids.js +0 -30
  474. package/es/components/viewer2d/group.js +0 -48
  475. package/es/components/viewer2d/item.js +0 -242
  476. package/es/components/viewer2d/layer.js +0 -164
  477. package/es/components/viewer2d/line.js +0 -997
  478. package/es/components/viewer2d/ruler.js +0 -84
  479. package/es/components/viewer2d/rulerDist.js +0 -102
  480. package/es/components/viewer2d/rulerX.js +0 -142
  481. package/es/components/viewer2d/rulerY.js +0 -144
  482. package/es/components/viewer2d/scene.js +0 -108
  483. package/es/components/viewer2d/snap.js +0 -74
  484. package/es/components/viewer2d/state.js +0 -73
  485. package/es/components/viewer2d/utils.js +0 -193
  486. package/es/components/viewer2d/vertex.js +0 -66
  487. package/es/components/viewer2d/viewer2d.js +0 -1405
  488. package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +0 -2585
  489. package/es/components/viewer3d/dcm.js +0 -401
  490. package/es/components/viewer3d/fbm.js +0 -414
  491. package/es/components/viewer3d/front3D.js +0 -62
  492. package/es/components/viewer3d/grid-creator.js +0 -25
  493. package/es/components/viewer3d/grids/grid-horizontal-streak.js +0 -36
  494. package/es/components/viewer3d/grids/grid-streak.js +0 -27
  495. package/es/components/viewer3d/grids/grid-vertical-streak.js +0 -36
  496. package/es/components/viewer3d/libs/first-person-controls.js +0 -67
  497. package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +0 -1281
  498. package/es/components/viewer3d/libs/mtl-loader.js +0 -357
  499. package/es/components/viewer3d/libs/obj-loader.js +0 -462
  500. package/es/components/viewer3d/libs/orbit-controls.js +0 -697
  501. package/es/components/viewer3d/libs/pointer-lock-controls.js +0 -44
  502. package/es/components/viewer3d/lrm.js +0 -305
  503. package/es/components/viewer3d/model.js +0 -708
  504. package/es/components/viewer3d/pointer-lock-navigation.js +0 -115
  505. package/es/components/viewer3d/ruler-utils/itemRect.js +0 -61
  506. package/es/components/viewer3d/ruler-utils/layer3D.js +0 -495
  507. package/es/components/viewer3d/ruler-utils/ruler3D.js +0 -224
  508. package/es/components/viewer3d/ruler-utils/scene3D.js +0 -59
  509. package/es/components/viewer3d/ruler-utils/state3D.js +0 -18
  510. package/es/components/viewer3d/scene-creator.js +0 -3818
  511. package/es/components/viewer3d/three-memory-cleaner.js +0 -51
  512. package/es/components/viewer3d/viewer3d-first-person.js +0 -311
  513. package/es/components/viewer3d/viewer3d.js +0 -2654
  514. package/es/constants.js +0 -769
  515. package/es/index.html.ejs +0 -264
  516. package/es/models.js +0 -512
  517. package/es/plugins/SVGLoader.js +0 -1414
  518. package/es/plugins/console-debugger.js +0 -34
  519. package/es/plugins/export.js +0 -7
  520. package/es/plugins/keyboard.js +0 -110
  521. package/es/reducers/areas-reducer.js +0 -12
  522. package/es/reducers/export.js +0 -25
  523. package/es/reducers/groups-reducer.js +0 -38
  524. package/es/reducers/holes-reducer.js +0 -62
  525. package/es/reducers/items-reducer.js +0 -143
  526. package/es/reducers/lines-reducer.js +0 -45
  527. package/es/reducers/project-reducer.js +0 -136
  528. package/es/reducers/reducer.js +0 -19
  529. package/es/reducers/scene-reducer.js +0 -28
  530. package/es/reducers/user-reducer.js +0 -41
  531. package/es/reducers/vertices-reducer.js +0 -19
  532. package/es/reducers/viewer2d-reducer.js +0 -77
  533. package/es/reducers/viewer3d-reducer.js +0 -58
  534. package/es/shared-style.js +0 -66
  535. package/es/translator/en.js +0 -104
  536. package/es/translator/it.js +0 -79
  537. package/es/translator/ru.js +0 -79
  538. package/es/translator/translator.js +0 -80
  539. package/es/utils/browser.js +0 -33
  540. package/es/utils/convert-units-lite.js +0 -29
  541. package/es/utils/email-validator.js +0 -4
  542. package/es/utils/export.js +0 -25
  543. package/es/utils/geometry.js +0 -2609
  544. package/es/utils/get-edges-of-subgraphs.js +0 -26
  545. package/es/utils/graph-cycles.js +0 -238
  546. package/es/utils/graph-inner-cycles.js +0 -46
  547. package/es/utils/graph.js +0 -145
  548. package/es/utils/helper.js +0 -436
  549. package/es/utils/history.js +0 -29
  550. package/es/utils/id-broker.js +0 -15
  551. package/es/utils/isolate-event-handler.js +0 -1622
  552. package/es/utils/logger.js +0 -8
  553. package/es/utils/math.js +0 -50
  554. package/es/utils/molding.js +0 -1347
  555. package/es/utils/name-generator.js +0 -17
  556. package/es/utils/objects-utils.js +0 -50
  557. package/es/utils/phone-validator.js +0 -4
  558. package/es/utils/process-black-list.js +0 -15
  559. package/es/utils/react-if.js +0 -18
  560. package/es/utils/ruler.js +0 -58
  561. package/es/utils/snap-scene.js +0 -94
  562. package/es/utils/snap.js +0 -231
  563. package/es/utils/summarizeCart.js +0 -24
  564. package/es/utils/threeCSG.es6.js +0 -494
  565. package/es/version.js +0 -1
  566. /package/es/{catalog/lines/wall/textures/plaster-normal.jpg → 1fc74a85baa030dbc913.jpg} +0 -0
  567. /package/es/{catalog/lines/wall/wall.png → 30a49a74d9bd10068b65.png} +0 -0
  568. /package/es/{catalog/lines/wall/textures/bricks-normal2.jpg → 340a84d3930143a53545.jpg} +0 -0
  569. /package/es/{catalog/lines/wall/textures/morden-normal.jpg → 5c8d36b3e7223934f447.jpg} +0 -0
  570. /package/es/{catalog/lines/wall/textures/bricks-normal.jpg → 81e7a7e6edf162e88b44.jpg} +0 -0
  571. /package/es/{catalog/lines/wall/textures/morden.jpg → 8fe0f1210d8ba435a790.jpg} +0 -0
  572. /package/es/{catalog/lines/wall/textures/bricks.jpg → a07d30a04bda8ee03491.jpg} +0 -0
  573. /package/es/{catalog/lines/wall/textures/painted.jpg → bee3f62687a97bcc3d9f.jpg} +0 -0
  574. /package/es/{catalog/areas/area/textures/strand-porcelain.jpg → c232d250fd899392b1b7.jpg} +0 -0
  575. /package/es/{catalog/areas/area/textures/tile1.jpg → c7ae6f4de09134ebe588.jpg} +0 -0
  576. /package/es/{catalog/lines/wall/textures/plaster.jpg → dad5ee758630256ee702.jpg} +0 -0
  577. /package/es/{catalog/areas/area/textures/grass.jpg → e470a2ce76062955fa98.jpg} +0 -0
  578. /package/es/{catalog/areas/area/textures/parquet.jpg → e5ae13166775e7d071e4.jpg} +0 -0
  579. /package/es/{catalog/areas/area/textures/ceramic-tile.jpg → e8e5de0892f5375460bd.jpg} +0 -0
@@ -1,1405 +0,0 @@
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
- };