tdesign-vue-next
Version:
TDesign Component for vue-next
116 lines (112 loc) • 4.12 kB
JavaScript
/**
* tdesign v1.20.2
* (c) 2026 tdesign
* @license MIT
*/
import { _ as _slicedToArray } from '../../_chunks/dep-ea5fbe21.mjs';
import { toRefs, computed, ref, watch } from 'vue';
import { j as useVModel } from '../../_chunks/dep-9ce910b6.mjs';
import { g as getDefaultFormat, e as extractTimeFormat, b as isValidDate, i as initYearMonthTime, f as formatDate, a as formatTime } from '../../_chunks/dep-6eb7ecfc.mjs';
import '../../_chunks/dep-26d65784.mjs';
import 'lodash-es';
import '../../_chunks/dep-557b68dd.mjs';
import '../../_chunks/dep-f038e2b4.mjs';
import '../../_chunks/dep-05bddb06.mjs';
import '../../_chunks/dep-57027bda.mjs';
import '../../config-provider/hooks/useConfig.mjs';
import '../../config-provider/utils/context.mjs';
import '../../_chunks/dep-57949dcd.mjs';
import '../../_chunks/dep-cafb5eac.mjs';
import '../../_chunks/dep-f1da7269.mjs';
import '../../_chunks/dep-192d0c88.mjs';
import '../../_chunks/dep-652c99fe.mjs';
import '../../_chunks/dep-5b369203.mjs';
import '../../_chunks/dep-a4f55e3b.mjs';
import '../../_chunks/dep-98dac781.mjs';
import '../../_chunks/dep-920eff5b.mjs';
import '../../_chunks/dep-b8f28b6e.mjs';
import '../../_chunks/dep-73946420.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