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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (358) hide show
  1. package/es/@history.js +2 -0
  2. package/es/AppContext.js +3 -0
  3. package/es/KitchenConfigurator.js +645 -0
  4. package/es/KitchenConfiguratorApp.js +480 -0
  5. package/es/actions/area-actions.js +14 -0
  6. package/es/actions/export.js +23 -0
  7. package/es/actions/groups-actions.js +89 -0
  8. package/es/actions/holes-actions.js +119 -0
  9. package/es/actions/items-actions.js +313 -0
  10. package/es/actions/lines-actions.js +81 -0
  11. package/es/actions/project-actions.js +281 -0
  12. package/es/actions/scene-actions.js +33 -0
  13. package/es/actions/vertices-actions.js +27 -0
  14. package/es/actions/viewer2d-actions.js +58 -0
  15. package/es/actions/viewer3d-actions.js +23 -0
  16. package/es/catalog/areas/area/planner-element.js +40 -0
  17. package/es/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
  18. package/es/catalog/areas/area/textures/grass.jpg +0 -0
  19. package/es/catalog/areas/area/textures/parquet.jpg +0 -0
  20. package/es/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
  21. package/es/catalog/areas/area/textures/tile1.jpg +0 -0
  22. package/es/catalog/catalog.js +277 -0
  23. package/es/catalog/envMap/nx.hdr +0 -0
  24. package/es/catalog/envMap/ny.hdr +0 -0
  25. package/es/catalog/envMap/nz.hdr +0 -0
  26. package/es/catalog/envMap/px.hdr +0 -0
  27. package/es/catalog/envMap/py.hdr +0 -0
  28. package/es/catalog/envMap/pz.hdr +0 -0
  29. package/es/catalog/factories/area-factory-3d.js +181 -0
  30. package/es/catalog/factories/area-factory.js +81 -0
  31. package/es/catalog/factories/export.js +7 -0
  32. package/es/catalog/factories/wall-factory-3d.js +202 -0
  33. package/es/catalog/factories/wall-factory.js +268 -0
  34. package/es/catalog/holes/door-closet/planner-element.js +222 -0
  35. package/es/catalog/holes/door-double/door_double.png +0 -0
  36. package/es/catalog/holes/door-double/planner-element.js +315 -0
  37. package/es/catalog/holes/door-exterior/planner-element.js +215 -0
  38. package/es/catalog/holes/door-interior/planner-element.js +227 -0
  39. package/es/catalog/holes/door-panic/panicDoor.png +0 -0
  40. package/es/catalog/holes/door-panic/planner-element.js +503 -0
  41. package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
  42. package/es/catalog/holes/door-panic-double/planner-element.js +463 -0
  43. package/es/catalog/holes/door-sliding/planner-element.js +225 -0
  44. package/es/catalog/holes/doorway-framed/planner-element.js +145 -0
  45. package/es/catalog/holes/doorway-frameless/planner-element.js +104 -0
  46. package/es/catalog/holes/export.js +13 -0
  47. package/es/catalog/holes/gate/gate.jpg +0 -0
  48. package/es/catalog/holes/window-clear/planner-element.js +166 -0
  49. package/es/catalog/holes/window-clear/texture.png +0 -0
  50. package/es/catalog/holes/window-cross/planner-element.js +165 -0
  51. package/es/catalog/holes/window-cross/texture.png +0 -0
  52. package/es/catalog/holes/window-double-hung/planner-element.js +303 -0
  53. package/es/catalog/holes/window-double-hung/texture.png +0 -0
  54. package/es/catalog/holes/window-vertical/planner-element.js +276 -0
  55. package/es/catalog/holes/window-vertical/texture.png +0 -0
  56. package/es/catalog/lines/wall/planner-element.js +70 -0
  57. package/es/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
  58. package/es/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
  59. package/es/catalog/lines/wall/textures/bricks.jpg +0 -0
  60. package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
  61. package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
  62. package/es/catalog/lines/wall/textures/morden-normal.jpg +0 -0
  63. package/es/catalog/lines/wall/textures/morden.jpg +0 -0
  64. package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
  65. package/es/catalog/lines/wall/textures/painted.jpg +0 -0
  66. package/es/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
  67. package/es/catalog/lines/wall/textures/plaster.jpg +0 -0
  68. package/es/catalog/lines/wall/wall.png +0 -0
  69. package/es/catalog/molding/molding-dcm/planner-element.js +28 -0
  70. package/es/catalog/molding/molding-dcm/texture.png +0 -0
  71. package/es/catalog/molding/molding-fbm/planner-element.js +28 -0
  72. package/es/catalog/molding/molding-fbm/texture.png +0 -0
  73. package/es/catalog/molding/molding-lrm/planner-element.js +28 -0
  74. package/es/catalog/molding/molding-lrm/texture.png +0 -0
  75. package/es/catalog/properties/export.js +21 -0
  76. package/es/catalog/properties/property-checkbox.js +116 -0
  77. package/es/catalog/properties/property-color.js +39 -0
  78. package/es/catalog/properties/property-enum.js +97 -0
  79. package/es/catalog/properties/property-hidden.js +19 -0
  80. package/es/catalog/properties/property-lenght-measure.js +101 -0
  81. package/es/catalog/properties/property-length-measure.js +134 -0
  82. package/es/catalog/properties/property-length-measure_hole.js +101 -0
  83. package/es/catalog/properties/property-number.js +48 -0
  84. package/es/catalog/properties/property-read-only.js +26 -0
  85. package/es/catalog/properties/property-string.js +48 -0
  86. package/es/catalog/properties/property-toggle.js +39 -0
  87. package/es/catalog/properties/shared-property-style.js +14 -0
  88. package/es/catalog/utils/FuseUtils.js +82 -0
  89. package/es/catalog/utils/exporter.js +148 -0
  90. package/es/catalog/utils/geom-utils.js +189 -0
  91. package/es/catalog/utils/item-loader.js +1521 -0
  92. package/es/catalog/utils/load-obj.js +91 -0
  93. package/es/catalog/utils/mtl-loader.js +358 -0
  94. package/es/catalog/utils/obj-loader.js +477 -0
  95. package/es/class/FuseUtils.js +82 -0
  96. package/es/class/area.js +145 -0
  97. package/es/class/export.js +24 -0
  98. package/es/class/group.js +440 -0
  99. package/es/class/guide.js +62 -0
  100. package/es/class/hole.js +929 -0
  101. package/es/class/item.js +1883 -0
  102. package/es/class/layer.js +667 -0
  103. package/es/class/line.js +1180 -0
  104. package/es/class/project.js +793 -0
  105. package/es/class/vertex.js +202 -0
  106. package/es/components/content.js +107 -0
  107. package/es/components/disclaimer/disclaimer.js +97 -0
  108. package/es/components/export.js +9 -0
  109. package/es/components/style/button.js +113 -0
  110. package/es/components/style/cancel-button.js +22 -0
  111. package/es/components/style/content-container.js +33 -0
  112. package/es/components/style/content-title.js +29 -0
  113. package/es/components/style/delete-button.js +25 -0
  114. package/es/components/style/export.js +31 -0
  115. package/es/components/style/form-block.js +24 -0
  116. package/es/components/style/form-color-input.js +27 -0
  117. package/es/components/style/form-label.js +26 -0
  118. package/es/components/style/form-number-input.js +213 -0
  119. package/es/components/style/form-number-input_2.js +206 -0
  120. package/es/components/style/form-select.js +68 -0
  121. package/es/components/style/form-slider.js +61 -0
  122. package/es/components/style/form-submit-button.js +26 -0
  123. package/es/components/style/form-text-input.js +95 -0
  124. package/es/components/viewer2d/area.js +81 -0
  125. package/es/components/viewer2d/export.js +31 -0
  126. package/es/components/viewer2d/grids/grid-horizontal-streak.js +37 -0
  127. package/es/components/viewer2d/grids/grid-streak.js +37 -0
  128. package/es/components/viewer2d/grids/grid-vertical-streak.js +37 -0
  129. package/es/components/viewer2d/grids/grids.js +35 -0
  130. package/es/components/viewer2d/group.js +53 -0
  131. package/es/components/viewer2d/item.js +513 -0
  132. package/es/components/viewer2d/layer.js +164 -0
  133. package/es/components/viewer2d/line.js +882 -0
  134. package/es/components/viewer2d/ruler.js +100 -0
  135. package/es/components/viewer2d/rulerDist.js +146 -0
  136. package/es/components/viewer2d/rulerX.js +151 -0
  137. package/es/components/viewer2d/rulerY.js +153 -0
  138. package/es/components/viewer2d/scene.js +140 -0
  139. package/es/components/viewer2d/snap.js +74 -0
  140. package/es/components/viewer2d/state.js +78 -0
  141. package/es/components/viewer2d/utils.js +198 -0
  142. package/es/components/viewer2d/vertex.js +65 -0
  143. package/es/components/viewer2d/viewer2d.js +1398 -0
  144. package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +2592 -0
  145. package/es/components/viewer3d/dcm.js +401 -0
  146. package/es/components/viewer3d/fbm.js +414 -0
  147. package/es/components/viewer3d/front3D.js +66 -0
  148. package/es/components/viewer3d/grid-creator.js +25 -0
  149. package/es/components/viewer3d/grids/grid-horizontal-streak.js +36 -0
  150. package/es/components/viewer3d/grids/grid-streak.js +27 -0
  151. package/es/components/viewer3d/grids/grid-vertical-streak.js +36 -0
  152. package/es/components/viewer3d/libs/first-person-controls.js +67 -0
  153. package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +1281 -0
  154. package/es/components/viewer3d/libs/mtl-loader.js +357 -0
  155. package/es/components/viewer3d/libs/obj-loader.js +462 -0
  156. package/es/components/viewer3d/libs/orbit-controls.js +699 -0
  157. package/es/components/viewer3d/libs/pointer-lock-controls.js +46 -0
  158. package/es/components/viewer3d/lrm.js +305 -0
  159. package/es/components/viewer3d/model.js +708 -0
  160. package/es/components/viewer3d/pointer-lock-navigation.js +115 -0
  161. package/es/components/viewer3d/ruler-utils/itemRect.js +61 -0
  162. package/es/components/viewer3d/ruler-utils/layer3D.js +495 -0
  163. package/es/components/viewer3d/ruler-utils/ruler3D.js +227 -0
  164. package/es/components/viewer3d/ruler-utils/scene3D.js +60 -0
  165. package/es/components/viewer3d/ruler-utils/state3D.js +18 -0
  166. package/es/components/viewer3d/scene-creator.js +3608 -0
  167. package/es/components/viewer3d/three-memory-cleaner.js +51 -0
  168. package/es/components/viewer3d/viewer3d-first-person.js +315 -0
  169. package/es/components/viewer3d/viewer3d.js +2527 -0
  170. package/es/constants.js +636 -0
  171. package/es/index.js +16 -0
  172. package/es/models.js +510 -0
  173. package/es/plugins/SVGLoader.js +1412 -0
  174. package/es/plugins/autosave.js +33 -0
  175. package/es/plugins/console-debugger.js +37 -0
  176. package/es/plugins/export.js +9 -0
  177. package/es/plugins/keyboard.js +101 -0
  178. package/es/reducers/areas-reducer.js +12 -0
  179. package/es/reducers/export.js +25 -0
  180. package/es/reducers/groups-reducer.js +38 -0
  181. package/es/reducers/holes-reducer.js +62 -0
  182. package/es/reducers/items-reducer.js +140 -0
  183. package/es/reducers/lines-reducer.js +45 -0
  184. package/es/reducers/project-reducer.js +129 -0
  185. package/es/reducers/reducer.js +19 -0
  186. package/es/reducers/scene-reducer.js +28 -0
  187. package/es/reducers/user-reducer.js +40 -0
  188. package/es/reducers/vertices-reducer.js +19 -0
  189. package/es/reducers/viewer2d-reducer.js +75 -0
  190. package/es/reducers/viewer3d-reducer.js +56 -0
  191. package/es/shared-style.js +66 -0
  192. package/es/styles/export.js +5 -0
  193. package/es/styles/tabs.css +40 -0
  194. package/es/translator/en.js +104 -0
  195. package/es/translator/it.js +79 -0
  196. package/es/translator/ru.js +79 -0
  197. package/es/translator/translator.js +84 -0
  198. package/es/utils/browser.js +33 -0
  199. package/es/utils/email-validator.js +4 -0
  200. package/es/utils/export.js +25 -0
  201. package/es/utils/geometry.js +2420 -0
  202. package/es/utils/get-edges-of-subgraphs.js +27 -0
  203. package/es/utils/graph-cycles.js +237 -0
  204. package/es/utils/graph-inner-cycles.js +46 -0
  205. package/es/utils/graph.js +150 -0
  206. package/es/utils/helper.js +268 -0
  207. package/es/utils/history.js +29 -0
  208. package/es/utils/id-broker.js +19 -0
  209. package/es/utils/logger.js +8 -0
  210. package/es/utils/math.js +50 -0
  211. package/es/utils/molding.js +871 -0
  212. package/es/utils/name-generator.js +18 -0
  213. package/es/utils/objects-utils.js +50 -0
  214. package/es/utils/phone-validator.js +4 -0
  215. package/es/utils/process-black-list.js +18 -0
  216. package/es/utils/react-if.js +18 -0
  217. package/es/utils/snap-scene.js +99 -0
  218. package/es/utils/snap.js +237 -0
  219. package/es/utils/summarizeCart.js +24 -0
  220. package/es/utils/threeCSG.es6.js +498 -0
  221. package/es/version.js +2 -0
  222. package/lib/catalog/properties/property-string.js +55 -0
  223. package/lib/catalog/properties/property-toggle.js +46 -0
  224. package/lib/catalog/properties/shared-property-style.js +20 -0
  225. package/lib/catalog/utils/FuseUtils.js +88 -0
  226. package/lib/catalog/utils/exporter.js +155 -0
  227. package/lib/catalog/utils/geom-utils.js +205 -0
  228. package/lib/catalog/utils/item-loader.js +1533 -0
  229. package/lib/catalog/utils/load-obj.js +99 -0
  230. package/lib/catalog/utils/mtl-loader.js +363 -0
  231. package/lib/catalog/utils/obj-loader.js +482 -0
  232. package/lib/class/FuseUtils.js +88 -0
  233. package/lib/class/area.js +150 -0
  234. package/lib/class/export.js +96 -0
  235. package/lib/class/group.js +445 -0
  236. package/lib/class/guide.js +67 -0
  237. package/lib/class/hole.js +934 -0
  238. package/lib/class/item.js +1889 -0
  239. package/lib/class/layer.js +672 -0
  240. package/lib/class/line.js +1186 -0
  241. package/lib/class/project.js +799 -0
  242. package/lib/class/vertex.js +207 -0
  243. package/lib/components/content.js +116 -0
  244. package/lib/components/disclaimer/disclaimer.js +105 -0
  245. package/lib/components/export.js +33 -0
  246. package/lib/components/style/button.js +120 -0
  247. package/lib/components/style/cancel-button.js +29 -0
  248. package/lib/components/style/content-container.js +40 -0
  249. package/lib/components/style/content-title.js +37 -0
  250. package/lib/components/style/delete-button.js +34 -0
  251. package/lib/components/style/export.js +121 -0
  252. package/lib/components/style/form-block.js +31 -0
  253. package/lib/components/style/form-color-input.js +34 -0
  254. package/lib/components/style/form-label.js +33 -0
  255. package/lib/components/style/form-number-input.js +220 -0
  256. package/lib/components/style/form-number-input_2.js +213 -0
  257. package/lib/components/style/form-select.js +75 -0
  258. package/lib/components/style/form-slider.js +68 -0
  259. package/lib/components/style/form-submit-button.js +35 -0
  260. package/lib/components/style/form-text-input.js +101 -0
  261. package/lib/components/viewer2d/area.js +88 -0
  262. package/lib/components/viewer2d/export.js +121 -0
  263. package/lib/components/viewer2d/grids/grid-horizontal-streak.js +44 -0
  264. package/lib/components/viewer2d/grids/grid-streak.js +44 -0
  265. package/lib/components/viewer2d/grids/grid-vertical-streak.js +44 -0
  266. package/lib/components/viewer2d/grids/grids.js +44 -0
  267. package/lib/components/viewer2d/group.js +62 -0
  268. package/lib/components/viewer2d/item.js +521 -0
  269. package/lib/components/viewer2d/layer.js +171 -0
  270. package/lib/components/viewer2d/line.js +892 -0
  271. package/lib/components/viewer2d/ruler.js +107 -0
  272. package/lib/components/viewer2d/rulerDist.js +153 -0
  273. package/lib/components/viewer2d/rulerX.js +158 -0
  274. package/lib/components/viewer2d/rulerY.js +160 -0
  275. package/lib/components/viewer2d/scene.js +147 -0
  276. package/lib/components/viewer2d/snap.js +83 -0
  277. package/lib/components/viewer2d/state.js +87 -0
  278. package/lib/components/viewer2d/utils.js +210 -0
  279. package/lib/components/viewer2d/vertex.js +74 -0
  280. package/lib/components/viewer2d/viewer2d.js +1405 -0
  281. package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +2597 -0
  282. package/lib/components/viewer3d/dcm.js +407 -0
  283. package/lib/components/viewer3d/fbm.js +420 -0
  284. package/lib/components/viewer3d/front3D.js +75 -0
  285. package/lib/components/viewer3d/grid-creator.js +34 -0
  286. package/lib/components/viewer3d/grids/grid-horizontal-streak.js +44 -0
  287. package/lib/components/viewer3d/grids/grid-streak.js +35 -0
  288. package/lib/components/viewer3d/grids/grid-vertical-streak.js +44 -0
  289. package/lib/components/viewer3d/libs/first-person-controls.js +74 -0
  290. package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +1287 -0
  291. package/lib/components/viewer3d/libs/mtl-loader.js +363 -0
  292. package/lib/components/viewer3d/libs/obj-loader.js +468 -0
  293. package/lib/components/viewer3d/libs/orbit-controls.js +705 -0
  294. package/lib/components/viewer3d/libs/pointer-lock-controls.js +52 -0
  295. package/lib/components/viewer3d/lrm.js +311 -0
  296. package/lib/components/viewer3d/model.js +714 -0
  297. package/lib/components/viewer3d/pointer-lock-navigation.js +122 -0
  298. package/lib/components/viewer3d/ruler-utils/itemRect.js +68 -0
  299. package/lib/components/viewer3d/ruler-utils/layer3D.js +502 -0
  300. package/lib/components/viewer3d/ruler-utils/ruler3D.js +234 -0
  301. package/lib/components/viewer3d/ruler-utils/scene3D.js +68 -0
  302. package/lib/components/viewer3d/ruler-utils/state3D.js +25 -0
  303. package/lib/components/viewer3d/scene-creator.js +3642 -0
  304. package/lib/components/viewer3d/three-memory-cleaner.js +60 -0
  305. package/lib/components/viewer3d/viewer3d-first-person.js +320 -0
  306. package/lib/components/viewer3d/viewer3d.js +2532 -0
  307. package/lib/constants.js +645 -0
  308. package/lib/index.js +96 -0
  309. package/lib/models.js +517 -0
  310. package/lib/plugins/SVGLoader.js +1417 -0
  311. package/lib/plugins/autosave.js +39 -0
  312. package/lib/plugins/console-debugger.js +44 -0
  313. package/lib/plugins/export.js +33 -0
  314. package/lib/plugins/keyboard.js +107 -0
  315. package/lib/reducers/areas-reducer.js +18 -0
  316. package/lib/reducers/export.js +97 -0
  317. package/lib/reducers/groups-reducer.js +44 -0
  318. package/lib/reducers/holes-reducer.js +68 -0
  319. package/lib/reducers/items-reducer.js +146 -0
  320. package/lib/reducers/lines-reducer.js +51 -0
  321. package/lib/reducers/project-reducer.js +135 -0
  322. package/lib/reducers/reducer.js +26 -0
  323. package/lib/reducers/scene-reducer.js +34 -0
  324. package/lib/reducers/user-reducer.js +46 -0
  325. package/lib/reducers/vertices-reducer.js +25 -0
  326. package/lib/reducers/viewer2d-reducer.js +82 -0
  327. package/lib/reducers/viewer3d-reducer.js +63 -0
  328. package/lib/shared-style.js +72 -0
  329. package/lib/styles/export.js +13 -0
  330. package/lib/translator/en.js +110 -0
  331. package/lib/translator/it.js +85 -0
  332. package/lib/translator/ru.js +85 -0
  333. package/lib/translator/translator.js +90 -0
  334. package/lib/utils/browser.js +40 -0
  335. package/lib/utils/email-validator.js +10 -0
  336. package/lib/utils/export.js +56 -0
  337. package/lib/utils/geometry.js +2516 -0
  338. package/lib/utils/get-edges-of-subgraphs.js +34 -0
  339. package/lib/utils/graph-cycles.js +240 -0
  340. package/lib/utils/graph-inner-cycles.js +54 -0
  341. package/lib/utils/graph.js +157 -0
  342. package/lib/utils/helper.js +291 -0
  343. package/lib/utils/history.js +36 -0
  344. package/lib/utils/id-broker.js +25 -0
  345. package/lib/utils/logger.js +14 -0
  346. package/lib/utils/math.js +57 -0
  347. package/lib/utils/molding.js +895 -0
  348. package/lib/utils/name-generator.js +23 -0
  349. package/lib/utils/objects-utils.js +60 -0
  350. package/lib/utils/phone-validator.js +10 -0
  351. package/lib/utils/process-black-list.js +24 -0
  352. package/lib/utils/react-if.js +24 -0
  353. package/lib/utils/snap-scene.js +105 -0
  354. package/lib/utils/snap.js +249 -0
  355. package/lib/utils/summarizeCart.js +30 -0
  356. package/lib/utils/threeCSG.es6.js +503 -0
  357. package/lib/version.js +8 -0
  358. package/package.json +3 -3
