tdesign-vue-next
Version:
TDesign Component for vue-next
140 lines (132 loc) • 5.11 kB
JavaScript
/**
* tdesign v1.19.2
* (c) 2026 tdesign
* @license MIT
*/
;
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-35e23c2b.js');
require('../../config-provider/hooks/useConfig.js');
require('../../_chunks/dep-0989c3be.js');
var index = require('../../_chunks/dep-ce9c15f5.js');
require('@babel/runtime/helpers/defineProperty');
var format = require('../../_chunks/dep-4d6191e3.js');
var isArray = require('../../_chunks/dep-4cb26289.js');
require('../../_chunks/dep-4a7162e7.js');
require('../../_chunks/dep-be1af85d.js');
require('../../_chunks/dep-db9c85b1.js');
require('dayjs');
require('../../_chunks/dep-82fe2026.js');
require('../../_chunks/dep-33b46a52.js');
require('../../_chunks/dep-930a2de5.js');
require('../../_chunks/dep-2dcf9237.js');
require('../../_chunks/dep-22dc294c.js');
require('../../_chunks/dep-bf76dead.js');
require('../../_chunks/dep-c3bbd06c.js');
require('../../_chunks/dep-6d87f74d.js');
require('../../_chunks/dep-281f7eb2.js');
require('../../_chunks/dep-f8f7b1af.js');
require('../../_chunks/dep-66d3f30f.js');
require('../../_chunks/dep-e1d22111.js');
require('../../_chunks/dep-754c0523.js');
require('../../_chunks/dep-7076a08a.js');
require('../../_chunks/dep-631750cd.js');
require('../../_chunks/dep-2fc884aa.js');
require('../../_chunks/dep-75d6da05.js');
require('../../_chunks/dep-274369eb.js');
require('../../_chunks/dep-df6e14a0.js');
require('@babel/runtime/helpers/createClass');
require('@babel/runtime/helpers/classCallCheck');
require('../../_chunks/dep-9f98bf9b.js');
require('../../_chunks/dep-b2024592.js');
require('../../_chunks/dep-2fb8d44f.js');
require('../../_chunks/dep-80a41429.js');
require('../../_chunks/dep-484d5d62.js');
require('../../_chunks/dep-692bdebe.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),
value = _useVModel2[0],
onChange = _useVModel2[1];
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 (!isArray.isArray(value.value)) {
console.error("typeof value: ".concat(value.value, " must be Array!"));
} else if (!format.isValidDate(value.value, formatRef.value.format)) {
console.error("value: ".concat(value.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 (!newValue) {
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,
onChange: onChange
};
}
exports.useRangeValue = useRangeValue;
//# sourceMappingURL=useRangeValue.js.map