kitchen-simulator 1.1.1-test.49 → 1.1.1-test.50

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 (358) hide show
  1. package/es/@history.js +2 -0
  2. package/es/AppContext.js +3 -0
  3. package/es/KitchenConfigurator.js +645 -0
  4. package/es/KitchenConfiguratorApp.js +480 -0
  5. package/es/actions/area-actions.js +14 -0
  6. package/es/actions/export.js +23 -0
  7. package/es/actions/groups-actions.js +89 -0
  8. package/es/actions/holes-actions.js +119 -0
  9. package/es/actions/items-actions.js +313 -0
  10. package/es/actions/lines-actions.js +81 -0
  11. package/es/actions/project-actions.js +281 -0
  12. package/es/actions/scene-actions.js +33 -0
  13. package/es/actions/vertices-actions.js +27 -0
  14. package/es/actions/viewer2d-actions.js +58 -0
  15. package/es/actions/viewer3d-actions.js +23 -0
  16. package/es/catalog/areas/area/planner-element.js +40 -0
  17. package/es/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  18. package/es/catalog/areas/area/textures/grass.jpg +0 -0
  19. package/es/catalog/areas/area/textures/parquet.jpg +0 -0
  20. package/es/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  21. package/es/catalog/areas/area/textures/tile1.jpg +0 -0
  22. package/es/catalog/catalog.js +277 -0
  23. package/es/catalog/envMap/nx.hdr +0 -0
  24. package/es/catalog/envMap/ny.hdr +0 -0
  25. package/es/catalog/envMap/nz.hdr +0 -0
  26. package/es/catalog/envMap/px.hdr +0 -0
  27. package/es/catalog/envMap/py.hdr +0 -0
  28. package/es/catalog/envMap/pz.hdr +0 -0
  29. package/es/catalog/factories/area-factory-3d.js +181 -0
  30. package/es/catalog/factories/area-factory.js +81 -0
  31. package/es/catalog/factories/export.js +7 -0
  32. package/es/catalog/factories/wall-factory-3d.js +202 -0
  33. package/es/catalog/factories/wall-factory.js +268 -0
  34. package/es/catalog/holes/door-closet/planner-element.js +222 -0
  35. package/es/catalog/holes/door-double/door_double.png +0 -0
  36. package/es/catalog/holes/door-double/planner-element.js +315 -0
  37. package/es/catalog/holes/door-exterior/planner-element.js +215 -0
  38. package/es/catalog/holes/door-interior/planner-element.js +227 -0
  39. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  40. package/es/catalog/holes/door-panic/planner-element.js +503 -0
  41. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  42. package/es/catalog/holes/door-panic-double/planner-element.js +463 -0
  43. package/es/catalog/holes/door-sliding/planner-element.js +225 -0
  44. package/es/catalog/holes/doorway-framed/planner-element.js +145 -0
  45. package/es/catalog/holes/doorway-frameless/planner-element.js +104 -0
  46. package/es/catalog/holes/export.js +13 -0
  47. package/es/catalog/holes/gate/gate.jpg +0 -0
  48. package/es/catalog/holes/window-clear/planner-element.js +166 -0
  49. package/es/catalog/holes/window-clear/texture.png +0 -0
  50. package/es/catalog/holes/window-cross/planner-element.js +165 -0
  51. package/es/catalog/holes/window-cross/texture.png +0 -0
  52. package/es/catalog/holes/window-double-hung/planner-element.js +303 -0
  53. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  54. package/es/catalog/holes/window-vertical/planner-element.js +276 -0
  55. package/es/catalog/holes/window-vertical/texture.png +0 -0
  56. package/es/catalog/lines/wall/planner-element.js +70 -0
  57. package/es/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  58. package/es/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
  59. package/es/catalog/lines/wall/textures/bricks.jpg +0 -0
  60. package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
  61. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  62. package/es/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  63. package/es/catalog/lines/wall/textures/morden.jpg +0 -0
  64. package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
  65. package/es/catalog/lines/wall/textures/painted.jpg +0 -0
  66. package/es/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  67. package/es/catalog/lines/wall/textures/plaster.jpg +0 -0
  68. package/es/catalog/lines/wall/wall.png +0 -0
  69. package/es/catalog/molding/molding-dcm/planner-element.js +28 -0
  70. package/es/catalog/molding/molding-dcm/texture.png +0 -0
  71. package/es/catalog/molding/molding-fbm/planner-element.js +28 -0
  72. package/es/catalog/molding/molding-fbm/texture.png +0 -0
  73. package/es/catalog/molding/molding-lrm/planner-element.js +28 -0
  74. package/es/catalog/molding/molding-lrm/texture.png +0 -0
  75. package/es/catalog/properties/export.js +21 -0
  76. package/es/catalog/properties/property-checkbox.js +116 -0
  77. package/es/catalog/properties/property-color.js +39 -0
  78. package/es/catalog/properties/property-enum.js +97 -0
  79. package/es/catalog/properties/property-hidden.js +19 -0
  80. package/es/catalog/properties/property-lenght-measure.js +101 -0
  81. package/es/catalog/properties/property-length-measure.js +134 -0
  82. package/es/catalog/properties/property-length-measure_hole.js +101 -0
  83. package/es/catalog/properties/property-number.js +48 -0
  84. package/es/catalog/properties/property-read-only.js +26 -0
  85. package/es/catalog/properties/property-string.js +48 -0
  86. package/es/catalog/properties/property-toggle.js +39 -0
  87. package/es/catalog/properties/shared-property-style.js +14 -0
  88. package/es/catalog/utils/FuseUtils.js +82 -0
  89. package/es/catalog/utils/exporter.js +148 -0
  90. package/es/catalog/utils/geom-utils.js +189 -0
  91. package/es/catalog/utils/item-loader.js +1521 -0
  92. package/es/catalog/utils/load-obj.js +91 -0
  93. package/es/catalog/utils/mtl-loader.js +358 -0
  94. package/es/catalog/utils/obj-loader.js +477 -0
  95. package/es/class/FuseUtils.js +82 -0
  96. package/es/class/area.js +145 -0
  97. package/es/class/export.js +24 -0
  98. package/es/class/group.js +440 -0
  99. package/es/class/guide.js +62 -0
  100. package/es/class/hole.js +929 -0
  101. package/es/class/item.js +1883 -0
  102. package/es/class/layer.js +667 -0
  103. package/es/class/line.js +1180 -0
  104. package/es/class/project.js +793 -0
  105. package/es/class/vertex.js +202 -0
  106. package/es/components/content.js +107 -0
  107. package/es/components/disclaimer/disclaimer.js +97 -0
  108. package/es/components/export.js +9 -0
  109. package/es/components/style/button.js +113 -0
  110. package/es/components/style/cancel-button.js +22 -0
  111. package/es/components/style/content-container.js +33 -0
  112. package/es/components/style/content-title.js +29 -0
  113. package/es/components/style/delete-button.js +25 -0
  114. package/es/components/style/export.js +31 -0
  115. package/es/components/style/form-block.js +24 -0
  116. package/es/components/style/form-color-input.js +27 -0
  117. package/es/components/style/form-label.js +26 -0
  118. package/es/components/style/form-number-input.js +213 -0
  119. package/es/components/style/form-number-input_2.js +206 -0
  120. package/es/components/style/form-select.js +68 -0
  121. package/es/components/style/form-slider.js +61 -0
  122. package/es/components/style/form-submit-button.js +26 -0
  123. package/es/components/style/form-text-input.js +95 -0
  124. package/es/components/viewer2d/area.js +81 -0
  125. package/es/components/viewer2d/export.js +31 -0
  126. package/es/components/viewer2d/grids/grid-horizontal-streak.js +37 -0
  127. package/es/components/viewer2d/grids/grid-streak.js +37 -0
  128. package/es/components/viewer2d/grids/grid-vertical-streak.js +37 -0
  129. package/es/components/viewer2d/grids/grids.js +35 -0
  130. package/es/components/viewer2d/group.js +53 -0
  131. package/es/components/viewer2d/item.js +513 -0
  132. package/es/components/viewer2d/layer.js +164 -0
  133. package/es/components/viewer2d/line.js +882 -0
  134. package/es/components/viewer2d/ruler.js +100 -0
  135. package/es/components/viewer2d/rulerDist.js +146 -0
  136. package/es/components/viewer2d/rulerX.js +151 -0
  137. package/es/components/viewer2d/rulerY.js +153 -0
  138. package/es/components/viewer2d/scene.js +140 -0
  139. package/es/components/viewer2d/snap.js +74 -0
  140. package/es/components/viewer2d/state.js +78 -0
  141. package/es/components/viewer2d/utils.js +198 -0
  142. package/es/components/viewer2d/vertex.js +65 -0
  143. package/es/components/viewer2d/viewer2d.js +1398 -0
  144. package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +2592 -0
  145. package/es/components/viewer3d/dcm.js +401 -0
  146. package/es/components/viewer3d/fbm.js +414 -0
  147. package/es/components/viewer3d/front3D.js +66 -0
  148. package/es/components/viewer3d/grid-creator.js +25 -0
  149. package/es/components/viewer3d/grids/grid-horizontal-streak.js +36 -0
  150. package/es/components/viewer3d/grids/grid-streak.js +27 -0
  151. package/es/components/viewer3d/grids/grid-vertical-streak.js +36 -0
  152. package/es/components/viewer3d/libs/first-person-controls.js +67 -0
  153. package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +1281 -0
  154. package/es/components/viewer3d/libs/mtl-loader.js +357 -0
  155. package/es/components/viewer3d/libs/obj-loader.js +462 -0
  156. package/es/components/viewer3d/libs/orbit-controls.js +699 -0
  157. package/es/components/viewer3d/libs/pointer-lock-controls.js +46 -0
  158. package/es/components/viewer3d/lrm.js +305 -0
  159. package/es/components/viewer3d/model.js +708 -0
  160. package/es/components/viewer3d/pointer-lock-navigation.js +115 -0
  161. package/es/components/viewer3d/ruler-utils/itemRect.js +61 -0
  162. package/es/components/viewer3d/ruler-utils/layer3D.js +495 -0
  163. package/es/components/viewer3d/ruler-utils/ruler3D.js +227 -0
  164. package/es/components/viewer3d/ruler-utils/scene3D.js +60 -0
  165. package/es/components/viewer3d/ruler-utils/state3D.js +18 -0
  166. package/es/components/viewer3d/scene-creator.js +3608 -0
  167. package/es/components/viewer3d/three-memory-cleaner.js +51 -0
  168. package/es/components/viewer3d/viewer3d-first-person.js +315 -0
  169. package/es/components/viewer3d/viewer3d.js +2527 -0
  170. package/es/constants.js +636 -0
  171. package/es/index.js +16 -0
  172. package/es/models.js +510 -0
  173. package/es/plugins/SVGLoader.js +1412 -0
  174. package/es/plugins/autosave.js +33 -0
  175. package/es/plugins/console-debugger.js +37 -0
  176. package/es/plugins/export.js +9 -0
  177. package/es/plugins/keyboard.js +101 -0
  178. package/es/reducers/areas-reducer.js +12 -0
  179. package/es/reducers/export.js +25 -0
  180. package/es/reducers/groups-reducer.js +38 -0
  181. package/es/reducers/holes-reducer.js +62 -0
  182. package/es/reducers/items-reducer.js +140 -0
  183. package/es/reducers/lines-reducer.js +45 -0
  184. package/es/reducers/project-reducer.js +129 -0
  185. package/es/reducers/reducer.js +19 -0
  186. package/es/reducers/scene-reducer.js +28 -0
  187. package/es/reducers/user-reducer.js +40 -0
  188. package/es/reducers/vertices-reducer.js +19 -0
  189. package/es/reducers/viewer2d-reducer.js +75 -0
  190. package/es/reducers/viewer3d-reducer.js +56 -0
  191. package/es/shared-style.js +66 -0
  192. package/es/styles/export.js +5 -0
  193. package/es/styles/tabs.css +40 -0
  194. package/es/translator/en.js +104 -0
  195. package/es/translator/it.js +79 -0
  196. package/es/translator/ru.js +79 -0
  197. package/es/translator/translator.js +84 -0
  198. package/es/utils/browser.js +33 -0
  199. package/es/utils/email-validator.js +4 -0
  200. package/es/utils/export.js +25 -0
  201. package/es/utils/geometry.js +2420 -0
  202. package/es/utils/get-edges-of-subgraphs.js +27 -0
  203. package/es/utils/graph-cycles.js +237 -0
  204. package/es/utils/graph-inner-cycles.js +46 -0
  205. package/es/utils/graph.js +150 -0
  206. package/es/utils/helper.js +268 -0
  207. package/es/utils/history.js +29 -0
  208. package/es/utils/id-broker.js +19 -0
  209. package/es/utils/logger.js +8 -0
  210. package/es/utils/math.js +50 -0
  211. package/es/utils/molding.js +871 -0
  212. package/es/utils/name-generator.js +18 -0
  213. package/es/utils/objects-utils.js +50 -0
  214. package/es/utils/phone-validator.js +4 -0
  215. package/es/utils/process-black-list.js +18 -0
  216. package/es/utils/react-if.js +18 -0
  217. package/es/utils/snap-scene.js +99 -0
  218. package/es/utils/snap.js +237 -0
  219. package/es/utils/summarizeCart.js +24 -0
  220. package/es/utils/threeCSG.es6.js +498 -0
  221. package/es/version.js +2 -0
  222. package/lib/catalog/properties/property-string.js +55 -0
  223. package/lib/catalog/properties/property-toggle.js +46 -0
  224. package/lib/catalog/properties/shared-property-style.js +20 -0
  225. package/lib/catalog/utils/FuseUtils.js +88 -0
  226. package/lib/catalog/utils/exporter.js +155 -0
  227. package/lib/catalog/utils/geom-utils.js +205 -0
  228. package/lib/catalog/utils/item-loader.js +1533 -0
  229. package/lib/catalog/utils/load-obj.js +99 -0
  230. package/lib/catalog/utils/mtl-loader.js +363 -0
  231. package/lib/catalog/utils/obj-loader.js +482 -0
  232. package/lib/class/FuseUtils.js +88 -0
  233. package/lib/class/area.js +150 -0
  234. package/lib/class/export.js +96 -0
  235. package/lib/class/group.js +445 -0
  236. package/lib/class/guide.js +67 -0
  237. package/lib/class/hole.js +934 -0
  238. package/lib/class/item.js +1889 -0
  239. package/lib/class/layer.js +672 -0
  240. package/lib/class/line.js +1186 -0
  241. package/lib/class/project.js +799 -0
  242. package/lib/class/vertex.js +207 -0
  243. package/lib/components/content.js +116 -0
  244. package/lib/components/disclaimer/disclaimer.js +105 -0
  245. package/lib/components/export.js +33 -0
  246. package/lib/components/style/button.js +120 -0
  247. package/lib/components/style/cancel-button.js +29 -0
  248. package/lib/components/style/content-container.js +40 -0
  249. package/lib/components/style/content-title.js +37 -0
  250. package/lib/components/style/delete-button.js +34 -0
  251. package/lib/components/style/export.js +121 -0
  252. package/lib/components/style/form-block.js +31 -0
  253. package/lib/components/style/form-color-input.js +34 -0
  254. package/lib/components/style/form-label.js +33 -0
  255. package/lib/components/style/form-number-input.js +220 -0
  256. package/lib/components/style/form-number-input_2.js +213 -0
  257. package/lib/components/style/form-select.js +75 -0
  258. package/lib/components/style/form-slider.js +68 -0
  259. package/lib/components/style/form-submit-button.js +35 -0
  260. package/lib/components/style/form-text-input.js +101 -0
  261. package/lib/components/viewer2d/area.js +88 -0
  262. package/lib/components/viewer2d/export.js +121 -0
  263. package/lib/components/viewer2d/grids/grid-horizontal-streak.js +44 -0
  264. package/lib/components/viewer2d/grids/grid-streak.js +44 -0
  265. package/lib/components/viewer2d/grids/grid-vertical-streak.js +44 -0
  266. package/lib/components/viewer2d/grids/grids.js +44 -0
  267. package/lib/components/viewer2d/group.js +62 -0
  268. package/lib/components/viewer2d/item.js +521 -0
  269. package/lib/components/viewer2d/layer.js +171 -0
  270. package/lib/components/viewer2d/line.js +892 -0
  271. package/lib/components/viewer2d/ruler.js +107 -0
  272. package/lib/components/viewer2d/rulerDist.js +153 -0
  273. package/lib/components/viewer2d/rulerX.js +158 -0
  274. package/lib/components/viewer2d/rulerY.js +160 -0
  275. package/lib/components/viewer2d/scene.js +147 -0
  276. package/lib/components/viewer2d/snap.js +83 -0
  277. package/lib/components/viewer2d/state.js +87 -0
  278. package/lib/components/viewer2d/utils.js +210 -0
  279. package/lib/components/viewer2d/vertex.js +74 -0
  280. package/lib/components/viewer2d/viewer2d.js +1405 -0
  281. package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +2597 -0
  282. package/lib/components/viewer3d/dcm.js +407 -0
  283. package/lib/components/viewer3d/fbm.js +420 -0
  284. package/lib/components/viewer3d/front3D.js +75 -0
  285. package/lib/components/viewer3d/grid-creator.js +34 -0
  286. package/lib/components/viewer3d/grids/grid-horizontal-streak.js +44 -0
  287. package/lib/components/viewer3d/grids/grid-streak.js +35 -0
  288. package/lib/components/viewer3d/grids/grid-vertical-streak.js +44 -0
  289. package/lib/components/viewer3d/libs/first-person-controls.js +74 -0
  290. package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +1287 -0
  291. package/lib/components/viewer3d/libs/mtl-loader.js +363 -0
  292. package/lib/components/viewer3d/libs/obj-loader.js +468 -0
  293. package/lib/components/viewer3d/libs/orbit-controls.js +705 -0
  294. package/lib/components/viewer3d/libs/pointer-lock-controls.js +52 -0
  295. package/lib/components/viewer3d/lrm.js +311 -0
  296. package/lib/components/viewer3d/model.js +714 -0
  297. package/lib/components/viewer3d/pointer-lock-navigation.js +122 -0
  298. package/lib/components/viewer3d/ruler-utils/itemRect.js +68 -0
  299. package/lib/components/viewer3d/ruler-utils/layer3D.js +502 -0
  300. package/lib/components/viewer3d/ruler-utils/ruler3D.js +234 -0
  301. package/lib/components/viewer3d/ruler-utils/scene3D.js +68 -0
  302. package/lib/components/viewer3d/ruler-utils/state3D.js +25 -0
  303. package/lib/components/viewer3d/scene-creator.js +3642 -0
  304. package/lib/components/viewer3d/three-memory-cleaner.js +60 -0
  305. package/lib/components/viewer3d/viewer3d-first-person.js +320 -0
  306. package/lib/components/viewer3d/viewer3d.js +2532 -0
  307. package/lib/constants.js +645 -0
  308. package/lib/index.js +96 -0
  309. package/lib/models.js +517 -0
  310. package/lib/plugins/SVGLoader.js +1417 -0
  311. package/lib/plugins/autosave.js +39 -0
  312. package/lib/plugins/console-debugger.js +44 -0
  313. package/lib/plugins/export.js +33 -0
  314. package/lib/plugins/keyboard.js +107 -0
  315. package/lib/reducers/areas-reducer.js +18 -0
  316. package/lib/reducers/export.js +97 -0
  317. package/lib/reducers/groups-reducer.js +44 -0
  318. package/lib/reducers/holes-reducer.js +68 -0
  319. package/lib/reducers/items-reducer.js +146 -0
  320. package/lib/reducers/lines-reducer.js +51 -0
  321. package/lib/reducers/project-reducer.js +135 -0
  322. package/lib/reducers/reducer.js +26 -0
  323. package/lib/reducers/scene-reducer.js +34 -0
  324. package/lib/reducers/user-reducer.js +46 -0
  325. package/lib/reducers/vertices-reducer.js +25 -0
  326. package/lib/reducers/viewer2d-reducer.js +82 -0
  327. package/lib/reducers/viewer3d-reducer.js +63 -0
  328. package/lib/shared-style.js +72 -0
  329. package/lib/styles/export.js +13 -0
  330. package/lib/translator/en.js +110 -0
  331. package/lib/translator/it.js +85 -0
  332. package/lib/translator/ru.js +85 -0
  333. package/lib/translator/translator.js +90 -0
  334. package/lib/utils/browser.js +40 -0
  335. package/lib/utils/email-validator.js +10 -0
  336. package/lib/utils/export.js +56 -0
  337. package/lib/utils/geometry.js +2516 -0
  338. package/lib/utils/get-edges-of-subgraphs.js +34 -0
  339. package/lib/utils/graph-cycles.js +240 -0
  340. package/lib/utils/graph-inner-cycles.js +54 -0
  341. package/lib/utils/graph.js +157 -0
  342. package/lib/utils/helper.js +291 -0
  343. package/lib/utils/history.js +36 -0
  344. package/lib/utils/id-broker.js +25 -0
  345. package/lib/utils/logger.js +14 -0
  346. package/lib/utils/math.js +57 -0
  347. package/lib/utils/molding.js +895 -0
  348. package/lib/utils/name-generator.js +23 -0
  349. package/lib/utils/objects-utils.js +60 -0
  350. package/lib/utils/phone-validator.js +10 -0
  351. package/lib/utils/process-black-list.js +24 -0
  352. package/lib/utils/react-if.js +24 -0
  353. package/lib/utils/snap-scene.js +105 -0
  354. package/lib/utils/snap.js +249 -0
  355. package/lib/utils/summarizeCart.js +30 -0
  356. package/lib/utils/threeCSG.es6.js +503 -0
  357. package/lib/version.js +8 -0
  358. package/package.json +3 -3
