UNPKG

tdesign-vue-next

Version:
167 lines (159 loc) 5.42 kB
/** * tdesign v1.20.2 * (c) 2026 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var Vue = require('vue'); var dayjs = require('dayjs'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); require('../../_chunks/dep-449273df.js'); var configProvider_hooks_useConfig = require('../../config-provider/hooks/useConfig.js'); require('@babel/runtime/helpers/slicedToArray'); require('../../_chunks/dep-497fc9a5.js'); require('@babel/runtime/helpers/defineProperty'); var calendar_constants_index = require('../constants/index.js'); var calendar_utils_index = require('../utils/index.js'); var isArray = require('../../_chunks/dep-959f4847.js'); require('../../_chunks/dep-f9b59444.js'); require('../../_chunks/dep-31abb282.js'); require('../../_chunks/dep-c71a9cd7.js'); require('../../_chunks/dep-39529ef1.js'); require('../../_chunks/dep-f4c1cb5b.js'); require('../../_chunks/dep-4896d30f.js'); require('../../_chunks/dep-80827572.js'); require('../../_chunks/dep-2610df9f.js'); require('../../_chunks/dep-2c7a67b8.js'); require('../../_chunks/dep-db6459dd.js'); require('../../_chunks/dep-4d7a3a91.js'); require('../../_chunks/dep-6e64ef0e.js'); require('../../_chunks/dep-ae380218.js'); require('../../_chunks/dep-fdac7521.js'); require('../../_chunks/dep-df5442c5.js'); require('../../_chunks/dep-141cbae1.js'); require('../../_chunks/dep-c277c7cb.js'); require('../../_chunks/dep-7653f80f.js'); require('../../_chunks/dep-6e7a2100.js'); require('@babel/runtime/helpers/createClass'); require('@babel/runtime/helpers/classCallCheck'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var dayjs__default = /*#__PURE__*/_interopDefaultLegacy(dayjs); function useState(props) { var _useConfig = configProvider_hooks_useConfig.useConfig(calendar_constants_index.COMPONENT_NAME), globalConfig = _useConfig.globalConfig; var state = Vue.reactive({ realFirstDayOfWeek: 1, curDate: null, curDateList: [], curSelectedYear: null, curSelectedMonth: null, curSelectedMode: null, isShowWeekend: true, controlSize: "medium" }); function toToday() { var curDate = calendar_utils_index.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) : calendar_utils_index.createDefaultCurDate().year(); if (!isNaN(curSelectedYear) && curSelectedYear > 0) { state.curSelectedYear = curSelectedYear; } } function setCurSelectedMonth(month) { var curSelectedMonth = month ? parseInt("".concat(month), 10) : parseInt(calendar_utils_index.createDefaultCurDate().format("M"), 10); if (!isNaN(curSelectedMonth) && curSelectedMonth > 0 && curSelectedMonth <= 12) { state.curSelectedMonth = curSelectedMonth; } } function setCurrentDate(value) { if (isArray.isArray(value)) { state.curDate = value && value.length ? dayjs__default["default"](value[0]) : calendar_utils_index.createDefaultCurDate(); } else { state.curDate = value ? dayjs__default["default"](value) : calendar_utils_index.createDefaultCurDate(); } } function setCurrentDateList(value) { if (isArray.isArray(value)) { state.curDateList = value && value.length ? value.map(function (item) { return dayjs__default["default"](item); }) : [calendar_utils_index.createDefaultCurDate()]; } else { state.curDateList = value ? [dayjs__default["default"](value)] : [calendar_utils_index.createDefaultCurDate()]; } } function checkDayVisible(day) { var re = true; if (!state.isShowWeekend) { re = day !== 6 && day !== 7; } return re; } Vue.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 }); Vue.watch(function () { return props.value; }, function (v) { if (props.multiple) { setCurrentDateList(v); } else { setCurrentDate(v); } }, { immediate: true }); Vue.watch(function () { return props.year; }, function (v) { setCurSelectedYear(v); }, { immediate: true }); Vue.watch(function () { return props.month; }, function (v) { setCurSelectedMonth(v); }, { immediate: true }); Vue.watch(function () { return props.isShowWeekendDefault; }, function (v) { state.isShowWeekend = v; }, { immediate: true }); Vue.watch(function () { return props.mode; }, function (v) { state.curSelectedMode = v; }, { immediate: true }); Vue.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 }; } exports.useState = useState; //# sourceMappingURL=useState.js.map