UNPKG

tdesign-vue-next

Version:
116 lines (112 loc) 4.12 kB
/** * tdesign v1.20.3 * (c) 2026 tdesign * @license MIT */ import { _ as _slicedToArray } from '../../_chunks/dep-ff183185.mjs'; import { toRefs, computed, ref, watch } from 'vue'; import { j as useVModel } from '../../_chunks/dep-5975d369.mjs'; import { g as getDefaultFormat, e as extractTimeFormat, b as isValidDate, i as initYearMonthTime, f as formatDate, a as formatTime } from '../../_chunks/dep-ce5b44b1.mjs'; import '../../_chunks/dep-390963eb.mjs'; import 'lodash-es'; import '../../_chunks/dep-adf8ce39.mjs'; import '../../_chunks/dep-d84a2ec7.mjs'; import '../../_chunks/dep-12b4e978.mjs'; import '../../_chunks/dep-0841ee8f.mjs'; import '../../config-provider/hooks/useConfig.mjs'; import '../../config-provider/utils/context.mjs'; import '../../_chunks/dep-cf105282.mjs'; import '../../_chunks/dep-dcbc09c5.mjs'; import '../../_chunks/dep-9fc6972b.mjs'; import '../../_chunks/dep-a1cbfaae.mjs'; import '../../_chunks/dep-3f53eff0.mjs'; import '../../_chunks/dep-4c65e11b.mjs'; import '../../_chunks/dep-46776e3b.mjs'; import '../../_chunks/dep-07d8f2aa.mjs'; import '../../_chunks/dep-8aebe545.mjs'; import '../../_chunks/dep-c05afcc8.mjs'; import '../../_chunks/dep-ad9e539e.mjs'; function useRangeValue(props) { var _toRefs = toRefs(props), valueFromProps = _toRefs.value, modelValue = _toRefs.modelValue; var _useVModel = useVModel(valueFromProps, modelValue, props.defaultValue, props.onChange), _useVModel2 = _slicedToArray(_useVModel, 2), rawValue = _useVModel2[0], onRawChange = _useVModel2[1]; var value = computed(function () { return Array.isArray(rawValue.value) ? rawValue.value : []; }); var formatRef = computed(function () { return getDefaultFormat({ mode: props.mode, format: props.format, valueType: props.valueType, enableTimePicker: props.enableTimePicker }); }); if (props.enableTimePicker) { if (!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 (!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 = ref(false); var time = ref(initYearMonthTime({ value: value.value, mode: props.mode, format: formatRef.value.format, timeFormat: formatRef.value.timeFormat }).time); var month = ref(initYearMonthTime({ value: value.value, mode: props.mode, format: formatRef.value.format, enableTimePicker: props.enableTimePicker }).month); var year = ref(initYearMonthTime({ value: value.value, mode: props.mode, format: formatRef.value.format }).year); var cacheValue = ref(formatDate(value.value, { format: formatRef.value.format })); 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]; } }); watch(value, function (newValue) { if (!rawValue.value) { cacheValue.value = []; return; } if (!isValidDate(newValue, formatRef.value.format)) return; cacheValue.value = formatDate(newValue, { format: formatRef.value.valueType, targetFormat: formatRef.value.format }); time.value = 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 }; } export { useRangeValue }; //# sourceMappingURL=useRangeValue.mjs.map