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,997 @@
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ 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; }
3
+ 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; }
4
+ import React from 'react';
5
+ import PropTypes from 'prop-types';
6
+ import { GeometryUtils } from "../../utils/export";
7
+ import Ruler from "./ruler";
8
+ import { BASE_CABINET_LAYOUTPOS, LINE_THICKNESS, MODE_DRAGGING_LINE, MODE_DRAWING_LINE, WALL_CABINET_LAYOUTPOS, MAX_ANGLE_SCALE, ROOM_SHAPE_MEASUREMENT_LINE_COLOR, ROOM_ELEMENT_MEASUREMENT_LINE_COLOR, BASE_ITEM_MEASUREMENT_LINE_COLOR, WALL_ITEM_MEASUREMENT_LINE_COLOR, DISTANCE_MEASUREMENT_LINE_COLOR, DASH_LINE_COLOR, TALL_CABINET_LAYOUTPOS, VANITY_CABINET_LAYOUTPOS } from "../../constants";
9
+ import * as Three from 'three';
10
+ import { isEmpty } from "./utils";
11
+ var STYLE = {
12
+ stroke: '#78909C',
13
+ strokeWidth: '1px',
14
+ strokeDasharray: '4 8'
15
+ };
16
+ var STYLE_ANGLE = {
17
+ stroke: 'rgb(77, 77, 77)',
18
+ strokeWidth: 1,
19
+ strokeLinecap: 'round',
20
+ strokeLinejoin: 'round',
21
+ strokeMiterlimit: 2.613,
22
+ fill: 'transparent'
23
+ };
24
+ var STYLE_TEXT = {
25
+ textAnchor: 'middle',
26
+ fontSize: '7px',
27
+ fontWeight: 'middle',
28
+ fontFamily: "'Courier New', Courier, monospace"
29
+ };
30
+ export var STYLE_ROOM_SHAPE = {
31
+ stroke: ROOM_SHAPE_MEASUREMENT_LINE_COLOR,
32
+ strokeWidth: '2px'
33
+ };
34
+ var STYLE_DASH = {
35
+ stroke: DASH_LINE_COLOR,
36
+ strokeDasharray: '4 4',
37
+ strokeWidth: '1px',
38
+ strokeLinecap: 'round'
39
+ };
40
+ var STYLE_ROOM_ELEMENT = {
41
+ fill: ROOM_ELEMENT_MEASUREMENT_LINE_COLOR,
42
+ stroke: ROOM_ELEMENT_MEASUREMENT_LINE_COLOR,
43
+ strokeWidth: '1.5px'
44
+ };
45
+ var STYLE_BASE_ITEM = {
46
+ fill: BASE_ITEM_MEASUREMENT_LINE_COLOR,
47
+ stroke: BASE_ITEM_MEASUREMENT_LINE_COLOR,
48
+ strokeWidth: '1.5px'
49
+ };
50
+ var STYLE_WALL_ITEM = {
51
+ fill: WALL_ITEM_MEASUREMENT_LINE_COLOR,
52
+ stroke: WALL_ITEM_MEASUREMENT_LINE_COLOR,
53
+ strokeWidth: '1.5px'
54
+ };
55
+ var STYLE_DISTANCE = {
56
+ fill: DISTANCE_MEASUREMENT_LINE_COLOR,
57
+ stroke: DISTANCE_MEASUREMENT_LINE_COLOR,
58
+ strokeWidth: '1.5px'
59
+ };
60
+ var selectStyle = function selectStyle(element, style) {
61
+ return element.iFlag ? style : STYLE_DISTANCE;
62
+ };
63
+ export function compareVertices(v0, v1) {
64
+ return v0.x === v1.x ? v0.y - v1.y : v0.x - v1.x;
65
+ }
66
+ export default function Line(_ref) {
67
+ var _state$getIn;
68
+ var line = _ref.line,
69
+ allLine = _ref.allLine,
70
+ layer = _ref.layer,
71
+ scene = _ref.scene,
72
+ num = _ref.num,
73
+ catalog = _ref.catalog,
74
+ state = _ref.state,
75
+ relatedLines = _ref.relatedLines;
76
+ var showWallLengthMeasure = scene.showWallLengthMeasure,
77
+ showWallCabinetMeasure = scene.showWallCabinetMeasure,
78
+ showBaseCabinetMeasure = scene.showBaseCabinetMeasure,
79
+ showWindowDoorMeasure = scene.showWindowDoorMeasure;
80
+ var vertex0 = layer.vertices.get(line.vertices.get(0));
81
+ var vertex1 = layer.vertices.get(line.vertices.get(1));
82
+ if (vertex0.id === vertex1.id || GeometryUtils.samePoints(vertex0, vertex1)) return null; //avoid 0-length lines
83
+ var x1 = vertex0.x,
84
+ y1 = vertex0.y;
85
+ var x2 = vertex1.x,
86
+ y2 = vertex1.y;
87
+ var l2 = {
88
+ x: x1,
89
+ y: y1
90
+ };
91
+ var l3 = {
92
+ x: x2,
93
+ y: y2
94
+ };
95
+ var isSnapped = function isSnapped(itemRect) {
96
+ var r0 = itemRect.rect[0];
97
+ var r1 = itemRect.rect[1];
98
+ var r2 = itemRect.rect[2];
99
+ var r3 = itemRect.rect[3];
100
+ var delta23 = GeometryUtils.verticesDistance(l2, r3) + GeometryUtils.verticesDistance(r3, r2) + GeometryUtils.verticesDistance(r2, l3) - GeometryUtils.verticesDistance(l3, l2);
101
+ if (delta23 < 0.1) {
102
+ return true;
103
+ } else {
104
+ return false;
105
+ }
106
+ };
107
+ var relatedvertice0x, relatedvertice0y, relatedvertice1x, relatedvertice1y;
108
+ line.relatedVertices.forEach(function (relatedVertice) {
109
+ if (relatedVertice.index == undefined) relatedVertice = relatedVertice.toJSON();
110
+ if (relatedVertice.index == 0) {
111
+ relatedvertice0x = relatedVertice.point.x;
112
+ relatedvertice0y = relatedVertice.point.y;
113
+ } else {
114
+ relatedvertice1x = relatedVertice.point.x;
115
+ relatedvertice1y = relatedVertice.point.y;
116
+ }
117
+ });
118
+ var thickness = LINE_THICKNESS;
119
+ var half_thickness = thickness / 2;
120
+ var STEP = 20;
121
+ var length = GeometryUtils.pointsDistance(x1, y1, x2, y2);
122
+ // let length = GeometryUtils.pointsDistance(relatedvertice0x,relatedvertice0y,relatedvertice1x,relatedvertice1y);
123
+ var rightHoleLength, leftHoleLength, holeLength;
124
+ var angle = GeometryUtils.angleBetweenTwoPointsAndOrigin(x1, y1, x2, y2);
125
+ // wall cabinet
126
+ var wallSpace = STEP;
127
+ var wall_item = GeometryUtils.getAllItemSpecified(scene, catalog, [WALL_CABINET_LAYOUTPOS, TALL_CABINET_LAYOUTPOS]);
128
+ var wallRuler = [];
129
+ var wall_posArray = [];
130
+ if (wall_item.cur) {
131
+ wall_item.others.push(wall_item.cur);
132
+ }
133
+ // let relatedLines = [];
134
+ var angleVertices = [];
135
+ var layerID = state.getIn(['scene', 'selectedLayer']);
136
+ var drawingLineID = (_state$getIn = state.getIn(['scene', 'layers', layerID, 'selected', 'lines'])) === null || _state$getIn === void 0 ? void 0 : _state$getIn.toJS();
137
+ if (!isEmpty(drawingLineID)) {
138
+ var drawingLine = state.getIn(['scene', 'layers', layerID, 'lines', drawingLineID[0]]).toJS();
139
+ var allLines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
140
+ var allLinesArray = state.getIn(['scene', 'layers', layerID, 'lines']).toArray();
141
+ var vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
142
+ var reget = false;
143
+ relatedLines.forEach(function (relLine) {
144
+ if (!allLinesArray.some(function (alLine) {
145
+ return alLine.id === relLine.id;
146
+ })) {
147
+ reget = true;
148
+ }
149
+ });
150
+ if (reget) {
151
+ relatedLines = [];
152
+ GeometryUtils.getRelatedLines(relatedLines, drawingLine, vertices, allLines);
153
+ }
154
+ // get the angle of two lines and check the angle.
155
+ if (drawingLine.vertices[0] !== drawingLine.vertices[1]) {
156
+ relatedLines.forEach(function (line) {
157
+ // get the points of two lines(drawing line and related line)
158
+ // the first value is overlapped point of two lines as a center of angle.
159
+ if (!isEmpty(line)) {
160
+ var points = [];
161
+ var anglePoints = [];
162
+ line.vertices.forEach(function (vt) {
163
+ if (drawingLine.vertices.some(function (dvt) {
164
+ return dvt === vt;
165
+ })) {
166
+ points.push(vt);
167
+ }
168
+ });
169
+ line.vertices.forEach(function (vt) {
170
+ if (!points.some(function (pt) {
171
+ return pt === vt;
172
+ })) {
173
+ points.push(vt);
174
+ }
175
+ });
176
+ drawingLine.vertices.forEach(function (vt) {
177
+ if (!points.some(function (pt) {
178
+ return pt === vt;
179
+ })) {
180
+ points.push(vt);
181
+ }
182
+ });
183
+ if (points.length < 3) {
184
+ points.push(points[points.length - 1]);
185
+ }
186
+ points.forEach(function (point) {
187
+ return anglePoints.push(vertices[point]);
188
+ });
189
+ angleVertices.push(anglePoints);
190
+ }
191
+ });
192
+ }
193
+ }
194
+ if (Math.sin(angle) === 0 || GeometryUtils.almostEqual(y1, y2)) wall_item.others.sort(function (a, b) {
195
+ return a.pos.x - b.pos.x;
196
+ });else wall_item.others.sort(function (a, b) {
197
+ return a.pos.y - b.pos.y;
198
+ });
199
+ wall_posArray.push(_objectSpread(_objectSpread({}, l2), {}, {
200
+ iFlag: false
201
+ }));
202
+ wall_item.others.forEach(function (itemRect) {
203
+ var r2 = l2 > l3 ? itemRect.rect[2] : itemRect.rect[3];
204
+ var r3 = l2 > l3 ? itemRect.rect[3] : itemRect.rect[2];
205
+ if (isSnapped(itemRect)) {
206
+ wall_posArray.push(_objectSpread(_objectSpread({}, r2), {}, {
207
+ iFlag: itemRect.itemInfo.id
208
+ }));
209
+ wall_posArray.push(_objectSpread(_objectSpread({}, r3), {}, {
210
+ iFlag: itemRect.itemInfo.id
211
+ }));
212
+ }
213
+ });
214
+ wall_posArray.push(_objectSpread(_objectSpread({}, l3), {}, {
215
+ iFlag: false
216
+ }));
217
+ var wall_posAndwidth = [];
218
+ if (Math.sin(angle) === 0 || GeometryUtils.almostEqual(y1, y2)) {
219
+ wall_posArray.sort(function (a, b) {
220
+ return a.x - b.x;
221
+ });
222
+ if (wall_posArray.length > 2) {
223
+ for (var index = 0; index < wall_posArray.length - 1; index++) {
224
+ var element = wall_posArray[index];
225
+ wall_posAndwidth.push({
226
+ pos: element,
227
+ length: wall_posArray[index + 1].x - element.x,
228
+ iFlag: wall_posArray[index + 1].iFlag === element.iFlag ? true : false
229
+ });
230
+ }
231
+ }
232
+ } else {
233
+ wall_posArray.sort(function (a, b) {
234
+ return a.y - b.y;
235
+ });
236
+ if (wall_posArray.length > 2) {
237
+ for (var _index = 0; _index < wall_posArray.length - 1; _index++) {
238
+ var _element = wall_posArray[_index];
239
+ wall_posAndwidth.push({
240
+ pos: _element,
241
+ length: Math.abs((wall_posArray[_index + 1].y - _element.y) / Math.sin(angle / 180 * Math.PI)),
242
+ iFlag: wall_posArray[_index + 1].iFlag === _element.iFlag ? true : false
243
+ });
244
+ }
245
+ }
246
+ }
247
+ if (!showWallCabinetMeasure || wall_posArray.length <= 2) {
248
+ wallSpace = 0;
249
+ }
250
+ wallRuler = wall_posAndwidth.map(function (pAw, idx) {
251
+ if (pAw.length <= 1) return null;
252
+ if (pAw.length > 1) {
253
+ if (Math.sin(angle) === 0 || GeometryUtils.almostEqual(y1, y2)) {
254
+ if (x1 - x2 > 0) {
255
+ return /*#__PURE__*/React.createElement("g", {
256
+ key: "wall-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
257
+ }, /*#__PURE__*/React.createElement("line", {
258
+ x1: pAw.pos.x + pAw.length,
259
+ y1: pAw.pos.y,
260
+ x2: pAw.pos.x + pAw.length,
261
+ y2: pAw.pos.y - thickness / 2 - wallSpace,
262
+ style: STYLE_DASH
263
+ }), /*#__PURE__*/React.createElement(Ruler, {
264
+ key: 4,
265
+ layer: layer,
266
+ unit: scene.unit,
267
+ rulerUnit: scene.rulerUnit,
268
+ length: pAw.length,
269
+ transform: "translate(".concat(pAw.pos.x, ", ").concat(pAw.pos.y - thickness / 2 - wallSpace, " ) rotate(").concat(angle + 180, ", 0, 0)"),
270
+ style: selectStyle(pAw, STYLE_WALL_ITEM)
271
+ }), /*#__PURE__*/React.createElement("line", {
272
+ x1: pAw.pos.x,
273
+ y1: pAw.pos.y,
274
+ x2: pAw.pos.x,
275
+ y2: pAw.pos.y - thickness / 2 - wallSpace,
276
+ style: STYLE_DASH
277
+ }));
278
+ } else {
279
+ return /*#__PURE__*/React.createElement("g", {
280
+ key: "wall-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
281
+ }, /*#__PURE__*/React.createElement("line", {
282
+ x1: pAw.pos.x + pAw.length,
283
+ y1: pAw.pos.y,
284
+ x2: pAw.pos.x + pAw.length,
285
+ y2: pAw.pos.y + thickness / 2 + wallSpace,
286
+ style: STYLE_DASH
287
+ }), /*#__PURE__*/React.createElement(Ruler, {
288
+ key: 4,
289
+ layer: layer,
290
+ unit: scene.unit,
291
+ rulerUnit: scene.rulerUnit,
292
+ length: pAw.length,
293
+ transform: "translate(".concat(pAw.pos.x, ", ").concat(pAw.pos.y + thickness / 2 + wallSpace, " ) rotate(").concat(angle, ", 0, 0)"),
294
+ style: selectStyle(pAw, STYLE_WALL_ITEM)
295
+ }), /*#__PURE__*/React.createElement("line", {
296
+ x1: pAw.pos.x,
297
+ y1: pAw.pos.y,
298
+ x2: pAw.pos.x,
299
+ y2: pAw.pos.y + thickness / 2 + wallSpace,
300
+ style: STYLE_DASH
301
+ }));
302
+ }
303
+ } else {
304
+ if (y1 - y2 > 0) {
305
+ if (x1 - x2 < 0 || GeometryUtils.almostEqual(x1, x2)) {
306
+ return /*#__PURE__*/React.createElement("g", {
307
+ key: "wall-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
308
+ }, /*#__PURE__*/React.createElement("line", {
309
+ x1: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI),
310
+ y1: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI),
311
+ x2: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
312
+ y2: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
313
+ style: STYLE_DASH
314
+ }), /*#__PURE__*/React.createElement(Ruler, {
315
+ key: 5,
316
+ layer: layer,
317
+ unit: scene.unit,
318
+ rulerUnit: scene.rulerUnit,
319
+ length: pAw.length,
320
+ transform: "translate(".concat(pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0)"),
321
+ style: selectStyle(pAw, STYLE_WALL_ITEM)
322
+ }), /*#__PURE__*/React.createElement("line", {
323
+ x1: pAw.pos.x,
324
+ y1: pAw.pos.y,
325
+ x2: pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
326
+ y2: pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
327
+ style: STYLE_DASH
328
+ }));
329
+ } else {
330
+ return /*#__PURE__*/React.createElement("g", {
331
+ key: "wall-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
332
+ }, /*#__PURE__*/React.createElement("line", {
333
+ x1: pAw.pos.x,
334
+ y1: pAw.pos.y,
335
+ x2: pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
336
+ y2: pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
337
+ style: STYLE_DASH
338
+ }), /*#__PURE__*/React.createElement(Ruler, {
339
+ key: 5,
340
+ layer: layer,
341
+ unit: scene.unit,
342
+ rulerUnit: scene.rulerUnit,
343
+ length: pAw.length,
344
+ transform: "translate(".concat(pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0) scale(-1, -1)"),
345
+ style: selectStyle(pAw, STYLE_WALL_ITEM)
346
+ }), /*#__PURE__*/React.createElement("line", {
347
+ x1: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI),
348
+ y1: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI),
349
+ x2: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
350
+ y2: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
351
+ style: STYLE_DASH
352
+ }));
353
+ }
354
+ } else {
355
+ if (x1 - x2 < 0 || GeometryUtils.almostEqual(x1, x2)) {
356
+ return /*#__PURE__*/React.createElement("g", {
357
+ key: "wall-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
358
+ }, /*#__PURE__*/React.createElement("line", {
359
+ x1: pAw.pos.x,
360
+ y1: pAw.pos.y,
361
+ x2: pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
362
+ y2: pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
363
+ style: STYLE_DASH
364
+ }), /*#__PURE__*/React.createElement(Ruler, {
365
+ key: 5,
366
+ layer: layer,
367
+ unit: scene.unit,
368
+ rulerUnit: scene.rulerUnit,
369
+ length: pAw.length,
370
+ transform: "translate(".concat(pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0)"),
371
+ style: selectStyle(pAw, STYLE_WALL_ITEM)
372
+ }), /*#__PURE__*/React.createElement("line", {
373
+ x1: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI),
374
+ y1: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI),
375
+ x2: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
376
+ y2: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
377
+ style: STYLE_DASH
378
+ }));
379
+ } else {
380
+ return /*#__PURE__*/React.createElement("g", {
381
+ key: "wall-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
382
+ }, /*#__PURE__*/React.createElement("line", {
383
+ x1: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI),
384
+ y1: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI),
385
+ x2: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
386
+ y2: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
387
+ style: STYLE_DASH
388
+ }), /*#__PURE__*/React.createElement(Ruler, {
389
+ key: 5,
390
+ layer: layer,
391
+ unit: scene.unit,
392
+ rulerUnit: scene.rulerUnit,
393
+ length: pAw.length,
394
+ transform: "translate(".concat(pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0) scale(-1, -1)"),
395
+ style: selectStyle(pAw, STYLE_WALL_ITEM)
396
+ }), /*#__PURE__*/React.createElement("line", {
397
+ x1: pAw.pos.x,
398
+ y1: pAw.pos.y,
399
+ x2: pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
400
+ y2: pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
401
+ style: STYLE_DASH
402
+ }));
403
+ }
404
+ }
405
+ }
406
+ }
407
+ });
408
+
409
+ //base cabinet
410
+ var baseSpace = wallSpace + STEP;
411
+ var base_item = GeometryUtils.getAllItemSpecified(scene, catalog, [BASE_CABINET_LAYOUTPOS, VANITY_CABINET_LAYOUTPOS]);
412
+
413
+ // base cabinet
414
+ var baseRuler = [];
415
+ var base_posArray = [];
416
+ if (base_item.cur) {
417
+ base_item.others.push(base_item.cur);
418
+ }
419
+ if (Math.sin(angle) === 0 || GeometryUtils.almostEqual(y1, y2)) base_item.others.sort(function (a, b) {
420
+ return a.pos.x - b.pos.x;
421
+ });else base_item.others.sort(function (a, b) {
422
+ return a.pos.y - b.pos.y;
423
+ });
424
+ base_posArray.push(_objectSpread(_objectSpread({}, l2), {}, {
425
+ iFlag: false
426
+ }));
427
+ base_item.others.forEach(function (itemRect) {
428
+ var r2 = l2 > l3 ? itemRect.rect[2] : itemRect.rect[3];
429
+ var r3 = l2 > l3 ? itemRect.rect[3] : itemRect.rect[2];
430
+ if (isSnapped(itemRect)) {
431
+ base_posArray.push(_objectSpread(_objectSpread({}, r2), {}, {
432
+ iFlag: itemRect.itemInfo.id
433
+ }));
434
+ base_posArray.push(_objectSpread(_objectSpread({}, r3), {}, {
435
+ iFlag: itemRect.itemInfo.id
436
+ }));
437
+ }
438
+ });
439
+ base_posArray.push(_objectSpread(_objectSpread({}, l3), {}, {
440
+ iFlag: false
441
+ }));
442
+ var base_posAndwidth = [];
443
+ if (Math.sin(angle) === 0 || GeometryUtils.almostEqual(y1, y2)) {
444
+ base_posArray.sort(function (a, b) {
445
+ return a.x - b.x;
446
+ });
447
+ if (base_posArray.length > 2) {
448
+ for (var _index2 = 0; _index2 < base_posArray.length - 1; _index2++) {
449
+ var _element2 = base_posArray[_index2];
450
+ base_posAndwidth.push({
451
+ pos: _element2,
452
+ length: base_posArray[_index2 + 1].x - _element2.x,
453
+ iFlag: base_posArray[_index2 + 1].iFlag === _element2.iFlag ? true : false
454
+ });
455
+ }
456
+ }
457
+ } else {
458
+ base_posArray.sort(function (a, b) {
459
+ return a.y - b.y;
460
+ });
461
+ if (base_posArray.length > 2) {
462
+ for (var _index3 = 0; _index3 < base_posArray.length - 1; _index3++) {
463
+ var _element3 = base_posArray[_index3];
464
+ base_posAndwidth.push({
465
+ pos: _element3,
466
+ length: Math.abs((base_posArray[_index3 + 1].y - _element3.y) / Math.sin(angle / 180 * Math.PI)),
467
+ iFlag: base_posArray[_index3 + 1].iFlag === _element3.iFlag ? true : false
468
+ });
469
+ }
470
+ }
471
+ }
472
+ if (!showBaseCabinetMeasure || base_posArray.length <= 2) {
473
+ baseSpace -= STEP;
474
+ }
475
+ baseRuler = base_posAndwidth.map(function (pAw, idx) {
476
+ if (pAw.length <= 1) return null;
477
+ if (pAw.length > 1) {
478
+ if (Math.sin(angle) === 0 || GeometryUtils.almostEqual(y1, y2)) {
479
+ if (x1 - x2 > 0) {
480
+ return /*#__PURE__*/React.createElement("g", {
481
+ key: "base-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
482
+ }, /*#__PURE__*/React.createElement("line", {
483
+ x1: pAw.pos.x + pAw.length,
484
+ y1: pAw.pos.y,
485
+ x2: pAw.pos.x + pAw.length,
486
+ y2: pAw.pos.y - thickness / 2 - baseSpace,
487
+ style: STYLE_DASH
488
+ }), /*#__PURE__*/React.createElement(Ruler, {
489
+ key: 4,
490
+ layer: layer,
491
+ unit: scene.unit,
492
+ rulerUnit: scene.rulerUnit,
493
+ length: pAw.length,
494
+ transform: "translate(".concat(pAw.pos.x, ", ").concat(pAw.pos.y - thickness / 2 - baseSpace, " ) rotate(").concat(angle + 180, ", 0, 0)"),
495
+ style: selectStyle(pAw, STYLE_BASE_ITEM)
496
+ }), /*#__PURE__*/React.createElement("line", {
497
+ x1: pAw.pos.x,
498
+ y1: pAw.pos.y,
499
+ x2: pAw.pos.x,
500
+ y2: pAw.pos.y - thickness / 2 - baseSpace,
501
+ style: STYLE_DASH
502
+ }));
503
+ } else {
504
+ return /*#__PURE__*/React.createElement("g", {
505
+ key: "base-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
506
+ }, /*#__PURE__*/React.createElement("line", {
507
+ x1: pAw.pos.x + pAw.length,
508
+ y1: pAw.pos.y,
509
+ x2: pAw.pos.x + pAw.length,
510
+ y2: pAw.pos.y + thickness / 2 + baseSpace,
511
+ style: STYLE_DASH
512
+ }), /*#__PURE__*/React.createElement(Ruler, {
513
+ key: 4,
514
+ layer: layer,
515
+ unit: scene.unit,
516
+ rulerUnit: scene.rulerUnit,
517
+ length: pAw.length,
518
+ transform: "translate(".concat(pAw.pos.x, ", ").concat(pAw.pos.y + thickness / 2 + baseSpace, " ) rotate(").concat(angle, ", 0, 0)"),
519
+ style: selectStyle(pAw, STYLE_BASE_ITEM)
520
+ }), /*#__PURE__*/React.createElement("line", {
521
+ x1: pAw.pos.x,
522
+ y1: pAw.pos.y,
523
+ x2: pAw.pos.x,
524
+ y2: pAw.pos.y + thickness / 2 + baseSpace,
525
+ style: STYLE_DASH
526
+ }));
527
+ }
528
+ } else {
529
+ if (y1 - y2 > 0) {
530
+ if (x1 - x2 < 0 || GeometryUtils.almostEqual(x1, x2)) {
531
+ return /*#__PURE__*/React.createElement("g", {
532
+ key: "base-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
533
+ }, /*#__PURE__*/React.createElement("line", {
534
+ x1: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI),
535
+ y1: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI),
536
+ x2: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
537
+ y2: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
538
+ style: STYLE_DASH
539
+ }), /*#__PURE__*/React.createElement(Ruler, {
540
+ key: 5,
541
+ layer: layer,
542
+ unit: scene.unit,
543
+ rulerUnit: scene.rulerUnit,
544
+ length: pAw.length,
545
+ transform: "translate(".concat(pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0)"),
546
+ style: selectStyle(pAw, STYLE_BASE_ITEM)
547
+ }), /*#__PURE__*/React.createElement("line", {
548
+ x1: pAw.pos.x,
549
+ y1: pAw.pos.y,
550
+ x2: pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
551
+ y2: pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
552
+ style: STYLE_DASH
553
+ }));
554
+ } else {
555
+ return /*#__PURE__*/React.createElement("g", {
556
+ key: "base-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
557
+ }, /*#__PURE__*/React.createElement("line", {
558
+ x1: pAw.pos.x,
559
+ y1: pAw.pos.y,
560
+ x2: pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
561
+ y2: pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
562
+ style: STYLE_DASH
563
+ }), /*#__PURE__*/React.createElement(Ruler, {
564
+ key: 5,
565
+ layer: layer,
566
+ unit: scene.unit,
567
+ rulerUnit: scene.rulerUnit,
568
+ length: pAw.length,
569
+ transform: "translate(".concat(pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0) scale(-1, -1)"),
570
+ style: selectStyle(pAw, STYLE_BASE_ITEM)
571
+ }), /*#__PURE__*/React.createElement("line", {
572
+ x1: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI),
573
+ y1: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI),
574
+ x2: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
575
+ y2: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
576
+ style: STYLE_DASH
577
+ }));
578
+ }
579
+ } else {
580
+ if (x1 - x2 < 0 || GeometryUtils.almostEqual(x1, x2)) {
581
+ return /*#__PURE__*/React.createElement("g", {
582
+ key: "base-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
583
+ }, /*#__PURE__*/React.createElement("line", {
584
+ x1: pAw.pos.x,
585
+ y1: pAw.pos.y,
586
+ x2: pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
587
+ y2: pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
588
+ style: STYLE_DASH
589
+ }), /*#__PURE__*/React.createElement(Ruler, {
590
+ key: 5,
591
+ layer: layer,
592
+ unit: scene.unit,
593
+ rulerUnit: scene.rulerUnit,
594
+ length: pAw.length,
595
+ transform: "translate(".concat(pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0)"),
596
+ style: selectStyle(pAw, STYLE_BASE_ITEM)
597
+ }), /*#__PURE__*/React.createElement("line", {
598
+ x1: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI),
599
+ y1: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI),
600
+ x2: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
601
+ y2: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
602
+ style: STYLE_DASH
603
+ }));
604
+ } else {
605
+ return /*#__PURE__*/React.createElement("g", {
606
+ key: "base-".concat(idx, "-").concat(pAw.pos.x, "-").concat(pAw.pos.y, "-").concat(pAw.length)
607
+ }, /*#__PURE__*/React.createElement("line", {
608
+ x1: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI),
609
+ y1: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI),
610
+ x2: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
611
+ y2: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
612
+ style: STYLE_DASH
613
+ }), /*#__PURE__*/React.createElement(Ruler, {
614
+ key: 5,
615
+ layer: layer,
616
+ unit: scene.unit,
617
+ rulerUnit: scene.rulerUnit,
618
+ length: pAw.length,
619
+ transform: "translate(".concat(pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0) scale(-1, -1)"),
620
+ style: selectStyle(pAw, STYLE_BASE_ITEM)
621
+ }), /*#__PURE__*/React.createElement("line", {
622
+ x1: pAw.pos.x,
623
+ y1: pAw.pos.y,
624
+ x2: pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
625
+ y2: pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
626
+ style: STYLE_DASH
627
+ }));
628
+ }
629
+ }
630
+ }
631
+ }
632
+ });
633
+ var doorSpace = baseSpace + STEP;
634
+ var renderedHoles = line.holes.map(function (holeID) {
635
+ var hole = layer.holes.get(holeID);
636
+ if (hole === undefined) {
637
+ return '';
638
+ }
639
+ var startAt = length * hole.offset;
640
+ var renderedHole = catalog.getElement(hole.type).render2D(hole, layer, scene);
641
+ return /*#__PURE__*/React.createElement("g", {
642
+ key: holeID,
643
+ transform: "translate(".concat(startAt, ", 3.5)"),
644
+ "data-element-root": true,
645
+ "data-prototype": hole.prototype,
646
+ "data-id": hole.id,
647
+ "data-selected": hole.selected,
648
+ "data-layer": layer.id
649
+ }, renderedHole);
650
+ });
651
+ var renderedLine = catalog.getElement(line.type).render2D(line, layer, scene, state);
652
+ var holeTemp = [];
653
+ var renderedRuler = [];
654
+ var renderedAllRuler = [];
655
+ if (!line.holes.size || !showWindowDoorMeasure) {
656
+ doorSpace -= STEP;
657
+ }
658
+ var allRuler = [0],
659
+ holeData = [];
660
+ var lineHoles = line.holes.sortBy(function (holeID) {
661
+ var hole = layer.holes.get(holeID);
662
+ return !hole ? 0 : hole.offset;
663
+ });
664
+ lineHoles.forEach(function (holeID) {
665
+ var hole = layer.holes.get(holeID);
666
+ if (hole !== undefined) {
667
+ var startAt = length * hole.offset;
668
+ var holeWidth = hole.properties.toJS().width.length;
669
+ allRuler.push(startAt - holeWidth / 2);
670
+ allRuler.push(startAt + holeWidth / 2);
671
+ holeData["".concat(startAt - holeWidth / 2, "_").concat(startAt + holeWidth / 2)] = holeID;
672
+ }
673
+ });
674
+ allRuler.push(length);
675
+ var lineSpace = doorSpace + STEP;
676
+ //the space from the dimensioning line to the top
677
+ var lineSpacedimension1 = 4;
678
+ //the space from the dimensioning line to the bottom
679
+ var lineSpacedimension2 = 14;
680
+ if (compareVertices(vertex0, vertex1) >= 0 && vertex0.x !== vertex1.x) {
681
+ renderedRuler.push(/*#__PURE__*/React.createElement("g", {
682
+ key: "wall-length"
683
+ }, /*#__PURE__*/React.createElement("line", {
684
+ x1: length,
685
+ y1: lineSpace + lineSpacedimension1,
686
+ x2: length,
687
+ y2: lineSpace + lineSpacedimension2,
688
+ style: STYLE_ROOM_SHAPE
689
+ }), /*#__PURE__*/React.createElement(Ruler, {
690
+ key: 0,
691
+ layer: layer,
692
+ unit: scene.unit,
693
+ rulerUnit: scene.rulerUnit,
694
+ length: length,
695
+ transform: "translate(".concat(length, ", ").concat(half_thickness + lineSpace, ") scale(-1, -1)"),
696
+ style: STYLE_ROOM_SHAPE
697
+ }), /*#__PURE__*/React.createElement("line", {
698
+ x1: 0,
699
+ y1: lineSpace + lineSpacedimension1,
700
+ x2: 0,
701
+ y2: lineSpace + lineSpacedimension2,
702
+ style: STYLE_ROOM_SHAPE
703
+ })));
704
+ } else {
705
+ renderedRuler.push(/*#__PURE__*/React.createElement("g", {
706
+ key: "wall-length"
707
+ }, /*#__PURE__*/React.createElement("line", {
708
+ x1: 0,
709
+ y1: lineSpace + lineSpacedimension1,
710
+ x2: 0,
711
+ y2: lineSpace + lineSpacedimension2,
712
+ style: STYLE_ROOM_SHAPE
713
+ }), /*#__PURE__*/React.createElement(Ruler, {
714
+ key: 0,
715
+ layer: layer,
716
+ unit: scene.unit,
717
+ rulerUnit: scene.rulerUnit,
718
+ length: length,
719
+ transform: "translate(0, ".concat(half_thickness + lineSpace, ")"),
720
+ style: STYLE_ROOM_SHAPE
721
+ }), /*#__PURE__*/React.createElement("line", {
722
+ x1: length,
723
+ y1: lineSpace + lineSpacedimension1,
724
+ x2: length,
725
+ y2: lineSpace + lineSpacedimension2,
726
+ style: STYLE_ROOM_SHAPE
727
+ })));
728
+ }
729
+ allRuler.sort(function (a, b) {
730
+ return a - b;
731
+ });
732
+ if (allRuler.length > 2) {
733
+ allRuler.forEach(function (rulerData, index) {
734
+ var element = allRuler[index + 1] - allRuler[index];
735
+ if (!Number.isNaN(element)) {
736
+ var dataProtoType = 'ruler';
737
+ var dataId = holeData["".concat(allRuler[index], "_").concat(allRuler[index + 1])];
738
+ if (!dataId) {
739
+ var holeID1 = holeData["".concat(allRuler[index - 1], "_").concat(allRuler[index])];
740
+ var holeID2 = holeData["".concat(allRuler[index + 1], "_").concat(allRuler[index + 2])];
741
+ if (holeID1 && holeID2) {
742
+ dataId = "".concat(holeID1, ",").concat(holeID2);
743
+ dataProtoType = 'twoHoleRuler';
744
+ } else if (holeID1) {
745
+ dataId = holeID1;
746
+ dataProtoType = 'rightHoleRuler';
747
+ } else if (holeID2) {
748
+ dataId = holeID2;
749
+ dataProtoType = 'leftHoleRuler';
750
+ }
751
+ } else {
752
+ dataProtoType = 'rulerHole';
753
+ }
754
+ if (compareVertices(vertex0, vertex1) >= 0 && vertex0.x !== vertex1.x) {
755
+ renderedAllRuler.push(/*#__PURE__*/React.createElement("g", {
756
+ key: "allRuler_".concat(index),
757
+ transform: "translate(".concat(x1, ", ").concat(y1, ") rotate(").concat(angle, ", 0, 0)")
758
+ }, /*#__PURE__*/React.createElement("line", {
759
+ x1: allRuler[index],
760
+ y1: half_thickness,
761
+ x2: allRuler[index],
762
+ y2: half_thickness + doorSpace,
763
+ style: STYLE_DASH
764
+ }), /*#__PURE__*/React.createElement(Ruler, {
765
+ key: "allRuler_".concat(index),
766
+ layer: layer,
767
+ unit: scene.unit,
768
+ rulerUnit: scene.rulerUnit,
769
+ length: element,
770
+ transform: "translate(".concat(allRuler[index] + element, ", ").concat(half_thickness + doorSpace, " ) scale(-1, -1)"),
771
+ style: STYLE_ROOM_ELEMENT
772
+ }), /*#__PURE__*/React.createElement("line", {
773
+ x1: allRuler[index] + element,
774
+ y1: half_thickness,
775
+ x2: allRuler[index] + element,
776
+ y2: half_thickness + doorSpace,
777
+ style: STYLE_DASH
778
+ })));
779
+ } else {
780
+ renderedAllRuler.push(/*#__PURE__*/React.createElement("g", {
781
+ key: "allRuler_".concat(index),
782
+ transform: "translate(".concat(x1, ", ").concat(y1, ") rotate(").concat(angle, ", 0, 0)")
783
+ }, /*#__PURE__*/React.createElement("line", {
784
+ x1: allRuler[index],
785
+ y1: half_thickness,
786
+ x2: allRuler[index],
787
+ y2: half_thickness + doorSpace,
788
+ style: STYLE_DASH
789
+ }), /*#__PURE__*/React.createElement(Ruler, {
790
+ key: "allRuler_".concat(index),
791
+ layer: layer,
792
+ unit: scene.unit,
793
+ rulerUnit: scene.rulerUnit,
794
+ length: element,
795
+ transform: "translate(".concat(allRuler[index], ", ").concat(half_thickness + doorSpace, " )"),
796
+ style: STYLE_ROOM_ELEMENT
797
+ }), /*#__PURE__*/React.createElement("line", {
798
+ x1: allRuler[index] + element,
799
+ y1: half_thickness,
800
+ x2: allRuler[index] + element,
801
+ y2: half_thickness + doorSpace,
802
+ style: STYLE_DASH
803
+ })));
804
+ }
805
+ }
806
+ });
807
+ }
808
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("g", {
809
+ transform: "translate(".concat(x1, ", ").concat(y1, ") rotate(").concat(angle, ", 0, 0)"),
810
+ "data-element-root": true,
811
+ "data-prototype": 'ruler',
812
+ "data-id": line.id,
813
+ "data-selected": line.selected,
814
+ "data-layer": layer.id,
815
+ "data-length": length
816
+ }, showWallLengthMeasure ? renderedRuler : null), line.selected && angleVertices.map(function (vertex, index) {
817
+ var _relateLineLengthArra2;
818
+ var lineGroup = vertex[0].lines;
819
+ var angles = [];
820
+ var thickness = [];
821
+ var vectories = [];
822
+ var relateLineLengthArray = [];
823
+
824
+ // get the vector of lines
825
+ lineGroup.forEach(function (line) {
826
+ var _relateLineLengthArra;
827
+ line = layer.lines.get(line);
828
+ var vertex0 = layer.vertices.get(line.vertices.get(0));
829
+ var vertex1 = layer.vertices.get(line.vertices.get(1));
830
+ var vec = vertex0 === vertex[0] ? new Three.Vector2(vertex1.x - vertex0.x, vertex1.y - vertex0.y) : new Three.Vector2(vertex0.x - vertex1.x, vertex0.y - vertex1.y);
831
+ (_relateLineLengthArra = relateLineLengthArray) === null || _relateLineLengthArra === void 0 || _relateLineLengthArra.push(GeometryUtils.verticesDistance(vertex0, vertex1));
832
+ var angle = vec.angle();
833
+ var thick = 15;
834
+ angles.push(angle);
835
+ thickness.push(thick);
836
+ vectories.push(vec.normalize());
837
+ });
838
+ relateLineLengthArray = (_relateLineLengthArra2 = relateLineLengthArray) === null || _relateLineLengthArra2 === void 0 ? void 0 : _relateLineLengthArra2.sort(function (a, b) {
839
+ return a - b;
840
+ });
841
+ var minLineLength = relateLineLengthArray[0] < MAX_ANGLE_SCALE * 2 ? relateLineLengthArray[0] / 2 // scale down to half of the smallest adjacent surface
842
+ : MAX_ANGLE_SCALE;
843
+
844
+ // calculate the angle between two lines
845
+ var center = new Three.Vector2(vertex[0].x, vertex[0].y);
846
+ var pos1 = new Three.Vector2(vertex[1].x, vertex[1].y);
847
+ var pos2 = new Three.Vector2(vertex[2].x, vertex[2].y);
848
+ var cen = center.clone();
849
+ var pos = pos1.clone();
850
+ var vec1 = pos.sub(cen).normalize();
851
+ pos = pos2.clone();
852
+ var vec2 = pos.sub(cen).normalize();
853
+ var v1 = vec1.clone(),
854
+ v2 = vec2.clone();
855
+ var vec = v1.add(v2).normalize();
856
+ var angle = Math.abs(Math.floor(vec1.angle() * 180 / Math.PI - vec2.angle() * 180 / Math.PI + 0.5));
857
+ angle = angle > 180 ? 360 - angle : angle;
858
+ var rotDir = vec1.cross(vec2) > 0; // true: rotate CCW, false: rotate CW
859
+
860
+ // Angle Text Position
861
+ var angleTextO = center.clone();
862
+ var textTranslation = vec1.clone().add(vec2).normalize().multiplyScalar(minLineLength * 2 / 3);
863
+ angleTextO.add(textTranslation);
864
+ angleTextO.y -= minLineLength / 10; // half the height of text `angle`
865
+ angleTextO.x += minLineLength / 10;
866
+ var tx = 0;
867
+ var ty = 0;
868
+ vec = vec.multiplyScalar(minLineLength);
869
+ vec1 = vec1.multiplyScalar(minLineLength);
870
+ var cen1 = center.clone(),
871
+ cen2 = center.clone();
872
+ center = center.add(vec);
873
+ pos1 = cen1.add(vec1);
874
+ var rotated = pos1.clone().rotateAround(cen2, angle / 2.0 * Math.PI / 180);
875
+ var lines = [];
876
+ var t = center.distanceTo(rotated) < 5 ? 1 : -1;
877
+ pos2 = pos1.clone().rotateAround(cen2, t * angle * Math.PI / 180);
878
+
879
+ // Angle SVG Path
880
+ lines.push(/*#__PURE__*/React.createElement("path", {
881
+ key: 'angle-line-' + vertex[0].id + '-' + vertex[1].id + '-' + rotDir,
882
+ style: STYLE_ANGLE,
883
+ d: "\n M ".concat(vertex[0].x, ",").concat(vertex[0].y, " L ").concat(pos1.x, ",").concat(pos1.y, " A ").concat(minLineLength, " ").concat(minLineLength, " ").concat(angle, " 0 ").concat(t > 0 ? 1 : 0, " ").concat(pos2.x, ",").concat(pos2.y, " z\n ")
884
+ }));
885
+ var length = angle;
886
+ // draw angle and angle text
887
+ return /*#__PURE__*/React.createElement("g", {
888
+ key: index,
889
+ transform: "translate(".concat(tx, ", ").concat(ty, ")"),
890
+ "data-element-root": true,
891
+ "data-prototype": "angleChange",
892
+ "data-layer": layer.id,
893
+ "data-selected": "true",
894
+ "data-id": [vertex[0].id, vertex[1].id, rotDir],
895
+ "data-length": length
896
+ }, lines, /*#__PURE__*/React.createElement("text", {
897
+ transform: "translate(".concat(angleTextO.x, ", ").concat(angleTextO.y, ") scale(").concat(minLineLength / 20, ", ").concat(-minLineLength / 20, ")"),
898
+ style: STYLE_TEXT
899
+ }, angle + '° '));
900
+ }), showWindowDoorMeasure ? renderedAllRuler : null, showBaseCabinetMeasure ? baseRuler : null, showWallCabinetMeasure ? wallRuler : null, /*#__PURE__*/React.createElement("g", {
901
+ "data-element-root": true,
902
+ "data-prototype": line.prototype,
903
+ "data-id": line.id,
904
+ id: line.id,
905
+ "data-selected": line.selected,
906
+ "data-layer": layer.id,
907
+ style: line.selected ? {
908
+ cursor: 'move'
909
+ } : {}
910
+ }, renderedLine, /*#__PURE__*/React.createElement("g", {
911
+ transform: "translate(".concat(x1, ", ").concat(y1, ") rotate(").concat(angle, ", 0, 0)")
912
+ }, renderedHoles)), line.selected && /*#__PURE__*/React.createElement("g", {
913
+ id: 'elevation-button',
914
+ key: 1,
915
+ transform: "translate(".concat(x1 + 35, ", ").concat(y1 - 15, ")"),
916
+ style: {
917
+ cursor: 'pointer'
918
+ }
919
+ }, /*#__PURE__*/React.createElement("defs", null, /*#__PURE__*/React.createElement("filter", {
920
+ id: "shadow"
921
+ }, /*#__PURE__*/React.createElement("feDropShadow", {
922
+ dx: "0",
923
+ dy: "0",
924
+ stdDeviation: "0.6"
925
+ }))), /*#__PURE__*/React.createElement("rect", {
926
+ rx: "4",
927
+ ry: "4",
928
+ y: "20",
929
+ height: "22",
930
+ width: "22",
931
+ fill: "white",
932
+ filter: "url(#shadow)"
933
+ }), /*#__PURE__*/React.createElement("image", {
934
+ href: "/assets/img/svg/bottombar/elevation.svg",
935
+ x: "5",
936
+ y: "-36",
937
+ height: "12",
938
+ width: "12",
939
+ style: {
940
+ transform: 'rotateX(180deg)'
941
+ }
942
+ })), line.selected && /*#__PURE__*/React.createElement("g", {
943
+ id: 'remove-button',
944
+ key: 2,
945
+ transform: "translate(".concat(x1 + 10, ", ").concat(y1, ")"),
946
+ style: {
947
+ cursor: 'pointer'
948
+ }
949
+ }, /*#__PURE__*/React.createElement("defs", null, /*#__PURE__*/React.createElement("filter", {
950
+ id: "shadow"
951
+ }, /*#__PURE__*/React.createElement("feDropShadow", {
952
+ dx: "0",
953
+ dy: "0",
954
+ stdDeviation: "0.6"
955
+ }))), /*#__PURE__*/React.createElement("rect", {
956
+ rx: "4",
957
+ ry: "4",
958
+ y: "5",
959
+ height: "22",
960
+ width: "22",
961
+ fill: "white",
962
+ filter: "url(#shadow)"
963
+ }), /*#__PURE__*/React.createElement("image", {
964
+ href: "/assets/img/svg/delete.svg",
965
+ x: "3",
966
+ y: "-24",
967
+ height: "16",
968
+ width: "16",
969
+ style: {
970
+ transform: 'rotateX(180deg)'
971
+ }
972
+ })), /*#__PURE__*/React.createElement("use", {
973
+ id: 'use elevation button',
974
+ xlinkHref: '#elevation-button',
975
+ "data-element-root": true,
976
+ "data-prototype": line.prototype,
977
+ "data-id": line.id,
978
+ "data-selected": line.selected,
979
+ "data-layer": layer.id,
980
+ "data-part": "elevation"
981
+ }), /*#__PURE__*/React.createElement("use", {
982
+ id: 'use remove button',
983
+ xlinkHref: '#remove-button',
984
+ "data-element-root": true,
985
+ "data-prototype": line.prototype,
986
+ "data-id": line.id,
987
+ "data-selected": line.selected,
988
+ "data-layer": layer.id,
989
+ "data-part": "remove"
990
+ }));
991
+ }
992
+ Line.propTypes = {
993
+ line: PropTypes.object.isRequired,
994
+ layer: PropTypes.object.isRequired,
995
+ scene: PropTypes.object.isRequired,
996
+ catalog: PropTypes.object.isRequired
997
+ };