import { defineComponent, computed, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, renderSlot, toDisplayString, createVNode, withCtx, createTextVNode, createCommentVNode, createSlots, normalizeProps, guardReactiveProps, Fragment, renderList, createBlock } from 'vue'; import { ElButtonGroup, ElButton } from '../../button/index.mjs'; import '../../../hooks/index.mjs'; import DateTable from './date-table2.mjs'; import { useCalendar } from './use-calendar.mjs'; import { calendarProps, calendarEmits } from './calendar.mjs'; import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs'; import { useNamespace } from '../../../hooks/use-namespace/index.mjs'; import { useLocale } from '../../../hooks/use-locale/index.mjs'; const COMPONENT_NAME = "ElCalendar"; const __default__ = defineComponent({ name: COMPONENT_NAME }); const _sfc_main = /* @__PURE__ */ defineComponent({ ...__default__, props: calendarProps, emits: calendarEmits, setup(__props, { expose, emit }) { const props = __props; const ns = useNamespace("calendar"); const { calculateValidatedDateRange, date, pickDay, realSelectedDay, selectDate, validatedRange } = useCalendar(props, emit, COMPONENT_NAME); const { t } = useLocale(); const i18nDate = computed(() => { const pickedMonth = `el.datepicker.month${date.value.format("M")}`; return `${date.value.year()} ${t("el.datepicker.year")} ${t(pickedMonth)}`; }); expose({ selectedDay: realSelectedDay, pickDay, selectDate, calculateValidatedDateRange }); return (_ctx, _cache) => { return openBlock(), createElementBlock("div", { class: normalizeClass(unref(ns).b()) }, [ createElementVNode("div", { class: normalizeClass(unref(ns).e("header")) }, [ renderSlot(_ctx.$slots, "header", { date: unref(i18nDate) }, () => [ createElementVNode("div", { class: normalizeClass(unref(ns).e("title")) }, toDisplayString(unref(i18nDate)), 3), unref(validatedRange).length === 0 ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass(unref(ns).e("button-group")) }, [ createVNode(unref(ElButtonGroup), null, { default: withCtx(() => [ createVNode(unref(ElButton), { size: "small", onClick: ($event) => unref(selectDate)("prev-month") }, { default: withCtx(() => [ createTextVNode(toDisplayString(unref(t)("el.datepicker.prevMonth")), 1) ]), _: 1 }, 8, ["onClick"]), createVNode(unref(ElButton), { size: "small", onClick: ($event) => unref(selectDate)("today") }, { default: withCtx(() => [ createTextVNode(toDisplayString(unref(t)("el.datepicker.today")), 1) ]), _: 1 }, 8, ["onClick"]), createVNode(unref(ElButton), { size: "small", onClick: ($event) => unref(selectDate)("next-month") }, { default: withCtx(() => [ createTextVNode(toDisplayString(unref(t)("el.datepicker.nextMonth")), 1) ]), _: 1 }, 8, ["onClick"]) ]), _: 1 }) ], 2)) : createCommentVNode("v-if", true) ]) ], 2), unref(validatedRange).length === 0 ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass(unref(ns).e("body")) }, [ createVNode(DateTable, { date: unref(date), "selected-day": unref(realSelectedDay), onPick: unref(pickDay) }, createSlots({ _: 2 }, [ _ctx.$slots["date-cell"] ? { name: "date-cell", fn: withCtx((data) => [ renderSlot(_ctx.$slots, "date-cell", normalizeProps(guardReactiveProps(data))) ]) } : void 0 ]), 1032, ["date", "selected-day", "onPick"]) ], 2)) : (openBlock(), createElementBlock("div", { key: 1, class: normalizeClass(unref(ns).e("body")) }, [ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(validatedRange), (range_, index) => { return openBlock(), createBlock(DateTable, { key: index, date: range_[0], "selected-day": unref(realSelectedDay), range: range_, "hide-header": index !== 0, onPick: unref(pickDay) }, createSlots({ _: 2 }, [ _ctx.$slots["date-cell"] ? { name: "date-cell", fn: withCtx((data) => [ renderSlot(_ctx.$slots, "date-cell", normalizeProps(guardReactiveProps(data))) ]) } : void 0 ]), 1032, ["date", "selected-day", "range", "hide-header", "onPick"]); }), 128)) ], 2)) ], 2); }; } }); var Calendar = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "calendar.vue"]]); export { Calendar as default }; //# sourceMappingURL=calendar2.mjs.map