UNPKG

tdesign-vue-next

Version:
143 lines (135 loc) 5.23 kB
/** * tdesign v1.20.3 * (c) 2026 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); var Vue = require('vue'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); require('../../_chunks/dep-2c21b252.js'); require('../../config-provider/hooks/useConfig.js'); require('../../_chunks/dep-c786fc66.js'); var index = require('../../_chunks/dep-45471156.js'); require('@babel/runtime/helpers/defineProperty'); var format = require('../../_chunks/dep-b2ba9870.js'); require('../../_chunks/dep-ce131a62.js'); require('../../_chunks/dep-f13dc940.js'); require('../../_chunks/dep-dc718ec7.js'); require('dayjs'); require('../../_chunks/dep-e1852b70.js'); require('../../_chunks/dep-d0ba8f3b.js'); require('../../_chunks/dep-34ae74be.js'); require('../../_chunks/dep-f8f6dc81.js'); require('../../_chunks/dep-2e72c048.js'); require('../../_chunks/dep-c1906837.js'); require('../../_chunks/dep-820ea949.js'); require('../../_chunks/dep-5ce4c94e.js'); require('../../_chunks/dep-38abd3cd.js'); require('../../_chunks/dep-48f8bd7a.js'); require('../../_chunks/dep-9488062b.js'); require('../../_chunks/dep-6475bea6.js'); require('../../_chunks/dep-53a0e29c.js'); require('../../_chunks/dep-ab3db94c.js'); require('../../_chunks/dep-577d39b3.js'); require('../../_chunks/dep-50880721.js'); require('../../_chunks/dep-00b0ff32.js'); require('../../_chunks/dep-5bcb760f.js'); require('../../_chunks/dep-bf13d379.js'); require('../../_chunks/dep-95fe29fa.js'); require('@babel/runtime/helpers/createClass'); require('@babel/runtime/helpers/classCallCheck'); require('../../_chunks/dep-8a60b761.js'); require('../../_chunks/dep-fec8a710.js'); require('../../_chunks/dep-a0c4328d.js'); require('../../_chunks/dep-0bba6d5f.js'); require('../../_chunks/dep-1cd1a179.js'); require('../../_chunks/dep-e4a2ed74.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_slicedToArray); function useRangeValue(props) { var _toRefs = Vue.toRefs(props), valueFromProps = _toRefs.value, modelValue = _toRefs.modelValue; var _useVModel = index.useVModel(valueFromProps, modelValue, props.defaultValue, props.onChange), _useVModel2 = _slicedToArray__default["default"](_useVModel, 2), rawValue = _useVModel2[0], onRawChange = _useVModel2[1]; var value = Vue.computed(function () { return Array.isArray(rawValue.value) ? rawValue.value : []; }); var formatRef = Vue.computed(function () { return format.getDefaultFormat({ mode: props.mode, format: props.format, valueType: props.valueType, enableTimePicker: props.enableTimePicker }); }); if (props.enableTimePicker) { if (!format.extractTimeFormat(formatRef.value.format)) console.error("format: ".concat(formatRef.value.format, " \u4E0D\u89C4\u8303\uFF0C\u5305\u542B\u65F6\u95F4\u9009\u62E9\u5FC5\u987B\u8981\u6709\u65F6\u95F4\u683C\u5F0F\u5316 HH:mm:ss")); } if (!Array.isArray(rawValue.value)) { console.error("typeof value: ".concat(rawValue.value, " must be Array!")); } else if (!format.isValidDate(rawValue.value, formatRef.value.format)) { console.error("value: ".concat(rawValue.value, " is invalid dateTime! Check whether the value is consistent with format: ").concat(formatRef.value.format)); } var isFirstValueSelected = Vue.ref(false); var time = Vue.ref(format.initYearMonthTime({ value: value.value, mode: props.mode, format: formatRef.value.format, timeFormat: formatRef.value.timeFormat }).time); var month = Vue.ref(format.initYearMonthTime({ value: value.value, mode: props.mode, format: formatRef.value.format, enableTimePicker: props.enableTimePicker }).month); var year = Vue.ref(format.initYearMonthTime({ value: value.value, mode: props.mode, format: formatRef.value.format }).year); var cacheValue = Vue.ref(format.formatDate(value.value, { format: formatRef.value.format })); Vue.watch(function () { return isFirstValueSelected.value; }, function () { if (year.value[1] < year.value[0]) { year.value[1] = year.value[0]; } if (year.value[0] === year.value[1] && month.value[1] < month.value[0]) { month.value[1] = month.value[0]; } }); Vue.watch(value, function (newValue) { if (!rawValue.value) { cacheValue.value = []; return; } if (!format.isValidDate(newValue, formatRef.value.format)) return; cacheValue.value = format.formatDate(newValue, { format: formatRef.value.valueType, targetFormat: formatRef.value.format }); time.value = format.formatTime(newValue, formatRef.value.format, formatRef.value.timeFormat, props.defaultTime); }, { immediate: true }); return { year: year, month: month, value: value, time: time, isFirstValueSelected: isFirstValueSelected, cacheValue: cacheValue, onRawChange: onRawChange }; } exports.useRangeValue = useRangeValue; //# sourceMappingURL=useRangeValue.js.map