kitchen-simulator 2.0.0 → 2.0.1-dot-color

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 (1165) hide show
  1. package/README.md +24 -1
  2. package/es/@history.js +2 -0
  3. package/es/AppContext.js +3 -0
  4. package/es/LiteKitchenConfigurator.js +480 -0
  5. package/es/LiteRenderer.js +503 -0
  6. package/es/actions/area-actions.js +14 -0
  7. package/es/actions/export.js +36 -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 +318 -0
  11. package/es/actions/lines-actions.js +81 -0
  12. package/es/actions/project-actions.js +286 -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/analytics/ga4.js +188 -0
  18. package/es/analytics/posthog.js +60 -0
  19. package/es/assets/Window.hdr +2100 -0
  20. package/es/assets/brown_photostudio_02_1k.hdr +0 -0
  21. package/es/assets/fonts/Rene Bieder Milliard Black Italic.woff +0 -0
  22. package/es/assets/fonts/Rene Bieder Milliard Black.woff +0 -0
  23. package/es/assets/fonts/Rene Bieder Milliard Bold Italic.woff +0 -0
  24. package/es/assets/fonts/Rene Bieder Milliard Bold.woff +0 -0
  25. package/es/assets/fonts/Rene Bieder Milliard Book Italic.woff +0 -0
  26. package/es/assets/fonts/Rene Bieder Milliard Book.woff +0 -0
  27. package/es/assets/fonts/Rene Bieder Milliard ExtraBold Italic.woff +0 -0
  28. package/es/assets/fonts/Rene Bieder Milliard ExtraBold.woff +0 -0
  29. package/es/assets/fonts/Rene Bieder Milliard ExtraLight Italic.woff +0 -0
  30. package/es/assets/fonts/Rene Bieder Milliard ExtraLight.woff +0 -0
  31. package/es/assets/fonts/Rene Bieder Milliard Hairline Italic.woff +0 -0
  32. package/es/assets/fonts/Rene Bieder Milliard Hairline.woff +0 -0
  33. package/es/assets/fonts/Rene Bieder Milliard Heavy Italic.woff +0 -0
  34. package/es/assets/fonts/Rene Bieder Milliard Heavy.woff +0 -0
  35. package/es/assets/fonts/Rene Bieder Milliard Light Italic.woff +0 -0
  36. package/es/assets/fonts/Rene Bieder Milliard Light.woff +0 -0
  37. package/es/assets/fonts/Rene Bieder Milliard Medium Italic.woff +0 -0
  38. package/es/assets/fonts/Rene Bieder Milliard Medium.woff +0 -0
  39. package/es/assets/fonts/Rene Bieder Milliard SemiBold Italic.woff +0 -0
  40. package/es/assets/fonts/Rene Bieder Milliard SemiBold.woff +0 -0
  41. package/es/assets/fonts/Rene Bieder Milliard Thin Italic.woff +0 -0
  42. package/es/assets/fonts/Rene Bieder Milliard Thin.woff +0 -0
  43. package/es/assets/fonts/style.css +177 -0
  44. package/es/assets/gltf/door_closet.bin +0 -0
  45. package/es/assets/gltf/door_closet.fbx +0 -0
  46. package/es/assets/gltf/door_closet.gltf +1 -0
  47. package/es/assets/gltf/door_exterior.bin +0 -0
  48. package/es/assets/gltf/door_exterior.fbx +0 -0
  49. package/es/assets/gltf/door_exterior.gltf +1 -0
  50. package/es/assets/gltf/door_interior.bin +0 -0
  51. package/es/assets/gltf/door_interior.fbx +0 -0
  52. package/es/assets/gltf/door_interior.gltf +1 -0
  53. package/es/assets/gltf/door_sliding.bin +0 -0
  54. package/es/assets/gltf/door_sliding.fbx +0 -0
  55. package/es/assets/gltf/door_sliding.gltf +1 -0
  56. package/es/assets/gltf/doorway_framed.bin +0 -0
  57. package/es/assets/gltf/doorway_framed.fbx +0 -0
  58. package/es/assets/gltf/doorway_framed.gltf +1 -0
  59. package/es/assets/gltf/window_clear.bin +0 -0
  60. package/es/assets/gltf/window_clear.fbx +0 -0
  61. package/es/assets/gltf/window_clear.gltf +1 -0
  62. package/es/assets/gltf/window_cross.bin +0 -0
  63. package/es/assets/gltf/window_cross.fbx +0 -0
  64. package/es/assets/gltf/window_cross.gltf +1 -0
  65. package/es/assets/gltf/window_double_hung.bin +0 -0
  66. package/es/assets/gltf/window_double_hung.fbx +0 -0
  67. package/es/assets/gltf/window_double_hung.gltf +1 -0
  68. package/es/assets/gltf/window_vertical.bin +0 -0
  69. package/es/assets/gltf/window_vertical.fbx +0 -0
  70. package/es/assets/gltf/window_vertical.gltf +1 -0
  71. package/es/assets/img/1.jpg +0 -0
  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 +11 -0
  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 +55 -0
  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 +33 -0
  105. package/es/assets/img/svg/2d_delete_object1.svg +33 -0
  106. package/es/assets/img/svg/2d_lock_object.svg +33 -0
  107. package/es/assets/img/svg/3d_item_move.svg +106 -0
  108. package/es/assets/img/svg/3d_item_rotation.svg +76 -0
  109. package/es/assets/img/svg/3d_item_warning_edit.svg +77 -0
  110. package/es/assets/img/svg/3d_item_warning_info.svg +81 -0
  111. package/es/assets/img/svg/accessories.svg +4 -0
  112. package/es/assets/img/svg/angle_icon.svg +39 -0
  113. package/es/assets/img/svg/blank_div.svg +14 -0
  114. package/es/assets/img/svg/bottombar/2d3d_button.svg +3 -0
  115. package/es/assets/img/svg/bottombar/2d3d_button_active.svg +3 -0
  116. package/es/assets/img/svg/bottombar/2d3d_toggle.svg +4 -0
  117. package/es/assets/img/svg/bottombar/2d3d_toggle_active.svg +4 -0
  118. package/es/assets/img/svg/bottombar/arrow-down.svg +3 -0
  119. package/es/assets/img/svg/bottombar/arrow-left.svg +3 -0
  120. package/es/assets/img/svg/bottombar/arrow-minus.svg +3 -0
  121. package/es/assets/img/svg/bottombar/arrow-plus.svg +11 -0
  122. package/es/assets/img/svg/bottombar/arrow-right.svg +3 -0
  123. package/es/assets/img/svg/bottombar/arrow-up.svg +3 -0
  124. package/es/assets/img/svg/bottombar/collapse.svg +3 -0
  125. package/es/assets/img/svg/bottombar/elevation-back.svg +6 -0
  126. package/es/assets/img/svg/bottombar/elevation-front.svg +6 -0
  127. package/es/assets/img/svg/bottombar/elevation-left.svg +6 -0
  128. package/es/assets/img/svg/bottombar/elevation-right.svg +7 -0
  129. package/es/assets/img/svg/bottombar/elevation.svg +6 -0
  130. package/es/assets/img/svg/bottombar/expand.svg +3 -0
  131. package/es/assets/img/svg/bottombar/help.svg +72 -0
  132. package/es/assets/img/svg/bottombar/incm_toggle.svg +39 -0
  133. package/es/assets/img/svg/bottombar/pan_1.svg +57 -0
  134. package/es/assets/img/svg/bottombar/pan_2.svg +27 -0
  135. package/es/assets/img/svg/bottombar/pan_3.svg +27 -0
  136. package/es/assets/img/svg/bottombar/pan_4.svg +27 -0
  137. package/es/assets/img/svg/bottombar/pan_5.svg +27 -0
  138. package/es/assets/img/svg/bottombar/settings.svg +23 -0
  139. package/es/assets/img/svg/bottombar/spin-down.svg +76 -0
  140. package/es/assets/img/svg/bottombar/spin-left.svg +75 -0
  141. package/es/assets/img/svg/bottombar/spin-right.svg +75 -0
  142. package/es/assets/img/svg/bottombar/spin-up.svg +76 -0
  143. package/es/assets/img/svg/bottombar/spin_1.svg +48 -0
  144. package/es/assets/img/svg/bottombar/spin_2.svg +31 -0
  145. package/es/assets/img/svg/bottombar/spin_3.svg +31 -0
  146. package/es/assets/img/svg/bottombar/spin_4.svg +31 -0
  147. package/es/assets/img/svg/bottombar/spin_5.svg +31 -0
  148. package/es/assets/img/svg/bottombar/zoomin.svg +29 -0
  149. package/es/assets/img/svg/bottombar/zoomout.svg +26 -0
  150. package/es/assets/img/svg/check.svg +10 -0
  151. package/es/assets/img/svg/close.svg +11 -0
  152. package/es/assets/img/svg/color/Black.svg +3 -0
  153. package/es/assets/img/svg/color/Blue.svg +3 -0
  154. package/es/assets/img/svg/color/Brown.svg +9 -0
  155. package/es/assets/img/svg/color/Cream.svg +3 -0
  156. package/es/assets/img/svg/color/Dark.svg +9 -0
  157. package/es/assets/img/svg/color/Gray.svg +3 -0
  158. package/es/assets/img/svg/color/Green.svg +3 -0
  159. package/es/assets/img/svg/color/Light.svg +9 -0
  160. package/es/assets/img/svg/color/Medium.svg +9 -0
  161. package/es/assets/img/svg/color/Unfinished.svg +9 -0
  162. package/es/assets/img/svg/color/White.svg +3 -0
  163. package/es/assets/img/svg/color/White.svg.bak +3 -0
  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 +11 -0
  167. package/es/assets/img/svg/delete.svg +3 -0
  168. package/es/assets/img/svg/detail.svg +77 -0
  169. package/es/assets/img/svg/disclaimer/background.svg +758 -0
  170. package/es/assets/img/svg/disclaimer/logo-dots.svg +11 -0
  171. package/es/assets/img/svg/door/Closet.svg +11 -0
  172. package/es/assets/img/svg/door/Exterior.svg +5 -0
  173. package/es/assets/img/svg/door/Framed_dorway.svg +5 -0
  174. package/es/assets/img/svg/door/Frameless_dorway.svg +5 -0
  175. package/es/assets/img/svg/door/Interior.svg +7 -0
  176. package/es/assets/img/svg/door/Sliding.svg +5 -0
  177. package/es/assets/img/svg/doors_closet.svg +47 -0
  178. package/es/assets/img/svg/doors_exterior.svg +25 -0
  179. package/es/assets/img/svg/doors_interior.svg +29 -0
  180. package/es/assets/img/svg/doors_patio.svg +26 -0
  181. package/es/assets/img/svg/duplicate.svg +11 -0
  182. package/es/assets/img/svg/duplicate_object_left.svg +32 -0
  183. package/es/assets/img/svg/duplicate_object_right.svg +32 -0
  184. package/es/assets/img/svg/filtersActive.svg +19 -0
  185. package/es/assets/img/svg/firstsetting/L.svg +3 -0
  186. package/es/assets/img/svg/firstsetting/L2.svg +3 -0
  187. package/es/assets/img/svg/firstsetting/Open.svg +3 -0
  188. package/es/assets/img/svg/firstsetting/Square.svg +3 -0
  189. package/es/assets/img/svg/firstsetting/bar-active.svg +9 -0
  190. package/es/assets/img/svg/firstsetting/bar-normal.svg +3 -0
  191. package/es/assets/img/svg/firstsetting/bullet-current.svg +3 -0
  192. package/es/assets/img/svg/firstsetting/bullet-done.svg +3 -0
  193. package/es/assets/img/svg/firstsetting/bullet-not-done.svg +3 -0
  194. package/es/assets/img/svg/firstsetting/check-active.svg +3 -0
  195. package/es/assets/img/svg/firstsetting/check-normal.svg +3 -0
  196. package/es/assets/img/svg/firstsetting/pencil.svg +11 -0
  197. package/es/assets/img/svg/green_checkmark.svg +27 -0
  198. package/es/assets/img/svg/headerbar/assist.svg +3 -0
  199. package/es/assets/img/svg/headerbar/cart.svg +3 -0
  200. package/es/assets/img/svg/headerbar/check.svg +10 -0
  201. package/es/assets/img/svg/headerbar/consult_designer.svg +45 -0
  202. package/es/assets/img/svg/headerbar/edit_name.svg +26 -0
  203. package/es/assets/img/svg/headerbar/file-dollar.svg +13 -0
  204. package/es/assets/img/svg/headerbar/hamburger_menu.svg +32 -0
  205. package/es/assets/img/svg/headerbar/plus.svg +11 -0
  206. package/es/assets/img/svg/headerbar/review_quote.svg +44 -0
  207. package/es/assets/img/svg/headerbar/ruler-measure.svg +11 -0
  208. package/es/assets/img/svg/headerbar/save.svg +3 -0
  209. package/es/assets/img/svg/headerbar/setting.svg +75 -0
  210. package/es/assets/img/svg/help/check.svg +10 -0
  211. package/es/assets/img/svg/help/search.svg +76 -0
  212. package/es/assets/img/svg/intro/1-start-with-floorplan-whole.svg +27 -0
  213. package/es/assets/img/svg/intro/1-start-with-floorplan.svg +26 -0
  214. package/es/assets/img/svg/intro/2-start-from-scratch-whole.svg +28 -0
  215. package/es/assets/img/svg/intro/2-start-from-scratch.svg +27 -0
  216. package/es/assets/img/svg/intro/3-retrieve-project-whole.svg +19 -0
  217. package/es/assets/img/svg/intro/3-retrieve-project.svg +18 -0
  218. package/es/assets/img/svg/invert.svg +127 -0
  219. package/es/assets/img/svg/lefttoolbar/appliance-active.svg +13 -0
  220. package/es/assets/img/svg/lefttoolbar/appliance.svg +13 -0
  221. package/es/assets/img/svg/lefttoolbar/cabinet-active.svg +10 -0
  222. package/es/assets/img/svg/lefttoolbar/cabinet-category.svg +3 -0
  223. package/es/assets/img/svg/lefttoolbar/cabinet-one.svg +3 -0
  224. package/es/assets/img/svg/lefttoolbar/cabinet.svg +10 -0
  225. package/es/assets/img/svg/lefttoolbar/disigner_assistance.svg +89 -0
  226. package/es/assets/img/svg/lefttoolbar/door-style-active.svg +20 -0
  227. package/es/assets/img/svg/lefttoolbar/door-style.svg +20 -0
  228. package/es/assets/img/svg/lefttoolbar/door.svg +12 -0
  229. package/es/assets/img/svg/lefttoolbar/error_icon.svg +81 -0
  230. package/es/assets/img/svg/lefttoolbar/finishing-active.svg +13 -0
  231. package/es/assets/img/svg/lefttoolbar/finishing.svg +13 -0
  232. package/es/assets/img/svg/lefttoolbar/reviewforquote-active.svg +86 -0
  233. package/es/assets/img/svg/lefttoolbar/reviewforquote.svg +12 -0
  234. package/es/assets/img/svg/lefttoolbar/room-shape-L.svg +3 -0
  235. package/es/assets/img/svg/lefttoolbar/room-shape-active.svg +18 -0
  236. package/es/assets/img/svg/lefttoolbar/room-shape-custom.svg +12 -0
  237. package/es/assets/img/svg/lefttoolbar/room-shape-irregular.svg +3 -0
  238. package/es/assets/img/svg/lefttoolbar/room-shape-open.svg +3 -0
  239. package/es/assets/img/svg/lefttoolbar/room-shape-square.svg +3 -0
  240. package/es/assets/img/svg/lefttoolbar/room-shape.svg +18 -0
  241. package/es/assets/img/svg/lefttoolbar/search.svg +76 -0
  242. package/es/assets/img/svg/lefttoolbar/view_more.svg +86 -0
  243. package/es/assets/img/svg/lefttoolbar/warning_icon.svg +81 -0
  244. package/es/assets/img/svg/lefttoolbar/window.svg +12 -0
  245. package/es/assets/img/svg/logo.svg +11 -0
  246. package/es/assets/img/svg/logo_with_text.svg +25 -0
  247. package/es/assets/img/svg/menubar/login.svg +84 -0
  248. package/es/assets/img/svg/menubar/my_projects.svg +85 -0
  249. package/es/assets/img/svg/menubar/new_project.svg +110 -0
  250. package/es/assets/img/svg/menubar/save_project.svg +84 -0
  251. package/es/assets/img/svg/options.svg +3 -0
  252. package/es/assets/img/svg/positioning.svg +3 -0
  253. package/es/assets/img/svg/rotate.png +0 -0
  254. package/es/assets/img/svg/rotate.svg +17 -0
  255. package/es/assets/img/svg/rotate_object_clockwise.svg +26 -0
  256. package/es/assets/img/svg/rotate_object_counterclockwise.svg +26 -0
  257. package/es/assets/img/svg/toggleFilters.svg +19 -0
  258. package/es/assets/img/svg/toolbar/add_appliances_active.svg +64 -0
  259. package/es/assets/img/svg/toolbar/add_appliances_inactive.svg +52 -0
  260. package/es/assets/img/svg/toolbar/add_button.svg +36 -0
  261. package/es/assets/img/svg/toolbar/add_cabinets_active.svg +59 -0
  262. package/es/assets/img/svg/toolbar/add_cabinets_inactive.svg +49 -0
  263. package/es/assets/img/svg/toolbar/add_items_doors.svg +25 -0
  264. package/es/assets/img/svg/toolbar/add_items_doorways.svg +24 -0
  265. package/es/assets/img/svg/toolbar/add_items_refrigerator.svg +32 -0
  266. package/es/assets/img/svg/toolbar/add_items_windows.svg +28 -0
  267. package/es/assets/img/svg/toolbar/apply_button.svg +38 -0
  268. package/es/assets/img/svg/toolbar/arrow-plus.svg +11 -0
  269. package/es/assets/img/svg/toolbar/backsplash.svg +8 -0
  270. package/es/assets/img/svg/toolbar/cancel_button.svg +37 -0
  271. package/es/assets/img/svg/toolbar/consult_a_designer_button.svg +47 -0
  272. package/es/assets/img/svg/toolbar/countertop.svg +7 -0
  273. package/es/assets/img/svg/toolbar/dcm.png +0 -0
  274. package/es/assets/img/svg/toolbar/dcm_off.svg +12 -0
  275. package/es/assets/img/svg/toolbar/dcm_on.svg +474 -0
  276. package/es/assets/img/svg/toolbar/delete_button.svg +37 -0
  277. package/es/assets/img/svg/toolbar/download.svg +77 -0
  278. package/es/assets/img/svg/toolbar/draw_custom_floor.svg +31 -0
  279. package/es/assets/img/svg/toolbar/edit_button.svg +75 -0
  280. package/es/assets/img/svg/toolbar/email_quote_button.svg +44 -0
  281. package/es/assets/img/svg/toolbar/fbm.png +0 -0
  282. package/es/assets/img/svg/toolbar/finishing_touches_active.svg +54 -0
  283. package/es/assets/img/svg/toolbar/finishing_touches_inactive.svg +42 -0
  284. package/es/assets/img/svg/toolbar/floorstyle.svg +9 -0
  285. package/es/assets/img/svg/toolbar/fmb.png +0 -0
  286. package/es/assets/img/svg/toolbar/fmb_off.svg +12 -0
  287. package/es/assets/img/svg/toolbar/fmb_on.svg +489 -0
  288. package/es/assets/img/svg/toolbar/furnishings_icon.svg +6 -0
  289. package/es/assets/img/svg/toolbar/get_started_button.svg +41 -0
  290. package/es/assets/img/svg/toolbar/handles.svg +5 -0
  291. package/es/assets/img/svg/toolbar/lighting.svg +7 -0
  292. package/es/assets/img/svg/toolbar/lrm.png +0 -0
  293. package/es/assets/img/svg/toolbar/lrm_off.svg +12 -0
  294. package/es/assets/img/svg/toolbar/lrm_on.svg +470 -0
  295. package/es/assets/img/svg/toolbar/make_floorplan_active.svg +66 -0
  296. package/es/assets/img/svg/toolbar/make_floorplan_inactive.svg +52 -0
  297. package/es/assets/img/svg/toolbar/predefined_room_l_shaped.svg +20 -0
  298. package/es/assets/img/svg/toolbar/predefined_room_layout.svg +20 -0
  299. package/es/assets/img/svg/toolbar/predefined_room_long_narrow.svg +20 -0
  300. package/es/assets/img/svg/toolbar/predefined_room_open_l_shape.svg +20 -0
  301. package/es/assets/img/svg/toolbar/predefined_room_open_pentagon.svg +20 -0
  302. package/es/assets/img/svg/toolbar/predefined_room_open_rectangle.svg +20 -0
  303. package/es/assets/img/svg/toolbar/predefined_room_open_rectangle_2.svg +20 -0
  304. package/es/assets/img/svg/toolbar/predefined_room_pentagon.svg +20 -0
  305. package/es/assets/img/svg/toolbar/predefined_room_rectangle.svg +20 -0
  306. package/es/assets/img/svg/toolbar/predefined_room_rectangle_with_alcove.svg +20 -0
  307. package/es/assets/img/svg/toolbar/redo_button.svg +75 -0
  308. package/es/assets/img/svg/toolbar/redo_button1.svg +75 -0
  309. package/es/assets/img/svg/toolbar/review_quote_active.svg +14 -0
  310. package/es/assets/img/svg/toolbar/review_quote_inactive.svg +44 -0
  311. package/es/assets/img/svg/toolbar/save_project_button.svg +44 -0
  312. package/es/assets/img/svg/toolbar/select_doorstyle_active.svg +67 -0
  313. package/es/assets/img/svg/toolbar/select_doorstyle_inactive.svg +57 -0
  314. package/es/assets/img/svg/toolbar/shopping-cart.svg +13 -0
  315. package/es/assets/img/svg/toolbar/style_change_button.svg +47 -0
  316. package/es/assets/img/svg/toolbar/take_picture.svg +75 -0
  317. package/es/assets/img/svg/toolbar/undo_button.svg +76 -0
  318. package/es/assets/img/svg/toolbar/undo_button1.svg +76 -0
  319. package/es/assets/img/svg/toolbar/use_button.svg +37 -0
  320. package/es/assets/img/svg/toolbar/wall_color_icon.svg +6 -0
  321. package/es/assets/img/svg/topbar/edit_active.svg +10 -0
  322. package/es/assets/img/svg/topbar/edit_inactive.svg +10 -0
  323. package/es/assets/img/svg/topbar/redo_active.svg +42 -0
  324. package/es/assets/img/svg/topbar/redo_inactive.svg +23 -0
  325. package/es/assets/img/svg/topbar/select_all_active.svg +50 -0
  326. package/es/assets/img/svg/topbar/select_all_inactive.svg +32 -0
  327. package/es/assets/img/svg/topbar/take_picture_active.svg +51 -0
  328. package/es/assets/img/svg/topbar/take_picture_inactive.svg +26 -0
  329. package/es/assets/img/svg/topbar/undo_active.svg +42 -0
  330. package/es/assets/img/svg/topbar/undo_inactive.svg +23 -0
  331. package/es/assets/img/svg/warning_info_2d.svg +81 -0
  332. package/es/assets/img/svg/window/Clear.svg +3 -0
  333. package/es/assets/img/svg/window/Cross.svg +5 -0
  334. package/es/assets/img/svg/window/Double_hung.svg +4 -0
  335. package/es/assets/img/svg/window/Vertical.svg +4 -0
  336. package/es/assets/img/svg/windows_clear.svg +23 -0
  337. package/es/assets/img/svg/windows_cross.svg +28 -0
  338. package/es/assets/img/svg/windows_double_hung.svg +24 -0
  339. package/es/assets/img/svg/windows_vertical.svg +24 -0
  340. package/es/assets/img/svg/wizardstep/Custom.svg +3 -0
  341. package/es/assets/img/svg/wizardstep/Dashed_line.svg +3 -0
  342. package/es/assets/img/svg/wizardstep/L.svg +3 -0
  343. package/es/assets/img/svg/wizardstep/L2.svg +3 -0
  344. package/es/assets/img/svg/wizardstep/Open.svg +3 -0
  345. package/es/assets/img/svg/wizardstep/Square.svg +3 -0
  346. package/es/assets/img/svg/wizardstep/bar-active.svg +9 -0
  347. package/es/assets/img/svg/wizardstep/bar-normal.svg +3 -0
  348. package/es/assets/img/svg/wizardstep/bullet-current.svg +3 -0
  349. package/es/assets/img/svg/wizardstep/bullet-done.svg +3 -0
  350. package/es/assets/img/svg/wizardstep/bullet-not-done.svg +3 -0
  351. package/es/assets/img/svg/wizardstep/check-active.svg +3 -0
  352. package/es/assets/img/svg/wizardstep/check-normal.svg +3 -0
  353. package/es/assets/img/svg/wizardstep/detail_view.svg +87 -0
  354. package/es/assets/img/svg/wizardstep/pencil.svg +11 -0
  355. package/es/assets/img/svg/wizardstep/tile_view.svg +95 -0
  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 +1 -0
  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 +1 -0
  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 +1 -0
  369. package/es/assets/rtastore_logo.png +0 -0
  370. package/es/catalog/areas/area/planner-element.js +45 -0
  371. package/es/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  372. package/es/catalog/areas/area/textures/grass.jpg +0 -0
  373. package/es/catalog/areas/area/textures/parquet.jpg +0 -0
  374. package/es/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  375. package/es/catalog/areas/area/textures/tile1.jpg +0 -0
  376. package/es/catalog/back.png +0 -0
  377. package/es/catalog/catalog.js +265 -0
  378. package/es/catalog/doors.png +0 -0
  379. package/es/catalog/doorways.png +0 -0
  380. package/es/catalog/envMap/nx.hdr +0 -0
  381. package/es/catalog/envMap/ny.hdr +0 -0
  382. package/es/catalog/envMap/nz.hdr +0 -0
  383. package/es/catalog/envMap/px.hdr +0 -0
  384. package/es/catalog/envMap/py.hdr +0 -0
  385. package/es/catalog/envMap/pz.hdr +0 -0
  386. package/es/catalog/export.js +0 -0
  387. package/es/catalog/factories/area-factory-3d.js +181 -0
  388. package/es/catalog/factories/area-factory.js +78 -0
  389. package/es/catalog/factories/export.js +7 -0
  390. package/es/catalog/factories/wall-factory-3d.js +202 -0
  391. package/es/catalog/factories/wall-factory.js +267 -0
  392. package/es/catalog/holes/door-closet/planner-element.js +222 -0
  393. package/es/catalog/holes/door-double/door_double.png +0 -0
  394. package/es/catalog/holes/door-double/planner-element.js +315 -0
  395. package/es/catalog/holes/door-exterior/planner-element.js +215 -0
  396. package/es/catalog/holes/door-interior/planner-element.js +227 -0
  397. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  398. package/es/catalog/holes/door-panic/planner-element.js +503 -0
  399. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  400. package/es/catalog/holes/door-panic-double/planner-element.js +463 -0
  401. package/es/catalog/holes/door-sliding/planner-element.js +225 -0
  402. package/es/catalog/holes/doorway-framed/planner-element.js +145 -0
  403. package/es/catalog/holes/doorway-frameless/planner-element.js +104 -0
  404. package/es/catalog/holes/export.js +13 -0
  405. package/es/catalog/holes/gate/gate.jpg +0 -0
  406. package/es/catalog/holes/window-clear/planner-element.js +166 -0
  407. package/es/catalog/holes/window-clear/texture.png +0 -0
  408. package/es/catalog/holes/window-cross/planner-element.js +165 -0
  409. package/es/catalog/holes/window-cross/texture.png +0 -0
  410. package/es/catalog/holes/window-double-hung/planner-element.js +303 -0
  411. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  412. package/es/catalog/holes/window-vertical/planner-element.js +276 -0
  413. package/es/catalog/holes/window-vertical/texture.png +0 -0
  414. package/es/catalog/lines/wall/planner-element.js +79 -0
  415. package/es/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  416. package/es/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
  417. package/es/catalog/lines/wall/textures/bricks.jpg +0 -0
  418. package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
  419. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  420. package/es/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  421. package/es/catalog/lines/wall/textures/morden.jpg +0 -0
  422. package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
  423. package/es/catalog/lines/wall/textures/painted.jpg +0 -0
  424. package/es/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  425. package/es/catalog/lines/wall/textures/plaster.jpg +0 -0
  426. package/es/catalog/lines/wall/wall.png +0 -0
  427. package/es/catalog/molding/molding-dcm/planner-element.js +26 -0
  428. package/es/catalog/molding/molding-dcm/texture.png +0 -0
  429. package/es/catalog/molding/molding-fbm/planner-element.js +26 -0
  430. package/es/catalog/molding/molding-fbm/texture.png +0 -0
  431. package/es/catalog/molding/molding-lrm/planner-element.js +26 -0
  432. package/es/catalog/molding/molding-lrm/texture.png +0 -0
  433. package/es/catalog/properties/export.js +21 -0
  434. package/es/catalog/properties/property-checkbox.js +68 -0
  435. package/es/catalog/properties/property-color.js +39 -0
  436. package/es/catalog/properties/property-enum.js +50 -0
  437. package/es/catalog/properties/property-hidden.js +19 -0
  438. package/es/catalog/properties/property-lenght-measure.js +100 -0
  439. package/es/catalog/properties/property-length-measure.js +84 -0
  440. package/es/catalog/properties/property-length-measure_hole.js +100 -0
  441. package/es/catalog/properties/property-number.js +48 -0
  442. package/es/catalog/properties/property-read-only.js +26 -0
  443. package/es/catalog/properties/property-string.js +48 -0
  444. package/es/catalog/properties/property-toggle.js +39 -0
  445. package/es/catalog/properties/shared-property-style.js +14 -0
  446. package/es/catalog/utils/FuseUtils.js +79 -0
  447. package/es/catalog/utils/exporter.js +149 -0
  448. package/es/catalog/utils/geom-utils.js +189 -0
  449. package/es/catalog/utils/item-loader.js +1594 -0
  450. package/es/catalog/utils/load-obj.js +91 -0
  451. package/es/catalog/utils/mtl-loader.js +357 -0
  452. package/es/catalog/utils/obj-loader.js +476 -0
  453. package/es/catalog/windows.png +0 -0
  454. package/es/class/FuseUtils.js +79 -0
  455. package/es/class/area.js +141 -0
  456. package/es/class/export.js +24 -0
  457. package/es/class/group.js +431 -0
  458. package/es/class/guide.js +58 -0
  459. package/es/class/hole.js +926 -0
  460. package/es/class/item.js +1845 -0
  461. package/es/class/layer.js +663 -0
  462. package/es/class/line.js +1221 -0
  463. package/es/class/project.js +795 -0
  464. package/es/class/vertex.js +198 -0
  465. package/es/components/content.js +131 -0
  466. package/es/components/export.js +7 -0
  467. package/es/components/style/button.js +106 -0
  468. package/es/components/style/cancel-button.js +21 -0
  469. package/es/components/style/content-container.js +30 -0
  470. package/es/components/style/content-title.js +25 -0
  471. package/es/components/style/delete-button.js +24 -0
  472. package/es/components/style/export.js +31 -0
  473. package/es/components/style/form-block.js +20 -0
  474. package/es/components/style/form-color-input.js +26 -0
  475. package/es/components/style/form-label.js +22 -0
  476. package/es/components/style/form-number-input.js +183 -0
  477. package/es/components/style/form-number-input_2.js +200 -0
  478. package/es/components/style/form-select.js +19 -0
  479. package/es/components/style/form-slider.js +60 -0
  480. package/es/components/style/form-submit-button.js +25 -0
  481. package/es/components/style/form-text-input.js +69 -0
  482. package/es/components/viewer2d/area.js +81 -0
  483. package/es/components/viewer2d/export.js +31 -0
  484. package/es/components/viewer2d/grids/grid-horizontal-streak.js +36 -0
  485. package/es/components/viewer2d/grids/grid-streak.js +36 -0
  486. package/es/components/viewer2d/grids/grid-vertical-streak.js +36 -0
  487. package/es/components/viewer2d/grids/grids.js +30 -0
  488. package/es/components/viewer2d/group.js +53 -0
  489. package/es/components/viewer2d/item.js +447 -0
  490. package/es/components/viewer2d/layer.js +164 -0
  491. package/es/components/viewer2d/line.js +964 -0
  492. package/es/components/viewer2d/ruler.js +79 -0
  493. package/es/components/viewer2d/rulerDist.js +132 -0
  494. package/es/components/viewer2d/rulerX.js +145 -0
  495. package/es/components/viewer2d/rulerY.js +147 -0
  496. package/es/components/viewer2d/scene.js +128 -0
  497. package/es/components/viewer2d/snap.js +74 -0
  498. package/es/components/viewer2d/state.js +73 -0
  499. package/es/components/viewer2d/utils.js +187 -0
  500. package/es/components/viewer2d/vertex.js +65 -0
  501. package/es/components/viewer2d/viewer2d.js +1433 -0
  502. package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +2585 -0
  503. package/es/components/viewer3d/dcm.js +401 -0
  504. package/es/components/viewer3d/fbm.js +414 -0
  505. package/es/components/viewer3d/front3D.js +61 -0
  506. package/es/components/viewer3d/grid-creator.js +25 -0
  507. package/es/components/viewer3d/grids/grid-horizontal-streak.js +36 -0
  508. package/es/components/viewer3d/grids/grid-streak.js +27 -0
  509. package/es/components/viewer3d/grids/grid-vertical-streak.js +36 -0
  510. package/es/components/viewer3d/libs/first-person-controls.js +67 -0
  511. package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +1281 -0
  512. package/es/components/viewer3d/libs/mtl-loader.js +357 -0
  513. package/es/components/viewer3d/libs/obj-loader.js +462 -0
  514. package/es/components/viewer3d/libs/orbit-controls.js +697 -0
  515. package/es/components/viewer3d/libs/pointer-lock-controls.js +44 -0
  516. package/es/components/viewer3d/lrm.js +305 -0
  517. package/es/components/viewer3d/model.js +708 -0
  518. package/es/components/viewer3d/pointer-lock-navigation.js +115 -0
  519. package/es/components/viewer3d/ruler-utils/itemRect.js +61 -0
  520. package/es/components/viewer3d/ruler-utils/layer3D.js +495 -0
  521. package/es/components/viewer3d/ruler-utils/ruler3D.js +224 -0
  522. package/es/components/viewer3d/ruler-utils/scene3D.js +59 -0
  523. package/es/components/viewer3d/ruler-utils/state3D.js +18 -0
  524. package/es/components/viewer3d/scene-creator.js +3617 -0
  525. package/es/components/viewer3d/three-memory-cleaner.js +51 -0
  526. package/es/components/viewer3d/viewer3d-first-person.js +309 -0
  527. package/es/components/viewer3d/viewer3d.js +2654 -0
  528. package/es/constants.js +688 -0
  529. package/es/devLiteRenderer.js +316 -0
  530. package/es/index.js +56 -0
  531. package/es/models.js +506 -0
  532. package/es/plugins/SVGLoader.js +1412 -0
  533. package/es/plugins/console-debugger.js +34 -0
  534. package/es/plugins/export.js +7 -0
  535. package/es/plugins/keyboard.js +101 -0
  536. package/es/reducers/areas-reducer.js +12 -0
  537. package/es/reducers/export.js +25 -0
  538. package/es/reducers/groups-reducer.js +38 -0
  539. package/es/reducers/holes-reducer.js +62 -0
  540. package/es/reducers/items-reducer.js +147 -0
  541. package/es/reducers/lines-reducer.js +45 -0
  542. package/es/reducers/project-reducer.js +131 -0
  543. package/es/reducers/reducer.js +19 -0
  544. package/es/reducers/scene-reducer.js +28 -0
  545. package/es/reducers/user-reducer.js +41 -0
  546. package/es/reducers/vertices-reducer.js +19 -0
  547. package/es/reducers/viewer2d-reducer.js +75 -0
  548. package/es/reducers/viewer3d-reducer.js +56 -0
  549. package/es/shared-style.js +66 -0
  550. package/es/styles/export.js +5 -0
  551. package/es/styles/tabs.css +40 -0
  552. package/es/translator/en.js +104 -0
  553. package/es/translator/it.js +79 -0
  554. package/es/translator/ru.js +79 -0
  555. package/es/translator/translator.js +80 -0
  556. package/es/utils/browser.js +33 -0
  557. package/es/utils/convert-units-lite.js +29 -0
  558. package/es/utils/email-validator.js +4 -0
  559. package/es/utils/export.js +25 -0
  560. package/es/utils/geometry.js +2446 -0
  561. package/es/utils/get-edges-of-subgraphs.js +26 -0
  562. package/es/utils/graph-cycles.js +238 -0
  563. package/es/utils/graph-inner-cycles.js +46 -0
  564. package/es/utils/graph.js +145 -0
  565. package/es/utils/helper.js +334 -0
  566. package/es/utils/history.js +29 -0
  567. package/es/utils/id-broker.js +15 -0
  568. package/es/utils/isolate-event-handler.js +683 -0
  569. package/es/utils/logger.js +8 -0
  570. package/es/utils/math.js +50 -0
  571. package/es/utils/molding.js +865 -0
  572. package/es/utils/name-generator.js +14 -0
  573. package/es/utils/objects-utils.js +50 -0
  574. package/es/utils/phone-validator.js +4 -0
  575. package/es/utils/process-black-list.js +15 -0
  576. package/es/utils/react-if.js +18 -0
  577. package/es/utils/snap-scene.js +94 -0
  578. package/es/utils/snap.js +231 -0
  579. package/es/utils/summarizeCart.js +24 -0
  580. package/es/utils/threeCSG.es6.js +494 -0
  581. package/es/version.js +1 -0
  582. package/lib/@history.js +11 -0
  583. package/lib/AppContext.js +11 -0
  584. package/lib/LiteKitchenConfigurator.js +490 -0
  585. package/lib/LiteRenderer.js +513 -0
  586. package/lib/actions/area-actions.js +21 -0
  587. package/lib/actions/export.js +36 -0
  588. package/lib/actions/groups-actions.js +107 -0
  589. package/lib/actions/holes-actions.js +140 -0
  590. package/lib/actions/items-actions.js +370 -0
  591. package/lib/actions/lines-actions.js +96 -0
  592. package/lib/actions/project-actions.js +338 -0
  593. package/lib/actions/scene-actions.js +43 -0
  594. package/lib/actions/vertices-actions.js +35 -0
  595. package/lib/actions/viewer2d-actions.js +73 -0
  596. package/lib/actions/viewer3d-actions.js +32 -0
  597. package/lib/analytics/ga4.js +194 -0
  598. package/lib/analytics/posthog.js +68 -0
  599. package/lib/assets/Window.hdr +2100 -0
  600. package/lib/assets/brown_photostudio_02_1k.hdr +0 -0
  601. package/lib/assets/fonts/Rene Bieder Milliard Black Italic.woff +0 -0
  602. package/lib/assets/fonts/Rene Bieder Milliard Black.woff +0 -0
  603. package/lib/assets/fonts/Rene Bieder Milliard Bold Italic.woff +0 -0
  604. package/lib/assets/fonts/Rene Bieder Milliard Bold.woff +0 -0
  605. package/lib/assets/fonts/Rene Bieder Milliard Book Italic.woff +0 -0
  606. package/lib/assets/fonts/Rene Bieder Milliard Book.woff +0 -0
  607. package/lib/assets/fonts/Rene Bieder Milliard ExtraBold Italic.woff +0 -0
  608. package/lib/assets/fonts/Rene Bieder Milliard ExtraBold.woff +0 -0
  609. package/lib/assets/fonts/Rene Bieder Milliard ExtraLight Italic.woff +0 -0
  610. package/lib/assets/fonts/Rene Bieder Milliard ExtraLight.woff +0 -0
  611. package/lib/assets/fonts/Rene Bieder Milliard Hairline Italic.woff +0 -0
  612. package/lib/assets/fonts/Rene Bieder Milliard Hairline.woff +0 -0
  613. package/lib/assets/fonts/Rene Bieder Milliard Heavy Italic.woff +0 -0
  614. package/lib/assets/fonts/Rene Bieder Milliard Heavy.woff +0 -0
  615. package/lib/assets/fonts/Rene Bieder Milliard Light Italic.woff +0 -0
  616. package/lib/assets/fonts/Rene Bieder Milliard Light.woff +0 -0
  617. package/lib/assets/fonts/Rene Bieder Milliard Medium Italic.woff +0 -0
  618. package/lib/assets/fonts/Rene Bieder Milliard Medium.woff +0 -0
  619. package/lib/assets/fonts/Rene Bieder Milliard SemiBold Italic.woff +0 -0
  620. package/lib/assets/fonts/Rene Bieder Milliard SemiBold.woff +0 -0
  621. package/lib/assets/fonts/Rene Bieder Milliard Thin Italic.woff +0 -0
  622. package/lib/assets/fonts/Rene Bieder Milliard Thin.woff +0 -0
  623. package/lib/assets/fonts/style.css +177 -0
  624. package/lib/assets/gltf/door_closet.bin +0 -0
  625. package/lib/assets/gltf/door_closet.fbx +0 -0
  626. package/lib/assets/gltf/door_closet.gltf +1 -0
  627. package/lib/assets/gltf/door_exterior.bin +0 -0
  628. package/lib/assets/gltf/door_exterior.fbx +0 -0
  629. package/lib/assets/gltf/door_exterior.gltf +1 -0
  630. package/lib/assets/gltf/door_interior.bin +0 -0
  631. package/lib/assets/gltf/door_interior.fbx +0 -0
  632. package/lib/assets/gltf/door_interior.gltf +1 -0
  633. package/lib/assets/gltf/door_sliding.bin +0 -0
  634. package/lib/assets/gltf/door_sliding.fbx +0 -0
  635. package/lib/assets/gltf/door_sliding.gltf +1 -0
  636. package/lib/assets/gltf/doorway_framed.bin +0 -0
  637. package/lib/assets/gltf/doorway_framed.fbx +0 -0
  638. package/lib/assets/gltf/doorway_framed.gltf +1 -0
  639. package/lib/assets/gltf/window_clear.bin +0 -0
  640. package/lib/assets/gltf/window_clear.fbx +0 -0
  641. package/lib/assets/gltf/window_clear.gltf +1 -0
  642. package/lib/assets/gltf/window_cross.bin +0 -0
  643. package/lib/assets/gltf/window_cross.fbx +0 -0
  644. package/lib/assets/gltf/window_cross.gltf +1 -0
  645. package/lib/assets/gltf/window_double_hung.bin +0 -0
  646. package/lib/assets/gltf/window_double_hung.fbx +0 -0
  647. package/lib/assets/gltf/window_double_hung.gltf +1 -0
  648. package/lib/assets/gltf/window_vertical.bin +0 -0
  649. package/lib/assets/gltf/window_vertical.fbx +0 -0
  650. package/lib/assets/gltf/window_vertical.gltf +1 -0
  651. package/lib/assets/img/1.jpg +0 -0
  652. package/lib/assets/img/TKC_thumbnail.png +0 -0
  653. package/lib/assets/img/Toggle.png +0 -0
  654. package/lib/assets/img/loading/loading.gif +0 -0
  655. package/lib/assets/img/loading/loading_1.svg +11 -0
  656. package/lib/assets/img/loading_large.gif +0 -0
  657. package/lib/assets/img/png/door/closet.png +0 -0
  658. package/lib/assets/img/png/door/doorwaysframed.png +0 -0
  659. package/lib/assets/img/png/door/doorwaysframeles.png +0 -0
  660. package/lib/assets/img/png/door/doorwaysframeless.png +0 -0
  661. package/lib/assets/img/png/door/exterior.png +0 -0
  662. package/lib/assets/img/png/door/interior.png +0 -0
  663. package/lib/assets/img/png/door/sliding.png +0 -0
  664. package/lib/assets/img/png/helper/outcome.png +0 -0
  665. package/lib/assets/img/png/helper/video_preview_3d.png +0 -0
  666. package/lib/assets/img/png/helper/video_preview_start.png +0 -0
  667. package/lib/assets/img/project_img.png +0 -0
  668. package/lib/assets/img/rta/rta_logo_box_blue.jpg +0 -0
  669. package/lib/assets/img/rta/rta_logo_box_blue_ico.jpg +0 -0
  670. package/lib/assets/img/rta/rta_logo_box_blue_ico.svg +55 -0
  671. package/lib/assets/img/rta/rta_logo_box_darkGray.jpg +0 -0
  672. package/lib/assets/img/rta/rta_logo_box_lightblue.png +0 -0
  673. package/lib/assets/img/rta/rta_logo_box_lightmaroon.png +0 -0
  674. package/lib/assets/img/rta/rta_logo_box_maroon.png +0 -0
  675. package/lib/assets/img/rta/rta_logo_box_white.png +0 -0
  676. package/lib/assets/img/rta_menu.png +0 -0
  677. package/lib/assets/img/step2.jpg +0 -0
  678. package/lib/assets/img/step3.jpg +0 -0
  679. package/lib/assets/img/step4.jpg +0 -0
  680. package/lib/assets/img/step5.jpg +0 -0
  681. package/lib/assets/img/step6.jpg +0 -0
  682. package/lib/assets/img/step7.jpg +0 -0
  683. package/lib/assets/img/step8.jpg +0 -0
  684. package/lib/assets/img/svg/2d_delete_object.svg +33 -0
  685. package/lib/assets/img/svg/2d_delete_object1.svg +33 -0
  686. package/lib/assets/img/svg/2d_lock_object.svg +33 -0
  687. package/lib/assets/img/svg/3d_item_move.svg +106 -0
  688. package/lib/assets/img/svg/3d_item_rotation.svg +76 -0
  689. package/lib/assets/img/svg/3d_item_warning_edit.svg +77 -0
  690. package/lib/assets/img/svg/3d_item_warning_info.svg +81 -0
  691. package/lib/assets/img/svg/accessories.svg +4 -0
  692. package/lib/assets/img/svg/angle_icon.svg +39 -0
  693. package/lib/assets/img/svg/blank_div.svg +14 -0
  694. package/lib/assets/img/svg/bottombar/2d3d_button.svg +3 -0
  695. package/lib/assets/img/svg/bottombar/2d3d_button_active.svg +3 -0
  696. package/lib/assets/img/svg/bottombar/2d3d_toggle.svg +4 -0
  697. package/lib/assets/img/svg/bottombar/2d3d_toggle_active.svg +4 -0
  698. package/lib/assets/img/svg/bottombar/arrow-down.svg +3 -0
  699. package/lib/assets/img/svg/bottombar/arrow-left.svg +3 -0
  700. package/lib/assets/img/svg/bottombar/arrow-minus.svg +3 -0
  701. package/lib/assets/img/svg/bottombar/arrow-plus.svg +11 -0
  702. package/lib/assets/img/svg/bottombar/arrow-right.svg +3 -0
  703. package/lib/assets/img/svg/bottombar/arrow-up.svg +3 -0
  704. package/lib/assets/img/svg/bottombar/collapse.svg +3 -0
  705. package/lib/assets/img/svg/bottombar/elevation-back.svg +6 -0
  706. package/lib/assets/img/svg/bottombar/elevation-front.svg +6 -0
  707. package/lib/assets/img/svg/bottombar/elevation-left.svg +6 -0
  708. package/lib/assets/img/svg/bottombar/elevation-right.svg +7 -0
  709. package/lib/assets/img/svg/bottombar/elevation.svg +6 -0
  710. package/lib/assets/img/svg/bottombar/expand.svg +3 -0
  711. package/lib/assets/img/svg/bottombar/help.svg +72 -0
  712. package/lib/assets/img/svg/bottombar/incm_toggle.svg +39 -0
  713. package/lib/assets/img/svg/bottombar/pan_1.svg +57 -0
  714. package/lib/assets/img/svg/bottombar/pan_2.svg +27 -0
  715. package/lib/assets/img/svg/bottombar/pan_3.svg +27 -0
  716. package/lib/assets/img/svg/bottombar/pan_4.svg +27 -0
  717. package/lib/assets/img/svg/bottombar/pan_5.svg +27 -0
  718. package/lib/assets/img/svg/bottombar/settings.svg +23 -0
  719. package/lib/assets/img/svg/bottombar/spin-down.svg +76 -0
  720. package/lib/assets/img/svg/bottombar/spin-left.svg +75 -0
  721. package/lib/assets/img/svg/bottombar/spin-right.svg +75 -0
  722. package/lib/assets/img/svg/bottombar/spin-up.svg +76 -0
  723. package/lib/assets/img/svg/bottombar/spin_1.svg +48 -0
  724. package/lib/assets/img/svg/bottombar/spin_2.svg +31 -0
  725. package/lib/assets/img/svg/bottombar/spin_3.svg +31 -0
  726. package/lib/assets/img/svg/bottombar/spin_4.svg +31 -0
  727. package/lib/assets/img/svg/bottombar/spin_5.svg +31 -0
  728. package/lib/assets/img/svg/bottombar/zoomin.svg +29 -0
  729. package/lib/assets/img/svg/bottombar/zoomout.svg +26 -0
  730. package/lib/assets/img/svg/check.svg +10 -0
  731. package/lib/assets/img/svg/close.svg +11 -0
  732. package/lib/assets/img/svg/color/Black.svg +3 -0
  733. package/lib/assets/img/svg/color/Blue.svg +3 -0
  734. package/lib/assets/img/svg/color/Brown.svg +9 -0
  735. package/lib/assets/img/svg/color/Cream.svg +3 -0
  736. package/lib/assets/img/svg/color/Dark.svg +9 -0
  737. package/lib/assets/img/svg/color/Gray.svg +3 -0
  738. package/lib/assets/img/svg/color/Green.svg +3 -0
  739. package/lib/assets/img/svg/color/Light.svg +9 -0
  740. package/lib/assets/img/svg/color/Medium.svg +9 -0
  741. package/lib/assets/img/svg/color/Unfinished.svg +9 -0
  742. package/lib/assets/img/svg/color/White.svg +3 -0
  743. package/lib/assets/img/svg/color/White.svg.bak +3 -0
  744. package/lib/assets/img/svg/color/stone2.jpg +0 -0
  745. package/lib/assets/img/svg/color/wood2.jpg +0 -0
  746. package/lib/assets/img/svg/copy.svg +11 -0
  747. package/lib/assets/img/svg/delete.svg +3 -0
  748. package/lib/assets/img/svg/detail.svg +77 -0
  749. package/lib/assets/img/svg/disclaimer/background.svg +758 -0
  750. package/lib/assets/img/svg/disclaimer/logo-dots.svg +11 -0
  751. package/lib/assets/img/svg/door/Closet.svg +11 -0
  752. package/lib/assets/img/svg/door/Exterior.svg +5 -0
  753. package/lib/assets/img/svg/door/Framed_dorway.svg +5 -0
  754. package/lib/assets/img/svg/door/Frameless_dorway.svg +5 -0
  755. package/lib/assets/img/svg/door/Interior.svg +7 -0
  756. package/lib/assets/img/svg/door/Sliding.svg +5 -0
  757. package/lib/assets/img/svg/doors_closet.svg +47 -0
  758. package/lib/assets/img/svg/doors_exterior.svg +25 -0
  759. package/lib/assets/img/svg/doors_interior.svg +29 -0
  760. package/lib/assets/img/svg/doors_patio.svg +26 -0
  761. package/lib/assets/img/svg/duplicate.svg +11 -0
  762. package/lib/assets/img/svg/duplicate_object_left.svg +32 -0
  763. package/lib/assets/img/svg/duplicate_object_right.svg +32 -0
  764. package/lib/assets/img/svg/filtersActive.svg +19 -0
  765. package/lib/assets/img/svg/firstsetting/L.svg +3 -0
  766. package/lib/assets/img/svg/firstsetting/L2.svg +3 -0
  767. package/lib/assets/img/svg/firstsetting/Open.svg +3 -0
  768. package/lib/assets/img/svg/firstsetting/Square.svg +3 -0
  769. package/lib/assets/img/svg/firstsetting/bar-active.svg +9 -0
  770. package/lib/assets/img/svg/firstsetting/bar-normal.svg +3 -0
  771. package/lib/assets/img/svg/firstsetting/bullet-current.svg +3 -0
  772. package/lib/assets/img/svg/firstsetting/bullet-done.svg +3 -0
  773. package/lib/assets/img/svg/firstsetting/bullet-not-done.svg +3 -0
  774. package/lib/assets/img/svg/firstsetting/check-active.svg +3 -0
  775. package/lib/assets/img/svg/firstsetting/check-normal.svg +3 -0
  776. package/lib/assets/img/svg/firstsetting/pencil.svg +11 -0
  777. package/lib/assets/img/svg/green_checkmark.svg +27 -0
  778. package/lib/assets/img/svg/headerbar/assist.svg +3 -0
  779. package/lib/assets/img/svg/headerbar/cart.svg +3 -0
  780. package/lib/assets/img/svg/headerbar/check.svg +10 -0
  781. package/lib/assets/img/svg/headerbar/consult_designer.svg +45 -0
  782. package/lib/assets/img/svg/headerbar/edit_name.svg +26 -0
  783. package/lib/assets/img/svg/headerbar/file-dollar.svg +13 -0
  784. package/lib/assets/img/svg/headerbar/hamburger_menu.svg +32 -0
  785. package/lib/assets/img/svg/headerbar/plus.svg +11 -0
  786. package/lib/assets/img/svg/headerbar/review_quote.svg +44 -0
  787. package/lib/assets/img/svg/headerbar/ruler-measure.svg +11 -0
  788. package/lib/assets/img/svg/headerbar/save.svg +3 -0
  789. package/lib/assets/img/svg/headerbar/setting.svg +75 -0
  790. package/lib/assets/img/svg/help/check.svg +10 -0
  791. package/lib/assets/img/svg/help/search.svg +76 -0
  792. package/lib/assets/img/svg/intro/1-start-with-floorplan-whole.svg +27 -0
  793. package/lib/assets/img/svg/intro/1-start-with-floorplan.svg +26 -0
  794. package/lib/assets/img/svg/intro/2-start-from-scratch-whole.svg +28 -0
  795. package/lib/assets/img/svg/intro/2-start-from-scratch.svg +27 -0
  796. package/lib/assets/img/svg/intro/3-retrieve-project-whole.svg +19 -0
  797. package/lib/assets/img/svg/intro/3-retrieve-project.svg +18 -0
  798. package/lib/assets/img/svg/invert.svg +127 -0
  799. package/lib/assets/img/svg/lefttoolbar/appliance-active.svg +13 -0
  800. package/lib/assets/img/svg/lefttoolbar/appliance.svg +13 -0
  801. package/lib/assets/img/svg/lefttoolbar/cabinet-active.svg +10 -0
  802. package/lib/assets/img/svg/lefttoolbar/cabinet-category.svg +3 -0
  803. package/lib/assets/img/svg/lefttoolbar/cabinet-one.svg +3 -0
  804. package/lib/assets/img/svg/lefttoolbar/cabinet.svg +10 -0
  805. package/lib/assets/img/svg/lefttoolbar/disigner_assistance.svg +89 -0
  806. package/lib/assets/img/svg/lefttoolbar/door-style-active.svg +20 -0
  807. package/lib/assets/img/svg/lefttoolbar/door-style.svg +20 -0
  808. package/lib/assets/img/svg/lefttoolbar/door.svg +12 -0
  809. package/lib/assets/img/svg/lefttoolbar/error_icon.svg +81 -0
  810. package/lib/assets/img/svg/lefttoolbar/finishing-active.svg +13 -0
  811. package/lib/assets/img/svg/lefttoolbar/finishing.svg +13 -0
  812. package/lib/assets/img/svg/lefttoolbar/reviewforquote-active.svg +86 -0
  813. package/lib/assets/img/svg/lefttoolbar/reviewforquote.svg +12 -0
  814. package/lib/assets/img/svg/lefttoolbar/room-shape-L.svg +3 -0
  815. package/lib/assets/img/svg/lefttoolbar/room-shape-active.svg +18 -0
  816. package/lib/assets/img/svg/lefttoolbar/room-shape-custom.svg +12 -0
  817. package/lib/assets/img/svg/lefttoolbar/room-shape-irregular.svg +3 -0
  818. package/lib/assets/img/svg/lefttoolbar/room-shape-open.svg +3 -0
  819. package/lib/assets/img/svg/lefttoolbar/room-shape-square.svg +3 -0
  820. package/lib/assets/img/svg/lefttoolbar/room-shape.svg +18 -0
  821. package/lib/assets/img/svg/lefttoolbar/search.svg +76 -0
  822. package/lib/assets/img/svg/lefttoolbar/view_more.svg +86 -0
  823. package/lib/assets/img/svg/lefttoolbar/warning_icon.svg +81 -0
  824. package/lib/assets/img/svg/lefttoolbar/window.svg +12 -0
  825. package/lib/assets/img/svg/logo.svg +11 -0
  826. package/lib/assets/img/svg/logo_with_text.svg +25 -0
  827. package/lib/assets/img/svg/menubar/login.svg +84 -0
  828. package/lib/assets/img/svg/menubar/my_projects.svg +85 -0
  829. package/lib/assets/img/svg/menubar/new_project.svg +110 -0
  830. package/lib/assets/img/svg/menubar/save_project.svg +84 -0
  831. package/lib/assets/img/svg/options.svg +3 -0
  832. package/lib/assets/img/svg/positioning.svg +3 -0
  833. package/lib/assets/img/svg/rotate.png +0 -0
  834. package/lib/assets/img/svg/rotate.svg +17 -0
  835. package/lib/assets/img/svg/rotate_object_clockwise.svg +26 -0
  836. package/lib/assets/img/svg/rotate_object_counterclockwise.svg +26 -0
  837. package/lib/assets/img/svg/toggleFilters.svg +19 -0
  838. package/lib/assets/img/svg/toolbar/add_appliances_active.svg +64 -0
  839. package/lib/assets/img/svg/toolbar/add_appliances_inactive.svg +52 -0
  840. package/lib/assets/img/svg/toolbar/add_button.svg +36 -0
  841. package/lib/assets/img/svg/toolbar/add_cabinets_active.svg +59 -0
  842. package/lib/assets/img/svg/toolbar/add_cabinets_inactive.svg +49 -0
  843. package/lib/assets/img/svg/toolbar/add_items_doors.svg +25 -0
  844. package/lib/assets/img/svg/toolbar/add_items_doorways.svg +24 -0
  845. package/lib/assets/img/svg/toolbar/add_items_refrigerator.svg +32 -0
  846. package/lib/assets/img/svg/toolbar/add_items_windows.svg +28 -0
  847. package/lib/assets/img/svg/toolbar/apply_button.svg +38 -0
  848. package/lib/assets/img/svg/toolbar/arrow-plus.svg +11 -0
  849. package/lib/assets/img/svg/toolbar/backsplash.svg +8 -0
  850. package/lib/assets/img/svg/toolbar/cancel_button.svg +37 -0
  851. package/lib/assets/img/svg/toolbar/consult_a_designer_button.svg +47 -0
  852. package/lib/assets/img/svg/toolbar/countertop.svg +7 -0
  853. package/lib/assets/img/svg/toolbar/dcm.png +0 -0
  854. package/lib/assets/img/svg/toolbar/dcm_off.svg +12 -0
  855. package/lib/assets/img/svg/toolbar/dcm_on.svg +474 -0
  856. package/lib/assets/img/svg/toolbar/delete_button.svg +37 -0
  857. package/lib/assets/img/svg/toolbar/download.svg +77 -0
  858. package/lib/assets/img/svg/toolbar/draw_custom_floor.svg +31 -0
  859. package/lib/assets/img/svg/toolbar/edit_button.svg +75 -0
  860. package/lib/assets/img/svg/toolbar/email_quote_button.svg +44 -0
  861. package/lib/assets/img/svg/toolbar/fbm.png +0 -0
  862. package/lib/assets/img/svg/toolbar/finishing_touches_active.svg +54 -0
  863. package/lib/assets/img/svg/toolbar/finishing_touches_inactive.svg +42 -0
  864. package/lib/assets/img/svg/toolbar/floorstyle.svg +9 -0
  865. package/lib/assets/img/svg/toolbar/fmb.png +0 -0
  866. package/lib/assets/img/svg/toolbar/fmb_off.svg +12 -0
  867. package/lib/assets/img/svg/toolbar/fmb_on.svg +489 -0
  868. package/lib/assets/img/svg/toolbar/furnishings_icon.svg +6 -0
  869. package/lib/assets/img/svg/toolbar/get_started_button.svg +41 -0
  870. package/lib/assets/img/svg/toolbar/handles.svg +5 -0
  871. package/lib/assets/img/svg/toolbar/lighting.svg +7 -0
  872. package/lib/assets/img/svg/toolbar/lrm.png +0 -0
  873. package/lib/assets/img/svg/toolbar/lrm_off.svg +12 -0
  874. package/lib/assets/img/svg/toolbar/lrm_on.svg +470 -0
  875. package/lib/assets/img/svg/toolbar/make_floorplan_active.svg +66 -0
  876. package/lib/assets/img/svg/toolbar/make_floorplan_inactive.svg +52 -0
  877. package/lib/assets/img/svg/toolbar/predefined_room_l_shaped.svg +20 -0
  878. package/lib/assets/img/svg/toolbar/predefined_room_layout.svg +20 -0
  879. package/lib/assets/img/svg/toolbar/predefined_room_long_narrow.svg +20 -0
  880. package/lib/assets/img/svg/toolbar/predefined_room_open_l_shape.svg +20 -0
  881. package/lib/assets/img/svg/toolbar/predefined_room_open_pentagon.svg +20 -0
  882. package/lib/assets/img/svg/toolbar/predefined_room_open_rectangle.svg +20 -0
  883. package/lib/assets/img/svg/toolbar/predefined_room_open_rectangle_2.svg +20 -0
  884. package/lib/assets/img/svg/toolbar/predefined_room_pentagon.svg +20 -0
  885. package/lib/assets/img/svg/toolbar/predefined_room_rectangle.svg +20 -0
  886. package/lib/assets/img/svg/toolbar/predefined_room_rectangle_with_alcove.svg +20 -0
  887. package/lib/assets/img/svg/toolbar/redo_button.svg +75 -0
  888. package/lib/assets/img/svg/toolbar/redo_button1.svg +75 -0
  889. package/lib/assets/img/svg/toolbar/review_quote_active.svg +14 -0
  890. package/lib/assets/img/svg/toolbar/review_quote_inactive.svg +44 -0
  891. package/lib/assets/img/svg/toolbar/save_project_button.svg +44 -0
  892. package/lib/assets/img/svg/toolbar/select_doorstyle_active.svg +67 -0
  893. package/lib/assets/img/svg/toolbar/select_doorstyle_inactive.svg +57 -0
  894. package/lib/assets/img/svg/toolbar/shopping-cart.svg +13 -0
  895. package/lib/assets/img/svg/toolbar/style_change_button.svg +47 -0
  896. package/lib/assets/img/svg/toolbar/take_picture.svg +75 -0
  897. package/lib/assets/img/svg/toolbar/undo_button.svg +76 -0
  898. package/lib/assets/img/svg/toolbar/undo_button1.svg +76 -0
  899. package/lib/assets/img/svg/toolbar/use_button.svg +37 -0
  900. package/lib/assets/img/svg/toolbar/wall_color_icon.svg +6 -0
  901. package/lib/assets/img/svg/topbar/edit_active.svg +10 -0
  902. package/lib/assets/img/svg/topbar/edit_inactive.svg +10 -0
  903. package/lib/assets/img/svg/topbar/redo_active.svg +42 -0
  904. package/lib/assets/img/svg/topbar/redo_inactive.svg +23 -0
  905. package/lib/assets/img/svg/topbar/select_all_active.svg +50 -0
  906. package/lib/assets/img/svg/topbar/select_all_inactive.svg +32 -0
  907. package/lib/assets/img/svg/topbar/take_picture_active.svg +51 -0
  908. package/lib/assets/img/svg/topbar/take_picture_inactive.svg +26 -0
  909. package/lib/assets/img/svg/topbar/undo_active.svg +42 -0
  910. package/lib/assets/img/svg/topbar/undo_inactive.svg +23 -0
  911. package/lib/assets/img/svg/warning_info_2d.svg +81 -0
  912. package/lib/assets/img/svg/window/Clear.svg +3 -0
  913. package/lib/assets/img/svg/window/Cross.svg +5 -0
  914. package/lib/assets/img/svg/window/Double_hung.svg +4 -0
  915. package/lib/assets/img/svg/window/Vertical.svg +4 -0
  916. package/lib/assets/img/svg/windows_clear.svg +23 -0
  917. package/lib/assets/img/svg/windows_cross.svg +28 -0
  918. package/lib/assets/img/svg/windows_double_hung.svg +24 -0
  919. package/lib/assets/img/svg/windows_vertical.svg +24 -0
  920. package/lib/assets/img/svg/wizardstep/Custom.svg +3 -0
  921. package/lib/assets/img/svg/wizardstep/Dashed_line.svg +3 -0
  922. package/lib/assets/img/svg/wizardstep/L.svg +3 -0
  923. package/lib/assets/img/svg/wizardstep/L2.svg +3 -0
  924. package/lib/assets/img/svg/wizardstep/Open.svg +3 -0
  925. package/lib/assets/img/svg/wizardstep/Square.svg +3 -0
  926. package/lib/assets/img/svg/wizardstep/bar-active.svg +9 -0
  927. package/lib/assets/img/svg/wizardstep/bar-normal.svg +3 -0
  928. package/lib/assets/img/svg/wizardstep/bullet-current.svg +3 -0
  929. package/lib/assets/img/svg/wizardstep/bullet-done.svg +3 -0
  930. package/lib/assets/img/svg/wizardstep/bullet-not-done.svg +3 -0
  931. package/lib/assets/img/svg/wizardstep/check-active.svg +3 -0
  932. package/lib/assets/img/svg/wizardstep/check-normal.svg +3 -0
  933. package/lib/assets/img/svg/wizardstep/detail_view.svg +87 -0
  934. package/lib/assets/img/svg/wizardstep/pencil.svg +11 -0
  935. package/lib/assets/img/svg/wizardstep/tile_view.svg +95 -0
  936. package/lib/assets/img/texture/glass.jpg +0 -0
  937. package/lib/assets/img/texture/steel.jpg +0 -0
  938. package/lib/assets/img/texture/white1px.jpg +0 -0
  939. package/lib/assets/img/texture/wood.jpg +0 -0
  940. package/lib/assets/model/DCM.bin +0 -0
  941. package/lib/assets/model/DCM.fbx +0 -0
  942. package/lib/assets/model/DCM.gltf +1 -0
  943. package/lib/assets/model/FBM.bin +0 -0
  944. package/lib/assets/model/FBM.fbx +0 -0
  945. package/lib/assets/model/FBM.gltf +1 -0
  946. package/lib/assets/model/LRM.bin +0 -0
  947. package/lib/assets/model/LRM.fbx +0 -0
  948. package/lib/assets/model/LRM.gltf +1 -0
  949. package/lib/assets/rtastore_logo.png +0 -0
  950. package/lib/catalog/areas/area/planner-element.js +53 -0
  951. package/lib/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  952. package/lib/catalog/areas/area/textures/grass.jpg +0 -0
  953. package/lib/catalog/areas/area/textures/parquet.jpg +0 -0
  954. package/lib/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  955. package/lib/catalog/areas/area/textures/tile1.jpg +0 -0
  956. package/lib/catalog/back.png +0 -0
  957. package/lib/catalog/catalog.js +272 -0
  958. package/lib/catalog/doors.png +0 -0
  959. package/lib/catalog/doorways.png +0 -0
  960. package/lib/catalog/envMap/nx.hdr +0 -0
  961. package/lib/catalog/envMap/ny.hdr +0 -0
  962. package/lib/catalog/envMap/nz.hdr +0 -0
  963. package/lib/catalog/envMap/px.hdr +0 -0
  964. package/lib/catalog/envMap/py.hdr +0 -0
  965. package/lib/catalog/envMap/pz.hdr +0 -0
  966. package/lib/catalog/export.js +1 -0
  967. package/lib/catalog/factories/area-factory-3d.js +190 -0
  968. package/lib/catalog/factories/area-factory.js +88 -0
  969. package/lib/catalog/factories/export.js +25 -0
  970. package/lib/catalog/factories/wall-factory-3d.js +212 -0
  971. package/lib/catalog/factories/wall-factory.js +279 -0
  972. package/lib/catalog/holes/door-closet/planner-element.js +232 -0
  973. package/lib/catalog/holes/door-double/door_double.png +0 -0
  974. package/lib/catalog/holes/door-double/planner-element.js +325 -0
  975. package/lib/catalog/holes/door-exterior/planner-element.js +225 -0
  976. package/lib/catalog/holes/door-interior/planner-element.js +237 -0
  977. package/lib/catalog/holes/door-panic/panicDoor.png +0 -0
  978. package/lib/catalog/holes/door-panic/planner-element.js +513 -0
  979. package/lib/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  980. package/lib/catalog/holes/door-panic-double/planner-element.js +473 -0
  981. package/lib/catalog/holes/door-sliding/planner-element.js +235 -0
  982. package/lib/catalog/holes/doorway-framed/planner-element.js +155 -0
  983. package/lib/catalog/holes/doorway-frameless/planner-element.js +114 -0
  984. package/lib/catalog/holes/export.js +97 -0
  985. package/lib/catalog/holes/gate/gate.jpg +0 -0
  986. package/lib/catalog/holes/window-clear/planner-element.js +176 -0
  987. package/lib/catalog/holes/window-clear/texture.png +0 -0
  988. package/lib/catalog/holes/window-cross/planner-element.js +175 -0
  989. package/lib/catalog/holes/window-cross/texture.png +0 -0
  990. package/lib/catalog/holes/window-double-hung/planner-element.js +313 -0
  991. package/lib/catalog/holes/window-double-hung/texture.png +0 -0
  992. package/lib/catalog/holes/window-vertical/planner-element.js +286 -0
  993. package/lib/catalog/holes/window-vertical/texture.png +0 -0
  994. package/lib/catalog/lines/wall/planner-element.js +87 -0
  995. package/lib/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  996. package/lib/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
  997. package/lib/catalog/lines/wall/textures/bricks.jpg +0 -0
  998. package/lib/catalog/lines/wall/textures/bricks2.jpg +0 -0
  999. package/lib/catalog/lines/wall/textures/bricks3.jpg +0 -0
  1000. package/lib/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  1001. package/lib/catalog/lines/wall/textures/morden.jpg +0 -0
  1002. package/lib/catalog/lines/wall/textures/painted-normal.jpg +0 -0
  1003. package/lib/catalog/lines/wall/textures/painted.jpg +0 -0
  1004. package/lib/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  1005. package/lib/catalog/lines/wall/textures/plaster.jpg +0 -0
  1006. package/lib/catalog/lines/wall/wall.png +0 -0
  1007. package/lib/catalog/molding/molding-dcm/planner-element.js +33 -0
  1008. package/lib/catalog/molding/molding-dcm/texture.png +0 -0
  1009. package/lib/catalog/molding/molding-fbm/planner-element.js +33 -0
  1010. package/lib/catalog/molding/molding-fbm/texture.png +0 -0
  1011. package/lib/catalog/molding/molding-lrm/planner-element.js +33 -0
  1012. package/lib/catalog/molding/molding-lrm/texture.png +0 -0
  1013. package/lib/catalog/properties/export.js +81 -0
  1014. package/lib/catalog/properties/property-checkbox.js +76 -0
  1015. package/lib/catalog/properties/property-color.js +47 -0
  1016. package/lib/catalog/properties/property-enum.js +58 -0
  1017. package/lib/catalog/properties/property-hidden.js +27 -0
  1018. package/lib/catalog/properties/property-lenght-measure.js +108 -0
  1019. package/lib/catalog/properties/property-length-measure.js +92 -0
  1020. package/lib/catalog/properties/property-length-measure_hole.js +108 -0
  1021. package/lib/catalog/properties/property-number.js +56 -0
  1022. package/lib/catalog/properties/property-read-only.js +34 -0
  1023. package/lib/catalog/properties/property-string.js +56 -0
  1024. package/lib/catalog/properties/property-toggle.js +47 -0
  1025. package/lib/catalog/properties/shared-property-style.js +21 -0
  1026. package/lib/catalog/utils/FuseUtils.js +87 -0
  1027. package/lib/catalog/utils/exporter.js +157 -0
  1028. package/lib/catalog/utils/geom-utils.js +205 -0
  1029. package/lib/catalog/utils/item-loader.js +1608 -0
  1030. package/lib/catalog/utils/load-obj.js +99 -0
  1031. package/lib/catalog/utils/mtl-loader.js +366 -0
  1032. package/lib/catalog/utils/obj-loader.js +486 -0
  1033. package/lib/catalog/windows.png +0 -0
  1034. package/lib/class/FuseUtils.js +87 -0
  1035. package/lib/class/area.js +148 -0
  1036. package/lib/class/export.js +96 -0
  1037. package/lib/class/group.js +438 -0
  1038. package/lib/class/guide.js +64 -0
  1039. package/lib/class/hole.js +932 -0
  1040. package/lib/class/item.js +1852 -0
  1041. package/lib/class/layer.js +670 -0
  1042. package/lib/class/line.js +1230 -0
  1043. package/lib/class/project.js +804 -0
  1044. package/lib/class/vertex.js +205 -0
  1045. package/lib/components/content.js +142 -0
  1046. package/lib/components/export.js +7 -0
  1047. package/lib/components/style/button.js +115 -0
  1048. package/lib/components/style/cancel-button.js +29 -0
  1049. package/lib/components/style/content-container.js +38 -0
  1050. package/lib/components/style/content-title.js +35 -0
  1051. package/lib/components/style/delete-button.js +34 -0
  1052. package/lib/components/style/export.js +121 -0
  1053. package/lib/components/style/form-block.js +28 -0
  1054. package/lib/components/style/form-color-input.js +34 -0
  1055. package/lib/components/style/form-label.js +30 -0
  1056. package/lib/components/style/form-number-input.js +192 -0
  1057. package/lib/components/style/form-number-input_2.js +209 -0
  1058. package/lib/components/style/form-select.js +29 -0
  1059. package/lib/components/style/form-slider.js +68 -0
  1060. package/lib/components/style/form-submit-button.js +35 -0
  1061. package/lib/components/style/form-text-input.js +78 -0
  1062. package/lib/components/viewer2d/area.js +89 -0
  1063. package/lib/components/viewer2d/export.js +121 -0
  1064. package/lib/components/viewer2d/grids/grid-horizontal-streak.js +44 -0
  1065. package/lib/components/viewer2d/grids/grid-streak.js +44 -0
  1066. package/lib/components/viewer2d/grids/grid-vertical-streak.js +44 -0
  1067. package/lib/components/viewer2d/grids/grids.js +40 -0
  1068. package/lib/components/viewer2d/group.js +63 -0
  1069. package/lib/components/viewer2d/item.js +457 -0
  1070. package/lib/components/viewer2d/layer.js +172 -0
  1071. package/lib/components/viewer2d/line.js +975 -0
  1072. package/lib/components/viewer2d/ruler.js +87 -0
  1073. package/lib/components/viewer2d/rulerDist.js +140 -0
  1074. package/lib/components/viewer2d/rulerX.js +154 -0
  1075. package/lib/components/viewer2d/rulerY.js +156 -0
  1076. package/lib/components/viewer2d/scene.js +137 -0
  1077. package/lib/components/viewer2d/snap.js +84 -0
  1078. package/lib/components/viewer2d/state.js +83 -0
  1079. package/lib/components/viewer2d/utils.js +200 -0
  1080. package/lib/components/viewer2d/vertex.js +75 -0
  1081. package/lib/components/viewer2d/viewer2d.js +1444 -0
  1082. package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +2591 -0
  1083. package/lib/components/viewer3d/dcm.js +408 -0
  1084. package/lib/components/viewer3d/fbm.js +421 -0
  1085. package/lib/components/viewer3d/front3D.js +71 -0
  1086. package/lib/components/viewer3d/grid-creator.js +35 -0
  1087. package/lib/components/viewer3d/grids/grid-horizontal-streak.js +45 -0
  1088. package/lib/components/viewer3d/grids/grid-streak.js +36 -0
  1089. package/lib/components/viewer3d/grids/grid-vertical-streak.js +45 -0
  1090. package/lib/components/viewer3d/libs/first-person-controls.js +74 -0
  1091. package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +1287 -0
  1092. package/lib/components/viewer3d/libs/mtl-loader.js +366 -0
  1093. package/lib/components/viewer3d/libs/obj-loader.js +471 -0
  1094. package/lib/components/viewer3d/libs/orbit-controls.js +706 -0
  1095. package/lib/components/viewer3d/libs/pointer-lock-controls.js +53 -0
  1096. package/lib/components/viewer3d/lrm.js +312 -0
  1097. package/lib/components/viewer3d/model.js +714 -0
  1098. package/lib/components/viewer3d/pointer-lock-navigation.js +122 -0
  1099. package/lib/components/viewer3d/ruler-utils/itemRect.js +69 -0
  1100. package/lib/components/viewer3d/ruler-utils/layer3D.js +503 -0
  1101. package/lib/components/viewer3d/ruler-utils/ruler3D.js +232 -0
  1102. package/lib/components/viewer3d/ruler-utils/scene3D.js +67 -0
  1103. package/lib/components/viewer3d/ruler-utils/state3D.js +26 -0
  1104. package/lib/components/viewer3d/scene-creator.js +3652 -0
  1105. package/lib/components/viewer3d/three-memory-cleaner.js +60 -0
  1106. package/lib/components/viewer3d/viewer3d-first-person.js +316 -0
  1107. package/lib/components/viewer3d/viewer3d.js +2661 -0
  1108. package/lib/constants.js +697 -0
  1109. package/lib/devLiteRenderer.js +320 -0
  1110. package/lib/index.js +64 -0
  1111. package/lib/models.js +513 -0
  1112. package/lib/plugins/SVGLoader.js +1417 -0
  1113. package/lib/plugins/console-debugger.js +42 -0
  1114. package/lib/plugins/export.js +25 -0
  1115. package/lib/plugins/keyboard.js +108 -0
  1116. package/lib/reducers/areas-reducer.js +19 -0
  1117. package/lib/reducers/export.js +97 -0
  1118. package/lib/reducers/groups-reducer.js +45 -0
  1119. package/lib/reducers/holes-reducer.js +69 -0
  1120. package/lib/reducers/items-reducer.js +151 -0
  1121. package/lib/reducers/lines-reducer.js +52 -0
  1122. package/lib/reducers/project-reducer.js +138 -0
  1123. package/lib/reducers/reducer.js +26 -0
  1124. package/lib/reducers/scene-reducer.js +35 -0
  1125. package/lib/reducers/user-reducer.js +48 -0
  1126. package/lib/reducers/vertices-reducer.js +26 -0
  1127. package/lib/reducers/viewer2d-reducer.js +82 -0
  1128. package/lib/reducers/viewer3d-reducer.js +63 -0
  1129. package/lib/shared-style.js +72 -0
  1130. package/lib/styles/export.js +13 -0
  1131. package/lib/styles/tabs.css +40 -0
  1132. package/lib/translator/en.js +111 -0
  1133. package/lib/translator/it.js +86 -0
  1134. package/lib/translator/ru.js +86 -0
  1135. package/lib/translator/translator.js +87 -0
  1136. package/lib/utils/browser.js +40 -0
  1137. package/lib/utils/convert-units-lite.js +35 -0
  1138. package/lib/utils/email-validator.js +10 -0
  1139. package/lib/utils/export.js +56 -0
  1140. package/lib/utils/geometry.js +2545 -0
  1141. package/lib/utils/get-edges-of-subgraphs.js +33 -0
  1142. package/lib/utils/graph-cycles.js +239 -0
  1143. package/lib/utils/graph-inner-cycles.js +54 -0
  1144. package/lib/utils/graph.js +153 -0
  1145. package/lib/utils/helper.js +358 -0
  1146. package/lib/utils/history.js +36 -0
  1147. package/lib/utils/id-broker.js +22 -0
  1148. package/lib/utils/isolate-event-handler.js +691 -0
  1149. package/lib/utils/logger.js +14 -0
  1150. package/lib/utils/math.js +57 -0
  1151. package/lib/utils/molding.js +890 -0
  1152. package/lib/utils/name-generator.js +21 -0
  1153. package/lib/utils/objects-utils.js +62 -0
  1154. package/lib/utils/phone-validator.js +10 -0
  1155. package/lib/utils/process-black-list.js +22 -0
  1156. package/lib/utils/react-if.js +25 -0
  1157. package/lib/utils/snap-scene.js +101 -0
  1158. package/lib/utils/snap.js +245 -0
  1159. package/lib/utils/summarizeCart.js +30 -0
  1160. package/lib/utils/threeCSG.es6.js +504 -0
  1161. package/lib/version.js +7 -0
  1162. package/package.json +93 -86
  1163. package/dist/index.js +0 -3
  1164. package/dist/index.js.LICENSE.txt +0 -55
  1165. package/dist/index.js.map +0 -1