@@ -0,0 +1,51 @@
1
+ import * as Three from 'three';
2
+ function disposeGeometry(geometry) {
3
+ geometry.dispose();
4
+ }
5
+ function disposeTexture(texture) {
6
+ if (!texture) {
7
+ return;
8
+ }
9
+ texture.dispose();
10
+ }
11
+ function disposeMultimaterial(material) {
12
+ if (!(material.isMaterial && !Array.isArray(material))) {
13
+ return;
14
+ }
15
+ material.materials.forEach(function (material) {
16
+ disposeMaterial(material);
17
+ });
18
+ }
19
+ function disposeMaterial(material) {
20
+ if (!(material instanceof Three.Material)) {
21
+ return;
22
+ }
23
+
24
+ // disposeTexture(material.map);
25
+ // material.map = null;
26
+ material.dispose();
27
+ }
28
+ function disposeMesh(mesh) {
29
+ if (!(mesh instanceof Three.Mesh || mesh instanceof Three.BoxHelper || mesh instanceof Three.LineSegments)) {
30
+ return;
31
+ }
32
+ if (mesh.geometry) {
33
+ disposeGeometry(mesh.geometry);
34
+ }
35
+ // disposeMultimaterial(mesh.material);
36
+ disposeMaterial(mesh.material);
37
+ mesh.geometry = null;
38
+ mesh.material = null;
39
+ }
40
+ export function disposeScene(scene3D) {
41
+ scene3D.traverse(function (child) {
42
+ disposeMesh(child);
43
+ child = null;
44
+ });
45
+ }
46
+ export function disposeObject(object) {
47
+ object.traverse(function (child) {
48
+ disposeMesh(child);
49
+ child = null;
50
+ });
51
+ }
@@ -0,0 +1,315 @@
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
+ function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
5
+ 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); } }
6
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
7
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
8
+ 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); }
9
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
10
+ function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); }
11
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
12
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
13
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
14
+ function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); }
15
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
16
+ import React from 'react';
17
+ import PropTypes from 'prop-types';
18
+ import ReactDOM from 'react-dom';
19
+ import * as Three from 'three';
20
+ import { parseData, updateScene } from "./scene-creator";
21
+ import { disposeScene } from "./three-memory-cleaner";
22
+ import diff from 'immutablediff';
23
+ import { initPointerLock } from "./pointer-lock-navigation";
24
+ import { firstPersonOnKeyDown, firstPersonOnKeyUp } from "./libs/first-person-controls";
25
+ import * as SharedStyle from "../../shared-style";
26
+ var Viewer3DFirstPerson = /*#__PURE__*/function (_React$Component) {
27
+ function Viewer3DFirstPerson(props) {
28
+ var _this;
29
+ _classCallCheck(this, Viewer3DFirstPerson);
30
+ _this = _callSuper(this, Viewer3DFirstPerson, [props]);
31
+ _this.width = props.width;
32
+ _this.height = props.height;
33
+ _this.stopRendering = false;
34
+ _this.renderer = window.__threeRenderer || new Three.WebGLRenderer({
35
+ preserveDrawingBuffer: true
36
+ });
37
+ window.__threeRenderer = _this.renderer;
38
+ return _this;
39
+ }
40
+ _inherits(Viewer3DFirstPerson, _React$Component);
41
+ return _createClass(Viewer3DFirstPerson, [{
42
+ key: "componentDidMount",
43
+ value: function componentDidMount() {
44
+ var _this2 = this;
45
+ /** Variables for movement control **/
46
+ var prevTime = performance.now();
47
+ var velocity = new Three.Vector3();
48
+ var direction = new Three.Vector3();
49
+ var moveForward = false;
50
+ var moveBackward = false;
51
+ var moveLeft = false;
52
+ var moveRight = false;
53
+ var canJump = false;
54
+ var catalog = this.context.catalog;
55
+ var actions = {
56
+ areaActions: this.context.areaActions,
57
+ holesActions: this.context.holesActions,
58
+ itemsActions: this.context.itemsActions,
59
+ linesActions: this.context.linesActions,
60
+ projectActions: this.context.projectActions
61
+ };
62
+ var state = this.props.state;
63
+ var data = state.scene;
64
+ var canvasWrapper = ReactDOM.findDOMNode(this.refs.canvasWrapper);
65
+ var scene3D = new Three.Scene();
66
+
67
+ // As I need to show the pointer above all scene objects, I use this workaround http://stackoverflow.com/a/13309722
68
+ var sceneOnTop = new Three.Scene();
69
+
70
+ //RENDERER
71
+ this.renderer.setClearColor(new Three.Color(SharedStyle.COLORS.white));
72
+ this.renderer.setSize(this.width, this.height);
73
+
74
+ // LOAD DATA
75
+ this.planData = parseData(data, actions, catalog);
76
+ scene3D.add(this.planData.plan);
77
+
78
+ // CAMERA
79
+ var aspectRatio = this.width / this.height;
80
+ var camera = new Three.OrthographicCamera(width / -4, width / 4, height / 4, height / -4, 1, 1000);
81
+ sceneOnTop.add(camera); // The pointer is on the camera so I show it above all
82
+
83
+ // Set position for the camera
84
+ camera.position.set(0, 0, 0);
85
+ camera.up = new Three.Vector3(0, 1, 0);
86
+
87
+ // HELPER AXIS
88
+ // let axisHelper = new Three.AxisHelper(100);
89
+ // scene3D.add(axisHelper);
90
+
91
+ // LIGHT
92
+ var light = new Three.AmbientLight(0xafafaf); // soft white light
93
+ scene3D.add(light);
94
+
95
+ // Add another light
96
+ var pointLight = new Three.PointLight(SharedStyle.COLORS.white, 0.4, 1000);
97
+ pointLight.position.set(0, 0, 0);
98
+ scene3D.add(pointLight);
99
+
100
+ // POINTER LOCK
101
+
102
+ document.body.requestPointerLock = document.body.requestPointerLock || document.body.mozRequestPointerLock || document.body.webkitRequestPointerLock;
103
+ document.body.requestPointerLock();
104
+ var _initPointerLock = initPointerLock(camera, this.renderer.domElement),
105
+ controls = _initPointerLock.controls,
106
+ pointerlockChangeEvent = _initPointerLock.pointerlockChangeEvent,
107
+ requestPointerLockEvent = _initPointerLock.requestPointerLockEvent;
108
+ this.controls = controls;
109
+ this.pointerlockChangeListener = pointerlockChangeEvent;
110
+ this.requestPointerLockEvent = requestPointerLockEvent;
111
+
112
+ /* Set user initial position */
113
+ var humanHeight = 170; // 170 cm
114
+
115
+ var yInitialPosition = this.planData.boundingBox.min.y + (this.planData.boundingBox.min.y - this.planData.boundingBox.max.y) / 2 + humanHeight;
116
+ this.controls.getObject().position.set(-50, yInitialPosition, -100);
117
+ sceneOnTop.add(this.controls.getObject()); // Add the pointer lock controls to the scene that will be rendered on top
118
+
119
+ // Add move controls on the page
120
+ this.keyDownEvent = function (event) {
121
+ var moveResult = firstPersonOnKeyDown(event, moveForward, moveLeft, moveBackward, moveRight, canJump, velocity);
122
+ moveForward = moveResult.moveForward;
123
+ moveLeft = moveResult.moveLeft;
124
+ moveBackward = moveResult.moveBackward;
125
+ moveRight = moveResult.moveRight;
126
+ canJump = moveResult.canJump;
127
+ };
128
+ this.keyUpEvent = function (event) {
129
+ var moveResult = firstPersonOnKeyUp(event, moveForward, moveLeft, moveBackward, moveRight, canJump);
130
+ moveForward = moveResult.moveForward;
131
+ moveLeft = moveResult.moveLeft;
132
+ moveBackward = moveResult.moveBackward;
133
+ moveRight = moveResult.moveRight;
134
+ canJump = moveResult.canJump;
135
+ };
136
+ document.addEventListener('keydown', this.keyDownEvent);
137
+ document.addEventListener('keyup', this.keyUpEvent);
138
+
139
+ // Add a pointer to the scene
140
+
141
+ var pointer = new Three.Object3D();
142
+ pointer.name = 'pointer';
143
+ var pointerMaterial = new Three.MeshBasicMaterial({
144
+ depthTest: false,
145
+ depthWrite: false,
146
+ color: SharedStyle.COLORS.black
147
+ });
148
+ var pointerGeometry1 = new Three.BufferGeometry();
149
+ var vertice = [-10, 0, 0, 10, 0, 0];
150
+ pointerGeometry1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertice), 3));
151
+ var linePointer1 = new Three.Line(pointerGeometry1, pointerMaterial);
152
+ linePointer1.position.z -= 100;
153
+ var pointerGeometry2 = new Three.BufferGeometry();
154
+ vertice = [0, 10, 0, 0, -10, 0];
155
+ pointerGeometry2.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertice), 3));
156
+ var linePointer2 = new Three.Line(pointerGeometry2, pointerMaterial);
157
+ linePointer2.renderDepth = 1e20;
158
+ linePointer2.position.z -= 100;
159
+ var pointerGeometry3 = new Three.BufferGeometry();
160
+ vertice = [-1, 1, 0, 1, 1, 0, 1, -1, 0, -1, -1, 0, -1, 1, 0];
161
+ pointerGeometry3.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertice), 3));
162
+ var linePointer3 = new Three.Line(pointerGeometry3, pointerMaterial);
163
+ linePointer3.position.z -= 100;
164
+ pointer.add(linePointer1);
165
+ pointer.add(linePointer2);
166
+ pointer.add(linePointer3);
167
+ camera.add(pointer); // Add the pointer to the camera
168
+
169
+ // OBJECT PICKING
170
+ var toIntersect = [this.planData.plan];
171
+ var mouseVector = new Three.Vector2(0, 0);
172
+ var raycaster = new Three.Raycaster();
173
+ this.firstPersonMouseDown = function (event) {
174
+ // First of all I check if controls are enabled
175
+
176
+ if (_this2.controls.enabled) {
177
+ event.preventDefault();
178
+
179
+ /* Per avere la direzione da assegnare al raycaster, chiamo il metodo getDirection di PointerLockControls,
180
+ * che restituisce una funzione che a sua volta prende un vettore, vi scrive i valori degli oggetti
181
+ * pitch e yaw e lo restituisce */
182
+
183
+ raycaster.setFromCamera(mouseVector, camera);
184
+ var intersects = raycaster.intersectObjects(toIntersect, true);
185
+ if (intersects.length > 0 && !isNaN(intersects[0].distance)) {
186
+ intersects[0].object.interact && intersects[0].object.interact();
187
+ } else {
188
+ _this2.context.projectActions.unselectAll();
189
+ }
190
+ }
191
+ };
192
+ document.addEventListener('mousedown', this.firstPersonMouseDown, false);
193
+ this.renderer.domElement.style.display = 'block';
194
+
195
+ // add the output of the renderer to the html element
196
+ canvasWrapper.appendChild(this.renderer.domElement);
197
+ this.renderer.autoClear = false;
198
+ var _render = function render() {
199
+ if (!_this2.stopRendering) {
200
+ yInitialPosition = _this2.planData.boundingBox.min.y + humanHeight;
201
+ var multiplier = 5;
202
+ var time = performance.now();
203
+ var delta = (time - prevTime) / 1000 * multiplier;
204
+ velocity.x -= velocity.x * 10.0 * delta;
205
+ velocity.z -= velocity.z * 10.0 * delta;
206
+ velocity.y -= 9.8 * 100.0 * delta / multiplier; // 100.0 = mass
207
+
208
+ direction.z = Number(moveForward) - Number(moveBackward);
209
+ direction.x = Number(moveLeft) - Number(moveRight);
210
+ direction.normalize(); // this ensures consistent movements in all directions
211
+
212
+ if (moveForward || moveBackward) velocity.z -= direction.z * 400.0 * delta;
213
+ if (moveLeft || moveRight) velocity.x -= direction.x * 400.0 * delta;
214
+ _this2.controls.getObject().translateX(velocity.x * delta);
215
+ _this2.controls.getObject().translateY(velocity.y * delta);
216
+ _this2.controls.getObject().translateZ(velocity.z * delta);
217
+ if (_this2.controls.getObject().position.y < yInitialPosition) {
218
+ velocity.y = 0;
219
+ _this2.controls.getObject().position.y = yInitialPosition;
220
+ canJump = true;
221
+ }
222
+ prevTime = time;
223
+
224
+ // Set light position
225
+ var controlObjectPosition = _this2.controls.getObject().position;
226
+ pointLight.position.set(controlObjectPosition.x, controlObjectPosition.y, controlObjectPosition.z);
227
+ for (var elemID in _this2.planData.sceneGraph.LODs) {
228
+ _this2.planData.sceneGraph.LODs[elemID].update(camera);
229
+ }
230
+ _this2.renderer.clear(); // clear buffers
231
+ _this2.renderer.render(scene3D, camera); // render scene 1
232
+ _this2.renderer.clearDepth(); // clear depth buffer
233
+ _this2.renderer.render(sceneOnTop, camera); // render scene 2
234
+
235
+ requestAnimationFrame(_render);
236
+ }
237
+ };
238
+ _render();
239
+ this.camera = camera;
240
+ this.scene3D = scene3D;
241
+ this.sceneOnTop = sceneOnTop;
242
+ // this.planData = planData;
243
+ }
244
+ }, {
245
+ key: "componentWillUnmount",
246
+ value: function componentWillUnmount() {
247
+ this.stopRendering = true;
248
+ this.renderer.autoClear = true;
249
+ document.removeEventListener('mousedown', this.firstPersonMouseDown);
250
+ document.removeEventListener('keydown', this.keyDownEvent);
251
+ document.removeEventListener('keyup', this.keyUpEvent);
252
+ document.removeEventListener('pointerlockchange', this.pointerlockChangeEvent);
253
+ document.removeEventListener('mozpointerlockchange', this.pointerlockChangeEvent);
254
+ document.removeEventListener('webkitpointerlockchange', this.pointerlockChangeEvent);
255
+ this.renderer.domElement.removeEventListener('click', this.requestPointerLockEvent);
256
+ disposeScene(this.scene3D);
257
+ this.scene3D.remove(this.planData.plan);
258
+ this.scene3D = null;
259
+ this.planData = null;
260
+ this.renderer.renderLists.dispose();
261
+ }
262
+ }, {
263
+ key: "componentWillReceiveProps",
264
+ value: function componentWillReceiveProps(nextProps) {
265
+ var width = nextProps.width,
266
+ height = nextProps.height;
267
+ var camera = this.camera,
268
+ renderer = this.renderer,
269
+ scene3D = this.scene3D,
270
+ sceneOnTop = this.sceneOnTop,
271
+ planData = this.planData;
272
+ var actions = {
273
+ areaActions: this.context.areaActions,
274
+ holesActions: this.context.holesActions,
275
+ itemsActions: this.context.itemsActions,
276
+ linesActions: this.context.linesActions,
277
+ projectActions: this.context.projectActions
278
+ };
279
+ this.width = width;
280
+ this.height = height;
281
+ camera.aspect = width / height;
282
+ camera.updateProjectionMatrix();
283
+ if (nextProps.scene !== this.props.state.scene) {
284
+ var changedValues = diff(this.props.state.scene, nextProps.state.scene);
285
+ updateScene(planData, nextProps.state.scene, this.props.state.scene, changedValues.toJS(), actions, this.context.catalog);
286
+ }
287
+ renderer.setSize(width, height);
288
+ renderer.clear(); // clear buffers
289
+ renderer.render(scene3D, camera); // render scene 1
290
+ renderer.clearDepth(); // clear depth buffer
291
+ renderer.render(sceneOnTop, camera); // render scene 2
292
+ }
293
+ }, {
294
+ key: "render",
295
+ value: function render() {
296
+ return /*#__PURE__*/React.createElement('div', {
297
+ ref: 'canvasWrapper'
298
+ });
299
+ }
300
+ }]);
301
+ }(React.Component);
302
+ export { Viewer3DFirstPerson as default };
303
+ Viewer3DFirstPerson.propTypes = {
304
+ state: PropTypes.object.isRequired,
305
+ width: PropTypes.number.isRequired,
306
+ height: PropTypes.number.isRequired
307
+ };
308
+ Viewer3DFirstPerson.contextTypes = {
309
+ areaActions: PropTypes.object.isRequired,
310
+ holesActions: PropTypes.object.isRequired,
311
+ itemsActions: PropTypes.object.isRequired,
312
+ linesActions: PropTypes.object.isRequired,
313
+ projectActions: PropTypes.object.isRequired,
314
+ catalog: PropTypes.object
315
+ };