04fe21a8cf8981c009d68d18bde9d83e3ed136f40850967969f7d710236915dae953a78921eba55ab37eb09de888a6e7c9890356f4ebc42e761e32af82a235 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823
  1. import { defineComponent, inject, toRef, ref, watch, computed, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, renderSlot, Fragment, renderList, toDisplayString, createCommentVNode, createVNode, withDirectives, withCtx, vShow, withKeys, createBlock, createTextVNode, nextTick } from 'vue';
  2. import dayjs from 'dayjs';
  3. import { ElButton } from '../../../button/index.mjs';
  4. import { ElInput } from '../../../input/index.mjs';
  5. import '../../../time-picker/index.mjs';
  6. import { ElIcon } from '../../../icon/index.mjs';
  7. import { ArrowRight, DArrowLeft, ArrowLeft, DArrowRight } from '@element-plus/icons-vue';
  8. import { panelDateRangeProps } from '../props/panel-date-range.mjs';
  9. import { useRangePicker } from '../composables/use-range-picker.mjs';
  10. import { isValidRange, getDefaultValue, correctlyParseUserInput } from '../utils.mjs';
  11. import { usePanelDateRange } from '../composables/use-panel-date-range.mjs';
  12. import { ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY } from '../constants.mjs';
  13. import YearTable from './basic-year-table.mjs';
  14. import MonthTable from './basic-month-table.mjs';
  15. import DateTable from './basic-date-table.mjs';
  16. import _export_sfc from '../../../../_virtual/plugin-vue_export-helper.mjs';
  17. import TimePickPanel from '../../../time-picker/src/time-picker-com/panel-time-pick.mjs';
  18. import ClickOutside from '../../../../directives/click-outside/index.mjs';
  19. import { PICKER_BASE_INJECTION_KEY, DEFAULT_FORMATS_TIME, DEFAULT_FORMATS_DATE } from '../../../time-picker/src/constants.mjs';
  20. import { useLocale } from '../../../../hooks/use-locale/index.mjs';
  21. import { extractTimeFormat, extractDateFormat } from '../../../time-picker/src/utils.mjs';
  22. import { isArray } from '@vue/shared';
  23. const unit = "month";
  24. const _sfc_main = /* @__PURE__ */ defineComponent({
  25. __name: "panel-date-range",
  26. props: panelDateRangeProps,
  27. emits: [
  28. "pick",
  29. "set-picker-option",
  30. "calendar-change",
  31. "panel-change"
  32. ],
  33. setup(__props, { emit }) {
  34. const props = __props;
  35. const pickerBase = inject(PICKER_BASE_INJECTION_KEY);
  36. const isDefaultFormat = inject(ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY, void 0);
  37. const { disabledDate, cellClassName, defaultTime, clearable } = pickerBase.props;
  38. const format = toRef(pickerBase.props, "format");
  39. const shortcuts = toRef(pickerBase.props, "shortcuts");
  40. const defaultValue = toRef(pickerBase.props, "defaultValue");
  41. const { lang } = useLocale();
  42. const leftDate = ref(dayjs().locale(lang.value));
  43. const rightDate = ref(dayjs().locale(lang.value).add(1, unit));
  44. const {
  45. minDate,
  46. maxDate,
  47. rangeState,
  48. ppNs,
  49. drpNs,
  50. handleChangeRange,
  51. handleRangeConfirm,
  52. handleShortcutClick,
  53. onSelect,
  54. parseValue,
  55. t
  56. } = useRangePicker(props, {
  57. defaultValue,
  58. defaultTime,
  59. leftDate,
  60. rightDate,
  61. unit,
  62. sortDates
  63. });
  64. watch(() => props.visible, (visible) => {
  65. if (!visible && rangeState.value.selecting) {
  66. parseValue(props.parsedValue);
  67. onSelect(false);
  68. }
  69. });
  70. const dateUserInput = ref({
  71. min: null,
  72. max: null
  73. });
  74. const timeUserInput = ref({
  75. min: null,
  76. max: null
  77. });
  78. const {
  79. leftCurrentView,
  80. rightCurrentView,
  81. leftCurrentViewRef,
  82. rightCurrentViewRef,
  83. leftYear,
  84. rightYear,
  85. leftMonth,
  86. rightMonth,
  87. leftYearLabel,
  88. rightYearLabel,
  89. showLeftPicker,
  90. showRightPicker,
  91. handleLeftYearPick,
  92. handleRightYearPick,
  93. handleLeftMonthPick,
  94. handleRightMonthPick,
  95. handlePanelChange,
  96. adjustDateByView
  97. } = usePanelDateRange(props, emit, leftDate, rightDate);
  98. const hasShortcuts = computed(() => !!shortcuts.value.length);
  99. const minVisibleDate = computed(() => {
  100. if (dateUserInput.value.min !== null)
  101. return dateUserInput.value.min;
  102. if (minDate.value)
  103. return minDate.value.format(dateFormat.value);
  104. return "";
  105. });
  106. const maxVisibleDate = computed(() => {
  107. if (dateUserInput.value.max !== null)
  108. return dateUserInput.value.max;
  109. if (maxDate.value || minDate.value)
  110. return (maxDate.value || minDate.value).format(dateFormat.value);
  111. return "";
  112. });
  113. const minVisibleTime = computed(() => {
  114. if (timeUserInput.value.min !== null)
  115. return timeUserInput.value.min;
  116. if (minDate.value)
  117. return minDate.value.format(timeFormat.value);
  118. return "";
  119. });
  120. const maxVisibleTime = computed(() => {
  121. if (timeUserInput.value.max !== null)
  122. return timeUserInput.value.max;
  123. if (maxDate.value || minDate.value)
  124. return (maxDate.value || minDate.value).format(timeFormat.value);
  125. return "";
  126. });
  127. const timeFormat = computed(() => {
  128. return props.timeFormat || extractTimeFormat(format.value || "") || DEFAULT_FORMATS_TIME;
  129. });
  130. const dateFormat = computed(() => {
  131. return props.dateFormat || extractDateFormat(format.value || "") || DEFAULT_FORMATS_DATE;
  132. });
  133. const isValidValue = (date) => {
  134. return isValidRange(date) && (disabledDate ? !disabledDate(date[0].toDate()) && !disabledDate(date[1].toDate()) : true);
  135. };
  136. const leftPrevYear = () => {
  137. leftDate.value = adjustDateByView(leftCurrentView.value, leftDate.value, false);
  138. if (!props.unlinkPanels) {
  139. rightDate.value = leftDate.value.add(1, "month");
  140. }
  141. handlePanelChange("year");
  142. };
  143. const leftPrevMonth = () => {
  144. leftDate.value = leftDate.value.subtract(1, "month");
  145. if (!props.unlinkPanels) {
  146. rightDate.value = leftDate.value.add(1, "month");
  147. }
  148. handlePanelChange("month");
  149. };
  150. const rightNextYear = () => {
  151. if (!props.unlinkPanels) {
  152. leftDate.value = adjustDateByView(rightCurrentView.value, leftDate.value, true);
  153. rightDate.value = leftDate.value.add(1, "month");
  154. } else {
  155. rightDate.value = adjustDateByView(rightCurrentView.value, rightDate.value, true);
  156. }
  157. handlePanelChange("year");
  158. };
  159. const rightNextMonth = () => {
  160. if (!props.unlinkPanels) {
  161. leftDate.value = leftDate.value.add(1, "month");
  162. rightDate.value = leftDate.value.add(1, "month");
  163. } else {
  164. rightDate.value = rightDate.value.add(1, "month");
  165. }
  166. handlePanelChange("month");
  167. };
  168. const leftNextYear = () => {
  169. leftDate.value = adjustDateByView(leftCurrentView.value, leftDate.value, true);
  170. handlePanelChange("year");
  171. };
  172. const leftNextMonth = () => {
  173. leftDate.value = leftDate.value.add(1, "month");
  174. handlePanelChange("month");
  175. };
  176. const rightPrevYear = () => {
  177. rightDate.value = adjustDateByView(rightCurrentView.value, rightDate.value, false);
  178. handlePanelChange("year");
  179. };
  180. const rightPrevMonth = () => {
  181. rightDate.value = rightDate.value.subtract(1, "month");
  182. handlePanelChange("month");
  183. };
  184. const enableMonthArrow = computed(() => {
  185. const nextMonth = (leftMonth.value + 1) % 12;
  186. const yearOffset = leftMonth.value + 1 >= 12 ? 1 : 0;
  187. return props.unlinkPanels && new Date(leftYear.value + yearOffset, nextMonth) < new Date(rightYear.value, rightMonth.value);
  188. });
  189. const enableYearArrow = computed(() => {
  190. return props.unlinkPanels && rightYear.value * 12 + rightMonth.value - (leftYear.value * 12 + leftMonth.value + 1) >= 12;
  191. });
  192. const btnDisabled = computed(() => {
  193. return !(minDate.value && maxDate.value && !rangeState.value.selecting && isValidRange([minDate.value, maxDate.value]));
  194. });
  195. const showTime = computed(() => props.type === "datetime" || props.type === "datetimerange");
  196. const formatEmit = (emitDayjs, index) => {
  197. if (!emitDayjs)
  198. return;
  199. if (defaultTime) {
  200. const defaultTimeD = dayjs(defaultTime[index] || defaultTime).locale(lang.value);
  201. return defaultTimeD.year(emitDayjs.year()).month(emitDayjs.month()).date(emitDayjs.date());
  202. }
  203. return emitDayjs;
  204. };
  205. const handleRangePick = (val, close = true) => {
  206. const min_ = val.minDate;
  207. const max_ = val.maxDate;
  208. const minDate_ = formatEmit(min_, 0);
  209. const maxDate_ = formatEmit(max_, 1);
  210. if (maxDate.value === maxDate_ && minDate.value === minDate_) {
  211. return;
  212. }
  213. emit("calendar-change", [min_.toDate(), max_ && max_.toDate()]);
  214. maxDate.value = maxDate_;
  215. minDate.value = minDate_;
  216. if (!showTime.value && close) {
  217. close = !minDate_ || !maxDate_;
  218. }
  219. handleRangeConfirm(close);
  220. };
  221. const minTimePickerVisible = ref(false);
  222. const maxTimePickerVisible = ref(false);
  223. const handleMinTimeClose = () => {
  224. minTimePickerVisible.value = false;
  225. };
  226. const handleMaxTimeClose = () => {
  227. maxTimePickerVisible.value = false;
  228. };
  229. const handleDateInput = (value, type) => {
  230. dateUserInput.value[type] = value;
  231. const parsedValueD = dayjs(value, dateFormat.value).locale(lang.value);
  232. if (parsedValueD.isValid()) {
  233. if (disabledDate && disabledDate(parsedValueD.toDate())) {
  234. return;
  235. }
  236. if (type === "min") {
  237. leftDate.value = parsedValueD;
  238. minDate.value = (minDate.value || leftDate.value).year(parsedValueD.year()).month(parsedValueD.month()).date(parsedValueD.date());
  239. if (!props.unlinkPanels && (!maxDate.value || maxDate.value.isBefore(minDate.value))) {
  240. rightDate.value = parsedValueD.add(1, "month");
  241. maxDate.value = minDate.value.add(1, "month");
  242. }
  243. } else {
  244. rightDate.value = parsedValueD;
  245. maxDate.value = (maxDate.value || rightDate.value).year(parsedValueD.year()).month(parsedValueD.month()).date(parsedValueD.date());
  246. if (!props.unlinkPanels && (!minDate.value || minDate.value.isAfter(maxDate.value))) {
  247. leftDate.value = parsedValueD.subtract(1, "month");
  248. minDate.value = maxDate.value.subtract(1, "month");
  249. }
  250. }
  251. sortDates(minDate.value, maxDate.value);
  252. handleRangeConfirm(true);
  253. }
  254. };
  255. const handleDateChange = (_, type) => {
  256. dateUserInput.value[type] = null;
  257. };
  258. const handleTimeInput = (value, type) => {
  259. timeUserInput.value[type] = value;
  260. const parsedValueD = dayjs(value, timeFormat.value).locale(lang.value);
  261. if (parsedValueD.isValid()) {
  262. if (type === "min") {
  263. minTimePickerVisible.value = true;
  264. minDate.value = (minDate.value || leftDate.value).hour(parsedValueD.hour()).minute(parsedValueD.minute()).second(parsedValueD.second());
  265. } else {
  266. maxTimePickerVisible.value = true;
  267. maxDate.value = (maxDate.value || rightDate.value).hour(parsedValueD.hour()).minute(parsedValueD.minute()).second(parsedValueD.second());
  268. rightDate.value = maxDate.value;
  269. }
  270. }
  271. };
  272. const handleTimeChange = (_value, type) => {
  273. timeUserInput.value[type] = null;
  274. if (type === "min") {
  275. leftDate.value = minDate.value;
  276. minTimePickerVisible.value = false;
  277. if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {
  278. maxDate.value = minDate.value;
  279. }
  280. } else {
  281. rightDate.value = maxDate.value;
  282. maxTimePickerVisible.value = false;
  283. if (maxDate.value && maxDate.value.isBefore(minDate.value)) {
  284. minDate.value = maxDate.value;
  285. }
  286. }
  287. handleRangeConfirm(true);
  288. };
  289. const handleMinTimePick = (value, visible, first) => {
  290. if (timeUserInput.value.min)
  291. return;
  292. if (value) {
  293. leftDate.value = value;
  294. minDate.value = (minDate.value || leftDate.value).hour(value.hour()).minute(value.minute()).second(value.second());
  295. }
  296. if (!first) {
  297. minTimePickerVisible.value = visible;
  298. }
  299. if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {
  300. maxDate.value = minDate.value;
  301. rightDate.value = value;
  302. nextTick(() => {
  303. parseValue(props.parsedValue);
  304. });
  305. }
  306. handleRangeConfirm(true);
  307. };
  308. const handleMaxTimePick = (value, visible, first) => {
  309. if (timeUserInput.value.max)
  310. return;
  311. if (value) {
  312. rightDate.value = value;
  313. maxDate.value = (maxDate.value || rightDate.value).hour(value.hour()).minute(value.minute()).second(value.second());
  314. }
  315. if (!first) {
  316. maxTimePickerVisible.value = visible;
  317. }
  318. if (maxDate.value && maxDate.value.isBefore(minDate.value)) {
  319. minDate.value = maxDate.value;
  320. }
  321. handleRangeConfirm(true);
  322. };
  323. const handleClear = () => {
  324. let valueOnClear = null;
  325. if (pickerBase == null ? void 0 : pickerBase.emptyValues) {
  326. valueOnClear = pickerBase.emptyValues.valueOnClear.value;
  327. }
  328. leftDate.value = getDefaultValue(unref(defaultValue), {
  329. lang: unref(lang),
  330. unit: "month",
  331. unlinkPanels: props.unlinkPanels
  332. })[0];
  333. rightDate.value = leftDate.value.add(1, "month");
  334. maxDate.value = void 0;
  335. minDate.value = void 0;
  336. handleRangeConfirm(true);
  337. emit("pick", valueOnClear);
  338. };
  339. const formatToString = (value) => {
  340. return isArray(value) ? value.map((_) => _.format(format.value)) : value.format(format.value);
  341. };
  342. const parseUserInput = (value) => {
  343. return correctlyParseUserInput(value, format.value || "", lang.value, isDefaultFormat);
  344. };
  345. function sortDates(minDate2, maxDate2) {
  346. if (props.unlinkPanels && maxDate2) {
  347. const minDateYear = (minDate2 == null ? void 0 : minDate2.year()) || 0;
  348. const minDateMonth = (minDate2 == null ? void 0 : minDate2.month()) || 0;
  349. const maxDateYear = maxDate2.year();
  350. const maxDateMonth = maxDate2.month();
  351. rightDate.value = minDateYear === maxDateYear && minDateMonth === maxDateMonth ? maxDate2.add(1, unit) : maxDate2;
  352. } else {
  353. rightDate.value = leftDate.value.add(1, unit);
  354. if (maxDate2) {
  355. rightDate.value = rightDate.value.hour(maxDate2.hour()).minute(maxDate2.minute()).second(maxDate2.second());
  356. }
  357. }
  358. }
  359. emit("set-picker-option", ["isValidValue", isValidValue]);
  360. emit("set-picker-option", ["parseUserInput", parseUserInput]);
  361. emit("set-picker-option", ["formatToString", formatToString]);
  362. emit("set-picker-option", ["handleClear", handleClear]);
  363. return (_ctx, _cache) => {
  364. return openBlock(), createElementBlock("div", {
  365. class: normalizeClass([
  366. unref(ppNs).b(),
  367. unref(drpNs).b(),
  368. unref(ppNs).is("border", _ctx.border),
  369. unref(ppNs).is("disabled", _ctx.disabled),
  370. {
  371. "has-sidebar": _ctx.$slots.sidebar || unref(hasShortcuts),
  372. "has-time": unref(showTime)
  373. }
  374. ])
  375. }, [
  376. createElementVNode("div", {
  377. class: normalizeClass(unref(ppNs).e("body-wrapper"))
  378. }, [
  379. renderSlot(_ctx.$slots, "sidebar", {
  380. class: normalizeClass(unref(ppNs).e("sidebar"))
  381. }),
  382. unref(hasShortcuts) ? (openBlock(), createElementBlock("div", {
  383. key: 0,
  384. class: normalizeClass(unref(ppNs).e("sidebar"))
  385. }, [
  386. (openBlock(true), createElementBlock(Fragment, null, renderList(unref(shortcuts), (shortcut, key) => {
  387. return openBlock(), createElementBlock("button", {
  388. key,
  389. type: "button",
  390. disabled: _ctx.disabled,
  391. class: normalizeClass(unref(ppNs).e("shortcut")),
  392. onClick: ($event) => unref(handleShortcutClick)(shortcut)
  393. }, toDisplayString(shortcut.text), 11, ["disabled", "onClick"]);
  394. }), 128))
  395. ], 2)) : createCommentVNode("v-if", true),
  396. createElementVNode("div", {
  397. class: normalizeClass(unref(ppNs).e("body"))
  398. }, [
  399. unref(showTime) ? (openBlock(), createElementBlock("div", {
  400. key: 0,
  401. class: normalizeClass(unref(drpNs).e("time-header"))
  402. }, [
  403. createElementVNode("span", {
  404. class: normalizeClass(unref(drpNs).e("editors-wrap"))
  405. }, [
  406. createElementVNode("span", {
  407. class: normalizeClass(unref(drpNs).e("time-picker-wrap"))
  408. }, [
  409. createVNode(unref(ElInput), {
  410. size: "small",
  411. disabled: unref(rangeState).selecting || _ctx.disabled,
  412. placeholder: unref(t)("el.datepicker.startDate"),
  413. class: normalizeClass(unref(drpNs).e("editor")),
  414. "model-value": unref(minVisibleDate),
  415. "validate-event": false,
  416. onInput: (val) => handleDateInput(val, "min"),
  417. onChange: (val) => handleDateChange(val, "min")
  418. }, null, 8, ["disabled", "placeholder", "class", "model-value", "onInput", "onChange"])
  419. ], 2),
  420. withDirectives((openBlock(), createElementBlock("span", {
  421. class: normalizeClass(unref(drpNs).e("time-picker-wrap"))
  422. }, [
  423. createVNode(unref(ElInput), {
  424. size: "small",
  425. class: normalizeClass(unref(drpNs).e("editor")),
  426. disabled: unref(rangeState).selecting || _ctx.disabled,
  427. placeholder: unref(t)("el.datepicker.startTime"),
  428. "model-value": unref(minVisibleTime),
  429. "validate-event": false,
  430. onFocus: ($event) => minTimePickerVisible.value = true,
  431. onInput: (val) => handleTimeInput(val, "min"),
  432. onChange: (val) => handleTimeChange(val, "min")
  433. }, null, 8, ["class", "disabled", "placeholder", "model-value", "onFocus", "onInput", "onChange"]),
  434. createVNode(unref(TimePickPanel), {
  435. visible: minTimePickerVisible.value,
  436. format: unref(timeFormat),
  437. "datetime-role": "start",
  438. "parsed-value": leftDate.value,
  439. onPick: handleMinTimePick
  440. }, null, 8, ["visible", "format", "parsed-value"])
  441. ], 2)), [
  442. [unref(ClickOutside), handleMinTimeClose]
  443. ])
  444. ], 2),
  445. createElementVNode("span", null, [
  446. createVNode(unref(ElIcon), null, {
  447. default: withCtx(() => [
  448. createVNode(unref(ArrowRight))
  449. ]),
  450. _: 1
  451. })
  452. ]),
  453. createElementVNode("span", {
  454. class: normalizeClass([unref(drpNs).e("editors-wrap"), "is-right"])
  455. }, [
  456. createElementVNode("span", {
  457. class: normalizeClass(unref(drpNs).e("time-picker-wrap"))
  458. }, [
  459. createVNode(unref(ElInput), {
  460. size: "small",
  461. class: normalizeClass(unref(drpNs).e("editor")),
  462. disabled: unref(rangeState).selecting || _ctx.disabled,
  463. placeholder: unref(t)("el.datepicker.endDate"),
  464. "model-value": unref(maxVisibleDate),
  465. readonly: !unref(minDate),
  466. "validate-event": false,
  467. onInput: (val) => handleDateInput(val, "max"),
  468. onChange: (val) => handleDateChange(val, "max")
  469. }, null, 8, ["class", "disabled", "placeholder", "model-value", "readonly", "onInput", "onChange"])
  470. ], 2),
  471. withDirectives((openBlock(), createElementBlock("span", {
  472. class: normalizeClass(unref(drpNs).e("time-picker-wrap"))
  473. }, [
  474. createVNode(unref(ElInput), {
  475. size: "small",
  476. class: normalizeClass(unref(drpNs).e("editor")),
  477. disabled: unref(rangeState).selecting || _ctx.disabled,
  478. placeholder: unref(t)("el.datepicker.endTime"),
  479. "model-value": unref(maxVisibleTime),
  480. readonly: !unref(minDate),
  481. "validate-event": false,
  482. onFocus: ($event) => unref(minDate) && (maxTimePickerVisible.value = true),
  483. onInput: (val) => handleTimeInput(val, "max"),
  484. onChange: (val) => handleTimeChange(val, "max")
  485. }, null, 8, ["class", "disabled", "placeholder", "model-value", "readonly", "onFocus", "onInput", "onChange"]),
  486. createVNode(unref(TimePickPanel), {
  487. "datetime-role": "end",
  488. visible: maxTimePickerVisible.value,
  489. format: unref(timeFormat),
  490. "parsed-value": rightDate.value,
  491. onPick: handleMaxTimePick
  492. }, null, 8, ["visible", "format", "parsed-value"])
  493. ], 2)), [
  494. [unref(ClickOutside), handleMaxTimeClose]
  495. ])
  496. ], 2)
  497. ], 2)) : createCommentVNode("v-if", true),
  498. createElementVNode("div", {
  499. class: normalizeClass([[unref(ppNs).e("content"), unref(drpNs).e("content")], "is-left"])
  500. }, [
  501. createElementVNode("div", {
  502. class: normalizeClass(unref(drpNs).e("header"))
  503. }, [
  504. createElementVNode("button", {
  505. type: "button",
  506. class: normalizeClass([unref(ppNs).e("icon-btn"), "d-arrow-left"]),
  507. "aria-label": unref(t)(`el.datepicker.prevYear`),
  508. disabled: _ctx.disabled,
  509. onClick: leftPrevYear
  510. }, [
  511. renderSlot(_ctx.$slots, "prev-year", {}, () => [
  512. createVNode(unref(ElIcon), null, {
  513. default: withCtx(() => [
  514. createVNode(unref(DArrowLeft))
  515. ]),
  516. _: 1
  517. })
  518. ])
  519. ], 10, ["aria-label", "disabled"]),
  520. withDirectives(createElementVNode("button", {
  521. type: "button",
  522. class: normalizeClass([unref(ppNs).e("icon-btn"), "arrow-left"]),
  523. "aria-label": unref(t)(`el.datepicker.prevMonth`),
  524. disabled: _ctx.disabled,
  525. onClick: leftPrevMonth
  526. }, [
  527. renderSlot(_ctx.$slots, "prev-month", {}, () => [
  528. createVNode(unref(ElIcon), null, {
  529. default: withCtx(() => [
  530. createVNode(unref(ArrowLeft))
  531. ]),
  532. _: 1
  533. })
  534. ])
  535. ], 10, ["aria-label", "disabled"]), [
  536. [vShow, unref(leftCurrentView) === "date"]
  537. ]),
  538. _ctx.unlinkPanels ? (openBlock(), createElementBlock("button", {
  539. key: 0,
  540. type: "button",
  541. disabled: !unref(enableYearArrow) || _ctx.disabled,
  542. class: normalizeClass([[
  543. unref(ppNs).e("icon-btn"),
  544. unref(ppNs).is("disabled", !unref(enableYearArrow) || _ctx.disabled)
  545. ], "d-arrow-right"]),
  546. "aria-label": unref(t)(`el.datepicker.nextYear`),
  547. onClick: leftNextYear
  548. }, [
  549. renderSlot(_ctx.$slots, "next-year", {}, () => [
  550. createVNode(unref(ElIcon), null, {
  551. default: withCtx(() => [
  552. createVNode(unref(DArrowRight))
  553. ]),
  554. _: 1
  555. })
  556. ])
  557. ], 10, ["disabled", "aria-label"])) : createCommentVNode("v-if", true),
  558. _ctx.unlinkPanels && unref(leftCurrentView) === "date" ? (openBlock(), createElementBlock("button", {
  559. key: 1,
  560. type: "button",
  561. disabled: !unref(enableMonthArrow) || _ctx.disabled,
  562. class: normalizeClass([[
  563. unref(ppNs).e("icon-btn"),
  564. unref(ppNs).is("disabled", !unref(enableMonthArrow) || _ctx.disabled)
  565. ], "arrow-right"]),
  566. "aria-label": unref(t)(`el.datepicker.nextMonth`),
  567. onClick: leftNextMonth
  568. }, [
  569. renderSlot(_ctx.$slots, "next-month", {}, () => [
  570. createVNode(unref(ElIcon), null, {
  571. default: withCtx(() => [
  572. createVNode(unref(ArrowRight))
  573. ]),
  574. _: 1
  575. })
  576. ])
  577. ], 10, ["disabled", "aria-label"])) : createCommentVNode("v-if", true),
  578. createElementVNode("div", null, [
  579. createElementVNode("span", {
  580. role: "button",
  581. class: normalizeClass(unref(drpNs).e("header-label")),
  582. "aria-live": "polite",
  583. tabindex: "0",
  584. onKeydown: withKeys(($event) => unref(showLeftPicker)("year"), ["enter"]),
  585. onClick: ($event) => unref(showLeftPicker)("year")
  586. }, toDisplayString(unref(leftYearLabel)), 43, ["onKeydown", "onClick"]),
  587. withDirectives(createElementVNode("span", {
  588. role: "button",
  589. "aria-live": "polite",
  590. tabindex: "0",
  591. class: normalizeClass([
  592. unref(drpNs).e("header-label"),
  593. { active: unref(leftCurrentView) === "month" }
  594. ]),
  595. onKeydown: withKeys(($event) => unref(showLeftPicker)("month"), ["enter"]),
  596. onClick: ($event) => unref(showLeftPicker)("month")
  597. }, toDisplayString(unref(t)(`el.datepicker.month${leftDate.value.month() + 1}`)), 43, ["onKeydown", "onClick"]), [
  598. [vShow, unref(leftCurrentView) === "date"]
  599. ])
  600. ])
  601. ], 2),
  602. unref(leftCurrentView) === "date" ? (openBlock(), createBlock(DateTable, {
  603. key: 0,
  604. ref_key: "leftCurrentViewRef",
  605. ref: leftCurrentViewRef,
  606. "selection-mode": "range",
  607. date: leftDate.value,
  608. "min-date": unref(minDate),
  609. "max-date": unref(maxDate),
  610. "range-state": unref(rangeState),
  611. "disabled-date": unref(disabledDate),
  612. "cell-class-name": unref(cellClassName),
  613. "show-week-number": _ctx.showWeekNumber,
  614. disabled: _ctx.disabled,
  615. onChangerange: unref(handleChangeRange),
  616. onPick: handleRangePick,
  617. onSelect: unref(onSelect)
  618. }, null, 8, ["date", "min-date", "max-date", "range-state", "disabled-date", "cell-class-name", "show-week-number", "disabled", "onChangerange", "onSelect"])) : createCommentVNode("v-if", true),
  619. unref(leftCurrentView) === "year" ? (openBlock(), createBlock(YearTable, {
  620. key: 1,
  621. ref_key: "leftCurrentViewRef",
  622. ref: leftCurrentViewRef,
  623. "selection-mode": "year",
  624. date: leftDate.value,
  625. "disabled-date": unref(disabledDate),
  626. "parsed-value": _ctx.parsedValue,
  627. disabled: _ctx.disabled,
  628. onPick: unref(handleLeftYearPick)
  629. }, null, 8, ["date", "disabled-date", "parsed-value", "disabled", "onPick"])) : createCommentVNode("v-if", true),
  630. unref(leftCurrentView) === "month" ? (openBlock(), createBlock(MonthTable, {
  631. key: 2,
  632. ref_key: "leftCurrentViewRef",
  633. ref: leftCurrentViewRef,
  634. "selection-mode": "month",
  635. date: leftDate.value,
  636. "parsed-value": _ctx.parsedValue,
  637. "disabled-date": unref(disabledDate),
  638. disabled: _ctx.disabled,
  639. onPick: unref(handleLeftMonthPick)
  640. }, null, 8, ["date", "parsed-value", "disabled-date", "disabled", "onPick"])) : createCommentVNode("v-if", true)
  641. ], 2),
  642. createElementVNode("div", {
  643. class: normalizeClass([[unref(ppNs).e("content"), unref(drpNs).e("content")], "is-right"])
  644. }, [
  645. createElementVNode("div", {
  646. class: normalizeClass([
  647. unref(drpNs).e("header"),
  648. unref(ppNs).is("disabled", !unref(enableYearArrow) || _ctx.disabled)
  649. ])
  650. }, [
  651. _ctx.unlinkPanels ? (openBlock(), createElementBlock("button", {
  652. key: 0,
  653. type: "button",
  654. disabled: !unref(enableYearArrow) || _ctx.disabled,
  655. class: normalizeClass([unref(ppNs).e("icon-btn"), "d-arrow-left"]),
  656. "aria-label": unref(t)(`el.datepicker.prevYear`),
  657. onClick: rightPrevYear
  658. }, [
  659. renderSlot(_ctx.$slots, "prev-year", {}, () => [
  660. createVNode(unref(ElIcon), null, {
  661. default: withCtx(() => [
  662. createVNode(unref(DArrowLeft))
  663. ]),
  664. _: 1
  665. })
  666. ])
  667. ], 10, ["disabled", "aria-label"])) : createCommentVNode("v-if", true),
  668. _ctx.unlinkPanels && unref(rightCurrentView) === "date" ? (openBlock(), createElementBlock("button", {
  669. key: 1,
  670. type: "button",
  671. disabled: !unref(enableMonthArrow) || _ctx.disabled,
  672. class: normalizeClass([unref(ppNs).e("icon-btn"), "arrow-left"]),
  673. "aria-label": unref(t)(`el.datepicker.prevMonth`),
  674. onClick: rightPrevMonth
  675. }, [
  676. renderSlot(_ctx.$slots, "prev-month", {}, () => [
  677. createVNode(unref(ElIcon), null, {
  678. default: withCtx(() => [
  679. createVNode(unref(ArrowLeft))
  680. ]),
  681. _: 1
  682. })
  683. ])
  684. ], 10, ["disabled", "aria-label"])) : createCommentVNode("v-if", true),
  685. createElementVNode("button", {
  686. type: "button",
  687. "aria-label": unref(t)(`el.datepicker.nextYear`),
  688. class: normalizeClass([unref(ppNs).e("icon-btn"), "d-arrow-right"]),
  689. disabled: _ctx.disabled,
  690. onClick: rightNextYear
  691. }, [
  692. renderSlot(_ctx.$slots, "next-year", {}, () => [
  693. createVNode(unref(ElIcon), null, {
  694. default: withCtx(() => [
  695. createVNode(unref(DArrowRight))
  696. ]),
  697. _: 1
  698. })
  699. ])
  700. ], 10, ["aria-label", "disabled"]),
  701. withDirectives(createElementVNode("button", {
  702. type: "button",
  703. class: normalizeClass([unref(ppNs).e("icon-btn"), "arrow-right"]),
  704. disabled: _ctx.disabled,
  705. "aria-label": unref(t)(`el.datepicker.nextMonth`),
  706. onClick: rightNextMonth
  707. }, [
  708. renderSlot(_ctx.$slots, "next-month", {}, () => [
  709. createVNode(unref(ElIcon), null, {
  710. default: withCtx(() => [
  711. createVNode(unref(ArrowRight))
  712. ]),
  713. _: 1
  714. })
  715. ])
  716. ], 10, ["disabled", "aria-label"]), [
  717. [vShow, unref(rightCurrentView) === "date"]
  718. ]),
  719. createElementVNode("div", null, [
  720. createElementVNode("span", {
  721. role: "button",
  722. class: normalizeClass(unref(drpNs).e("header-label")),
  723. "aria-live": "polite",
  724. tabindex: "0",
  725. onKeydown: withKeys(($event) => unref(showRightPicker)("year"), ["enter"]),
  726. onClick: ($event) => unref(showRightPicker)("year")
  727. }, toDisplayString(unref(rightYearLabel)), 43, ["onKeydown", "onClick"]),
  728. withDirectives(createElementVNode("span", {
  729. role: "button",
  730. "aria-live": "polite",
  731. tabindex: "0",
  732. class: normalizeClass([
  733. unref(drpNs).e("header-label"),
  734. { active: unref(rightCurrentView) === "month" }
  735. ]),
  736. onKeydown: withKeys(($event) => unref(showRightPicker)("month"), ["enter"]),
  737. onClick: ($event) => unref(showRightPicker)("month")
  738. }, toDisplayString(unref(t)(`el.datepicker.month${rightDate.value.month() + 1}`)), 43, ["onKeydown", "onClick"]), [
  739. [vShow, unref(rightCurrentView) === "date"]
  740. ])
  741. ])
  742. ], 2),
  743. unref(rightCurrentView) === "date" ? (openBlock(), createBlock(DateTable, {
  744. key: 0,
  745. ref_key: "rightCurrentViewRef",
  746. ref: rightCurrentViewRef,
  747. "selection-mode": "range",
  748. date: rightDate.value,
  749. "min-date": unref(minDate),
  750. "max-date": unref(maxDate),
  751. "range-state": unref(rangeState),
  752. "disabled-date": unref(disabledDate),
  753. "cell-class-name": unref(cellClassName),
  754. "show-week-number": _ctx.showWeekNumber,
  755. disabled: _ctx.disabled,
  756. onChangerange: unref(handleChangeRange),
  757. onPick: handleRangePick,
  758. onSelect: unref(onSelect)
  759. }, null, 8, ["date", "min-date", "max-date", "range-state", "disabled-date", "cell-class-name", "show-week-number", "disabled", "onChangerange", "onSelect"])) : createCommentVNode("v-if", true),
  760. unref(rightCurrentView) === "year" ? (openBlock(), createBlock(YearTable, {
  761. key: 1,
  762. ref_key: "rightCurrentViewRef",
  763. ref: rightCurrentViewRef,
  764. "selection-mode": "year",
  765. date: rightDate.value,
  766. "disabled-date": unref(disabledDate),
  767. "parsed-value": _ctx.parsedValue,
  768. disabled: _ctx.disabled,
  769. onPick: unref(handleRightYearPick)
  770. }, null, 8, ["date", "disabled-date", "parsed-value", "disabled", "onPick"])) : createCommentVNode("v-if", true),
  771. unref(rightCurrentView) === "month" ? (openBlock(), createBlock(MonthTable, {
  772. key: 2,
  773. ref_key: "rightCurrentViewRef",
  774. ref: rightCurrentViewRef,
  775. "selection-mode": "month",
  776. date: rightDate.value,
  777. "parsed-value": _ctx.parsedValue,
  778. "disabled-date": unref(disabledDate),
  779. disabled: _ctx.disabled,
  780. onPick: unref(handleRightMonthPick)
  781. }, null, 8, ["date", "parsed-value", "disabled-date", "disabled", "onPick"])) : createCommentVNode("v-if", true)
  782. ], 2)
  783. ], 2)
  784. ], 2),
  785. _ctx.showFooter && unref(showTime) && (_ctx.showConfirm || unref(clearable)) ? (openBlock(), createElementBlock("div", {
  786. key: 0,
  787. class: normalizeClass(unref(ppNs).e("footer"))
  788. }, [
  789. unref(clearable) ? (openBlock(), createBlock(unref(ElButton), {
  790. key: 0,
  791. text: "",
  792. size: "small",
  793. class: normalizeClass(unref(ppNs).e("link-btn")),
  794. onClick: handleClear
  795. }, {
  796. default: withCtx(() => [
  797. createTextVNode(toDisplayString(unref(t)("el.datepicker.clear")), 1)
  798. ]),
  799. _: 1
  800. }, 8, ["class"])) : createCommentVNode("v-if", true),
  801. _ctx.showConfirm ? (openBlock(), createBlock(unref(ElButton), {
  802. key: 1,
  803. plain: "",
  804. size: "small",
  805. class: normalizeClass(unref(ppNs).e("link-btn")),
  806. disabled: unref(btnDisabled),
  807. onClick: ($event) => unref(handleRangeConfirm)(false)
  808. }, {
  809. default: withCtx(() => [
  810. createTextVNode(toDisplayString(unref(t)("el.datepicker.confirm")), 1)
  811. ]),
  812. _: 1
  813. }, 8, ["class", "disabled", "onClick"])) : createCommentVNode("v-if", true)
  814. ], 2)) : createCommentVNode("v-if", true)
  815. ], 2);
  816. };
  817. }
  818. });
  819. var DateRangePickPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "panel-date-range.vue"]]);
  820. export { DateRangePickPanel as default };
  821. //# sourceMappingURL=panel-date-range.mjs.map