UNPKG

reactjs-query-builder

Version:
204 lines (162 loc) 9.2 kB
'use strict'; exports.__esModule = true; exports.default = undefined; var _slider = require('antd/lib/slider'); var _slider2 = _interopRequireDefault(_slider); var _col = require('antd/lib/col'); var _col2 = _interopRequireDefault(_col); var _inputNumber = require('antd/lib/input-number'); var _inputNumber2 = _interopRequireDefault(_inputNumber); 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 _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); 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; }; }(); var _class, _temp2; require('antd/lib/slider/style/css'); require('antd/lib/col/style/css'); require('antd/lib/input-number/style/css'); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _reactDom = require('react-dom'); var _reactDom2 = _interopRequireDefault(_reactDom); require('antd/lib/date-picker/style'); var _configUtils = require('../../utils/configUtils'); var _reactAddonsShallowCompare = require('react-addons-shallow-compare'); var _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } 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; } var RangeWidget = (_temp2 = _class = function (_Component) { _inherits(RangeWidget, _Component); function RangeWidget() { var _ref; var _temp, _this, _ret; _classCallCheck(this, RangeWidget); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = RangeWidget.__proto__ || Object.getPrototypeOf(RangeWidget)).call.apply(_ref, [this].concat(args))), _this), _this.state = {}, _this.shouldComponentUpdate = _reactAddonsShallowCompare2.default, _this.handleChange = function (value) { _this.props.setValue(value); }, _this.handleChangeFrom = function (valueFrom) { var value = _this.props.value || [undefined, undefined]; value = [].concat(_toConsumableArray(value)); value[0] = valueFrom; if (value[1] == undefined) value[1] = valueFrom; _this.props.setValue(value); }, _this.handleChangeTo = function (valueTo) { var value = _this.props.value || [undefined, undefined]; value = [].concat(_toConsumableArray(value)); value[1] = valueTo; if (value[0] == undefined) value[0] = valueTo; _this.props.setValue(value); }, _this.defaultProps = { min: 0, max: 100, step: 10 }, _temp), _possibleConstructorReturn(_this, _ret); } _createClass(RangeWidget, [{ key: 'render', value: function render() { var fieldDefinition = (0, _configUtils.getFieldConfig)(this.props.field, this.props.config); var fieldSettings = fieldDefinition.fieldSettings || {}; var customProps = this.props.customProps || {}; var value = this.props.value != undefined ? this.props.value : undefined; var _ref2 = value || [null, null], _ref3 = _slicedToArray(_ref2, 2), valueFrom = _ref3[0], valueTo = _ref3[1]; var min = fieldSettings.min === null ? this.defaultProps.min : fieldSettings.min; var max = fieldSettings.max === null ? this.defaultProps.max : fieldSettings.max; var step = fieldSettings.step === undefined ? this.defaultProps.step : fieldSettings.step; var marks = fieldSettings.marks === undefined ? this.defaultProps.marks : fieldSettings.marks; if (value && (valueFrom == undefined || valueTo == undefined)) { // happens if we change value source - this leads to incomplete slider value, fix it: if (valueFrom == undefined) this.handleChangeTo(valueTo); if (valueTo == undefined) this.handleChangeFrom(valueFrom); return null; } return _react2.default.createElement( _col2.default, { style: { display: 'inline-flex' } }, _react2.default.createElement( _col2.default, { style: { float: 'left', marginRight: '5px' } }, _react2.default.createElement(_inputNumber2.default, _extends({ size: this.props.config.settings.renderSize || "small", ref: 'numFrom', key: 'numFrom', value: valueFrom, min: min, max: max, step: step, placeholder: this.props.placeholders[0], onChange: this.handleChangeFrom }, customProps)) ), _react2.default.createElement( _col2.default, { style: { float: 'left', marginRight: '5px', lineHeight: '20px' } }, _react2.default.createElement( 'span', null, this.props.textSeparators[1] ) ), _react2.default.createElement( _col2.default, { style: { float: 'left', marginRight: '5px' } }, _react2.default.createElement(_inputNumber2.default, _extends({ size: this.props.config.settings.renderSize || "small", ref: 'numTo', key: 'numTo', value: valueTo, min: min, max: max, marks: marks, step: step, placeholder: this.props.placeholders[1], onChange: this.handleChangeTo }, customProps)) ), _react2.default.createElement( _col2.default, { style: { float: 'left', width: customProps.width || '300px' } }, _react2.default.createElement(_slider2.default, _extends({ ref: 'slider', value: value, tipFormatter: function tipFormatter(val) { return val != undefined ? val.toString() : ''; }, min: min, max: max, step: step, marks: marks, included: false, range: true //placeholder={this.props.placeholder} , onChange: this.handleChange }, customProps)) ), _react2.default.createElement(_col2.default, { style: { clear: 'both' } }) ); } }]); return RangeWidget; }(_react.Component), _class.propTypes = { setValue: _propTypes2.default.func.isRequired, min: _propTypes2.default.number, max: _propTypes2.default.number, step: _propTypes2.default.number, placeholder: _propTypes2.default.string, placeholders: _propTypes2.default.array, textSeparators: _propTypes2.default.array, config: _propTypes2.default.object.isRequired, field: _propTypes2.default.string.isRequired, value: _propTypes2.default.array, customProps: _propTypes2.default.object }, _temp2); exports.default = RangeWidget;