UNPKG

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
'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"]}