UNPKG

@fe6/water-pro

Version:

An enterprise-class UI design language and Vue-based implementation

572 lines (483 loc) 20.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _vue = require("vue"); var _moment = _interopRequireDefault(require("moment")); var _RangeCalendar = _interopRequireDefault(require("../vc-calendar/src/RangeCalendar")); var _Panel = _interopRequireDefault(require("../vc-time-picker/Panel")); var _Picker = _interopRequireDefault(require("../vc-calendar/src/Picker")); var _classNames4 = _interopRequireDefault(require("../_util/classNames")); var _shallowequal = _interopRequireDefault(require("../_util/shallowequal")); var _CloseCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CloseCircleFilled")); var _tag = _interopRequireDefault(require("../tag")); var _configProvider = require("../config-provider"); var _interopDefault = _interopRequireDefault(require("../_util/interopDefault")); var _propsUtil = require("../_util/props-util"); var _BaseMixin = _interopRequireDefault(require("../_util/BaseMixin")); var _utils = require("./utils"); var _InputIcon = _interopRequireDefault(require("./InputIcon")); var _util = require("../_util/util"); var _initDefaultProps = _interopRequireDefault(require("../_util/props-util/initDefaultProps")); var _props = require("./props"); var _shared = require("@fe6/shared"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _extends() { _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; }; return _extends.apply(this, arguments); } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_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"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } function getShowDateFromValue(value, valueFormat) { var _value = _slicedToArray(value, 2), start = _value[0], end = _value[1]; // value could be an empty array, then we should not reset showDate if (!start && !end) { return; } var newStart = typeof start === 'string' ? (0, _moment.default)(start, valueFormat) : start; var newEnd = typeof end === 'string' ? (0, _moment.default)(end, valueFormat) : end; return [newStart, newEnd]; } function pickerValueAdapter(value) { if (!value) { return; } if (Array.isArray(value)) { return value; } return [value, value.clone().add(1, 'month')]; } function isEmptyArray(arr) { if (Array.isArray(arr)) { return arr.length === 0 || arr.every(function (i) { return !i; }); } return false; } function fixLocale(value, localeCode) { if (!localeCode) { return; } if (!value || value.length === 0) { return; } var _value2 = _slicedToArray(value, 2), start = _value2[0], end = _value2[1]; if (start) { start.locale(localeCode); } if (end) { end.locale(localeCode); } } function getColumns(_ref) { var showHour = _ref.showHour, showMinute = _ref.showMinute, showSecond = _ref.showSecond, use12Hours = _ref.use12Hours; var column = 0; if (showHour) { column += 1; } if (showMinute) { column += 1; } if (showSecond) { column += 1; } if (use12Hours) { column += 1; } return column; } var _default2 = (0, _vue.defineComponent)({ name: 'ATimeRangePicker', mixins: [_BaseMixin.default], inheritAttrs: false, // props: initDefaultProps(RangePickerGroupProps, { // allowClear: true, // showToday: false, // }), props: (0, _initDefaultProps.default)((0, _props.TimeRangePickerProps)(), { align: { offset: [0, -2] }, disabled: false, disabledHours: undefined, disabledMinutes: undefined, disabledSeconds: undefined, hideDisabledOptions: false, placement: 'bottomLeft', transitionName: 'slide-up', focusOnOpen: true, allowClear: true, format: 'HH:mm:ss', valueFormat: 'HH:mm:ss', separator: '~' }), emits: ['update:value', 'ok', 'mouseleave', 'mouseenter', 'update:open', 'change', 'openChange', 'focus', 'blur', 'keydown'], setup: function setup() { return { configProvider: (0, _vue.inject)('configProvider', _configProvider.defaultConfigProvider), picker: null, sTagPrefixCls: undefined, sPrefixCls: '' }; }, data: function data() { var value = this.value || this.defaultValue || []; var pickerValue = !value || isEmptyArray(value) ? this.defaultPickerValue : value; return { sValue: value, sShowDate: pickerValueAdapter(pickerValue || (0, _interopDefault.default)(_moment.default)()), sOpen: this.open, sHoverValue: [] }; }, watch: { value: function value(val) { var value = val || []; var state = { sValue: value }; if (!(0, _shallowequal.default)(val, this.sValue)) { state = _extends(_extends({}, state), { sShowDate: getShowDateFromValue(value, this.valueFormat) || this.sShowDate }); } this.setState(state); }, open: function open(val) { var state = { sOpen: val }; this.setState(state); }, sOpen: function sOpen(val, oldVal) { var _this = this; (0, _vue.nextTick)(function () { if (!(0, _propsUtil.hasProp)(_this, 'open') && oldVal && !val) { _this.focus(); } }); } }, methods: { setValue: function setValue(value, hidePanel) { this.handleChange(value); if (hidePanel && !(0, _propsUtil.hasProp)(this, 'open')) { this.setState({ sOpen: false }); } }, savePicker: function savePicker(node) { this.picker = node; }, clearSelection: function clearSelection(e) { e.preventDefault(); e.stopPropagation(); this.setState({ sValue: [] }); this.handleChange([]); }, clearHoverValue: function clearHoverValue() { this.setState({ sHoverValue: [] }); }, handleChange: function handleChange(value) { var _this2 = this; if (!(0, _propsUtil.hasProp)(this, 'value')) { this.setState(function (_ref2) { var sShowDate = _ref2.sShowDate; return { sValue: value, sShowDate: getShowDateFromValue(value, _this2.valueFormat) || sShowDate }; }); } if (value[0] && value[1] && value[0].diff(value[1]) > 0) { value[1] = undefined; } var _value3 = _slicedToArray(value, 2), start = _value3[0], end = _value3[1]; var formatValues = value.length ? [(0, _utils.formatDate)(start, this.valueFormat), (0, _utils.formatDate)(end, this.valueFormat)] : value; this.$emit('change', formatValues, value); this.$emit('update:value', formatValues); }, handleOpenChange: function handleOpenChange(open) { if (!(0, _propsUtil.hasProp)(this, 'open')) { this.setState({ sOpen: open }); } if (open === false) { this.clearHoverValue(); } this.$emit('openChange', open); }, handleShowDateChange: function handleShowDateChange(showDate) { this.setState({ sShowDate: showDate }); }, handleHoverChange: function handleHoverChange(hoverValue) { this.setState({ sHoverValue: hoverValue }); }, handleRangeMouseLeave: function handleRangeMouseLeave() { if (this.sOpen) { this.clearHoverValue(); } }, handleCalendarInputSelect: function handleCalendarInputSelect(value) { var _this3 = this; var _value4 = _slicedToArray(value, 1), start = _value4[0]; if (!start) { return; } this.setState(function (_ref3) { var sShowDate = _ref3.sShowDate; return { sValue: value, sShowDate: getShowDateFromValue(value, _this3.valueFormat) || sShowDate }; }); }, handleRangeClick: function handleRangeClick(value) { if (typeof value === 'function') { value = value(); } this.setValue(value, true); this.$emit('ok', value); this.$emit('openChange', false); }, onMouseEnter: function onMouseEnter(e) { this.$emit('mouseenter', e); }, onMouseLeave: function onMouseLeave(e) { this.$emit('mouseleave', e); }, focus: function focus() { this.picker.focus(); }, blur: function blur() { this.picker.blur(); }, renderFooter: function renderFooter() { var _this4 = this; var ranges = this.ranges, $slots = this.$slots; var prefixCls = this.sPrefixCls, tagPrefixCls = this.sTagPrefixCls; var renderExtraFooter = this.renderExtraFooter || $slots.renderExtraFooter; if (!ranges && !renderExtraFooter) { return null; } var customFooter = renderExtraFooter ? (0, _vue.createVNode)("div", { "class": "".concat(prefixCls, "-footer-extra"), "key": "extra" }, [typeof renderExtraFooter === 'function' ? renderExtraFooter() : renderExtraFooter]) : null; var operations = ranges && Object.keys(ranges).map(function (range) { var value = ranges[range]; var hoverValue = typeof value === 'function' ? value.call(_this4) : value; return (0, _vue.createVNode)(_tag.default, { "key": range, "prefixCls": tagPrefixCls, "color": "blue", "onClick": function onClick() { return _this4.handleRangeClick(value); }, "onMouseenter": function onMouseenter() { return _this4.setState({ sHoverValue: hoverValue }); }, "onMouseleave": _this4.handleRangeMouseLeave }, { default: function _default() { return [range]; } }); }); var rangeNode = operations && operations.length > 0 ? (0, _vue.createVNode)("div", { "class": "".concat(prefixCls, "-footer-extra ").concat(prefixCls, "-range-quick-selector"), "key": "range" }, [operations]) : null; return [rangeNode, customFooter]; } }, render: function render() { var _classNames, _this5 = this, _classNames3; var props = _extends(_extends({}, (0, _propsUtil.getOptionProps)(this)), this.$attrs); var suffixIcon = (0, _propsUtil.getComponent)(this, 'suffixIcon'); suffixIcon = Array.isArray(suffixIcon) ? suffixIcon[0] : suffixIcon; var value = this.sValue, showDate = this.sShowDate, hoverValue = this.sHoverValue, open = this.sOpen, $slots = this.$slots; var customizePrefixCls = props.prefixCls, customizeTagPrefixCls = props.tagPrefixCls, popupStyle = props.popupStyle, disabledDate = props.disabledDate, disabledTime = props.disabledTime, ranges = props.ranges, localeCode = props.localeCode, format = props.format, separator = props.separator, inputReadOnly = props.inputReadOnly, style = props.style, onCalendarChange = props.onCalendarChange, onOk = props.onOk, onBlur = props.onBlur, onFocus = props.onFocus, onPanelChange = props.onPanelChange, customizeInputPrefixCls = props.inputPrefixCls, use12Hours = props.use12Hours; var getPrefixCls = this.configProvider.getPrefixCls; var prefixCls = getPrefixCls('calendar', customizePrefixCls); var tagPrefixCls = getPrefixCls('tag', customizeTagPrefixCls); this.sPrefixCls = prefixCls; this.sTagPrefixCls = tagPrefixCls; var dateRender = props.dateRender || $slots.dateRender; fixLocale(value, localeCode); fixLocale(showDate, localeCode); var calendarClassName = (0, _classNames4.default)((_classNames = {}, _defineProperty(_classNames, "".concat(prefixCls, "-time"), true), _defineProperty(_classNames, "".concat(prefixCls, "-range-with-ranges"), ranges), _classNames)); // 需要选择时间时,点击 ok 时才触发 onChange var pickerChangeHandler = { onChange: this.handleChange }; var calendarProps = { onOk: this.handleChange }; pickerChangeHandler.onChange = function (changedValue) { return _this5.handleChange(changedValue); }; if ('mode' in props) { calendarProps.mode = props.mode; } var startPlaceholder = Array.isArray(props.placeholder) ? props.placeholder[0] : '开始时间'; var endPlaceholder = Array.isArray(props.placeholder) ? props.placeholder[1] : '结束时间'; var vcTimePickerProps = _extends(_extends({}, (0, _utils.generateShowHourMinuteSecond)(format)), { format: format, use12Hours: use12Hours }); var columns = getColumns(vcTimePickerProps); var timePickerCls = "".concat(prefixCls, "-time-picker-column-").concat(columns); var timePickerPanelProps = _extends(_extends({}, vcTimePickerProps), { prefixCls: "".concat(prefixCls, "-time-picker"), placeholder: '请选择时间', transitionName: 'slide-up', class: timePickerCls, onEsc: function onEsc() {} }); var timePicker = (0, _vue.createVNode)(_Panel.default, timePickerPanelProps, null); var rangeCalendarProps = _extends(_extends({}, calendarProps), { separator: separator, format: format, prefixCls: prefixCls, renderFooter: this.renderFooter, timePicker: timePicker, showTimePickerButton: false, disabledDate: disabledDate, disabledTime: disabledTime, dateInputPlaceholder: [startPlaceholder, endPlaceholder], // locale: locale.lang, dateRender: dateRender, value: false, hoverValue: hoverValue, showToday: false, inputReadOnly: inputReadOnly, onChange: onCalendarChange, onOk: onOk, mode: ['time', 'time'], onValueChange: this.handleShowDateChange, onHoverChange: this.handleHoverChange, onPanelChange: onPanelChange, onInputSelect: this.handleCalendarInputSelect, class: calendarClassName }); var calendar = (0, _vue.createVNode)(_RangeCalendar.default, rangeCalendarProps, $slots); // default width for showTime var pickerStyle = {}; pickerStyle.width = '210px'; // const [startValue, endValue] = value; var clearIcon = !props.disabled && props.allowClear && value && value.length > 1 ? (0, _vue.createVNode)(_CloseCircleFilled.default, { "class": "".concat(prefixCls, "-picker-clear"), "onClick": this.clearSelection }, null) : null; var inputIcon = (0, _vue.createVNode)(_InputIcon.default, { "suffixIcon": suffixIcon, "prefixCls": prefixCls }, null); var pickerClass = (0, _classNames4.default)("".concat(prefixCls, "-picker"), _defineProperty({}, "".concat(prefixCls, "-picker-").concat(this.size), !!this.size)); var inputPrefixCls = getPrefixCls('input', customizeInputPrefixCls); var pickerInputClass = (0, _classNames4.default)("".concat(prefixCls, "-picker-input"), inputPrefixCls, (_classNames3 = {}, _defineProperty(_classNames3, "".concat(inputPrefixCls, "-lg"), this.size === 'large'), _defineProperty(_classNames3, "".concat(inputPrefixCls, "-sm"), this.size === 'small'), _defineProperty(_classNames3, "".concat(inputPrefixCls, "-disabled"), this.disabled), _classNames3)); var input = function input(_ref4) { var inputValue = _ref4.value; var _inputValue = _slicedToArray(inputValue, 2), start = _inputValue[0], end = _inputValue[1]; var newStart = start && (0, _shared.isString)(start) ? (0, _moment.default)(start, _this5.valueFormat) : start; var newEnd = end && (0, _shared.isString)(end) ? (0, _moment.default)(end, _this5.valueFormat) : end; return (0, _vue.createVNode)("span", { "class": pickerInputClass }, [(0, _vue.createVNode)("input", { "disabled": props.disabled, "readonly": true, "value": (0, _utils.formatDate)(newStart, props.format), "placeholder": startPlaceholder, "class": "".concat(prefixCls, "-range-picker-input"), "tabindex": -1 }, null), (0, _vue.createVNode)("span", { "class": "".concat(prefixCls, "-range-picker-separator") }, [(0, _vue.createTextVNode)(" "), separator, (0, _vue.createTextVNode)(" ")]), (0, _vue.createVNode)("input", { "disabled": props.disabled, "readonly": true, "value": (0, _utils.formatDate)(newEnd, props.format), "placeholder": endPlaceholder, "class": "".concat(prefixCls, "-range-picker-input"), "tabindex": -1 }, null), clearIcon, inputIcon]); }; var vcDatePickerProps = _extends(_extends(_extends({}, props), pickerChangeHandler), { calendar: calendar, value: (0, _shared.isArray)(value) ? value.map(function (vItem) { return (0, _shared.isString)(vItem) ? (0, _moment.default)(vItem, _this5.valueFormat) : vItem; }) : [], open: open, prefixCls: "".concat(prefixCls, "-picker-container ").concat(prefixCls, "-picker-container-time"), onOpenChange: this.handleOpenChange, style: popupStyle }); return (0, _vue.createVNode)("span", { "class": "".concat(prefixCls, "-range-picker-box") }, [(0, _vue.createVNode)("span", _objectSpread({ "ref": this.savePicker, "id": props.id, "class": (0, _classNames4.default)(props.class ? props.class : '', pickerClass), "style": _extends(_extends({}, pickerStyle), style), "tabindex": props.disabled ? -1 : 0, "onFocus": onFocus, "onBlur": onBlur, "onMouseenter": this.onMouseEnter, "onMouseleave": this.onMouseLeave }, (0, _util.getDataAndAriaProps)(props)), [(0, _vue.createVNode)(_Picker.default, vcDatePickerProps, _extends({ default: input }, $slots))])]); } }); exports.default = _default2;