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,1405 +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["default"] = Viewer2D;
8
- var _react = _interopRequireWildcard(require("react"));
9
- var _propTypes = _interopRequireDefault(require("prop-types"));
10
- var _reactSvgPanZoom = require("react-svg-pan-zoom");
11
- var _constants = _interopRequireWildcard(require("../../constants"));
12
- var constants = _constants;
13
- var _state = _interopRequireDefault(require("./state"));
14
- var SharedStyle = _interopRequireWildcard(require("../../shared-style"));
15
- var _export = require("./export");
16
- var _export2 = require("../../utils/export");
17
- var _formNumberInput = _interopRequireDefault(require("../style/form-number-input"));
18
- var _convertUnits = _interopRequireDefault(require("convert-units"));
19
- var _immutable = require("immutable");
20
- var _math = require("../../utils/math");
21
- var _helper = require("../../utils/helper");
22
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
23
- function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
24
- function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
25
- function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
26
- function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
27
- function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
28
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
29
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
30
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
31
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
32
- 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); }
33
- function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
34
- function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
35
- function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
36
- function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
37
- function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
38
- function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
39
- // variables
40
- var pinFlag = false;
41
- var sFlag = false; //for all object move
42
- var sPoint = {}; //for all object move
43
- var endPoint = {};
44
- var current_sel_obj_id = null;
45
- var allItemRect;
46
- var allItemSnap;
47
- var allLines;
48
- var allLineRects;
49
- var allLineSnap;
50
- var allRect;
51
- var holeRect;
52
- var allArea;
53
-
54
- // /////////
55
- function mode2Tool(mode) {
56
- if (pinFlag) {
57
- return _reactSvgPanZoom.TOOL_NONE;
58
- }
59
- switch (mode) {
60
- case constants.MODE_2D_PAN:
61
- return _reactSvgPanZoom.TOOL_PAN;
62
- case constants.MODE_2D_ZOOM_IN:
63
- return _reactSvgPanZoom.TOOL_ZOOM_IN;
64
- case constants.MODE_2D_ZOOM_OUT:
65
- return _reactSvgPanZoom.TOOL_ZOOM_OUT;
66
- case constants.MODE_IDLE:
67
- return _reactSvgPanZoom.TOOL_AUTO;
68
- default:
69
- return _reactSvgPanZoom.TOOL_NONE;
70
- }
71
- }
72
- function mode2PointerEvents(mode) {
73
- switch (mode) {
74
- case constants.MODE_DRAWING_LINE:
75
- case constants.MODE_DRAWING_HOLE:
76
- case constants.MODE_DRAWING_ITEM:
77
- case constants.MODE_DRAGGING_HOLE:
78
- case constants.MODE_DRAGGING_ITEM:
79
- case constants.MODE_DRAGGING_LINE:
80
- case constants.MODE_DRAGGING_VERTEX:
81
- return {
82
- pointerEvents: 'none'
83
- };
84
- default:
85
- return {};
86
- }
87
- }
88
- function mode2Cursor(mode) {
89
- switch (mode) {
90
- case constants.MODE_DRAGGING_HOLE:
91
- case constants.MODE_DRAGGING_LINE:
92
- case constants.MODE_DRAGGING_VERTEX:
93
- case constants.MODE_DRAGGING_ITEM:
94
- return {
95
- cursor: 'move'
96
- };
97
- case constants.MODE_ROTATING_ITEM:
98
- return {
99
- cursor: 'ew-resize'
100
- };
101
- case constants.MODE_WAITING_DRAWING_LINE:
102
- case constants.MODE_DRAWING_LINE:
103
- return {
104
- cursor: 'crosshair'
105
- };
106
- default:
107
- return {
108
- cursor: 'default'
109
- };
110
- }
111
- }
112
- function mode2DetectAutopan(mode) {
113
- switch (mode) {
114
- case constants.MODE_DRAWING_LINE:
115
- case constants.MODE_DRAGGING_LINE:
116
- case constants.MODE_DRAGGING_VERTEX:
117
- case constants.MODE_DRAGGING_HOLE:
118
- case constants.MODE_DRAGGING_ITEM:
119
- case constants.MODE_DRAWING_HOLE:
120
- case constants.MODE_DRAWING_ITEM:
121
- return true;
122
- default:
123
- return false;
124
- }
125
- }
126
- function extractElementData(node) {
127
- while (!node.attributes.getNamedItem('data-element-root') && node.tagName !== 'svg') {
128
- node = node.parentNode;
129
- }
130
- if (node.tagName === 'svg') return null;
131
- return {
132
- length: node.attributes.getNamedItem('data-length') ? parseFloat(node.attributes.getNamedItem('data-length').value) : 0,
133
- part: node.attributes.getNamedItem('data-part') ? node.attributes.getNamedItem('data-part').value : undefined,
134
- layer: node.attributes.getNamedItem('data-layer').value,
135
- prototype: node.attributes.getNamedItem('data-prototype').value,
136
- selected: node.attributes.getNamedItem('data-selected').value === 'true',
137
- id: node.attributes.getNamedItem('data-id').value,
138
- direct: node.attributes.getNamedItem('data-direct') ? node.attributes.getNamedItem('data-direct').value : 0
139
- };
140
- }
141
- function Viewer2D(_ref, _ref2) {
142
- var state = _ref.state,
143
- width = _ref.width,
144
- height = _ref.height,
145
- setToolbar = _ref.setToolbar,
146
- replaceCabinet = _ref.replaceCabinet;
147
- var viewer2DActions = _ref2.viewer2DActions,
148
- linesActions = _ref2.linesActions,
149
- holesActions = _ref2.holesActions,
150
- verticesActions = _ref2.verticesActions,
151
- itemsActions = _ref2.itemsActions,
152
- areaActions = _ref2.areaActions,
153
- projectActions = _ref2.projectActions,
154
- catalog = _ref2.catalog;
155
- var _useState = (0, _react.useState)(null),
156
- _useState2 = _slicedToArray(_useState, 2),
157
- rulerEdit = _useState2[0],
158
- setRulerEdit = _useState2[1];
159
- var _useState3 = (0, _react.useState)(null),
160
- _useState4 = _slicedToArray(_useState3, 2),
161
- rulerEditID = _useState4[0],
162
- setRulerEditID = _useState4[1];
163
- var Viewer = (0, _react.useRef)(null);
164
- var viewer2D = state.viewer2D,
165
- mode = state.mode,
166
- scene = state.scene;
167
-
168
- // let relatedLines = [];
169
- var _useState5 = (0, _react.useState)([]),
170
- _useState6 = _slicedToArray(_useState5, 2),
171
- relatedLines = _useState6[0],
172
- setRelatedLines = _useState6[1];
173
- var _useState7 = (0, _react.useState)(false),
174
- _useState8 = _slicedToArray(_useState7, 2),
175
- drawStart = _useState8[0],
176
- setdrawStart = _useState8[1];
177
- (0, _react.useEffect)(function () {
178
- // move viewer point to center
179
- var selectedLayer = state.scene.layers.get(state.scene.selectedLayer);
180
- var vertices = selectedLayer.vertices;
181
- if (vertices.isEmpty()) {
182
- return;
183
- }
184
- var bottomX = 0,
185
- bottomY = 100000,
186
- topX = 100000,
187
- topY = 0;
188
- vertices.forEach(function (vertex) {
189
- if (bottomX < vertex.x) bottomX = vertex.x;
190
- if (bottomY > vertex.y) bottomY = vertex.y;
191
- if (topX > vertex.x) topX = vertex.x;
192
- if (topY < vertex.y) topY = vertex.y;
193
- });
194
- var moveX = topX + (bottomX - topX) / 2;
195
- var moveY = 2000 - (bottomY + (topY - bottomY) / 2);
196
- Viewer.current.setPointOnViewerCenter(moveX, moveY, viewer2D.get('a'));
197
- }, []);
198
- var layerID = scene.selectedLayer;
199
- var wall_thickness = _constants.LINE_THICKNESS / 2;
200
- var layer = scene.getIn(['layers', layerID]);
201
- var mapCursorPosition = function mapCursorPosition(_ref3) {
202
- var x = _ref3.x,
203
- y = _ref3.y;
204
- return {
205
- x: x,
206
- y: -y + scene.height
207
- };
208
- };
209
- // let pinBackColor = pinFlag ? "#4488ff" : "black";
210
- // let topRightImg = state.mode == MODE_IDLE || state.mode == MODE_2D_PAN ? "/assets/img/svg/topbar/edit_inactive.svg" : "/assets/img/svg/topbar/edit_active.svg";
211
- // let topBtnAction = state.mode == MODE_IDLE || state.mode == MODE_2D_PAN ? () => linesActions.selectToolDrawingLine("wall") : () => projectActions.setMode(MODE_IDLE);
212
-
213
- var prepareSnap = function prepareSnap() {
214
- var layerID = scene.selectedLayer;
215
- var layer = scene.layers.get(layerID);
216
- allLines = _export2.GeometryUtils.getAllLines(layer);
217
- allLineRects = _export2.GeometryUtils.buildRectFromLines(layer, allLines);
218
- allItemRect = _export2.GeometryUtils.getAllItems(scene, catalog, allLineRects);
219
- allItemSnap = _export2.GeometryUtils.getAllItemSnap(allItemRect);
220
- allLineSnap = _export2.GeometryUtils.getAllLineSnap(allLineRects, allItemRect.cur);
221
- allRect = allItemRect.others.concat(allLineRects);
222
- allItemSnap = _export2.GeometryUtils.validateSnaps(allItemSnap, allRect);
223
- allLineSnap = _export2.GeometryUtils.validateSnaps(allLineSnap, allRect);
224
- allArea = _export2.GeometryUtils.getAllArea(layer);
225
- };
226
- var updateRulerDistAttribute = function updateRulerDistAttribute(elementData, value) {
227
- var newVal = value.get('length');
228
- var oldVal = elementData.length;
229
- var direct = elementData.direct;
230
- var thisItem = scene.getIn(['layers', elementData.layer, 'items', elementData.id]).toJS();
231
- var oldX = thisItem.x;
232
- var oldY = thisItem.y;
233
- var oldRotRad = thisItem.rotation / 180 * Math.PI;
234
- var rotRad = oldRotRad + direct / 180 * Math.PI;
235
- var delta = oldVal - newVal;
236
- var newX = oldX + delta * Math.cos(rotRad);
237
- var newY = oldY + delta * Math.sin(rotRad);
238
- itemsActions.updateDraggingItemChanged(newX, newY, elementData.layer, elementData.id);
239
- setRulerEdit(null);
240
- };
241
- var updateangleChangeAttribute = function updateangleChangeAttribute(elementData, value) {
242
- var verArr = elementData.id.split(',');
243
- var oldAngle = elementData.length;
244
- var newAngle = value.getIn(['_length']);
245
- var cenId = verArr[0];
246
- var verId = verArr[1];
247
- var x0 = state.scene.getIn(['layers', layerID, 'vertices', verArr[0], 'x']);
248
- var y0 = state.scene.getIn(['layers', layerID, 'vertices', verArr[0], 'y']);
249
- var x1 = state.scene.getIn(['layers', layerID, 'vertices', verArr[1], 'x']);
250
- var y1 = state.scene.getIn(['layers', layerID, 'vertices', verArr[1], 'y']);
251
- var x, y, delta;
252
- delta = newAngle - oldAngle;
253
- if (verArr[2] === 'true') {
254
- delta = -delta;
255
- }
256
- x = (x1 - x0) * Math.cos(delta * Math.PI / 180) - (y1 - y0) * Math.sin(delta * Math.PI / 180) + x0;
257
- y = (x1 - x0) * Math.sin(delta * Math.PI / 180) + (y1 - y0) * Math.cos(delta * Math.PI / 180) + y0;
258
- setRulerEdit(null);
259
- verticesActions.beginDraggingVertex(elementData.layer, verArr[1], x, y, state.snapMask);
260
- verticesActions.updateDraggingVertex(x, y, state.snapMask);
261
- verticesActions.endDraggingVertex(x, y, state.snapMask);
262
- };
263
- var updateRulerAttribute = function updateRulerAttribute(elementData, value) {
264
- var selectedLine = scene.getIn(['layers', elementData.layer, 'lines', elementData.id]).toJS();
265
- var v_0 = scene.getIn(['layers', elementData.layer, 'vertices', selectedLine.vertices[0]]);
266
- var v_1 = scene.getIn(['layers', elementData.layer, 'vertices', selectedLine.vertices[1]]);
267
- var _GeometryUtils$orderV = _export2.GeometryUtils.orderVertices([v_0, v_1]),
268
- _GeometryUtils$orderV2 = _slicedToArray(_GeometryUtils$orderV, 2),
269
- v_a = _GeometryUtils$orderV2[0],
270
- v_b = _GeometryUtils$orderV2[1];
271
- var v_b_new = _export2.GeometryUtils.extendLine(v_a.x, v_a.y, v_b.x, v_b.y, value.get('length'), 2);
272
-
273
- // Blocked function that as wall changed, opposite wall should changed together.
274
- // let layer = scene.getIn(['layers', elementData.layer]);
275
- // let allLines = layer.lines.toArray()
276
- // let relatedLine = allLines.filter(line => { return line.vertices.toArray().includes(v_b.id) && line.id != selectedLine.id })[0];
277
- // let relatedVertexID = relatedLine && (relatedLine.vertices.toArray()[0] == v_b.id ? relatedLine.vertices.toArray()[1] : relatedLine.vertices.toArray()[0]);
278
- // let v_d = relatedVertexID && layer.getIn(['vertices', relatedVertexID]);
279
- // let delta = {
280
- // x : v_b_new.x - v_b.x,
281
- // y : v_b_new.y - v_b.y
282
- // };
283
- // let newPosition = {
284
- // x : v_d.x + delta.x,
285
- // y : v_d.y + delta.y
286
- // }
287
-
288
- var attributesData = {
289
- // (v_0 === v_a ? 'vertexTwo' : 'vertexOne') : v_b.merge(v_b_new)),
290
- lineLength: value
291
- };
292
- if (v_0 === v_a) {
293
- attributesData = _objectSpread(_objectSpread({}, attributesData), {}, {
294
- vertexTwo: v_b.merge(v_b_new),
295
- vertexOne: v_a
296
- });
297
- } else {
298
- attributesData = _objectSpread(_objectSpread({}, attributesData), {}, {
299
- vertexOne: v_b.merge(v_b_new),
300
- vertexTwo: v_a
301
- });
302
- }
303
- var attributesFormData = new _immutable.Map(_objectSpread({}, attributesData));
304
- setRulerEdit(null);
305
- projectActions.setLinesAttributes(attributesFormData, true, {
306
- layerID: elementData.layer,
307
- lineID: elementData.id
308
- });
309
-
310
- // Blocked function that as wall changed, opposite wall should changed together.
311
- // verticesActions.beginDraggingVertex(elementData.layer, relatedVertexID, newPosition.x, newPosition.y, state.snapMask);
312
- // verticesActions.updateDraggingVertex(newPosition.x, newPosition.y, state.snapMask);
313
- // verticesActions.endDraggingVertex(newPosition.x, newPosition.y, state.snapMask);
314
- };
315
- var updateTwoHoleRulerAttribute = function updateTwoHoleRulerAttribute(elementData, value) {
316
- var elementIds = elementData.id.split(',');
317
- elementData.id = elementIds[1];
318
- elementData.length /= 2;
319
- updateLeftHoleRulerAttribute(elementData, value);
320
- elementData.id = elementIds[0];
321
- updateRightHoleRulerAttribute(elementData, value);
322
- };
323
- var updateLeftHoleRulerAttribute = function updateLeftHoleRulerAttribute(elementData, value) {
324
- var newVal = value.get('length');
325
- var oldVal = elementData.length;
326
- var thisItem = scene.getIn(['layers', elementData.layer, 'holes', elementData.id]).toJS();
327
- var oldX = thisItem.x;
328
- var oldY = thisItem.y;
329
- var oldRotRad = thisItem.rotation;
330
- var delta = oldVal - newVal;
331
- var newX = oldX - delta * Math.cos(oldRotRad);
332
- var newY = oldY - delta * Math.sin(oldRotRad);
333
- holesActions.beginDraggingHole(elementData.layer, elementData.id, newX, newY);
334
- holesActions.updateDraggingHoleChanged(newX, newY, elementData.layer, elementData.id);
335
- holesActions.endDraggingHole(newX, newY);
336
- setRulerEdit(null);
337
- };
338
- var updateHoleRulerAttribute = function updateHoleRulerAttribute(elementData, value) {
339
- var newVal = value.get('length');
340
- var thisItem = scene.getIn(['layers', elementData.layer, 'holes', elementData.id]).toJS();
341
- var oldX = thisItem.x;
342
- var oldY = thisItem.y;
343
- holesActions.beginDraggingHole(elementData.layer, elementData.id, oldX, oldY);
344
- holesActions.updateDraggingHoleRulerChanged(newVal, elementData.layer, elementData.id);
345
- holesActions.endDraggingHole(oldX, oldY);
346
- setRulerEdit(null);
347
- };
348
- var updateRightHoleRulerAttribute = function updateRightHoleRulerAttribute(elementData, value) {
349
- var newVal = value.get('length');
350
- var oldVal = elementData.length;
351
- var thisItem = scene.getIn(['layers', elementData.layer, 'holes', elementData.id]).toJS();
352
- var oldX = thisItem.x;
353
- var oldY = thisItem.y;
354
- var oldRotRad = thisItem.rotation;
355
- var delta = oldVal - newVal;
356
- var newX = oldX + delta * Math.cos(oldRotRad);
357
- var newY = oldY + delta * Math.sin(oldRotRad);
358
- holesActions.beginDraggingHole(elementData.layer, elementData.id, newX, newY);
359
- holesActions.updateDraggingHoleChanged(newX, newY, elementData.layer, elementData.id);
360
- holesActions.endDraggingHole(newX, newY);
361
- setRulerEdit(null);
362
- };
363
- var getRelatedLines = function getRelatedLines(tlines, drawingLine, vertices, lines) {
364
- var _loop = function _loop() {
365
- var vertex = vertices[drawingLine.vertices[i]];
366
- var _loop2 = function _loop2(j) {
367
- if (vertex.lines[j] !== drawingLine.id) {
368
- if (!tlines.some(function (line) {
369
- return line.id === lines[vertex.lines[j]].id;
370
- })) {
371
- tlines.push(lines[vertex.lines[j]]);
372
- }
373
- }
374
- };
375
- for (var j = 0; j < vertex.lines.length; j++) {
376
- _loop2(j);
377
- }
378
- };
379
- // if (drawingLine.vertices[0] !== drawingLine.vertices[1]) {
380
- for (var i = 0; i < drawingLine.vertices.length; i++) {
381
- _loop();
382
- }
383
- // }
384
- };
385
- var getEndPoint = function getEndPoint(vertices, x, y, mode) {
386
- var selLineID = state.getIn(['scene', 'layers', layerID, 'selected', 'lines']).first();
387
- if ((0, _helper.isEmpty)(selLineID)) {
388
- return {
389
- isEndDrag: true,
390
- x: x,
391
- y: y
392
- };
393
- }
394
- var draggingLine = state.getIn(['scene', 'layers', layerID, 'lines', selLineID]).toJS();
395
- var allLines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
396
- var dragVertexId = state.getIn(['draggingSupport', 'vertexID']);
397
- dragVertexId = !(0, _helper.isEmpty)(dragVertexId) ? dragVertexId : draggingLine.vertices[1];
398
- var vtx, vty;
399
- var stepUnit = false;
400
- vtx = vertices[dragVertexId].x;
401
- vty = vertices[dragVertexId].y;
402
- if (!vertices[dragVertexId].lines.some(function (line) {
403
- return line !== draggingLine.id;
404
- })) {
405
- stepUnit = true;
406
- }
407
- var endDrag = [];
408
- if (!(0, _helper.isEmpty)(relatedLines) && mode !== 'DRAGGING_LINE') {
409
- vertices[dragVertexId].x = x;
410
- vertices[dragVertexId].y = y;
411
- }
412
- var absAngle, lineAngle;
413
- if (draggingLine.vertices[0] !== draggingLine.vertices[1]) {
414
- for (var i = 0; i < relatedLines.length; i++) {
415
- var line = relatedLines[i];
416
- lineAngle = _export2.GeometryUtils.angleBetweenTwoLines(line, draggingLine, vertices);
417
- absAngle = Math.abs(lineAngle);
418
- var tmpRelated = [];
419
- _export2.GeometryUtils.getRelatedLines(tmpRelated, line, vertices, allLines, draggingLine.id);
420
- for (var j = 0; j < tmpRelated.length; j++) {
421
- var tmpAngle = Math.abs(_export2.GeometryUtils.angleBetweenTwoLines(tmpRelated[j], line, vertices));
422
- if (tmpAngle < _constants.MIN_ANGLE_DISALLOW_DRAW_WALL || tmpAngle > 360 - _constants.MIN_ANGLE_DISALLOW_DRAW_WALL) {
423
- endDrag.push(false);
424
- } else endDrag.push(true);
425
- }
426
- if (absAngle < _constants.MIN_ANGLE_DISALLOW_DRAW_WALL || absAngle > 360 - _constants.MIN_ANGLE_DISALLOW_DRAW_WALL) {
427
- endDrag.push(false);
428
- } else endDrag.push(true);
429
- }
430
- }
431
- if (!endDrag.some(function (flag) {
432
- return flag === false;
433
- })) {
434
- vtx = x;
435
- vty = y;
436
- } else {
437
- var rest = _constants.MIN_ANGLE_DISALLOW_DRAW_WALL - absAngle;
438
- // the origin point of rotation(snapping)
439
- var originVerId = draggingLine.vertices.findIndex(function (vertice) {
440
- return vertice !== dragVertexId;
441
- });
442
- originVerId = originVerId < 0 ? draggingLine.vertices[0] : draggingLine.vertices[originVerId];
443
- if (stepUnit) {
444
- var ox = vertices[originVerId].x;
445
- var oy = vertices[originVerId].y;
446
- // determine the direction of rotation.
447
- rest = lineAngle > 0 ? -rest : rest;
448
- // rotate the current point to last point around the first point of drawing line.
449
- var res = _export2.GeometryUtils.rotatePointAroundPoint(x, y, ox, oy, rest);
450
- vtx = res.x;
451
- vty = res.y;
452
- }
453
- }
454
-
455
- // angle snapping as a value of UNIT_ANGLE
456
- if (!endDrag.some(function (flag) {
457
- return flag === false;
458
- }) && !(0, _helper.isEmpty)(absAngle) && absAngle % _constants.UNIT_ANGLE !== 0 && stepUnit) {
459
- var _result = _export2.GeometryUtils.snapAngleByUnit(lineAngle, vertices, draggingLine, vtx, vty, dragVertexId);
460
- vtx = _result.x;
461
- vty = _result.y;
462
- }
463
- var result = {
464
- isEndDrag: endDrag,
465
- x: vtx,
466
- y: vty
467
- };
468
- return result;
469
- };
470
- var getProperties = function getProperties(item, property) {
471
- var _item$properties;
472
- if (!(item !== null && item !== void 0 && (_item$properties = item.properties) !== null && _item$properties !== void 0 && _item$properties.getIn)) return 0;
473
- var length = item.properties.getIn([property, '_length']);
474
- var unit = item.properties.getIn([property, '_unit']);
475
- return length && unit ? (0, _convertUnits["default"])(length).from(unit).to('cm') : 0;
476
- };
477
- var point = function point(x, y) {
478
- return {
479
- x: x,
480
- y: y
481
- };
482
- };
483
- var getDistant = function getDistant(x, y, rotRad, curItemInfo, allRect) {
484
- var center_h = 3 * height / 8;
485
- var center_x1 = x - center_h * Math.sin(rotRad);
486
- var center_y1 = y + center_h * Math.cos(rotRad);
487
- var pointArray = [];
488
- curItemInfo.rectCenterPoint.forEach(function (centerpoint) {
489
- if (!Array.isArray(centerpoint) || centerpoint.length < 2) return;
490
- var _centerpoint = _slicedToArray(centerpoint, 2),
491
- pt = _centerpoint[0],
492
- angle = _centerpoint[1];
493
- if (!pt) return;
494
-
495
- // line through centerpoint and reference center
496
- var rectLine = angle === 180 || angle === 0 ? _export2.GeometryUtils.linePassingThroughTwoPoints(pt.x, pt.y, center_x1, center_y1) : _export2.GeometryUtils.linePassingThroughTwoPoints(pt.x, pt.y, x, y);
497
- if (!rectLine) return;
498
- var minDist;
499
- allRect.forEach(function (linerect) {
500
- if (!(linerect !== null && linerect !== void 0 && linerect.rect) || linerect.rect.length < 4) return;
501
- var p0 = _export2.GeometryUtils.clone_point(linerect.rect[2]);
502
- var p1 = _export2.GeometryUtils.clone_point(linerect.rect[3]);
503
- if (!p0 || !p1 || p0.x === p1.x && p0.y === p1.y) return;
504
- var lineFn = _export2.GeometryUtils.linePassingThroughTwoPoints(p0.x, p0.y, p1.x, p1.y);
505
- if (!lineFn) return;
506
- var ip = _export2.GeometryUtils.twoLinesIntersection(lineFn.a, lineFn.b, lineFn.c, rectLine.a, rectLine.b, rectLine.c);
507
- if (!ip) return;
508
-
509
- // intersection must lie within line segment
510
- var segLen = _export2.GeometryUtils.pointsDistance(p0.x, p0.y, p1.x, p1.y);
511
- if (segLen <= _export2.GeometryUtils.pointsDistance(p0.x, p0.y, ip.x, ip.y) || segLen <= _export2.GeometryUtils.pointsDistance(p1.x, p1.y, ip.x, ip.y)) return;
512
-
513
- // ensure intersection is farther than pt→center
514
- var distToCenter = _export2.GeometryUtils.pointsDistance(ip.x, ip.y, x, y);
515
- var baseDist = _export2.GeometryUtils.pointsDistance(pt.x, pt.y, ip.x, ip.y);
516
- if (distToCenter <= baseDist) return;
517
- var candidate = baseDist;
518
- minDist = minDist !== undefined ? Math.min(minDist, candidate) : candidate;
519
- });
520
- pointArray.push([minDist !== null && minDist !== void 0 ? minDist : 0, angle]);
521
- });
522
- return pointArray;
523
- };
524
- var getCalcRectFromItem = function getCalcRectFromItem(item) {
525
- if (!(item !== null && item !== void 0 && item.pos) || !(item !== null && item !== void 0 && item.size)) return {
526
- rectCenterPoint: []
527
- };
528
- var _item$pos = item.pos,
529
- x = _item$pos.x,
530
- y = _item$pos.y;
531
- var w = item.size.width / 2;
532
- var h = item.size.height / 2;
533
- var rotRad = item.rotRad;
534
- var mh = 3 * h / 4;
535
- var mx = x - w * Math.cos(rotRad) - mh * Math.sin(rotRad);
536
- var my = y - w * Math.sin(rotRad) + mh * Math.cos(rotRad);
537
- var m2x = x + w * Math.cos(rotRad) - mh * Math.sin(rotRad);
538
- var m2y = y + w * Math.sin(rotRad) + mh * Math.cos(rotRad);
539
- var m3x = x - h * Math.sin(rotRad);
540
- var m3y = y + h * Math.cos(rotRad);
541
- var m1x = x + h * Math.sin(rotRad);
542
- var m1y = y - h * Math.cos(rotRad);
543
- return {
544
- rectCenterPoint: [[point(mx, my), 180], [point(m1x, m1y), -90], [point(m2x, m2y), 0], [point(m3x, m3y), 90]]
545
- };
546
- };
547
- var calcDistanceArray = function calcDistanceArray() {
548
- var items = layer === null || layer === void 0 ? void 0 : layer.get('items');
549
- if (!items) return;
550
- items.forEach(function (item) {
551
- if ((item === null || item === void 0 ? void 0 : item.selected) === true) {
552
- var x = item.x,
553
- y = item.y,
554
- rotation = item.rotation,
555
- id = item.id;
556
- if (x == null || y == null) return;
557
- var val = {
558
- pos: {
559
- x: x,
560
- y: y
561
- },
562
- rotRad: rotation / 180 * Math.PI
563
- };
564
- var _width = getProperties(item, 'width');
565
- var depth = getProperties(item, 'depth');
566
- val.size = {
567
- width: _width,
568
- height: depth
569
- };
570
-
571
- // collect geometry
572
- var _allLines = _export2.GeometryUtils.getAllLines(layer) || [];
573
- var _allLineRects = _export2.GeometryUtils.buildRectFromLines(layer, _allLines) || [];
574
- var _allItemRect = _export2.GeometryUtils.getAllItems(scene, catalog, _allLineRects) || {
575
- others: []
576
- };
577
- var _allRect = [].concat(_toConsumableArray(_allItemRect.others || []), _toConsumableArray(_allLineRects));
578
-
579
- // current item
580
- var curItemInfo = getCalcRectFromItem(val);
581
- var pointArray = getDistant(x, y, val.rotRad, curItemInfo, _allRect);
582
-
583
- // store results safely
584
- if (Array.isArray(pointArray)) {
585
- itemsActions.storeDistArray(layerID, id, pointArray);
586
- }
587
- }
588
- });
589
- };
590
- var onMouseMove = function onMouseMove(viewerEvent) {
591
- //workaround that allow imageful component to work
592
-
593
- // let evt = new Event('mousemove-planner-event');
594
- // evt.viewerEvent = viewerEvent;
595
- // document.dispatchEvent(evt);
596
- var _mapCursorPosition = mapCursorPosition(viewerEvent),
597
- x = _mapCursorPosition.x,
598
- y = _mapCursorPosition.y;
599
- projectActions.updateMouseCoord({
600
- x: x,
601
- y: y
602
- });
603
- if (sFlag) {
604
- var differs = {
605
- x: x - sPoint.x,
606
- y: y - sPoint.y
607
- };
608
- projectActions.selectAll(differs);
609
- } else switch (mode) {
610
- case constants.MODE_DRAWING_LINE:
611
- // check whether the drawing line is started.
612
- if (drawStart || state.getIn(['scene', 'setLineAttributes'])) {
613
- var lineID = state.getIn(['scene', 'layers', layerID, 'selected', 'lines']).first();
614
- var _vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
615
- var lines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
616
- var drawingLine = state.getIn(['scene', 'layers', layerID, 'lines', lineID]).toJS();
617
- var tlines = [];
618
- setdrawStart(false);
619
- // get the lines that have same points with drawing line.
620
- getRelatedLines(tlines, drawingLine, _vertices, lines);
621
- setRelatedLines(tlines);
622
- linesActions.updateDrawingLine(x, y, tlines, state.snapMask);
623
- } else {
624
- linesActions.updateDrawingLine(x, y, relatedLines, state.snapMask);
625
- }
626
- // Blocked 90 degree snap.
627
- // let prevVertexID = state.getIn(['scene', 'layers', layerID, 'selected', 'vertices']).toJS()[0];
628
- // let prevVertex = state.getIn(['scene', 'layers', layerID, 'vertices', prevVertexID]);
629
- // let dx = Math.abs(x - prevVertex.x);
630
- // let dy = Math.abs(y - prevVertex.y);
631
- // if (dx > dy) y = prevVertex.y
632
- // else x = prevVertex.x;
633
- break;
634
- case constants.MODE_DRAWING_HOLE:
635
- holesActions.updateDrawingHole(layerID, x, y);
636
- break;
637
- case constants.MODE_DRAWING_ITEM:
638
- calcDistanceArray();
639
- var _layer = scene.layers.get(layerID);
640
- var flag = false;
641
- _layer.items.some(function (item) {
642
- if (item.selected) {
643
- item.counterTop.uri = _layer.counterTop.uri;
644
- current_sel_obj_id = item.id;
645
- flag = true;
646
- }
647
- });
648
- if (current_sel_obj_id === null || !flag) {
649
- itemsActions.updateDrawingItem(layerID, x, y);
650
- endPoint.x = x;
651
- endPoint.y = y;
652
- } else {
653
- prepareSnap();
654
- var _GeometryUtils$calcSn = _export2.GeometryUtils.calcSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, x, y, allArea),
655
- nx = _GeometryUtils$calcSn.nx,
656
- ny = _GeometryUtils$calcSn.ny,
657
- rot = _GeometryUtils$calcSn.rot,
658
- rotRad = _GeometryUtils$calcSn.rotRad;
659
- var _val = {
660
- pos: {
661
- x: x,
662
- y: y
663
- },
664
- rotRad: rotRad,
665
- size: allItemRect.cur && allItemRect.cur.size,
666
- layoutpos: allItemRect.cur && allItemRect.cur.layoutpos,
667
- is_corner: allItemRect.cur && allItemRect.cur.is_corner
668
- };
669
- var _GeometryUtils$getAll = _export2.GeometryUtils.getAllHoleRect(scene, _val),
670
- _isSect = _GeometryUtils$getAll.isSect,
671
- _snap = _GeometryUtils$getAll.snap;
672
- if (!(0, _helper.isEmpty)(_snap) && _isSect) {
673
- if (_snap.length == 1) _val.pos = {
674
- x: _snap[0].x,
675
- y: _snap[0].y
676
- };else {
677
- if ((_snap[0].x - x) * (_snap[0].x - x) + (_snap[0].y - y) * (_snap[0].y - y) < (_snap[1].x - x) * (_snap[1].x - x) + (_snap[1].y - y) * (_snap[1].y - y)) _val.pos = {
678
- x: _snap[0].x,
679
- y: _snap[0].y
680
- };else _val.pos = {
681
- x: _snap[1].x,
682
- y: _snap[1].y
683
- };
684
- }
685
- var interSect = _export2.GeometryUtils.validInterSect(allItemRect.others, _val);
686
- if (interSect) {
687
- nx = _val.pos.x;
688
- ny = _val.pos.y;
689
- }
690
- }
691
- _val.pos = {
692
- x: nx,
693
- y: ny
694
- };
695
- var _isrectSect = _export2.GeometryUtils.validInterSect(allItemRect.others, _val);
696
- if (_isrectSect && _isSect) {
697
- itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
698
- itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
699
- endPoint.x = nx;
700
- endPoint.y = ny;
701
- }
702
- if (allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cook Top') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('cabinet')) {
703
- itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
704
- itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
705
- endPoint.x = nx;
706
- endPoint.y = ny;
707
- }
708
- if (allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Hood') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Range') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cook Top')) {
709
- itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
710
- itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
711
- endPoint.x = nx;
712
- endPoint.y = ny;
713
- }
714
- }
715
- break;
716
- case constants.MODE_DRAGGING_HOLE:
717
- holesActions.updateDraggingHole(x, y);
718
- break;
719
- case constants.MODE_DRAGGING_LINE:
720
- linesActions.updateDraggingLine(x, y, relatedLines, state.snapMask);
721
- break;
722
- case constants.MODE_DRAGGING_VERTEX:
723
- var vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
724
- var result = getEndPoint(vertices, x, y, 'DRAGGING_VERTEX');
725
- verticesActions.updateDraggingVertex(result.x, result.y, state.snapMask);
726
- break;
727
- case constants.MODE_DRAGGING_ITEM:
728
- calcDistanceArray();
729
- prepareSnap();
730
- var _GeometryUtils$calcSn2 = _export2.GeometryUtils.calcSnap(allItemRect, allItemSnap, allLineRects, allLineSnap, allRect, x, y, allArea),
731
- nx = _GeometryUtils$calcSn2.nx,
732
- ny = _GeometryUtils$calcSn2.ny,
733
- rot = _GeometryUtils$calcSn2.rot,
734
- rotRad = _GeometryUtils$calcSn2.rotRad;
735
- var val = {
736
- pos: {
737
- x: x,
738
- y: y
739
- },
740
- rotRad: rotRad,
741
- size: allItemRect.cur && allItemRect.cur.size,
742
- layoutpos: allItemRect.cur && allItemRect.cur.layoutpos,
743
- is_corner: allItemRect.cur && allItemRect.cur.is_corner
744
- };
745
- var _GeometryUtils$getAll2 = _export2.GeometryUtils.getAllHoleRect(scene, val),
746
- isSect = _GeometryUtils$getAll2.isSect,
747
- snap = _GeometryUtils$getAll2.snap;
748
- if (!(0, _helper.isEmpty)(snap) && isSect) {
749
- if (snap.length == 1) val.pos = {
750
- x: snap[0].x,
751
- y: snap[0].y
752
- };else if (snap.length == 2) {
753
- if ((snap[0].x - x) * (snap[0].x - x) + (snap[0].y - y) * (snap[0].y - y) < (snap[1].x - x) * (snap[1].x - x) + (snap[1].y - y) * (snap[1].y - y)) val.pos = {
754
- x: snap[0].x,
755
- y: snap[0].y
756
- };else val.pos = {
757
- x: snap[1].x,
758
- y: snap[1].y
759
- };
760
- }
761
- var _interSect = _export2.GeometryUtils.validInterSect(allItemRect.others, val);
762
- if (_interSect) {
763
- nx = val.pos.x;
764
- ny = val.pos.y;
765
- }
766
- }
767
- val.pos = {
768
- x: nx,
769
- y: ny
770
- };
771
- var isrectSect = _export2.GeometryUtils.validInterSect(allItemRect.others, val);
772
- if (isrectSect && isSect) {
773
- itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
774
- itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
775
- }
776
- if (allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cook Top') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cabinet')) {
777
- itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
778
- itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
779
- }
780
- if (allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Hood') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Range') || allItemRect.cur && allItemRect.cur.itemInfo.name.includes('Cook Top')) {
781
- itemsActions.updateDraggingItemChanged(nx, ny, layerID, current_sel_obj_id);
782
- itemsActions.updateRotatingItemChanged(rot, layerID, current_sel_obj_id);
783
- }
784
- break;
785
- case constants.MODE_ROTATING_ITEM:
786
- itemsActions.updateRotatingItem(x, y);
787
- break;
788
- }
789
- viewerEvent.originalEvent.stopPropagation();
790
- };
791
- var onMouseDown = function onMouseDown(viewerEvent) {
792
- var event = viewerEvent.originalEvent;
793
- //workaround that allow imageful component to work
794
- // let evt = new Event('mousedown-planner-event');
795
- // evt.viewerEvent = viewerEvent;
796
- // document.dispatchEvent(evt);
797
- var _mapCursorPosition2 = mapCursorPosition(viewerEvent),
798
- x = _mapCursorPosition2.x,
799
- y = _mapCursorPosition2.y;
800
- var layer = state.scene.getIn(['layers', state.scene.selectedLayer]);
801
- var sCount = layer.selected.areas.size + layer.selected.holes.size + layer.selected.items.size + layer.selected.lines.size;
802
- if (mode === constants.MODE_DRAWING_LINE) {
803
- if (event.nativeEvent.which === 3) {
804
- projectActions.rollback();
805
- event.stopPropagation();
806
- return;
807
- }
808
- }
809
- if (mode === constants.MODE_IDLE) {
810
- var elementData = extractElementData(event.target);
811
- if (!elementData) return;
812
- if (sCount < 2) switch (elementData.prototype) {
813
- case 'lines':
814
- if (elementData.selected) {
815
- if (elementData.part === 'remove') break;else if (elementData.part === 'elevation') break;
816
- linesActions.beginDraggingLine(elementData.layer, elementData.id, x, y, state.snapMask);
817
- }
818
- break;
819
- case 'vertices':
820
- verticesActions.beginDraggingVertex(elementData.layer, elementData.id, x, y, state.snapMask);
821
- break;
822
- case 'items':
823
- setToolbar('');
824
- current_sel_obj_id = elementData.id;
825
- if (elementData.part === 'rotation-anchor') itemsActions.beginRotatingItem(elementData.layer, elementData.id, x, y);else if (elementData.part === 'remove') break;else if (elementData.part === 'duplicate') break;else if (elementData.part === 'warning_edit') break;else {
826
- // closes the setting dialog
827
- // document.getElementById('setting_dialog').style.display = 'none';
828
-
829
- itemsActions.selectItem(elementData.layer, elementData.id);
830
- // projectActions.setMode(constants.MODE_DRAGGING_ITEM);
831
- itemsActions.beginDraggingItem(elementData.layer, elementData.id, x, y);
832
- replaceCabinet(false);
833
- }
834
- break;
835
- case 'holes':
836
- if (elementData.selected) holesActions.beginDraggingHole(elementData.layer, elementData.id, x, y);
837
- break;
838
- default:
839
- break;
840
- } else {
841
- sPoint.x = x;
842
- sPoint.y = y;
843
- sFlag = true;
844
- }
845
- }
846
- event.stopPropagation();
847
- };
848
- var onMouseUp = function onMouseUp(viewerEvent) {
849
- //set move all flag false
850
- sFlag = false;
851
- // //////////////////////
852
- // setRulerEdit(null);
853
- var event = viewerEvent.originalEvent;
854
- var bbox = event.target.getBoundingClientRect();
855
- if (!mode.includes('ING')) {
856
- setToolbar('');
857
- }
858
- // bbox.width = event.target.getBBox().width;
859
- // bbox.height = event.target.getBBox().height;
860
- if (event.target.tagName === 'rect') {
861
- if (event.target.id) {
862
- setRulerEditID(event.target.id);
863
- }
864
- }
865
- setRulerEdit(null);
866
- // let evt = new Event('mouseup-planner-event');
867
- // evt.viewerEvent = viewerEvent;
868
- // document.dispatchEvent(evt);
869
-
870
- var _mapCursorPosition3 = mapCursorPosition(viewerEvent),
871
- x = _mapCursorPosition3.x,
872
- y = _mapCursorPosition3.y;
873
- var vertices = state.getIn(['scene', 'layers', layerID, 'vertices']).toJS();
874
- var lines = state.getIn(['scene', 'layers', layerID, 'lines']).toJS();
875
- switch (mode) {
876
- case constants.MODE_IDLE:
877
- var elementData = extractElementData(event.target);
878
- var selectedLayer = scene.getIn(['layers', layerID]);
879
- switch (elementData ? elementData.prototype : 'none') {
880
- case 'areas':
881
- // document.getElementById('setting_dialog').style.display = 'none';
882
- areaActions.selectArea(elementData.layer, elementData.id);
883
- break;
884
- case 'lines':
885
- // document.getElementById('setting_dialog').style.display = 'none';
886
- if (elementData.part === 'remove') {
887
- projectActions.remove();
888
- break;
889
- } else if (elementData.part === 'elevation') {
890
- // handle action when click elevation about selected line
891
- var _mode = _constants.MODE_ELEVATION_VIEW;
892
- projectActions.setMode(_mode);
893
- break;
894
- } else {
895
- var _tlines = [];
896
- var _drawingLine = state.getIn(['scene', 'layers', layerID, 'lines', elementData.id]).toJS();
897
- getRelatedLines(_tlines, _drawingLine, vertices, lines);
898
- setRelatedLines(_tlines);
899
- linesActions.selectLine(elementData.layer, elementData.id);
900
- break;
901
- }
902
- case 'holes':
903
- // document.getElementById('setting_dialog').style.display = 'none';
904
- holesActions.selectHole(elementData.layer, elementData.id);
905
- break;
906
- case 'items':
907
- if (elementData.part === 'duplicate') {
908
- var currentObject = state.getIn(['scene', 'layers', layerID, 'items', elementData.id]);
909
- itemsActions.duplicateSelected(currentObject);
910
- break;
911
- } else if (elementData.part === 'remove') {
912
- projectActions.remove();
913
- break;
914
- } else if (elementData.part === 'warning_edit') {
915
- // closes the setting dialog
916
- // document.getElementById('setting_dialog').style.display = 'none';
917
-
918
- itemsActions.selectItem(elementData.layer, elementData.id);
919
- replaceCabinet(true);
920
- break;
921
- } else {
922
- projectActions.unselectAll();
923
- break;
924
- }
925
- case 'rulerDist':
926
- var _length1 = (0, _convertUnits["default"])(elementData.length).from(scene.unit).to(scene.rulerUnit);
927
- var distanceText1 = "".concat((0, _math.formatNumber)(_length1, _constants.DECIMAL_PLACES_2));
928
- var numberInput1 = /*#__PURE__*/_react["default"].createElement("div", {
929
- id: "ruler_numberInput",
930
- style: {
931
- position: 'absolute',
932
- left: bbox.left - (150 - bbox.width) / 2,
933
- top: bbox.top - (50 - bbox.height) / 2,
934
- zIndex: 1000
935
- }
936
- }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
937
- style: {
938
- width: 150,
939
- height: 50,
940
- textAlign: 'center',
941
- paddingRight: 10,
942
- fontSize: '16px',
943
- lineHeight: '22px',
944
- fontWeight: 600
945
- },
946
- value: distanceText1,
947
- onChange: function onChange(event) {
948
- var value = new _immutable.Map({
949
- length: (0, _convertUnits["default"])(event.target.value).from(scene.rulerUnit).to(scene.unit),
950
- _length: event.target.value,
951
- _unit: scene.rulerUnit
952
- });
953
- updateRulerDistAttribute(elementData, value);
954
- },
955
- precision: 2
956
- }));
957
- setRulerEdit(numberInput1);
958
- projectActions.unselectAll();
959
- break;
960
- case 'ruler':
961
- var _length = (0, _convertUnits["default"])(elementData.length).from(scene.unit).to(selectedLayer.unit);
962
- var numberInput = /*#__PURE__*/_react["default"].createElement("div", {
963
- id: "ruler_numberInput",
964
- style: {
965
- position: 'absolute',
966
- left: bbox.left - (150 - bbox.width) / 2,
967
- top: bbox.top - (50 - bbox.height) / 2,
968
- zIndex: 1000
969
- }
970
- }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
971
- style: {
972
- width: 150,
973
- height: 50,
974
- textAlign: 'center',
975
- paddingRight: 10,
976
- fontSize: '16px',
977
- lineHeight: '22px',
978
- fontWeight: 600
979
- },
980
- value: (0, _math.formatNumber)(_length, _constants.DECIMAL_PLACES_2),
981
- onChange: function onChange(event) {
982
- var value = new _immutable.Map({
983
- length: (0, _convertUnits["default"])(event.target.value).from(selectedLayer.unit).to(scene.unit),
984
- _length: event.target.value,
985
- _unit: selectedLayer.unit
986
- });
987
- updateRulerAttribute(elementData, value);
988
- },
989
- precision: 2
990
- }));
991
- setRulerEdit(numberInput);
992
- projectActions.unselectAll();
993
- break;
994
- case 'twoHoleRuler':
995
- var _lengthTwoHoleRuler = (0, _convertUnits["default"])(elementData.length).from(scene.unit).to(scene.rulerUnit);
996
- var distanceTextTwoHoleRuler = "".concat((0, _math.formatNumber)(_lengthTwoHoleRuler, _constants.DECIMAL_PLACES_2));
997
- var numberInputTwoHoleRuler = /*#__PURE__*/_react["default"].createElement("div", {
998
- id: "ruler_numberInput",
999
- style: {
1000
- position: 'absolute',
1001
- left: bbox.left - (150 - bbox.width) / 2,
1002
- top: bbox.top - (50 - bbox.height) / 2,
1003
- zIndex: 1000
1004
- }
1005
- }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1006
- style: {
1007
- width: 150,
1008
- height: 50,
1009
- textAlign: 'center',
1010
- padding: 'auto',
1011
- fontSize: '16px',
1012
- lineHeight: '22px',
1013
- fontWeight: 600
1014
- },
1015
- value: distanceTextTwoHoleRuler,
1016
- onChange: function onChange(event) {
1017
- var value = new _immutable.Map({
1018
- length: (0, _convertUnits["default"])(event.target.value / 2).from(scene.rulerUnit).to(scene.unit),
1019
- _length: event.target.value / 2,
1020
- _unit: scene.rulerUnit
1021
- });
1022
- updateTwoHoleRulerAttribute(elementData, value);
1023
- },
1024
- precision: 2
1025
- }));
1026
- setRulerEdit(numberInputTwoHoleRuler);
1027
- projectActions.unselectAll();
1028
- break;
1029
- case 'leftHoleRuler':
1030
- var _lengthLeftHoleRuler = (0, _convertUnits["default"])(elementData.length).from(scene.unit).to(scene.rulerUnit);
1031
- var distanceTextLeftHoleRuler = "".concat(_lengthLeftHoleRuler.toFixed(2));
1032
- var numberInputLeftHoleRuler = /*#__PURE__*/_react["default"].createElement("div", {
1033
- id: "ruler_numberInput",
1034
- style: {
1035
- position: 'absolute',
1036
- left: bbox.left - (150 - bbox.width) / 2,
1037
- top: bbox.top - (50 - bbox.height) / 2,
1038
- zIndex: 1000
1039
- }
1040
- }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1041
- style: {
1042
- width: 150,
1043
- height: 50,
1044
- textAlign: 'center',
1045
- paddingRight: 10,
1046
- fontSize: '16px',
1047
- lineHeight: '22px',
1048
- fontWeight: 600
1049
- },
1050
- value: distanceTextLeftHoleRuler,
1051
- onChange: function onChange(event) {
1052
- var value = new _immutable.Map({
1053
- length: (0, _convertUnits["default"])(event.target.value).from(scene.rulerUnit).to(scene.unit),
1054
- _length: event.target.value,
1055
- _unit: scene.rulerUnit
1056
- });
1057
- updateLeftHoleRulerAttribute(elementData, value);
1058
- },
1059
- precision: 2
1060
- }));
1061
- setRulerEdit(numberInputLeftHoleRuler);
1062
- projectActions.unselectAll();
1063
- break;
1064
- case 'rulerHole':
1065
- var _lengthRulerHole = (0, _convertUnits["default"])(elementData.length).from(scene.unit).to(scene.rulerUnit);
1066
- var distanceTextRulerHole = "".concat((0, _math.formatNumber)(_lengthRulerHole, _constants.DECIMAL_PLACES_2));
1067
- var numberInputRulerHole = /*#__PURE__*/_react["default"].createElement("div", {
1068
- id: "ruler_numberInput",
1069
- style: {
1070
- position: 'absolute',
1071
- left: bbox.left - (150 - bbox.width) / 2,
1072
- top: bbox.top - (50 - bbox.height) / 2,
1073
- zIndex: 1000
1074
- }
1075
- }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1076
- style: {
1077
- width: 150,
1078
- height: 50,
1079
- textAlign: 'center',
1080
- paddingRight: 10,
1081
- fontSize: '16px',
1082
- lineHeight: '22px',
1083
- fontWeight: 600
1084
- },
1085
- value: distanceTextRulerHole,
1086
- onChange: function onChange(event) {
1087
- var value = new _immutable.Map({
1088
- length: (0, _convertUnits["default"])(event.target.value).from(scene.rulerUnit).to(scene.unit),
1089
- _length: event.target.value,
1090
- _unit: scene.rulerUnit
1091
- });
1092
- updateHoleRulerAttribute(elementData, value);
1093
- },
1094
- precision: 2
1095
- }));
1096
- setRulerEdit(numberInputRulerHole);
1097
- projectActions.unselectAll();
1098
- break;
1099
- case 'rightHoleRuler':
1100
- var _lengthRightHoleRuler = (0, _convertUnits["default"])(elementData.length).from(scene.unit).to(scene.rulerUnit);
1101
- var distanceTextRightHoleRuler = "".concat(_lengthRightHoleRuler.toFixed(2));
1102
- var numberInputRightHoleRuler = /*#__PURE__*/_react["default"].createElement("div", {
1103
- id: "ruler_numberInput",
1104
- style: {
1105
- position: 'absolute',
1106
- left: bbox.left - (150 - bbox.width) / 2,
1107
- top: bbox.top - (50 - bbox.height) / 2,
1108
- zIndex: 1000
1109
- }
1110
- }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1111
- style: {
1112
- width: 150,
1113
- height: 50,
1114
- textAlign: 'center',
1115
- paddingRight: 10,
1116
- fontSize: '16px',
1117
- lineHeight: '22px',
1118
- fontWeight: 600
1119
- },
1120
- value: distanceTextRightHoleRuler,
1121
- onChange: function onChange(event) {
1122
- var value = new _immutable.Map({
1123
- length: (0, _convertUnits["default"])(event.target.value).from(scene.rulerUnit).to(scene.unit),
1124
- _length: event.target.value,
1125
- _unit: scene.rulerUnit
1126
- });
1127
- updateRightHoleRulerAttribute(elementData, value);
1128
- },
1129
- precision: 2
1130
- }));
1131
- setRulerEdit(numberInputRightHoleRuler);
1132
- projectActions.unselectAll();
1133
- break;
1134
- case 'angleChange':
1135
- var _length2 = elementData.length;
1136
- var numberInput2 = /*#__PURE__*/_react["default"].createElement("div", {
1137
- id: "ruler_numberInput",
1138
- style: {
1139
- position: 'absolute',
1140
- left: bbox.left - (150 - bbox.width) / 2,
1141
- top: bbox.top - (50 - bbox.height) / 2,
1142
- zIndex: 1000
1143
- }
1144
- }, /*#__PURE__*/_react["default"].createElement(_formNumberInput["default"], {
1145
- style: {
1146
- width: 50,
1147
- height: 50
1148
- },
1149
- value: _length2,
1150
- onChange: function onChange(event) {
1151
- var value = new _immutable.Map({
1152
- length: (0, _convertUnits["default"])(event.target.value).from(scene.rulerUnit).to(scene.unit),
1153
- _length: event.target.value,
1154
- _unit: scene.rulerUnit
1155
- });
1156
- updateangleChangeAttribute(elementData, value);
1157
- },
1158
- precision: 2
1159
- }));
1160
- setRulerEdit(numberInput2);
1161
- projectActions.unselectAll();
1162
- break;
1163
- case 'none':
1164
- projectActions.unselectAll();
1165
- break;
1166
- }
1167
- break;
1168
- case constants.MODE_WAITING_DRAWING_LINE:
1169
- setdrawStart(true);
1170
- linesActions.beginDrawingLine(layerID, x, y, state.snapMask);
1171
- break;
1172
- case constants.MODE_DRAWING_LINE:
1173
- // Blocked 90 degree snap.
1174
- // let prevVertexID = state.getIn(['scene', 'layers', layerID, 'selected', 'vertices']).toJS()[0];
1175
- // let prevVertex = state.getIn(['scene', 'layers', layerID, 'vertices', prevVertexID]);
1176
- // let dx = Math.abs(x - prevVertex.x);
1177
- // let dy = Math.abs(y - prevVertex.y);
1178
- // if (dx > dy) y = prevVertex.y
1179
- // else x = prevVertex.x;
1180
- setdrawStart(true);
1181
- var lineID = state.getIn(['scene', 'layers', layerID, 'selected', 'lines']).first();
1182
- var drawingLine = state.getIn(['scene', 'layers', layerID, 'lines', lineID]).toJS();
1183
- // get the lines that have same points with drawing line.
1184
- var tlines = [];
1185
- getRelatedLines(tlines, drawingLine, vertices, lines);
1186
- setRelatedLines(tlines);
1187
- var endInfor = getEndPoint(vertices, x, y, 'END_DRAWIN_LINE');
1188
- linesActions.endDrawingLine(endInfor.x, endInfor.y, state.snapMask);
1189
- linesActions.beginDrawingLine(layerID, endInfor.x, endInfor.y, state.snapMask);
1190
- break;
1191
- case constants.MODE_DRAWING_HOLE:
1192
- holesActions.endDrawingHole(layerID, x, y);
1193
- break;
1194
- case constants.MODE_DRAWING_ITEM:
1195
- itemsActions.endDrawingItem(layerID, endPoint.x, endPoint.y);
1196
- break;
1197
- case constants.MODE_DRAGGING_LINE:
1198
- linesActions.endDraggingLine(x, y, relatedLines, state.snapMask);
1199
- break;
1200
- case constants.MODE_DRAGGING_VERTEX:
1201
- var result = getEndPoint(vertices, x, y, 'DRAGGING_VERTEX');
1202
- verticesActions.endDraggingVertex(result.x, result.y, state.snapMask);
1203
- break;
1204
- case constants.MODE_DRAGGING_ITEM:
1205
- itemsActions.updateMolding();
1206
- projectActions.setMode(_constants.MODE_IDLE);
1207
- break;
1208
- case constants.MODE_DRAGGING_HOLE:
1209
- holesActions.endDraggingHole(x, y);
1210
- break;
1211
- case constants.MODE_ROTATING_ITEM:
1212
- itemsActions.endRotatingItem(x, y);
1213
- break;
1214
- }
1215
- event.stopPropagation();
1216
- };
1217
- var onChangeValue = function onChangeValue(value) {
1218
- if (sFlag) return;
1219
- var _zoomValue = parseInt((value.a - 0.5) / constants.ZOOM_VARIABLE);
1220
- if (_zoomValue > 404) return;
1221
- if (_zoomValue < 0 || Number.isNaN(_zoomValue)) return;
1222
- if (rulerEdit !== null && value.startX && value.startY || value.lastAction === 'zoom') {
1223
- var _rulerEdit = document.getElementById('ruler_numberInput'),
1224
- _rect;
1225
- if (rulerEditID !== null) {
1226
- _rect = document.getElementById(rulerEditID);
1227
- }
1228
- var bbox;
1229
- if (_rect && _rulerEdit) {
1230
- bbox = _rect.getBoundingClientRect();
1231
- // bbox.width = _rect.getBBox().width;
1232
- // bbox.height = _rect.getBBox().height;
1233
- _rulerEdit.style.left = "".concat(bbox.left - (150 - bbox.width) / 2, "px");
1234
- _rulerEdit.style.top = "".concat(bbox.top - (50 - bbox.height) / 2, "px");
1235
- }
1236
- }
1237
- if (value.e <= 10 && value.e + value.a * value.SVGWidth + 10 >= value.viewerWidth && value.f <= 80 && value.f + value.d * value.SVGHeight + 10 >= value.viewerHeight) {
1238
- /*let val = Object.assign({}, value);
1239
- if (refresh === 2) {
1240
- val.a += 0.4; val.d += 0.4;
1241
- val.e -= (val.SVGWidth * val.a - val.SVGWidth * (val.a - 0.4)) / 2;
1242
- val.f -= (val.SVGHeight * val.d - val.SVGHeight * (val.d - 0.4)) / 2;
1243
- console.log('----', val)
1244
- }*/
1245
- projectActions.updateZoomScale(value.a);
1246
- return viewer2DActions.updateCameraView(value);
1247
- }
1248
- };
1249
- var onChangeTool = function onChangeTool(tool) {
1250
- switch (tool) {
1251
- case _reactSvgPanZoom.TOOL_NONE:
1252
- projectActions.selectToolEdit();
1253
- break;
1254
- case _reactSvgPanZoom.TOOL_PAN:
1255
- viewer2DActions.selectToolPan();
1256
- break;
1257
- case _reactSvgPanZoom.TOOL_ZOOM_IN:
1258
- viewer2DActions.selectToolZoomIn();
1259
- break;
1260
- case _reactSvgPanZoom.TOOL_ZOOM_OUT:
1261
- viewer2DActions.selectToolZoomOut();
1262
- break;
1263
- }
1264
- };
1265
- var onZoom = function onZoom(value) {
1266
- // var nextValue = viewer2D.toJS();
1267
- // nextValue = zoom(nextValue, 0, 0, value.a / nextValue.a)
1268
- // projectActions.updateZoomScale(nextValue.a);
1269
- // return viewer2DActions.updateCameraView(nextValue)
1270
- };
1271
- var _state$get$toJS = state.get('viewer2D').toJS(),
1272
- e = _state$get$toJS.e,
1273
- f = _state$get$toJS.f,
1274
- SVGWidth = _state$get$toJS.SVGWidth,
1275
- SVGHeight = _state$get$toJS.SVGHeight;
1276
- var rulerSize = 0; //px
1277
- var rulerUnitPixelSize = 100;
1278
- var rulerBgColor = SharedStyle.PRIMARY_COLOR.main;
1279
- var rulerFnColor = SharedStyle.COLORS.white;
1280
- var rulerMkColor = SharedStyle.SECONDARY_COLOR.main;
1281
- var sceneWidth = SVGWidth || state.getIn(['scene', 'width']);
1282
- var sceneHeight = SVGHeight || state.getIn(['scene', 'height']);
1283
- var sceneZoom = state.zoom || 1;
1284
- var rulerXElements = Math.ceil(sceneWidth / rulerUnitPixelSize) + 1;
1285
- var rulerYElements = Math.ceil(sceneHeight / rulerUnitPixelSize) + 1;
1286
- return /*#__PURE__*/_react["default"].createElement("div", null, rulerEdit, /*#__PURE__*/_react["default"].createElement("div", {
1287
- style: {
1288
- margin: 0,
1289
- padding: 0,
1290
- display: 'grid',
1291
- gridRowGap: '0',
1292
- gridColumnGap: '0',
1293
- gridTemplateColumns: "".concat(rulerSize, "px ").concat(width - rulerSize, "px"),
1294
- gridTemplateRows: "".concat(rulerSize, "px ").concat(height - rulerSize, "px"),
1295
- position: 'relative'
1296
- }
1297
- }, /*#__PURE__*/_react["default"].createElement("div", {
1298
- style: {
1299
- gridColumn: 1,
1300
- gridRow: 1,
1301
- backgroundColor: rulerBgColor
1302
- }
1303
- }), /*#__PURE__*/_react["default"].createElement("div", {
1304
- style: {
1305
- gridRow: 1,
1306
- gridColumn: 2,
1307
- position: 'relative',
1308
- overflow: 'hidden'
1309
- },
1310
- id: "rulerX"
1311
- }, sceneWidth ? /*#__PURE__*/_react["default"].createElement(_export.RulerX, {
1312
- unitPixelSize: rulerUnitPixelSize,
1313
- zoom: sceneZoom,
1314
- mouseX: state.mouse.get('x'),
1315
- width: width - rulerSize,
1316
- zeroLeftPosition: e || 0,
1317
- backgroundColor: rulerBgColor,
1318
- fontColor: rulerFnColor,
1319
- markerColor: rulerMkColor,
1320
- positiveUnitsNumber: rulerXElements,
1321
- negativeUnitsNumber: 0
1322
- }) : null), /*#__PURE__*/_react["default"].createElement("div", {
1323
- style: {
1324
- gridColumn: 1,
1325
- gridRow: 2,
1326
- position: 'relative',
1327
- overflow: 'hidden'
1328
- },
1329
- id: "rulerY"
1330
- }, sceneHeight ? /*#__PURE__*/_react["default"].createElement(_export.RulerY, {
1331
- unitPixelSize: rulerUnitPixelSize,
1332
- zoom: sceneZoom,
1333
- mouseY: state.mouse.get('y'),
1334
- height: height - rulerSize,
1335
- zeroTopPosition: sceneHeight * sceneZoom + f || 0,
1336
- backgroundColor: rulerBgColor,
1337
- fontColor: rulerFnColor,
1338
- markerColor: rulerMkColor,
1339
- positiveUnitsNumber: rulerYElements,
1340
- negativeUnitsNumber: 0
1341
- }) : null), /*#__PURE__*/_react["default"].createElement(_reactSvgPanZoom.ReactSVGPanZoom, {
1342
- style: {
1343
- gridColumn: 2,
1344
- gridRow: 2
1345
- },
1346
- width: width - rulerSize,
1347
- height: height - rulerSize,
1348
- value: viewer2D.isEmpty() ? null : viewer2D.toJS(),
1349
- onChangeValue: onChangeValue,
1350
- tool: mode2Tool(mode),
1351
- onChangeTool: onChangeTool,
1352
- detectAutoPan: mode2DetectAutopan(mode),
1353
- onMouseDown: onMouseDown,
1354
- onMouseMove: onMouseMove,
1355
- onMouseUp: onMouseUp,
1356
- miniaturePosition: "none",
1357
- toolbarPosition: "none",
1358
- detectPinchGesture: false,
1359
- disableDoubleClickZoomWithToolAuto: true,
1360
- ref: Viewer
1361
- }, /*#__PURE__*/_react["default"].createElement("svg", {
1362
- width: scene.width,
1363
- height: scene.height
1364
- }, /*#__PURE__*/_react["default"].createElement("defs", null, /*#__PURE__*/_react["default"].createElement("pattern", {
1365
- id: "diagonalFill",
1366
- patternUnits: "userSpaceOnUse",
1367
- width: "4",
1368
- height: "4",
1369
- fill: "#FFF"
1370
- }, /*#__PURE__*/_react["default"].createElement("rect", {
1371
- x: "0",
1372
- y: "0",
1373
- width: "4",
1374
- height: "4",
1375
- fill: "#FFF"
1376
- }), /*#__PURE__*/_react["default"].createElement("path", {
1377
- d: "M-1,1 l2,-2 M0,4 l4,-4 M3,5 l2,-2",
1378
- style: {
1379
- stroke: '#8E9BA2',
1380
- strokeWidth: 1
1381
- }
1382
- }))), /*#__PURE__*/_react["default"].createElement("g", {
1383
- style: Object.assign(mode2Cursor(mode), mode2PointerEvents(mode))
1384
- }, /*#__PURE__*/_react["default"].createElement(_state["default"], {
1385
- state: state,
1386
- catalog: catalog,
1387
- viewer2DActions: viewer2DActions,
1388
- relatedLines: relatedLines
1389
- }))))));
1390
- }
1391
- Viewer2D.propTypes = {
1392
- state: _propTypes["default"].object.isRequired,
1393
- width: _propTypes["default"].number.isRequired,
1394
- height: _propTypes["default"].number.isRequired
1395
- };
1396
- Viewer2D.contextTypes = {
1397
- viewer2DActions: _propTypes["default"].object.isRequired,
1398
- linesActions: _propTypes["default"].object.isRequired,
1399
- holesActions: _propTypes["default"].object.isRequired,
1400
- verticesActions: _propTypes["default"].object.isRequired,
1401
- itemsActions: _propTypes["default"].object.isRequired,
1402
- areaActions: _propTypes["default"].object.isRequired,
1403
- projectActions: _propTypes["default"].object.isRequired,
1404
- catalog: _propTypes["default"].object.isRequired
1405
- };