kitchen-simulator 4.0.9-react-18 → 4.0.9

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 (202) hide show
  1. package/README.md +3 -0
  2. package/es/AppContext.js +1 -1
  3. package/es/LiteKitchenConfigurator.js +162 -107
  4. package/es/LiteRenderer.js +162 -137
  5. package/es/actions/export.js +25 -12
  6. package/es/assets/gltf/door_sliding.bin +0 -0
  7. package/es/assets/img/png/helper/video_preview_start.png +0 -0
  8. package/es/assets/img/svg/bottombar/elevation.svg +12 -5
  9. package/es/catalog/catalog.js +21 -5
  10. package/es/catalog/factories/wall-factory.js +1 -1
  11. package/es/catalog/holes/window-clear/planner-element.js +2 -2
  12. package/es/catalog/properties/export.js +21 -0
  13. package/es/catalog/properties/property-checkbox.js +68 -0
  14. package/es/catalog/properties/property-color.js +39 -0
  15. package/es/catalog/properties/property-enum.js +50 -0
  16. package/es/catalog/properties/property-hidden.js +19 -0
  17. package/es/catalog/properties/property-lenght-measure.js +100 -0
  18. package/es/catalog/properties/property-length-measure.js +84 -0
  19. package/es/catalog/properties/property-length-measure_hole.js +100 -0
  20. package/es/catalog/properties/property-number.js +48 -0
  21. package/es/catalog/properties/property-read-only.js +26 -0
  22. package/es/catalog/properties/property-string.js +48 -0
  23. package/es/catalog/properties/property-toggle.js +39 -0
  24. package/es/catalog/properties/shared-property-style.js +14 -0
  25. package/es/catalog/utils/exporter.js +24 -11
  26. package/es/catalog/utils/item-loader.js +35 -26
  27. package/es/class/hole.js +0 -2
  28. package/es/class/item.js +96 -70
  29. package/es/class/layer.js +1 -1
  30. package/es/class/line.js +4 -8
  31. package/es/class/project.js +97 -80
  32. package/es/components/content.js +5 -93
  33. package/es/components/export.js +4 -6
  34. package/es/components/style/button.js +106 -0
  35. package/es/components/style/cancel-button.js +21 -0
  36. package/es/components/style/content-container.js +30 -0
  37. package/es/components/style/content-title.js +25 -0
  38. package/es/components/style/delete-button.js +24 -0
  39. package/es/components/style/export.js +28 -2
  40. package/es/components/style/form-block.js +20 -0
  41. package/es/components/style/form-color-input.js +26 -0
  42. package/es/components/style/form-label.js +22 -0
  43. package/es/components/style/form-number-input.js +29 -27
  44. package/es/components/style/form-number-input_2.js +200 -0
  45. package/es/components/style/form-select.js +19 -0
  46. package/es/components/style/form-slider.js +60 -0
  47. package/es/components/style/form-submit-button.js +25 -0
  48. package/es/components/style/form-text-input.js +69 -0
  49. package/es/components/viewer2d/grids/grid-streak.js +1 -1
  50. package/es/components/viewer2d/group.js +5 -4
  51. package/es/components/viewer2d/item.js +155 -359
  52. package/es/components/viewer2d/layer.js +1 -1
  53. package/es/components/viewer2d/line.js +22 -52
  54. package/es/components/viewer2d/ruler.js +16 -11
  55. package/es/components/viewer2d/rulerDist.js +38 -51
  56. package/es/components/viewer2d/rulerX.js +4 -2
  57. package/es/components/viewer2d/rulerY.js +3 -0
  58. package/es/components/viewer2d/scene.js +17 -12
  59. package/es/components/viewer2d/state.js +1 -1
  60. package/es/components/viewer2d/utils.js +2 -2
  61. package/es/components/viewer2d/vertex.js +3 -2
  62. package/es/components/viewer2d/viewer2d.js +56 -87
  63. package/es/components/viewer3d/ruler-utils/scene3D.js +1 -1
  64. package/es/components/viewer3d/scene-creator.js +108 -52
  65. package/es/components/viewer3d/viewer3d-first-person.js +24 -26
  66. package/es/components/viewer3d/viewer3d.js +115 -120
  67. package/es/constants.js +7 -2
  68. package/es/devLiteRenderer.js +491 -150
  69. package/es/index.js +614 -29
  70. package/es/models.js +13 -8
  71. package/es/plugins/SVGLoader.js +1414 -0
  72. package/es/plugins/console-debugger.js +34 -0
  73. package/es/plugins/export.js +7 -0
  74. package/es/plugins/keyboard.js +110 -0
  75. package/es/reducers/project-reducer.js +3 -0
  76. package/es/reducers/viewer2d-reducer.js +3 -1
  77. package/es/reducers/viewer3d-reducer.js +3 -1
  78. package/es/styles/export.js +5 -0
  79. package/es/styles/tabs.css +40 -0
  80. package/es/utils/geometry.js +77 -119
  81. package/es/utils/helper.js +38 -1
  82. package/es/utils/isolate-event-handler.js +827 -607
  83. package/es/utils/molding.js +459 -11
  84. package/es/utils/ruler.js +58 -0
  85. package/lib/AppContext.js +1 -1
  86. package/lib/LiteKitchenConfigurator.js +161 -107
  87. package/lib/LiteRenderer.js +161 -137
  88. package/lib/actions/export.js +35 -39
  89. package/lib/assets/gltf/door_sliding.bin +0 -0
  90. package/lib/assets/img/png/helper/video_preview_start.png +0 -0
  91. package/lib/assets/img/svg/bottombar/elevation.svg +12 -5
  92. package/lib/catalog/catalog.js +20 -4
  93. package/lib/catalog/factories/wall-factory.js +1 -1
  94. package/lib/catalog/holes/window-clear/planner-element.js +2 -2
  95. package/lib/catalog/properties/export.js +81 -0
  96. package/lib/catalog/properties/property-checkbox.js +76 -0
  97. package/lib/catalog/properties/property-color.js +47 -0
  98. package/lib/catalog/properties/property-enum.js +58 -0
  99. package/lib/catalog/properties/property-hidden.js +27 -0
  100. package/lib/catalog/properties/property-lenght-measure.js +108 -0
  101. package/lib/catalog/properties/property-length-measure.js +92 -0
  102. package/lib/catalog/properties/property-length-measure_hole.js +108 -0
  103. package/lib/catalog/properties/property-number.js +56 -0
  104. package/lib/catalog/properties/property-read-only.js +34 -0
  105. package/lib/catalog/properties/property-string.js +56 -0
  106. package/lib/catalog/properties/property-toggle.js +47 -0
  107. package/lib/catalog/properties/shared-property-style.js +21 -0
  108. package/lib/catalog/utils/exporter.js +24 -11
  109. package/lib/catalog/utils/item-loader.js +35 -26
  110. package/lib/class/hole.js +0 -2
  111. package/lib/class/item.js +94 -68
  112. package/lib/class/layer.js +1 -1
  113. package/lib/class/line.js +3 -7
  114. package/lib/class/project.js +97 -80
  115. package/lib/components/content.js +5 -93
  116. package/lib/components/export.js +6 -26
  117. package/lib/components/style/button.js +115 -0
  118. package/lib/components/style/cancel-button.js +29 -0
  119. package/lib/components/style/content-container.js +38 -0
  120. package/lib/components/style/content-title.js +35 -0
  121. package/lib/components/style/delete-button.js +34 -0
  122. package/lib/components/style/export.js +105 -1
  123. package/lib/components/style/form-block.js +28 -0
  124. package/lib/components/style/form-color-input.js +34 -0
  125. package/lib/components/style/form-label.js +30 -0
  126. package/lib/components/style/form-number-input.js +29 -27
  127. package/lib/components/style/form-number-input_2.js +209 -0
  128. package/lib/components/style/form-select.js +29 -0
  129. package/lib/components/style/form-slider.js +68 -0
  130. package/lib/components/style/form-submit-button.js +35 -0
  131. package/lib/components/style/form-text-input.js +78 -0
  132. package/lib/components/viewer2d/grids/grid-streak.js +1 -1
  133. package/lib/components/viewer2d/group.js +5 -4
  134. package/lib/components/viewer2d/item.js +152 -356
  135. package/lib/components/viewer2d/layer.js +1 -1
  136. package/lib/components/viewer2d/line.js +22 -52
  137. package/lib/components/viewer2d/ruler.js +15 -10
  138. package/lib/components/viewer2d/rulerDist.js +38 -51
  139. package/lib/components/viewer2d/rulerX.js +4 -2
  140. package/lib/components/viewer2d/rulerY.js +3 -0
  141. package/lib/components/viewer2d/scene.js +17 -12
  142. package/lib/components/viewer2d/state.js +1 -1
  143. package/lib/components/viewer2d/utils.js +2 -2
  144. package/lib/components/viewer2d/vertex.js +3 -2
  145. package/lib/components/viewer2d/viewer2d.js +54 -84
  146. package/lib/components/viewer3d/ruler-utils/scene3D.js +1 -1
  147. package/lib/components/viewer3d/scene-creator.js +105 -49
  148. package/lib/components/viewer3d/viewer3d-first-person.js +24 -26
  149. package/lib/components/viewer3d/viewer3d.js +112 -116
  150. package/lib/constants.js +12 -7
  151. package/lib/devLiteRenderer.js +489 -148
  152. package/lib/index.js +614 -29
  153. package/lib/models.js +13 -8
  154. package/lib/plugins/SVGLoader.js +1419 -0
  155. package/lib/plugins/console-debugger.js +42 -0
  156. package/lib/plugins/export.js +25 -0
  157. package/lib/plugins/keyboard.js +117 -0
  158. package/lib/reducers/project-reducer.js +3 -0
  159. package/lib/reducers/viewer2d-reducer.js +3 -1
  160. package/lib/reducers/viewer3d-reducer.js +3 -1
  161. package/lib/styles/export.js +13 -0
  162. package/lib/styles/tabs.css +40 -0
  163. package/lib/utils/geometry.js +77 -119
  164. package/lib/utils/helper.js +40 -1
  165. package/lib/utils/isolate-event-handler.js +827 -606
  166. package/lib/utils/molding.js +460 -9
  167. package/lib/utils/ruler.js +63 -0
  168. package/package.json +20 -15
  169. package/es/mocks/appliancePayload.json +0 -27
  170. package/es/mocks/cabinetPayload.json +0 -1914
  171. package/es/mocks/cabinetPayload2.json +0 -76
  172. package/es/mocks/dataBundle2.json +0 -4
  173. package/es/mocks/distancePayload.json +0 -6
  174. package/es/mocks/doorStylePayload2.json +0 -84
  175. package/es/mocks/furnishingPayload.json +0 -23
  176. package/es/mocks/itemCDSPayload.json +0 -27
  177. package/es/mocks/lightingPayload.json +0 -23
  178. package/es/mocks/mockProps.json +0 -43
  179. package/es/mocks/mockProps2.json +0 -9
  180. package/es/mocks/moldingPayload.json +0 -19
  181. package/es/mocks/projectItemsCatalog.json +0 -133
  182. package/es/mocks/rectangleShape.json +0 -238
  183. package/es/mocks/replaceCabinetPayload.json +0 -81
  184. package/es/mocks/roomShapePayload.json +0 -5
  185. package/es/useAppContext.js +0 -8
  186. package/lib/mocks/appliancePayload.json +0 -27
  187. package/lib/mocks/cabinetPayload.json +0 -1914
  188. package/lib/mocks/cabinetPayload2.json +0 -76
  189. package/lib/mocks/dataBundle2.json +0 -4
  190. package/lib/mocks/distancePayload.json +0 -6
  191. package/lib/mocks/doorStylePayload2.json +0 -84
  192. package/lib/mocks/furnishingPayload.json +0 -23
  193. package/lib/mocks/itemCDSPayload.json +0 -27
  194. package/lib/mocks/lightingPayload.json +0 -23
  195. package/lib/mocks/mockProps.json +0 -43
  196. package/lib/mocks/mockProps2.json +0 -9
  197. package/lib/mocks/moldingPayload.json +0 -19
  198. package/lib/mocks/projectItemsCatalog.json +0 -133
  199. package/lib/mocks/rectangleShape.json +0 -238
  200. package/lib/mocks/replaceCabinetPayload.json +0 -81
  201. package/lib/mocks/roomShapePayload.json +0 -5
  202. package/lib/useAppContext.js +0 -16