@@ -0,0 +1,882 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { GeometryUtils } from "../../utils/export";
4
+ import Ruler from "./ruler";
5
+ import { BASE_CABINET_LAYOUTPOS, LINE_THICKNESS, WALL_CABINET_LAYOUTPOS } from "../../constants";
6
+ import * as Three from 'three';
7
+ import { isEmpty } from "./utils";
8
+ var STYLE = {
9
+ stroke: 'rgb(77, 77, 77)',
10
+ strokeWidth: '1px'
11
+ };
12
+ var STYLE_ANGLE = {
13
+ stroke: 'rgb(77, 77, 77)',
14
+ strokeWidth: 1,
15
+ strokeLinecap: 'round',
16
+ strokeLinejoin: 'round',
17
+ strokeMiterlimit: 2.613,
18
+ fill: 'transparent'
19
+ };
20
+ var STYLE_TEXT = {
21
+ textAnchor: 'middle',
22
+ fontSize: '7px',
23
+ fontWeight: 'middle',
24
+ fontFamily: "'Microsoft YaHei UI', Courier, monospace"
25
+ };
26
+ export function compareVertices(v0, v1) {
27
+ return v0.x === v1.x ? v0.y - v1.y : v0.x - v1.x;
28
+ }
29
+ export default function Line(_ref) {
30
+ var _state$getIn;
31
+ var line = _ref.line,
32
+ allLine = _ref.allLine,
33
+ layer = _ref.layer,
34
+ scene = _ref.scene,
35
+ num = _ref.num,
36
+ catalog = _ref.catalog,
37
+ state = _ref.state,
38
+ relatedLines = _ref.relatedLines;
39
+ var showWallLengthMeasure = scene.showWallLengthMeasure,
40
+ showWallCabinetMeasure = scene.showWallCabinetMeasure,
41
+ showBaseCabinetMeasure = scene.showBaseCabinetMeasure,
42
+ showWindowDoorMeasure = scene.showWindowDoorMeasure;
43
+ var vertex0 = layer.vertices.get(line.vertices.get(0));
44
+ var vertex1 = layer.vertices.get(line.vertices.get(1));
45
+ if (vertex0.id === vertex1.id || GeometryUtils.samePoints(vertex0, vertex1)) return null; //avoid 0-length lines
46
+ var x1 = vertex0.x,
47
+ y1 = vertex0.y;
48
+ var x2 = vertex1.x,
49
+ y2 = vertex1.y;
50
+ var relatedvertice0x, relatedvertice0y, relatedvertice1x, relatedvertice1y;
51
+ // relatedvertice0x = relatedVertice.point.x;
52
+ // relatedvertice0y = relatedVertice.point.y;
53
+ line.relatedVertices.forEach(function (relatedVertice) {
54
+ if (relatedVertice.index == undefined) relatedVertice = relatedVertice.toJSON();
55
+ if (relatedVertice.index == 0) {
56
+ relatedvertice0x = relatedVertice.point.x;
57
+ relatedvertice0y = relatedVertice.point.y;
58
+ } else {
59
+ relatedvertice1x = relatedVertice.point.x;
60
+ relatedvertice1y = relatedVertice.point.y;
61
+ }
62
+ });
63
+ var thickness = LINE_THICKNESS;
64
+ var half_thickness = thickness / 2;
65
+ // if (compareVertices(vertex0, vertex1) >= 0 && vertex0.x !== vertex1.x) {
66
+ // ({ x: x1, y: y1 } = vertex1);
67
+ // ({ x: x2, y: y2 } = vertex0);
68
+ // }
69
+
70
+ var length = GeometryUtils.pointsDistance(x1, y1, x2, y2);
71
+ // let length = GeometryUtils.pointsDistance(relatedvertice0x,relatedvertice0y,relatedvertice1x,relatedvertice1y);
72
+ var rightHoleLength, leftHoleLength, holeLength;
73
+ var angle = GeometryUtils.angleBetweenTwoPointsAndOrigin(x1, y1, x2, y2);
74
+ var baseSpace = 20;
75
+ var base_item = GeometryUtils.getAllItemSpecified(scene, catalog, BASE_CABINET_LAYOUTPOS);
76
+ // let relatedLines = [];
77
+ var angleVertices = [];
78
+ var layerID = state.getIn(['scene', 'selectedLayer']);
79
+ var drawingLineID = (_state$getIn = state.getIn(['scene', 'layers', layerID, 'selected', 'lines'])) === null || _state$getIn === void 0 ? void 0 : _state$getIn.toJS();
80
+ if (!isEmpty(drawingLineID)) {
81
+ var drawingLine = state.getIn(['scene', 'layers', layerID, 'lines', drawingLineID[0]]).toJS();
82
+ var allLines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
83
+ var allLinesArray = state.getIn(['scene', 'layers', layerID, 'lines']).toArray();
84
+ var vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
85
+ var reget = false;
86
+ relatedLines.forEach(function (relLine) {
87
+ if (!allLinesArray.some(function (alLine) {
88
+ return alLine.id === relLine.id;
89
+ })) {
90
+ reget = true;
91
+ }
92
+ });
93
+ if (reget) {
94
+ relatedLines = [];
95
+ GeometryUtils.getRelatedLines(relatedLines, drawingLine, vertices, allLines);
96
+ }
97
+ // get the angle of two lines and check the angle.
98
+ if (drawingLine.vertices[0] !== drawingLine.vertices[1]) {
99
+ relatedLines.forEach(function (line) {
100
+ // get the points of two lines(drawing line and related line)
101
+ // the first value is overlapped point of two lines as a center of angle.
102
+ if (!isEmpty(line)) {
103
+ var points = [];
104
+ var anglePoints = [];
105
+ line.vertices.forEach(function (vt) {
106
+ if (drawingLine.vertices.some(function (dvt) {
107
+ return dvt === vt;
108
+ })) {
109
+ points.push(vt);
110
+ }
111
+ });
112
+ line.vertices.forEach(function (vt) {
113
+ if (!points.some(function (pt) {
114
+ return pt === vt;
115
+ })) {
116
+ points.push(vt);
117
+ }
118
+ });
119
+ drawingLine.vertices.forEach(function (vt) {
120
+ if (!points.some(function (pt) {
121
+ return pt === vt;
122
+ })) {
123
+ points.push(vt);
124
+ }
125
+ });
126
+ if (points.length < 3) {
127
+ points.push(points[points.length - 1]);
128
+ }
129
+ points.forEach(function (point) {
130
+ return anglePoints.push(vertices[point]);
131
+ });
132
+ angleVertices.push(anglePoints);
133
+ }
134
+ });
135
+ }
136
+ }
137
+ var l2 = {
138
+ x: x1,
139
+ y: y1
140
+ };
141
+ var l3 = {
142
+ x: x2,
143
+ y: y2
144
+ };
145
+ var isSnapped = function isSnapped(itemRect) {
146
+ var r0 = itemRect.rect[0];
147
+ var r1 = itemRect.rect[1];
148
+ var r2 = itemRect.rect[2];
149
+ var r3 = itemRect.rect[3];
150
+ var delta23 = GeometryUtils.verticesDistance(l2, r3) + GeometryUtils.verticesDistance(r3, r2) + GeometryUtils.verticesDistance(r2, l3) - GeometryUtils.verticesDistance(l3, l2);
151
+ if (delta23 < 0.1) {
152
+ return true;
153
+ } else {
154
+ return false;
155
+ }
156
+ };
157
+ // base cabinet
158
+ var baseRuler = [];
159
+ var base_posArray = [];
160
+ if (base_item.cur) {
161
+ base_item.others.push(base_item.cur);
162
+ }
163
+ base_item.others.forEach(function (itemRect) {
164
+ var r2 = itemRect.rect[2];
165
+ var r3 = itemRect.rect[3];
166
+ if (isSnapped(itemRect)) {
167
+ base_posArray.push(r2);
168
+ base_posArray.push(r3);
169
+ }
170
+ });
171
+ base_posArray.push(l2);
172
+ base_posArray.push(l3);
173
+ var base_posAndwidth = [];
174
+ if (Math.abs(angle) === 0 || Math.abs(angle) === 180 || GeometryUtils.almostEqual(y1, y2)) {
175
+ base_posArray.sort(function (a, b) {
176
+ return a.x - b.x;
177
+ });
178
+ if (base_posArray.length > 2) {
179
+ for (var index = 0; index < base_posArray.length - 1; index++) {
180
+ var element = base_posArray[index];
181
+ base_posAndwidth.push({
182
+ pos: element,
183
+ length: base_posArray[index + 1].x - element.x
184
+ });
185
+ }
186
+ }
187
+ } else {
188
+ base_posArray.sort(function (a, b) {
189
+ return a.y - b.y;
190
+ });
191
+ if (base_posArray.length > 2) {
192
+ for (var _index = 0; _index < base_posArray.length - 1; _index++) {
193
+ var _element = base_posArray[_index];
194
+ base_posAndwidth.push({
195
+ pos: _element,
196
+ length: Math.abs((base_posArray[_index + 1].y - _element.y) / Math.sin(angle / 180 * Math.PI))
197
+ });
198
+ }
199
+ }
200
+ }
201
+ if (!showBaseCabinetMeasure || base_posArray.length <= 2) {
202
+ baseSpace -= 20;
203
+ }
204
+ baseRuler = base_posAndwidth.map(function (pAw) {
205
+ if (pAw.length > 1) {
206
+ if (Math.abs(angle) === 0 || Math.abs(angle) === 180 || GeometryUtils.almostEqual(y1, y2)) {
207
+ if (x1 - x2 > 0) {
208
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
209
+ x1: pAw.pos.x + pAw.length,
210
+ y1: pAw.pos.y,
211
+ x2: pAw.pos.x + pAw.length,
212
+ y2: pAw.pos.y - thickness / 2 - baseSpace,
213
+ style: STYLE
214
+ }), /*#__PURE__*/React.createElement(Ruler, {
215
+ key: 4,
216
+ layer: layer,
217
+ unit: scene.unit,
218
+ rulerUnit: scene.rulerUnit,
219
+ length: pAw.length,
220
+ transform: "translate(".concat(pAw.pos.x, ", ").concat(pAw.pos.y - thickness / 2 - baseSpace, " ) rotate(").concat(angle + 180, ", 0, 0)")
221
+ }), /*#__PURE__*/React.createElement("line", {
222
+ x1: pAw.pos.x,
223
+ y1: pAw.pos.y,
224
+ x2: pAw.pos.x,
225
+ y2: pAw.pos.y - thickness / 2 - baseSpace,
226
+ style: STYLE
227
+ }));
228
+ } else {
229
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
230
+ x1: pAw.pos.x + pAw.length,
231
+ y1: pAw.pos.y,
232
+ x2: pAw.pos.x + pAw.length,
233
+ y2: pAw.pos.y + thickness / 2 + baseSpace,
234
+ style: STYLE
235
+ }), /*#__PURE__*/React.createElement(Ruler, {
236
+ key: 4,
237
+ layer: layer,
238
+ unit: scene.unit,
239
+ rulerUnit: scene.rulerUnit,
240
+ length: pAw.length,
241
+ transform: "translate(".concat(pAw.pos.x, ", ").concat(pAw.pos.y + thickness / 2 + baseSpace, " ) rotate(").concat(angle, ", 0, 0)")
242
+ }), /*#__PURE__*/React.createElement("line", {
243
+ x1: pAw.pos.x,
244
+ y1: pAw.pos.y,
245
+ x2: pAw.pos.x,
246
+ y2: pAw.pos.y + thickness / 2 + baseSpace,
247
+ style: STYLE
248
+ }));
249
+ }
250
+ } else {
251
+ if (y1 - y2 > 0) {
252
+ if (x1 - x2 < 0 || GeometryUtils.almostEqual(x1, x2)) {
253
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
254
+ x1: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI),
255
+ y1: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI),
256
+ x2: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
257
+ y2: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
258
+ style: STYLE
259
+ }), /*#__PURE__*/React.createElement(Ruler, {
260
+ key: 5,
261
+ layer: layer,
262
+ unit: scene.unit,
263
+ rulerUnit: scene.rulerUnit,
264
+ length: pAw.length,
265
+ transform: "translate(".concat(pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0)")
266
+ }), /*#__PURE__*/React.createElement("line", {
267
+ x1: pAw.pos.x,
268
+ y1: pAw.pos.y,
269
+ x2: pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
270
+ y2: pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
271
+ style: STYLE
272
+ }));
273
+ } else {
274
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
275
+ x1: pAw.pos.x,
276
+ y1: pAw.pos.y,
277
+ x2: pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
278
+ y2: pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
279
+ style: STYLE
280
+ }), /*#__PURE__*/React.createElement(Ruler, {
281
+ key: 5,
282
+ layer: layer,
283
+ unit: scene.unit,
284
+ rulerUnit: scene.rulerUnit,
285
+ length: pAw.length,
286
+ transform: "translate(".concat(pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0) scale(-1, -1)")
287
+ }), /*#__PURE__*/React.createElement("line", {
288
+ x1: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI),
289
+ y1: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI),
290
+ x2: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
291
+ y2: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
292
+ style: STYLE
293
+ }));
294
+ }
295
+ } else {
296
+ if (x1 - x2 < 0 || GeometryUtils.almostEqual(x1, x2)) {
297
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
298
+ x1: pAw.pos.x,
299
+ y1: pAw.pos.y,
300
+ x2: pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
301
+ y2: pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
302
+ style: STYLE
303
+ }), /*#__PURE__*/React.createElement(Ruler, {
304
+ key: 5,
305
+ layer: layer,
306
+ unit: scene.unit,
307
+ rulerUnit: scene.rulerUnit,
308
+ length: pAw.length,
309
+ transform: "translate(".concat(pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0)")
310
+ }), /*#__PURE__*/React.createElement("line", {
311
+ x1: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI),
312
+ y1: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI),
313
+ x2: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
314
+ y2: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
315
+ style: STYLE
316
+ }));
317
+ } else {
318
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
319
+ x1: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI),
320
+ y1: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI),
321
+ x2: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
322
+ y2: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
323
+ style: STYLE
324
+ }), /*#__PURE__*/React.createElement(Ruler, {
325
+ key: 5,
326
+ layer: layer,
327
+ unit: scene.unit,
328
+ rulerUnit: scene.rulerUnit,
329
+ length: pAw.length,
330
+ transform: "translate(".concat(pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0) scale(-1, -1)")
331
+ }), /*#__PURE__*/React.createElement("line", {
332
+ x1: pAw.pos.x,
333
+ y1: pAw.pos.y,
334
+ x2: pAw.pos.x - (thickness / 2 + baseSpace) * Math.sin(angle / 180 * Math.PI),
335
+ y2: pAw.pos.y + (thickness / 2 + baseSpace) * Math.cos(angle / 180 * Math.PI),
336
+ style: STYLE
337
+ }));
338
+ }
339
+ }
340
+ }
341
+ }
342
+ });
343
+ var doorSpace = baseSpace + 20;
344
+ var renderedHoles = line.holes.map(function (holeID) {
345
+ var hole = layer.holes.get(holeID);
346
+ if (hole === undefined) {
347
+ return '';
348
+ }
349
+ var startAt = length * hole.offset;
350
+ var renderedHole = catalog.getElement(hole.type).render2D(hole, layer, scene);
351
+ return /*#__PURE__*/React.createElement("g", {
352
+ key: holeID,
353
+ transform: "translate(".concat(startAt, ", 3.5)"),
354
+ "data-element-root": true,
355
+ "data-prototype": hole.prototype,
356
+ "data-id": hole.id,
357
+ "data-selected": hole.selected,
358
+ "data-layer": layer.id
359
+ }, renderedHole);
360
+ });
361
+ var renderedLine = catalog.getElement(line.type).render2D(line, layer, scene, state);
362
+ var holeTemp = [];
363
+ var renderedRuler = [];
364
+ var renderedAllRuler = [];
365
+ if (!line.holes.size || !showWindowDoorMeasure) {
366
+ doorSpace -= 20;
367
+ }
368
+ var allRuler = [0],
369
+ holeData = [];
370
+ var lineHoles = line.holes.sortBy(function (holeID) {
371
+ var hole = layer.holes.get(holeID);
372
+ return !hole ? 0 : hole.offset;
373
+ });
374
+ lineHoles.forEach(function (holeID) {
375
+ var hole = layer.holes.get(holeID);
376
+ if (hole !== undefined) {
377
+ var startAt = length * hole.offset;
378
+ var holeWidth = hole.properties.toJS().width.length;
379
+ allRuler.push(startAt - holeWidth / 2);
380
+ allRuler.push(startAt + holeWidth / 2);
381
+ holeData["".concat(startAt - holeWidth / 2, "_").concat(startAt + holeWidth / 2)] = holeID;
382
+ }
383
+ });
384
+ allRuler.push(length);
385
+
386
+ // wall cabinet
387
+ var wallSpace = doorSpace + 20;
388
+ var wall_item = GeometryUtils.getAllItemSpecified(scene, catalog, WALL_CABINET_LAYOUTPOS);
389
+ var wallRuler = [];
390
+ var wall_posArray = [];
391
+ if (wall_item.cur) {
392
+ wall_item.others.push(wall_item.cur);
393
+ }
394
+ wall_item.others.forEach(function (itemRect) {
395
+ var r2 = itemRect.rect[2];
396
+ var r3 = itemRect.rect[3];
397
+ if (isSnapped(itemRect)) {
398
+ wall_posArray.push(r2);
399
+ wall_posArray.push(r3);
400
+ }
401
+ });
402
+ wall_posArray.push(l2);
403
+ wall_posArray.push(l3);
404
+ var wall_posAndwidth = [];
405
+ if (Math.abs(angle) === 0 || Math.abs(angle) === 180 || GeometryUtils.almostEqual(y1, y2)) {
406
+ wall_posArray.sort(function (a, b) {
407
+ return a.x - b.x;
408
+ });
409
+ if (wall_posArray.length > 2) {
410
+ for (var _index2 = 0; _index2 < wall_posArray.length - 1; _index2++) {
411
+ var _element2 = wall_posArray[_index2];
412
+ wall_posAndwidth.push({
413
+ pos: _element2,
414
+ length: wall_posArray[_index2 + 1].x - _element2.x
415
+ });
416
+ }
417
+ }
418
+ } else {
419
+ wall_posArray.sort(function (a, b) {
420
+ return a.y - b.y;
421
+ });
422
+ if (wall_posArray.length > 2) {
423
+ for (var _index3 = 0; _index3 < wall_posArray.length - 1; _index3++) {
424
+ var _element3 = wall_posArray[_index3];
425
+ wall_posAndwidth.push({
426
+ pos: _element3,
427
+ length: Math.abs((wall_posArray[_index3 + 1].y - _element3.y) / Math.sin(angle / 180 * Math.PI))
428
+ });
429
+ }
430
+ }
431
+ }
432
+ if (!showWallCabinetMeasure || wall_posArray.length <= 2) {
433
+ wallSpace -= 20;
434
+ }
435
+ wallRuler = wall_posAndwidth.map(function (pAw) {
436
+ if (pAw.length > 1) {
437
+ if (Math.abs(angle) === 0 || Math.abs(angle) === 180 || GeometryUtils.almostEqual(y1, y2)) {
438
+ if (x1 - x2 > 0) {
439
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
440
+ x1: pAw.pos.x + pAw.length,
441
+ y1: pAw.pos.y,
442
+ x2: pAw.pos.x + pAw.length,
443
+ y2: pAw.pos.y - thickness / 2 - wallSpace,
444
+ style: STYLE
445
+ }), /*#__PURE__*/React.createElement(Ruler, {
446
+ key: 4,
447
+ layer: layer,
448
+ unit: scene.unit,
449
+ rulerUnit: scene.rulerUnit,
450
+ length: pAw.length,
451
+ transform: "translate(".concat(pAw.pos.x, ", ").concat(pAw.pos.y - thickness / 2 - wallSpace, " ) rotate(").concat(angle + 180, ", 0, 0)")
452
+ }), /*#__PURE__*/React.createElement("line", {
453
+ x1: pAw.pos.x,
454
+ y1: pAw.pos.y,
455
+ x2: pAw.pos.x,
456
+ y2: pAw.pos.y - thickness / 2 - wallSpace,
457
+ style: STYLE
458
+ }));
459
+ } else {
460
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
461
+ x1: pAw.pos.x + pAw.length,
462
+ y1: pAw.pos.y,
463
+ x2: pAw.pos.x + pAw.length,
464
+ y2: pAw.pos.y + thickness / 2 + wallSpace,
465
+ style: STYLE
466
+ }), /*#__PURE__*/React.createElement(Ruler, {
467
+ key: 4,
468
+ layer: layer,
469
+ unit: scene.unit,
470
+ rulerUnit: scene.rulerUnit,
471
+ length: pAw.length,
472
+ transform: "translate(".concat(pAw.pos.x, ", ").concat(pAw.pos.y + thickness / 2 + wallSpace, " ) rotate(").concat(angle, ", 0, 0)")
473
+ }), /*#__PURE__*/React.createElement("line", {
474
+ x1: pAw.pos.x,
475
+ y1: pAw.pos.y,
476
+ x2: pAw.pos.x,
477
+ y2: pAw.pos.y + thickness / 2 + wallSpace,
478
+ style: STYLE
479
+ }));
480
+ }
481
+ } else {
482
+ if (y1 - y2 > 0) {
483
+ if (x1 - x2 < 0 || GeometryUtils.almostEqual(x1, x2)) {
484
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
485
+ x1: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI),
486
+ y1: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI),
487
+ x2: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
488
+ y2: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
489
+ style: STYLE
490
+ }), /*#__PURE__*/React.createElement(Ruler, {
491
+ key: 5,
492
+ layer: layer,
493
+ unit: scene.unit,
494
+ rulerUnit: scene.rulerUnit,
495
+ length: pAw.length,
496
+ transform: "translate(".concat(pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0)")
497
+ }), /*#__PURE__*/React.createElement("line", {
498
+ x1: pAw.pos.x,
499
+ y1: pAw.pos.y,
500
+ x2: pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
501
+ y2: pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
502
+ style: STYLE
503
+ }));
504
+ } else {
505
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
506
+ x1: pAw.pos.x,
507
+ y1: pAw.pos.y,
508
+ x2: pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
509
+ y2: pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
510
+ style: STYLE
511
+ }), /*#__PURE__*/React.createElement(Ruler, {
512
+ key: 5,
513
+ layer: layer,
514
+ unit: scene.unit,
515
+ rulerUnit: scene.rulerUnit,
516
+ length: pAw.length,
517
+ transform: "translate(".concat(pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0) scale(-1, -1)")
518
+ }), /*#__PURE__*/React.createElement("line", {
519
+ x1: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI),
520
+ y1: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI),
521
+ x2: pAw.pos.x - pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
522
+ y2: pAw.pos.y - pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
523
+ style: STYLE
524
+ }));
525
+ }
526
+ } else {
527
+ if (x1 - x2 < 0 || GeometryUtils.almostEqual(x1, x2)) {
528
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
529
+ x1: pAw.pos.x,
530
+ y1: pAw.pos.y,
531
+ x2: pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
532
+ y2: pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
533
+ style: STYLE
534
+ }), /*#__PURE__*/React.createElement(Ruler, {
535
+ key: 5,
536
+ layer: layer,
537
+ unit: scene.unit,
538
+ rulerUnit: scene.rulerUnit,
539
+ length: pAw.length,
540
+ transform: "translate(".concat(pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0)")
541
+ }), /*#__PURE__*/React.createElement("line", {
542
+ x1: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI),
543
+ y1: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI),
544
+ x2: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
545
+ y2: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
546
+ style: STYLE
547
+ }));
548
+ } else {
549
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
550
+ x1: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI),
551
+ y1: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI),
552
+ x2: pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
553
+ y2: pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
554
+ style: STYLE
555
+ }), /*#__PURE__*/React.createElement(Ruler, {
556
+ key: 5,
557
+ layer: layer,
558
+ unit: scene.unit,
559
+ rulerUnit: scene.rulerUnit,
560
+ length: pAw.length,
561
+ transform: "translate(".concat(pAw.pos.x + pAw.length * Math.cos(angle / 180 * Math.PI) - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI), ", ").concat(pAw.pos.y + pAw.length * Math.sin(angle / 180 * Math.PI) + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI), " ) rotate(").concat(angle, ", 0, 0) scale(-1, -1)")
562
+ }), /*#__PURE__*/React.createElement("line", {
563
+ x1: pAw.pos.x,
564
+ y1: pAw.pos.y,
565
+ x2: pAw.pos.x - (thickness / 2 + wallSpace) * Math.sin(angle / 180 * Math.PI),
566
+ y2: pAw.pos.y + (thickness / 2 + wallSpace) * Math.cos(angle / 180 * Math.PI),
567
+ style: STYLE
568
+ }));
569
+ }
570
+ }
571
+ }
572
+ }
573
+ });
574
+ var lineSpace = wallSpace + 20;
575
+ //the space from the dimensioning line to the top
576
+ var lineSpacedimension1 = 5;
577
+ //the space from the dimensioning line to the bottom
578
+ var lineSpacedimension2 = 15;
579
+ if (compareVertices(vertex0, vertex1) >= 0 && vertex0.x !== vertex1.x) {
580
+ renderedRuler.push(/*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
581
+ x1: length,
582
+ y1: half_thickness + lineSpace + lineSpacedimension1,
583
+ x2: length,
584
+ y2: half_thickness + lineSpacedimension2,
585
+ style: STYLE
586
+ }), /*#__PURE__*/React.createElement(Ruler, {
587
+ key: 0,
588
+ layer: layer,
589
+ unit: scene.unit,
590
+ rulerUnit: scene.rulerUnit,
591
+ length: length,
592
+ transform: "translate(".concat(length, ", ").concat(half_thickness + lineSpace, ") scale(-1, -1)")
593
+ }), /*#__PURE__*/React.createElement("line", {
594
+ x1: 0,
595
+ y1: half_thickness + lineSpace + lineSpacedimension1,
596
+ x2: 0,
597
+ y2: half_thickness + lineSpacedimension2,
598
+ style: STYLE
599
+ })));
600
+ } else {
601
+ renderedRuler.push(/*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("line", {
602
+ x1: 0,
603
+ y1: half_thickness + lineSpace + lineSpacedimension1,
604
+ x2: 0,
605
+ y2: half_thickness + lineSpacedimension2,
606
+ style: STYLE
607
+ }), /*#__PURE__*/React.createElement(Ruler, {
608
+ key: 0,
609
+ layer: layer,
610
+ unit: scene.unit,
611
+ rulerUnit: scene.rulerUnit,
612
+ length: length,
613
+ transform: "translate(0, ".concat(half_thickness + lineSpace, ")")
614
+ }), /*#__PURE__*/React.createElement("line", {
615
+ x1: length,
616
+ y1: half_thickness + lineSpace + lineSpacedimension1,
617
+ x2: length,
618
+ y2: half_thickness + lineSpacedimension2,
619
+ style: STYLE
620
+ })));
621
+ }
622
+ allRuler.sort(function (a, b) {
623
+ return a - b;
624
+ });
625
+ if (allRuler.length > 2) {
626
+ allRuler.forEach(function (rulerData, index) {
627
+ var element = allRuler[index + 1] - allRuler[index];
628
+ if (!Number.isNaN(element)) {
629
+ var dataProtoType = 'ruler';
630
+ var dataId = holeData["".concat(allRuler[index], "_").concat(allRuler[index + 1])];
631
+ if (!dataId) {
632
+ var holeID1 = holeData["".concat(allRuler[index - 1], "_").concat(allRuler[index])];
633
+ var holeID2 = holeData["".concat(allRuler[index + 1], "_").concat(allRuler[index + 2])];
634
+ if (holeID1 && holeID2) {
635
+ dataId = "".concat(holeID1, ",").concat(holeID2);
636
+ dataProtoType = 'twoHoleRuler';
637
+ } else if (holeID1) {
638
+ dataId = holeID1;
639
+ dataProtoType = 'rightHoleRuler';
640
+ } else if (holeID2) {
641
+ dataId = holeID2;
642
+ dataProtoType = 'leftHoleRuler';
643
+ }
644
+ } else {
645
+ dataProtoType = 'rulerHole';
646
+ }
647
+ if (compareVertices(vertex0, vertex1) >= 0 && vertex0.x !== vertex1.x) {
648
+ renderedAllRuler.push(/*#__PURE__*/React.createElement("g", {
649
+ transform: "translate(".concat(x1, ", ").concat(y1, ") rotate(").concat(angle, ", 0, 0)")
650
+ }, /*#__PURE__*/React.createElement("line", {
651
+ x1: allRuler[index],
652
+ y1: half_thickness,
653
+ x2: allRuler[index],
654
+ y2: half_thickness + doorSpace,
655
+ style: STYLE
656
+ }), /*#__PURE__*/React.createElement(Ruler, {
657
+ key: "allRuler_".concat(index),
658
+ layer: layer,
659
+ unit: scene.unit,
660
+ rulerUnit: scene.rulerUnit,
661
+ length: element,
662
+ transform: "translate(".concat(allRuler[index] + element, ", ").concat(half_thickness + doorSpace, " ) scale(-1, -1)")
663
+ }), /*#__PURE__*/React.createElement("line", {
664
+ x1: allRuler[index] + element,
665
+ y1: half_thickness,
666
+ x2: allRuler[index] + element,
667
+ y2: half_thickness + doorSpace,
668
+ style: STYLE
669
+ })));
670
+ } else {
671
+ renderedAllRuler.push(/*#__PURE__*/React.createElement("g", {
672
+ transform: "translate(".concat(x1, ", ").concat(y1, ") rotate(").concat(angle, ", 0, 0)")
673
+ }, /*#__PURE__*/React.createElement("line", {
674
+ x1: allRuler[index],
675
+ y1: half_thickness,
676
+ x2: allRuler[index],
677
+ y2: half_thickness + doorSpace,
678
+ style: STYLE
679
+ }), /*#__PURE__*/React.createElement(Ruler, {
680
+ key: "allRuler_".concat(index),
681
+ layer: layer,
682
+ unit: scene.unit,
683
+ rulerUnit: scene.rulerUnit,
684
+ length: element,
685
+ transform: "translate(".concat(allRuler[index], ", ").concat(half_thickness + doorSpace, " )")
686
+ }), /*#__PURE__*/React.createElement("line", {
687
+ x1: allRuler[index] + element,
688
+ y1: half_thickness,
689
+ x2: allRuler[index] + element,
690
+ y2: half_thickness + doorSpace,
691
+ style: STYLE
692
+ })));
693
+ }
694
+ }
695
+ });
696
+ }
697
+ return /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("g", {
698
+ transform: "translate(".concat(x1, ", ").concat(y1, ") rotate(").concat(angle, ", 0, 0)"),
699
+ "data-element-root": true,
700
+ "data-prototype": 'ruler',
701
+ "data-id": line.id,
702
+ "data-selected": line.selected,
703
+ "data-layer": layer.id,
704
+ "data-length": length
705
+ }, showWallLengthMeasure ? renderedRuler : null), line.selected && angleVertices.map(function (vertex, index) {
706
+ var lineGroup = vertex[0].lines;
707
+ var angles = [];
708
+ var thickness = [];
709
+ var vectories = [];
710
+ // get the vector of lines
711
+ lineGroup.forEach(function (line) {
712
+ line = layer.lines.get(line);
713
+ var vertex0 = layer.vertices.get(line.vertices.get(0));
714
+ var vertex1 = layer.vertices.get(line.vertices.get(1));
715
+ var vec = vertex0 === vertex[0] ? new Three.Vector2(vertex1.x - vertex0.x, vertex1.y - vertex0.y) : new Three.Vector2(vertex0.x - vertex1.x, vertex0.y - vertex1.y);
716
+ var angle = vec.angle();
717
+ var thick = 15;
718
+ angles.push(angle);
719
+ thickness.push(thick);
720
+ vectories.push(vec.normalize());
721
+ });
722
+
723
+ // calculate the angle between two lines
724
+ var center = new Three.Vector2(vertex[0].x, vertex[0].y);
725
+ var pos1 = new Three.Vector2(vertex[1].x, vertex[1].y);
726
+ var pos2 = new Three.Vector2(vertex[2].x, vertex[2].y);
727
+ var cen = center.clone();
728
+ var pos = pos1.clone();
729
+ var vec1 = pos.sub(cen).normalize();
730
+ pos = pos2.clone();
731
+ var vec2 = pos.sub(cen).normalize();
732
+ var v1 = vec1.clone(),
733
+ v2 = vec2.clone();
734
+ var vec = v1.add(v2).normalize();
735
+ var angle = Math.abs(Math.floor(vec1.angle() * 180 / Math.PI - vec2.angle() * 180 / Math.PI + 0.5));
736
+ angle = angle > 180 ? 360 - angle : angle;
737
+ var rotDir = vec1.cross(vec2) > 0; // true: rotate CCW, false: rotate CW
738
+
739
+ // Angle Text Position
740
+
741
+ var angleTextO = center.clone();
742
+ var textTranslation = vec1.clone().add(vec2).normalize().multiplyScalar(25);
743
+ angleTextO.add(textTranslation);
744
+ angleTextO.y -= 5; // half the height of text `angle`
745
+
746
+ var tx = 0;
747
+ var ty = 0;
748
+ vec = vec.multiplyScalar(35);
749
+ vec1 = vec1.multiplyScalar(35);
750
+ var cen1 = center.clone(),
751
+ cen2 = center.clone();
752
+ center = center.add(vec);
753
+ pos1 = cen1.add(vec1);
754
+ var rotated = pos1.clone().rotateAround(cen2, angle / 2.0 * Math.PI / 180);
755
+ var lines = [];
756
+ var t = center.distanceTo(rotated) < 5 ? 1 : -1;
757
+ pos2 = pos1.clone().rotateAround(cen2, t * angle * Math.PI / 180);
758
+
759
+ // Angle SVG Path
760
+ lines.push(/*#__PURE__*/React.createElement("path", {
761
+ style: STYLE_ANGLE,
762
+ d: "\n M ".concat(vertex[0].x, ",").concat(vertex[0].y, " L ").concat(pos1.x, ",").concat(pos1.y, " A 30,30 ").concat(angle, " 0 ").concat(t > 0 ? 1 : 0, " ").concat(pos2.x, ",").concat(pos2.y, " z\n ")
763
+ }));
764
+ var length = angle;
765
+ // draw angle and angle text
766
+ return /*#__PURE__*/React.createElement("g", {
767
+ key: index,
768
+ transform: "translate(".concat(tx, ", ").concat(ty, ")"),
769
+ "data-element-root": true,
770
+ "data-prototype": "angleChange",
771
+ "data-layer": layer.id,
772
+ "data-selected": "true",
773
+ "data-id": [vertex[0].id, vertex[1].id, rotDir],
774
+ "data-length": length
775
+ }, lines, /*#__PURE__*/React.createElement("text", {
776
+ transform: "translate(".concat(angleTextO.x, ", ").concat(angleTextO.y, ") scale(1.5, -1.5)"),
777
+ style: STYLE_TEXT
778
+ }, angle), /*#__PURE__*/React.createElement("circle", {
779
+ transform: "translate(".concat(angleTextO.x, ", ").concat(angleTextO.y, ") translate(10, 9)"),
780
+ fill: "transparent",
781
+ stroke: "rgb(77, 77, 77)",
782
+ strokeWidth: 1,
783
+ r: 2
784
+ }));
785
+ }), showWindowDoorMeasure ? renderedAllRuler : null, showBaseCabinetMeasure ? baseRuler : null, showWallCabinetMeasure ? wallRuler : null, /*#__PURE__*/React.createElement("g", {
786
+ "data-element-root": true,
787
+ "data-prototype": line.prototype,
788
+ "data-id": line.id,
789
+ id: line.id,
790
+ "data-selected": line.selected,
791
+ "data-layer": layer.id,
792
+ style: line.selected ? {
793
+ cursor: 'move'
794
+ } : {}
795
+ }, renderedLine, /*#__PURE__*/React.createElement("g", {
796
+ transform: "translate(".concat(x1, ", ").concat(y1, ") rotate(").concat(angle, ", 0, 0)")
797
+ }, renderedHoles)), line.selected && /*#__PURE__*/React.createElement("g", {
798
+ id: 'elevation-button',
799
+ key: 1,
800
+ transform: "translate(".concat(x1 + 35, ", ").concat(y1 - 15, ")"),
801
+ style: {
802
+ cursor: 'pointer'
803
+ }
804
+ }, /*#__PURE__*/React.createElement("defs", null, /*#__PURE__*/React.createElement("filter", {
805
+ id: "shadow"
806
+ }, /*#__PURE__*/React.createElement("feDropShadow", {
807
+ dx: "0",
808
+ dy: "0",
809
+ stdDeviation: "0.6"
810
+ }))), /*#__PURE__*/React.createElement("rect", {
811
+ rx: "4",
812
+ ry: "4",
813
+ y: "20",
814
+ height: "22",
815
+ width: "22",
816
+ fill: "white",
817
+ filter: "url(#shadow)"
818
+ }), /*#__PURE__*/React.createElement("image", {
819
+ href: "/assets/img/svg/bottombar/elevation.svg",
820
+ x: "5",
821
+ y: "-36",
822
+ height: "12",
823
+ width: "12",
824
+ style: {
825
+ transform: 'rotateX(180deg)'
826
+ }
827
+ })), line.selected && /*#__PURE__*/React.createElement("g", {
828
+ id: 'remove-button',
829
+ key: 2,
830
+ transform: "translate(".concat(x1 + 10, ", ").concat(y1, ")"),
831
+ style: {
832
+ cursor: 'pointer'
833
+ }
834
+ }, /*#__PURE__*/React.createElement("defs", null, /*#__PURE__*/React.createElement("filter", {
835
+ id: "shadow"
836
+ }, /*#__PURE__*/React.createElement("feDropShadow", {
837
+ dx: "0",
838
+ dy: "0",
839
+ stdDeviation: "0.6"
840
+ }))), /*#__PURE__*/React.createElement("rect", {
841
+ rx: "4",
842
+ ry: "4",
843
+ y: "5",
844
+ height: "22",
845
+ width: "22",
846
+ fill: "white",
847
+ filter: "url(#shadow)"
848
+ }), /*#__PURE__*/React.createElement("image", {
849
+ href: "/assets/img/svg/delete.svg",
850
+ x: "3",
851
+ y: "-24",
852
+ height: "16",
853
+ width: "16",
854
+ style: {
855
+ transform: 'rotateX(180deg)'
856
+ }
857
+ })), /*#__PURE__*/React.createElement("use", {
858
+ id: 'use elevation button',
859
+ xlinkHref: '#elevation-button',
860
+ "data-element-root": true,
861
+ "data-prototype": line.prototype,
862
+ "data-id": line.id,
863
+ "data-selected": line.selected,
864
+ "data-layer": layer.id,
865
+ "data-part": "elevation"
866
+ }), /*#__PURE__*/React.createElement("use", {
867
+ id: 'use remove button',
868
+ xlinkHref: '#remove-button',
869
+ "data-element-root": true,
870
+ "data-prototype": line.prototype,
871
+ "data-id": line.id,
872
+ "data-selected": line.selected,
873
+ "data-layer": layer.id,
874
+ "data-part": "remove"
875
+ }));
876
+ }
877
+ Line.propTypes = {
878
+ line: PropTypes.object.isRequired,
879
+ layer: PropTypes.object.isRequired,
880
+ scene: PropTypes.object.isRequired,
881
+ catalog: PropTypes.object.isRequired
882
+ };