UNPKG

tdesign-vue-next

Version:
148 lines (144 loc) 4.31 kB
/** * tdesign v1.20.0 * (c) 2026 tdesign * @license MIT */ import { reactive, watch } from 'vue'; import { d as dayjs } from '../../_chunks/dep-b9ecb840.mjs'; import '../../_chunks/dep-6e1ec500.mjs'; import { COMPONENT_NAME } from '../constants/index.mjs'; import { createDefaultCurDate } from '../utils/index.mjs'; import { isArray } from 'lodash-es'; import { useConfig } from '../../config-provider/hooks/useConfig.mjs'; import '../../_chunks/dep-7e80b480.mjs'; import '../../_chunks/dep-c53b1c81.mjs'; import '../../_chunks/dep-3a6b2289.mjs'; import '../../_chunks/dep-1e8a6a5e.mjs'; import '../../_chunks/dep-98b885ec.mjs'; import '../../_chunks/dep-67ace303.mjs'; import '../../_chunks/dep-a1cffe73.mjs'; import '../../_chunks/dep-8768d1f1.mjs'; import '../../_chunks/dep-68c88886.mjs'; import '../../config-provider/utils/context.mjs'; import '../../_chunks/dep-fc168c9c.mjs'; import '../../_chunks/dep-2242b0fd.mjs'; import '../../_chunks/dep-dfce43be.mjs'; import '../../_chunks/dep-e25ecc4b.mjs'; import '../../_chunks/dep-d9965fa1.mjs'; function useState(props) { var _useConfig = useConfig(COMPONENT_NAME), globalConfig = _useConfig.globalConfig; var state = reactive({ realFirstDayOfWeek: 1, curDate: null, curDateList: [], curSelectedYear: null, curSelectedMonth: null, curSelectedMode: null, isShowWeekend: true, controlSize: "medium" }); function toToday() { var curDate = createDefaultCurDate(); state.curDate = curDate; state.curSelectedYear = curDate.year(); state.curSelectedMonth = parseInt(curDate.format("M"), 10); } function setCurSelectedYear(year) { var curSelectedYear = year ? parseInt("".concat(year), 10) : createDefaultCurDate().year(); if (!isNaN(curSelectedYear) && curSelectedYear > 0) { state.curSelectedYear = curSelectedYear; } } function setCurSelectedMonth(month) { var curSelectedMonth = month ? parseInt("".concat(month), 10) : parseInt(createDefaultCurDate().format("M"), 10); if (!isNaN(curSelectedMonth) && curSelectedMonth > 0 && curSelectedMonth <= 12) { state.curSelectedMonth = curSelectedMonth; } } function setCurrentDate(value) { if (isArray(value)) { state.curDate = value && value.length ? dayjs(value[0]) : createDefaultCurDate(); } else { state.curDate = value ? dayjs(value) : createDefaultCurDate(); } } function setCurrentDateList(value) { if (isArray(value)) { state.curDateList = value && value.length ? value.map(function (item) { return dayjs(item); }) : [createDefaultCurDate()]; } else { state.curDateList = value ? [dayjs(value)] : [createDefaultCurDate()]; } } function checkDayVisible(day) { var re = true; if (!state.isShowWeekend) { re = day !== 6 && day !== 7; } return re; } watch(function () { return props.firstDayOfWeek; }, function () { var _ref, _props$firstDayOfWeek; state.realFirstDayOfWeek = (_ref = (_props$firstDayOfWeek = props.firstDayOfWeek) !== null && _props$firstDayOfWeek !== void 0 ? _props$firstDayOfWeek : globalConfig.value.firstDayOfWeek) !== null && _ref !== void 0 ? _ref : 1; }, { immediate: true }); watch(function () { return props.value; }, function (v) { if (props.multiple) { setCurrentDateList(v); } else { setCurrentDate(v); } }, { immediate: true }); watch(function () { return props.year; }, function (v) { setCurSelectedYear(v); }, { immediate: true }); watch(function () { return props.month; }, function (v) { setCurSelectedMonth(v); }, { immediate: true }); watch(function () { return props.isShowWeekendDefault; }, function (v) { state.isShowWeekend = v; }, { immediate: true }); watch(function () { return props.mode; }, function (v) { state.curSelectedMode = v; }, { immediate: true }); watch(function () { return props.theme; }, function (v) { if (v === "card") state.controlSize = "small"; if (v === "full") state.controlSize = "medium"; }, { immediate: true }); return { state: state, toToday: toToday, checkDayVisible: checkDayVisible }; } export { useState }; //# sourceMappingURL=useState.mjs.map