UNPKG

xdesign-vue-next

Version:

XDesign Component for vue-next

112 lines (108 loc) 4.04 kB
/** * 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 useVModel from '../../hooks/useVModel.mjs'; import { i as isArray_1 } from '../../_chunks/dep-a95026f2.mjs'; import { getDefaultFormat, isValidDate, initYearMonthTime, formatDate, formatTime } from '../../_common/js/date-picker/format.mjs'; import { extractTimeFormat } from '../../_common/js/date-picker/utils.mjs'; import '../../_chunks/dep-89b966f4.mjs'; import '../../_chunks/dep-ae4bffa5.mjs'; import '../../_chunks/dep-10a947a6.mjs'; import '../../_chunks/dep-8db27830.mjs'; import '../../_chunks/dep-4903a8a8.mjs'; import '../../_chunks/dep-b75d8d74.mjs'; import '../../_chunks/dep-82805301.mjs'; import '../../_chunks/dep-068e912d.mjs'; import '../../_chunks/dep-7dcfa37a.mjs'; import '../../_chunks/dep-addc2a84.mjs'; import '../../_chunks/dep-11fa9c2c.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-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'; var PARTIAL_MAP = { first: "start", second: "end" }; 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), 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")); } if (!isArray_1(value.value)) { console.error("typeof value: ".concat(value.value, " must be Array!")); } else if (!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 = 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 })); 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, isFirstValueSelected: isFirstValueSelected, cacheValue: cacheValue, onChange: onChange }; } export { PARTIAL_MAP, useRangeValue as default }; //# sourceMappingURL=useRangeValue.mjs.map