UNPKG

@aliretail/react-materials-components

Version:
142 lines (112 loc) 5.94 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = true; exports["default"] = void 0; var _numberPicker = _interopRequireDefault(require("@alifd/next/lib/number-picker")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose")); var React = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _lodash = _interopRequireDefault(require("lodash")); function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } var RangeNumberPicker = /*#__PURE__*/function (_React$Component) { (0, _inheritsLoose2["default"])(RangeNumberPicker, _React$Component); function RangeNumberPicker() { var _this; for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this; _this.onFirstChange = function (value) { var _this$props = _this.props, oldValue = _this$props.value, onChange = _this$props.onChange; onChange([value, oldValue[1]]); }; _this.onSecondChange = function (value) { var _this$props2 = _this.props, oldValue = _this$props2.value, onChange = _this$props2.onChange; onChange([oldValue[0], value]); }; return _this; } var _proto = RangeNumberPicker.prototype; _proto.getSecNumMin = function getSecNumMin() { var _this$props3 = this.props, notConstrain = _this$props3.notConstrain, secondNumberPickerProps = _this$props3.secondNumberPickerProps, value = _this$props3.value; var firstNum = value === null || value === void 0 ? void 0 : value[0]; var secNumMin = secondNumberPickerProps === null || secondNumberPickerProps === void 0 ? void 0 : secondNumberPickerProps.min; // 如果是受到约束的话 最小值为设置的min和第一个值的最小值 if (!notConstrain && firstNum) { if (typeof secNumMin !== 'number' || secNumMin < firstNum) { return firstNum; } } return secNumMin; }; _proto.getFirNumMax = function getFirNumMax() { var _this$props4 = this.props, notConstrain = _this$props4.notConstrain, secondNumberPickerProps = _this$props4.secondNumberPickerProps, value = _this$props4.value; var SecNum = value === null || value === void 0 ? void 0 : value[1]; var firNumMax = secondNumberPickerProps === null || secondNumberPickerProps === void 0 ? void 0 : secondNumberPickerProps.max; // 如果是受到约束的话 最小值为设置的min和第一个值的最小值 if (!notConstrain && SecNum) { if (typeof firNumMax !== 'number' || SecNum < firNumMax) { return SecNum; } } return firNumMax; }; _proto.render = function render() { var _cx; var _this$props5 = this.props, value = _this$props5.value, className = _this$props5.className, style = _this$props5.style, prefixText = _this$props5.prefixText, suffixText = _this$props5.suffixText, betweenText = _this$props5.betweenText, firstNumberPickerProps = _this$props5.firstNumberPickerProps, secondNumberPickerProps = _this$props5.secondNumberPickerProps; var otherProps = _lodash["default"].omit(this.props, ['value', 'onChange', 'className', 'style', 'firstNumberPickerProps', 'secondNumberPickerProps', 'notConstrain']); var classes = (0, _classnames["default"])((_cx = { 'aliretail-range-number-picker': true }, _cx[className] = !!className, _cx)); var firNum = value[0], secNum = value[1]; return /*#__PURE__*/React.createElement("div", { className: classes, style: style }, prefixText, /*#__PURE__*/React.createElement(_numberPicker["default"], (0, _extends2["default"])({ value: firNum, onChange: this.onFirstChange }, otherProps, firstNumberPickerProps, { max: this.getFirNumMax() })), /*#__PURE__*/React.createElement("span", { className: "split-char" }, betweenText), /*#__PURE__*/React.createElement(_numberPicker["default"], (0, _extends2["default"])({ value: secNum, onChange: this.onSecondChange }, otherProps, secondNumberPickerProps, { min: this.getSecNumMin() })), suffixText); }; return RangeNumberPicker; }(React.Component); RangeNumberPicker.defaultProps = { value: [], className: '', style: {}, prefixText: '', suffixText: '', betweenText: '-', notConstrain: false, firstNumberPickerProps: {}, secondNumberPickerProps: {} }; var _default = RangeNumberPicker; exports["default"] = _default;