tdesign-vue-next
Version:
TDesign Component for vue-next
80 lines (72 loc) • 3.46 kB
JavaScript
/**
* tdesign v1.11.5
* (c) 2025 tdesign
* @license MIT
*/
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var _slicedToArray = require('@babel/runtime/helpers/slicedToArray');
var Vue = require('vue');
var format = require('../../_chunks/dep-497b9bf8.js');
var hooks_useVModel = require('../../hooks/useVModel.js');
require('dayjs');
require('../../_chunks/dep-30fb1b25.js');
require('../../_chunks/dep-cef23b69.js');
require('../../_chunks/dep-b8b9c2a3.js');
require('../../_chunks/dep-bbe343d7.js');
require('@babel/runtime/helpers/typeof');
require('../../_chunks/dep-5ad8a2ab.js');
require('../../_chunks/dep-0c2ad01b.js');
require('../../_chunks/dep-76218bd8.js');
require('../../_chunks/dep-acb090bf.js');
require('../../_chunks/dep-e495f218.js');
require('../../_chunks/dep-bafc1f63.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_slicedToArray);
function useSingleValue(props) {
var _value$value, _value$value2, _value$value3, _value$value4;
var _toRefs = Vue.toRefs(props),
valueFromProps = _toRefs.value,
modelValue = _toRefs.modelValue;
var _useVModel = hooks_useVModel["default"](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,
enableTimePicker: props.multiple ? false : 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"));
}
var time = Vue.ref(format.formatTime(props.multiple ? (_value$value = value.value) === null || _value$value === void 0 ? void 0 : _value$value[0] : value.value, formatRef.value.format, formatRef.value.timeFormat, props.defaultTime));
var month = Vue.ref(format.parseToDayjs(props.multiple ? (_value$value2 = value.value) === null || _value$value2 === void 0 ? void 0 : _value$value2[0] : value.value, formatRef.value.format).month());
var year = Vue.ref(format.parseToDayjs(props.multiple ? (_value$value3 = value.value) === null || _value$value3 === void 0 ? void 0 : _value$value3[0] : value.value, formatRef.value.format).year());
var cacheValue = Vue.ref(format.formatDate(props.multiple ? (_value$value4 = value.value) === null || _value$value4 === void 0 ? void 0 : _value$value4[0] : value.value, {
format: formatRef.value.format
}));
Vue.watchEffect(function () {
if (!value.value) {
cacheValue.value = "";
return;
}
if (!format.isValidDate(value.value, formatRef.value.format)) return;
cacheValue.value = format.formatDate(value.value, {
format: formatRef.value.format
});
time.value = format.formatTime(value.value, formatRef.value.format, formatRef.value.timeFormat, props.defaultTime);
});
return {
year: year,
month: month,
value: value,
time: time,
cacheValue: cacheValue,
onChange: onChange
};
}
exports.useSingleValue = useSingleValue;
//# sourceMappingURL=useSingleValue.js.map