react-planner-viewer
Version:
react-planner-viewer is a React Component for view plans builded with react-planner in 2D mode
228 lines (177 loc) • 23.7 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = function (state, action) {
switch (action.type) {
case _constants.SELECT_ITEM:
return selectItem(state, action.layerID, action.itemID);
case _constants.SELECT_TOOL_DRAWING_ITEM:
return selectToolDrawingItem(state, action.sceneComponentType);
case _constants.UPDATE_DRAWING_ITEM:
return updateDrawingItem(state, action.layerID, action.x, action.y);
case _constants.END_DRAWING_ITEM:
return endDrawingItem(state, action.layerID, action.x, action.y);
case _constants.BEGIN_DRAGGING_ITEM:
return beginDraggingItem(state, action.layerID, action.itemID, action.x, action.y);
case _constants.UPDATE_DRAGGING_ITEM:
return updateDraggingItem(state, action.x, action.y);
case _constants.END_DRAGGING_ITEM:
return endDraggingItem(state, action.x, action.y);
case _constants.BEGIN_ROTATING_ITEM:
return beginRotatingItem(state, action.layerID, action.itemID, action.x, action.y);
case _constants.UPDATE_ROTATING_ITEM:
return updateRotatingItem(state, action.x, action.y);
case _constants.END_ROTATING_ITEM:
return endRotatingItem(state, action.x, action.y);
default:
return state;
}
};
var _immutable = require('immutable');
var _constants = require('../constants');
var _layerOperations = require('../utils/layer-operations');
var _geometry = require('../utils/geometry');
var Geometry = _interopRequireWildcard(_geometry);
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }
function selectToolDrawingItem(state, sceneComponentType) {
return state.merge({
mode: _constants.MODE_DRAWING_ITEM,
drawingSupport: (0, _immutable.Map)({
type: sceneComponentType
})
});
}
/** holes operations **/
function updateDrawingItem(state, layerID, x, y) {
var drawingSupport = state.drawingSupport,
catalog = state.catalog;
var scene = state.scene.updateIn(['layers', layerID], function (layer) {
return layer.withMutations(function (layer) {
if (drawingSupport.has('currentID')) {
layer.updateIn(['items', drawingSupport.get('currentID')], function (item) {
return item.merge({ x: x, y: y });
});
} else {
var _addItem = (0, _layerOperations.addItem)(layer, drawingSupport.get('type'), x, y, 200, 100, 0, catalog),
item = _addItem.item;
(0, _layerOperations.select)(layer, 'items', item.id);
drawingSupport = drawingSupport.set('currentID', item.id);
}
});
});
return state.merge({
scene: scene,
drawingSupport: drawingSupport
});
}
function endDrawingItem(state, layerID, x, y) {
var catalog = state.catalog;
state = updateDrawingItem(state, layerID, x, y, catalog);
var scene = state.scene.updateIn(['layers', layerID], function (layer) {
return (0, _layerOperations.unselectAll)(layer);
});
return state.merge({
scene: scene,
sceneHistory: state.sceneHistory.push(scene),
drawingSupport: (0, _immutable.Map)({
type: state.drawingSupport.get('type')
})
});
}
function beginDraggingItem(state, layerID, itemID, x, y) {
var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
return state.merge({
mode: _constants.MODE_DRAGGING_ITEM,
draggingSupport: (0, _immutable.Map)({
layerID: layerID,
itemID: itemID,
startPointX: x,
startPointY: y,
originalX: item.x,
originalY: item.y
})
});
}
function updateDraggingItem(state, x, y) {
var draggingSupport = state.draggingSupport,
scene = state.scene;
var layerID = draggingSupport.get('layerID');
var itemID = draggingSupport.get('itemID');
var startPointX = draggingSupport.get('startPointX');
var startPointY = draggingSupport.get('startPointY');
var originalX = draggingSupport.get('originalX');
var originalY = draggingSupport.get('originalY');
var diffX = startPointX - x;
var diffY = startPointY - y;
var item = scene.getIn(['layers', layerID, 'items', itemID]);
item = item.merge({
x: originalX - diffX,
y: originalY - diffY
});
return state.merge({
scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
});
}
function endDraggingItem(state, x, y) {
state = updateDraggingItem(state, x, y);
return state.merge({
mode: _constants.MODE_IDLE,
sceneHistory: state.sceneHistory.push(state.scene)
});
}
function beginRotatingItem(state, layerID, itemID, x, y) {
var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
return state.merge({
mode: _constants.MODE_ROTATING_ITEM,
rotatingSupport: (0, _immutable.Map)({
layerID: layerID,
itemID: itemID
})
});
}
function updateRotatingItem(state, x, y) {
var rotatingSupport = state.rotatingSupport,
scene = state.scene;
var layerID = rotatingSupport.get('layerID');
var itemID = rotatingSupport.get('itemID');
var item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);
var deltaX = x - item.x;
var deltaY = y - item.y;
var rotation = Math.atan2(deltaY, deltaX) * 180 / Math.PI - 90;
if (-5 < rotation && rotation < 5) rotation = 0;
if (-95 < rotation && rotation < -85) rotation = -90;
if (-185 < rotation && rotation < -175) rotation = -180;
if (85 < rotation && rotation < 90) rotation = 90;
if (-270 < rotation && rotation < -265) rotation = 90;
item = item.merge({
rotation: rotation
});
return state.merge({
scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)
});
}
function endRotatingItem(state, x, y) {
state = updateRotatingItem(state, x, y);
return state.merge({
mode: _constants.MODE_IDLE,
sceneHistory: state.sceneHistory.push(state.scene)
});
}
function selectItem(state, layerID, itemID) {
var scene = state.scene;
scene = scene.merge({
layers: scene.layers.map(_layerOperations.unselectAll),
selectedLayer: layerID
});
scene = scene.updateIn(['layers', layerID], function (layer) {
return layer.withMutations(function (layer) {
(0, _layerOperations.select)(layer, 'items', itemID);
});
});
return state.merge({
scene: scene,
sceneHistory: state.sceneHistory.push(scene)
});
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/reducers/items-reducer.js"],"names":["state","action","type","selectItem","layerID","itemID","selectToolDrawingItem","sceneComponentType","updateDrawingItem","x","y","endDrawingItem","beginDraggingItem","updateDraggingItem","endDraggingItem","beginRotatingItem","updateRotatingItem","endRotatingItem","Geometry","merge","mode","drawingSupport","catalog","scene","updateIn","layer","withMutations","has","get","item","id","set","sceneHistory","push","getIn","draggingSupport","startPointX","startPointY","originalX","originalY","diffX","diffY","mergeIn","rotatingSupport","deltaX","deltaY","rotation","Math","atan2","PI","layers","map","selectedLayer"],"mappings":"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","file":"items-reducer.js","sourcesContent":["import {List, Map} from 'immutable';\n\nimport {\n  SELECT_TOOL_DRAWING_ITEM,\n  UPDATE_DRAWING_ITEM,\n  END_DRAWING_ITEM,\n  BEGIN_DRAGGING_ITEM,\n  UPDATE_DRAGGING_ITEM,\n  END_DRAGGING_ITEM,\n  BEGIN_ROTATING_ITEM,\n  UPDATE_ROTATING_ITEM,\n  END_ROTATING_ITEM,\n  SELECT_ITEM,\n\n  MODE_IDLE,\n  MODE_DRAWING_ITEM,\n  MODE_DRAGGING_ITEM,\n  MODE_ROTATING_ITEM\n} from '../constants';\n\nimport {addItem, removeItem, unselect, select, unselectAll} from '../utils/layer-operations';\nimport * as Geometry from '../utils/geometry';\n\nexport default function (state, action) {\n  switch (action.type) {\n    case SELECT_ITEM:\n      return selectItem(state, action.layerID, action.itemID);\n\n    case SELECT_TOOL_DRAWING_ITEM:\n      return selectToolDrawingItem(state, action.sceneComponentType);\n\n    case UPDATE_DRAWING_ITEM:\n      return updateDrawingItem(state, action.layerID, action.x, action.y);\n\n    case END_DRAWING_ITEM:\n      return endDrawingItem(state, action.layerID, action.x, action.y);\n\n    case BEGIN_DRAGGING_ITEM:\n      return beginDraggingItem(state, action.layerID, action.itemID, action.x, action.y);\n\n    case UPDATE_DRAGGING_ITEM:\n      return updateDraggingItem(state, action.x, action.y);\n\n    case END_DRAGGING_ITEM:\n      return endDraggingItem(state, action.x, action.y);\n\n    case BEGIN_ROTATING_ITEM:\n      return beginRotatingItem(state, action.layerID, action.itemID, action.x, action.y);\n\n    case UPDATE_ROTATING_ITEM:\n      return updateRotatingItem(state, action.x, action.y);\n\n    case END_ROTATING_ITEM:\n      return endRotatingItem(state, action.x, action.y);\n\n    default:\n      return state;\n  }\n}\n\nfunction selectToolDrawingItem(state, sceneComponentType) {\n  return state.merge({\n    mode: MODE_DRAWING_ITEM,\n    drawingSupport: Map({\n      type: sceneComponentType\n    })\n  });\n}\n\n/** holes operations **/\nfunction updateDrawingItem(state, layerID, x, y) {\n  let {drawingSupport, catalog} = state;\n\n  let scene = state.scene.updateIn(['layers', layerID], layer => layer.withMutations(layer => {\n\n    if (drawingSupport.has('currentID')) {\n      layer.updateIn(['items', drawingSupport.get('currentID')], item => item.merge({x, y}));\n    } else {\n      let {item} = addItem(layer, drawingSupport.get('type'), x, y, 200, 100, 0, catalog);\n      select(layer, 'items', item.id);\n      drawingSupport = drawingSupport.set('currentID', item.id);\n    }\n  }));\n\n  return state.merge({\n    scene,\n    drawingSupport\n  });\n}\n\nfunction endDrawingItem(state, layerID, x, y) {\n  let catalog = state.catalog;\n  state = updateDrawingItem(state, layerID, x, y, catalog);\n  let scene = state.scene.updateIn(['layers', layerID], layer => unselectAll(layer));\n  return state.merge({\n    scene,\n    sceneHistory: state.sceneHistory.push(scene),\n    drawingSupport: Map({\n      type: state.drawingSupport.get('type')\n    })\n  });\n\n}\n\nfunction beginDraggingItem(state, layerID, itemID, x, y) {\n\n  let item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);\n\n  return state.merge({\n    mode: MODE_DRAGGING_ITEM,\n    draggingSupport: Map({\n      layerID,\n      itemID,\n      startPointX: x,\n      startPointY: y,\n      originalX: item.x,\n      originalY: item.y\n    })\n  });\n}\n\nfunction updateDraggingItem(state, x, y) {\n  let {draggingSupport, scene} = state;\n\n  let layerID = draggingSupport.get('layerID');\n  let itemID = draggingSupport.get('itemID');\n  let startPointX = draggingSupport.get('startPointX');\n  let startPointY = draggingSupport.get('startPointY');\n  let originalX = draggingSupport.get('originalX');\n  let originalY = draggingSupport.get('originalY');\n\n  let diffX = startPointX - x;\n  let diffY = startPointY - y;\n\n  let item = scene.getIn(['layers', layerID, 'items', itemID]);\n  item = item.merge({\n    x: originalX - diffX,\n    y: originalY - diffY\n  });\n\n  return state.merge({\n    scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)\n  });\n}\n\nfunction endDraggingItem(state, x, y) {\n  state = updateDraggingItem(state, x, y);\n  return state.merge({\n    mode: MODE_IDLE,\n    sceneHistory: state.sceneHistory.push(state.scene)\n  });\n}\n\nfunction beginRotatingItem(state, layerID, itemID, x, y) {\n\n  let item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);\n\n  return state.merge({\n    mode: MODE_ROTATING_ITEM,\n    rotatingSupport: Map({\n      layerID,\n      itemID\n    })\n  });\n}\n\nfunction updateRotatingItem(state, x, y) {\n  let {rotatingSupport, scene} = state;\n\n  let layerID = rotatingSupport.get('layerID');\n  let itemID = rotatingSupport.get('itemID');\n  let item = state.getIn(['scene', 'layers', layerID, 'items', itemID]);\n\n  let deltaX = x - item.x;\n  let deltaY = y - item.y;\n  let rotation = Math.atan2(deltaY, deltaX) * 180 / Math.PI - 90;\n\n  if (-5 < rotation && rotation < 5) rotation = 0;\n  if (-95 < rotation && rotation < -85) rotation = -90;\n  if (-185 < rotation && rotation < -175) rotation = -180;\n  if (85 < rotation && rotation < 90) rotation = 90;\n  if (-270 < rotation && rotation < -265) rotation = 90;\n\n  item = item.merge({\n    rotation,\n  });\n\n  return state.merge({\n    scene: scene.mergeIn(['layers', layerID, 'items', itemID], item)\n  });\n}\n\nfunction endRotatingItem(state, x, y) {\n  state = updateRotatingItem(state, x, y);\n  return state.merge({\n    mode: MODE_IDLE,\n    sceneHistory: state.sceneHistory.push(state.scene)\n  });\n}\n\nfunction selectItem(state, layerID, itemID) {\n  let scene = state.scene;\n\n  scene = scene.merge({\n    layers: scene.layers.map(unselectAll),\n    selectedLayer: layerID\n  });\n\n  scene = scene.updateIn(['layers', layerID], layer => layer.withMutations(layer => {\n      select(layer, 'items', itemID);\n    })\n  );\n\n  return state.merge({\n    scene,\n    sceneHistory: state.sceneHistory.push(scene)\n  })\n}\n"]}