kitchen-simulator 1.1.1-test.71 → 1.1.1-test.72

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 (188) hide show
  1. package/es/@history.js +5 -2
  2. package/es/AppContext.js +6 -3
  3. package/es/KitchenConfigurator.js +86 -87
  4. package/es/KitchenConfiguratorApp.js +128 -135
  5. package/es/actions/area-actions.js +8 -5
  6. package/es/actions/export.js +24 -12
  7. package/es/actions/groups-actions.js +41 -27
  8. package/es/actions/holes-actions.js +51 -34
  9. package/es/actions/items-actions.js +141 -94
  10. package/es/actions/lines-actions.js +32 -21
  11. package/es/actions/project-actions.js +141 -94
  12. package/es/actions/scene-actions.js +17 -11
  13. package/es/actions/vertices-actions.js +11 -7
  14. package/es/actions/viewer2d-actions.js +32 -21
  15. package/es/actions/viewer3d-actions.js +14 -9
  16. package/es/catalog/areas/area/planner-element.js +5 -2
  17. package/es/catalog/catalog.js +17 -15
  18. package/es/catalog/factories/area-factory-3d.js +26 -22
  19. package/es/catalog/factories/area-factory.js +15 -13
  20. package/es/catalog/factories/export.js +10 -6
  21. package/es/catalog/factories/wall-factory-3d.js +36 -31
  22. package/es/catalog/factories/wall-factory.js +26 -21
  23. package/es/catalog/holes/door-closet/planner-element.js +19 -15
  24. package/es/catalog/holes/door-double/planner-element.js +19 -15
  25. package/es/catalog/holes/door-exterior/planner-element.js +20 -16
  26. package/es/catalog/holes/door-interior/planner-element.js +20 -16
  27. package/es/catalog/holes/door-panic/planner-element.js +11 -7
  28. package/es/catalog/holes/door-panic-double/planner-element.js +19 -15
  29. package/es/catalog/holes/door-sliding/planner-element.js +21 -17
  30. package/es/catalog/holes/doorway-framed/planner-element.js +15 -11
  31. package/es/catalog/holes/doorway-frameless/planner-element.js +11 -7
  32. package/es/catalog/holes/export.js +29 -13
  33. package/es/catalog/holes/window-clear/planner-element.js +14 -10
  34. package/es/catalog/holes/window-cross/planner-element.js +14 -10
  35. package/es/catalog/holes/window-double-hung/planner-element.js +14 -10
  36. package/es/catalog/holes/window-vertical/planner-element.js +14 -10
  37. package/es/catalog/lines/wall/planner-element.js +5 -2
  38. package/es/catalog/molding/molding-dcm/planner-element.js +9 -5
  39. package/es/catalog/molding/molding-fbm/planner-element.js +9 -5
  40. package/es/catalog/molding/molding-lrm/planner-element.js +9 -5
  41. package/es/catalog/properties/export.js +31 -20
  42. package/es/catalog/properties/property-checkbox.js +29 -28
  43. package/es/catalog/properties/property-color.js +19 -16
  44. package/es/catalog/properties/property-enum.js +27 -24
  45. package/es/catalog/properties/property-hidden.js +12 -9
  46. package/es/catalog/properties/property-lenght-measure.js +41 -38
  47. package/es/catalog/properties/property-length-measure.js +39 -36
  48. package/es/catalog/properties/property-length-measure_hole.js +41 -38
  49. package/es/catalog/properties/property-number.js +20 -17
  50. package/es/catalog/properties/property-read-only.js +19 -16
  51. package/es/catalog/properties/property-string.js +19 -16
  52. package/es/catalog/properties/property-toggle.js +19 -16
  53. package/es/catalog/properties/shared-property-style.js +3 -1
  54. package/es/catalog/utils/FuseUtils.js +13 -12
  55. package/es/catalog/utils/exporter.js +11 -10
  56. package/es/catalog/utils/geom-utils.js +24 -13
  57. package/es/catalog/utils/item-loader.js +92 -86
  58. package/es/catalog/utils/load-obj.js +24 -20
  59. package/es/catalog/utils/mtl-loader.js +4 -3
  60. package/es/catalog/utils/obj-loader.js +4 -3
  61. package/es/class/FuseUtils.js +13 -12
  62. package/es/class/area.js +24 -24
  63. package/es/class/export.js +36 -23
  64. package/es/class/group.js +55 -53
  65. package/es/class/guide.js +17 -15
  66. package/es/class/hole.js +85 -83
  67. package/es/class/item.js +155 -155
  68. package/es/class/layer.js +61 -59
  69. package/es/class/line.js +138 -135
  70. package/es/class/project.js +94 -93
  71. package/es/class/vertex.js +31 -29
  72. package/es/components/content.js +23 -19
  73. package/es/components/disclaimer/disclaimer.js +13 -10
  74. package/es/components/export.js +13 -8
  75. package/es/components/style/button.js +25 -25
  76. package/es/components/style/cancel-button.js +10 -7
  77. package/es/components/style/content-container.js +12 -11
  78. package/es/components/style/content-title.js +15 -13
  79. package/es/components/style/delete-button.js +12 -8
  80. package/es/components/style/export.js +46 -30
  81. package/es/components/style/form-block.js +11 -10
  82. package/es/components/style/form-color-input.js +10 -7
  83. package/es/components/style/form-label.js +11 -10
  84. package/es/components/style/form-number-input.js +43 -45
  85. package/es/components/style/form-number-input_2.js +39 -41
  86. package/es/components/style/form-select.js +20 -19
  87. package/es/components/style/form-slider.js +13 -10
  88. package/es/components/style/form-submit-button.js +12 -8
  89. package/es/components/style/form-text-input.js +28 -30
  90. package/es/components/viewer2d/area.js +20 -17
  91. package/es/components/viewer2d/export.js +46 -30
  92. package/es/components/viewer2d/grids/grid-horizontal-streak.js +13 -10
  93. package/es/components/viewer2d/grids/grid-streak.js +13 -10
  94. package/es/components/viewer2d/grids/grid-vertical-streak.js +13 -10
  95. package/es/components/viewer2d/grids/grids.js +14 -10
  96. package/es/components/viewer2d/group.js +19 -15
  97. package/es/components/viewer2d/item.js +65 -61
  98. package/es/components/viewer2d/layer.js +26 -23
  99. package/es/components/viewer2d/line.js +106 -101
  100. package/es/components/viewer2d/ruler.js +25 -22
  101. package/es/components/viewer2d/rulerDist.js +24 -21
  102. package/es/components/viewer2d/rulerX.js +44 -46
  103. package/es/components/viewer2d/rulerY.js +42 -44
  104. package/es/components/viewer2d/scene.js +34 -35
  105. package/es/components/viewer2d/snap.js +17 -13
  106. package/es/components/viewer2d/state.js +22 -18
  107. package/es/components/viewer2d/utils.js +33 -24
  108. package/es/components/viewer2d/vertex.js +12 -8
  109. package/es/components/viewer2d/viewer2d.js +159 -156
  110. package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +19 -21
  111. package/es/components/viewer3d/dcm.js +3 -1
  112. package/es/components/viewer3d/fbm.js +3 -1
  113. package/es/components/viewer3d/front3D.js +16 -12
  114. package/es/components/viewer3d/grid-creator.js +12 -8
  115. package/es/components/viewer3d/grids/grid-horizontal-streak.js +9 -6
  116. package/es/components/viewer3d/grids/grid-streak.js +8 -5
  117. package/es/components/viewer3d/grids/grid-vertical-streak.js +9 -6
  118. package/es/components/viewer3d/libs/first-person-controls.js +5 -2
  119. package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +3 -1
  120. package/es/components/viewer3d/libs/mtl-loader.js +3 -1
  121. package/es/components/viewer3d/libs/obj-loader.js +3 -1
  122. package/es/components/viewer3d/libs/orbit-controls.js +4 -2
  123. package/es/components/viewer3d/libs/pointer-lock-controls.js +4 -2
  124. package/es/components/viewer3d/lrm.js +3 -1
  125. package/es/components/viewer3d/model.js +3 -1
  126. package/es/components/viewer3d/pointer-lock-navigation.js +6 -3
  127. package/es/components/viewer3d/ruler-utils/itemRect.js +21 -18
  128. package/es/components/viewer3d/ruler-utils/layer3D.js +62 -59
  129. package/es/components/viewer3d/ruler-utils/ruler3D.js +43 -42
  130. package/es/components/viewer3d/ruler-utils/scene3D.js +13 -9
  131. package/es/components/viewer3d/ruler-utils/state3D.js +7 -4
  132. package/es/components/viewer3d/scene-creator.js +223 -197
  133. package/es/components/viewer3d/three-memory-cleaner.js +7 -3
  134. package/es/components/viewer3d/viewer3d-first-person.js +42 -42
  135. package/es/components/viewer3d/viewer3d.js +198 -200
  136. package/es/constants.js +354 -349
  137. package/es/index.js +11 -7
  138. package/es/models.js +191 -193
  139. package/es/plugins/SVGLoader.js +49 -48
  140. package/es/plugins/autosave.js +5 -3
  141. package/es/plugins/console-debugger.js +7 -6
  142. package/es/plugins/export.js +13 -8
  143. package/es/plugins/keyboard.js +31 -29
  144. package/es/reducers/areas-reducer.js +9 -7
  145. package/es/reducers/export.js +37 -24
  146. package/es/reducers/groups-reducer.js +33 -31
  147. package/es/reducers/holes-reducer.js +45 -43
  148. package/es/reducers/items-reducer.js +108 -106
  149. package/es/reducers/lines-reducer.js +30 -28
  150. package/es/reducers/project-reducer.js +107 -105
  151. package/es/reducers/reducer.js +19 -16
  152. package/es/reducers/scene-reducer.js +17 -15
  153. package/es/reducers/user-reducer.js +7 -5
  154. package/es/reducers/vertices-reducer.js +13 -11
  155. package/es/reducers/viewer2d-reducer.js +20 -18
  156. package/es/reducers/viewer3d-reducer.js +18 -16
  157. package/es/shared-style.js +12 -10
  158. package/es/styles/export.js +6 -3
  159. package/es/translator/en.js +3 -1
  160. package/es/translator/it.js +3 -1
  161. package/es/translator/ru.js +3 -1
  162. package/es/translator/translator.js +15 -13
  163. package/es/utils/browser.js +5 -2
  164. package/es/utils/convert-units-lite.js +3 -1
  165. package/es/utils/email-validator.js +3 -1
  166. package/es/utils/export.js +29 -15
  167. package/es/utils/geometry.js +280 -190
  168. package/es/utils/get-edges-of-subgraphs.js +5 -2
  169. package/es/utils/graph-cycles.js +7 -8
  170. package/es/utils/graph-inner-cycles.js +14 -10
  171. package/es/utils/graph.js +13 -9
  172. package/es/utils/helper.js +58 -41
  173. package/es/utils/history.js +11 -8
  174. package/es/utils/id-broker.js +11 -8
  175. package/es/utils/logger.js +3 -1
  176. package/es/utils/math.js +8 -5
  177. package/es/utils/molding.js +146 -130
  178. package/es/utils/name-generator.js +9 -7
  179. package/es/utils/objects-utils.js +14 -7
  180. package/es/utils/phone-validator.js +3 -1
  181. package/es/utils/process-black-list.js +6 -5
  182. package/es/utils/react-if.js +9 -7
  183. package/es/utils/snap-scene.js +30 -27
  184. package/es/utils/snap.js +57 -53
  185. package/es/utils/summarizeCart.js +3 -1
  186. package/es/utils/threeCSG.es6.js +17 -13
  187. package/es/version.js +3 -1
  188. package/package.json +1 -1