@@ -0,0 +1,2661 @@
1
+ 'use strict';
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _readOnlyError2 = _interopRequireDefault(require("@babel/runtime/helpers/readOnlyError"));
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
12
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
+ var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
14
+ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
15
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
16
+ var _react = _interopRequireDefault(require("react"));
17
+ var _propTypes = _interopRequireDefault(require("prop-types"));
18
+ var _reactDom = _interopRequireDefault(require("react-dom"));
19
+ var Three = _interopRequireWildcard(require("three"));
20
+ var _sceneCreator = require("./scene-creator");
21
+ var _threeMemoryCleaner = require("./three-memory-cleaner");
22
+ var _immutablediff = _interopRequireDefault(require("immutablediff"));
23
+ var SharedStyle = _interopRequireWildcard(require("../../shared-style"));
24
+ var _constants = require("../../constants");
25
+ var _util = require("util");
26
+ var _geometry = require("../../utils/geometry");
27
+ var _convertUnitsLite = require("../../utils/convert-units-lite");
28
+ var _export = require("../../utils/export");
29
+ var _helper = require("../../utils/helper");
30
+ var _RGBELoader = require("three/examples/jsm/loaders/RGBELoader");
31
+ var _cameraControls = _interopRequireDefault(require("camera-controls"));
32
+ var _utils = require("../viewer2d/utils");
33
+ var _objectsUtils = require("../../utils/objects-utils");
34
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
35
+ 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; }
36
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
37
+ function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
38
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
39
+ _cameraControls["default"].install({
40
+ THREE: Three
41
+ });
42
+ var Scene3DViewer = exports["default"] = /*#__PURE__*/function (_React$Component) {
43
+ function Scene3DViewer(props) {
44
+ var _this;
45
+ (0, _classCallCheck2["default"])(this, Scene3DViewer);
46
+ _this = _callSuper(this, Scene3DViewer, [props]);
47
+ _this.state = {
48
+ isLoading: false,
49
+ showflag: true,
50
+ isLoadingCabinet: props.state.scene.isLoadingCabinet,
51
+ toolObj: null,
52
+ angleObj: null,
53
+ waitForRender: 0,
54
+ lineLength: null // when view wall's elevation, that wall's length
55
+ };
56
+ _this.lastMousePosition = {};
57
+ _this.width = props.width;
58
+ _this.height = props.height;
59
+ _this.renderingID = 0;
60
+ var mode = props.state.mode;
61
+ if (!window.__elevationRendererDownload) {
62
+ window.__elevationRendererDownload = {};
63
+ }
64
+ switch (mode) {
65
+ case _constants.MODE_IDLE_3D:
66
+ _this.renderer = window.__threeRenderer || new Three.WebGLRenderer({
67
+ preserveDrawingBuffer: true,
68
+ alpha: true,
69
+ antialias: true
70
+ });
71
+ break;
72
+ case _constants.MODE_3D_VIEW:
73
+ _this.renderer = window.__threeRendererDownload || new Three.WebGLRenderer({
74
+ preserveDrawingBuffer: true,
75
+ alpha: true,
76
+ antialias: true
77
+ });
78
+ break;
79
+ default:
80
+ if (_this.props.downloadFlag) {
81
+ _this.renderer = window.__elevationRendererDownload[mode] || new Three.WebGLRenderer({
82
+ preserveDrawingBuffer: true,
83
+ alpha: true,
84
+ antialias: true
85
+ });
86
+ } else {
87
+ _this.renderer = window.__elevationRenderer || new Three.WebGLRenderer({
88
+ preserveDrawingBuffer: true,
89
+ alpha: true,
90
+ antialias: true
91
+ });
92
+ }
93
+ break;
94
+ }
95
+ _this.renderer.shadowMap.enabled = true;
96
+ _this.renderer.shadowMapSoft = true;
97
+ if (mode == 'MODE_IDLE_3D') {
98
+ window.__threeRenderer = _this.renderer;
99
+ } else if (mode == 'MODE_3D_VIEW') {
100
+ window.__threeRendererDownload = _this.renderer;
101
+ } else {
102
+ if (_this.props.downloadFlag) window.__elevationRendererDownload[mode] = _this.renderer;else window.__elevationRenderer = _this.renderer;
103
+ }
104
+ _this.renderer.domElement.style.display = 'none';
105
+ return _this;
106
+ }
107
+ (0, _inherits2["default"])(Scene3DViewer, _React$Component);
108
+ return (0, _createClass2["default"])(Scene3DViewer, [{
109
+ key: "componentDidMount",
110
+ value: function componentDidMount(nextProps) {
111
+ var _this2 = this;
112
+ var scene3D, camera, pivot, cameraControls, clock;
113
+ var spotLight1, spotLightTarget;
114
+ var actions = {
115
+ areaActions: this.context.areaActions,
116
+ holesActions: this.context.holesActions,
117
+ itemsActions: this.context.itemsActions,
118
+ sceneActions: this.context.sceneActions,
119
+ linesActions: this.context.linesActions,
120
+ projectActions: this.context.projectActions,
121
+ catalog: this.context.catalog
122
+ };
123
+ var self = this;
124
+ var state = this.props.state;
125
+ var mode = state.mode,
126
+ scene = state.scene;
127
+ function setupLight(scene, inbBox) {
128
+ if ((0, _helper.isElevationView)(mode)) {
129
+ var ambilight = new Three.AmbientLight('0xffffff', 3);
130
+ scene.add(ambilight);
131
+ } else {
132
+ var addDirLight = function addDirLight(inColor, inIntensity, inPosition) {
133
+ var dirLight = new Three.DirectionalLight(inColor, inIntensity);
134
+ dirLight.castShadow = true;
135
+ dirLight.shadow.mapSize.x = shadowMapSize;
136
+ dirLight.shadow.mapSize.y = shadowMapSize;
137
+ dirLight.shadow.camera.near = 0;
138
+ dirLight.shadow.camera.far = shadowCameraFar;
139
+ dirLight.shadow.camera.top = shadowCameraSize * 1.5;
140
+ dirLight.shadow.camera.bottom = -shadowCameraSize * 1.5;
141
+ dirLight.shadow.camera.left = -shadowCameraSize * 1.5;
142
+ dirLight.shadow.camera.right = shadowCameraSize * 1.5;
143
+ dirLight.position.copy(inPosition);
144
+ var targetObject = new Three.Object3D();
145
+ targetObject.position.copy(bboxCenter);
146
+ scene.add(targetObject);
147
+ dirLight.target = targetObject;
148
+ dirLight.target.updateMatrixWorld();
149
+ scene.add(dirLight);
150
+ };
151
+ var addSpotLight = function addSpotLight(inColor, inIntensity, inPosition, inTarget, inDistance) {
152
+ var spotLight = new Three.SpotLight();
153
+ spotLight.intensity = inIntensity;
154
+ spotLight.color.setHex(inColor);
155
+ spotLight.position.copy(inPosition);
156
+ spotLight.angle = 1.3;
157
+ spotLight.distance = inDistance;
158
+ spotLight.penumbra = 1.8;
159
+ spotLight.decay = 0.01;
160
+ spotLight.castShadow = true;
161
+ spotLight.shadow.intensity = 2;
162
+ spotLight.shadow.mapSize.width = 4096;
163
+ spotLight.shadow.mapSize.height = 4096;
164
+ var targetObject = new Three.Object3D();
165
+ targetObject.position.copy(new Three.Vector3(inTarget.x, 0, inTarget.z));
166
+ scene.add(targetObject);
167
+ spotLight.target = targetObject;
168
+ spotLight.target.updateMatrixWorld();
169
+ scene.add(spotLight);
170
+ };
171
+ var shadowMapSize = 2048;
172
+ var shadowCameraSize = Math.max(Math.abs(inbBox.min.x - inbBox.max.x), Math.abs(inbBox.min.y - inbBox.max.y), Math.abs(inbBox.min.z - inbBox.max.z)) / 2;
173
+ var shadowCameraFar = shadowCameraSize * 10;
174
+ var bboxCenter = new Three.Vector3((inbBox.min.x + inbBox.max.x) / 2, inbBox.min.y, (inbBox.min.z + inbBox.max.z) / 2);
175
+ var dirLightPos = new Three.Vector3(inbBox.max.x, inbBox.max.y + 1.8 * Math.abs(inbBox.max.y - inbBox.min.y), inbBox.min.z - 0.5 * Math.abs(inbBox.max.z - inbBox.min.z));
176
+ addDirLight('white', 1.5, dirLightPos);
177
+ var ceiling = scene3D.getObjectByName('ceil');
178
+ if (ceiling) {
179
+ var ceilBBox = new Three.Box3().setFromObject(ceiling);
180
+ var spot1 = new Three.Vector3(ceilBBox.min.x + Math.abs(ceilBBox.min.x - ceilBBox.max.x) / 4, ceilBBox.max.y - 0.5, ceilBBox.min.z + Math.abs(ceilBBox.min.z - inbBox.max.z) / 4);
181
+ var spot2 = new Three.Vector3(ceilBBox.min.x + Math.abs(ceilBBox.min.x - ceilBBox.max.x) / 4, ceilBBox.max.y - 0.5, ceilBBox.max.z - Math.abs(ceilBBox.min.z - ceilBBox.max.z) / 4);
182
+ var spot3 = new Three.Vector3(ceilBBox.max.x - Math.abs(ceilBBox.min.x - ceilBBox.max.x) / 4, ceilBBox.max.y - 0.5, ceilBBox.min.z + Math.abs(ceilBBox.min.z - ceilBBox.max.z) / 4);
183
+ var spot4 = new Three.Vector3(ceilBBox.max.x - Math.abs(ceilBBox.min.x - ceilBBox.max.x) / 4, ceilBBox.max.y - 0.5, ceilBBox.max.z - Math.abs(ceilBBox.min.z - ceilBBox.max.z) / 4);
184
+ var spotlightDis = 1.5 * Math.abs(inbBox.min.y - inbBox.max.y);
185
+
186
+ // check if spotlight is inside the room
187
+ (0, _objectsUtils.vectorIntersectWithMesh)(spot1, scene3D.getObjectByName('floor')) && addSpotLight('0xffffff', 0.8, spot1, spot1, spotlightDis);
188
+ (0, _objectsUtils.vectorIntersectWithMesh)(spot2, scene3D.getObjectByName('floor')) && addSpotLight('0xffffff', 0.8, spot2, spot2, spotlightDis);
189
+ (0, _objectsUtils.vectorIntersectWithMesh)(spot3, scene3D.getObjectByName('floor')) && addSpotLight('0xffffff', 0.8, spot3, spot3, spotlightDis);
190
+ (0, _objectsUtils.vectorIntersectWithMesh)(spot4, scene3D.getObjectByName('floor')) && addSpotLight('0xffffff', 0.8, spot4, spot4, spotlightDis);
191
+ }
192
+ }
193
+ }
194
+
195
+ // Load data
196
+ this.setState({
197
+ isLoading: true
198
+ });
199
+ if (self.props.downloadFlag) {
200
+ this.setState({
201
+ waitForRender: 0
202
+ });
203
+
204
+ // set loading bar
205
+ switch (self.props.state.mode) {
206
+ case _constants.MODE_ELEVATION_VIEW:
207
+ self.props.setIsLoadingElevation('front', true);
208
+ break;
209
+ case _constants.MODE_3D_VIEW:
210
+ self.props.setIsLoading3D(true);
211
+ break;
212
+ }
213
+ }
214
+ var _parseData = (0, _sceneCreator.parseData)(scene, actions, this.context.catalog, camera, this.renderer, state.mode),
215
+ promise = _parseData.promise,
216
+ planData = _parseData.planData;
217
+ promise.then(function () {
218
+ var objToRemove = [];
219
+ planData.plan.traverse(function (obj) {
220
+ if (obj.geometry === null) {
221
+ objToRemove.push(obj);
222
+ }
223
+ });
224
+ objToRemove.forEach(function (obj) {
225
+ obj.removeFromParent();
226
+ });
227
+ var bbox = new Three.Box3().setFromObject(planData.plan);
228
+ if (!(0, _helper.isElevationView)(state.mode)) {
229
+ cameraControls.fitToBox(bbox);
230
+ }
231
+ setupLight(scene3D, planData.boundingBox);
232
+ self.setState({
233
+ waitForRender: 1
234
+ });
235
+ setTimeout(function () {
236
+ self.setState({
237
+ isLoading: false
238
+ });
239
+ self.renderer.domElement.style.display = 'block';
240
+ }, 1500);
241
+ });
242
+ var area = scene.getIn(['layers', scene.selectedLayer, 'areas']);
243
+ var layer = scene.getIn(['layers', scene.selectedLayer]);
244
+ var areas = [],
245
+ lights = [];
246
+ var snapBox = null;
247
+
248
+ // Check for data
249
+ var msg = '';
250
+ scene.layers.forEach(function (layer) {
251
+ if (layer.id === scene.selectedLayer || layer.visible) {
252
+ layer.items.forEach(function (item) {
253
+ if (item.doorStyle === null) {
254
+ if (!msg.includes(item.name + "'s doorStyle is null.")) msg += item.name + "'s doorStyle is null.\n";
255
+ }
256
+ });
257
+ }
258
+ });
259
+ if (msg !== '') {
260
+ confirm(msg);
261
+ }
262
+ init();
263
+ render();
264
+
265
+ // area lightning(wall lightning)/////
266
+
267
+ area.forEach(function (data) {
268
+ areas.push(data);
269
+ });
270
+ var _loop = function _loop() {
271
+ var aVertices = [];
272
+ var lines = [];
273
+ var height = 100;
274
+ areas[i].vertices.forEach(function (data) {
275
+ aVertices.push(data);
276
+ });
277
+ layer.lines.forEach(function (data) {
278
+ lines.push(data);
279
+ });
280
+ var _loop3 = function _loop3() {
281
+ var data = lines[_i15];
282
+ var realVec = [];
283
+ data.vertices.forEach(function (vec) {
284
+ realVec.push(vec);
285
+ });
286
+ if (aVertices.includes(realVec[0]) && aVertices.includes(realVec[1])) {
287
+ height = (0, _convertUnitsLite.convert)(layer.ceilHeight).from(layer.unit).to(_constants.UNIT_CENTIMETER);
288
+ // height = data.properties.getIn(['height', 'length']);
289
+ return 1; // break
290
+ }
291
+ };
292
+ for (var _i15 = 0; _i15 < lines.length; _i15++) {
293
+ if (_loop3()) break;
294
+ }
295
+ var vertices = [];
296
+ areas[i].vertices.forEach(function (datas) {
297
+ var vertex = scene.getIn(['layers', scene.selectedLayer, 'vertices', datas]);
298
+ vertices.push(vertex);
299
+ });
300
+ vertices.push(vertices[0]);
301
+ var fLen = vertices.length - 1;
302
+ for (var _i16 = 0; _i16 < fLen; _i16++) {
303
+ var sX = vertices[_i16].x;
304
+ var sY = vertices[_i16].y;
305
+ var eX = vertices[_i16 + 1].x;
306
+ var eY = vertices[_i16 + 1].y;
307
+ var len = Math.sqrt((eX - sX) * (eX - sX) + (eY - sY) * (eY - sY));
308
+ for (var cLen = 200; cLen < len; cLen += 200) {
309
+ var cX = sX + (eX - sX) * cLen / len;
310
+ var cY = sY + (eY - sY) * cLen / len;
311
+ var endLen = Math.sqrt((eX - cX) * (eX - cX) + (eY - cY) * (eY - cY));
312
+ if (endLen <= 100) continue;
313
+ var vec2 = new Three.Vector2(cX - sX, cY - sY);
314
+ var angle = vec2.angle() + Math.PI / 2;
315
+ cX = Math.cos(angle) * 30 + cX;
316
+ cY = Math.sin(angle) * 30 + cY;
317
+ var spotLight = new Three.SpotLight(0xeeeeee, 1.7);
318
+ spotLight.angle = 0.76;
319
+ spotLight.castShadow = true;
320
+ spotLight.penumbra = 1;
321
+ spotLight.decay = 1.7;
322
+ spotLight.distance = height - 20;
323
+ var target = new Three.Object3D();
324
+ spotLight.target = target;
325
+ lights.push({
326
+ light: spotLight,
327
+ target: target,
328
+ x: cX,
329
+ y: cY,
330
+ height: height
331
+ });
332
+ }
333
+ }
334
+ };
335
+ for (var i = 0; i < areas.length; i++) {
336
+ _loop();
337
+ }
338
+ // //////////////////////////
339
+
340
+ // OBJECT PICKING
341
+ var toIntersect = [planData.plan];
342
+ var mouse = new Three.Vector2();
343
+ var gridPlane = planData.grid;
344
+ var raycaster = new Three.Raycaster();
345
+ var selectedObject = {};
346
+ var selectedFlag = false;
347
+ var currentObject = null;
348
+ var isSelected = false;
349
+ var bRotate = false;
350
+ var bMove = false;
351
+ var bMoveUP = false;
352
+ /** Transformation matrix of grid */
353
+ var gridMatrix = new Three.Matrix4();
354
+ var rayDirection = new Three.Vector3();
355
+ /** World position of grid plane */
356
+ var gridPlanOrigin = new Three.Vector3();
357
+ var Point = new Three.Vector2();
358
+ var sPoint = new Three.Vector2();
359
+
360
+ // SNAP FUNCTION VARIABLE
361
+ var snapFlag = false;
362
+ var snapAnimI = 0;
363
+ var snapDelta = 6;
364
+ var t_i = 0;
365
+ var targetPoint = new Three.Vector3();
366
+ var targetRot = 0;
367
+ var targetUVec = new Three.Vector3();
368
+ var targetCRotation = 0;
369
+ var targetObj = null;
370
+ var targetNumber = 0;
371
+ var wallSlide = false;
372
+ var pinFlag = false;
373
+ var sFlag = false; //for all object move
374
+ var endPoint = {};
375
+ var allItemRect;
376
+ var allItemSnap;
377
+ var allLines;
378
+ var allLineRects;
379
+ var allLineSnap;
380
+ var allRect;
381
+ var allArea;
382
+
383
+ // FLAG FOR initial phase of drawing an item
384
+ var isInitialPhase = true;
385
+
386
+ // end snap function variable///////////////////////
387
+ var backsplashVisible = false;
388
+ var holeItems = _export.GeometryUtils.getHoleItems(layer);
389
+ var removeSnapBox = function removeSnapBox() {
390
+ if (snapBox != null) {
391
+ planData.plan.remove(snapBox);
392
+ (0, _threeMemoryCleaner.disposeObject)(snapBox);
393
+ snapBox = null;
394
+ targetObj = null;
395
+ snapFlag = false;
396
+ }
397
+ };
398
+ var camToGrid = new Three.Vector3();
399
+ var camPos = camera.position;
400
+ var mapCursorPosition = function mapCursorPosition(e, altitude) {
401
+ camToGrid.subVectors(gridPlanOrigin, camPos);
402
+ var camD = camToGrid.y + (altitude ? altitude : 0);
403
+ var rayD = rayDirection.y;
404
+ var intersectPt = rayDirection.multiplyScalar(camD / rayD).add(camPos);
405
+ intersectPt.y = gridPlanOrigin.y;
406
+ intersectPt.applyMatrix4(gridMatrix);
407
+ return {
408
+ x: intersectPt.x,
409
+ y: -intersectPt.z
410
+ };
411
+ };
412
+
413
+ /* for Snap Functions*/
414
+
415
+ var pointLineDistance = function pointLineDistance(point, line) {
416
+ // return distance from point to line and directional point of line
417
+ var pX = point.x;
418
+ var pY = point.y;
419
+ var l1x = line[0].x;
420
+ var l1y = line[0].y;
421
+ var l2x = line[1].x;
422
+ var l2y = line[1].y;
423
+ var pLine = new Three.Vector2(l1x - pX, l1y - pY);
424
+ var Line = new Three.Vector2(l1x - l2x, l1y - l2y);
425
+ var pAngle = pLine.angle();
426
+ var lAngle = Line.angle();
427
+ var pDistance = pLine.length();
428
+ var oDistance = Line.length();
429
+ var directDistance = Math.sin(pAngle - lAngle) * pDistance;
430
+ var lineDistance = Math.cos(pAngle - lAngle) * pDistance;
431
+ var dX = l1x + (l2x - l1x) * lineDistance / oDistance;
432
+ var dY = l1y + (l2y - l1y) * lineDistance / oDistance;
433
+ var dPoint = {
434
+ x: dX,
435
+ y: dY
436
+ };
437
+ return {
438
+ distance: directDistance,
439
+ point: dPoint
440
+ };
441
+ };
442
+ var getInterSect = function getInterSect(shape1, shape2) {
443
+ // return result of intersect of two shape
444
+ var count = 0;
445
+ for (var _i = 0; _i < shape1.length - 1; _i++) {
446
+ var sl1 = {
447
+ x: shape1[_i].x,
448
+ y: shape1[_i].y
449
+ };
450
+ var sl2 = {
451
+ x: shape1[_i + 1].x,
452
+ y: shape1[_i + 1].y
453
+ };
454
+ for (var j = 0; j < shape2.length - 1; j++) {
455
+ var el1 = {
456
+ x: shape2[j].x,
457
+ y: shape2[j].y
458
+ };
459
+ var el2 = {
460
+ x: shape2[j + 1].x,
461
+ y: shape2[j + 1].y
462
+ };
463
+ var flag = _export.GeometryUtils.getLineInterSect(sl1.x, sl1.y, sl2.x, sl2.y, el1.x, el1.y, el2.x, el2.y);
464
+ if (flag) {
465
+ count++;
466
+ if (count > 1) return true;
467
+ }
468
+ }
469
+ }
470
+ return false;
471
+ };
472
+ this.getRectPoints = function (width, height, pos, rot) {
473
+ // return 4 points from it's position, width, height, and rotation info
474
+ var rX = width / 2;
475
+ var rY = height / 2;
476
+ var vertices = [];
477
+ var cRot = rot;
478
+ var pX = pos.x + Math.cos(cRot) * rX + Math.cos(cRot + Math.PI / 2) * rY;
479
+ var pY = pos.y + Math.sin(cRot) * rX + Math.sin(cRot + Math.PI / 2) * rY;
480
+ vertices.push({
481
+ x: Math.floor(pX + 0.5),
482
+ y: Math.floor(pY + 0.5)
483
+ });
484
+ rX = -rX;
485
+ pX = pos.x + Math.cos(cRot) * rX + Math.cos(cRot + Math.PI / 2) * rY;
486
+ pY = pos.y + Math.sin(cRot) * rX + Math.sin(cRot + Math.PI / 2) * rY;
487
+ vertices.push({
488
+ x: Math.floor(pX + 0.5),
489
+ y: Math.floor(pY + 0.5)
490
+ });
491
+ rY = -rY;
492
+ pX = pos.x + Math.cos(cRot) * rX + Math.cos(cRot + Math.PI / 2) * rY;
493
+ pY = pos.y + Math.sin(cRot) * rX + Math.sin(cRot + Math.PI / 2) * rY;
494
+ vertices.push({
495
+ x: Math.floor(pX + 0.5),
496
+ y: Math.floor(pY + 0.5)
497
+ });
498
+ rX = -rX;
499
+ pX = pos.x + Math.cos(cRot) * rX + Math.cos(cRot + Math.PI / 2) * rY;
500
+ pY = pos.y + Math.sin(cRot) * rX + Math.sin(cRot + Math.PI / 2) * rY;
501
+ vertices.push({
502
+ x: Math.floor(pX + 0.5),
503
+ y: Math.floor(pY + 0.5)
504
+ });
505
+ vertices.push(vertices[0]);
506
+ vertices.push(vertices[2]);
507
+ return vertices;
508
+ };
509
+ var prepareSnap = function prepareSnap(layer) {
510
+ allLines = _export.GeometryUtils.getAllLines(layer);
511
+ allLineRects = _export.GeometryUtils.buildRectFromLines(layer, allLines);
512
+ allItemRect = _export.GeometryUtils.getAllItems(_this2.props.state.scene, actions.catalog, allLineRects);
513
+ allItemSnap = _export.GeometryUtils.getAllItemSnap(allItemRect);
514
+ allLineSnap = _export.GeometryUtils.getAllLineSnap(allLineRects, allItemRect.cur);
515
+ allRect = allItemRect.others.concat(allLineRects);
516
+ allItemSnap = _export.GeometryUtils.validateSnaps(allItemSnap, allRect);
517
+ allLineSnap = _export.GeometryUtils.validateSnaps(allLineSnap, allRect);
518
+ allArea = _export.GeometryUtils.getAllArea(layer);
519
+ };
520
+ var prepareSnapSpec = function prepareSnapSpec(layer) {
521
+ allLines = _export.GeometryUtils.getAllLines(layer);
522
+ allLineRects = _export.GeometryUtils.buildRectFromLines(layer, allLines);
523
+ allItemRect = _export.GeometryUtils.getAllItemSpecified(_this2.props.state.scene, actions.catalog, _constants.WALL_CABINET_LAYOUTPOS);
524
+ // allItemSnap = GeometryUtils.getAllItemSnap(allItemRect);
525
+ };
526
+
527
+ // prepareSnapSpec(layer);
528
+ var lineRect = function lineRect(layer) {
529
+ var areainfo = [];
530
+ layer.areas.forEach(function (area) {
531
+ var sz = area.vertices.size;
532
+ for (var i = 0; i < sz; i++) {
533
+ areainfo.push(area.vertices.get(i));
534
+ }
535
+ });
536
+ var rect = [];
537
+ areainfo.forEach(function (area) {
538
+ var vert = layer.vertices.get(area);
539
+ rect.push(vert.x, vert.y);
540
+ });
541
+ return rect;
542
+ };
543
+ this.collisionCheck = function (obj, pos, rot, tObj) {
544
+ var _this3 = this;
545
+ var item = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : null;
546
+ var catalog = arguments.length > 5 ? arguments[5] : undefined;
547
+ //collision check from one object to every other object excpet target object
548
+ var layer = this.props.state.scene.getIn(['layers', obj.userData.layerId]);
549
+ var layoutpos = 'utype';
550
+ if (item !== null) {
551
+ var catid = item.type;
552
+ var cat = catalog.elements[catid];
553
+ layoutpos = cat.info.layoutpos;
554
+ }
555
+ var oPos = new Three.Vector2(pos.clone().x, pos.clone().y);
556
+ var sBounding = obj.children[0].userData;
557
+ var width = sBounding.max.x - sBounding.min.x;
558
+ var depth = sBounding.max.z - sBounding.min.z;
559
+ var oVertices = this.getRectPoints(width, depth, oPos.clone(), rot % 360 / 180 * Math.PI);
560
+ var datas = [];
561
+ layer.items.forEach(function (data) {
562
+ datas.push(data);
563
+ });
564
+ for (var _i2 = 0; _i2 < datas.length; _i2++) {
565
+ var data = datas[_i2];
566
+ if (data.id == obj.userData.itemId || data.id == tObj.userData.itemId) continue;
567
+ var target = planData.sceneGraph.layers[obj.userData.layerId].items[data.id];
568
+ if (target === undefined) {
569
+ console.log(data.id + ' does not exist in viewer3d/viewer3d.js collisionCheck function');
570
+ return false;
571
+ }
572
+ var _item = layer.items.getIn([data.id]);
573
+ var ocatid = _item.type;
574
+ var ocat = catalog.elements[ocatid];
575
+ var olayoutpos = ocat.info.layoutpos;
576
+ if (!(layoutpos === _constants.BASE_CABINET_LAYOUTPOS && olayoutpos === _constants.WALL_CABINET_LAYOUTPOS || layoutpos === _constants.WALL_CABINET_LAYOUTPOS && olayoutpos === _constants.BASE_CABINET_LAYOUTPOS)) {
577
+ var tRot = _item.rotation;
578
+ var tPos = new Three.Vector2(_item.x, _item.y);
579
+ var tBounding = target.children[0].userData;
580
+ var twidth = tBounding.max.x - tBounding.min.x;
581
+ var tdepth = tBounding.max.z - tBounding.min.z;
582
+ var tVertices = this.getRectPoints(twidth, tdepth, tPos.clone(), tRot % 360 / 180 * Math.PI);
583
+ if (getInterSect(oVertices, tVertices)) {
584
+ return false;
585
+ }
586
+ }
587
+ }
588
+ datas = [];
589
+ layer.lines.forEach(function (data) {
590
+ datas.push(data);
591
+ });
592
+ var _loop2 = function _loop2() {
593
+ var data = datas[_i3];
594
+ if (data.id == obj.userData.itemId || data.id == tObj.userData.itemId) return 0; // continue
595
+ var item = layer.lines.getIn([data.id]);
596
+ // let llayoutpos = catalog.elements[item.type].info.layoutpos;
597
+ var vertices = [];
598
+ item.vertices.forEach(function (data) {
599
+ var vertex = layer.vertices.get(data);
600
+ vertices.push({
601
+ x: vertex.x,
602
+ y: vertex.y
603
+ });
604
+ });
605
+ var vec = new Three.Vector2(vertices[1].x - vertices[0].x, vertices[1].y - vertices[0].y);
606
+ var tRot = vec.angle();
607
+ var tPos = new Three.Vector2((vertices[0].x + vertices[1].x) / 2, (vertices[0].y + vertices[1].y) / 2);
608
+ var tdepth = item.properties.getIn(['thickness', 'length']);
609
+ var twidth = Math.sqrt(vec.x * vec.x + vec.y * vec.y);
610
+ var tVertices = _this3.getRectPoints(twidth, tdepth, tPos.clone(), tRot);
611
+ if (getInterSect(oVertices, tVertices)) {
612
+ return {
613
+ v: false
614
+ };
615
+ }
616
+ },
617
+ _ret;
618
+ for (var _i3 = 0; _i3 < datas.length; _i3++) {
619
+ _ret = _loop2();
620
+ if (_ret === 0) continue;
621
+ if (_ret) return _ret.v;
622
+ }
623
+ return true;
624
+ };
625
+ this.collisionHoleCheck = function (obj, pos, rot, tObj) {
626
+ var item = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : null;
627
+ var catalog = arguments.length > 5 ? arguments[5] : undefined;
628
+ var layer = this.props.state.scene.getIn(['layers', obj.userData.layerId]);
629
+ var currentItem;
630
+ if (item !== null) {
631
+ var catid = item.type;
632
+ var cat = catalog.elements[catid];
633
+ currentItem = {
634
+ selectedItem: item,
635
+ cat: cat
636
+ };
637
+ }
638
+ var oPos = new Three.Vector2(pos.clone().x, pos.clone().y);
639
+ var sBounding = obj.children[0].userData;
640
+ var width = sBounding.max.x - sBounding.min.x;
641
+ var depth = sBounding.max.z - sBounding.min.z;
642
+ var oVertices = this.getRectPoints(width, depth, oPos.clone(), rot % 360 / 180 * Math.PI);
643
+ var datas = [];
644
+ layer.items.forEach(function (data) {
645
+ datas.push(data);
646
+ });
647
+ for (var _i4 = 0; _i4 < datas.length; _i4++) {
648
+ var data = datas[_i4];
649
+ if (data.id == obj.userData.itemId || data.id == tObj.userData.itemId) continue;
650
+ var target = planData.sceneGraph.layers[obj.userData.layerId].items[data.id];
651
+ if (target === undefined) {
652
+ console.log(data.id + ' does not exist in viewer3d/viewer3d.js collisionCheck function');
653
+ return false;
654
+ }
655
+ var _item2 = layer.items.getIn([data.id]);
656
+ var ocatid = _item2.type;
657
+ var ocat = catalog.elements[ocatid];
658
+ if (!ocat) ocat = catalog.elements[(0, _utils.returnReplaceableDeepSearchType)(ocatid)];
659
+ var otherItem = {
660
+ item: _item2,
661
+ cat: ocat
662
+ };
663
+ if (_export.GeometryUtils.needSnap(currentItem, otherItem) && otherItem.cat.type != 'cabinet') {
664
+ var tRot = _item2.rotation;
665
+ var tPos = new Three.Vector2(_item2.x, _item2.y);
666
+ var tBounding = target.children[0].userData;
667
+ var twidth = tBounding.max.x - tBounding.min.x;
668
+ var tdepth = tBounding.max.z - tBounding.min.z;
669
+ var tVertices = this.getRectPoints(twidth, tdepth, tPos.clone(), tRot % 360 / 180 * Math.PI);
670
+ if (getInterSect(oVertices, tVertices)) {
671
+ return false;
672
+ }
673
+ }
674
+ }
675
+ var holes = [];
676
+ layer.lines.forEach(function (line) {
677
+ line.holes.forEach(function (holeID) {
678
+ var hole = layer.holes.get(holeID);
679
+ holes.push(hole);
680
+ });
681
+ });
682
+ var i = 0;
683
+ for (; i < holes.length; i++) {
684
+ var _tPos = new Three.Vector2(holes[i].x, holes[i].y);
685
+ var _twidth = holes[i].properties.getIn(['width', 'length']);
686
+ var theight = holes[i].properties.getIn(['thickness', 'length']);
687
+ var trot = holes[i].rotation;
688
+ var _tVertices = this.getRectPoints(_twidth, theight, _tPos.clone(), trot);
689
+ if (getInterSect(oVertices, _tVertices)) {
690
+ return false;
691
+ }
692
+ }
693
+ return true;
694
+ };
695
+ this.collisionSlide = function (item3D, originPos, layer, sVertices, tPos, item) {
696
+ var items = [];
697
+ var cur_category = '';
698
+ var catalog = actions.catalog;
699
+ if (layer.selected.items.size > 0) {
700
+ var selectedItem = layer.getIn(['items', layer.selected.items.get(0)]);
701
+ var catid = selectedItem.type;
702
+ var cat = catalog.elements[catid];
703
+ if (cat === undefined || cat === null) cat = catalog.getIn(['elements', catid]);
704
+ cur_category = cat.obj.category;
705
+ }
706
+ layer.items.forEach(function (data) {
707
+ if (data.id == selectedObject.itemID) {
708
+ return;
709
+ }
710
+ items.push(data.toJS());
711
+ });
712
+ var oPos = new Three.Vector2(originPos.x, -originPos.z);
713
+
714
+ // sort from distance
715
+ for (var _i5 = 0; _i5 < items.length - 1; _i5++) {
716
+ for (var j = _i5 + 1; j < items.length; j++) {
717
+ if ((0, _geometry.verticesDistance)(oPos, new Three.Vector2(items[_i5].x, items[_i5].y)) > (0, _geometry.verticesDistance)(oPos, new Three.Vector2(items[j].x, items[j].y))) {
718
+ var exchange = items[j];
719
+ items[j] = items[_i5];
720
+ items[_i5] = exchange;
721
+ }
722
+ }
723
+ }
724
+ var i = 0;
725
+ for (; i < items.length; i++) {
726
+ if (!items[i]) return;
727
+ var _target = planData.sceneGraph.layers[selectedObject.layerID].items[items[i].id];
728
+ if (_target === undefined) {
729
+ return false;
730
+ }
731
+ var _targetData = layer.items.getIn([items[i].id]);
732
+ var _tRot = _targetData.rotation;
733
+ var _tPos2 = new Three.Vector2(_targetData.x, _targetData.y);
734
+ var _tBounding = _target.children[0].userData;
735
+ var _twidth2 = _tBounding.max.x - _tBounding.min.x;
736
+ var _tdepth = _tBounding.max.z - _tBounding.min.z;
737
+ var _tVertices2 = this.getRectPoints(_twidth2, _tdepth, _tPos2.clone(), _tRot % 360 / 180 * Math.PI);
738
+ if (getInterSect(sVertices, _tVertices2)) {
739
+ break;
740
+ }
741
+ }
742
+ if (items.length == 0 || !items[i]) return;
743
+ var target = planData.sceneGraph.layers[selectedObject.layerID].items[items[i].id];
744
+ var targetData = layer.items.getIn([items[i].id]);
745
+ var targetPos = new Three.Vector2(targetData.x, targetData.y);
746
+ var tRot = targetData.rotation;
747
+ var tBounding = target.children[0].userData;
748
+ var twidth = tBounding.max.x - tBounding.min.x;
749
+ var tdepth = tBounding.max.z - tBounding.min.z;
750
+ var tVertices = this.getRectPoints(twidth, tdepth, targetPos.clone(), tRot % 360 / 180 * Math.PI);
751
+ // ////////////////////////
752
+ var vArray = [];
753
+ var dteArray = [];
754
+ var lineArray = [];
755
+ var vdistanceArray = [];
756
+ var cVecArray = [];
757
+ var inFlag = false;
758
+ for (var _i6 = 0; _i6 < 4; _i6++) {
759
+ var v1 = tVertices[_i6];
760
+ var v2 = tVertices[_i6 + 1];
761
+ var data = pointLineDistance({
762
+ x: tPos.x,
763
+ y: tPos.y
764
+ }, [{
765
+ x: v1.x,
766
+ y: v1.y
767
+ }, {
768
+ x: v2.x,
769
+ y: v2.y
770
+ }]);
771
+ dteArray.push(data.distance);
772
+ vArray.push(data.point);
773
+ lineArray.push([v1, v2]);
774
+ }
775
+ // if tPos in target object
776
+ var tPosDistance = Math.abs(pointLineDistance(tPos, lineArray[0]).distance) + Math.abs(pointLineDistance(tPos, lineArray[2]).distance);
777
+ var realDistance = new Three.Vector2(lineArray[1][0].x - lineArray[1][1].x, lineArray[1][0].y - lineArray[1][1].y).length();
778
+ var tPosDistance1 = Math.abs(pointLineDistance(tPos, lineArray[1]).distance) + Math.abs(pointLineDistance(tPos, lineArray[3]).distance);
779
+ var realDistance1 = new Three.Vector2(lineArray[0][0].x - lineArray[0][1].x, lineArray[0][0].y - lineArray[0][1].y).length();
780
+ if (Math.abs(Math.abs(tPosDistance) - Math.abs(realDistance)) < 0.01 && Math.abs(Math.abs(tPosDistance1) - Math.abs(realDistance1)) < 0.01) inFlag = true;
781
+ // ////////////////////
782
+ var key = 0;
783
+ // sort distance from origin point
784
+ for (var _j = 0; _j < dteArray.length - 1; _j++) {
785
+ for (var k = _j + 1; k < dteArray.length; k++) {
786
+ if (Math.abs(dteArray[_j]) > Math.abs(dteArray[k])) {
787
+ var temp = dteArray[k];
788
+ dteArray[_j] = dteArray[k];
789
+ dteArray[k] = temp;
790
+ var temp1 = vArray[k];
791
+ vArray[_j] = vArray[k];
792
+ vArray[k] = temp1;
793
+ var temp2 = lineArray[k];
794
+ lineArray[_j] = lineArray[k];
795
+ lineArray[k] = temp2;
796
+ }
797
+ }
798
+ }
799
+ // //////////////////////////////
800
+ for (var _i7 = 0; _i7 < 4; _i7++) {
801
+ var _data = pointLineDistance(sVertices[_i7], lineArray[key]);
802
+ vdistanceArray.push(_data.distance);
803
+ cVecArray.push({
804
+ x: _data.point.x - sVertices[_i7].x,
805
+ y: _data.point.y - sVertices[_i7].y
806
+ });
807
+ }
808
+ for (var _j2 = 0; _j2 < vdistanceArray.length; _j2++) {
809
+ var tX = tPos.x + cVecArray[_j2].x;
810
+ var tY = tPos.y + cVecArray[_j2].y;
811
+ if (this.collisionCheck(item3D, new Three.Vector2(tX, tY), item.rotation, {
812
+ userData: {
813
+ itemId: null
814
+ }
815
+ }, item, this.context.catalog)) {
816
+ item3D.position.set(tX, originPos.y, -tY);
817
+ sPoint.set(tX, tY);
818
+ break;
819
+ }
820
+ }
821
+ };
822
+ this.snap = function (obj, layer) {
823
+ // snap operation
824
+ var target = obj.userData.target;
825
+ for (; target.parent != null;) {
826
+ if (target.name == 'pivot') break;
827
+ target = target.parent;
828
+ }
829
+ var source = obj.parent.parent.parent;
830
+ if (target.userData.type == 'item') {
831
+ var sRot = layer.getIn(['items', source.userData.itemId]).rotation;
832
+ var tRot = layer.getIn(['items', target.userData.itemId]) ? layer.getIn(['items', target.userData.itemId]).rotation : 0;
833
+ var item = layer.getIn(['items', source.userData.itemId]);
834
+ var layoutType = item.layoutpos;
835
+ var altitudeLength = (0, _convertUnitsLite.convert)(item.properties.getIn(['altitude', '_length'])).from('in').to('cm');
836
+ var sBounding = source.children[0].userData;
837
+ var tBounding = target.children[0].userData;
838
+ var tPos = target.position.clone();
839
+ var width = sBounding.max.x - sBounding.min.x;
840
+ var height = sBounding.max.y - sBounding.min.y;
841
+ var depth = sBounding.max.z - sBounding.min.z;
842
+ var snapBoxGeom = new Three.BoxGeometry(width, height, depth);
843
+ var snapBoxObj = new Three.Mesh(snapBoxGeom, new Three.MeshBasicMaterial({
844
+ // color: 0x2cde6b,
845
+ // opacity: 0.7,
846
+ transparent: true,
847
+ blending: Three.MultiplyBlending
848
+ }));
849
+ var removeSnapBoxObj = function removeSnapBoxObj() {
850
+ if (snapBoxObj) {
851
+ planData.plan.remove(snapBoxObj);
852
+ (0, _threeMemoryCleaner.disposeObject)(snapBoxObj);
853
+ }
854
+ snapFlag = false;
855
+ };
856
+ var box = new Three.BoxHelper(snapBoxObj, 0xffffff);
857
+ box.material.linewidth = 2;
858
+ box.material.depthTest = false;
859
+ box.renderOrder = 200;
860
+ snapBoxObj.add(box);
861
+ snapBoxObj.position.set(source.position.x, layoutType === _constants.WALL_CABINET_LAYOUTPOS ? altitudeLength + source.position.y + height / 2 : source.position.y + height / 2, source.position.z);
862
+ snapBoxObj.rotation.set(source.rotation.x, source.rotation.y, source.rotation.z);
863
+ snapBoxObj.name = 'TransformBox';
864
+ planData.plan.add(snapBoxObj);
865
+ var deltaX = (tBounding.max.x - tBounding.min.x) / 2 + (sBounding.max.x - sBounding.min.x) / 2;
866
+ var deltaZ = (tBounding.max.z - tBounding.min.z) / 2 - (sBounding.max.z - sBounding.min.z) / 2;
867
+ var sPos = snapBoxObj.position.clone();
868
+ // avaliable snap place///////////////
869
+ var tPoses = [];
870
+ var pX = tPos.x + deltaX * Math.cos(tRot / 180 * Math.PI) + deltaZ * Math.sin(tRot / 180 * Math.PI);
871
+ var pZ = tPos.z - deltaX * Math.sin(tRot / 180 * Math.PI) + deltaZ * Math.cos(tRot / 180 * Math.PI);
872
+ tPoses.push(new Three.Vector3(pX, 0, pZ));
873
+ deltaX = -deltaX;
874
+ pX = tPos.x + deltaX * Math.cos(tRot / 180 * Math.PI) + deltaZ * Math.sin(tRot / 180 * Math.PI);
875
+ pZ = tPos.z - deltaX * Math.sin(tRot / 180 * Math.PI) + deltaZ * Math.cos(tRot / 180 * Math.PI);
876
+ tPoses.push(new Three.Vector3(pX, 0, pZ));
877
+ deltaX = (tBounding.max.x - tBounding.min.x) / 2 - (sBounding.max.x - sBounding.min.x) / 2;
878
+ deltaZ = -(tBounding.max.z - tBounding.min.z) / 2 - (sBounding.max.z - sBounding.min.z) / 2;
879
+ pX = tPos.x + deltaX * Math.cos(tRot / 180 * Math.PI) + deltaZ * Math.sin(tRot / 180 * Math.PI);
880
+ pZ = tPos.z - deltaX * Math.sin(tRot / 180 * Math.PI) + deltaZ * Math.cos(tRot / 180 * Math.PI);
881
+ tPoses.push(new Three.Vector3(pX, 0, pZ));
882
+ deltaX = -deltaX;
883
+ pX = tPos.x + deltaX * Math.cos(tRot / 180 * Math.PI) + deltaZ * Math.sin(tRot / 180 * Math.PI);
884
+ pZ = tPos.z - deltaX * Math.sin(tRot / 180 * Math.PI) + deltaZ * Math.cos(tRot / 180 * Math.PI);
885
+ tPoses.push(new Three.Vector3(pX, 0, pZ));
886
+ var distance = Math.sqrt((sPos.x - tPoses[0].x) * (sPos.x - tPoses[0].x) + (sPos.z - tPoses[0].z) * (sPos.z - tPoses[0].z));
887
+ var tNum = 1;
888
+ tPos = tPoses[0].clone();
889
+ for (var _i8 = 1; _i8 < tPoses.length; _i8++) {
890
+ var curDis = Math.sqrt((sPos.x - tPoses[_i8].x) * (sPos.x - tPoses[_i8].x) + (sPos.z - tPoses[_i8].z) * (sPos.z - tPoses[_i8].z));
891
+ if (curDis < distance) {
892
+ distance = curDis;
893
+ tNum = _i8 + 1;
894
+ tPos = tPoses[_i8].clone();
895
+ }
896
+ }
897
+ // //////////////////////////////////
898
+ if (targetObj != null && targetObj.userData.itemId == target.userData.itemId && tNum == targetNumber) {
899
+ removeSnapBoxObj();
900
+ return;
901
+ } else {
902
+ removeSnapBox();
903
+ }
904
+ // //////////////////////////////////
905
+ if (tNum >= 3) tRot += 180;
906
+ snapAnimI = 0;
907
+ t_i = 0;
908
+ targetObj = target;
909
+ targetNumber = tNum;
910
+ targetRot = tRot;
911
+ targetPoint = tPos;
912
+ snapBox = snapBoxObj;
913
+ var cx = sPos.x - tPos.x;
914
+ var cz = sPos.z - tPos.z;
915
+ targetUVec = new Three.Vector3(cx, 0, cz);
916
+ targetCRotation = (tRot - sRot) % 360 / 180 * Math.PI;
917
+ } else {
918
+ var _item3 = layer.getIn(['items', source.userData.itemId]);
919
+ if (holeItems.length && selectedObj) {
920
+ var _i9;
921
+ for (_i9 = 0; _i9 < holeItems.length; _i9++) {
922
+ var hole = holeItems[_i9];
923
+ if (Math.abs(Math.sin(selectedObj.rotRad)) === 1) {
924
+ if (_item3.y + selectedObj.size.width / 2 >= hole.y - hole.width / 2 && _item3.y - selectedObj.size.width / 2 <= hole.y + hole.width / 2 && (selectedObj.rotRad == 0 || selectedObj.rotRad == -Math.PI / 2 ? _item3.x <= hole.x && _item3.x + selectedObj.size.height >= hole.x : _item3.x >= hole.x && _item3.x - selectedObj.size.height <= hole.x)) break;
925
+ } else {
926
+ if (_item3.x + selectedObj.size.width / 2 >= hole.x - hole.width / 2 && _item3.x - selectedObj.size.width / 2 <= hole.x + hole.width / 2 && (selectedObj.rotRad == 0 || selectedObj.rotRad == -Math.PI / 2 ? _item3.y <= hole.y && _item3.y + selectedObj.size.height >= hole.y : _item3.y >= hole.y && _item3.y - selectedObj.size.height <= hole.y)) break;
927
+ }
928
+ }
929
+ if (_i9 != holeItems.length) return;
930
+ }
931
+ if (target.userData.type == 'hole') {
932
+ snapFlag = false;
933
+ return;
934
+ } else {
935
+ var _layoutType = _item3.layoutpos;
936
+ var _altitudeLength = (0, _convertUnitsLite.convert)(_item3.properties.getIn(['altitude', '_length'])).from('in').to('cm');
937
+ var _sBounding = source.children[0].userData;
938
+ var _width = _sBounding.max.x - _sBounding.min.x;
939
+ var _height = _sBounding.max.y - _sBounding.min.y;
940
+ var _depth = _sBounding.max.z - _sBounding.min.z;
941
+ var _snapBoxGeom = new Three.BoxGeometry(_width, _height, _depth);
942
+ var _snapBoxObj = new Three.Mesh(_snapBoxGeom, new Three.MeshBasicMaterial({
943
+ // color: 0x2cde6b,
944
+ // opacity: 0.7,
945
+ transparent: true,
946
+ blending: Three.MultiplyBlending
947
+ }));
948
+ var _removeSnapBoxObj = function _removeSnapBoxObj() {
949
+ if (_snapBoxObj) {
950
+ planData.plan.remove(_snapBoxObj);
951
+ (0, _threeMemoryCleaner.disposeObject)(_snapBoxObj);
952
+ }
953
+ snapFlag = false;
954
+ };
955
+ var _box = new Three.BoxHelper(_snapBoxObj, 0xffffff);
956
+ _box.material.linewidth = 2;
957
+ _box.material.depthTest = false;
958
+ _box.renderOrder = 100;
959
+ _snapBoxObj.add(_box);
960
+ _snapBoxObj.position.set(source.position.x, _layoutType === _constants.WALL_CABINET_LAYOUTPOS ? _altitudeLength + source.position.y + _height / 2 : source.position.y + _height / 2, source.position.z);
961
+ _snapBoxObj.rotation.set(source.rotation.x, source.rotation.y, source.rotation.z);
962
+ _snapBoxObj.name = 'TransformBox';
963
+ planData.plan.add(_snapBoxObj);
964
+ var snapLine = layer.getIn(['lines', target.userData.lineId]);
965
+ // let snapLineThickness = snapLine.properties.getIn([
966
+ // 'thickness',
967
+ // 'length'
968
+ // ]);
969
+ var snapLineThickness = 10.64;
970
+ var vertices = [];
971
+ if (snapLine === undefined) return;
972
+ snapLine.vertices.forEach(function (data) {
973
+ var vec = layer.getIn(['vertices', data]);
974
+ vertices.push(vec);
975
+ });
976
+ var iX = source.position.clone().x;
977
+ var iY = -source.position.clone().z;
978
+ var lineVec = new Three.Vector2(vertices[1].x - vertices[0].x, vertices[1].y - vertices[0].y);
979
+ var oLength = Math.sqrt(lineVec.x * lineVec.x + lineVec.y * lineVec.y);
980
+ lineVec.normalize();
981
+ var vec2 = new Three.Vector2(iX - vertices[0].x, iY - vertices[0].y);
982
+ var vec2Legnth = Math.sqrt(vec2.x * vec2.x + vec2.y * vec2.y);
983
+ var angle = Math.abs(lineVec.angle() - vec2.angle());
984
+ angle = angle > Math.PI ? 2 * Math.PI - angle : angle;
985
+ var lineLength = Math.cos(angle) * vec2Legnth;
986
+ var transLength = 0;
987
+ if (lineLength < 100) {
988
+ transLength = -lineLength + (snapLineThickness + _width) / 2;
989
+ }
990
+ if (lineLength > oLength - 100) {
991
+ transLength = -lineLength - (snapLineThickness + _width) / 2 + oLength;
992
+ }
993
+ var directPoint = new Three.Vector2(lineVec.x * lineLength + vertices[0].x, lineVec.y * lineLength + vertices[0].y);
994
+ var directLine = new Three.Vector2(directPoint.x - iX, directPoint.y - iY);
995
+ var dLength = Math.sqrt((iX - directPoint.x) * (iX - directPoint.x) + (iY - directPoint.y) * (iY - directPoint.y));
996
+ var reduceLen = (snapLineThickness + _depth) / 2;
997
+ var scale = (dLength - reduceLen) / dLength;
998
+ var _tPos3 = new Three.Vector2(iX + (directPoint.x - iX) * scale + lineVec.x * transLength, iY + (directPoint.y - iY) * scale + lineVec.y * transLength);
999
+ var realAngle = directLine.angle() - Math.PI / 2;
1000
+ var _tRot2 = realAngle * 180 / Math.PI;
1001
+ var _sPos = new Three.Vector2(iX, iY);
1002
+ var _sRot = _item3.rotation;
1003
+ var _tNum = 0;
1004
+ // //////////////////////////////////////
1005
+ // check part////
1006
+ var result = this.collisionCheck(source, _tPos3, _tRot2, target, _item3, this.context.catalog);
1007
+ // console.log('result', result);
1008
+ if (result == false) {
1009
+ _removeSnapBoxObj();
1010
+ removeSnapBox();
1011
+ return;
1012
+ }
1013
+ // ////////////////
1014
+ if (targetObj === target && snapBox !== null) {
1015
+ _removeSnapBoxObj();
1016
+ snapAnimI = 20;
1017
+ targetPoint = new Three.Vector3(_tPos3.x, 0, -_tPos3.y);
1018
+ var _sourcePos = snapBox.position.clone();
1019
+ var _cx = _sourcePos.x - targetPoint.x;
1020
+ var _cz = _sourcePos.z - targetPoint.z;
1021
+ targetUVec = new Three.Vector3(_cx, 0, _cz);
1022
+ targetRot = _tRot2;
1023
+ targetCRotation = (_tRot2 - _sRot) % 360 / 180 * Math.PI;
1024
+ snapFlag = false;
1025
+ return;
1026
+ } else {
1027
+ removeSnapBox();
1028
+ }
1029
+ // //////////////////////////////////////
1030
+ snapAnimI = 0;
1031
+ t_i = 0;
1032
+ targetObj = target;
1033
+ targetNumber = _tNum;
1034
+ targetRot = _tRot2;
1035
+ targetPoint = new Three.Vector3(_tPos3.x, 0, -_tPos3.y);
1036
+ snapBox = _snapBoxObj;
1037
+ var sourcePos = snapBox.position.clone();
1038
+ var _cx2 = sourcePos.x - targetPoint.x;
1039
+ var _cz2 = sourcePos.z - targetPoint.z;
1040
+ targetUVec = new Three.Vector3(_cx2, 0, _cz2);
1041
+ targetRot = _tRot2;
1042
+ targetCRotation = (_tRot2 - _sRot) % 360 / 180 * Math.PI;
1043
+ }
1044
+ }
1045
+ };
1046
+
1047
+ /*end of snap functions*/
1048
+ var selectedObj = null;
1049
+ var firstMove = false;
1050
+ var prevX, prevY;
1051
+ var selObj = null;
1052
+ var createToolObject = function createToolObject() {
1053
+ var canvas = document.createElement('canvas');
1054
+ canvas.width = 100;
1055
+ canvas.height = 200;
1056
+ canvas.style.width = 50 + 'px';
1057
+ canvas.style.height = 100 + 'px';
1058
+ var ctx = canvas.getContext('2d');
1059
+ ctx.fillStyle = '#FFFFFF';
1060
+ ctx.strokeStyle = '#000000';
1061
+ ctx.beginPath();
1062
+ ctx.arc(50, 50, 40, 0, 4 * Math.PI);
1063
+ ctx.fill();
1064
+ ctx.stroke();
1065
+ var img1 = new Image();
1066
+ img1.crossOrigin = 'anonymous';
1067
+ img1.src = '/assets/img/svg/3d_item_rotation.svg';
1068
+ img1.onload = function () {
1069
+ ctx.drawImage(img1, 16, 16, 68, 68);
1070
+ };
1071
+ ctx.beginPath();
1072
+ ctx.arc(50, 150, 40, 0, 4 * Math.PI);
1073
+ ctx.fill();
1074
+ ctx.stroke();
1075
+ var img2 = new Image();
1076
+ img2.crossOrigin = 'anonymous';
1077
+ img2.src = '/assets/img/svg/3d_item_move.svg';
1078
+ img2.onload = function () {
1079
+ ctx.drawImage(img2, 16, 116, 68, 68);
1080
+ };
1081
+ return canvas;
1082
+ };
1083
+ var clockWise = true;
1084
+ var lastAngle = 0;
1085
+ var createAngleObject = function createAngleObject(rotate) {
1086
+ var canvas = document.createElement('canvas');
1087
+ canvas.width = 100;
1088
+ canvas.height = 100;
1089
+ canvas.style.width = 100 + 'px';
1090
+ canvas.style.height = 100 + 'px';
1091
+ var ctx = canvas.getContext('2d');
1092
+ ctx.strokeStyle = '#FFFFFF';
1093
+ ctx.lineWidth = 10;
1094
+ ctx.beginPath();
1095
+ ctx.arc(50, 50, 45, 0, 2 * Math.PI);
1096
+ ctx.stroke();
1097
+ ctx.strokeStyle = _constants.SECONDARY_PURPLE_COLOR;
1098
+ ctx.lineWidth = 6;
1099
+ ctx.beginPath();
1100
+ if (lastAngle < 15 && lastAngle > -15) {
1101
+ if (rotate >= 0) {
1102
+ clockWise = false;
1103
+ } else {
1104
+ clockWise = true;
1105
+ }
1106
+ if (lastAngle === 0) {
1107
+ if (rotate > -180) {
1108
+ clockWise = true;
1109
+ } else {
1110
+ clockWise = false;
1111
+ }
1112
+ }
1113
+ }
1114
+ ctx.arc(50, 50, 45, 0, rotate / 180.0 * Math.PI, clockWise);
1115
+ ctx.stroke();
1116
+ lastAngle = rotate;
1117
+ return canvas;
1118
+ };
1119
+ var toolTexture = new Three.Texture(createToolObject());
1120
+ toolTexture.needsUpdate = true;
1121
+ var toolObj = new Three.Sprite(new Three.SpriteMaterial({
1122
+ map: toolTexture,
1123
+ sizeAttenuation: true
1124
+ }));
1125
+ toolObj.material.transparent = true;
1126
+ toolObj.material.depthTest = false;
1127
+ toolObj.scale.set(20, 40, 20);
1128
+ toolObj.renderOrder = 3;
1129
+ toolObj.name = 'toolObj';
1130
+ var angleTexture = new Three.Texture(createAngleObject(0));
1131
+ angleTexture.needsUpdate = true;
1132
+ var angleObj = new Three.Sprite(new Three.SpriteMaterial({
1133
+ map: angleTexture,
1134
+ sizeAttenuation: false
1135
+ }));
1136
+ angleObj.scale.set(0.075, 0.075, 0.075);
1137
+ angleObj.material.transparent = true;
1138
+ angleObj.material.depthTest = false;
1139
+ angleObj.renderOrder = 3;
1140
+ angleObj.name = 'angleObj';
1141
+
1142
+ /**
1143
+ * Calculate plane point of mouse with `event` & `altitude`
1144
+ * * Calculate mouse.x & mouse.y
1145
+ * * Set raycaster from camera & Set raycaster direction
1146
+ * * Calculate Point & dispatch an action
1147
+ */
1148
+ var getPoint = function getPoint(e, alti) {
1149
+ mouse.x = e.offsetX / _this2.width * 2 - 1;
1150
+ mouse.y = -e.offsetY / _this2.height * 2 + 1;
1151
+ raycaster.setFromCamera(mouse, camera);
1152
+ rayDirection = raycaster.ray.direction;
1153
+ Point = mapCursorPosition(e, alti);
1154
+ _this2.context.projectActions.updateMouseCoord(Point);
1155
+ };
1156
+ var getIntersectWallPoint = function getIntersectWallPoint(e) {
1157
+ mouse.x = e.offsetX / _this2.width * 2 - 1;
1158
+ mouse.y = -e.offsetY / _this2.height * 2 + 1;
1159
+ raycaster.setFromCamera(mouse, camera);
1160
+ rayDirection = raycaster.ray.direction;
1161
+ var lines = planData.sceneGraph.layers[scene.selectedLayer].lines;
1162
+ var keys = Object.keys(lines);
1163
+ var arrMesh = [];
1164
+ keys.forEach(function (key) {
1165
+ lines[key].children[0].children.forEach(function (mesh) {
1166
+ if (mesh.name == 'soul' && mesh.visible) arrMesh.push(mesh);
1167
+ });
1168
+ });
1169
+ if (arrMesh.length > 0) {
1170
+ var intersects = raycaster.intersectObjects(arrMesh);
1171
+ if (intersects.length > 0) {
1172
+ var intersectPt = intersects[0].point;
1173
+ intersectPt.applyMatrix4(gridMatrix);
1174
+ Point = {
1175
+ x: intersectPt.x,
1176
+ y: -intersectPt.z
1177
+ };
1178
+ _this2.context.projectActions.updateMouseCoord(Point);
1179
+ return true;
1180
+ }
1181
+ }
1182
+ return false;
1183
+ };
1184
+ var updateSelectedObject = function updateSelectedObject() {
1185
+ // update the selected object
1186
+ var selectedLayerId = _this2.props.state.scene.selectedLayer;
1187
+ var selItemId = _this2.props.state.scene.getIn(['layers', selectedLayerId, 'selected', 'items']).toJS()[0];
1188
+ selectedObject = {
1189
+ layerID: selectedLayerId,
1190
+ itemID: selItemId
1191
+ };
1192
+ };
1193
+ this.mouseDownEvent = function (event) {
1194
+ gridPlanOrigin = gridPlane.position;
1195
+ gridMatrix.copy(gridPlane.matrixWorld).invert();
1196
+ var altitude = 0;
1197
+ if (allItemRect && allItemRect.cur && allItemRect.cur.itemInfo !== undefined) {
1198
+ var properties = allItemRect.cur.itemInfo.properties;
1199
+ altitude = properties.getIn(['altitude', '_length']);
1200
+ var unit = properties.getIn(['altitude', '_unit']) || 'in';
1201
+ altitude = (0, _convertUnitsLite.convert)(altitude).from(unit).to(_this2.props.state.scene.unit);
1202
+ }
1203
+ getPoint(event, altitude);
1204
+ var state = _this2.props.state;
1205
+ _this2.lastMousePosition.x = mouse.x;
1206
+ _this2.lastMousePosition.y = mouse.y;
1207
+ var layer = state.scene.getIn(['layers', state.scene.selectedLayer]);
1208
+ var sCount = layer.selected.areas.size + layer.selected.holes.size + layer.selected.items.size + layer.selected.lines.size;
1209
+ if (sCount <= 0) {
1210
+ isSelected = false;
1211
+ } else if (sCount >= 0 && selectedObject && 'holeID' in selectedObject) {
1212
+ isSelected = true;
1213
+ }
1214
+ prevX = Point.x;
1215
+ prevY = Point.y;
1216
+
1217
+ /**
1218
+ * 0 - rotate
1219
+ * 1 - move up/down
1220
+ * 2 - move x/y
1221
+ * 3 - camera rotate
1222
+ */
1223
+ var transflag = 3;
1224
+ raycaster.setFromCamera(mouse, camera);
1225
+ var meshes = [];
1226
+ toIntersect.forEach(function (object) {
1227
+ if (!object) return;
1228
+ object.traverse(function (o) {
1229
+ if (o.isMesh) meshes.push(o);
1230
+ });
1231
+ });
1232
+ var intersects = raycaster.intersectObjects(meshes, true);
1233
+ var toolIntersects = raycaster.intersectObjects([toolObj], true);
1234
+
1235
+ // This code is excuted when click the tool object(rotation or move icon).
1236
+ if (toolIntersects.length > 0) {
1237
+ updateSelectedObject();
1238
+ // it determines whether mouse is over on rotation icon or move icon.
1239
+ var distance = Math.sqrt(Math.pow((toolIntersects[0].uv.x - 0.5) * 50, 2) + Math.pow((toolIntersects[0].uv.y - 0.25) * 100, 2));
1240
+ // move icon selected
1241
+ if (distance <= 20) {
1242
+ transflag = 2;
1243
+ } else {
1244
+ distance = Math.sqrt(Math.pow((toolIntersects[0].uv.x - 0.5) * 50, 2) + Math.pow((toolIntersects[0].uv.y - 0.75) * 100, 2));
1245
+ // rotation icon selected
1246
+ if (distance <= 20) {
1247
+ transflag = 0;
1248
+ }
1249
+ }
1250
+ }
1251
+ if (intersects.length > 0) {
1252
+ var _i0 = 0,
1253
+ length = intersects.length;
1254
+ for (_i0 = 0; _i0 < length; _i0++) {
1255
+ if (intersects[_i0].object.type !== 'BoxHelper' &&
1256
+ // intersects[i].object.type === OBJTYPE_MESH &&
1257
+ intersects[_i0].object.name !== 'lineText' && intersects[_i0].object.name !== 'soul' && !intersects[_i0].object.name.includes('WarningBox')) break;
1258
+ }
1259
+ if (intersects[_i0] !== undefined) {
1260
+ if (intersects[_i0].object.name.indexOf('transUp') != -1) transflag = 1;
1261
+ if (intersects[_i0].object.name.indexOf('transHole') != -1) transflag = 2;
1262
+ } else {
1263
+ console.log('intersects[i] is undefined in viewer3d/viewer3d.js');
1264
+ }
1265
+ }
1266
+ if (_this2.props.state.mode == _constants.MODE_DRAWING_ITEM_3D) return;
1267
+ if (isSelected) {
1268
+ !_this2.props.downloadFlag && _this2.props.setToolbar('');
1269
+ if (intersects.length > 0 && !isNaN(intersects[0].distance)) {
1270
+ var _i1;
1271
+ for (_i1 = 0; _i1 < intersects.length; _i1++) {
1272
+ if (intersects[_i1].object instanceof Three.Mesh && intersects[_i1].object.name != 'TransformBox' && intersects[_i1].object.type != 'Line' && intersects[_i1].object.name != 'lineText' && intersects[_i1].object.name != 'countertops' && intersects[_i1].object.type != 'BoxHelper' && intersects[_i1].object.name != 'floor' && intersects[_i1].object.name != 'backFace' && intersects[_i1].object.name != 'soul' && !intersects[_i1].object.name.includes('backsplash') && !intersects[_i1].object.name.includes('WarningBox')) break;
1273
+ }
1274
+ if (intersects[_i1] === undefined) {
1275
+ if (transflag !== 0 && transflag !== 2) {
1276
+ isSelected = false;
1277
+ _this2.context.projectActions.unselectAll();
1278
+ scene3D.remove(toolObj);
1279
+ _this2.context.itemsActions.removeReplacingSupport();
1280
+ return;
1281
+ }
1282
+ }
1283
+ if (selectedObject !== undefined) {
1284
+ // get selected object from planData.sceneGraph
1285
+ var selectedItem = null;
1286
+ switch (true) {
1287
+ case 'itemID' in selectedObject:
1288
+ selectedItem = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1289
+ break;
1290
+ case 'holeID' in selectedObject:
1291
+ selectedItem = planData.sceneGraph.layers[selectedObject.layerID].holes[selectedObject.holeID];
1292
+ break;
1293
+ default:
1294
+ break;
1295
+ }
1296
+ sPoint.set(Point.x, Point.y);
1297
+ if (transflag == 0) {
1298
+ scene3D.remove(toolObj);
1299
+ var alti = 0;
1300
+ if (allItemRect && allItemRect.cur && allItemRect.cur.itemInfo !== undefined) {
1301
+ var _properties = allItemRect.cur.itemInfo.properties;
1302
+ alti = _properties.getIn(['altitude', '_length']);
1303
+ var _unit = _properties.getIn(['altitude', '_unit']) || 'in';
1304
+ alti = (0, _convertUnitsLite.convert)(alti).from(_unit).to(_this2.props.state.scene.unit);
1305
+ }
1306
+ getPoint({
1307
+ offsetX: event.offsetX - 50,
1308
+ offsetY: event.offsetY
1309
+ }, alti);
1310
+ if ((0, _util.isUndefined)(selectedItem)) return;
1311
+ var selItem = _this2.props.state.scene.layers.get(selectedObject.layerID).items.get(selectedObject.itemID);
1312
+ lastAngle = 0;
1313
+ angleObj.position.set(planData.plan.position.x + Point.x, selItem.category === 'lighting' ? -planData.plan.position.y - selItem.properties.get('height').get('length') : selItem.properties.get('altitude').get('length') + planData.plan.position.y, planData.plan.position.z - Point.y);
1314
+ angleTexture.image = createAngleObject(0);
1315
+ angleTexture.needsUpdate = true;
1316
+ scene3D.add(angleObj);
1317
+ _this2.setState({
1318
+ angleObj: angleObj
1319
+ });
1320
+ var centerPos = Point;
1321
+ getPoint(event, alti);
1322
+ _this2.context.itemsActions.beginRotatingItem3D(selectedObject.layerID, selectedObject.itemID, Point.x, Point.y, centerPos.x, centerPos.y);
1323
+ bRotate = true;
1324
+ } else if (transflag == 1) {
1325
+ bMoveUP = true;
1326
+ } else if (transflag == 2) {
1327
+ switch (true) {
1328
+ case 'holeID' in selectedObject:
1329
+ _this2.context.holesActions.beginDraggingHole3D(selectedObject.layerID, selectedObject.holeID, Point.x, Point.y);
1330
+ break;
1331
+ default:
1332
+ _this2.context.itemsActions.beginDraggingItem3D(selectedObject.layerID, selectedObject.itemID, Point.x, Point.y);
1333
+ break;
1334
+ }
1335
+ bMove = true;
1336
+ scene3D.remove(toolObj);
1337
+ }
1338
+ for (_i1 = 0; _i1 < intersects.length; _i1++) {
1339
+ if (selectedItem != undefined && intersects[_i1].object.parent && intersects[_i1].object.parent.parent.userData.itemId === selectedItem.userData.itemId) selectedFlag = true;
1340
+ }
1341
+ if (selectedFlag || toolIntersects.length > 0 && !(0, _helper.isElevationView)(mode)) {
1342
+ cameraControls.mouseButtons.left = _cameraControls["default"].ACTION.NONE;
1343
+ selectedFlag = false;
1344
+ } else {
1345
+ isSelected = false;
1346
+ _this2.context.projectActions.unselectAll();
1347
+ scene3D.remove(toolObj);
1348
+ _this2.context.itemsActions.removeReplacingSupport();
1349
+ }
1350
+ }
1351
+ } else {
1352
+ isSelected = false;
1353
+ _this2.context.projectActions.unselectAll();
1354
+ scene3D.remove(toolObj);
1355
+ _this2.context.itemsActions.removeReplacingSupport();
1356
+ return;
1357
+ }
1358
+ }
1359
+ };
1360
+ this.mouseUpEvent = function (event) {
1361
+ var internalType = ''; // internalEvent type - select/drag/draw
1362
+ var selectedElement; // internalEvent data
1363
+ firstMove = 0;
1364
+ var altitude = 0;
1365
+ if (allItemRect && allItemRect.cur && allItemRect.cur.itemInfo !== undefined) {
1366
+ var properties = allItemRect.cur.itemInfo.properties;
1367
+ altitude = properties.getIn(['altitude', '_length']);
1368
+ var unit = properties.getIn(['altitude', '_unit']) || 'in';
1369
+ altitude = (0, _convertUnitsLite.convert)(altitude).from(unit).to(_this2.props.state.scene.unit);
1370
+ }
1371
+ scene3D.remove(angleObj);
1372
+ scene3D.remove(toolObj);
1373
+ if (!_this2.props.downloadFlag && !_this2.props.state.mode.includes('ING')) {
1374
+ _this2.props.setToolbar('');
1375
+ }
1376
+ if (_this2.props.state.mode == _constants.MODE_DRAWING_ITEM_3D) {
1377
+ if (Point.x > _this2.props.state.scene.width) Point.x = _this2.props.state.width;
1378
+ if (Point.y > _this2.props.state.scene.height) Point.y = _this2.props.state.height;
1379
+ if (Point.x < 0) Point.x = 0;
1380
+ if (Point.y < 0) Point.y = 0;
1381
+ if (snapBox == null) {
1382
+ actions.itemsActions.endDrawingItem(_this2.props.state.scene.selectedLayer, sPoint.x, sPoint.y);
1383
+ } else {
1384
+ removeSnapBox();
1385
+ var polygon = _export.GeometryUtils.getPoylgonPoints(layer);
1386
+ // if cursor is outside of room
1387
+ if (polygon.length > 0 && !_export.GeometryUtils.ContainsPoint(polygon, Point.x, Point.y)) {
1388
+ actions.itemsActions.endDrawingItem(_this2.props.state.scene.selectedLayer, sPoint.x, sPoint.y);
1389
+ } else {
1390
+ actions.itemsActions.updateDraggingItemChanged(targetPoint.x, -targetPoint.z, selectedObject.layerID, selectedObject.itemID);
1391
+ _this2.context.itemsActions.updateRotatingItemChanged(targetRot, selectedObject.layerID, selectedObject.itemID);
1392
+ actions.itemsActions.endDrawingItem(_this2.props.state.scene.selectedLayer, Point.x, Point.y);
1393
+ }
1394
+ }
1395
+ bMove = false;
1396
+ isInitialPhase = true;
1397
+ return;
1398
+ }
1399
+ switch (_this2.props.state.mode) {
1400
+ case _constants.MODE_DRAGGING_ITEM_3D:
1401
+ internalType = _constants.INTERNAL_EVENT_DRAG_ELEMENT;
1402
+ break;
1403
+ case _constants.MODE_ROTATING_ITEM_3D:
1404
+ internalType = _constants.INTERNAL_EVENT_ROTATE_ELEMENT;
1405
+ break;
1406
+ }
1407
+ if (_this2.props.state.mode == _constants.MODE_DRAGGING_ITEM_3D) {
1408
+ _this2.context.itemsActions.endDraggingItem3D();
1409
+ }
1410
+ if (_this2.props.state.mode == _constants.MODE_ROTATING_ITEM_3D) {
1411
+ _this2.context.itemsActions.endRotatingItem3D(sPoint.x, sPoint.y);
1412
+ }
1413
+ getPoint(event, altitude);
1414
+ if (_this2.props.state.mode == _constants.MODE_DRAWING_HOLE_3D) {
1415
+ gridPlanOrigin = gridPlane.position;
1416
+ gridMatrix.copy(gridPlane.matrixWorld).invert();
1417
+ camPos = camera.position;
1418
+ if (!getIntersectWallPoint(event)) return;
1419
+ actions.holesActions.endDrawingHole3D(_this2.props.state.scene.selectedLayer, Point.x, Point.y);
1420
+ bMove = false;
1421
+ return;
1422
+ }
1423
+ event.preventDefault();
1424
+ if (event.button === 0) {
1425
+ cameraControls.mouseButtons.left = _cameraControls["default"].ACTION.ROTATE;
1426
+ mouse.x = event.offsetX / _this2.width * 2 - 1;
1427
+ mouse.y = -(event.offsetY / _this2.height) * 2 + 1;
1428
+ raycaster.setFromCamera(mouse, camera);
1429
+ rayDirection = raycaster.ray.direction;
1430
+ rayDirection = rayDirection.normalize();
1431
+ var meshes = [];
1432
+ toIntersect.forEach(function (object) {
1433
+ if (!object) return;
1434
+ object.traverse(function (o) {
1435
+ if (o.isMesh) meshes.push(o);
1436
+ });
1437
+ });
1438
+ var intersects = raycaster.intersectObjects(meshes, true);
1439
+ var _i10;
1440
+ if (intersects.length > 0 && !isNaN(intersects[0].distance)) {
1441
+ for (_i10 = 0; _i10 < intersects.length; _i10++) {
1442
+ if (intersects[_i10].object.name === 'warningObj') break;
1443
+ }
1444
+ if (intersects[_i10] !== undefined) {
1445
+ var distance = Math.sqrt(Math.pow((intersects[_i10].uv.x - 0.5) * 50, 2) + Math.pow((intersects[_i10].uv.y - 0.25) * 100, 2));
1446
+ if (distance <= 20) {
1447
+ if (!bMove && !bRotate) {
1448
+ isSelected = false;
1449
+ _this2.context.projectActions.unselectAll();
1450
+ scene3D.remove(toolObj);
1451
+ _this2.context.itemsActions.removeReplacingSupport();
1452
+ var replaceInfo = intersects[_i10].object.parent.parent.userData;
1453
+ _this2.context.itemsActions.selectItem(replaceInfo.layerId, replaceInfo.itemId);
1454
+ !_this2.props.downloadFlag && _this2.props.replaceCabinet(true);
1455
+ return;
1456
+ }
1457
+ }
1458
+ }
1459
+ }
1460
+ !_this2.props.downloadFlag && _this2.props.replaceCabinet(false);
1461
+ if (intersects.length > 0 && !isNaN(intersects[0].distance)) {
1462
+ for (_i10 = 0; _i10 < intersects.length; _i10++) {
1463
+ if (intersects[_i10].object instanceof Three.Mesh && intersects[_i10].object.name != 'TransformBox' && intersects[_i10].object.type != 'Line' && intersects[_i10].object.name != 'lineText' && intersects[_i10].object.name != 'countertops' && intersects[_i10].object.type != 'BoxHelper' && intersects[_i10].object.name != 'soul' && !intersects[_i10].object.name.includes('backsplash') && !intersects[_i10].object.name.includes('WarningBox')) break;
1464
+ }
1465
+ }
1466
+ gridMatrix.copy(gridPlane.matrixWorld).invert();
1467
+ if (Math.abs(mouse.x - _this2.lastMousePosition.x) <= 0.02 && Math.abs(mouse.y - _this2.lastMousePosition.y) <= 0.02 || bMove) {
1468
+ if (intersects.length > 0 && !isNaN(intersects[0].distance)) {
1469
+ if (intersects[_i10] === undefined) {
1470
+ if (!bMove) {
1471
+ isSelected = false;
1472
+ _this2.context.projectActions.unselectAll();
1473
+ scene3D.remove(toolObj);
1474
+ _this2.context.itemsActions.removeReplacingSupport();
1475
+ return;
1476
+ }
1477
+ }
1478
+ if (!bMove) {
1479
+ selectedObject = intersects[_i10].object.interact && intersects[_i10].object.interact();
1480
+ }
1481
+ if (selectedObject !== undefined && 'itemID' in selectedObject) {
1482
+ currentObject = intersects[_i10].object;
1483
+ for (; currentObject.parent != null;) {
1484
+ if (currentObject.name == 'pivot') break;
1485
+ currentObject = currentObject.parent;
1486
+ }
1487
+ isSelected = true;
1488
+ (0, _sceneCreator.getDistances)(layer);
1489
+ var selectedItem = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1490
+ if ((0, _util.isUndefined)(selectedItem)) return;
1491
+ selectedElement = _this2.props.state.scene.layers.get(selectedObject.layerID).items.get(selectedObject.itemID);
1492
+ var itemPos = selectedItem.position.clone();
1493
+ if (intersects[_i10].object.parent && intersects[_i10].object.parent.parent.userData.itemId === selectedItem.userData.itemId) {
1494
+ toolObj.position.set(intersects[_i10].point.x, intersects[_i10].point.y, intersects[_i10].point.z);
1495
+ } else {
1496
+ toolObj.position.set(planData.plan.position.x + itemPos.x, selectedElement.category === 'lighting' ? -planData.plan.position.y - selectedElement.properties.get('height').get('length') : planData.plan.position.y + selectedItem.children[0].position.y, planData.plan.position.z + itemPos.z);
1497
+ }
1498
+ scene3D.add(toolObj);
1499
+ _this2.setState({
1500
+ toolObj: toolObj
1501
+ });
1502
+ // showItemButtons(layer.getIn(['items', selectedObject.itemID]), currentObject, event, camera, this.renderer);
1503
+ var pointArray = [],
1504
+ cnt = 0;
1505
+ pointArray.push([_sceneCreator.fVLine[0].userData.distance, 90]);
1506
+ pointArray.push([_sceneCreator.fVLine[1].userData.distance, -90]);
1507
+ pointArray.push([_sceneCreator.fVLine[2].userData.distance, 180]);
1508
+ pointArray.push([_sceneCreator.fVLine[3].userData.distance, 0]);
1509
+ pointArray.forEach(function (pointElement, index) {
1510
+ if (pointElement[0] == undefined) pointArray[index][0] = 0;
1511
+ });
1512
+ pointArray.forEach(function (pointElement) {
1513
+ if (pointElement[0] == 0) cnt++;
1514
+ });
1515
+ if (cnt == 4 || cnt == 3) {
1516
+ pointArray[0][0] = 100;
1517
+ pointArray[1][0] = 100;
1518
+ }
1519
+ actions.itemsActions.storeDistArray(layer.id, selectedObject.itemID, pointArray);
1520
+ internalType = internalType ? internalType : _constants.INTERNAL_EVENT_SELECT_ELEMENT;
1521
+ } else {
1522
+ if (selectedObject) {
1523
+ var elementID = null;
1524
+ var elementPrototype = null;
1525
+ switch (true) {
1526
+ case 'holeID' in selectedObject:
1527
+ case 'lineID' in selectedObject:
1528
+ if (_this2.props.state.mode === _constants.MODE_DRAGGING_HOLE_3D) {
1529
+ actions.holesActions.endDraggingHole3D(sPoint.x, sPoint.y);
1530
+ internalType = _constants.INTERNAL_EVENT_SELECT_ELEMENT;
1531
+ elementID = selectedObject.holeID;
1532
+ elementPrototype = 'holeID';
1533
+ }
1534
+ break;
1535
+ case 'areaID' in selectedObject:
1536
+ internalType = _constants.INTERNAL_EVENT_SELECT_ELEMENT;
1537
+ elementID = selectedObject.areaID;
1538
+ elementPrototype = 'areas';
1539
+ break;
1540
+ default:
1541
+ break;
1542
+ }
1543
+ selectedElement = _this2.props.state.scene.layers.get(selectedObject.layerID).getIn([elementPrototype, elementID]);
1544
+ }
1545
+ isSelected = false;
1546
+ }
1547
+ } else {
1548
+ isSelected = false;
1549
+ _this2.context.projectActions.unselectAll();
1550
+ switch (true) {
1551
+ case 'holeID' in selectedObject:
1552
+ actions.holesActions.endDraggingHole3D(sPoint.x, sPoint.y);
1553
+ break;
1554
+ default:
1555
+ _this2.context.itemsActions.removeReplacingSupport();
1556
+ break;
1557
+ }
1558
+ }
1559
+ bMove = false;
1560
+ bRotate = false;
1561
+ bMoveUP = false;
1562
+ if (isSelected) {
1563
+ prepareSnap(layer);
1564
+ selectedObj = allItemRect.cur;
1565
+ }
1566
+ } else {
1567
+ (0, _sceneCreator.visibleTransformBox)(false);
1568
+ var alti = 0;
1569
+ if (allItemRect && allItemRect.cur && allItemRect.cur.itemInfo !== undefined) {
1570
+ var _properties2 = allItemRect.cur.itemInfo.properties;
1571
+ alti = _properties2.getIn(['altitude', '_length']);
1572
+ var _unit2 = _properties2.getIn(['altitude', '_unit']) || 'in';
1573
+ alti = (0, _convertUnitsLite.convert)(alti).from(_unit2).to(_this2.props.state.scene.unit);
1574
+ }
1575
+ getPoint(event, alti);
1576
+ if (bRotate) {
1577
+ var _intersects$_i;
1578
+ var _selectedItem = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1579
+ if ((0, _util.isUndefined)(_selectedItem)) return;
1580
+ selectedElement = _this2.props.state.scene.layers.get(selectedObject.layerID).items.get(selectedObject.itemID);
1581
+ var _itemPos = _selectedItem.position.clone();
1582
+ if (((_intersects$_i = intersects[_i10]) === null || _intersects$_i === void 0 || (_intersects$_i = _intersects$_i.object) === null || _intersects$_i === void 0 || (_intersects$_i = _intersects$_i.parent) === null || _intersects$_i === void 0 || (_intersects$_i = _intersects$_i.parent) === null || _intersects$_i === void 0 || (_intersects$_i = _intersects$_i.userData) === null || _intersects$_i === void 0 ? void 0 : _intersects$_i.itemId) === _selectedItem.userData.itemId) {
1583
+ toolObj.position.set(intersects[_i10].point.x, intersects[_i10].point.y, intersects[_i10].point.z);
1584
+ } else {
1585
+ toolObj.position.set(planData.plan.position.x + _itemPos.x, selectedElement.category === 'lighting' ? -planData.plan.position.y - selectedElement.properties.get('height').get('length') : planData.plan.position.y + _selectedItem.children[0].position.y, planData.plan.position.z + _itemPos.z);
1586
+ }
1587
+ scene3D.add(toolObj);
1588
+ _this2.setState({
1589
+ toolObj: toolObj
1590
+ });
1591
+ _this2.context.itemsActions.endRotatingItem3D(Point.x, Point.y);
1592
+ bRotate = false;
1593
+ }
1594
+ if (bMove) {
1595
+ bMove = false;
1596
+ var _selectedItem2 = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1597
+ if ((0, _util.isUndefined)(_selectedItem2)) return;
1598
+ selectedElement = _this2.props.state.scene.layers.get(selectedObject.layerID).items.get(selectedObject.itemID);
1599
+ var _itemPos2 = _selectedItem2.position.clone();
1600
+ if (intersects[_i10].object.parent.parent.userData.itemId === _selectedItem2.userData.itemId) {
1601
+ toolObj.position.set(intersects[_i10].point.x, intersects[_i10].point.y, intersects[_i10].point.z);
1602
+ } else {
1603
+ toolObj.position.set(planData.plan.position.x + _itemPos2.x, selectedElement.category === 'lighting' ? -planData.plan.position.y - selectedElement.properties.get('height').get('length') : planData.plan.position.y + _selectedItem2.children[0].position.y, planData.plan.position.z + _itemPos2.z);
1604
+ }
1605
+ scene3D.add(toolObj);
1606
+ _this2.setState({
1607
+ toolObj: toolObj
1608
+ });
1609
+ if (snapBox == null) {
1610
+ var item3D = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1611
+ if (!item3D) return;
1612
+ item3D.visible = true;
1613
+ var originPos = item3D.position.clone();
1614
+ setTimeout(function () {
1615
+ _this2.context.itemsActions.updateDraggingItemChanged(originPos.x, -originPos.z, selectedObject.layerID, selectedObject.itemID);
1616
+ }, 50);
1617
+ } else {
1618
+ _this2.context.itemsActions.updateDraggingItemChanged(targetPoint.x, -targetPoint.z, selectedObject.layerID, selectedObject.itemID);
1619
+ _this2.context.itemsActions.updateRotatingItemChanged(targetRot, selectedObject.layerID, selectedObject.itemID);
1620
+ var _item3D = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1621
+ _item3D.position.x = targetPoint.x;
1622
+ _item3D.position.z = targetPoint.z;
1623
+ _item3D.visible = true;
1624
+ }
1625
+ }
1626
+ if (bMoveUP) {
1627
+ bMoveUP = false;
1628
+ }
1629
+ }
1630
+ removeSnapBox();
1631
+ actions.sceneActions.updateMovingState(true);
1632
+ if (isSelected === true) {
1633
+ prepareSnap(layer);
1634
+ selectedObj = allItemRect.cur;
1635
+ }
1636
+ }
1637
+ if (!(0, _helper.isEmpty)(internalType)) {
1638
+ var _this2$props$onIntern, _this2$props;
1639
+ (_this2$props$onIntern = (_this2$props = _this2.props).onInternalEvent) === null || _this2$props$onIntern === void 0 || _this2$props$onIntern.call(_this2$props, {
1640
+ type: internalType,
1641
+ value: selectedElement.toJS()
1642
+ });
1643
+ }
1644
+ };
1645
+ this.mouseEnterEvent = function (event) {
1646
+ if (_this2.props.state.mode !== _constants.MODE_DRAWING_ITEM_3D) return;
1647
+ // if not initial moment of drawing an item
1648
+ if (!isInitialPhase) return;
1649
+ var bNormalFlow = true;
1650
+ _this2.getSelectedObject();
1651
+ var layer = _this2.props.state.scene.getIn(['layers', selectedObject.layerID]);
1652
+ var mX = Point.x - sPoint.x;
1653
+ var mY = Point.y - sPoint.y;
1654
+ var item3D = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1655
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('TransformBox');
1656
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('WarningBox' + selectedObject.itemID);
1657
+ var item = layer.getIn(['items', selectedObject.itemID]);
1658
+ if (!item3D || !item) return;
1659
+ if (item.counterTop.uri == '') item.counterTop.uri = layer.counterTop.uri;
1660
+ var sRot = item.rotation;
1661
+ var originPos = item3D.position.clone();
1662
+ var tPos = new Three.Vector2(mX + originPos.x, mY - originPos.z);
1663
+ var sBounding = item3D.children[0].userData;
1664
+ var swidth = sBounding.max.x - sBounding.min.x;
1665
+ var sdepth = sBounding.max.z - sBounding.min.z;
1666
+ var sVertices = _this2.getRectPoints(swidth, sdepth, tPos.clone(), sRot % 360 / 180 * Math.PI);
1667
+ prepareSnap(layer);
1668
+
1669
+ // calc altitude
1670
+ var altitude = 0;
1671
+ if (allItemRect && allItemRect.cur && allItemRect.cur.itemInfo !== undefined) {
1672
+ var properties = allItemRect.cur.itemInfo.properties;
1673
+ altitude = properties.getIn(['altitude', '_length']);
1674
+ var unit = properties.getIn(['altitude', '_unit']) || 'in';
1675
+ altitude = (0, _convertUnitsLite.convert)(altitude).from(unit).to(_this2.props.state.scene.unit);
1676
+ }
1677
+ // We need to set cam position since when MODE_DRAWING_ITEM_3D mouse down event
1678
+ // is not emited so cam position is not valid
1679
+ gridPlanOrigin = gridPlane.position;
1680
+ gridMatrix.copy(gridPlane.matrixWorld).invert();
1681
+ camPos = camera.position;
1682
+
1683
+ // calc cursor position
1684
+ getPoint(event, altitude);
1685
+ var polygon = _export.GeometryUtils.getPoylgonPoints(layer);
1686
+
1687
+ // if no wall (no area)
1688
+ if (!polygon.length) {
1689
+ // place the item at cursor position
1690
+ actions.itemsActions.updateDraggingItemChanged(Point.x, Point.y, selectedObject.layerID, selectedObject.itemID);
1691
+ return;
1692
+ }
1693
+
1694
+ // calc snap
1695
+ var _GeometryUtils$calcCr = _export.GeometryUtils.calcCreateSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, Point.x, Point.y, polygon),
1696
+ cx = _GeometryUtils$calcCr.cx,
1697
+ cy = _GeometryUtils$calcCr.cy,
1698
+ crot = _GeometryUtils$calcCr.crot,
1699
+ rotRad = _GeometryUtils$calcCr.rotRad;
1700
+ var finalPosition = {
1701
+ x: cx,
1702
+ y: cy,
1703
+ rot: crot,
1704
+ rotRad: rotRad
1705
+ };
1706
+
1707
+ // calc current item rect
1708
+ var itemRect = _objectSpread(_objectSpread({}, allItemRect.cur), {}, {
1709
+ pos: {
1710
+ x: Point.x,
1711
+ y: Point.y
1712
+ }
1713
+ });
1714
+
1715
+ // if cursor position is inside the room
1716
+ if (_export.GeometryUtils.ContainsPoint(polygon, Point.x, Point.y)) {
1717
+ // if cursor position is available to place the item
1718
+ if (_export.GeometryUtils.validRect(itemRect, allRect)) {
1719
+ actions.itemsActions.updateDraggingItemChanged(Point.x, Point.y, selectedObject.layerID, selectedObject.itemID);
1720
+ sPoint.set(Point.x, Point.y);
1721
+ bNormalFlow = false;
1722
+ }
1723
+ } else {
1724
+ // if cursor is outside the room and there is no snap candidate,
1725
+ // then place the item at any free position inside the room.
1726
+ if (!_export.GeometryUtils.ContainsPoint(polygon, cx, cy)) {
1727
+ var points = [];
1728
+ var point = [];
1729
+
1730
+ // rebuild variable to be passed to getCentriodOfPolygon
1731
+ // polygon: [ x0, y0, x1, y1, ... ] ==> points: [[x0, y0], [x1, y1], ...]
1732
+ polygon === null || polygon === void 0 || polygon.forEach(function (value, index) {
1733
+ point.push(value);
1734
+ if (index % 2) {
1735
+ points.push(point);
1736
+ point = [];
1737
+ }
1738
+ });
1739
+
1740
+ // calc center position of the room
1741
+ var centerPos = _export.GeometryUtils.getCentroidOfPolygon(points);
1742
+ var itemRect1 = _objectSpread(_objectSpread({}, allItemRect.cur), {}, {
1743
+ pos: {
1744
+ x: centerPos.x,
1745
+ y: centerPos.y
1746
+ }
1747
+ });
1748
+ var itemRect2 = _objectSpread(_objectSpread({}, allItemRect.cur), {}, {
1749
+ pos: {
1750
+ x: centerPos.x,
1751
+ y: centerPos.y
1752
+ },
1753
+ rotRad: allItemRect.cur.rotRad + Math.PI / 2
1754
+ });
1755
+
1756
+ // find a free position in the room
1757
+ if (_export.GeometryUtils.validRect(itemRect1, allRect)) {
1758
+ actions.itemsActions.updateDraggingItemChanged(centerPos.x, centerPos.y, selectedObject.layerID, selectedObject.itemID);
1759
+ sPoint.set(centerPos.x, centerPos.y);
1760
+ bNormalFlow = false;
1761
+ } else if (_export.GeometryUtils.validRect(itemRect2, allRect)) {
1762
+ finalPosition = {
1763
+ x: centerPos.x,
1764
+ y: centerPos.y,
1765
+ rotRad: itemRect2.rotRad,
1766
+ rot: itemRect2.rotRad / Math.PI * 180
1767
+ };
1768
+ sPoint.set(centerPos.x, centerPos.y);
1769
+ }
1770
+ }
1771
+ }
1772
+ var nPos = new Three.Vector2(cx, cy);
1773
+ if (!_this2.collisionHoleCheck(item3D, nPos, item.rotation, {
1774
+ userData: {
1775
+ itemId: null
1776
+ }
1777
+ }, item, _this2.context.catalog)) {
1778
+ _this2.collisionSlide(item3D, originPos, layer, sVertices, tPos, item);
1779
+ }
1780
+ itemRect = _objectSpread(_objectSpread({}, allItemRect.cur), {}, {
1781
+ pos: {
1782
+ x: finalPosition.x,
1783
+ y: finalPosition.y
1784
+ },
1785
+ rotRad: finalPosition.rotRad
1786
+ });
1787
+
1788
+ // if the room is fullfilled with items or can't calc snap correctly
1789
+ if (!_export.GeometryUtils.validRect(itemRect, allRect)) {
1790
+ // then place the item at cursor position
1791
+ actions.itemsActions.updateDraggingItemChanged(Point.x, Point.y, selectedObject.layerID, selectedObject.itemID);
1792
+ sPoint.set(Point.x, Point.y);
1793
+ bNormalFlow = false;
1794
+ }
1795
+ if (bNormalFlow) {
1796
+ actions.itemsActions.updateDraggingItemChanged(finalPosition.x, finalPosition.y, selectedObject.layerID, selectedObject.itemID);
1797
+ actions.itemsActions.updateRotatingItemChanged(finalPosition.rot, selectedObject.layerID, selectedObject.itemID);
1798
+ sPoint.set(finalPosition.x, finalPosition.y);
1799
+ }
1800
+ isInitialPhase = false;
1801
+ _this2.handleAfterMovingItem();
1802
+ };
1803
+ this.mouseMoveEvent = function (event) {
1804
+ event.preventDefault();
1805
+ backsplashVisible = false;
1806
+ var altitude = 0;
1807
+ if (allItemRect && allItemRect.cur && allItemRect.cur.itemInfo !== undefined) {
1808
+ var properties = allItemRect.cur.itemInfo.properties;
1809
+ altitude = properties.getIn(['altitude', '_length']);
1810
+ var unit = properties.getIn(['altitude', '_unit']) || 'in';
1811
+ altitude = (0, _convertUnitsLite.convert)(altitude).from(unit).to(_this2.props.state.scene.unit);
1812
+ }
1813
+ if (_this2.props.state.mode === _constants.MODE_DRAWING_HOLE_3D) {
1814
+ gridPlanOrigin = gridPlane.position;
1815
+ gridMatrix.copy(gridPlane.matrixWorld).invert();
1816
+ camPos = camera.position;
1817
+ if (!getIntersectWallPoint(event)) return;
1818
+ var drawingSupport = _this2.props.state.drawingSupport;
1819
+ if (!drawingSupport.has('currentID')) {
1820
+ _this2.context.holesActions.updateDrawingHole3D(_this2.props.state.scene.selectedLayer, Point.x, Point.y);
1821
+ sPoint.set(Point.x, Point.y);
1822
+ } else {
1823
+ var layerID = _this2.props.state.scene.selectedLayer;
1824
+ var holeID = _this2.props.state.drawingSupport.get('currentID');
1825
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('WarningBox' + holeID);
1826
+ prepareSnap(layer);
1827
+
1828
+ // let {nx, ny, rot} = GeometryUtils.calcSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, Point.x, Point.y, allArea);
1829
+ var nx = Point.x;
1830
+ var ny = Point.y;
1831
+ actions.holesActions.updateDrawingHole3D(layerID, nx, ny);
1832
+ sPoint.set(nx, ny);
1833
+ }
1834
+ }
1835
+ if (_this2.props.state.mode === _constants.MODE_DRAWING_ITEM_3D) {
1836
+ // We need to set cam position since when MODE_DRAWING_ITEM_3D mouse down event
1837
+ // is not emited so cam position is not valid
1838
+ gridPlanOrigin = gridPlane.position;
1839
+ gridMatrix.copy(gridPlane.matrixWorld).invert();
1840
+ camPos = camera.position;
1841
+ getPoint(event, altitude);
1842
+ if (Point.x > _this2.props.state.scene.width || Point.x < 0 || Point.y > _this2.props.state.scene.height || Point.y < 0) return;
1843
+ _this2.getSelectedObject();
1844
+ var _drawingSupport = _this2.props.state.drawingSupport;
1845
+ if (!_drawingSupport.has('currentID')) {
1846
+ _this2.context.itemsActions.updateDrawingItem(selectedObject.layerID, Point.x, Point.y);
1847
+ sPoint.set(Point.x, Point.y);
1848
+ } else {
1849
+ var mX = Point.x - sPoint.x;
1850
+ var mY = Point.y - sPoint.y;
1851
+ var _layer = _this2.props.state.scene.getIn(['layers', selectedObject.layerID]);
1852
+ var item3D = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1853
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('TransformBox');
1854
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('WarningBox' + selectedObject.itemID);
1855
+ var item = _layer.getIn(['items', selectedObject.itemID]);
1856
+ if (!item3D || !item) return;
1857
+ if (item.counterTop.uri == '') item.counterTop.uri = _layer.counterTop.uri;
1858
+ var sRot = item.rotation;
1859
+ var originPos = item3D.position.clone();
1860
+ var tPos = new Three.Vector2(mX + originPos.x, mY - originPos.z);
1861
+ var sBounding = item3D.children[0].userData;
1862
+ var swidth = sBounding.max.x - sBounding.min.x;
1863
+ var sdepth = sBounding.max.z - sBounding.min.z;
1864
+ var sVertices = _this2.getRectPoints(swidth, sdepth, tPos.clone(), sRot % 360 / 180 * Math.PI);
1865
+ prepareSnap(_layer);
1866
+ var _GeometryUtils$calcSn = _export.GeometryUtils.calcSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, Point.x, Point.y, allArea),
1867
+ _nx = _GeometryUtils$calcSn.nx,
1868
+ _ny = _GeometryUtils$calcSn.ny,
1869
+ rot = _GeometryUtils$calcSn.rot;
1870
+ var nPos = new Three.Vector2(_nx, _ny);
1871
+ if (!_this2.collisionHoleCheck(item3D, nPos, item.rotation, {
1872
+ userData: {
1873
+ itemId: null
1874
+ }
1875
+ }, item, _this2.context.catalog)) {
1876
+ _this2.collisionSlide(item3D, originPos, _layer, sVertices, tPos, item);
1877
+ }
1878
+ var polygonPoint = _export.GeometryUtils.getPoylgonPoints(_layer);
1879
+ if (polygonPoint.length > 0) {
1880
+ var PolygonSect = _export.GeometryUtils.ContainsPoint(polygonPoint, _nx, _ny);
1881
+ if (!PolygonSect) {
1882
+ var _GeometryUtils$calcCr2 = _export.GeometryUtils.calcCreateSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, Point.x, Point.y, polygonPoint),
1883
+ cx = _GeometryUtils$calcCr2.cx,
1884
+ cy = _GeometryUtils$calcCr2.cy,
1885
+ crot = _GeometryUtils$calcCr2.crot;
1886
+ _nx = cx;
1887
+ _ny = cy;
1888
+ rot = crot;
1889
+ }
1890
+ }
1891
+ if (polygonPoint.length > 0) {
1892
+ var isSect = _export.GeometryUtils.ContainsPoint(polygonPoint, _nx, _ny);
1893
+ if (!isSect) return;
1894
+ }
1895
+ actions.itemsActions.updateDraggingItemChanged(_nx, _ny, selectedObject.layerID, selectedObject.itemID);
1896
+ actions.itemsActions.updateRotatingItemChanged(rot, selectedObject.layerID, selectedObject.itemID);
1897
+ sPoint.set(_nx, _ny);
1898
+ _this2.handleAfterMovingItem();
1899
+ }
1900
+ }
1901
+ if (bRotate) {
1902
+ getPoint(event, altitude);
1903
+ _this2.context.itemsActions.updateRotatingItem(Point.x, Point.y);
1904
+ var _layer2 = _this2.props.state.scene.getIn(['layers', selectedObject.layerID]);
1905
+ var _item4 = _layer2.items.getIn([selectedObject.itemID]);
1906
+ var orginRot = _this2.props.state.rotatingSupport.get('originRotation');
1907
+ angleTexture.image = createAngleObject((orginRot < 0 ? 360 - orginRot : orginRot) - _item4.rotation);
1908
+ angleTexture.needsUpdate = true;
1909
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('WarningBox' + selectedObject.itemID);
1910
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('backsplash' + selectedObject.itemID);
1911
+ actions.sceneActions.updateMovingState(false);
1912
+ }
1913
+ if (bMoveUP) {
1914
+ _this2.context.itemsActions.updateItemsAltitude(selectedObject.layerID, selectedObject.itemID, event.movementY);
1915
+ }
1916
+ if (bMove) {
1917
+ if ('holeID' in selectedObject) {
1918
+ gridPlanOrigin = gridPlane.position;
1919
+ gridMatrix.copy(gridPlane.matrixWorld).invert();
1920
+ camPos = camera.position;
1921
+ if (!getIntersectWallPoint(event)) return;
1922
+ var draggingSupport = _this2.props.state.draggingSupport;
1923
+ if (!draggingSupport.has('currentID')) {
1924
+ _this2.context.holesActions.updateDraggingHole(Point.x, Point.y);
1925
+ sPoint.set(Point.x, Point.y);
1926
+ } else {
1927
+ var _holeID = _this2.props.state.draggingSupport.get('currentID');
1928
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('WarningBox' + _holeID);
1929
+ var _nx2 = Point.x;
1930
+ var _ny2 = Point.y;
1931
+ actions.holesActions.updateDraggingHole(_nx2, _ny2);
1932
+ sPoint.set(_nx2, _ny2);
1933
+ }
1934
+ } else {
1935
+ var _item3D2 = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
1936
+ if (_item3D2 === undefined) return;
1937
+ var _layer3 = _this2.props.state.scene.getIn(['layers', _item3D2.userData.layerId]);
1938
+ var _item5 = _layer3.items.getIn([selectedObject.itemID]);
1939
+ if (_item5.counterTop.uri == '') _item5.counterTop.uri = _layer3.counterTop.uri;
1940
+ var _sRot2 = _item5.rotation;
1941
+ var _mX = Point.x - sPoint.x;
1942
+ var _mY = Point.y - sPoint.y;
1943
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('WarningBox' + selectedObject.itemID);
1944
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('backsplash' + selectedObject.itemID);
1945
+ prepareSnap(_layer3);
1946
+ getPoint(event, altitude);
1947
+ var _originPos = _item3D2.position.clone();
1948
+ var _tPos4 = new Three.Vector2(_mX + _originPos.x, _mY - _originPos.z);
1949
+ var _sBounding2 = _item3D2.children[0].userData;
1950
+ var _swidth = _sBounding2.max.x - _sBounding2.min.x;
1951
+ var _sdepth = _sBounding2.max.z - _sBounding2.min.z;
1952
+ var _sVertices = _this2.getRectPoints(_swidth, _sdepth, _tPos4.clone(), _sRot2 % 360 / 180 * Math.PI);
1953
+ var _GeometryUtils$calcSn2 = _export.GeometryUtils.calcSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, Point.x, Point.y, allArea),
1954
+ _nx3 = _GeometryUtils$calcSn2.nx,
1955
+ _ny3 = _GeometryUtils$calcSn2.ny,
1956
+ _rot = _GeometryUtils$calcSn2.rot;
1957
+ var _nPos = new Three.Vector2(_nx3, _ny3);
1958
+ if (!_this2.collisionHoleCheck(_item3D2, _nPos, _item5.rotation, {
1959
+ userData: {
1960
+ itemId: null
1961
+ }
1962
+ }, _item5, _this2.context.catalog)) {
1963
+ _this2.collisionSlide(_item3D2, _originPos, _layer3, _sVertices, _tPos4, _item5);
1964
+ //return;
1965
+ }
1966
+ var _polygonPoint = _export.GeometryUtils.getPoylgonPoints(_layer3);
1967
+ if (_polygonPoint.length > 0) {
1968
+ var _PolygonSect = _export.GeometryUtils.ContainsPoint(_polygonPoint, _nx3, _ny3);
1969
+ if (!_PolygonSect) {
1970
+ var _GeometryUtils$calcCr3 = _export.GeometryUtils.calcCreateSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, Point.x, Point.y, _polygonPoint),
1971
+ _cx3 = _GeometryUtils$calcCr3.cx,
1972
+ _cy = _GeometryUtils$calcCr3.cy,
1973
+ _crot = _GeometryUtils$calcCr3.crot;
1974
+ _nx3 = _cx3;
1975
+ _ny3 = _cy;
1976
+ _rot = _crot;
1977
+ }
1978
+ }
1979
+ var polygon = _export.GeometryUtils.getPoylgonPoints(_layer3);
1980
+ if (polygon.length > 0) {
1981
+ var Sect = _export.GeometryUtils.ContainsPoint(polygon, _nx3, _ny3);
1982
+ if (!Sect) return;
1983
+ }
1984
+ actions.itemsActions.updateDraggingItemChanged(_nx3, _ny3, selectedObject.layerID, selectedObject.itemID);
1985
+ actions.itemsActions.updateRotatingItemChanged(_rot, selectedObject.layerID, selectedObject.itemID);
1986
+ sPoint.set(_nx3, _ny3);
1987
+ _this2.handleAfterMovingItem();
1988
+ }
1989
+ }
1990
+ if (!bMove && !bRotate && !bMoveUP) {
1991
+ var curPos = {
1992
+ x: event.offsetX / _this2.width * 2 - 1,
1993
+ y: -(event.offsetY / _this2.height) * 2 + 1
1994
+ };
1995
+ raycaster.setFromCamera(curPos, camera);
1996
+ rayDirection = raycaster.ray.direction;
1997
+ rayDirection = rayDirection.normalize();
1998
+ var meshes = (0, _objectsUtils.getAllMeshes)(toIntersect);
1999
+ var intersects = raycaster.intersectObjects(meshes, true);
2000
+ var _i11;
2001
+ if (intersects.length > 0 && !isNaN(intersects[0].distance)) {
2002
+ for (_i11 = 0; _i11 < intersects.length; _i11++) {
2003
+ if (intersects[_i11].object.name === 'warningObj') break;
2004
+ }
2005
+ if (intersects[_i11] !== undefined) {
2006
+ var distance = Math.sqrt(Math.pow((intersects[_i11].uv.x - 0.5) * 50, 2) + Math.pow((intersects[_i11].uv.y - 0.75) * 100, 2));
2007
+ if (distance <= 20) {
2008
+ var infoPos = {
2009
+ x: 0,
2010
+ y: 0
2011
+ };
2012
+ if (event.offsetY > 150) {
2013
+ infoPos.y = event.offsetY - 60;
2014
+ } else {
2015
+ infoPos.y = event.offsetY + 10;
2016
+ }
2017
+ if (event.offsetX > _this2.width - 650) {
2018
+ infoPos.x = event.offsetX - 650;
2019
+ } else {
2020
+ infoPos.x = event.offsetX;
2021
+ }
2022
+ if (!(0, _helper.isEmpty)(document.getElementById('warning_box_2d'))) {
2023
+ document.getElementById('warning_box_2d').style.display = 'flex';
2024
+ document.getElementById('warning_box_2d').style.top = "".concat(infoPos.y, "px");
2025
+ document.getElementById('warning_box_2d').style.left = "".concat(infoPos.x, "px");
2026
+ return;
2027
+ }
2028
+ }
2029
+ }
2030
+ }
2031
+ }
2032
+ if (!(0, _helper.isEmpty)(document.getElementById('warning_box_2d'))) document.getElementById('warning_box_2d').style.display = 'none';
2033
+ };
2034
+
2035
+ // handle snapBox, distArray, backsplash
2036
+ this.handleAfterMovingItem = function () {
2037
+ var layer = _this2.props.state.scene.getIn(['layers', selectedObject.layerID]);
2038
+ var item3D = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
2039
+ (0, _sceneCreator.getDistances)(layer);
2040
+ var pointArray = [],
2041
+ cnt = 0;
2042
+ pointArray.push([_sceneCreator.fVLine[0].userData.distance, 90]);
2043
+ pointArray.push([_sceneCreator.fVLine[1].userData.distance, -90]);
2044
+ pointArray.push([_sceneCreator.fVLine[2].userData.distance, 180]);
2045
+ pointArray.push([_sceneCreator.fVLine[3].userData.distance, 0]);
2046
+ pointArray.forEach(function (pointElement, index) {
2047
+ if (pointElement[0] == undefined) pointArray[index][0] = 0;
2048
+ });
2049
+ pointArray.forEach(function (pointElement) {
2050
+ if (pointElement[0] == 0) cnt++;
2051
+ });
2052
+ if (cnt == 4 || cnt == 3) {
2053
+ pointArray[0][0] = 100;
2054
+ pointArray[1][0] = 100;
2055
+ }
2056
+ actions.itemsActions.storeDistArray(selectedObject.layerID, selectedObject.itemID, pointArray);
2057
+ var minDis = _sceneCreator.fVLine[0].userData.distance;
2058
+ var snapObj = _sceneCreator.fVLine[0];
2059
+ var iPos = item3D.position.clone();
2060
+ var snapDis = Math.sqrt((iPos.x - targetPoint.x) * (iPos.x - targetPoint.x) + (iPos.z - targetPoint.z) * (iPos.z - targetPoint.z));
2061
+ if (snapDis >= 100 && snapObj != null) {
2062
+ removeSnapBox();
2063
+ backsplashVisible = false;
2064
+ }
2065
+ for (var _i12 = 1; _i12 < _sceneCreator.fVLine.length; _i12++) {
2066
+ if (minDis > _sceneCreator.fVLine[_i12].userData.distance) {
2067
+ minDis = _sceneCreator.fVLine[_i12].userData.distance;
2068
+ snapObj = _sceneCreator.fVLine[_i12];
2069
+ }
2070
+ }
2071
+ if (snapBox == null) {
2072
+ snapFlag = false;
2073
+ }
2074
+ actions.sceneActions.updateMovingState(false);
2075
+ if (minDis < snapDelta && !snapFlag) {
2076
+ _this2.snap(snapObj, layer);
2077
+ snapFlag = true;
2078
+ (0, _sceneCreator.getDistances)(layer, true);
2079
+ var _i13 = 0;
2080
+ for (_i13 = 0; _i13 < _sceneCreator.fVLine.length; _i13++) {
2081
+ if (_sceneCreator.fVLine[_i13].userData.distance < snapDelta) {
2082
+ break;
2083
+ }
2084
+ }
2085
+ if (_i13 === _sceneCreator.fVLine.length) backsplashVisible = false;else backsplashVisible = true;
2086
+ }
2087
+ actions.itemsActions.setBacksplashVisible(selectedObject.itemID, backsplashVisible);
2088
+ };
2089
+ this.onkeydown = function (event) {
2090
+ if (_this2.props.keyDownEnable && !(0, _helper.isElevationView)(state.mode)) {
2091
+ switch (event.keyCode) {
2092
+ case 27:
2093
+ // escape key
2094
+ isSelected = false;
2095
+ _this2.context.projectActions.unselectAll();
2096
+ _this2.context.itemsActions.removeReplacingSupport();
2097
+ _this2.context.itemsActions.setMoveStatus(false);
2098
+ _this2.context.itemsActions.setRotateStatus(false);
2099
+ bMoveUP = false;
2100
+ removeSnapBox();
2101
+ break;
2102
+ case 65:
2103
+ // w (move forward)
2104
+ pivot.rotation.y -= 0.03;
2105
+ break;
2106
+ case 68:
2107
+ // s (move backward)
2108
+ pivot.rotation.y += 0.03;
2109
+ break;
2110
+ case 83:
2111
+ // a (look left)
2112
+ pivot.rotation.x += 0.03;
2113
+ break;
2114
+ case 87:
2115
+ // d (look left)
2116
+ pivot.rotation.x -= 0.03;
2117
+ break;
2118
+ case 37:
2119
+ // left (move forward)
2120
+ planData.plan.position.x += 10;
2121
+ planData.grid.position.x += 10;
2122
+ break;
2123
+ case 38:
2124
+ // Up (move backward)
2125
+ planData.plan.position.y += 10;
2126
+ planData.grid.position.y += 10;
2127
+ break;
2128
+ case 39:
2129
+ // right arrow (look left)
2130
+ planData.plan.position.x -= 10;
2131
+ planData.grid.position.x -= 10;
2132
+ break;
2133
+ case 40:
2134
+ // down arrow (look left)
2135
+ planData.plan.position.y -= 10;
2136
+ planData.grid.position.y -= 10;
2137
+ break;
2138
+ }
2139
+ }
2140
+ };
2141
+ this.handleKeyDown = function (event) {
2142
+ _this2.onkeydown(event);
2143
+ };
2144
+ this.getSelectedObject = function () {
2145
+ var layerID = _this2.props.state.scene.selectedLayer;
2146
+ var itemID = _this2.props.state.drawingSupport.get('currentID');
2147
+ selectedObject = {
2148
+ layerID: layerID,
2149
+ itemID: itemID
2150
+ };
2151
+ };
2152
+
2153
+ // Renderer & Event listener
2154
+
2155
+ this.renderer.setClearColor(new Three.Color(SharedStyle.COLORS.white)); // 3D background color
2156
+ this.renderer.setSize(this.width, this.height);
2157
+ if (!this.props.downloadFlag) {
2158
+ this.renderer.domElement.addEventListener('mousedown', this.mouseDownEvent);
2159
+ this.renderer.domElement.addEventListener('mouseup', this.mouseUpEvent);
2160
+ this.renderer.domElement.addEventListener('mouseenter', this.mouseEnterEvent);
2161
+ this.renderer.domElement.addEventListener('mousemove', this.mouseMoveEvent);
2162
+ window.addEventListener('keydown', this.onkeydown);
2163
+ window.SPKeyDown = this.handleKeyDown;
2164
+ window.tDKeyDown = this.handleKeyDown;
2165
+ }
2166
+
2167
+ // Add the output of the renderer to the html element
2168
+ var canvasWrapper = _reactDom["default"].findDOMNode(this.refs.canvasWrapper);
2169
+ canvasWrapper && canvasWrapper.appendChild(this.renderer.domElement);
2170
+
2171
+ //
2172
+
2173
+ if (scene.getIn(['layers', scene.selectedLayer, 'selected', 'items']).size != 0) {
2174
+ // if selected Object
2175
+ isSelected = true;
2176
+ selectedObject.layerID = scene.selectedLayer;
2177
+ selectedObject.itemID = scene.getIn(['layers', scene.selectedLayer, 'selected', 'items']).toJS()[0];
2178
+ setTimeout(function () {
2179
+ try {
2180
+ currentObject = planData.sceneGraph.layers[selectedObject.layerID].items[selectedObject.itemID];
2181
+ if ((0, _util.isUndefined)(currentObject)) return;
2182
+ var selItem = _this2.props.state.scene.layers.get(selectedObject.layerID).items.get(selectedObject.itemID);
2183
+ var itemPos = currentObject.position.clone();
2184
+ toolObj.position.set(planData.plan.position.x + itemPos.x, selItem.category === 'lighting' ? -planData.plan.position.y - selItem.properties.get('height').get('length') : planData.plan.position.y + currentObject.children[0].position.y, planData.plan.position.z + itemPos.z);
2185
+ scene3D.add(toolObj);
2186
+ _this2.setState({
2187
+ toolObj: toolObj
2188
+ });
2189
+ } catch (err) {
2190
+ console.log('selectedObject : ' + JSON.stringify(selectedObject) + '\nError: ' + err);
2191
+ }
2192
+ }, 2000);
2193
+ }
2194
+
2195
+ // Scene functions
2196
+
2197
+ function init() {
2198
+ clock = new Three.Clock();
2199
+ scene3D = new Three.Scene();
2200
+ if ((0, _helper.isElevationView)(state.mode)) scene3D.background = new Three.Color(0xffffff);
2201
+ // change color about v1: 0x8791AB, v2: 0xC2C2C2, v3: 0xC3CADC
2202
+ else scene3D.background = new Three.Color(0xe4ebfe); // change color about v1: 0x8791AB, v2: 0xC2C2C2, v3: 0xC3CADC
2203
+ // scene3D.fog = new Three.Fog(0xC3CADC, 2000, 3500);
2204
+ window.scene3D = scene3D;
2205
+ // Camera
2206
+ if ((0, _helper.isElevationView)(state.mode)) {
2207
+ // In elevation view, set Orthographic camera's position, angle and rotation about selected line
2208
+ var layers = scene.layers;
2209
+ var selectedLayer = layers.get(scene.selectedLayer);
2210
+ var ceilHeight = (0, _convertUnitsLite.convert)(selectedLayer.ceilHeight).from(selectedLayer.unit).to(scene.unit);
2211
+ var lines = [];
2212
+ var selectedLine = selectedLayer.lines.get(selectedLayer.selected.lines.toJS()[0]);
2213
+ var vertex0 = selectedLayer.vertices.get(selectedLine.vertices.get(0));
2214
+ var vertex1 = selectedLayer.vertices.get(selectedLine.vertices.get(1));
2215
+ var x1 = vertex0.x,
2216
+ y1 = vertex0.y;
2217
+ var x2 = vertex1.x,
2218
+ y2 = vertex1.y;
2219
+ if (_export.GeometryUtils.compareVertices(vertex0, vertex1) >= 0 && vertex0.x !== vertex1.x) {
2220
+ x1 = vertex1.x;
2221
+ y1 = vertex1.y;
2222
+ x2 = vertex0.x;
2223
+ y2 = vertex0.y;
2224
+ }
2225
+ selectedLayer.lines.toArray().forEach(function (line) {
2226
+ if (line.id === selectedLine) {
2227
+ var data = line.toJS();
2228
+ data = _objectSpread(_objectSpread({}, data), {}, {
2229
+ l0: {
2230
+ x: x1,
2231
+ y: y1
2232
+ },
2233
+ l1: {
2234
+ x: x2,
2235
+ y: y2
2236
+ }
2237
+ });
2238
+ lines.push(data);
2239
+ }
2240
+ });
2241
+ var lineLength = _export.GeometryUtils.pointsDistance(x1, y1, x2, y2);
2242
+ self.setState({
2243
+ lineLength: lineLength
2244
+ });
2245
+ var cameraRect = (0, _helper.handleCamRect)(self.width, self.height, ceilHeight, lineLength);
2246
+ camera = new Three.OrthographicCamera(-cameraRect.width / 2, cameraRect.width / 2, cameraRect.height / 2, -cameraRect.height / 2, 1, 1000);
2247
+ var angle = Math.atan((y1 - y2) / (x1 - x2));
2248
+ var r = 300;
2249
+ if (Math.abs(angle) === Math.PI / 2) {
2250
+ camera.position.set((x1 + x2) / 2 - Math.sin(angle) * r, ceilHeight / 2, -((y1 + y2) / 2 - Math.cos(angle) * r));
2251
+ camera.rotation.set(0, -angle, 0);
2252
+ } else if (vertex0.x > vertex1.x) {
2253
+ camera.position.set((x1 + x2) / 2 + Math.sin(angle + Math.PI) * r, ceilHeight / 2, -((y1 + y2) / 2 - Math.cos(angle + Math.PI) * r));
2254
+ camera.rotation.set(0, angle + Math.PI, 0);
2255
+ } else {
2256
+ camera.position.set((x1 + x2) / 2 + Math.sin(angle) * r, ceilHeight / 2, -((y1 + y2) / 2 - Math.cos(angle) * r));
2257
+ camera.rotation.set(0, angle, 0);
2258
+ }
2259
+ } else {
2260
+ var aspectRatio = self.width / self.height;
2261
+ camera = new Three.PerspectiveCamera(45, aspectRatio, 1, 300000);
2262
+ camera.position.set(0, 0, 1);
2263
+ }
2264
+ camera.layers.enable(1);
2265
+ function loadENV() {
2266
+ new _RGBELoader.RGBELoader().load('/assets/brown_photostudio_02_1k.hdr', function (texture) {
2267
+ texture.mapping = Three.EquirectangularReflectionMapping;
2268
+ scene3D.environment = texture;
2269
+ texture.dispose();
2270
+ });
2271
+ }
2272
+ // Camera Controls
2273
+ if (!(0, _helper.isElevationView)(state.mode)) {
2274
+ cameraControls = new _cameraControls["default"](camera, self.renderer.domElement);
2275
+ cameraControls.dollyToCursor = true;
2276
+ cameraControls.infinityDolly = true;
2277
+ cameraControls.minDistance = 50;
2278
+ cameraControls.maxDistance = Infinity;
2279
+ cameraControls.zoomSpeed = 1;
2280
+ loadENV();
2281
+ }
2282
+ scene3D.add(planData.plan);
2283
+ scene3D.add(planData.grid);
2284
+ scene3D.add(camera);
2285
+ if ((0, _helper.isElevationView)(state.mode)) {
2286
+ planData.cam.add(camera);
2287
+ scene3D.add(planData.cam);
2288
+ } else {
2289
+ pivot = new Three.Object3D();
2290
+ pivot.add(camera);
2291
+ scene3D.add(pivot);
2292
+ }
2293
+
2294
+ // LIGHT
2295
+
2296
+ var light = new Three.AmbientLight(0xbfbfbf, 0.9); // soft white light
2297
+ }
2298
+ function render() {
2299
+ var delta = clock.getDelta(); // Get time delta for smooth updates
2300
+ if (!(0, _helper.isElevationView)(state.mode)) cameraControls.update(delta);
2301
+ for (var _i14 = 0; _i14 < lights.length; _i14++) {
2302
+ lights[_i14].light.position.set(planData.plan.position.x + lights[_i14].x, planData.plan.position.y + lights[_i14].height - 10, planData.plan.position.z - lights[_i14].y);
2303
+ lights[_i14].target.position.set(planData.plan.position.x + lights[_i14].x, planData.plan.position.y, planData.plan.position.z - lights[_i14].y);
2304
+ }
2305
+ camera.updateMatrix();
2306
+ camera.updateMatrixWorld();
2307
+ for (var elemID in planData.sceneGraph.LODs) {
2308
+ planData.sceneGraph.LODs[elemID].update(camera);
2309
+ }
2310
+ if (snapBox !== null) {
2311
+ if (snapAnimI >= 15) {
2312
+ if ('x' in targetPoint) snapBox.position.set(targetPoint.x, snapBox.position.y, targetPoint.z);
2313
+ snapFlag = false;
2314
+ t_i++;
2315
+ } else {
2316
+ if (snapAnimI == 0) {
2317
+ targetCRotation = (targetRot / 180 * Math.PI - snapBox.rotation.y + Math.PI) * 180 / Math.PI % 360;
2318
+ if (targetCRotation > 180) targetCRotation -= 360;
2319
+ if (targetCRotation < -180) targetCRotation += 360;
2320
+ targetCRotation = targetCRotation / 180 * Math.PI;
2321
+ }
2322
+ if (snapAnimI < 10) {
2323
+ snapBox.rotateY(targetCRotation / 10);
2324
+ } else {
2325
+ snapBox.position.set(snapBox.position.clone().x - targetUVec.x / 10, snapBox.position.clone().y - targetUVec.y / 10, snapBox.position.clone().z - targetUVec.z / 10);
2326
+ }
2327
+ snapAnimI++;
2328
+ }
2329
+ }
2330
+ if (t_i === 20) {
2331
+ //stop snap after 5s
2332
+ removeSnapBox();
2333
+ }
2334
+
2335
+ // hide hole if wall is not visible
2336
+ var layerID = self.props.state.scene.selectedLayer;
2337
+ var layer = self.props.state.scene.layers.get(layerID);
2338
+ layer.holes.forEach(function (data) {
2339
+ var line = planData.sceneGraph.layers[layerID].lines[data.line];
2340
+ var hole = planData.sceneGraph.layers[layerID].holes[data.id];
2341
+ if (line instanceof Three.Object3D && !line.isMesh) {
2342
+ line = line.children[0].children[0];
2343
+ // index(faces) of the line
2344
+ var indexAttribute = line.geometry.getIndex();
2345
+ var firstFaceIndices = undefined;
2346
+ if (indexAttribute && indexAttribute.length > 0) {
2347
+ [indexAttribute.getX(0), indexAttribute.getX(1), indexAttribute.getX(2)], (0, _readOnlyError2["default"])("firstFaceIndices");
2348
+ }
2349
+ if (firstFaceIndices == undefined) return;
2350
+ // normal vector of the line
2351
+ var normalAttribute = line.geometry.attributes.normal;
2352
+ var normal = new Three.Vector3().fromBufferAttribute(normalAttribute, 0).clone();
2353
+ normal = normal.applyMatrix4(line.matrixWorld).sub(new Three.Vector3(0, 0, 0).applyMatrix4(line.matrixWorld)).normalize();
2354
+ var vertices = layer.lines.get(data.line).vertices.toJS();
2355
+ var vertex1 = layer.vertices.get(vertices[0]);
2356
+ var vertex2 = layer.vertices.get(vertices[1]);
2357
+ var cX = (vertex1.x + vertex2.x) / 2;
2358
+ var cY = (vertex1.y + vertex2.y) / 2;
2359
+ var posVec = new Three.Vector3(cX, 150, -cY);
2360
+ posVec = posVec.add(planData.plan.position.clone());
2361
+ var cameraLine = camera.position.clone().sub(posVec);
2362
+ if (hole) {
2363
+ hole.traverse(function (child) {
2364
+ if (child.isMesh) {
2365
+ child.material.opacity = cameraLine.dot(normal) > 0 ? 1 : 0;
2366
+ child.material.transparent = cameraLine.dot(normal) > 0 ? false : true;
2367
+ child.material.needsUpdate = true;
2368
+ }
2369
+ });
2370
+ }
2371
+ }
2372
+ // /////////////////////////////////////
2373
+ });
2374
+ if (scene3D && camera) {
2375
+ if (planData.elevationGroup) {
2376
+ planData.elevationGroup.visible = true;
2377
+ self.renderer.render(scene3D, camera);
2378
+ self.renderer.autoClearDepth = false;
2379
+ planData.elevationGroup.visible = false;
2380
+ // console.log('---originalScene:', scene3D)
2381
+ self.renderer.render(scene3D, camera);
2382
+ self.renderer.autoClearDepth = true;
2383
+ } else {
2384
+ self.renderer.render(scene3D, camera);
2385
+ }
2386
+ }
2387
+ self.renderingID = requestAnimationFrame(render);
2388
+ if (self.props.downloadFlag) {
2389
+ if (self.state.waitForRender > 0) {
2390
+ self.state.waitForRender++;
2391
+ if (self.state.waitForRender > 2) {
2392
+ self.setState({
2393
+ isLoading: false,
2394
+ waitForRender: 0
2395
+ });
2396
+ if ((0, _helper.isElevationView)(self.props.state.mode)) {
2397
+ setTimeout(function () {
2398
+ self.props.setIsLoadingElevation('front', false);
2399
+ }, 100);
2400
+ }
2401
+ self.renderer.domElement.style.display = 'block';
2402
+ }
2403
+ }
2404
+ }
2405
+ }
2406
+
2407
+ //
2408
+
2409
+ window.planData = planData;
2410
+ this.planData = planData;
2411
+ this.camera = camera;
2412
+ this.cameraControls = cameraControls;
2413
+ this.scene3D = scene3D;
2414
+ prepareSnap(layer);
2415
+ }
2416
+ }, {
2417
+ key: "componentWillUnmount",
2418
+ value: function componentWillUnmount() {
2419
+ cancelAnimationFrame(this.renderingID);
2420
+ if (!(0, _helper.isElevationView)(this.props.state.mode)) {
2421
+ if (this.cameraControls !== undefined) this.cameraControls.dispose();
2422
+ }
2423
+ if (!this.props.downloadFlag) {
2424
+ this.renderer.domElement.removeEventListener('mousedown', this.mouseDownEvent);
2425
+ this.renderer.domElement.removeEventListener('mouseup', this.mouseUpEvent);
2426
+ }
2427
+ (0, _threeMemoryCleaner.disposeScene)(this.scene3D);
2428
+ this.scene3D.remove(this.planData.plan);
2429
+ this.scene3D.remove(this.planData.grid);
2430
+ this.scene3D = null;
2431
+ this.planData = null;
2432
+ this.camera = null;
2433
+ this.cameraControls = null;
2434
+ this.renderer.renderLists.dispose();
2435
+ }
2436
+ }, {
2437
+ key: "componentWillReceiveProps",
2438
+ value: function componentWillReceiveProps(nextProps) {
2439
+ var _this4 = this;
2440
+ if (this.props.downloadFlag && (0, _immutablediff["default"])(this.props.state, nextProps.state).toJS().length == 0 || (0, _helper.isEmpty)(nextProps.state.scene)) return;
2441
+ var width = nextProps.width,
2442
+ height = nextProps.height;
2443
+ var selectedLayer = nextProps.state.getIn(['scene', 'layers', nextProps.state.scene.selectedLayer]);
2444
+ var ceilHeight = (0, _convertUnitsLite.convert)(selectedLayer.ceilHeight).from(selectedLayer.unit).to(nextProps.state.scene.unit);
2445
+ var actions = {
2446
+ areaActions: this.context.areaActions,
2447
+ holesActions: this.context.holesActions,
2448
+ itemsActions: this.context.itemsActions,
2449
+ sceneActions: this.context.sceneActions,
2450
+ linesActions: this.context.linesActions,
2451
+ projectActions: this.context.projectActions,
2452
+ catalog: this.context.catalog
2453
+ };
2454
+ var isLoadingCabinet = nextProps.state.scene.isLoadingCabinet;
2455
+ if (this.state.isLoadingCabinet !== isLoadingCabinet) this.setState({
2456
+ isLoadingCabinet: isLoadingCabinet
2457
+ });
2458
+ this.width = width;
2459
+ this.height = height;
2460
+ var allLines;
2461
+ var allLineRects;
2462
+ var allItemRect;
2463
+
2464
+ // handle camera setting
2465
+ switch (this.props.state.mode) {
2466
+ case _constants.MODE_ELEVATION_VIEW:
2467
+ // when Elevation mode (camera: Orthographic)
2468
+ var cameraRect = (0, _helper.handleCamRect)(width, height, ceilHeight, this.state.lineLength);
2469
+ // camera size
2470
+ this.camera.left = -cameraRect.width / 2;
2471
+ this.camera.right = cameraRect.width / 2;
2472
+ this.camera.top = cameraRect.height / 2;
2473
+ this.camera.bottom = -cameraRect.height / 2;
2474
+ //camera position
2475
+ this.camera.position.y = ceilHeight / 2;
2476
+ break;
2477
+ case _constants.MODE_3D_VIEW:
2478
+ // when 3D mode (camera: Perspective)
2479
+ this.camera.aspect = width / height;
2480
+ break;
2481
+ }
2482
+ this.camera.updateProjectionMatrix();
2483
+ var data = nextProps.state.scene;
2484
+ var layer = data.getIn(['layers', data.selectedLayer]);
2485
+ var self = this;
2486
+ function implementBacksplash() {
2487
+ if ((0, _helper.isElevationView)(self.props.state.mode)) return; // apply backsplash when just 3D_mode, not elevation_mode
2488
+ var allItems = _export.GeometryUtils.getAllItemSpecified(nextProps.state.scene, actions.catalog, _constants.BASE_CABINET_LAYOUTPOS);
2489
+ var i,
2490
+ items = [];
2491
+ for (i = 0; i < allItems.others.length; i++) items.push(allItems.others[i]);
2492
+ if (allItems.cur) items.push(allItems.cur);
2493
+ for (i = 0; i < items.length; i++) {
2494
+ var calcRect = _export.GeometryUtils.getCalcRectFromItem3D(items[i]);
2495
+ var visible = _export.GeometryUtils.isSnappedLine(calcRect, allLineRects);
2496
+ actions.itemsActions.setBacksplashVisible(items[i].itemInfo.id, visible);
2497
+ (0, _sceneCreator.createBacksplash)(items[i], nextProps.state.scene.getIn(['layers', nextProps.state.scene.selectedLayer]), planData, nextProps.state.scene);
2498
+ }
2499
+ }
2500
+ function implementWarningBox() {
2501
+ var holeItems = _export.GeometryUtils.getHoleItems(layer);
2502
+ var i,
2503
+ items = [];
2504
+ for (i = 0; i < allItemRect.others.length; i++) items.push(allItemRect.others[i]);
2505
+ if (allItemRect.cur) items.push(allItemRect.cur);
2506
+ for (i = 0; i < items.length; i++) (0, _sceneCreator.checkCabinetOverlap)({
2507
+ x: items[i].pos.x,
2508
+ y: items[i].pos.y
2509
+ }, items[i], holeItems, planData);
2510
+ }
2511
+ var prepareSnapSpec = function prepareSnapSpec(layer) {
2512
+ allLines = _export.GeometryUtils.getAllLines(layer);
2513
+ allLineRects = _export.GeometryUtils.buildRectFromLines(layer, allLines);
2514
+ allItemRect = _export.GeometryUtils.getAllItemSpecified(_this4.props.state.scene, actions.catalog, [_constants.WALL_CABINET_LAYOUTPOS, _constants.TALL_CABINET_LAYOUTPOS]);
2515
+ };
2516
+ var layer1 = this.props.state.scene.getIn(['layers', data.selectedLayer]);
2517
+ if (this.state.showflag) {
2518
+ prepareSnapSpec(layer);
2519
+ implementBacksplash();
2520
+ implementWarningBox();
2521
+ this.setState({
2522
+ showflag: false
2523
+ });
2524
+ }
2525
+ if (nextProps.state.scene !== this.props.state.scene || nextProps.state.doorStyle && nextProps.state.doorStyle.get('name') !== this.props.state.doorStyle.get('name')) {
2526
+ var changedValues = (0, _immutablediff["default"])(this.props.state.scene, nextProps.state.scene);
2527
+ prepareSnapSpec(layer);
2528
+ if (nextProps.state.doorStyle && nextProps.state.doorStyle.get('name') === this.props.state.doorStyle.get('name')) {
2529
+ self.setState({
2530
+ isLoading: true
2531
+ });
2532
+ if (self.props.downloadFlag) {
2533
+ self.setState({
2534
+ waitForRender: 0
2535
+ });
2536
+ switch (self.props.state.mode) {
2537
+ case _constants.MODE_ELEVATION_VIEW:
2538
+ self.props.setIsLoadingElevation('front', true);
2539
+ break;
2540
+ case _constants.MODE_3D_VIEW:
2541
+ self.props.setIsLoading3D(true);
2542
+ break;
2543
+ }
2544
+ }
2545
+ self.renderer.domElement.style.display = 'none';
2546
+ }
2547
+ if (nextProps.state.scene.showfg == true) {
2548
+ implementBacksplash();
2549
+ implementWarningBox();
2550
+ } else {
2551
+ (0, _sceneCreator.deleteSpecifiedMeshObjects)('TransformBox');
2552
+ }
2553
+ var _this$state = this.state,
2554
+ toolObj = _this$state.toolObj,
2555
+ angleObj = _this$state.angleObj;
2556
+ var _updateScene = (0, _sceneCreator.updateScene)(this.planData, nextProps.state.scene, this.props.state.scene, changedValues.toJS(), actions, this.context.catalog, nextProps.state.mode, toolObj, angleObj, nextProps.state.draggingSupport),
2557
+ promise = _updateScene.promise;
2558
+ self.setState();
2559
+ promise.then(function (p1Value) {
2560
+ self.setState({
2561
+ isLoading: false
2562
+ });
2563
+ self.props.downloadFlag && self.setState({
2564
+ waitForRender: 1
2565
+ });
2566
+ self.renderer.domElement.style.display = 'block';
2567
+ });
2568
+ if (nextProps.state.getIn(['scene', 'isEndDragging'])) {
2569
+ nextProps.state.setIn(['scene', 'isEndDragging'], false);
2570
+ }
2571
+ }
2572
+ this.renderer.setSize(width, height);
2573
+ }
2574
+ }, {
2575
+ key: "render",
2576
+ value: function render() {
2577
+ var _this$state2 = this.state,
2578
+ isLoading = _this$state2.isLoading,
2579
+ isLoadingCabinet = _this$state2.isLoadingCabinet;
2580
+ if (isLoading) {
2581
+ if (this.props.downloadFlag) {
2582
+ this.renderer.domElement.style.display = 'none';
2583
+ return /*#__PURE__*/_react["default"].createElement("div", {
2584
+ style: {
2585
+ alignItems: ' center',
2586
+ width: this.props.width,
2587
+ height: this.props.height,
2588
+ display: 'inline-flex',
2589
+ justifyContent: 'center'
2590
+ }
2591
+ }, /*#__PURE__*/_react["default"].createElement("img", {
2592
+ style: {
2593
+ width: '70px',
2594
+ height: '70px',
2595
+ animation: 'spin 2s linear infinite'
2596
+ },
2597
+ src: '/assets/img/loading_large.gif',
2598
+ alt: "img"
2599
+ }));
2600
+ } else {
2601
+ document.getElementById('front') && (document.getElementById('front').style.display = 'none');
2602
+ this.renderer.domElement.style.display = 'none';
2603
+ return /*#__PURE__*/_react["default"].createElement("div", {
2604
+ style: {
2605
+ textAlign: 'center',
2606
+ width: '100%'
2607
+ }
2608
+ }, /*#__PURE__*/_react["default"].createElement("img", {
2609
+ style: {
2610
+ animation: 'spin 2s linear infinite',
2611
+ marginTop: "22%"
2612
+ },
2613
+ src: '/assets/img/loading_large.gif',
2614
+ alt: "img"
2615
+ }));
2616
+ }
2617
+ } else if (isLoadingCabinet) {
2618
+ this.renderer.domElement.style.pointerEvents = 'none';
2619
+ document.getElementById('front') && (document.getElementById('front').style.display = 'none');
2620
+ this.renderer.domElement.style.opacity = '0.4';
2621
+ return /*#__PURE__*/_react["default"].createElement("div", {
2622
+ style: {
2623
+ textAlign: 'center',
2624
+ width: '100%'
2625
+ }
2626
+ }, /*#__PURE__*/_react["default"].createElement("img", {
2627
+ style: {
2628
+ animation: 'spin 2s linear infinite',
2629
+ position: "absolute",
2630
+ top: "50%"
2631
+ },
2632
+ src: '/assets/img/loading_large.gif',
2633
+ alt: "img"
2634
+ }));
2635
+ } else {
2636
+ this.renderer.domElement.style.pointerEvents = 'auto';
2637
+ this.renderer.domElement.style.opacity = '1';
2638
+ !this.props.downloadFlag && document.getElementById('front') && (document.getElementById('front').style.display = 'block');
2639
+ return /*#__PURE__*/_react["default"].createElement('div', {
2640
+ ref: 'canvasWrapper'
2641
+ });
2642
+ }
2643
+ }
2644
+ }]);
2645
+ }(_react["default"].Component);
2646
+ Scene3DViewer.propTypes = {
2647
+ state: _propTypes["default"].object.isRequired,
2648
+ width: _propTypes["default"].number.isRequired,
2649
+ height: _propTypes["default"].number.isRequired,
2650
+ replaceCabinet: _propTypes["default"].func.isRequired
2651
+ };
2652
+ Scene3DViewer.contextTypes = {
2653
+ areaActions: _propTypes["default"].object.isRequired,
2654
+ holesActions: _propTypes["default"].object.isRequired,
2655
+ itemsActions: _propTypes["default"].object.isRequired,
2656
+ linesActions: _propTypes["default"].object.isRequired,
2657
+ sceneActions: _propTypes["default"].object.isRequired,
2658
+ projectActions: _propTypes["default"].object.isRequired,
2659
+ catalog: _propTypes["default"].object
2660
+ };
2661
+ module.exports = exports.default;