52b1c3bc05f9bab2b6890121a45955165aa18e2f6e2c1097012d1bec3c95b2137c8257bb1031f84d0ea7a1c528fa56c9ba45aeae3c3a127863382e966173b2 38 KB

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