@@ -1,21 +1,23 @@
1
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
3
- import _createClass from "@babel/runtime/helpers/esm/createClass";
4
- 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; }
5
- 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; }
6
- import { List, Map } from 'immutable';
7
- import * as constants from "../constants";
8
- import { ARRAY_3D_MODES, END_DRAWING_LINE, MODE_CONFIGURING_PROJECT, MODE_DRAWING_HOLE, MODE_DRAWING_ITEM, MODE_DRAWING_ITEM_3D, MODE_DRAWING_LINE, MODE_IDLE, MODE_IDLE_3D, MODE_VIEWING_CATALOG, MODE_WAITING_DRAWING_LINE } from "../constants";
9
- import { Catalog, Scene, State } from "../models";
10
- import { GeometryUtils, history } from "../utils/export";
11
- import { Area, Group, Hole, HorizontalGuide, Item, Layer, Line, VerticalGuide } from "../class/export";
12
- import * as viewer2DActions from "../actions/viewer2d-actions";
13
- import { isEmpty } from "../utils/helper";
14
- var Project = /*#__PURE__*/function () {
1
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard")["default"];
2
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault")["default"];
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectSpread2"));
6
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/classCallCheck"));
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/createClass"));
8
+ var _immutable = require("immutable");
9
+ var _constants = _interopRequireWildcard(require("../constants"));
10
+ var constants = _constants;
11
+ var _models = require("../models");
12
+ var _export = require("../utils/export");
13
+ var _export2 = require("../class/export");
14
+ var viewer2DActions = _interopRequireWildcard(require("../actions/viewer2d-actions"));
15
+ var _helper = require("../utils/helper");
16
+ var Project = exports["default"] = /*#__PURE__*/function () {
15
17
  function Project() {
16
- _classCallCheck(this, Project);
18
+ (0, _classCallCheck2["default"])(this, Project);
17
19
  }
18
- return _createClass(Project, null, [{
20
+ return (0, _createClass2["default"])(Project, null, [{
19
21
  key: "setAlterate",
20
22
  value: function setAlterate(state) {
21
23
  return {
@@ -25,7 +27,7 @@ var Project = /*#__PURE__*/function () {
25
27
  }, {
26
28
  key: "openCatalog",
27
29
  value: function openCatalog(state) {
28
- state = this.setMode(state, MODE_VIEWING_CATALOG).updatedState;
30
+ state = this.setMode(state, _constants.MODE_VIEWING_CATALOG).updatedState;
29
31
  return {
30
32
  updatedState: state
31
33
  };
@@ -45,7 +47,7 @@ var Project = /*#__PURE__*/function () {
45
47
  a: 0.99,
46
48
  d: 0.99
47
49
  });
48
- state = new State({});
50
+ state = new _models.State({});
49
51
  state = state.merge({
50
52
  doorStyle: doorStyle,
51
53
  oStyle: oStyle,
@@ -93,20 +95,20 @@ var Project = /*#__PURE__*/function () {
93
95
  for (var x in json_items) {
94
96
  _loop(x);
95
97
  }
96
- var newScene = new Scene(sceneJSON);
97
- state = new State({
98
+ var newScene = new _models.Scene(sceneJSON);
99
+ state = new _models.State({
98
100
  scene: newScene.toJS(),
99
101
  catalog: state.catalog.toJS()
100
102
  });
101
103
  state = state.merge({
102
- sceneHistory: history.historyPush(oldSceneHistory, oldScene)
104
+ sceneHistory: _export.history.historyPush(oldSceneHistory, oldScene)
103
105
  });
104
106
  if (state.scene.title === '') {
105
107
  state = state.mergeIn(['scene', 'title'], oldScene.title);
106
108
  }
107
109
 
108
110
  //Validate item positions after loading project.
109
- state = Item.validateItemPositions(state, layerID).updatedState;
111
+ state = _export2.Item.validateItemPositions(state, layerID).updatedState;
110
112
 
111
113
  // get counterTop and floorStyle is after state created from sceneJSON
112
114
  if (state.getIn(['scene', 'layers', layerID, 'counterTop']).uri) {
@@ -164,8 +166,8 @@ var Project = /*#__PURE__*/function () {
164
166
  oStyle: oStyle,
165
167
  viewer2D: _viewer2D
166
168
  });
167
- state = Item.setCounterTop(state, counterTop).updatedState;
168
- state = Area.setFloorStyles(state, floorStyle).updatedState;
169
+ state = _export2.Item.setCounterTop(state, counterTop).updatedState;
170
+ state = _export2.Area.setFloorStyles(state, floorStyle).updatedState;
169
171
  if (state.getIn(['scene', 'layers', layerID, 'doorStyle']) && !state.getIn(['scene', 'layers', layerID, 'doorStyle', 'install'])) {
170
172
  var layerDoorStyle = state.getIn(['scene', 'layers', layerID, 'doorStyle']);
171
173
  var install = '';
@@ -178,7 +180,7 @@ var Project = /*#__PURE__*/function () {
178
180
  }
179
181
  });
180
182
  });
181
- layerDoorStyle = _objectSpread(_objectSpread({}, layerDoorStyle), {}, {
183
+ layerDoorStyle = (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, layerDoorStyle), {}, {
182
184
  install: install
183
185
  });
184
186
  state = state.mergeIn(['scene', 'layers', layerID, 'doorStyle'], layerDoorStyle);
@@ -199,8 +201,8 @@ var Project = /*#__PURE__*/function () {
199
201
  updatedState: state
200
202
  };
201
203
  }
202
- state = Layer.setPropertiesOnSelected(state, layerID, properties).updatedState;
203
- state = Layer.updateMovingState(state, false).updatedState;
204
+ state = _export2.Layer.setPropertiesOnSelected(state, layerID, properties).updatedState;
205
+ state = _export2.Layer.updateMovingState(state, false).updatedState;
204
206
  return {
205
207
  updatedState: state
206
208
  };
@@ -208,7 +210,7 @@ var Project = /*#__PURE__*/function () {
208
210
  }, {
209
211
  key: "updateProperties",
210
212
  value: function updateProperties(state, layerID, properties) {
211
- state = Layer.updatePropertiesOnSelected(state, layerID, properties).updatedState;
213
+ state = _export2.Layer.updatePropertiesOnSelected(state, layerID, properties).updatedState;
212
214
  return {
213
215
  updatedState: state
214
216
  };
@@ -217,9 +219,9 @@ var Project = /*#__PURE__*/function () {
217
219
  key: "setItemsAttributes",
218
220
  value: function setItemsAttributes(state, attributes) {
219
221
  //TODO apply only to items
220
- state = Layer.updateMovingState(state, false).updatedState;
222
+ state = _export2.Layer.updateMovingState(state, false).updatedState;
221
223
  state.getIn(['scene', 'layers']).forEach(function (layer) {
222
- state = Layer.setAttributesOnSelected(state, layer.id, attributes).updatedState;
224
+ state = _export2.Layer.setAttributesOnSelected(state, layer.id, attributes).updatedState;
223
225
  });
224
226
  return {
225
227
  updatedState: state
@@ -231,12 +233,12 @@ var Project = /*#__PURE__*/function () {
231
233
  //TODO apply only to lines
232
234
  if (!isDirect) {
233
235
  state.getIn(['scene', 'layers']).forEach(function (layer) {
234
- state = Layer.setAttributesOnSelected(state, layer.id, attributes).updatedState;
236
+ state = _export2.Layer.setAttributesOnSelected(state, layer.id, attributes).updatedState;
235
237
  });
236
238
  } else if (isDirect && directData !== null) {
237
239
  var layerID = directData.layerID,
238
240
  lineID = directData.lineID;
239
- if (layerID && lineID) state = Line.setAttributes(state, layerID, lineID, attributes).updatedState;
241
+ if (layerID && lineID) state = _export2.Line.setAttributes(state, layerID, lineID, attributes).updatedState;
240
242
  }
241
243
  return {
242
244
  updatedState: state
@@ -247,7 +249,7 @@ var Project = /*#__PURE__*/function () {
247
249
  value: function setHolesAttributes(state, attributes) {
248
250
  //TODO apply only to holes
249
251
  state.getIn(['scene', 'layers']).forEach(function (layer) {
250
- state = Layer.setAttributesOnSelected(state, layer.id, attributes).updatedState;
252
+ state = _export2.Layer.setAttributesOnSelected(state, layer.id, attributes).updatedState;
251
253
  });
252
254
  return {
253
255
  updatedState: state
@@ -258,19 +260,19 @@ var Project = /*#__PURE__*/function () {
258
260
  value: function unselectAll(state) {
259
261
  state.getIn(['scene', 'layers']).forEach(function (_ref) {
260
262
  var layerID = _ref.id;
261
- state = Layer.unselectAll(state, layerID).updatedState;
263
+ state = _export2.Layer.unselectAll(state, layerID).updatedState;
262
264
  });
263
265
  state.getIn(['scene', 'groups']).forEach(function (group) {
264
- state = Group.unselect(state, group.get('id')).updatedState;
266
+ state = _export2.Group.unselect(state, group.get('id')).updatedState;
265
267
  });
266
268
  var mode = state.getIn(['mode']);
267
269
  if (mode === constants.MODE_DRAGGING_LINE || mode === constants.MODE_DRAGGING_VERTEX) {
268
270
  if (mode.includes('3D')) {
269
- state = state.setIn(['mode'], MODE_IDLE_3D);
270
- } else state = state.setIn(['mode'], MODE_IDLE);
271
+ state = state.setIn(['mode'], _constants.MODE_IDLE_3D);
272
+ } else state = state.setIn(['mode'], _constants.MODE_IDLE);
271
273
  state = state.merge({
272
274
  activeSnapElement: null,
273
- snapElements: new List()
275
+ snapElements: new _immutable.List()
274
276
  });
275
277
  }
276
278
  return {
@@ -283,7 +285,7 @@ var Project = /*#__PURE__*/function () {
283
285
  if (value == null) {
284
286
  state.getIn(['scene', 'layers']).forEach(function (_ref2) {
285
287
  var layerID = _ref2.id;
286
- state = Layer.selectAll(state, layerID).updatedState;
288
+ state = _export2.Layer.selectAll(state, layerID).updatedState;
287
289
  });
288
290
  } else {
289
291
  var layerID = state.getIn(['scene', 'selectedLayer']);
@@ -324,33 +326,33 @@ var Project = /*#__PURE__*/function () {
324
326
  var allVertices = state.getIn(['scene', 'layers', selectedLayer, 'vertices']).toJS();
325
327
  var selLines = state.getIn(['scene', 'layers', selectedLayer, 'selected', 'lines']).toJS();
326
328
  var lineID = selLines[0];
327
- var delLine = !isEmpty(lineID) && state.getIn(['scene', 'layers', selectedLayer, 'lines', lineID]).toJS();
329
+ var delLine = !(0, _helper.isEmpty)(lineID) && state.getIn(['scene', 'layers', selectedLayer, 'lines', lineID]).toJS();
328
330
  var allLines = state.getIn(['scene', 'layers', selectedLayer, 'lines']).toJS();
329
331
  var relatedLines = [];
330
- delLine && GeometryUtils.getRelatedLines(relatedLines, delLine, allVertices, allLines);
332
+ delLine && _export.GeometryUtils.getRelatedLines(relatedLines, delLine, allVertices, allLines);
331
333
  selectedLines.forEach(function (lineID) {
332
- state = Line.remove(state, selectedLayer, lineID).updatedState;
334
+ state = _export2.Line.remove(state, selectedLayer, lineID).updatedState;
333
335
  });
334
336
  selectedHoles.forEach(function (holeID) {
335
- state = Hole.remove(state, selectedLayer, holeID).updatedState;
337
+ state = _export2.Hole.remove(state, selectedLayer, holeID).updatedState;
336
338
  });
337
339
  selectedItems.forEach(function (itemID) {
338
- state = Item.remove(state, selectedLayer, itemID).updatedState;
340
+ state = _export2.Item.remove(state, selectedLayer, itemID).updatedState;
339
341
  });
340
- if (!isEmpty(relatedLines)) {
341
- state = state.setIn(['mode'], MODE_DRAWING_LINE);
342
+ if (!(0, _helper.isEmpty)(relatedLines)) {
343
+ state = state.setIn(['mode'], _constants.MODE_DRAWING_LINE);
342
344
  relatedLines.forEach(function (relLine, index) {
343
- state = Line.select(state, selectedLayer, relLine.id).updatedState;
344
- state = Line.applyWallChanges(state, END_DRAWING_LINE).updatedState;
345
+ state = _export2.Line.select(state, selectedLayer, relLine.id).updatedState;
346
+ state = _export2.Line.applyWallChanges(state, _constants.END_DRAWING_LINE).updatedState;
345
347
  });
346
348
  }
347
- state = Layer.unselectAll(state, selectedLayer).updatedState;
349
+ state = _export2.Layer.unselectAll(state, selectedLayer).updatedState;
348
350
  var mode = state.getIn(['mode']);
349
351
  if (mode.includes('DRAWING') || mode.includes('DRAGGING') || mode.includes('ROTATING')) {
350
352
  state = state.merge({
351
353
  activeSnapElement: null
352
354
  });
353
- if (mode.endsWith('3D')) state = state.setIn(['mode'], MODE_IDLE_3D);else state = state.setIn(['mode'], MODE_IDLE);
355
+ if (mode.endsWith('3D')) state = state.setIn(['mode'], _constants.MODE_IDLE_3D);else state = state.setIn(['mode'], _constants.MODE_IDLE);
354
356
  }
355
357
  return {
356
358
  updatedState: state
@@ -367,15 +369,15 @@ var Project = /*#__PURE__*/function () {
367
369
  var forRedo = window.forRedo;
368
370
  window.forRedo = forRedo;
369
371
  if (state.scene === sceneHistory.last && sceneHistory.list.size > 1) {
370
- sceneHistory = history.historyPop(sceneHistory);
372
+ sceneHistory = _export.history.historyPop(sceneHistory);
371
373
  }
372
374
  forRedo.push(state.scene);
373
375
  var mode;
374
- if (ARRAY_3D_MODES.includes(state.mode)) mode = MODE_IDLE_3D;else mode = MODE_IDLE;
376
+ if (_constants.ARRAY_3D_MODES.includes(state.mode)) mode = _constants.MODE_IDLE_3D;else mode = _constants.MODE_IDLE;
375
377
  state = state.merge({
376
378
  mode: mode,
377
379
  scene: sceneHistory.last,
378
- sceneHistory: history.historyPop(sceneHistory)
380
+ sceneHistory: _export.history.historyPop(sceneHistory)
379
381
  });
380
382
  return {
381
383
  updatedState: state
@@ -390,11 +392,11 @@ var Project = /*#__PURE__*/function () {
390
392
  };
391
393
  var scene = forRedo.pop();
392
394
  var mode;
393
- if (ARRAY_3D_MODES.includes(state.mode)) mode = MODE_IDLE_3D;else mode = MODE_IDLE;
395
+ if (_constants.ARRAY_3D_MODES.includes(state.mode)) mode = _constants.MODE_IDLE_3D;else mode = _constants.MODE_IDLE;
394
396
  state = state.merge({
395
397
  mode: mode,
396
398
  scene: scene,
397
- sceneHistory: history.historyPush(state.sceneHistory, state.scene)
399
+ sceneHistory: _export.history.historyPush(state.sceneHistory, state.scene)
398
400
  });
399
401
  window.forRedo = forRedo;
400
402
  return {
@@ -423,7 +425,7 @@ var Project = /*#__PURE__*/function () {
423
425
  key: "recreate",
424
426
  value: function recreate(state) {
425
427
  if (state.getIn(['drawingSupport', 'type']) !== undefined) state = state.merge({
426
- mode: MODE_DRAWING_ITEM_3D,
428
+ mode: _constants.MODE_DRAWING_ITEM_3D,
427
429
  popup: true
428
430
  });
429
431
  return {
@@ -445,10 +447,10 @@ var Project = /*#__PURE__*/function () {
445
447
  value: function shift2doff(state) {
446
448
  if (state.getIn(['drawingSupport', 'type']) !== undefined) {
447
449
  if (state.get('selectedElementsHistory')._tail.array[0].prototype === 'holes') state = state.merge({
448
- mode: MODE_DRAWING_HOLE,
450
+ mode: _constants.MODE_DRAWING_HOLE,
449
451
  popup: true
450
452
  });else state = state.merge({
451
- mode: MODE_DRAWING_ITEM,
453
+ mode: _constants.MODE_DRAWING_ITEM,
452
454
  popup: true
453
455
  });
454
456
  }
@@ -470,22 +472,22 @@ var Project = /*#__PURE__*/function () {
470
472
  }
471
473
 
472
474
  // ESC event doesn't need when mode = MODE_IDLE || MODE_IDLE_3D
473
- if (state.mode == MODE_IDLE_3D || state.mode == MODE_IDLE) {
475
+ if (state.mode == _constants.MODE_IDLE_3D || state.mode == _constants.MODE_IDLE) {
474
476
  return {
475
477
  updatedState: state
476
478
  };
477
479
  }
478
480
  var mode;
479
- if (state.mode == MODE_DRAWING_ITEM_3D) {
480
- mode = MODE_IDLE_3D;
481
- if (state.drawingSupport.has('currentID')) state = Layer.removeElement(state, state.scene.selectedLayer, 'items', state.drawingSupport.get('currentID')).updatedState;
481
+ if (state.mode == _constants.MODE_DRAWING_ITEM_3D) {
482
+ mode = _constants.MODE_IDLE_3D;
483
+ if (state.drawingSupport.has('currentID')) state = _export2.Layer.removeElement(state, state.scene.selectedLayer, 'items', state.drawingSupport.get('currentID')).updatedState;
482
484
  state = state.merge({
483
485
  mode: mode,
484
- snapElements: new List(),
486
+ snapElements: new _immutable.List(),
485
487
  activeSnapElement: null,
486
- drawingSupport: new Map(),
487
- draggingSupport: new Map(),
488
- rotatingSupport: new Map()
488
+ drawingSupport: new _immutable.Map(),
489
+ draggingSupport: new _immutable.Map(),
490
+ rotatingSupport: new _immutable.Map()
489
491
  });
490
492
  return {
491
493
  updatedState: state
@@ -493,30 +495,30 @@ var Project = /*#__PURE__*/function () {
493
495
  }
494
496
 
495
497
  // when Add Walls button clicked
496
- if (state.mode == MODE_WAITING_DRAWING_LINE) {
497
- mode = MODE_IDLE;
498
+ if (state.mode == _constants.MODE_WAITING_DRAWING_LINE) {
499
+ mode = _constants.MODE_IDLE;
498
500
  state = state.merge({
499
501
  mode: mode,
500
- snapElements: new List(),
502
+ snapElements: new _immutable.List(),
501
503
  activeSnapElement: null,
502
- drawingSupport: new Map(),
503
- draggingSupport: new Map(),
504
- rotatingSupport: new Map()
504
+ drawingSupport: new _immutable.Map(),
505
+ draggingSupport: new _immutable.Map(),
506
+ rotatingSupport: new _immutable.Map()
505
507
  });
506
508
  return {
507
509
  updatedState: state
508
510
  };
509
511
  }
510
- if (ARRAY_3D_MODES.includes(state.mode)) mode = MODE_IDLE_3D;else mode = MODE_IDLE;
512
+ if (_constants.ARRAY_3D_MODES.includes(state.mode)) mode = _constants.MODE_IDLE_3D;else mode = _constants.MODE_IDLE;
511
513
  state = state.merge({
512
514
  mode: mode,
513
515
  scene: sceneHistory.last,
514
- sceneHistory: history.historyPush(sceneHistory, sceneHistory.last),
515
- snapElements: new List(),
516
+ sceneHistory: _export.history.historyPush(sceneHistory, sceneHistory.last),
517
+ snapElements: new _immutable.List(),
516
518
  activeSnapElement: null,
517
- drawingSupport: new Map(),
518
- draggingSupport: new Map(),
519
- rotatingSupport: new Map()
519
+ drawingSupport: new _immutable.Map(),
520
+ draggingSupport: new _immutable.Map(),
521
+ rotatingSupport: new _immutable.Map()
520
522
  });
521
523
  return {
522
524
  updatedState: state
@@ -527,7 +529,7 @@ var Project = /*#__PURE__*/function () {
527
529
  value: function removeDrawingSupport(state) {
528
530
  var sceneHistory = state.sceneHistory;
529
531
  var mode = state.mode;
530
- if (!sceneHistory.last && sceneHistory.list.isEmpty() || mode != MODE_DRAWING_ITEM_3D) {
532
+ if (!sceneHistory.last && sceneHistory.list.isEmpty() || mode != _constants.MODE_DRAWING_ITEM_3D) {
531
533
  return {
532
534
  updatedState: state
533
535
  };
@@ -535,8 +537,8 @@ var Project = /*#__PURE__*/function () {
535
537
  state = this.unselectAll(state).updatedState;
536
538
  state = state.merge({
537
539
  scene: sceneHistory.last,
538
- sceneHistory: history.historyPush(sceneHistory, sceneHistory.last),
539
- drawingSupport: new Map()
540
+ sceneHistory: _export.history.historyPush(sceneHistory, sceneHistory.last),
541
+ drawingSupport: new _immutable.Map()
540
542
  });
541
543
  return {
542
544
  updatedState: state
@@ -547,7 +549,7 @@ var Project = /*#__PURE__*/function () {
547
549
  value: function setProjectProperties(state, properties) {
548
550
  var scene = state.scene.merge(properties);
549
551
  state = state.merge({
550
- mode: MODE_IDLE,
552
+ mode: _constants.MODE_IDLE,
551
553
  scene: scene
552
554
  });
553
555
  return {
@@ -569,7 +571,7 @@ var Project = /*#__PURE__*/function () {
569
571
  key: "openProjectConfigurator",
570
572
  value: function openProjectConfigurator(state) {
571
573
  state = state.merge({
572
- mode: MODE_CONFIGURING_PROJECT
574
+ mode: _constants.MODE_CONFIGURING_PROJECT
573
575
  });
574
576
  return {
575
577
  updatedState: state
@@ -579,7 +581,7 @@ var Project = /*#__PURE__*/function () {
579
581
  key: "initCatalog",
580
582
  value: function initCatalog(state, catalog) {
581
583
  try {
582
- state = state.set('catalog', new Catalog(catalog));
584
+ state = state.set('catalog', new _models.Catalog(catalog));
583
585
  return {
584
586
  updatedState: state
585
587
  };
@@ -593,7 +595,7 @@ var Project = /*#__PURE__*/function () {
593
595
  }, {
594
596
  key: "updateMouseCoord",
595
597
  value: function updateMouseCoord(state, coords) {
596
- state = state.set('mouse', new Map(coords));
598
+ state = state.set('mouse', new _immutable.Map(coords));
597
599
  return {
598
600
  updatedState: state
599
601
  };
@@ -645,7 +647,7 @@ var Project = /*#__PURE__*/function () {
645
647
  updatedState: state
646
648
  };else {
647
649
  state = state.merge({
648
- mode: MODE_WAITING_DRAWING_LINE,
650
+ mode: _constants.MODE_WAITING_DRAWING_LINE,
649
651
  activeSnapElement: null
650
652
  });
651
653
  return {
@@ -711,7 +713,7 @@ var Project = /*#__PURE__*/function () {
711
713
  }, {
712
714
  key: "addHorizontalGuide",
713
715
  value: function addHorizontalGuide(state, coordinate) {
714
- state = HorizontalGuide.create(state, coordinate).updatedState;
716
+ state = _export2.HorizontalGuide.create(state, coordinate).updatedState;
715
717
  return {
716
718
  updatedState: state
717
719
  };
@@ -719,7 +721,7 @@ var Project = /*#__PURE__*/function () {
719
721
  }, {
720
722
  key: "addVerticalGuide",
721
723
  value: function addVerticalGuide(state, coordinate) {
722
- state = VerticalGuide.create(state, coordinate).updatedState;
724
+ state = _export2.VerticalGuide.create(state, coordinate).updatedState;
723
725
  return {
724
726
  updatedState: state
725
727
  };
@@ -735,7 +737,7 @@ var Project = /*#__PURE__*/function () {
735
737
  }, {
736
738
  key: "removeHorizontalGuide",
737
739
  value: function removeHorizontalGuide(state, guideID) {
738
- state = HorizontalGuide.remove(state, guideID).updatedState;
740
+ state = _export2.HorizontalGuide.remove(state, guideID).updatedState;
739
741
  return {
740
742
  updatedState: state
741
743
  };
@@ -743,7 +745,7 @@ var Project = /*#__PURE__*/function () {
743
745
  }, {
744
746
  key: "removeVerticalGuide",
745
747
  value: function removeVerticalGuide(state, guideID) {
746
- state = VerticalGuide.remove(state, guideID).updatedState;
748
+ state = _export2.VerticalGuide.remove(state, guideID).updatedState;
747
749
  return {
748
750
  updatedState: state
749
751
  };
@@ -759,7 +761,7 @@ var Project = /*#__PURE__*/function () {
759
761
  }, {
760
762
  key: "setStateProperties",
761
763
  value: function setStateProperties(state, properties) {
762
- state = state.merge(_objectSpread({}, properties));
764
+ state = state.merge((0, _objectSpread2["default"])({}, properties));
763
765
  return {
764
766
  updatedState: state
765
767
  };
@@ -785,5 +787,4 @@ var Project = /*#__PURE__*/function () {
785
787
  };
786
788
  }
787
789
  }]);
788
- }();
789
- export { Project as default };
790
+ }();
@@ -1,21 +1,24 @@
1
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
3
- import _createClass from "@babel/runtime/helpers/esm/createClass";
4
- import { List, Map } from 'immutable';
5
- import { Vertex as VertexModel } from "../models";
6
- import { GeometryUtils, IDBroker, SnapSceneUtils, SnapUtils } from "../utils/export";
7
- import { END_DRAGGING_VERTEX, MODE_DRAGGING_VERTEX } from "../constants";
8
- import { Layer, Line } from "../class/export";
9
- import { isEmpty } from "../utils/helper";
10
- var Vertex = /*#__PURE__*/function () {
1
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault")["default"];
2
+ exports.__esModule = true;
3
+ exports["default"] = void 0;
4
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/defineProperty"));
5
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/classCallCheck"));
6
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/createClass"));
7
+ var _immutable = require("immutable");
8
+ var _models = require("../models");
9
+ var _export = require("../utils/export");
10
+ var _constants = require("../constants");
11
+ var _export2 = require("../class/export");
12
+ var _helper = require("../utils/helper");
13
+ var Vertex = exports["default"] = /*#__PURE__*/function () {
11
14
  function Vertex() {
12
- _classCallCheck(this, Vertex);
15
+ (0, _classCallCheck2["default"])(this, Vertex);
13
16
  }
14
- return _createClass(Vertex, null, [{
17
+ return (0, _createClass2["default"])(Vertex, null, [{
15
18
  key: "add",
16
19
  value: function add(state, layerID, x, y, relatedPrototype, relatedID) {
17
20
  var vertex = state.getIn(['scene', 'layers', layerID, 'vertices']).find(function (vertex) {
18
- return GeometryUtils.samePoints(vertex, {
21
+ return _export.GeometryUtils.samePoints(vertex, {
19
22
  x: x,
20
23
  y: y
21
24
  });
@@ -25,12 +28,12 @@ var Vertex = /*#__PURE__*/function () {
25
28
  return related.push(relatedID);
26
29
  });
27
30
  } else {
28
- vertex = new VertexModel(_defineProperty({
29
- id: IDBroker.acquireID(),
31
+ vertex = new _models.Vertex((0, _defineProperty2["default"])({
32
+ id: _export.IDBroker.acquireID(),
30
33
  name: 'Vertex',
31
34
  x: x,
32
35
  y: y
33
- }, relatedPrototype, new List([relatedID])));
36
+ }, relatedPrototype, new _immutable.List([relatedID])));
34
37
  }
35
38
  state = state.setIn(['scene', 'layers', layerID, 'vertices', vertex.id], vertex);
36
39
  return {
@@ -120,11 +123,11 @@ var Vertex = /*#__PURE__*/function () {
120
123
  }, {
121
124
  key: "beginDraggingVertex",
122
125
  value: function beginDraggingVertex(state, layerID, vertexID, x, y) {
123
- var snapElements = SnapSceneUtils.sceneSnapElements(state.scene, new List(), state.snapMask);
126
+ var snapElements = _export.SnapSceneUtils.sceneSnapElements(state.scene, new _immutable.List(), state.snapMask);
124
127
  state = state.merge({
125
- mode: MODE_DRAGGING_VERTEX,
128
+ mode: _constants.MODE_DRAGGING_VERTEX,
126
129
  snapElements: snapElements,
127
- draggingSupport: Map({
130
+ draggingSupport: (0, _immutable.Map)({
128
131
  layerID: layerID,
129
132
  vertexID: vertexID,
130
133
  previousMode: state.get('mode')
@@ -143,7 +146,7 @@ var Vertex = /*#__PURE__*/function () {
143
146
  scene = _state.scene;
144
147
  var snap = null;
145
148
  if (state.snapMask && !state.snapMask.isEmpty()) {
146
- snap = SnapUtils.nearestSnap(snapElements, x, y, state.snapMask);
149
+ snap = _export.SnapUtils.nearestSnap(snapElements, x, y, state.snapMask);
147
150
  if (snap) {
148
151
  var _snap$point = snap.point;
149
152
  x = _snap$point.x;
@@ -174,12 +177,12 @@ var Vertex = /*#__PURE__*/function () {
174
177
  if (lines) {
175
178
  state = lines.reduce(function (reducedState, lineID) {
176
179
  var eachLine = reducedState.getIn(['scene', 'layers', layerID, 'lines', lineID]);
177
- if (isEmpty(eachLine)) return reducedState;
178
- reducedState = Layer.removeZeroLengthLines(reducedState, layerID).updatedState;
179
- reducedState = Layer.mergeEqualsVertices(reducedState, layerID, vertexID).updatedState;
180
- reducedState = Line.select(reducedState, layerID, eachLine.id).updatedState;
181
- reducedState = reducedState.setIn(['mode'], MODE_DRAGGING_VERTEX);
182
- reducedState = Line.applyWallChanges(reducedState, END_DRAGGING_VERTEX).updatedState;
180
+ if ((0, _helper.isEmpty)(eachLine)) return reducedState;
181
+ reducedState = _export2.Layer.removeZeroLengthLines(reducedState, layerID).updatedState;
182
+ reducedState = _export2.Layer.mergeEqualsVertices(reducedState, layerID, vertexID).updatedState;
183
+ reducedState = _export2.Line.select(reducedState, layerID, eachLine.id).updatedState;
184
+ reducedState = reducedState.setIn(['mode'], _constants.MODE_DRAGGING_VERTEX);
185
+ reducedState = _export2.Line.applyWallChanges(reducedState, _constants.END_DRAGGING_VERTEX).updatedState;
183
186
  return reducedState;
184
187
  }, state);
185
188
  }
@@ -187,12 +190,11 @@ var Vertex = /*#__PURE__*/function () {
187
190
  mode: draggingSupport.get('previousMode'),
188
191
  draggingSupport: null,
189
192
  activeSnapElement: null,
190
- snapElements: new List()
193
+ snapElements: new _immutable.List()
191
194
  });
192
195
  return {
193
196
  updatedState: state
194
197
  };
195
198
  }
196
199
  }]);
197
- }();
198
- export { Vertex as default };
200
+ }();