UNPKG

kitchen-simulator

Version:

It is a kitchen simulator (self-contained micro-frontend).

192 lines (191 loc) 8.76 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _constants = require("../../constants"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _helper = require("../../utils/helper"); var _templateObject; 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); } 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)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var StyledInput = _styledComponents["default"].input(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: block;\n padding: 15px 25px 12px 0px;\n width: 120px;\n color: ", ";\n background-color: rgb(255, 255, 255);\n border: 2px solid;\n text-align: right;\n float: right;\n font-family: ", ";\n font-size: 16px;\n font-weight: 600;\n line-height: 17px;\n border-radius: 5px;\n outline: 0;\n :focus {\n border-color: ", ";\n }\n"])), _constants.TEXT_COLOR_NEUTRAL_0, _constants.DEFAULT_FONT_FAMILY, _constants.SECONDARY_PURPLE_COLOR); var FormNumberInput = exports["default"] = /*#__PURE__*/function (_Component) { function FormNumberInput(props, context) { var _this; (0, _classCallCheck2["default"])(this, FormNumberInput); _this = _callSuper(this, FormNumberInput, [props, context]); _this.state = { focus: false, valid: true, showedValue: props.value, focusOn: false, flag: true }; _this.input = /*#__PURE__*/_react["default"].createRef(null); return _this; } (0, _inherits2["default"])(FormNumberInput, _Component); return (0, _createClass2["default"])(FormNumberInput, [{ key: "componentDidMount", value: function componentDidMount() { if (this.input.current && ['width', 'length'].includes(this.props.labelName.toLowerCase())) { this.input.current.focus(); this.input.current.select(); } } }, { key: "componentWillReceiveProps", value: function componentWillReceiveProps(nextProps) { if (this.props.value !== nextProps.value || this.props.focus !== nextProps.focus) { this.setState({ showedValue: nextProps.value, focusOn: nextProps.focus }); } } }, { key: "componentDidUpdate", value: function componentDidUpdate(prevProps, preprevState) { if (this.props.value !== prevProps.value && prevProps.labelName !== 'Ceiling Height') { this.input.current.focus(); this.input.current.select(); } var showedValue = this.state.showedValue; var _this$props = this.props, min = _this$props.min, max = _this$props.max, isCeiling = _this$props.isCeiling; if (!isCeiling) { if ((0, _helper.isValidNumber)(min) && showedValue < min) { this.setState({ showedValue: min }); } else if ((0, _helper.isValidNumber)(max) && showedValue > max) { this.setState({ showedValue: max }); } } return null; } }, { key: "render", value: function render() { var _this2 = this; var _this$props2 = this.props, value = _this$props2.value, min = _this$props2.min, max = _this$props2.max, precision = _this$props2.precision, onChange = _this$props2.onChange, onValid = _this$props2.onValid, onInvalid = _this$props2.onInvalid, style = _this$props2.style, placeholder = _this$props2.placeholder, isCeiling = _this$props2.isCeiling; var regexp = new RegExp("^-?([0-9]+)?\\.?([0-9]{0,".concat(precision, "})?$")); var currValue = regexp.test(this.state.showedValue) ? this.state.showedValue : parseFloat(this.state.showedValue).toFixed(precision); var different = parseFloat(this.props.value).toFixed(precision) !== parseFloat(this.state.showedValue).toFixed(precision); var saveFn = function saveFn(e) { e.stopPropagation(); if (_this2.state.valid) { var savedValue = _this2.state.showedValue !== '' && _this2.state.showedValue !== '-' ? parseFloat(_this2.state.showedValue) : 0; _this2.setState({ showedValue: savedValue }); onChange({ target: { value: savedValue } }); } }; return /*#__PURE__*/_react["default"].createElement(StyledInput, { id: "form_number_input", autoFocus: this.state.focusOn, readOnly: !!this.props.disabled, type: "text", value: currValue, style: style, onChange: function onChange(evt) { _this2.context.projectActions.copyProperties('ddddd'); var valid = regexp.test(evt.nativeEvent.target.value); if (valid) { _this2.setState({ showedValue: evt.nativeEvent.target.value, flag: false }); if (onValid) onValid(evt.nativeEvent); } else { if (onInvalid) onInvalid(evt.nativeEvent); } _this2.setState({ valid: valid }); }, onFocus: function onFocus(e) { return _this2.setState({ focusOn: true }); }, onBlur: function onBlur(e) { return _this2.setState({ focusOn: false }); }, ref: this.input, onKeyDown: function onKeyDown(e) { var keyCode = e.keyCode || e.which; if (keyCode == _constants.KEYBOARD_BUTTON_CODE.ENTER || keyCode == _constants.KEYBOARD_BUTTON_CODE.TAB) { saveFn(e); _this2.input.current.blur(); } if (keyCode == _constants.KEYBOARD_BUTTON_CODE.ESC) { _this2.context.projectActions.rollback(); } }, placeholder: placeholder }); } }]); }(_react.Component); FormNumberInput.propTypes = { value: _propTypes["default"].oneOfType([_propTypes["default"].number, _propTypes["default"].string]), style: _propTypes["default"].object, onChange: _propTypes["default"].func.isRequired, onValid: _propTypes["default"].func, onInvalid: _propTypes["default"].func, min: _propTypes["default"].number, max: _propTypes["default"].number, precision: _propTypes["default"].number, placeholder: _propTypes["default"].string, labelName: _propTypes["default"].string, isCeiling: _propTypes["default"].string }; FormNumberInput.contextTypes = { translator: _propTypes["default"].object.isRequired, projectActions: _propTypes["default"].object.isRequired, linesActions: _propTypes["default"].object.isRequired }; FormNumberInput.defaultProps = { value: 0, style: {}, min: Number.MIN_SAFE_INTEGER, max: Number.MAX_SAFE_INTEGER, precision: 2, disabled: false, labelName: 'default' }; module.exports = exports.default;