kitchen-simulator 1.1.1-test.47 → 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 +15 -16
  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 -26
  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,672 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports["default"] = void 0;
7
- var _immutable = require("immutable");
8
- var _export = require("./export");
9
- var _export2 = require("../utils/export");
10
- var _models = require("../models");
11
- var _helper = require("../utils/helper");
12
- function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
13
- function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
14
- function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
15
- function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
16
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
17
- function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
18
- var sameSet = function sameSet(set1, set2) {
19
- return set1.size === set2.size && set1.isSuperset(set2) && set1.isSubset(set2);
20
- };
21
- var sameDirection = function sameDirection(list1, list2) {
22
- if (!sameSet(list1, list2)) return false;
23
- if (list1.size < 3) return true;
24
- var l0 = list1.get(0);
25
- var l1 = list1.get(1);
26
- var i0 = list2.indexOf(l0);
27
- var i1 = list2.indexOf(l1);
28
- return (i1 - i0 - 1) % list1.size == 0;
29
- };
30
- var Layer = exports["default"] = /*#__PURE__*/function () {
31
- function Layer() {
32
- _classCallCheck(this, Layer);
33
- }
34
- return _createClass(Layer, null, [{
35
- key: "create",
36
- value: function create(state, name, altitude) {
37
- var layerID = _export2.IDBroker.acquireID();
38
- name = name || "layer ".concat(layerID);
39
- altitude = altitude || 0;
40
- var layer = new _models.Layer({
41
- id: layerID,
42
- name: name,
43
- altitude: altitude
44
- });
45
- state = state.setIn(['scene', 'selectedLayer'], layerID);
46
- state = state.setIn(['scene', 'layers', layerID], layer);
47
- return {
48
- updatedState: state
49
- };
50
- }
51
- }, {
52
- key: "select",
53
- value: function select(state, layerID) {
54
- if (!state.get('alterate')) state = _export.Project.unselectAll(state).updatedState;
55
- state = state.setIn(['scene', 'selectedLayer'], layerID);
56
- return {
57
- updatedState: state
58
- };
59
- }
60
- }, {
61
- key: "selectAll",
62
- value: function selectAll(state, layerID) {
63
- if (!state.get('alterate')) state = _export.Project.unselectAll(state).updatedState;
64
- state = state.setIn(['scene', 'selectedLayer'], layerID);
65
- var layer = state.scene.layers.get(layerID);
66
- layer.items.forEach(function (data) {
67
- state = Layer.selectElement(state, layerID, 'items', data.id).updatedState;
68
- });
69
- layer.lines.forEach(function (data) {
70
- state = Layer.selectElement(state, layerID, 'lines', data.id).updatedState;
71
- });
72
- layer.holes.forEach(function (data) {
73
- state = Layer.selectElement(state, layerID, 'holes', data.id).updatedState;
74
- });
75
- layer.areas.forEach(function (data) {
76
- state = Layer.selectElement(state, layerID, 'areas', data.id).updatedState;
77
- });
78
- layer.vertices.forEach(function (data) {
79
- state = Layer.selectElement(state, layerID, 'vertices', data.id).updatedState;
80
- });
81
- return {
82
- updatedState: state
83
- };
84
- }
85
- }, {
86
- key: "selectElement",
87
- value: function selectElement(state, layerID, elementPrototype, elementID) {
88
- state = state.setIn(['scene', 'layers', layerID, elementPrototype, elementID, 'selected'], true);
89
- state = state.updateIn(['scene', 'layers', layerID, 'selected', elementPrototype], function (elems) {
90
- return elems.push(elementID);
91
- });
92
- return {
93
- updatedState: state
94
- };
95
- }
96
- }, {
97
- key: "unselect",
98
- value: function unselect(state, layerID, elementPrototype, elementID) {
99
- state = state.setIn(['scene', 'layers', layerID, elementPrototype, elementID, 'selected'], false);
100
- state = state.updateIn(['scene', 'layers', layerID, 'selected', elementPrototype], function (elems) {
101
- return elems.filter(function (el) {
102
- return el.id === elementID;
103
- });
104
- });
105
- return {
106
- updatedState: state
107
- };
108
- }
109
- }, {
110
- key: "updateMovingState",
111
- value: function updateMovingState(state, showflag) {
112
- var _state = state,
113
- scene = _state.scene;
114
- state = state.merge({
115
- scene: scene.mergeIn(['showfg'], showflag)
116
- });
117
- return {
118
- updatedState: state
119
- };
120
- }
121
- }, {
122
- key: "unselectAll",
123
- value: function unselectAll(state, layerID) {
124
- var _state$getIn = state.getIn(['scene', 'layers', layerID]),
125
- lines = _state$getIn.lines,
126
- holes = _state$getIn.holes,
127
- items = _state$getIn.items,
128
- areas = _state$getIn.areas;
129
- if (lines) lines.forEach(function (line) {
130
- state = _export.Line.unselect(state, layerID, line.id).updatedState;
131
- });
132
- if (holes) holes.forEach(function (hole) {
133
- state = _export.Hole.unselect(state, layerID, hole.id).updatedState;
134
- });
135
- if (items) items.forEach(function (item) {
136
- state = _export.Item.unselect(state, layerID, item.id).updatedState;
137
- });
138
- if (areas) areas.forEach(function (area) {
139
- state = _export.Area.unselect(state, layerID, area.id).updatedState;
140
- });
141
- return {
142
- updatedState: state
143
- };
144
- }
145
- }, {
146
- key: "setInitialDoorStyle",
147
- value: function setInitialDoorStyle(state, doorStyle, oStyle) {
148
- state = state.merge({
149
- doorStyle: doorStyle
150
- });
151
- var _state2 = state,
152
- scene = _state2.scene;
153
- var layerID = scene.get('selectedLayer');
154
- var selectedLayer = scene.layers.get(layerID);
155
- selectedLayer = selectedLayer.setIn(['doorStyle'], doorStyle);
156
- state = state.merge({
157
- scene: scene.setIn(['layers', layerID], selectedLayer)
158
- });
159
- return {
160
- updatedState: state
161
- };
162
- }
163
- }, {
164
- key: "setProperties",
165
- value: function setProperties(state, layerID, properties) {
166
- state = state.mergeIn(['scene', 'layers', layerID], properties);
167
- state = state.updateIn(['scene', 'layers'], function (layers) {
168
- return layers.sort(function (a, b) {
169
- return a.altitude !== b.altitude ? a.altitude - b.altitude : a.order - b.order;
170
- });
171
- });
172
- return {
173
- updatedState: state
174
- };
175
- }
176
- }, {
177
- key: "remove",
178
- value: function remove(state, layerID) {
179
- state = state.removeIn(['scene', 'layers', layerID]);
180
- state = state.setIn(['scene', 'selectedLayer'], state.scene.selectedLayer !== layerID ? state.scene.selectedLayer : state.scene.layers.first().id);
181
- return {
182
- updatedState: state
183
- };
184
- }
185
- }, {
186
- key: "removeElement",
187
- value: function removeElement(state, layerID, elementPrototype, elementID) {
188
- state = state.deleteIn(['scene', 'layers', layerID, elementPrototype, elementID]);
189
- return {
190
- updatedState: state
191
- };
192
- }
193
- }, {
194
- key: "lineInterior",
195
- value: function lineInterior(relatedLine, line, changeLines, vertices, allLines, checkLines) {
196
- var _this = this;
197
- if (line.vertices[1] === relatedLine.vertices[1] || line.vertices[0] === relatedLine.vertices[0]) {
198
- var tmp = line.vertices[0];
199
- line.vertices[0] = line.vertices[1];
200
- line.vertices[1] = tmp;
201
- changeLines.push(line);
202
- }
203
- checkLines.push(relatedLine);
204
- checkLines.push(line);
205
- var relatedLines = [];
206
- _export2.GeometryUtils.getRelatedLines(relatedLines, line, vertices, allLines);
207
- var delflag = false;
208
- if ((0, _helper.isEmpty)(allLines[line.id])) {
209
- delflag = true;
210
- }
211
- if (relatedLines.length > 1) {
212
- var _loop = function _loop(i) {
213
- if (!changeLines.some(function (line) {
214
- return line.id === relatedLines[i].id;
215
- }) && !checkLines.some(function (cline) {
216
- return cline.id === relatedLines[i].id;
217
- })) {
218
- var tline = delflag ? relatedLine : line;
219
- _this.lineInterior(tline, relatedLines[i], changeLines, vertices, allLines, checkLines);
220
- }
221
- };
222
- for (var i = 0; i < relatedLines.length; i++) {
223
- _loop(i);
224
- }
225
- } else return;
226
- }
227
- }, {
228
- key: "interiorsurfacedetect",
229
- value: function interiorsurfacedetect(state, drawingLine, vertices, allLineArray, layerID) {
230
- var relatedLines = [];
231
- var allLines = allLineArray.toJS();
232
- _export2.GeometryUtils.getRelatedLines(relatedLines, drawingLine, vertices, allLines);
233
- if ((0, _helper.isEmpty)(relatedLines)) {
234
- return {
235
- updatedState: state
236
- };
237
- }
238
- var changeLines = [];
239
- var checkLines = [];
240
- this.lineInterior(relatedLines[0], drawingLine, changeLines, vertices, allLines, checkLines);
241
- for (var i = 0; i < changeLines.length; i++) {
242
- // if (changeLines[i].vertices.length === 2)
243
- if (!(0, _helper.isEmpty)(allLines[changeLines[i].id])) {
244
- state = state.mergeIn(['scene', 'layers', layerID, 'lines', changeLines[i].id, 'vertices'], changeLines[i].vertices);
245
- }
246
- }
247
- // determine the interior surface
248
- var alltriangles = [];
249
- var interiorLines = state.getIn(['scene', 'layers', layerID, 'lines']);
250
- var tallLines = interiorLines.toJS();
251
- var tallLinesArray = interiorLines.toArray();
252
- var reverseLines = [];
253
- tallLinesArray.forEach(function (tline) {
254
- var line = tline.toJS();
255
- var relatedLines = [];
256
- _export2.GeometryUtils.getRelatedLines(relatedLines, line, vertices, tallLines);
257
- relatedLines.forEach(function (relLine) {
258
- if (relLine.vertices[0] === line.vertices[1]) {
259
- if (!reverseLines.some(function (reverseLine) {
260
- return reverseLine.id === relLine.id;
261
- })) {
262
- reverseLines.push(relLine);
263
- }
264
- if (!reverseLines.some(function (reverseLine) {
265
- return reverseLine.id === line.id;
266
- })) {
267
- reverseLines.push(line);
268
- }
269
- // get the three points of triangle
270
- var x1 = vertices[line.vertices[0]].x;
271
- var y1 = vertices[line.vertices[0]].y;
272
- var x2 = vertices[line.vertices[1]].x;
273
- var y2 = vertices[line.vertices[1]].y;
274
- var x3 = vertices[relLine.vertices[1]].x;
275
- var y3 = vertices[relLine.vertices[1]].y;
276
- // calculate the area of triangle
277
- var triArea = Math.abs((y1 + y3) * (x3 - x1) - (y1 + y2) * (x2 - x1) - (y3 + y2) * (x3 - x2)) / 2;
278
- var triangle = {
279
- points: [{
280
- x: x1,
281
- y: y1
282
- }, {
283
- x: x2,
284
- y: y2
285
- }, {
286
- x: x3,
287
- y: y3
288
- }],
289
- area: triArea
290
- };
291
- // determine the + or - symbol of triangle
292
- var area = 0;
293
- for (var _i = 0; _i < 3; _i++) {
294
- var j = (_i + 1) % 3;
295
- area += triangle.points[_i].x * triangle.points[j].y;
296
- area -= triangle.points[j].x * triangle.points[_i].y;
297
- }
298
- if (area > 0) {
299
- triangle.area = -triangle.area;
300
- }
301
- alltriangles.push(triangle);
302
- }
303
- });
304
- });
305
- var reverse = false;
306
- var allSum = 0;
307
- alltriangles.forEach(function (triangle) {
308
- allSum += triangle.area;
309
- });
310
- // if all sum of triangle's area is smaller than zero, all walls have to be inverted.
311
- if (allSum >= 0) {
312
- reverse = false;
313
- } else reverse = true;
314
- if (reverse) {
315
- reverseLines.forEach(function (line) {
316
- var tmp = line.vertices[0];
317
- line.vertices[0] = line.vertices[1];
318
- line.vertices[1] = tmp;
319
- state = state.mergeIn(['scene', 'layers', layerID, 'lines', line.id, 'vertices'], line.vertices);
320
- });
321
- }
322
- return {
323
- updatedState: state
324
- };
325
- }
326
- }, {
327
- key: "detectAndUpdateAreas",
328
- value: function detectAndUpdateAreas(state, layerID, drawingInfor) {
329
- var verticesArray = []; //array with vertices coords
330
- var linesArray;
331
- var virtualArray = []; //array with edges
332
-
333
- var vertexID_to_verticesArrayIndex = {};
334
- var verticesArrayIndex_to_vertexID = {};
335
- state.getIn(['scene', 'layers', layerID, 'vertices']).forEach(function (vertex) {
336
- var verticesCount = verticesArray.push([vertex.x, vertex.y]);
337
- var latestVertexIndex = verticesCount - 1;
338
- vertexID_to_verticesArrayIndex[vertex.id] = latestVertexIndex;
339
- verticesArrayIndex_to_vertexID[latestVertexIndex] = vertex.id;
340
- });
341
- var vertexCount = verticesArray.length;
342
- var vitual = {};
343
- linesArray = state.getIn(['scene', 'layers', layerID, 'lines']).map(function (line) {
344
- return line.vertices.map(function (vertexID) {
345
- return vertexID_to_verticesArrayIndex[vertexID];
346
- }).toArray();
347
- });
348
-
349
- //open line
350
- // if (vertexCount > 1 && !linesArray.some(line => (line[0]==0 && line[1]==vertexCount-1) || (line[1]==0 && line[0]==vertexCount-1))) {
351
- // linesArray = linesArray.set(IDBroker.acquireID(), [0, vertexCount-1]);
352
- // }
353
- var innerCyclesByVerticesArrayIndex = _export2.GraphInnerCycles.calculateInnerCycles(verticesArray, linesArray);
354
- var innerCyclesByVerticesID = new _immutable.List(innerCyclesByVerticesArrayIndex).map(function (cycle) {
355
- return new _immutable.List(cycle.map(function (vertexIndex) {
356
- return verticesArrayIndex_to_vertexID[vertexIndex];
357
- }));
358
- });
359
- // All area vertices should be ordered in counterclockwise order
360
- innerCyclesByVerticesID = innerCyclesByVerticesID.map(function (area) {
361
- return _export2.GraphInnerCycles.isClockWiseOrder(area.map(function (vertexID) {
362
- return state.getIn(['scene', 'layers', layerID, 'vertices', vertexID]);
363
- })) ? area.reverse() : area;
364
- });
365
- var areaIDs = [];
366
-
367
- //remove areas
368
- state.getIn(['scene', 'layers', layerID, 'areas']).forEach(function (area) {
369
- var areaInUse = innerCyclesByVerticesID.some(function (vertices) {
370
- return sameDirection(vertices, area.vertices);
371
- });
372
- if (!areaInUse) {
373
- state = _export.Area.remove(state, layerID, area.id).updatedState;
374
- }
375
- });
376
-
377
- //add new areas
378
- innerCyclesByVerticesID.forEach(function (cycle, ind) {
379
- var areaInUse = state.getIn(['scene', 'layers', layerID, 'areas']).find(function (area) {
380
- return sameDirection(area.vertices, cycle);
381
- });
382
- if (areaInUse) {
383
- areaIDs[ind] = areaInUse.id;
384
- state = state.setIn(['scene', 'layers', layerID, 'areas', areaIDs[ind], 'holes'], new _immutable.List());
385
- } else {
386
- var areaVerticesCoords = cycle.map(function (vertexID) {
387
- return state.getIn(['scene', 'layers', layerID, 'vertices', vertexID]);
388
- });
389
- var resultAdd = _export.Area.add(state, layerID, 'area', areaVerticesCoords, state.catalog);
390
- areaIDs[ind] = resultAdd.area.id;
391
- state = resultAdd.updatedState;
392
- }
393
- });
394
-
395
- // Build a relationship between areas and their coordinates
396
- var verticesCoordsForArea = areaIDs.map(function (id) {
397
- var vertices = state.getIn(['scene', 'layers', layerID, 'areas', id]).vertices.map(function (vertexID) {
398
- var _state$getIn2 = state.getIn(['scene', 'layers', layerID, 'vertices', vertexID]),
399
- x = _state$getIn2.x,
400
- y = _state$getIn2.y;
401
- return new _immutable.List([x, y]);
402
- });
403
- return {
404
- id: id,
405
- vertices: vertices
406
- };
407
- });
408
-
409
- // Find all holes for an area
410
- var i, j;
411
- for (i = 0; i < verticesCoordsForArea.length; i++) {
412
- var holesList = new _immutable.List(); // The holes for this area
413
- var areaVerticesList = verticesCoordsForArea[i].vertices.flatten().toArray();
414
- for (j = 0; j < verticesCoordsForArea.length; j++) {
415
- if (i !== j) {
416
- var isHole = _export2.GeometryUtils.ContainsPoint(areaVerticesList, verticesCoordsForArea[j].vertices.get(0).get(0), verticesCoordsForArea[j].vertices.get(0).get(1));
417
- if (isHole) {
418
- holesList = holesList.push(verticesCoordsForArea[j].id);
419
- }
420
- }
421
- }
422
- state = state.setIn(['scene', 'layers', layerID, 'areas', verticesCoordsForArea[i].id, 'holes'], holesList);
423
- }
424
-
425
- // Remove holes which are already holes for other areas
426
- areaIDs.forEach(function (areaID) {
427
- var doubleHoles = new Set();
428
- var areaHoles = state.getIn(['scene', 'layers', layerID, 'areas', areaID, 'holes']);
429
- areaHoles.forEach(function (areaHoleID) {
430
- var holesOfholes = state.getIn(['scene', 'layers', layerID, 'areas', areaHoleID, 'holes']);
431
- holesOfholes.forEach(function (holeID) {
432
- if (areaHoles.indexOf(holeID) !== -1) doubleHoles.add(holeID);
433
- });
434
- });
435
- doubleHoles.forEach(function (doubleHoleID) {
436
- areaHoles = areaHoles.remove(areaHoles.indexOf(doubleHoleID));
437
- });
438
- state = state.setIn(['scene', 'layers', layerID, 'areas', areaID, 'holes'], areaHoles);
439
- });
440
-
441
- // update direction of lines surrounding area
442
- var layer = state.getIn(['scene', 'layers', layerID]);
443
- var allAreaLines = _export2.GeometryUtils.getAllAreaLines(layer);
444
- // check whether the room is colsed. in this case, the allAreaLines have some values and if doesn't close, this value has nothing.
445
- layer.lines.forEach(function (line) {
446
- allAreaLines.some(function (l) {
447
- if (line.vertices.get(0) == l[0] && line.vertices.get(1) == l[1]) {
448
- state = state.setIn(['scene', 'layers', layerID, 'lines', line.id, 'vertices', 0], l[1]);
449
- state = state.setIn(['scene', 'layers', layerID, 'lines', line.id, 'vertices', 1], l[0]);
450
- return true;
451
- } else if (line.vertices.get(1) == l[0] && line.vertices.get(0) == l[1]) {
452
- return true;
453
- } else {
454
- return false;
455
- }
456
- });
457
- });
458
-
459
- //
460
- var separatedLine = [];
461
- var allLinesArray = state.getIn(['scene', 'layers', layerID, 'lines']);
462
- allLinesArray.forEach(function (line) {
463
- var isAreaLine = false;
464
- isAreaLine = allAreaLines.some(function (areaLine) {
465
- if (areaLine[0] == line.vertices.get(0) && areaLine[1] == line.vertices.get(1) || areaLine[0] == line.vertices.get(1) && areaLine[1] == line.vertices.get(0)) return true;
466
- });
467
- // console.log(
468
- // 'Layer_Vertices',
469
- // layer.vertices.get(line.vertices.get(0)).toJS()
470
- // );
471
- if (!isAreaLine) {
472
- if (!(_export2.GeometryUtils.isPointInArea(_export2.GeometryUtils.getAllArea(layer), layer.vertices.get(line.vertices.get(0))) && _export2.GeometryUtils.isPointInArea(_export2.GeometryUtils.getAllArea(layer), layer.vertices.get(line.vertices.get(1))))) {
473
- separatedLine.push(line);
474
- }
475
- }
476
- });
477
- var separatedLineCnt = separatedLine.length;
478
- if (separatedLineCnt == 1) {
479
- separatedLine.forEach(function (line) {
480
- var ptArray = [],
481
- pt3 = [],
482
- pt4 = [];
483
- ptArray.push(verticesArray[vertexID_to_verticesArrayIndex[line.vertices.get(0)]]);
484
- ptArray.push(verticesArray[vertexID_to_verticesArrayIndex[line.vertices.get(1)]]);
485
- pt3.push(ptArray[1][1] - ptArray[0][1] + ptArray[1][0]);
486
- pt3.push(ptArray[0][0] - ptArray[1][0] + ptArray[1][1]);
487
- ptArray.push(pt3);
488
- pt4.push(ptArray[0][0] + ptArray[2][0] - ptArray[1][0]);
489
- pt4.push(ptArray[0][1] + ptArray[2][1] - ptArray[1][1]);
490
- ptArray.push(pt4);
491
- var pointArray = [];
492
- ptArray.forEach(function (pt) {
493
- var point = {
494
- x: pt[0],
495
- y: pt[1]
496
- };
497
- pointArray.push(point);
498
- });
499
- pointArray.reverse();
500
- var resultAdd = _export.Area.add(state, layerID, 'area', pointArray, state.catalog);
501
- state = resultAdd.updatedState;
502
- });
503
- } else if (separatedLineCnt > 1) {
504
- var ptXArray = [],
505
- ptYArray = [],
506
- ptXMin,
507
- ptXMax,
508
- ptYMin,
509
- ptYMAX;
510
- separatedLine.forEach(function (line) {
511
- ptXArray.push(verticesArray[vertexID_to_verticesArrayIndex[line.vertices.get(0)]][0]);
512
- ptXArray.push(verticesArray[vertexID_to_verticesArrayIndex[line.vertices.get(1)]][0]);
513
- ptYArray.push(verticesArray[vertexID_to_verticesArrayIndex[line.vertices.get(0)]][1]);
514
- ptYArray.push(verticesArray[vertexID_to_verticesArrayIndex[line.vertices.get(1)]][1]);
515
- });
516
- ptXMin = Math.min.apply(null, ptXArray);
517
- ptXMax = Math.max.apply(null, ptXArray);
518
- ptYMin = Math.min.apply(null, ptYArray);
519
- ptYMAX = Math.max.apply(null, ptYArray);
520
- var pointArray = [];
521
- pointArray.push({
522
- x: ptXMin,
523
- y: ptYMin
524
- });
525
- pointArray.push({
526
- x: ptXMax,
527
- y: ptYMin
528
- });
529
- pointArray.push({
530
- x: ptXMax,
531
- y: ptYMAX
532
- });
533
- pointArray.push({
534
- x: ptXMin,
535
- y: ptYMAX
536
- });
537
- var resultAdd = _export.Area.add(state, layerID, 'area', pointArray, state.catalog);
538
- state = resultAdd.updatedState;
539
- if (!(0, _helper.isEmpty)(drawingInfor)) {
540
- var allVertices = state.getIn(['scene', 'layers', layerID, 'vertices']);
541
- var resultInterior = this.interiorsurfacedetect(state, drawingInfor.drawingLine.toJS(), allVertices.toJS(), allLinesArray, layerID);
542
- if (!(0, _helper.isEmpty)(resultInterior)) {
543
- state = resultInterior.updatedState;
544
- }
545
- }
546
- }
547
- return {
548
- updatedState: state
549
- };
550
- }
551
- }, {
552
- key: "removeZeroLengthLines",
553
- value: function removeZeroLengthLines(state, layerID) {
554
- var updatedState = state.getIn(['scene', 'layers', layerID, 'lines']).reduce(function (newState, line) {
555
- var v_id0 = line.getIn(['vertices', 0]);
556
- var v_id1 = line.getIn(['vertices', 1]);
557
- var v0 = newState.getIn(['scene', 'layers', layerID, 'vertices', v_id0]);
558
- var v1 = newState.getIn(['scene', 'layers', layerID, 'vertices', v_id1]);
559
- if (_export2.GeometryUtils.verticesDistance(v0, v1) === 0) {
560
- newState = _export.Line.remove(newState, layerID, line.id).updatedState;
561
- }
562
- return newState;
563
- }, state);
564
- return {
565
- updatedState: updatedState
566
- };
567
- }
568
- }, {
569
- key: "mergeEqualsVertices",
570
- value: function mergeEqualsVertices(state, layerID, vertexID) {
571
- //1. find vertices to remove
572
- var vertex = state.getIn(['scene', 'layers', layerID, 'vertices', vertexID]);
573
- if (vertex === undefined || vertex === null) return {
574
- updatedState: state
575
- };
576
- var doubleVertices = state.getIn(['scene', 'layers', layerID, 'vertices']).filter(function (v) {
577
- return v.id !== vertexID && _export2.GeometryUtils.samePoints(vertex, v) // &&
578
- //!v.lines.contains( vertexID ) &&
579
- //!v.areas.contains( vertexID )
580
- ;
581
- });
582
- if (doubleVertices.isEmpty()) return {
583
- updatedState: state
584
- };
585
- doubleVertices.forEach(function (doubleVertex) {
586
- var reduced = doubleVertex.lines.reduce(function (reducedState, lineID) {
587
- reducedState = reducedState.updateIn(['scene', 'layers', layerID, 'lines', lineID, 'vertices'], function (vertices) {
588
- if (vertices) {
589
- return vertices.map(function (v) {
590
- return v === doubleVertex.id ? vertexID : v;
591
- });
592
- }
593
- });
594
- reducedState = _export.Vertex.addElement(reducedState, layerID, vertexID, 'lines', lineID).updatedState;
595
- return reducedState;
596
- }, state);
597
- var biReduced = doubleVertex.areas.reduce(function (reducedState, areaID) {
598
- reducedState = reducedState.updateIn(['scene', 'layers', layerID, 'areas', areaID, 'vertices'], function (vertices) {
599
- if (vertices) return vertices.map(function (v) {
600
- return v === doubleVertex.id ? vertexID : v;
601
- });
602
- });
603
- reducedState = _export.Vertex.addElement(reducedState, layerID, vertexID, 'areas', areaID).updatedState;
604
- return reducedState;
605
- }, reduced);
606
- state = _export.Vertex.remove(biReduced, layerID, doubleVertex.id, null, null, true).updatedState;
607
- });
608
- return {
609
- updatedState: state
610
- };
611
- }
612
- }, {
613
- key: "setPropertiesOnSelected",
614
- value: function setPropertiesOnSelected(state, layerID, properties) {
615
- var selected = state.getIn(['scene', 'layers', layerID, 'selected']);
616
- selected.lines.forEach(function (lineID) {
617
- return state = _export.Line.setProperties(state, layerID, lineID, properties).updatedState;
618
- });
619
- selected.holes.forEach(function (holeID) {
620
- return state = _export.Hole.setProperties(state, layerID, holeID, properties).updatedState;
621
- });
622
- selected.areas.forEach(function (areaID) {
623
- return state = _export.Area.setProperties(state, layerID, areaID, properties).updatedState;
624
- });
625
- selected.items.forEach(function (itemID) {
626
- return state = _export.Item.setProperties(state, layerID, itemID, properties).updatedState;
627
- });
628
- return {
629
- updatedState: state
630
- };
631
- }
632
- }, {
633
- key: "updatePropertiesOnSelected",
634
- value: function updatePropertiesOnSelected(state, layerID, properties) {
635
- var selected = state.getIn(['scene', 'layers', layerID, 'selected']);
636
- selected.lines.forEach(function (lineID) {
637
- return state = _export.Line.updateProperties(state, layerID, lineID, properties).updatedState;
638
- });
639
- selected.holes.forEach(function (holeID) {
640
- return state = _export.Hole.updateProperties(state, layerID, holeID, properties).updatedState;
641
- });
642
- selected.areas.forEach(function (areaID) {
643
- return state = _export.Area.updateProperties(state, layerID, areaID, properties).updatedState;
644
- });
645
- selected.items.forEach(function (itemID) {
646
- return state = _export.Item.updateProperties(state, layerID, itemID, properties).updatedState;
647
- });
648
- return {
649
- updatedState: state
650
- };
651
- }
652
- }, {
653
- key: "setAttributesOnSelected",
654
- value: function setAttributesOnSelected(state, layerID, attributes) {
655
- var selected = state.getIn(['scene', 'layers', layerID, 'selected']);
656
- selected.lines.forEach(function (lineID) {
657
- return state = _export.Line.setAttributes(state, layerID, lineID, attributes).updatedState;
658
- });
659
- selected.holes.forEach(function (holeID) {
660
- return state = _export.Hole.setAttributes(state, layerID, holeID, attributes).updatedState;
661
- });
662
- selected.items.forEach(function (itemID) {
663
- return state = _export.Item.setAttributes(state, layerID, itemID, attributes).updatedState;
664
- });
665
- //selected.areas.forEach(areaID => state = Area.setAttributes( state, layerID, areaID, attributes ).updatedState);
666
-
667
- return {
668
- updatedState: state
669
- };
670
- }
671
- }]);
672
- }();