reactjs-query-builder
Version:
204 lines (162 loc) • 9.2 kB
JavaScript
'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;