@@ -43,7 +43,8 @@ var Project = exports["default"] = /*#__PURE__*/function () {
43
43
  }, {
44
44
  key: "newProject",
45
45
  value: function newProject(state) {
46
- var doorStyle = state.toJS().doorStyle === null ? null : state.toJS().doorStyle;
46
+ var _state$toJS$doorStyle, _state;
47
+ var doorStyle = (_state$toJS$doorStyle = (_state = state) === null || _state === void 0 || (_state = _state.toJS()) === null || _state === void 0 ? void 0 : _state.doorStyle) !== null && _state$toJS$doorStyle !== void 0 ? _state$toJS$doorStyle : null;
47
48
  // let counterTop = state.getIn(['scene', 'layers', layerID, 'counterTop']);
48
49
  // let floorStyle = state.getIn(['scene', 'layers', layerID, 'floorStyle']);
49
50
  var _viewer2D = state.viewer2D;
@@ -83,9 +84,9 @@ var Project = exports["default"] = /*#__PURE__*/function () {
83
84
  a: 0.99,
84
85
  d: 0.99
85
86
  });
86
- var _state = state,
87
- oldScene = _state.scene,
88
- oldSceneHistory = _state.sceneHistory;
87
+ var _state2 = state,
88
+ oldScene = _state2.scene,
89
+ oldSceneHistory = _state2.sceneHistory;
89
90
  var json_items = sceneJSON.layers[sceneJSON.selectedLayer].items;
90
91
  var elements = state.catalog.get('elements').toArray();
91
92
  var _loop = function _loop(x) {
@@ -111,6 +112,8 @@ var Project = exports["default"] = /*#__PURE__*/function () {
111
112
  // sceneJSON && (sceneJSON.layers[layerID] = newlayer);
112
113
  // }
113
114
 
115
+ // check type of ceilHeight and make it to Number
116
+ if (typeof sceneJSON.layers[layerID].ceilHeight !== 'number') sceneJSON.layers[layerID].ceilHeight = Number(sceneJSON.layers[layerID].ceilHeight);
114
117
  var newScene = new _models.Scene(sceneJSON);
115
118
  state = new _models.State({
116
119
  scene: newScene.toJS(),
@@ -176,6 +179,8 @@ var Project = exports["default"] = /*#__PURE__*/function () {
176
179
  // Matching state.doorStyle with layer.doorStyle
177
180
  if (state.getIn(['scene', 'layers', layerID, 'doorStyle'])) {
178
181
  doorStyle = state.getIn(['scene', 'layers', layerID, 'doorStyle']);
182
+ } else if (!(0, _helper.isEmpty)(doorStyle)) {
183
+ state = state.setIn(['scene', 'layers', layerID, 'doorStyle'], doorStyle);
179
184
  }
180
185
  state = state.merge({
181
186
  doorStyle: doorStyle,
@@ -838,89 +843,101 @@ var Project = exports["default"] = /*#__PURE__*/function () {
838
843
  key: "createRoomWithShape",
839
844
  value: function createRoomWithShape(state, roomShapeType, width, height, doorStyle) {
840
845
  var catalog = state.catalog;
846
+ // keep measurement unit, sceneHistory
847
+ var curLayerID = state.scene.selectedLayer;
848
+ var layerUnit = state.getIn(['scene', 'layers', curLayerID, 'unit']);
849
+ var ceilHeight = state.getIn(['scene', 'layers', curLayerID, 'ceilHeight']);
850
+ var sceneHistory = state.getIn(['sceneHistory']);
841
851
  state = this.newProject(state).updatedState;
842
852
  state = state.merge({
843
853
  catalog: catalog
844
854
  });
845
- var _viewer2D = state.viewer2D;
846
- var viewer = _viewer2D.toJS();
847
- width = (0, _convertUnitsLite.convert)(width).from('in').to('cm');
848
- height = (0, _convertUnitsLite.convert)(height).from('in').to('cm');
849
- var layerID = state.scene.selectedLayer;
850
855
  state = _export2.Item.setInitialDoorStyle(state, doorStyle).updatedState;
851
- if ((0, _helper.isEmpty)(viewer)) return {
852
- updatedState: state
853
- };
854
- var halfWidth = width / 2;
855
- var halfHeight = height / 2;
856
- var viewerWidth = viewer.SVGWidth;
857
- var viewerHeight = viewer.SVGHeight;
858
- var centerPos = {
859
- x: viewerWidth / 2,
860
- y: viewerHeight / 2
861
- };
862
- var vtLB = {
863
- x: centerPos.x - halfWidth,
864
- y: centerPos.y - halfHeight
865
- };
866
- var vtRB = {
867
- x: centerPos.x + halfWidth,
868
- y: centerPos.y - halfHeight
869
- };
870
- var vtRT = {
871
- x: centerPos.x + halfWidth,
872
- y: centerPos.y + halfHeight
873
- };
874
- var vtLT = {
875
- x: centerPos.x - halfWidth,
876
- y: centerPos.y + halfHeight
877
- };
878
- var vertices = [];
879
- switch (roomShapeType) {
880
- case 'rectangle':
881
- vertices = [vtLB, vtLT, vtRT, vtRB];
882
- break;
883
- case constants.ROOM_SHAPE_TYPE.TWO_WALLS_RIGHT_BOTTOM:
884
- vertices = [vtLB, vtRB, vtRT];
885
- break;
886
- case constants.ROOM_SHAPE_TYPE.TWO_WALLS_RIGHT_TOP:
887
- vertices = [vtRB, vtRT, vtLT];
888
- break;
889
- case constants.ROOM_SHAPE_TYPE.TWO_WALLS_LEFT_TOP:
890
- vertices = [vtRT, vtLT, vtLB];
891
- break;
892
- case constants.ROOM_SHAPE_TYPE.TWO_WALLS_LEFT_BOTTOM:
893
- vertices = [vtLT, vtLB, vtRB];
894
- break;
895
- case constants.ROOM_SHAPE_TYPE.THREE_WALLS_LEFT_TOP_RIGHT:
896
- vertices = [vtRB, vtRT, vtLT, vtLB];
897
- break;
898
- case constants.ROOM_SHAPE_TYPE.THREE_WALLS_TOP_RIGHT_BOTTOM:
899
- vertices = [vtLB, vtRB, vtRT, vtLT];
900
- break;
901
- case constants.ROOM_SHAPE_TYPE.THREE_WALLS_RIGHT_BOTTOM_LEFT:
902
- vertices = [vtLT, vtLB, vtRB, vtRT];
903
- break;
904
- case constants.ROOM_SHAPE_TYPE.THREE_WALLS_BOTTOM_LEFT_TOP:
905
- vertices = [vtRT, vtLT, vtLB, vtRB];
906
- break;
907
- }
908
- for (var i = 0; i < vertices.length - 1; i++) {
909
- state = _export2.Line.create(state, layerID, 'wall', vertices[i].x, vertices[i].y, vertices[i + 1].x, vertices[i + 1].y).updatedState;
910
- }
911
- if (roomShapeType === constants.ROOM_SHAPE_TYPE.RECTANGLE) {
912
- state = _export2.Line.create(state, layerID, 'wall', vertices[vertices.length - 1].x, vertices[vertices.length - 1].y, vertices[0].x, vertices[0].y).updatedState;
913
- }
914
- var layer = state.getIn(['scene', 'layers', layerID]);
915
- var lines = layer.getIn(['lines']).toJS();
916
- var drawingInfo = {};
917
- var lineKey = Object.keys(lines);
918
- for (var _i = 0; _i < lineKey.length; _i++) {
919
- if (!(0, _helper.isEmpty)(lineKey)) {
920
- drawingInfo.drawingLine = layer.getIn(['lines', lineKey[_i]]);
856
+ var layerID = state.scene.selectedLayer;
857
+ if (roomShapeType !== constants.ROOM_SHAPE_TYPE.CUSTOM && !(0, _helper.isEmpty)(width) && !(0, _helper.isEmpty)(height) && width !== 0 && height !== 0) {
858
+ var _viewer2D = state.viewer2D;
859
+ var viewer = _viewer2D.toJS();
860
+ if ((0, _helper.isEmpty)(viewer)) return {
861
+ updatedState: state
862
+ };
863
+ width = (0, _convertUnitsLite.convert)(width).from(state.getIn(['scene', 'layers', 'layer-1', 'unit'])).to('cm');
864
+ height = (0, _convertUnitsLite.convert)(height).from(state.getIn(['scene', 'layers', 'layer-1', 'unit'])).to('cm');
865
+ var halfWidth = width / 2;
866
+ var halfHeight = height / 2;
867
+ var viewerWidth = viewer.SVGWidth;
868
+ var viewerHeight = viewer.SVGHeight;
869
+ var centerPos = {
870
+ x: viewerWidth / 2,
871
+ y: viewerHeight / 2
872
+ };
873
+ var vtLB = {
874
+ x: centerPos.x - halfWidth,
875
+ y: centerPos.y - halfHeight
876
+ };
877
+ var vtRB = {
878
+ x: centerPos.x + halfWidth,
879
+ y: centerPos.y - halfHeight
880
+ };
881
+ var vtRT = {
882
+ x: centerPos.x + halfWidth,
883
+ y: centerPos.y + halfHeight
884
+ };
885
+ var vtLT = {
886
+ x: centerPos.x - halfWidth,
887
+ y: centerPos.y + halfHeight
888
+ };
889
+ var vertices = [];
890
+ switch (roomShapeType) {
891
+ case 'rectangle':
892
+ vertices = [vtLB, vtLT, vtRT, vtRB];
893
+ break;
894
+ case constants.ROOM_SHAPE_TYPE.TWO_WALLS_RIGHT_BOTTOM:
895
+ vertices = [vtLB, vtRB, vtRT];
896
+ break;
897
+ case constants.ROOM_SHAPE_TYPE.TWO_WALLS_RIGHT_TOP:
898
+ vertices = [vtRB, vtRT, vtLT];
899
+ break;
900
+ case constants.ROOM_SHAPE_TYPE.TWO_WALLS_LEFT_TOP:
901
+ vertices = [vtRT, vtLT, vtLB];
902
+ break;
903
+ case constants.ROOM_SHAPE_TYPE.TWO_WALLS_LEFT_BOTTOM:
904
+ vertices = [vtLT, vtLB, vtRB];
905
+ break;
906
+ case constants.ROOM_SHAPE_TYPE.THREE_WALLS_LEFT_TOP_RIGHT:
907
+ vertices = [vtRB, vtRT, vtLT, vtLB];
908
+ break;
909
+ case constants.ROOM_SHAPE_TYPE.THREE_WALLS_TOP_RIGHT_BOTTOM:
910
+ vertices = [vtLB, vtRB, vtRT, vtLT];
911
+ break;
912
+ case constants.ROOM_SHAPE_TYPE.THREE_WALLS_RIGHT_BOTTOM_LEFT:
913
+ vertices = [vtLT, vtLB, vtRB, vtRT];
914
+ break;
915
+ case constants.ROOM_SHAPE_TYPE.THREE_WALLS_BOTTOM_LEFT_TOP:
916
+ vertices = [vtRT, vtLT, vtLB, vtRB];
917
+ break;
918
+ }
919
+ for (var i = 0; i < vertices.length - 1; i++) {
920
+ state = _export2.Line.create(state, layerID, 'wall', vertices[i].x, vertices[i].y, vertices[i + 1].x, vertices[i + 1].y).updatedState;
921
+ }
922
+ if (roomShapeType === constants.ROOM_SHAPE_TYPE.RECTANGLE) {
923
+ state = _export2.Line.create(state, layerID, 'wall', vertices[vertices.length - 1].x, vertices[vertices.length - 1].y, vertices[0].x, vertices[0].y).updatedState;
924
+ }
925
+ var layer = state.getIn(['scene', 'layers', layerID]);
926
+ var lines = layer.getIn(['lines']).toJS();
927
+ var drawingInfo = {};
928
+ var lineKey = Object.keys(lines);
929
+ for (var _i = 0; _i < lineKey.length; _i++) {
930
+ if (!(0, _helper.isEmpty)(lineKey)) {
931
+ drawingInfo.drawingLine = layer.getIn(['lines', lineKey[_i]]);
932
+ }
933
+ state = _export2.Layer.detectAndUpdateAreas(state, layerID, drawingInfo).updatedState;
921
934
  }
922
- state = _export2.Layer.detectAndUpdateAreas(state, layerID, drawingInfo).updatedState;
923
935
  }
936
+
937
+ // copy keeped measurement unit, sceneHistory
938
+ state = state.setIn(['scene', 'layers', layerID, 'unit'], layerUnit);
939
+ state = state.setIn(['scene', 'layers', layerID, 'ceilHeight'], ceilHeight);
940
+ state = state.setIn(['sceneHistory'], sceneHistory);
924
941
  state = (0, _helper.centering2D)(state);
925
942
  return {
926
943
  updatedState: state
@@ -13,12 +13,11 @@ var _viewer3d = _interopRequireDefault(require("./viewer3d/viewer3d"));
13
13
  var _viewer3dFirstPerson = _interopRequireDefault(require("./viewer3d/viewer3d-first-person"));
14
14
  var constants = _interopRequireWildcard(require("../constants"));
15
15
  var _front3D = _interopRequireDefault(require("./viewer3d/front3D"));
16
- var _useAppContext2 = require("../useAppContext");
17
16
  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); }
18
17
  // import CatalogList from './catalog-view/catalog-list';
19
18
  // import ProjectConfigurator from './configurator/project-configurator';
20
19
 
21
- function Content(_ref) {
20
+ function Content(_ref, _ref2) {
22
21
  var width = _ref.width,
23
22
  height = _ref.height,
24
23
  state = _ref.state,
@@ -29,98 +28,8 @@ function Content(_ref) {
29
28
  keyDownEnable = _ref.keyDownEnable,
30
29
  catalog = _ref.catalog,
31
30
  onInternalEvent = _ref.onInternalEvent;
31
+ var projectActions = _ref2.projectActions;
32
32
  var mode = state.get('mode');
33
- var _useAppContext = (0, _useAppContext2.useAppContext)(),
34
- projectActions = _useAppContext.projectActions;
35
- var rollback = projectActions.rollback,
36
- undo = projectActions.undo,
37
- redo = projectActions.redo,
38
- toggleSnap = projectActions.toggleSnap,
39
- copyProperties = projectActions.copyProperties,
40
- pasteProperties = projectActions.pasteProperties,
41
- recreate = projectActions.recreate,
42
- uncreate = projectActions.uncreate,
43
- shift2doff = projectActions.shift2doff,
44
- shift2don = projectActions.shift2don;
45
- (0, _react.useEffect)(function () {
46
- function handleKeyDown(event) {
47
- switch (event.keyCode) {
48
- case constants.KEYBOARD_BUTTON_CODE.ESC:
49
- rollback();
50
- break;
51
- case constants.KEYBOARD_BUTTON_CODE.Z:
52
- if (event.getModifierState('Control') || event.getModifierState('Meta')) undo();
53
- break;
54
- case constants.KEYBOARD_BUTTON_CODE.Q:
55
- if (event.getModifierState('Control') || event.getModifierState('Meta')) redo();
56
- break;
57
- case constants.KEYBOARD_BUTTON_CODE.ALT:
58
- if (constants.MODE_SNAPPING.includes(mode)) toggleSnap(state.snapMask.merge({
59
- SNAP_POINT: false,
60
- SNAP_LINE: false,
61
- SNAP_SEGMENT: false,
62
- SNAP_GRID: false,
63
- SNAP_GUIDE: false,
64
- tempSnapConfiguartion: state.snapMask.toJS()
65
- }));
66
- break;
67
- case constants.KEYBOARD_BUTTON_CODE.C:
68
- {
69
- var selectedLayer = state.getIn(['scene', 'selectedLayer']);
70
- var selected = state.getIn(['scene', 'layers', selectedLayer, 'selected']);
71
- if ((mode === constants.MODE_IDLE || mode === constants.MODE_3D_VIEW) && (selected.holes.size || selected.areas.size || selected.items.size || selected.lines.size)) {
72
- if (selected.holes.size) {
73
- var hole = state.getIn(['scene', 'layers', selectedLayer, 'holes', selected.holes.get(0)]);
74
- copyProperties(hole.get('properties'));
75
- } else if (selected.areas.size) {
76
- var area = state.getIn(['scene', 'layers', selectedLayer, 'areas', selected.areas.get(0)]);
77
- copyProperties(area.properties);
78
- } else if (selected.items.size) {
79
- var item = state.getIn(['scene', 'layers', selectedLayer, 'items', selected.items.get(0)]);
80
- copyProperties(item.properties);
81
- } else if (selected.lines.size) {
82
- var line = state.getIn(['scene', 'layers', selectedLayer, 'lines', selected.lines.get(0)]);
83
- copyProperties(line.properties);
84
- }
85
- }
86
- break;
87
- }
88
- case constants.KEYBOARD_BUTTON_CODE.V:
89
- pasteProperties();
90
- break;
91
- case constants.KEYBOARD_BUTTON_CODE.SHIFT:
92
- if (!['TEXTAREA', 'INPUT'].includes(document.activeElement.tagName)) {
93
- if ([constants.MODE_DRAWING_ITEM_3D, constants.MODE_IDLE_3D].includes(mode)) recreate();else if ([constants.MODE_DRAWING_ITEM, constants.MODE_IDLE].includes(mode)) shift2doff();
94
- }
95
- break;
96
- default:
97
- break;
98
- }
99
- }
100
- function handleKeyUp(event) {
101
- switch (event.keyCode) {
102
- case constants.KEYBOARD_BUTTON_CODE.ALT:
103
- if (constants.MODE_SNAPPING.includes(mode)) toggleSnap(state.snapMask.merge(state.snapMask.get('tempSnapConfiguartion')));
104
- break;
105
- case constants.KEYBOARD_BUTTON_CODE.CTRL:
106
- // setAlterateState();
107
- break;
108
- case constants.KEYBOARD_BUTTON_CODE.SHIFT:
109
- if (!['TEXTAREA', 'INPUT'].includes(document.activeElement.tagName)) {
110
- if ([constants.MODE_DRAWING_ITEM_3D, constants.MODE_IDLE_3D].includes(mode)) uncreate();else if ([constants.MODE_DRAWING_ITEM, constants.MODE_IDLE].includes(mode)) shift2don();
111
- }
112
- break;
113
- default:
114
- break;
115
- }
116
- }
117
- window.addEventListener('keydown', handleKeyDown);
118
- window.addEventListener('keyup', handleKeyUp);
119
- return function () {
120
- window.removeEventListener('keydown', handleKeyDown);
121
- window.removeEventListener('keyup', handleKeyUp);
122
- };
123
- }, [state, rollback, undo, redo, toggleSnap, copyProperties, pasteProperties, recreate, uncreate, shift2doff, shift2don]);
124
33
 
125
34
  // Internal Event for unselect_all
126
35
  (0, _react.useEffect)(function () {
@@ -235,4 +144,7 @@ Content.propTypes = {
235
144
  replaceCabinet: _propTypes["default"].func.isRequired,
236
145
  onInternalEvent: _propTypes["default"].func.isRequired
237
146
  };
147
+ Content.contextTypes = {
148
+ projectActions: _propTypes["default"].object.isRequired
149
+ };
238
150
  module.exports = exports.default;
@@ -1,27 +1,7 @@
1
- "use strict";
1
+ import Content from "./content";
2
+ import Viewer2DComponents from "./viewer2d/export";
3
+ import StyleComponents from "./style/export";
2
4
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- Object.defineProperty(exports, "Content", {
8
- enumerable: true,
9
- get: function get() {
10
- return _content["default"];
11
- }
12
- });
13
- Object.defineProperty(exports, "Viewer2DComponents", {
14
- enumerable: true,
15
- get: function get() {
16
- return _export["default"];
17
- }
18
- });
19
- exports["default"] = void 0;
20
- var _content = _interopRequireDefault(require("./content"));
21
- var _export = _interopRequireDefault(require("./viewer2d/export"));
22
- var _export2 = _interopRequireDefault(require("./style/export"));
23
- var _default = exports["default"] = {
24
- Content: _content["default"],
25
- Viewer2DComponents: _export["default"],
26
- StyleComponents: _export2["default"]
27
- };
5
+ export { Content, Viewer2DComponents, StyleComponents };
6
+
7
+ export default { Content, Viewer2DComponents, StyleComponents };
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
12
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
+ var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
14
+ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
15
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
16
+ var _react = _interopRequireWildcard(require("react"));
17
+ var _propTypes = _interopRequireDefault(require("prop-types"));
18
+ var SharedStyle = _interopRequireWildcard(require("../../shared-style"));
19
+ var _excluded = ["type", "style", "styleHover", "children", "size"];
20
+ 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); }
21
+ function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
22
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
23
+ var BASE_STYLE = {
24
+ display: 'inline-block',
25
+ fontWeight: '400',
26
+ lineHeight: '1.25',
27
+ textAlign: 'center',
28
+ whiteSpace: 'nowrap',
29
+ verticalAlign: 'middle',
30
+ cursor: 'pointer',
31
+ WebkitUserSelect: 'none',
32
+ MozUserSelect: 'none',
33
+ MsUserSelect: 'none',
34
+ userSelect: 'none',
35
+ padding: '5px 14px',
36
+ fontSize: '14px',
37
+ color: SharedStyle.COLORS.black,
38
+ fonWeight: '400px',
39
+ transition: 'background-color 175ms ease, border 175ms ease',
40
+ outline: 'none',
41
+ borderRadius: '2px',
42
+ borderWidth: '1px',
43
+ borderType: 'solid',
44
+ width: '100%'
45
+ };
46
+ var BASE_STYLE_SIZE = {
47
+ small: {
48
+ fontSize: '12px',
49
+ padding: '3px 8px'
50
+ },
51
+ normal: {},
52
+ large: {
53
+ padding: '8px 20px'
54
+ }
55
+ };
56
+ var Button = exports["default"] = /*#__PURE__*/function (_Component) {
57
+ function Button(props) {
58
+ var _this;
59
+ (0, _classCallCheck2["default"])(this, Button);
60
+ _this = _callSuper(this, Button, [props]);
61
+ _this.state = {
62
+ hover: false
63
+ };
64
+ return _this;
65
+ }
66
+ (0, _inherits2["default"])(Button, _Component);
67
+ return (0, _createClass2["default"])(Button, [{
68
+ key: "render",
69
+ value: function render() {
70
+ var _this2 = this;
71
+ var hover = this.state.hover;
72
+ var _this$props = this.props,
73
+ type = _this$props.type,
74
+ customStyle = _this$props.style,
75
+ customStyleHover = _this$props.styleHover,
76
+ children = _this$props.children,
77
+ size = _this$props.size,
78
+ rest = (0, _objectWithoutProperties2["default"])(_this$props, _excluded);
79
+ var styleMerged = Object.assign({}, BASE_STYLE, BASE_STYLE_SIZE[size], hover ? customStyleHover : customStyle);
80
+ return /*#__PURE__*/_react["default"].createElement("button", (0, _extends2["default"])({
81
+ type: type,
82
+ onMouseEnter: function onMouseEnter(e) {
83
+ return _this2.setState({
84
+ hover: true
85
+ });
86
+ },
87
+ onMouseLeave: function onMouseLeave(e) {
88
+ return _this2.setState({
89
+ hover: false
90
+ });
91
+ },
92
+ style: styleMerged
93
+ }, rest), children);
94
+ }
95
+ }]);
96
+ }(_react.Component);
97
+ Button.defaultProps = {
98
+ type: 'button',
99
+ size: 'normal',
100
+ style: {
101
+ backgroundColor: '#e6e6e6',
102
+ borderColor: '#adadad'
103
+ },
104
+ styleHover: {
105
+ backgroundColor: '#d4d4d4',
106
+ borderColor: '#8c8c8c'
107
+ }
108
+ };
109
+ Button.propTypes = {
110
+ type: _propTypes["default"].string,
111
+ style: _propTypes["default"].object,
112
+ styleHover: _propTypes["default"].object,
113
+ size: _propTypes["default"].oneOf(['large', 'normal', 'small'])
114
+ };
115
+ module.exports = exports.default;
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = CancelButton;
8
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
10
+ var _react = _interopRequireDefault(require("react"));
11
+ var _button = _interopRequireDefault(require("./button"));
12
+ var _excluded = ["children"];
13
+ var STYLE = {
14
+ borderColor: '#adadad',
15
+ backgroundColor: '#e6e6e6'
16
+ };
17
+ var STYLE_HOVER = {
18
+ backgroundColor: '#d4d4d4',
19
+ borderColor: '#8c8c8c'
20
+ };
21
+ function CancelButton(_ref) {
22
+ var children = _ref.children,
23
+ rest = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
24
+ return /*#__PURE__*/_react["default"].createElement(_button["default"], (0, _extends2["default"])({
25
+ style: STYLE,
26
+ styleHover: STYLE_HOVER
27
+ }, rest), children);
28
+ }
29
+ module.exports = exports.default;
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = ContentContainer;
8
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _propTypes = _interopRequireDefault(require("prop-types"));
11
+ 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; }
12
+ 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) { (0, _defineProperty2["default"])(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; }
13
+ var STYLE = {
14
+ padding: '0 20px',
15
+ overflowY: 'auto'
16
+ };
17
+ function ContentContainer(_ref) {
18
+ var children = _ref.children,
19
+ width = _ref.width,
20
+ height = _ref.height,
21
+ _ref$style = _ref.style,
22
+ style = _ref$style === void 0 ? {} : _ref$style;
23
+ return /*#__PURE__*/_react["default"].createElement("div", {
24
+ style: _objectSpread(_objectSpread({
25
+ width: width,
26
+ height: height
27
+ }, STYLE), style),
28
+ onWheel: function onWheel(event) {
29
+ return event.stopPropagation();
30
+ }
31
+ }, children);
32
+ }
33
+ ContentContainer.propsType = {
34
+ width: _propTypes["default"].number.isRequired,
35
+ height: _propTypes["default"].number.isRequired,
36
+ style: _propTypes["default"].object
37
+ };
38
+ module.exports = exports.default;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = ContentTitle;
9
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
12
+ var _react = _interopRequireDefault(require("react"));
13
+ var _propTypes = _interopRequireDefault(require("prop-types"));
14
+ var SharedStyle = _interopRequireWildcard(require("../../shared-style"));
15
+ var _excluded = ["children", "style"];
16
+ 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); }
17
+ 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; }
18
+ 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) { (0, _defineProperty2["default"])(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; }
19
+ var STYLE = {
20
+ color: SharedStyle.PRIMARY_COLOR.alt,
21
+ fontWeight: 300
22
+ };
23
+ function ContentTitle(_ref) {
24
+ var children = _ref.children,
25
+ _ref$style = _ref.style,
26
+ style = _ref$style === void 0 ? {} : _ref$style,
27
+ rest = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
28
+ return /*#__PURE__*/_react["default"].createElement("h1", (0, _extends2["default"])({
29
+ style: _objectSpread(_objectSpread({}, STYLE), style)
30
+ }, rest), children);
31
+ }
32
+ ContentTitle.propsType = {
33
+ style: _propTypes["default"].object
34
+ };
35
+ module.exports = exports.default;
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = FormDeleteButton;
9
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
+ var _react = _interopRequireDefault(require("react"));
12
+ var _button = _interopRequireDefault(require("./button"));
13
+ var SharedStyle = _interopRequireWildcard(require("../../shared-style"));
14
+ var _excluded = ["children"];
15
+ 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); }
16
+ var STYLE = {
17
+ borderColor: '#c12e2a',
18
+ backgroundColor: '#c9302c',
19
+ color: SharedStyle.COLORS.white
20
+ };
21
+ var STYLE_HOVER = {
22
+ backgroundColor: '#972726',
23
+ borderColor: '#c12e2a',
24
+ color: SharedStyle.COLORS.white
25
+ };
26
+ function FormDeleteButton(_ref) {
27
+ var children = _ref.children,
28
+ rest = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
29
+ return /*#__PURE__*/_react["default"].createElement(_button["default"], (0, _extends2["default"])({
30
+ style: STYLE,
31
+ styleHover: STYLE_HOVER
32
+ }, rest), children);
33
+ }
34
+ module.exports = exports.default;