react-planner
Version:
react-planner is a React Component for plans design. Draw a 2D floorplan and navigate it in 3D mode.
58 lines (51 loc) • 2.13 kB
JavaScript
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
import React, { Component } from 'react';
import PropTypes from 'prop-types';
import ItemAttributesEditor from './item-attributes-editor';
import LineAttributesEditor from './line-attributes-editor';
import HoleAttributesEditor from './hole-attributes-editor';
export default function AttributesEditor(_ref) {
var element = _ref.element,
onUpdate = _ref.onUpdate,
onValid = _ref.onValid,
attributeFormData = _ref.attributeFormData,
state = _ref.state,
rest = _objectWithoutProperties(_ref, ['element', 'onUpdate', 'onValid', 'attributeFormData', 'state']);
switch (element.prototype) {
case 'items':
return React.createElement(ItemAttributesEditor, _extends({
element: element,
onUpdate: onUpdate,
onValid: onValid,
attributeFormData: attributeFormData,
state: state
}, rest));
case 'lines':
return React.createElement(LineAttributesEditor, _extends({
element: element,
onUpdate: onUpdate,
onValid: onValid,
attributeFormData: attributeFormData,
state: state
}, rest));
case 'holes':
return React.createElement(HoleAttributesEditor, _extends({
element: element,
onUpdate: onUpdate,
onValid: onValid,
attributeFormData: attributeFormData,
state: state
}, rest));
case 'areas':
return null;
}
return null;
}
AttributesEditor.propTypes = {
element: PropTypes.object.isRequired,
onUpdate: PropTypes.func.isRequired,
onValid: PropTypes.func,
attributeFormData: PropTypes.object.isRequired,
state: PropTypes.object.isRequired
};