react-planner-viewer
Version:
react-planner-viewer is a React Component for view plans builded with react-planner in 2D mode
140 lines (119 loc) • 14.1 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; };
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
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; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
import React, { Component } from 'react';
import PropTypes from 'prop-types';
import NumericInput from 'react-numeric-input';
import * as SharedStyle from '../../shared-style';
var STYLE_INPUT = {
display: 'block',
width: '100%',
padding: '0 2px',
fontSize: '13px',
lineHeight: '1.25',
color: '#55595c',
backgroundColor: SharedStyle.COLORS.white,
backgroundImage: 'none',
border: '1px solid rgba(0,0,0,.15)',
outline: 'none',
height: '30px'
};
var FormNumberInput = function (_Component) {
_inherits(FormNumberInput, _Component);
function FormNumberInput(props) {
_classCallCheck(this, FormNumberInput);
var _this = _possibleConstructorReturn(this, (FormNumberInput.__proto__ || Object.getPrototypeOf(FormNumberInput)).call(this, props));
_this.state = { focus: false };
return _this;
}
_createClass(FormNumberInput, [{
key: 'onChangeCustom',
value: function onChangeCustom(valueAsNumber, valueAsString, input) {
if (this.refs.realNumber.refs.input.checkValidity()) {
this.props.onChange({ target: { value: valueAsNumber } });
this.onValidCustom(valueAsNumber, valueAsString);
} else {
this.onInvalidCustom(valueAsNumber, valueAsString);
}
}
}, {
key: 'onValidCustom',
value: function onValidCustom(valueAsNumber, valueAsString) {
if (this.refs.realNumber) this.refs.realNumber.refs.input.style.color = STYLE_INPUT.color;
}
}, {
key: 'onInvalidCustom',
value: function onInvalidCustom(error, valueAsNumber, valueAsString) {
if (this.refs.realNumber) this.refs.realNumber.refs.input.style.color = 'red';
}
}, {
key: 'render',
value: function render() {
var _this2 = this;
var _props = this.props,
value = _props.value,
configs = _props.configs,
onChange = _props.onChange,
onValid = _props.onValid,
style = _props.style,
rest = _objectWithoutProperties(_props, ['value', 'configs', 'onChange', 'onValid', 'style']);
var min = configs.min,
max = configs.max,
precision = configs.precision;
var step = 1 / Math.pow(10, precision);
return React.createElement(NumericInput, {
ref: 'realNumber',
onChange: this.onChangeCustom.bind(this),
onInvalid: this.onInvalidCustom.bind(this),
onInput: function onInput(evt) {
return _this2.refs.realNumber.refs.input.style.color = evt.nativeEvent.target.checkValidity() ? STYLE_INPUT.color : 'red';
},
step: step,
precision: precision,
value: value,
type: 'number',
min: min,
max: max,
pattern: '^-?([0-9]+)\.?([0-9]+)?',
style: {
wrap: { width: '100%' },
input: _extends({}, STYLE_INPUT, style, {
border: this.state.focus ? '1px solid #66afe9' : '1px solid rgba(0,0,0,.15)'
})
},
snap: true
});
}
}]);
return FormNumberInput;
}(Component);
export default FormNumberInput;
FormNumberInput.propTypes = {
value: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
style: PropTypes.object,
onChange: PropTypes.func,
onValid: PropTypes.func,
configs: PropTypes.object
};
FormNumberInput.defaultProps = {
value: 0,
style: {},
onChange: function onChange() {
return console.log('onValid instead');
},
onValid: function onValid() {
return console.log('onValid not defined');
},
onInvalid: function onInvalid() {
return console.log('onInvalid not defined');
},
configs: {
min: Number.MIN_SAFE_INTEGER,
max: Number.MAX_SAFE_INTEGER,
precision: 3
}
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/style/form-number-input.jsx"],"names":["React","Component","PropTypes","NumericInput","SharedStyle","STYLE_INPUT","display","width","padding","fontSize","lineHeight","color","backgroundColor","COLORS","white","backgroundImage","border","outline","height","FormNumberInput","props","state","focus","valueAsNumber","valueAsString","input","refs","realNumber","checkValidity","onChange","target","value","onValidCustom","onInvalidCustom","style","error","configs","onValid","rest","min","max","precision","step","Math","pow","onChangeCustom","bind","evt","nativeEvent","wrap","propTypes","oneOfType","number","string","object","func","defaultProps","console","log","onInvalid","Number","MIN_SAFE_INTEGER","MAX_SAFE_INTEGER"],"mappings":"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","file":"form-number-input.js","sourcesContent":["import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport NumericInput from 'react-numeric-input';\nimport * as SharedStyle from '../../shared-style';\n\nconst STYLE_INPUT = {\n  display: 'block',\n  width: '100%',\n  padding: '0 2px',\n  fontSize: '13px',\n  lineHeight: '1.25',\n  color: '#55595c',\n  backgroundColor: SharedStyle.COLORS.white,\n  backgroundImage: 'none',\n  border: '1px solid rgba(0,0,0,.15)',\n  outline: 'none',\n  height: '30px',\n};\n\nexport default class FormNumberInput extends Component {\n\n  constructor(props) {\n    super(props);\n    this.state = {focus: false};\n  }\n\n  onChangeCustom(valueAsNumber, valueAsString, input) {\n    if( this.refs.realNumber.refs.input.checkValidity() )\n    {\n      this.props.onChange( { target: { value: valueAsNumber } } );\n      this.onValidCustom(valueAsNumber, valueAsString);\n    }\n    else\n    {\n      this.onInvalidCustom(valueAsNumber, valueAsString);\n    }\n  }\n\n  onValidCustom( valueAsNumber, valueAsString ) {\n    if( this.refs.realNumber) this.refs.realNumber.refs.input.style.color = STYLE_INPUT.color;\n\n  }\n\n  onInvalidCustom( error, valueAsNumber, valueAsString ) {\n    if( this.refs.realNumber) this.refs.realNumber.refs.input.style.color = 'red';\n  }\n\n  render() {\n\n    let {value, configs, onChange, onValid, style, ...rest} = this.props;\n    let { min, max, precision } = configs;\n    let step = 1 / Math.pow(10, precision);\n\n    return <NumericInput\n      ref=\"realNumber\"\n      onChange={this.onChangeCustom.bind(this)}\n      onInvalid={this.onInvalidCustom.bind(this)}\n      onInput={(evt) => this.refs.realNumber.refs.input.style.color = evt.nativeEvent.target.checkValidity() ? STYLE_INPUT.color : 'red' }\n      step={step}\n      precision={precision}\n      value={value}\n      type={'number'}\n      min={min}\n      max={max}\n      pattern={'^-?([0-9]+)\\.?([0-9]+)?'}\n      style={\n        {\n          wrap: { width: '100%'},\n          input: {\n            ...STYLE_INPUT,\n            ...style,\n            border: this.state.focus ? '1px solid #66afe9' : '1px solid rgba(0,0,0,.15)'\n          }\n        }\n      }\n      snap\n    />;\n  }\n}\n\nFormNumberInput.propTypes = {\n  value: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n  style: PropTypes.object,\n  onChange: PropTypes.func,\n  onValid: PropTypes.func,\n  configs: PropTypes.object\n};\n\nFormNumberInput.defaultProps = {\n  value: 0,\n  style: {},\n  onChange: () => console.log('onValid instead'),\n  onValid: () => console.log('onValid not defined'),\n  onInvalid: () => console.log('onInvalid not defined'),\n  configs: {\n    min: Number.MIN_SAFE_INTEGER,\n    max: Number.MAX_SAFE_INTEGER,\n    precision: 3\n  }\n};\n"]}