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,34 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports["default"] = void 0;
7
- exports.getEdgesOfSubgraphs = getEdgesOfSubgraphs;
8
- exports.getVerticesFromBiconnectedComponent = getVerticesFromBiconnectedComponent;
9
- function getEdgesOfSubgraphs(subgraphs, graph) {
10
- var edges = [];
11
- subgraphs.forEach(function (component) {
12
- edges.push([]);
13
- var vertices = getVerticesFromBiconnectedComponent(component);
14
- var inserted = [];
15
- vertices.forEach(function (vertex) {
16
- var adjacents = graph.adj[vertex];
17
- adjacents.forEach(function (adj) {
18
- if (vertex <= adj && vertices.has(adj)) {
19
- edges[edges.length - 1].push([vertex, adj]);
20
- }
21
- });
22
- });
23
- });
24
- return edges;
25
- }
26
- function getVerticesFromBiconnectedComponent(component) {
27
- var vertices = new Set();
28
- component.forEach(function (edge) {
29
- vertices.add(edge.u);
30
- vertices.add(edge.v);
31
- });
32
- return vertices;
33
- }
34
- var _default = exports["default"] = getEdgesOfSubgraphs;
@@ -1,240 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.compute_ev_mapping = compute_ev_mapping;
7
- exports.compute_incidences = compute_incidences;
8
- exports["default"] = void 0;
9
- exports.find_cycles = find_cycles;
10
- exports.find_inner_cycles = find_inner_cycles;
11
- /**
12
- * UTILS
13
- */
14
-
15
- function sub(v1, v2) {
16
- return [v1[0] - v2[0], v1[1] - v2[1]];
17
- }
18
- function mod(n, m) {
19
- return (n % m + m) % m;
20
- }
21
-
22
- /**
23
- * CYCLES
24
- */
25
-
26
- function compute_ev_mapping(EV) {
27
- var ev_mapping = EV.map(function (ev) {
28
- return {
29
- ev: ev,
30
- color: 0,
31
- direction: -1
32
- };
33
- });
34
- return ev_mapping;
35
- }
36
- function compute_angle(P, V) {
37
- var point = sub(V, P);
38
- var angle = Math.atan2(point[1], point[0]);
39
- return angle;
40
- }
41
- function compute_incidences(V, EV) {
42
- var incidences = V.map(function (vertex, i) {
43
- var incidence = [];
44
- EV.forEach(function (edge, j) {
45
- var endpoint;
46
- var position;
47
- if (edge[0] === i) {
48
- endpoint = edge[1];
49
- position = 1;
50
- }
51
- if (edge[1] === i) {
52
- endpoint = edge[0];
53
- position = 0;
54
- }
55
- endpoint !== undefined && incidence.push({
56
- index: j,
57
- endpoint: endpoint,
58
- angle: compute_angle(vertex, V[endpoint]),
59
- edge: edge,
60
- position: position
61
- });
62
- });
63
- incidence.sort(function (i1, i2) {
64
- return i2.angle - i1.angle;
65
- });
66
- return incidence;
67
- });
68
- return incidences;
69
- }
70
- function get_starting_edge(incidences, ev_mapping) {
71
- var e;
72
- var position;
73
- var direction;
74
- for (e = 0; e < ev_mapping.length; e += 1) {
75
- if (ev_mapping[e].color < 2) {
76
- direction = -1 * ev_mapping[e].direction;
77
- color(ev_mapping, e, direction);
78
- return {
79
- edge: e,
80
- direction: direction,
81
- position: direction === -1 ? 0 : 1
82
- };
83
- }
84
- }
85
- }
86
- function get_next_edge(incidences, edge, position, EV) {
87
- var items = incidences[EV[edge][position]];
88
- //console.log(items, incidences, EV, edge, position);
89
- var n_items = items.length;
90
- var item;
91
- var out;
92
- var j;
93
- for (j = 0; j < n_items; j += 1) {
94
- item = items[j];
95
- if (item.index === edge) {
96
- out = items[mod(j + 1, items.length)];
97
- return {
98
- edge: out.index,
99
- vertex: out.endpoint,
100
- position: out.position,
101
- direction: out.position ? 1 : -1
102
- };
103
- }
104
- }
105
- }
106
- function color(ev_mapping, index, direction) {
107
- ev_mapping[index].color += 1;
108
- ev_mapping[index].direction = direction;
109
- }
110
- function find_cycles(V, EV) {
111
- var ev_mapping = compute_ev_mapping(EV);
112
- var incidences = compute_incidences(V, EV);
113
- var V_cycles = [];
114
- var E_cycles = [];
115
- var dir_E_cycles = [];
116
- var V_cycle;
117
- var E_cycle;
118
- var dir_E_cycle;
119
- var next;
120
- var counter = 0;
121
- var start = get_starting_edge(incidences, ev_mapping);
122
- while (start !== undefined) {
123
- V_cycle = [EV[start.edge][mod(start.position + 1, 2)], EV[start.edge][start.position]];
124
- E_cycle = [start.edge];
125
- dir_E_cycle = [start.direction];
126
- next = get_next_edge(incidences, start.edge, start.position, EV);
127
- while (next.edge !== start.edge) {
128
- V_cycle.push(next.vertex);
129
- E_cycle.push(next.edge);
130
- dir_E_cycle.push(next.direction);
131
- color(ev_mapping, next.edge, next.direction);
132
- next = get_next_edge(incidences, next.edge, next.position, EV);
133
- }
134
- E_cycles.push(E_cycle);
135
- V_cycles.push(V_cycle);
136
- dir_E_cycles.push(dir_E_cycle);
137
-
138
- //console.log('############## CYCLE ', ++counter)
139
- //console.log('EDGES:', E_cycle)
140
- //console.log('VERTICES:', V_cycle)
141
- //console.log('START', 'edge:', start.edge, 'position:', start.position)
142
- //console.log('COUNTER:', ev_mapping.map(e => e.color), ev_mapping.map(e => e.color).reduce((a, b) => a + b));
143
- //console.log('\n')
144
-
145
- start = get_starting_edge(incidences, ev_mapping);
146
- }
147
- return {
148
- v_cycles: V_cycles,
149
- e_cycles: E_cycles,
150
- dir_e_cycles: dir_E_cycles,
151
- ev_mapping: ev_mapping
152
- };
153
- }
154
- function find_short_cycles_indexes(v_cycles, e_cycles) {
155
- var indexes = [];
156
- var e_cycle;
157
- var v_cycle;
158
- var i;
159
- for (i = 0; i < e_cycles.length; i += 1) {
160
- e_cycle = e_cycles[i];
161
- v_cycle = v_cycles[i];
162
- if (e_cycle.length < 3 || v_cycle[0] !== v_cycle[v_cycle.length - 1]) {
163
- indexes.push(i);
164
- }
165
- }
166
- return indexes;
167
- }
168
- function find_inner_cycles(V, EV) {
169
- var cycles = find_cycles(V, EV);
170
- var v_cycles = cycles.v_cycles;
171
- var e_cycles = cycles.e_cycles;
172
- var short_cycles_indexes = find_short_cycles_indexes(v_cycles, e_cycles);
173
- short_cycles_indexes.forEach(function (indx) {
174
- v_cycles.splice(indx, 1);
175
- e_cycles.splice(indx, 1);
176
- });
177
- var dir_e_cycles = cycles.dir_e_cycles;
178
- var rooms_values = cycles.e_cycles.map(function (cycle, i) {
179
- return cycle.map(function (edge, j) {
180
- var v1;
181
- var v2;
182
- var dir = dir_e_cycles[i][j] > 0;
183
- if (dir > 0) {
184
- v1 = EV[edge][0];
185
- v2 = EV[edge][1];
186
- } else {
187
- v1 = EV[edge][1];
188
- v2 = EV[edge][0];
189
- }
190
- return (V[v2][0] - V[v1][0]) * (V[v2][1] + V[v1][1]);
191
- });
192
- });
193
- var rooms_sums = rooms_values.map(function (room) {
194
- return room.reduce(function (a, b) {
195
- return a + b;
196
- });
197
- });
198
- var positive_count = rooms_sums.filter(function (sum) {
199
- return sum > 0;
200
- }).length;
201
- var negative_count = rooms_sums.length - positive_count;
202
- var rm_neg = positive_count >= negative_count ? 1 : -1;
203
- return {
204
- v_cycles: cycles.v_cycles.filter(function (v, i) {
205
- return rm_neg * rooms_sums[i] > 0;
206
- }),
207
- e_cycles: cycles.e_cycles.filter(function (v, i) {
208
- return rm_neg * rooms_sums[i] > 0;
209
- }),
210
- ev_mapping: cycles.ev_mapping
211
- };
212
- }
213
- var _default = exports["default"] = find_inner_cycles;
214
- /**
215
- * DATA
216
- */
217
- // let V = [[0.5774, 1.0], [1.0, 1.0], [1.1547, 0.0], [1.0, 0.0], [0.0, 0.0], [0.0, 0.732], [1.0, 0.1547], [0.732, 0.0], [1.0491, 0.183], [-0.317, 0.549], [1.0, 0.268], [0.183, -0.3169], [0.5491, 1.049], [0.4642, 1.0], [0.0, -0.4226], [0.0, 1.0]]
218
- // let EV = [[0, 1], [2, 3], [5, 4], [7, 6], [2, 8], [3, 6], [4, 9], [0, 10], [9, 5], [8, 10], [7, 11], [12, 13], [6, 8], [6, 10], [4, 7], [4, 11], [4, 14], [5, 15], [11, 14], [0, 12], [13, 15], [0, 13], [1, 10], [3, 7], [5, 13]]
219
- // let V = [[0,0],[10,0],[10,10],[0,10], [100,100],[110,100],[110,110],[100,110], [5,0], [5,10]]
220
- // let V = [[0,0.5],[12,-0.7],[14,14],[-2,10], [103,106],[117,98],[96,112],[104,109], [5.5,0.8], [4.8,10.5]]
221
- // let EV = [[3,9],[9,2],[2,1],[1,8],[8,0],[0,3],[8,9]] // IT WORKS
222
- // let EV = [[3,9],[9,2],[2,1],[1,8],[8,0],[0,3],[8,9], [5,6], [6,7], [2,5]] // IT DOESN'T WORK
223
- // let EV = [[3,2],[2,1],[1,0],[0,3]] // IT WORKS
224
- // let EV = [[2,3],[1,2],[0,1],[3,0]] // IT WORKS
225
- // let EV = [[2,3],[1,2],[0,1],[3,0],[6,7],[5,6],[4,5],[7,4]] // IT WORKS
226
- // let EV = [[3,2],[2,1],[1,0],[0,3],[7,6],[6,5],[5,4],[4,7]] // IT WORKS
227
- // let V = [[2,5],[5,6],[10,6.8],[23,8],[9.6,11.3],[20,15],[25,16],[29,18],[30,22],[4,11],[6,10],[24,25],[18,20],[27,7]]
228
- // let EV = [[0,1],[10,0],[9,10],[9,1],[1,2],[4,2],[3,13],[2,3],[4,5],[5,6],[6,7],[12,5],[12,11],[11,6],[11,8],[7,8],[9,4]]
229
- /**
230
- * MAIN
231
- */
232
- // let cycles_data = find_inner_cycles(V, EV)
233
- // console.log('############## OUTPUT')
234
- // console.log('EDGES:')
235
- // console.log(cycles_data.e_cycles)
236
- // console.log('\n')
237
- // console.log('VERTICES:')
238
- // console.log(cycles_data.v_cycles)
239
- // console.log('\n')
240
- // console.log(cycles_data.ev_mapping.every(m => m.color === 2))
@@ -1,54 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.calculateInnerCycles = calculateInnerCycles;
7
- exports.isClockWiseOrder = isClockWiseOrder;
8
- var _graph = _interopRequireDefault(require("./graph"));
9
- var _getEdgesOfSubgraphs = _interopRequireDefault(require("./get-edges-of-subgraphs"));
10
- var _graphCycles = _interopRequireDefault(require("./graph-cycles"));
11
- var _immutable = require("immutable");
12
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
13
- function calculateInnerCycles(verticesArray, edgesArray) {
14
- var innerCycles = new _immutable.List();
15
- var graph = new _graph["default"](verticesArray.length);
16
- edgesArray.forEach(function (line) {
17
- graph.addEdge(line[0], line[1]);
18
- graph.addEdge(line[1], line[0]);
19
- });
20
- graph.BCC();
21
- var subgraphs = graph.subgraphs.filter(function (subgraph) {
22
- return subgraph.length >= 3;
23
- });
24
- var edgesOfSubgraphsArray = (0, _getEdgesOfSubgraphs["default"])(subgraphs, graph);
25
- var edges = [];
26
- edgesOfSubgraphsArray.forEach(function (es) {
27
- es.forEach(function (edge) {
28
- return edges.push(edge);
29
- });
30
- });
31
- var cycles = (0, _graphCycles["default"])(verticesArray, edges);
32
- cycles.v_cycles.forEach(function (cycle) {
33
- cycle.shift();
34
- innerCycles = innerCycles.push(cycle);
35
- });
36
- return innerCycles;
37
- }
38
- function isClockWiseOrder(innerCycleWithCoords) {
39
- // See: https://stackoverflow.com/a/1165943 and http://blog.element84.com/polygon-winding.html
40
-
41
- var i = 0;
42
- var twiceEnclosedArea = 0;
43
- var size = innerCycleWithCoords.size;
44
- for (i = 0; i < size; i++) {
45
- var _innerCycleWithCoords = innerCycleWithCoords.get(i),
46
- x1 = _innerCycleWithCoords.x,
47
- y1 = _innerCycleWithCoords.y;
48
- var _innerCycleWithCoords2 = innerCycleWithCoords.get((i + 1) % size),
49
- x2 = _innerCycleWithCoords2.x,
50
- y2 = _innerCycleWithCoords2.y;
51
- twiceEnclosedArea += (x2 - x1) * (y2 + y1);
52
- }
53
- return twiceEnclosedArea > 0;
54
- }
@@ -1,157 +0,0 @@
1
- "use strict";
2
-
3
- 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); }
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.Graph = exports.Edge = void 0;
8
- exports.create_array = create_array;
9
- exports["default"] = void 0;
10
- 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); } }
11
- function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
12
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
13
- 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); }
14
- function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
15
- //JS porting of this code http://www.geeksforgeeks.org/biconnected-components/
16
-
17
- function create_array(length) {
18
- var array = [];
19
- for (var i = 0; i < length; ++i) {
20
- array.push([]);
21
- }
22
- return array;
23
- }
24
- var Edge = exports.Edge = /*#__PURE__*/_createClass(function Edge(u, v) {
25
- _classCallCheck(this, Edge);
26
- this.u = u;
27
- this.v = v;
28
- });
29
- var Graph = exports.Graph = /*#__PURE__*/function () {
30
- function Graph(v) {
31
- _classCallCheck(this, Graph);
32
- this.count = 0; // count is number of biconnected components
33
- this.subgraphs = []; //biconnected components
34
- this.time = 0; // time is used to find discovery times
35
-
36
- this.V = v; // No. of vertices
37
- this.E = 0; // No. of Edges
38
- this.adj = []; // Adjacency List
39
-
40
- this.adj = create_array(v);
41
- }
42
-
43
- //Function to add an edge into the graph
44
- return _createClass(Graph, [{
45
- key: "addEdge",
46
- value: function addEdge(v, w) {
47
- this.adj[v].push(w);
48
- this.E++;
49
- }
50
-
51
- // A recursive function that finds and prints strongly connected
52
- // components using DFS traversal
53
- // u --> The vertex to be visited next
54
- // disc[] --> Stores discovery times of visited vertices
55
- // low[] -- >> earliest visited vertex (the vertex with minimum
56
- // discovery time) that can be reached from subtree
57
- // rooted with current vertex
58
- // *st -- >> To store visited edges
59
- // // A recursive function that finds and prints strongly connected
60
- // components using DFS traversal
61
- // u --> The vertex to be visited next
62
- // disc[] --> Stores discovery times of visited vertices
63
- // low[] -- >> earliest visited vertex (the vertex with minimum
64
- // discovery time) that can be reached from subtree
65
- // rooted with current vertex
66
- // *st -- >> To store visited edges
67
- }, {
68
- key: "_BCCUtil",
69
- value: function _BCCUtil(u, disc, low, st, parent) {
70
- var _this = this;
71
- // Initialize discovery time and low value
72
- disc[u] = low[u] = ++this.time;
73
- this.children = 0;
74
-
75
- // Go through all vertices adjacent to this
76
- // v is current adjacent of 'u'
77
- this.adj[u].forEach(function (v) {
78
- // If v is not visited yet, then recur for it
79
- if (disc[v] == -1) {
80
- _this.children++;
81
- parent[v] = u;
82
-
83
- // store the edge in stack
84
- st.push(new Edge(u, v));
85
- _this._BCCUtil(v, disc, low, st, parent);
86
-
87
- // Check if the subtree rooted with 'v' has a
88
- // connection to one of the ancestors of 'u'
89
- // Case 1 -- per Strongly Connected Components Article
90
- if (low[u] > low[v]) low[u] = low[v];
91
-
92
- // If u is an articulation point,
93
- // pop all edges from stack till u -- v
94
- if (disc[u] == 1 && _this.children > 1 || disc[u] > 1 && low[v] >= disc[u]) {
95
- var subgraph = [];
96
- while (st[st.length - 1].u != u || st[st.length - 1].v != v) {
97
- subgraph.push(st[st.length - 1]);
98
- //console.log(st[st.length - 1].u + "--" + st[st.length - 1].v + " ");
99
- st.splice(st.length - 1, 1);
100
- }
101
- subgraph.push(st[st.length - 1]);
102
- //console.log(st[st.length - 1].u + "--" + st[st.length - 1].v + " ");
103
- _this.subgraphs.push(subgraph);
104
- subgraph = [];
105
- //console.log()
106
- st.splice(st.length - 1, 1);
107
- _this.count++;
108
- }
109
- }
110
-
111
- // Update low value of 'u' only of 'v' is still in stack
112
- // (i.e. it's a back edge, not cross edge).
113
- // Case 2 -- per Strongly Connected Components Article
114
- else if (v != parent[u] && disc[v] < low[u]) {
115
- if (low[u] > disc[v]) low[u] = disc[v];
116
- st.push(new Edge(u, v));
117
- }
118
- });
119
- }
120
- }, {
121
- key: "BCC",
122
- value: function BCC() {
123
- var V = this.V;
124
- var disc = create_array(V);
125
- var low = create_array(V);
126
- var parent = create_array(V);
127
- var st = [];
128
-
129
- // Initialize disc and low, and parent arrays
130
- for (var i = 0; i < V; i++) {
131
- disc[i] = -1;
132
- low[i] = -1;
133
- parent[i] = -1;
134
- }
135
- for (var _i = 0; _i < V; _i++) {
136
- if (disc[_i] == -1) this._BCCUtil(_i, disc, low, st, parent);
137
- var j = 0;
138
-
139
- // If stack is not empty, pop all edges from stack
140
- var subgraph = [];
141
- while (st.length > 0) {
142
- j = 1;
143
- subgraph.push(st[st.length - 1]);
144
- //console.log(st[st.length - 1].u + "--" + st[st.length - 1].v + " ");
145
- st.splice(st.length - 1, 1);
146
- }
147
- if (j == 1) {
148
- this.subgraphs.push(subgraph);
149
- subgraph = [];
150
- //console.log();
151
- this.count++;
152
- }
153
- }
154
- }
155
- }]);
156
- }();
157
- var _default = exports["default"] = Graph;