xdesign-vue-next
Version:
XDesign Component for vue-next
87 lines (83 loc) • 3.31 kB
JavaScript
/**
* xdesign v1.0.6
* (c) 2023 xdesign
* @license MIT
*/
import { _ as _slicedToArray } from '../../_chunks/dep-32d4c595.mjs';
import { toRefs, computed, ref, watchEffect } from 'vue';
import { getDefaultFormat, formatTime, parseToDayjs, formatDate, isValidDate } from '../../_common/js/date-picker/format.mjs';
import useVModel from '../../hooks/useVModel.mjs';
import { extractTimeFormat } from '../../_common/js/date-picker/utils.mjs';
import '../../_chunks/dep-89b966f4.mjs';
import '../../_chunks/dep-11fa9c2c.mjs';
import '../../_chunks/dep-10a947a6.mjs';
import '../../_chunks/dep-b75d8d74.mjs';
import '../../_chunks/dep-82805301.mjs';
import '../../_chunks/dep-a95026f2.mjs';
import '../../_chunks/dep-068e912d.mjs';
import '../../_chunks/dep-addc2a84.mjs';
import '../../_chunks/dep-6fe15f5a.mjs';
import '../../_common/js/log/index.mjs';
import '../../_common/js/log/log.mjs';
import '../../_chunks/dep-f9e836af.mjs';
import '../../_chunks/dep-1cc1c24f.mjs';
import '../../_chunks/dep-6ad18815.mjs';
import '../../_chunks/dep-1671cde7.mjs';
import '../../_chunks/dep-e727a519.mjs';
import '../../_chunks/dep-7dcfa37a.mjs';
import '../../_chunks/dep-765678ef.mjs';
import '../../_chunks/dep-a666b9ad.mjs';
import '../../_chunks/dep-7f239c43.mjs';
import '../../_chunks/dep-0e832fc7.mjs';
import '../../_chunks/dep-5755c21c.mjs';
import '../../_chunks/dep-e1ab85c5.mjs';
import '../../_chunks/dep-71f84cf2.mjs';
import '../../_chunks/dep-ae4bffa5.mjs';
import '../../_chunks/dep-8db27830.mjs';
import '../../_chunks/dep-4903a8a8.mjs';
function useSingleValue(props) {
var _toRefs = toRefs(props),
valueFromProps = _toRefs.value,
modelValue = _toRefs.modelValue;
var _useVModel = useVModel(valueFromProps, modelValue, props.defaultValue, props.onChange),
_useVModel2 = _slicedToArray(_useVModel, 2),
value = _useVModel2[0],
onChange = _useVModel2[1];
var formatRef = computed(function () {
return getDefaultFormat({
mode: props.mode,
format: props.format,
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"));
}
var time = ref(formatTime(value.value, formatRef.value.format, formatRef.value.timeFormat, props.defaultTime));
var month = ref(parseToDayjs(value.value, formatRef.value.format).month());
var year = ref(parseToDayjs(value.value, formatRef.value.format).year());
var cacheValue = ref(formatDate(value.value, {
format: formatRef.value.format
}));
watchEffect(function () {
if (!value.value) {
cacheValue.value = "";
return;
}
if (!isValidDate(value.value, formatRef.value.format)) return;
cacheValue.value = formatDate(value.value, {
format: formatRef.value.format
});
time.value = formatTime(value.value, formatRef.value.format, formatRef.value.timeFormat, props.defaultTime);
});
return {
year: year,
month: month,
value: value,
time: time,
cacheValue: cacheValue,
onChange: onChange
};
}
export { useSingleValue as default };
//# sourceMappingURL=useSingleValue.mjs.map