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

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 (359) hide show
  1. package/lib/KitchenConfiguratorApp.js +3 -0
  2. package/package.json +1 -1
  3. package/es/@history.js +0 -2
  4. package/es/AppContext.js +0 -3
  5. package/es/KitchenConfigurator.js +0 -645
  6. package/es/KitchenConfiguratorApp.js +0 -478
  7. package/es/actions/area-actions.js +0 -14
  8. package/es/actions/export.js +0 -23
  9. package/es/actions/groups-actions.js +0 -89
  10. package/es/actions/holes-actions.js +0 -119
  11. package/es/actions/items-actions.js +0 -313
  12. package/es/actions/lines-actions.js +0 -81
  13. package/es/actions/project-actions.js +0 -281
  14. package/es/actions/scene-actions.js +0 -33
  15. package/es/actions/vertices-actions.js +0 -27
  16. package/es/actions/viewer2d-actions.js +0 -58
  17. package/es/actions/viewer3d-actions.js +0 -23
  18. package/es/catalog/areas/area/planner-element.js +0 -40
  19. package/es/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  20. package/es/catalog/areas/area/textures/grass.jpg +0 -0
  21. package/es/catalog/areas/area/textures/parquet.jpg +0 -0
  22. package/es/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  23. package/es/catalog/areas/area/textures/tile1.jpg +0 -0
  24. package/es/catalog/catalog.js +0 -277
  25. package/es/catalog/envMap/nx.hdr +0 -0
  26. package/es/catalog/envMap/ny.hdr +0 -0
  27. package/es/catalog/envMap/nz.hdr +0 -0
  28. package/es/catalog/envMap/px.hdr +0 -0
  29. package/es/catalog/envMap/py.hdr +0 -0
  30. package/es/catalog/envMap/pz.hdr +0 -0
  31. package/es/catalog/factories/area-factory-3d.js +0 -181
  32. package/es/catalog/factories/area-factory.js +0 -81
  33. package/es/catalog/factories/export.js +0 -7
  34. package/es/catalog/factories/wall-factory-3d.js +0 -202
  35. package/es/catalog/factories/wall-factory.js +0 -268
  36. package/es/catalog/holes/door-closet/planner-element.js +0 -222
  37. package/es/catalog/holes/door-double/door_double.png +0 -0
  38. package/es/catalog/holes/door-double/planner-element.js +0 -315
  39. package/es/catalog/holes/door-exterior/planner-element.js +0 -215
  40. package/es/catalog/holes/door-interior/planner-element.js +0 -227
  41. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  42. package/es/catalog/holes/door-panic/planner-element.js +0 -503
  43. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  44. package/es/catalog/holes/door-panic-double/planner-element.js +0 -463
  45. package/es/catalog/holes/door-sliding/planner-element.js +0 -225
  46. package/es/catalog/holes/doorway-framed/planner-element.js +0 -145
  47. package/es/catalog/holes/doorway-frameless/planner-element.js +0 -104
  48. package/es/catalog/holes/export.js +0 -13
  49. package/es/catalog/holes/gate/gate.jpg +0 -0
  50. package/es/catalog/holes/window-clear/planner-element.js +0 -166
  51. package/es/catalog/holes/window-clear/texture.png +0 -0
  52. package/es/catalog/holes/window-cross/planner-element.js +0 -165
  53. package/es/catalog/holes/window-cross/texture.png +0 -0
  54. package/es/catalog/holes/window-double-hung/planner-element.js +0 -303
  55. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  56. package/es/catalog/holes/window-vertical/planner-element.js +0 -276
  57. package/es/catalog/holes/window-vertical/texture.png +0 -0
  58. package/es/catalog/lines/wall/planner-element.js +0 -70
  59. package/es/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  60. package/es/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
  61. package/es/catalog/lines/wall/textures/bricks.jpg +0 -0
  62. package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
  63. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  64. package/es/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  65. package/es/catalog/lines/wall/textures/morden.jpg +0 -0
  66. package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
  67. package/es/catalog/lines/wall/textures/painted.jpg +0 -0
  68. package/es/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  69. package/es/catalog/lines/wall/textures/plaster.jpg +0 -0
  70. package/es/catalog/lines/wall/wall.png +0 -0
  71. package/es/catalog/molding/molding-dcm/planner-element.js +0 -28
  72. package/es/catalog/molding/molding-dcm/texture.png +0 -0
  73. package/es/catalog/molding/molding-fbm/planner-element.js +0 -28
  74. package/es/catalog/molding/molding-fbm/texture.png +0 -0
  75. package/es/catalog/molding/molding-lrm/planner-element.js +0 -28
  76. package/es/catalog/molding/molding-lrm/texture.png +0 -0
  77. package/es/catalog/properties/export.js +0 -21
  78. package/es/catalog/properties/property-checkbox.js +0 -116
  79. package/es/catalog/properties/property-color.js +0 -39
  80. package/es/catalog/properties/property-enum.js +0 -97
  81. package/es/catalog/properties/property-hidden.js +0 -19
  82. package/es/catalog/properties/property-lenght-measure.js +0 -101
  83. package/es/catalog/properties/property-length-measure.js +0 -134
  84. package/es/catalog/properties/property-length-measure_hole.js +0 -101
  85. package/es/catalog/properties/property-number.js +0 -48
  86. package/es/catalog/properties/property-read-only.js +0 -26
  87. package/es/catalog/properties/property-string.js +0 -48
  88. package/es/catalog/properties/property-toggle.js +0 -39
  89. package/es/catalog/properties/shared-property-style.js +0 -14
  90. package/es/catalog/utils/FuseUtils.js +0 -82
  91. package/es/catalog/utils/exporter.js +0 -148
  92. package/es/catalog/utils/geom-utils.js +0 -189
  93. package/es/catalog/utils/item-loader.js +0 -1521
  94. package/es/catalog/utils/load-obj.js +0 -91
  95. package/es/catalog/utils/mtl-loader.js +0 -358
  96. package/es/catalog/utils/obj-loader.js +0 -477
  97. package/es/class/FuseUtils.js +0 -82
  98. package/es/class/area.js +0 -145
  99. package/es/class/export.js +0 -24
  100. package/es/class/group.js +0 -440
  101. package/es/class/guide.js +0 -62
  102. package/es/class/hole.js +0 -929
  103. package/es/class/item.js +0 -1883
  104. package/es/class/layer.js +0 -667
  105. package/es/class/line.js +0 -1180
  106. package/es/class/project.js +0 -793
  107. package/es/class/vertex.js +0 -202
  108. package/es/components/content.js +0 -107
  109. package/es/components/disclaimer/disclaimer.js +0 -97
  110. package/es/components/export.js +0 -9
  111. package/es/components/style/button.js +0 -113
  112. package/es/components/style/cancel-button.js +0 -22
  113. package/es/components/style/content-container.js +0 -33
  114. package/es/components/style/content-title.js +0 -29
  115. package/es/components/style/delete-button.js +0 -25
  116. package/es/components/style/export.js +0 -31
  117. package/es/components/style/form-block.js +0 -24
  118. package/es/components/style/form-color-input.js +0 -27
  119. package/es/components/style/form-label.js +0 -26
  120. package/es/components/style/form-number-input.js +0 -213
  121. package/es/components/style/form-number-input_2.js +0 -206
  122. package/es/components/style/form-select.js +0 -68
  123. package/es/components/style/form-slider.js +0 -61
  124. package/es/components/style/form-submit-button.js +0 -26
  125. package/es/components/style/form-text-input.js +0 -95
  126. package/es/components/viewer2d/area.js +0 -81
  127. package/es/components/viewer2d/export.js +0 -31
  128. package/es/components/viewer2d/grids/grid-horizontal-streak.js +0 -37
  129. package/es/components/viewer2d/grids/grid-streak.js +0 -37
  130. package/es/components/viewer2d/grids/grid-vertical-streak.js +0 -37
  131. package/es/components/viewer2d/grids/grids.js +0 -35
  132. package/es/components/viewer2d/group.js +0 -53
  133. package/es/components/viewer2d/item.js +0 -513
  134. package/es/components/viewer2d/layer.js +0 -164
  135. package/es/components/viewer2d/line.js +0 -882
  136. package/es/components/viewer2d/ruler.js +0 -100
  137. package/es/components/viewer2d/rulerDist.js +0 -146
  138. package/es/components/viewer2d/rulerX.js +0 -151
  139. package/es/components/viewer2d/rulerY.js +0 -153
  140. package/es/components/viewer2d/scene.js +0 -140
  141. package/es/components/viewer2d/snap.js +0 -74
  142. package/es/components/viewer2d/state.js +0 -78
  143. package/es/components/viewer2d/utils.js +0 -198
  144. package/es/components/viewer2d/vertex.js +0 -65
  145. package/es/components/viewer2d/viewer2d.js +0 -1398
  146. package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +0 -2592
  147. package/es/components/viewer3d/dcm.js +0 -401
  148. package/es/components/viewer3d/fbm.js +0 -414
  149. package/es/components/viewer3d/front3D.js +0 -66
  150. package/es/components/viewer3d/grid-creator.js +0 -25
  151. package/es/components/viewer3d/grids/grid-horizontal-streak.js +0 -36
  152. package/es/components/viewer3d/grids/grid-streak.js +0 -27
  153. package/es/components/viewer3d/grids/grid-vertical-streak.js +0 -36
  154. package/es/components/viewer3d/libs/first-person-controls.js +0 -67
  155. package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +0 -1281
  156. package/es/components/viewer3d/libs/mtl-loader.js +0 -357
  157. package/es/components/viewer3d/libs/obj-loader.js +0 -462
  158. package/es/components/viewer3d/libs/orbit-controls.js +0 -699
  159. package/es/components/viewer3d/libs/pointer-lock-controls.js +0 -46
  160. package/es/components/viewer3d/lrm.js +0 -305
  161. package/es/components/viewer3d/model.js +0 -708
  162. package/es/components/viewer3d/pointer-lock-navigation.js +0 -115
  163. package/es/components/viewer3d/ruler-utils/itemRect.js +0 -61
  164. package/es/components/viewer3d/ruler-utils/layer3D.js +0 -495
  165. package/es/components/viewer3d/ruler-utils/ruler3D.js +0 -227
  166. package/es/components/viewer3d/ruler-utils/scene3D.js +0 -60
  167. package/es/components/viewer3d/ruler-utils/state3D.js +0 -18
  168. package/es/components/viewer3d/scene-creator.js +0 -3608
  169. package/es/components/viewer3d/three-memory-cleaner.js +0 -51
  170. package/es/components/viewer3d/viewer3d-first-person.js +0 -315
  171. package/es/components/viewer3d/viewer3d.js +0 -2527
  172. package/es/constants.js +0 -636
  173. package/es/index.js +0 -16
  174. package/es/models.js +0 -510
  175. package/es/plugins/SVGLoader.js +0 -1412
  176. package/es/plugins/autosave.js +0 -33
  177. package/es/plugins/console-debugger.js +0 -37
  178. package/es/plugins/export.js +0 -9
  179. package/es/plugins/keyboard.js +0 -101
  180. package/es/reducers/areas-reducer.js +0 -12
  181. package/es/reducers/export.js +0 -25
  182. package/es/reducers/groups-reducer.js +0 -38
  183. package/es/reducers/holes-reducer.js +0 -62
  184. package/es/reducers/items-reducer.js +0 -140
  185. package/es/reducers/lines-reducer.js +0 -45
  186. package/es/reducers/project-reducer.js +0 -129
  187. package/es/reducers/reducer.js +0 -19
  188. package/es/reducers/scene-reducer.js +0 -28
  189. package/es/reducers/user-reducer.js +0 -40
  190. package/es/reducers/vertices-reducer.js +0 -19
  191. package/es/reducers/viewer2d-reducer.js +0 -75
  192. package/es/reducers/viewer3d-reducer.js +0 -56
  193. package/es/shared-style.js +0 -66
  194. package/es/styles/export.js +0 -5
  195. package/es/styles/tabs.css +0 -40
  196. package/es/translator/en.js +0 -104
  197. package/es/translator/it.js +0 -79
  198. package/es/translator/ru.js +0 -79
  199. package/es/translator/translator.js +0 -84
  200. package/es/utils/browser.js +0 -33
  201. package/es/utils/email-validator.js +0 -4
  202. package/es/utils/export.js +0 -25
  203. package/es/utils/geometry.js +0 -2420
  204. package/es/utils/get-edges-of-subgraphs.js +0 -27
  205. package/es/utils/graph-cycles.js +0 -237
  206. package/es/utils/graph-inner-cycles.js +0 -46
  207. package/es/utils/graph.js +0 -150
  208. package/es/utils/helper.js +0 -268
  209. package/es/utils/history.js +0 -29
  210. package/es/utils/id-broker.js +0 -19
  211. package/es/utils/logger.js +0 -8
  212. package/es/utils/math.js +0 -50
  213. package/es/utils/molding.js +0 -871
  214. package/es/utils/name-generator.js +0 -18
  215. package/es/utils/objects-utils.js +0 -50
  216. package/es/utils/phone-validator.js +0 -4
  217. package/es/utils/process-black-list.js +0 -18
  218. package/es/utils/react-if.js +0 -18
  219. package/es/utils/snap-scene.js +0 -99
  220. package/es/utils/snap.js +0 -237
  221. package/es/utils/summarizeCart.js +0 -24
  222. package/es/utils/threeCSG.es6.js +0 -498
  223. package/es/version.js +0 -2
  224. package/lib/catalog/properties/property-string.js +0 -55
  225. package/lib/catalog/properties/property-toggle.js +0 -46
  226. package/lib/catalog/properties/shared-property-style.js +0 -20
  227. package/lib/catalog/utils/FuseUtils.js +0 -88
  228. package/lib/catalog/utils/exporter.js +0 -155
  229. package/lib/catalog/utils/geom-utils.js +0 -205
  230. package/lib/catalog/utils/item-loader.js +0 -1533
  231. package/lib/catalog/utils/load-obj.js +0 -99
  232. package/lib/catalog/utils/mtl-loader.js +0 -363
  233. package/lib/catalog/utils/obj-loader.js +0 -482
  234. package/lib/class/FuseUtils.js +0 -88
  235. package/lib/class/area.js +0 -150
  236. package/lib/class/export.js +0 -96
  237. package/lib/class/group.js +0 -445
  238. package/lib/class/guide.js +0 -67
  239. package/lib/class/hole.js +0 -934
  240. package/lib/class/item.js +0 -1889
  241. package/lib/class/layer.js +0 -672
  242. package/lib/class/line.js +0 -1186
  243. package/lib/class/project.js +0 -799
  244. package/lib/class/vertex.js +0 -207
  245. package/lib/components/content.js +0 -116
  246. package/lib/components/disclaimer/disclaimer.js +0 -105
  247. package/lib/components/export.js +0 -33
  248. package/lib/components/style/button.js +0 -120
  249. package/lib/components/style/cancel-button.js +0 -29
  250. package/lib/components/style/content-container.js +0 -40
  251. package/lib/components/style/content-title.js +0 -37
  252. package/lib/components/style/delete-button.js +0 -34
  253. package/lib/components/style/export.js +0 -121
  254. package/lib/components/style/form-block.js +0 -31
  255. package/lib/components/style/form-color-input.js +0 -34
  256. package/lib/components/style/form-label.js +0 -33
  257. package/lib/components/style/form-number-input.js +0 -220
  258. package/lib/components/style/form-number-input_2.js +0 -213
  259. package/lib/components/style/form-select.js +0 -75
  260. package/lib/components/style/form-slider.js +0 -68
  261. package/lib/components/style/form-submit-button.js +0 -35
  262. package/lib/components/style/form-text-input.js +0 -101
  263. package/lib/components/viewer2d/area.js +0 -88
  264. package/lib/components/viewer2d/export.js +0 -121
  265. package/lib/components/viewer2d/grids/grid-horizontal-streak.js +0 -44
  266. package/lib/components/viewer2d/grids/grid-streak.js +0 -44
  267. package/lib/components/viewer2d/grids/grid-vertical-streak.js +0 -44
  268. package/lib/components/viewer2d/grids/grids.js +0 -44
  269. package/lib/components/viewer2d/group.js +0 -62
  270. package/lib/components/viewer2d/item.js +0 -521
  271. package/lib/components/viewer2d/layer.js +0 -171
  272. package/lib/components/viewer2d/line.js +0 -892
  273. package/lib/components/viewer2d/ruler.js +0 -107
  274. package/lib/components/viewer2d/rulerDist.js +0 -153
  275. package/lib/components/viewer2d/rulerX.js +0 -158
  276. package/lib/components/viewer2d/rulerY.js +0 -160
  277. package/lib/components/viewer2d/scene.js +0 -147
  278. package/lib/components/viewer2d/snap.js +0 -83
  279. package/lib/components/viewer2d/state.js +0 -87
  280. package/lib/components/viewer2d/utils.js +0 -210
  281. package/lib/components/viewer2d/vertex.js +0 -74
  282. package/lib/components/viewer2d/viewer2d.js +0 -1405
  283. package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +0 -2597
  284. package/lib/components/viewer3d/dcm.js +0 -407
  285. package/lib/components/viewer3d/fbm.js +0 -420
  286. package/lib/components/viewer3d/front3D.js +0 -75
  287. package/lib/components/viewer3d/grid-creator.js +0 -34
  288. package/lib/components/viewer3d/grids/grid-horizontal-streak.js +0 -44
  289. package/lib/components/viewer3d/grids/grid-streak.js +0 -35
  290. package/lib/components/viewer3d/grids/grid-vertical-streak.js +0 -44
  291. package/lib/components/viewer3d/libs/first-person-controls.js +0 -74
  292. package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +0 -1287
  293. package/lib/components/viewer3d/libs/mtl-loader.js +0 -363
  294. package/lib/components/viewer3d/libs/obj-loader.js +0 -468
  295. package/lib/components/viewer3d/libs/orbit-controls.js +0 -705
  296. package/lib/components/viewer3d/libs/pointer-lock-controls.js +0 -52
  297. package/lib/components/viewer3d/lrm.js +0 -311
  298. package/lib/components/viewer3d/model.js +0 -714
  299. package/lib/components/viewer3d/pointer-lock-navigation.js +0 -122
  300. package/lib/components/viewer3d/ruler-utils/itemRect.js +0 -68
  301. package/lib/components/viewer3d/ruler-utils/layer3D.js +0 -502
  302. package/lib/components/viewer3d/ruler-utils/ruler3D.js +0 -234
  303. package/lib/components/viewer3d/ruler-utils/scene3D.js +0 -68
  304. package/lib/components/viewer3d/ruler-utils/state3D.js +0 -25
  305. package/lib/components/viewer3d/scene-creator.js +0 -3642
  306. package/lib/components/viewer3d/three-memory-cleaner.js +0 -60
  307. package/lib/components/viewer3d/viewer3d-first-person.js +0 -320
  308. package/lib/components/viewer3d/viewer3d.js +0 -2532
  309. package/lib/constants.js +0 -645
  310. package/lib/index.js +0 -96
  311. package/lib/models.js +0 -517
  312. package/lib/plugins/SVGLoader.js +0 -1417
  313. package/lib/plugins/autosave.js +0 -39
  314. package/lib/plugins/console-debugger.js +0 -44
  315. package/lib/plugins/export.js +0 -33
  316. package/lib/plugins/keyboard.js +0 -107
  317. package/lib/reducers/areas-reducer.js +0 -18
  318. package/lib/reducers/export.js +0 -97
  319. package/lib/reducers/groups-reducer.js +0 -44
  320. package/lib/reducers/holes-reducer.js +0 -68
  321. package/lib/reducers/items-reducer.js +0 -146
  322. package/lib/reducers/lines-reducer.js +0 -51
  323. package/lib/reducers/project-reducer.js +0 -135
  324. package/lib/reducers/reducer.js +0 -26
  325. package/lib/reducers/scene-reducer.js +0 -34
  326. package/lib/reducers/user-reducer.js +0 -46
  327. package/lib/reducers/vertices-reducer.js +0 -25
  328. package/lib/reducers/viewer2d-reducer.js +0 -82
  329. package/lib/reducers/viewer3d-reducer.js +0 -63
  330. package/lib/shared-style.js +0 -72
  331. package/lib/styles/export.js +0 -13
  332. package/lib/translator/en.js +0 -110
  333. package/lib/translator/it.js +0 -85
  334. package/lib/translator/ru.js +0 -85
  335. package/lib/translator/translator.js +0 -90
  336. package/lib/utils/browser.js +0 -40
  337. package/lib/utils/email-validator.js +0 -10
  338. package/lib/utils/export.js +0 -56
  339. package/lib/utils/geometry.js +0 -2516
  340. package/lib/utils/get-edges-of-subgraphs.js +0 -34
  341. package/lib/utils/graph-cycles.js +0 -240
  342. package/lib/utils/graph-inner-cycles.js +0 -54
  343. package/lib/utils/graph.js +0 -157
  344. package/lib/utils/helper.js +0 -291
  345. package/lib/utils/history.js +0 -36
  346. package/lib/utils/id-broker.js +0 -25
  347. package/lib/utils/logger.js +0 -14
  348. package/lib/utils/math.js +0 -57
  349. package/lib/utils/molding.js +0 -895
  350. package/lib/utils/name-generator.js +0 -23
  351. package/lib/utils/objects-utils.js +0 -60
  352. package/lib/utils/phone-validator.js +0 -10
  353. package/lib/utils/process-black-list.js +0 -24
  354. package/lib/utils/react-if.js +0 -24
  355. package/lib/utils/snap-scene.js +0 -105
  356. package/lib/utils/snap.js +0 -249
  357. package/lib/utils/summarizeCart.js +0 -30
  358. package/lib/utils/threeCSG.es6.js +0 -503
  359. package/lib/version.js +0 -8
@@ -1,882 +0,0 @@
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
- };