@element-plus/nightly 0.0.20260410 → 0.0.20260411

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (328) hide show
  1. package/attributes.json +1 -1
  2. package/dist/index.css +1 -1
  3. package/dist/index.full.js +50 -23
  4. package/dist/index.full.min.js +4 -4
  5. package/dist/index.full.min.js.map +1 -1
  6. package/dist/index.full.min.mjs +4 -4
  7. package/dist/index.full.min.mjs.map +1 -1
  8. package/dist/index.full.mjs +50 -23
  9. package/dist/locale/af.js +1 -1
  10. package/dist/locale/af.min.js +1 -1
  11. package/dist/locale/af.min.mjs +1 -1
  12. package/dist/locale/af.mjs +1 -1
  13. package/dist/locale/ar-eg.js +1 -1
  14. package/dist/locale/ar-eg.min.js +1 -1
  15. package/dist/locale/ar-eg.min.mjs +1 -1
  16. package/dist/locale/ar-eg.mjs +1 -1
  17. package/dist/locale/ar.js +1 -1
  18. package/dist/locale/ar.min.js +1 -1
  19. package/dist/locale/ar.min.mjs +1 -1
  20. package/dist/locale/ar.mjs +1 -1
  21. package/dist/locale/az.js +1 -1
  22. package/dist/locale/az.min.js +1 -1
  23. package/dist/locale/az.min.mjs +1 -1
  24. package/dist/locale/az.mjs +1 -1
  25. package/dist/locale/bg.js +1 -1
  26. package/dist/locale/bg.min.js +1 -1
  27. package/dist/locale/bg.min.mjs +1 -1
  28. package/dist/locale/bg.mjs +1 -1
  29. package/dist/locale/bn.js +1 -1
  30. package/dist/locale/bn.min.js +1 -1
  31. package/dist/locale/bn.min.mjs +1 -1
  32. package/dist/locale/bn.mjs +1 -1
  33. package/dist/locale/ca.js +1 -1
  34. package/dist/locale/ca.min.js +1 -1
  35. package/dist/locale/ca.min.mjs +1 -1
  36. package/dist/locale/ca.mjs +1 -1
  37. package/dist/locale/ckb.js +1 -1
  38. package/dist/locale/ckb.min.js +1 -1
  39. package/dist/locale/ckb.min.mjs +1 -1
  40. package/dist/locale/ckb.mjs +1 -1
  41. package/dist/locale/cs.js +1 -1
  42. package/dist/locale/cs.min.js +1 -1
  43. package/dist/locale/cs.min.mjs +1 -1
  44. package/dist/locale/cs.mjs +1 -1
  45. package/dist/locale/da.js +1 -1
  46. package/dist/locale/da.min.js +1 -1
  47. package/dist/locale/da.min.mjs +1 -1
  48. package/dist/locale/da.mjs +1 -1
  49. package/dist/locale/de.js +1 -1
  50. package/dist/locale/de.min.js +1 -1
  51. package/dist/locale/de.min.mjs +1 -1
  52. package/dist/locale/de.mjs +1 -1
  53. package/dist/locale/el.js +1 -1
  54. package/dist/locale/el.min.js +1 -1
  55. package/dist/locale/el.min.mjs +1 -1
  56. package/dist/locale/el.mjs +1 -1
  57. package/dist/locale/en.js +1 -1
  58. package/dist/locale/en.min.js +1 -1
  59. package/dist/locale/en.min.mjs +1 -1
  60. package/dist/locale/en.mjs +1 -1
  61. package/dist/locale/eo.js +1 -1
  62. package/dist/locale/eo.min.js +1 -1
  63. package/dist/locale/eo.min.mjs +1 -1
  64. package/dist/locale/eo.mjs +1 -1
  65. package/dist/locale/es.js +1 -1
  66. package/dist/locale/es.min.js +1 -1
  67. package/dist/locale/es.min.mjs +1 -1
  68. package/dist/locale/es.mjs +1 -1
  69. package/dist/locale/et.js +1 -1
  70. package/dist/locale/et.min.js +1 -1
  71. package/dist/locale/et.min.mjs +1 -1
  72. package/dist/locale/et.mjs +1 -1
  73. package/dist/locale/eu.js +1 -1
  74. package/dist/locale/eu.min.js +1 -1
  75. package/dist/locale/eu.min.mjs +1 -1
  76. package/dist/locale/eu.mjs +1 -1
  77. package/dist/locale/fa.js +1 -1
  78. package/dist/locale/fa.min.js +1 -1
  79. package/dist/locale/fa.min.mjs +1 -1
  80. package/dist/locale/fa.mjs +1 -1
  81. package/dist/locale/fi.js +1 -1
  82. package/dist/locale/fi.min.js +1 -1
  83. package/dist/locale/fi.min.mjs +1 -1
  84. package/dist/locale/fi.mjs +1 -1
  85. package/dist/locale/fr.js +1 -1
  86. package/dist/locale/fr.min.js +1 -1
  87. package/dist/locale/fr.min.mjs +1 -1
  88. package/dist/locale/fr.mjs +1 -1
  89. package/dist/locale/he.js +1 -1
  90. package/dist/locale/he.min.js +1 -1
  91. package/dist/locale/he.min.mjs +1 -1
  92. package/dist/locale/he.mjs +1 -1
  93. package/dist/locale/hi.js +1 -1
  94. package/dist/locale/hi.min.js +1 -1
  95. package/dist/locale/hi.min.mjs +1 -1
  96. package/dist/locale/hi.mjs +1 -1
  97. package/dist/locale/hr.js +1 -1
  98. package/dist/locale/hr.min.js +1 -1
  99. package/dist/locale/hr.min.mjs +1 -1
  100. package/dist/locale/hr.mjs +1 -1
  101. package/dist/locale/hu.js +1 -1
  102. package/dist/locale/hu.min.js +1 -1
  103. package/dist/locale/hu.min.mjs +1 -1
  104. package/dist/locale/hu.mjs +1 -1
  105. package/dist/locale/hy-am.js +1 -1
  106. package/dist/locale/hy-am.min.js +1 -1
  107. package/dist/locale/hy-am.min.mjs +1 -1
  108. package/dist/locale/hy-am.mjs +1 -1
  109. package/dist/locale/id.js +1 -1
  110. package/dist/locale/id.min.js +1 -1
  111. package/dist/locale/id.min.mjs +1 -1
  112. package/dist/locale/id.mjs +1 -1
  113. package/dist/locale/it.js +1 -1
  114. package/dist/locale/it.min.js +1 -1
  115. package/dist/locale/it.min.mjs +1 -1
  116. package/dist/locale/it.mjs +1 -1
  117. package/dist/locale/ja.js +1 -1
  118. package/dist/locale/ja.min.js +1 -1
  119. package/dist/locale/ja.min.mjs +1 -1
  120. package/dist/locale/ja.mjs +1 -1
  121. package/dist/locale/kk.js +1 -1
  122. package/dist/locale/kk.min.js +1 -1
  123. package/dist/locale/kk.min.mjs +1 -1
  124. package/dist/locale/kk.mjs +1 -1
  125. package/dist/locale/km.js +1 -1
  126. package/dist/locale/km.min.js +1 -1
  127. package/dist/locale/km.min.mjs +1 -1
  128. package/dist/locale/km.mjs +1 -1
  129. package/dist/locale/ko.js +1 -1
  130. package/dist/locale/ko.min.js +1 -1
  131. package/dist/locale/ko.min.mjs +1 -1
  132. package/dist/locale/ko.mjs +1 -1
  133. package/dist/locale/ku.js +1 -1
  134. package/dist/locale/ku.min.js +1 -1
  135. package/dist/locale/ku.min.mjs +1 -1
  136. package/dist/locale/ku.mjs +1 -1
  137. package/dist/locale/ky.js +1 -1
  138. package/dist/locale/ky.min.js +1 -1
  139. package/dist/locale/ky.min.mjs +1 -1
  140. package/dist/locale/ky.mjs +1 -1
  141. package/dist/locale/lo.js +1 -1
  142. package/dist/locale/lo.min.js +1 -1
  143. package/dist/locale/lo.min.mjs +1 -1
  144. package/dist/locale/lo.mjs +1 -1
  145. package/dist/locale/lt.js +1 -1
  146. package/dist/locale/lt.min.js +1 -1
  147. package/dist/locale/lt.min.mjs +1 -1
  148. package/dist/locale/lt.mjs +1 -1
  149. package/dist/locale/lv.js +1 -1
  150. package/dist/locale/lv.min.js +1 -1
  151. package/dist/locale/lv.min.mjs +1 -1
  152. package/dist/locale/lv.mjs +1 -1
  153. package/dist/locale/mg.js +1 -1
  154. package/dist/locale/mg.min.js +1 -1
  155. package/dist/locale/mg.min.mjs +1 -1
  156. package/dist/locale/mg.mjs +1 -1
  157. package/dist/locale/mn.js +1 -1
  158. package/dist/locale/mn.min.js +1 -1
  159. package/dist/locale/mn.min.mjs +1 -1
  160. package/dist/locale/mn.mjs +1 -1
  161. package/dist/locale/ms.js +1 -1
  162. package/dist/locale/ms.min.js +1 -1
  163. package/dist/locale/ms.min.mjs +1 -1
  164. package/dist/locale/ms.mjs +1 -1
  165. package/dist/locale/my.js +1 -1
  166. package/dist/locale/my.min.js +1 -1
  167. package/dist/locale/my.min.mjs +1 -1
  168. package/dist/locale/my.mjs +1 -1
  169. package/dist/locale/nb-no.js +1 -1
  170. package/dist/locale/nb-no.min.js +1 -1
  171. package/dist/locale/nb-no.min.mjs +1 -1
  172. package/dist/locale/nb-no.mjs +1 -1
  173. package/dist/locale/nl.js +1 -1
  174. package/dist/locale/nl.min.js +1 -1
  175. package/dist/locale/nl.min.mjs +1 -1
  176. package/dist/locale/nl.mjs +1 -1
  177. package/dist/locale/no.js +1 -1
  178. package/dist/locale/no.min.js +1 -1
  179. package/dist/locale/no.min.mjs +1 -1
  180. package/dist/locale/no.mjs +1 -1
  181. package/dist/locale/pa.js +1 -1
  182. package/dist/locale/pa.min.js +1 -1
  183. package/dist/locale/pa.min.mjs +1 -1
  184. package/dist/locale/pa.mjs +1 -1
  185. package/dist/locale/pl.js +1 -1
  186. package/dist/locale/pl.min.js +1 -1
  187. package/dist/locale/pl.min.mjs +1 -1
  188. package/dist/locale/pl.mjs +1 -1
  189. package/dist/locale/pt-br.js +1 -1
  190. package/dist/locale/pt-br.min.js +1 -1
  191. package/dist/locale/pt-br.min.mjs +1 -1
  192. package/dist/locale/pt-br.mjs +1 -1
  193. package/dist/locale/pt.js +1 -1
  194. package/dist/locale/pt.min.js +1 -1
  195. package/dist/locale/pt.min.mjs +1 -1
  196. package/dist/locale/pt.mjs +1 -1
  197. package/dist/locale/ro.js +1 -1
  198. package/dist/locale/ro.min.js +1 -1
  199. package/dist/locale/ro.min.mjs +1 -1
  200. package/dist/locale/ro.mjs +1 -1
  201. package/dist/locale/ru.js +1 -1
  202. package/dist/locale/ru.min.js +1 -1
  203. package/dist/locale/ru.min.mjs +1 -1
  204. package/dist/locale/ru.mjs +1 -1
  205. package/dist/locale/sk.js +1 -1
  206. package/dist/locale/sk.min.js +1 -1
  207. package/dist/locale/sk.min.mjs +1 -1
  208. package/dist/locale/sk.mjs +1 -1
  209. package/dist/locale/sl.js +1 -1
  210. package/dist/locale/sl.min.js +1 -1
  211. package/dist/locale/sl.min.mjs +1 -1
  212. package/dist/locale/sl.mjs +1 -1
  213. package/dist/locale/sr.js +1 -1
  214. package/dist/locale/sr.min.js +1 -1
  215. package/dist/locale/sr.min.mjs +1 -1
  216. package/dist/locale/sr.mjs +1 -1
  217. package/dist/locale/sv.js +1 -1
  218. package/dist/locale/sv.min.js +1 -1
  219. package/dist/locale/sv.min.mjs +1 -1
  220. package/dist/locale/sv.mjs +1 -1
  221. package/dist/locale/sw.js +1 -1
  222. package/dist/locale/sw.min.js +1 -1
  223. package/dist/locale/sw.min.mjs +1 -1
  224. package/dist/locale/sw.mjs +1 -1
  225. package/dist/locale/ta.js +1 -1
  226. package/dist/locale/ta.min.js +1 -1
  227. package/dist/locale/ta.min.mjs +1 -1
  228. package/dist/locale/ta.mjs +1 -1
  229. package/dist/locale/te.js +1 -1
  230. package/dist/locale/te.min.js +1 -1
  231. package/dist/locale/te.min.mjs +1 -1
  232. package/dist/locale/te.mjs +1 -1
  233. package/dist/locale/th.js +1 -1
  234. package/dist/locale/th.min.js +1 -1
  235. package/dist/locale/th.min.mjs +1 -1
  236. package/dist/locale/th.mjs +1 -1
  237. package/dist/locale/tk.js +1 -1
  238. package/dist/locale/tk.min.js +1 -1
  239. package/dist/locale/tk.min.mjs +1 -1
  240. package/dist/locale/tk.mjs +1 -1
  241. package/dist/locale/tr.js +1 -1
  242. package/dist/locale/tr.min.js +1 -1
  243. package/dist/locale/tr.min.mjs +1 -1
  244. package/dist/locale/tr.mjs +1 -1
  245. package/dist/locale/ug-cn.js +1 -1
  246. package/dist/locale/ug-cn.min.js +1 -1
  247. package/dist/locale/ug-cn.min.mjs +1 -1
  248. package/dist/locale/ug-cn.mjs +1 -1
  249. package/dist/locale/uk.js +1 -1
  250. package/dist/locale/uk.min.js +1 -1
  251. package/dist/locale/uk.min.mjs +1 -1
  252. package/dist/locale/uk.mjs +1 -1
  253. package/dist/locale/uz-uz.js +1 -1
  254. package/dist/locale/uz-uz.min.js +1 -1
  255. package/dist/locale/uz-uz.min.mjs +1 -1
  256. package/dist/locale/uz-uz.mjs +1 -1
  257. package/dist/locale/vi.js +1 -1
  258. package/dist/locale/vi.min.js +1 -1
  259. package/dist/locale/vi.min.mjs +1 -1
  260. package/dist/locale/vi.mjs +1 -1
  261. package/dist/locale/zh-cn.js +1 -1
  262. package/dist/locale/zh-cn.min.js +1 -1
  263. package/dist/locale/zh-cn.min.mjs +1 -1
  264. package/dist/locale/zh-cn.mjs +1 -1
  265. package/dist/locale/zh-hk.js +1 -1
  266. package/dist/locale/zh-hk.min.js +1 -1
  267. package/dist/locale/zh-hk.min.mjs +1 -1
  268. package/dist/locale/zh-hk.mjs +1 -1
  269. package/dist/locale/zh-mo.js +1 -1
  270. package/dist/locale/zh-mo.min.js +1 -1
  271. package/dist/locale/zh-mo.min.mjs +1 -1
  272. package/dist/locale/zh-mo.mjs +1 -1
  273. package/dist/locale/zh-tw.js +1 -1
  274. package/dist/locale/zh-tw.min.js +1 -1
  275. package/dist/locale/zh-tw.min.mjs +1 -1
  276. package/dist/locale/zh-tw.mjs +1 -1
  277. package/es/components/date-picker/src/date-picker.d.ts +3 -0
  278. package/es/components/date-picker/src/props.d.ts +1 -0
  279. package/es/components/date-picker-panel/src/date-picker-com/panel-date-range.mjs.map +1 -1
  280. package/es/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.mjs +16 -8
  281. package/es/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  282. package/es/components/date-picker-panel/src/date-picker-com/panel-month-range.mjs.map +1 -1
  283. package/es/components/date-picker-panel/src/date-picker-com/panel-month-range.vue_vue_type_script_setup_true_lang.mjs +16 -6
  284. package/es/components/date-picker-panel/src/date-picker-com/panel-month-range.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  285. package/es/components/date-picker-panel/src/date-picker-com/panel-year-range.mjs.map +1 -1
  286. package/es/components/date-picker-panel/src/date-picker-com/panel-year-range.vue_vue_type_script_setup_true_lang.mjs +12 -6
  287. package/es/components/date-picker-panel/src/date-picker-com/panel-year-range.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  288. package/es/components/date-picker-panel/src/props/shared.mjs +2 -1
  289. package/es/components/date-picker-panel/src/props/shared.mjs.map +1 -1
  290. package/es/components/time-picker/src/common/picker.mjs.map +1 -1
  291. package/es/components/time-picker/src/common/picker.vue.d.ts +4 -0
  292. package/es/components/time-picker/src/common/picker.vue_vue_type_script_setup_true_lang.mjs +1 -0
  293. package/es/components/time-picker/src/common/picker.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  294. package/es/components/time-picker/src/common/props.d.ts +1 -0
  295. package/es/components/time-picker/src/common/props.mjs +1 -0
  296. package/es/components/time-picker/src/common/props.mjs.map +1 -1
  297. package/es/components/time-picker/src/time-picker.d.ts +3 -0
  298. package/es/version.mjs +1 -1
  299. package/es/version.mjs.map +1 -1
  300. package/lib/components/date-picker/src/date-picker.d.ts +3 -0
  301. package/lib/components/date-picker/src/props.d.ts +1 -0
  302. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-range.js.map +1 -1
  303. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.js +16 -8
  304. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.js.map +1 -1
  305. package/lib/components/date-picker-panel/src/date-picker-com/panel-month-range.js.map +1 -1
  306. package/lib/components/date-picker-panel/src/date-picker-com/panel-month-range.vue_vue_type_script_setup_true_lang.js +16 -6
  307. package/lib/components/date-picker-panel/src/date-picker-com/panel-month-range.vue_vue_type_script_setup_true_lang.js.map +1 -1
  308. package/lib/components/date-picker-panel/src/date-picker-com/panel-year-range.js.map +1 -1
  309. package/lib/components/date-picker-panel/src/date-picker-com/panel-year-range.vue_vue_type_script_setup_true_lang.js +12 -6
  310. package/lib/components/date-picker-panel/src/date-picker-com/panel-year-range.vue_vue_type_script_setup_true_lang.js.map +1 -1
  311. package/lib/components/date-picker-panel/src/props/shared.js +2 -1
  312. package/lib/components/date-picker-panel/src/props/shared.js.map +1 -1
  313. package/lib/components/time-picker/src/common/picker.js.map +1 -1
  314. package/lib/components/time-picker/src/common/picker.vue.d.ts +4 -0
  315. package/lib/components/time-picker/src/common/picker.vue_vue_type_script_setup_true_lang.js +1 -0
  316. package/lib/components/time-picker/src/common/picker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  317. package/lib/components/time-picker/src/common/props.d.ts +1 -0
  318. package/lib/components/time-picker/src/common/props.js +1 -0
  319. package/lib/components/time-picker/src/common/props.js.map +1 -1
  320. package/lib/components/time-picker/src/time-picker.d.ts +3 -0
  321. package/lib/version.js +1 -1
  322. package/lib/version.js.map +1 -1
  323. package/package.json +3 -3
  324. package/tags.json +1 -1
  325. package/theme-chalk/el-date-picker-panel.css +1 -1
  326. package/theme-chalk/index.css +1 -1
  327. package/theme-chalk/src/date-picker/date-range-picker.scss +24 -0
  328. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"version.mjs","names":[],"sources":["../../../packages/element-plus/version.ts"],"sourcesContent":["export const version = '0.0.20260410'\n"],"mappings":";AAAA,MAAa,UAAU"}
1
+ {"version":3,"file":"version.mjs","names":[],"sources":["../../../packages/element-plus/version.ts"],"sourcesContent":["export const version = '0.0.20260411'\n"],"mappings":";AAAA,MAAa,UAAU"}
@@ -36,6 +36,7 @@ declare const _default: vue.DefineComponent<vue.ExtractPropTypes<{
36
36
  readonly tabindex: EpPropFinalized<(new (...args: any[]) => string | number) | (() => string | number) | (((new (...args: any[]) => string | number) | (() => string | number)) | null)[], unknown, unknown, 0, boolean>;
37
37
  readonly validateEvent: EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
38
38
  readonly unlinkPanels: BooleanConstructor;
39
+ readonly singlePanel: BooleanConstructor;
39
40
  readonly placement: EpPropFinalized<(new (...args: any[]) => "top" | "auto" | "bottom" | "left" | "right" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement) | (((new (...args: any[]) => "top" | "auto" | "bottom" | "left" | "right" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement)) | null)[], Placement, unknown, "bottom", boolean>;
40
41
  readonly fallbackPlacements: EpPropFinalized<(new (...args: any[]) => Placement[]) | (() => Placement[]) | (((new (...args: any[]) => Placement[]) | (() => Placement[])) | null)[], unknown, unknown, readonly ["bottom", "top", "right", "left"], boolean>;
41
42
  readonly disabledHours: {
@@ -239,6 +240,7 @@ declare const _default: vue.DefineComponent<vue.ExtractPropTypes<{
239
240
  readonly tabindex: EpPropFinalized<(new (...args: any[]) => string | number) | (() => string | number) | (((new (...args: any[]) => string | number) | (() => string | number)) | null)[], unknown, unknown, 0, boolean>;
240
241
  readonly validateEvent: EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
241
242
  readonly unlinkPanels: BooleanConstructor;
243
+ readonly singlePanel: BooleanConstructor;
242
244
  readonly placement: EpPropFinalized<(new (...args: any[]) => "top" | "auto" | "bottom" | "left" | "right" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement) | (((new (...args: any[]) => "top" | "auto" | "bottom" | "left" | "right" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement)) | null)[], Placement, unknown, "bottom", boolean>;
243
245
  readonly fallbackPlacements: EpPropFinalized<(new (...args: any[]) => Placement[]) | (() => Placement[]) | (((new (...args: any[]) => Placement[]) | (() => Placement[])) | null)[], unknown, unknown, readonly ["bottom", "top", "right", "left"], boolean>;
244
246
  readonly disabledHours: {
@@ -444,6 +446,7 @@ declare const _default: vue.DefineComponent<vue.ExtractPropTypes<{
444
446
  readonly showWeekNumber: boolean;
445
447
  readonly arrowControl: boolean;
446
448
  readonly unlinkPanels: boolean;
449
+ readonly singlePanel: boolean;
447
450
  readonly isRange: boolean;
448
451
  }, {}, {}, {}, string, vue.ComponentProvideOptions, true, {}, any>;
449
452
  //#endregion
@@ -35,6 +35,7 @@ declare const datePickerProps: {
35
35
  readonly tabindex: EpPropFinalized<(new (...args: any[]) => string | number) | (() => string | number) | (((new (...args: any[]) => string | number) | (() => string | number)) | null)[], unknown, unknown, 0, boolean>;
36
36
  readonly validateEvent: EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
37
37
  readonly unlinkPanels: BooleanConstructor;
38
+ readonly singlePanel: BooleanConstructor;
38
39
  readonly placement: EpPropFinalized<(new (...args: any[]) => "top" | "auto" | "bottom" | "left" | "right" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement) | (((new (...args: any[]) => "top" | "auto" | "bottom" | "left" | "right" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement)) | null)[], Placement, unknown, "bottom", boolean>;
39
40
  readonly fallbackPlacements: EpPropFinalized<(new (...args: any[]) => Placement[]) | (() => Placement[]) | (((new (...args: any[]) => Placement[]) | (() => Placement[])) | null)[], unknown, unknown, readonly ["bottom", "top", "right", "left"], boolean>;
40
41
  readonly disabledHours: {
@@ -1 +1 @@
1
- {"version":3,"file":"panel-date-range.js","names":[],"sources":["../../../../../../../packages/components/date-picker-panel/src/date-picker-com/panel-date-range.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ppNs.b(),\n drpNs.b(),\n ppNs.is('border', border),\n ppNs.is('disabled', dateRangeDisabled),\n {\n 'has-sidebar': $slots.sidebar || hasShortcuts,\n 'has-time': showTime,\n },\n ]\"\n >\n <div :class=\"ppNs.e('body-wrapper')\">\n <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n <button\n v-for=\"(shortcut, key) in shortcuts\"\n :key=\"key\"\n type=\"button\"\n :disabled=\"dateRangeDisabled\"\n :class=\"ppNs.e('shortcut')\"\n @click=\"handleShortcutClick(shortcut)\"\n >\n {{ shortcut.text }}\n </button>\n </div>\n <div :class=\"ppNs.e('body')\">\n <div v-if=\"showTime\" :class=\"drpNs.e('time-header')\">\n <span :class=\"drpNs.e('editors-wrap')\">\n <span :class=\"drpNs.e('time-picker-wrap')\">\n <el-input\n size=\"small\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.startDate')\"\n :class=\"drpNs.e('editor')\"\n :model-value=\"minVisibleDate\"\n :validate-event=\"false\"\n :readonly=\"!editable\"\n @input=\"(val) => handleDateInput(val, 'min')\"\n @change=\"(val) => handleDateChange(val, 'min')\"\n />\n </span>\n <span\n v-clickoutside=\"handleMinTimeClose\"\n :class=\"drpNs.e('time-picker-wrap')\"\n >\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.startTime')\"\n :model-value=\"minVisibleTime\"\n :validate-event=\"false\"\n :readonly=\"!editable\"\n @focus=\"minTimePickerVisible = true\"\n @input=\"(val) => handleTimeInput(val, 'min')\"\n @change=\"(val) => handleTimeChange(val, 'min')\"\n />\n <time-pick-panel\n :visible=\"minTimePickerVisible\"\n :format=\"timeFormat\"\n datetime-role=\"start\"\n :parsed-value=\"minDate || leftDate\"\n @pick=\"handleMinTimePick\"\n />\n </span>\n </span>\n <span>\n <el-icon><arrow-right /></el-icon>\n </span>\n <span :class=\"drpNs.e('editors-wrap')\" class=\"is-right\">\n <span :class=\"drpNs.e('time-picker-wrap')\">\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.endDate')\"\n :model-value=\"maxVisibleDate\"\n :readonly=\"!minDate || !editable\"\n :validate-event=\"false\"\n @input=\"(val) => handleDateInput(val, 'max')\"\n @change=\"(val) => handleDateChange(val, 'max')\"\n />\n </span>\n <span\n v-clickoutside=\"handleMaxTimeClose\"\n :class=\"drpNs.e('time-picker-wrap')\"\n >\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.endTime')\"\n :model-value=\"maxVisibleTime\"\n :readonly=\"!minDate || !editable\"\n :validate-event=\"false\"\n @focus=\"minDate && (maxTimePickerVisible = true)\"\n @input=\"(val) => handleTimeInput(val, 'max')\"\n @change=\"(val) => handleTimeChange(val, 'max')\"\n />\n <time-pick-panel\n datetime-role=\"end\"\n :visible=\"maxTimePickerVisible\"\n :format=\"timeFormat\"\n :parsed-value=\"maxDate || rightDate\"\n @pick=\"handleMaxTimePick\"\n />\n </span>\n </span>\n </div>\n <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-left\">\n <div :class=\"drpNs.e('header')\">\n <button\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :aria-label=\"t(`el.datepicker.prevYear`)\"\n class=\"d-arrow-left\"\n :disabled=\"dateRangeDisabled\"\n @click=\"leftPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon>\n <d-arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-show=\"leftCurrentView === 'date'\"\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :aria-label=\"t(`el.datepicker.prevMonth`)\"\n class=\"arrow-left\"\n :disabled=\"dateRangeDisabled\"\n @click=\"leftPrevMonth\"\n >\n <slot name=\"prev-month\">\n <el-icon>\n <arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.nextYear`)\"\n class=\"d-arrow-right\"\n @click=\"leftNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon>\n <d-arrow-right />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels && leftCurrentView === 'date'\"\n type=\"button\"\n :disabled=\"!enableMonthArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableMonthArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.nextMonth`)\"\n class=\"arrow-right\"\n @click=\"leftNextMonth\"\n >\n <slot name=\"next-month\">\n <el-icon>\n <arrow-right />\n </el-icon>\n </slot>\n </button>\n <div>\n <span\n role=\"button\"\n :class=\"drpNs.e('header-label')\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n @keydown.enter=\"showLeftPicker('year')\"\n @click=\"showLeftPicker('year')\"\n >\n {{ leftYearLabel }}\n </span>\n <span\n v-show=\"leftCurrentView === 'date'\"\n role=\"button\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n :class=\"[\n drpNs.e('header-label'),\n { active: leftCurrentView === 'month' },\n ]\"\n @keydown.enter=\"showLeftPicker('month')\"\n @click=\"showLeftPicker('month')\"\n >\n {{ t(`el.datepicker.month${leftDate.month() + 1}`) }}\n </span>\n </div>\n </div>\n <date-table\n v-if=\"leftCurrentView === 'date'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"range\"\n :date=\"leftDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :cell-class-name=\"cellClassName\"\n :show-week-number=\"showWeekNumber\"\n :disabled=\"dateRangeDisabled\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n <year-table\n v-if=\"leftCurrentView === 'year'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"year\"\n :date=\"leftDate\"\n :disabled-date=\"disabledDate\"\n :parsed-value=\"parsedValue\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleLeftYearPick\"\n />\n <month-table\n v-if=\"leftCurrentView === 'month'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"month\"\n :date=\"leftDate\"\n :parsed-value=\"parsedValue\"\n :disabled-date=\"disabledDate\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleLeftMonthPick\"\n />\n </div>\n <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-right\">\n <div :class=\"drpNs.e('header')\">\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.prevYear`)\"\n class=\"d-arrow-left\"\n @click=\"rightPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon>\n <d-arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels && rightCurrentView === 'date'\"\n type=\"button\"\n :disabled=\"!enableMonthArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableMonthArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.prevMonth`)\"\n class=\"arrow-left\"\n @click=\"rightPrevMonth\"\n >\n <slot name=\"prev-month\">\n <el-icon>\n <arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n type=\"button\"\n :aria-label=\"t(`el.datepicker.nextYear`)\"\n :class=\"ppNs.e('icon-btn')\"\n :disabled=\"dateRangeDisabled\"\n class=\"d-arrow-right\"\n @click=\"rightNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon>\n <d-arrow-right />\n </el-icon>\n </slot>\n </button>\n <button\n v-show=\"rightCurrentView === 'date'\"\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :disabled=\"dateRangeDisabled\"\n :aria-label=\"t(`el.datepicker.nextMonth`)\"\n class=\"arrow-right\"\n @click=\"rightNextMonth\"\n >\n <slot name=\"next-month\">\n <el-icon>\n <arrow-right />\n </el-icon>\n </slot>\n </button>\n <div>\n <span\n role=\"button\"\n :class=\"drpNs.e('header-label')\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n @keydown.enter=\"showRightPicker('year')\"\n @click=\"showRightPicker('year')\"\n >\n {{ rightYearLabel }}\n </span>\n <span\n v-show=\"rightCurrentView === 'date'\"\n role=\"button\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n :class=\"[\n drpNs.e('header-label'),\n { active: rightCurrentView === 'month' },\n ]\"\n @keydown.enter=\"showRightPicker('month')\"\n @click=\"showRightPicker('month')\"\n >\n {{ t(`el.datepicker.month${rightDate.month() + 1}`) }}\n </span>\n </div>\n </div>\n <date-table\n v-if=\"rightCurrentView === 'date'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"range\"\n :date=\"rightDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :cell-class-name=\"cellClassName\"\n :show-week-number=\"showWeekNumber\"\n :disabled=\"dateRangeDisabled\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n <year-table\n v-if=\"rightCurrentView === 'year'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"year\"\n :date=\"rightDate\"\n :disabled-date=\"disabledDate\"\n :parsed-value=\"parsedValue\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleRightYearPick\"\n />\n <month-table\n v-if=\"rightCurrentView === 'month'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"month\"\n :date=\"rightDate\"\n :parsed-value=\"parsedValue\"\n :disabled-date=\"disabledDate\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleRightMonthPick\"\n />\n </div>\n </div>\n </div>\n <div\n v-if=\"showFooter && showTime && (showConfirm || clearable)\"\n :class=\"ppNs.e('footer')\"\n >\n <el-button\n v-if=\"clearable\"\n text\n size=\"small\"\n :class=\"ppNs.e('link-btn')\"\n @click=\"onClear\"\n >\n {{ t('el.datepicker.clear') }}\n </el-button>\n <el-button\n v-if=\"showConfirm\"\n plain\n size=\"small\"\n :class=\"ppNs.e('link-btn')\"\n :disabled=\"btnDisabled\"\n @click=\"handleRangeConfirm(false)\"\n >\n {{ t('el.datepicker.confirm') }}\n </el-button>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, nextTick, ref, toRef, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport { useLocale } from '@element-plus/hooks'\nimport ElButton from '@element-plus/components/button'\nimport ElInput from '@element-plus/components/input'\nimport {\n DEFAULT_FORMATS_DATE,\n DEFAULT_FORMATS_TIME,\n PICKER_BASE_INJECTION_KEY,\n TimePickPanel,\n extractDateFormat,\n extractTimeFormat,\n} from '@element-plus/components/time-picker'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n ArrowLeft,\n ArrowRight,\n DArrowLeft,\n DArrowRight,\n} from '@element-plus/icons-vue'\nimport { panelDateRangeProps } from '../props/panel-date-range'\nimport { useRangePicker } from '../composables/use-range-picker'\nimport {\n correctlyParseUserInput,\n getDefaultValue,\n isValidRange,\n} from '../utils'\nimport { usePanelDateRange } from '../composables/use-panel-date-range'\nimport { ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY } from '../constants'\nimport YearTable from './basic-year-table.vue'\nimport MonthTable from './basic-month-table.vue'\nimport DateTable from './basic-date-table.vue'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { Ref } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\ntype ChangeType = 'min' | 'max'\ntype UserInput = {\n min: string | null\n max: string | null\n}\n\nconst props = defineProps(panelDateRangeProps)\nconst emit = defineEmits([\n 'pick',\n 'set-picker-option',\n 'calendar-change',\n 'panel-change',\n 'clear',\n])\n\nconst unit = 'month'\n// FIXME: fix the type for ep picker\nconst pickerBase = inject(PICKER_BASE_INJECTION_KEY) as any\nconst isDefaultFormat = inject(\n ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY,\n undefined\n) as any\nconst { disabledDate, cellClassName, defaultTime, clearable } = pickerBase.props\nconst format: Ref<string | undefined> = toRef(pickerBase.props, 'format')\nconst shortcuts = toRef(pickerBase.props, 'shortcuts')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst { lang } = useLocale()\nconst leftDate = ref<Dayjs>(dayjs().locale(lang.value))\nconst rightDate = ref<Dayjs>(dayjs().locale(lang.value).add(1, unit))\n\nconst {\n minDate,\n maxDate,\n rangeState,\n ppNs,\n drpNs,\n handleChangeRange,\n handleRangeConfirm,\n handleShortcutClick,\n onSelect,\n parseValue,\n t,\n} = useRangePicker(props, {\n defaultValue,\n defaultTime,\n leftDate,\n rightDate,\n unit,\n sortDates,\n})\n\nwatch(\n () => props.visible,\n (visible) => {\n if (!visible && rangeState.value.selecting) {\n parseValue(props.parsedValue)\n onSelect(false)\n }\n }\n)\n\nconst dateUserInput = ref<UserInput>({\n min: null,\n max: null,\n})\n\nconst timeUserInput = ref<UserInput>({\n min: null,\n max: null,\n})\n\nconst {\n leftCurrentView,\n rightCurrentView,\n leftCurrentViewRef,\n rightCurrentViewRef,\n leftYear,\n rightYear,\n leftMonth,\n rightMonth,\n leftYearLabel,\n rightYearLabel,\n showLeftPicker,\n showRightPicker,\n handleLeftYearPick,\n handleRightYearPick,\n handleLeftMonthPick,\n handleRightMonthPick,\n handlePanelChange,\n adjustDateByView,\n} = usePanelDateRange(props, emit, leftDate, rightDate)\n\nconst hasShortcuts = computed(() => !!shortcuts.value.length)\n\nconst minVisibleDate = computed(() => {\n if (dateUserInput.value.min !== null) return dateUserInput.value.min\n if (minDate.value) return minDate.value.format(dateFormat.value)\n return ''\n})\n\nconst maxVisibleDate = computed(() => {\n if (dateUserInput.value.max !== null) return dateUserInput.value.max\n if (maxDate.value || minDate.value)\n return (maxDate.value || minDate.value)!.format(dateFormat.value)\n return ''\n})\n\nconst minVisibleTime = computed(() => {\n if (timeUserInput.value.min !== null) return timeUserInput.value.min\n if (minDate.value) return minDate.value.format(timeFormat.value)\n return ''\n})\n\nconst maxVisibleTime = computed(() => {\n if (timeUserInput.value.max !== null) return timeUserInput.value.max\n if (maxDate.value || minDate.value)\n return (maxDate.value || minDate.value)!.format(timeFormat.value)\n return ''\n})\n\nconst timeFormat = computed(() => {\n return (\n props.timeFormat ||\n extractTimeFormat(format.value || '') ||\n DEFAULT_FORMATS_TIME\n )\n})\n\nconst dateFormat = computed(() => {\n return (\n props.dateFormat ||\n extractDateFormat(format.value || '') ||\n DEFAULT_FORMATS_DATE\n )\n})\n\nconst isValidValue = (date: [Dayjs, Dayjs]) => {\n return (\n isValidRange(date) &&\n (disabledDate\n ? !disabledDate(date[0].toDate()) && !disabledDate(date[1].toDate())\n : true)\n )\n}\n\nconst leftPrevYear = () => {\n leftDate.value = adjustDateByView(\n leftCurrentView.value,\n leftDate.value,\n false\n )\n\n if (!props.unlinkPanels) {\n rightDate.value = leftDate.value.add(1, 'month')\n }\n handlePanelChange('year')\n}\n\nconst leftPrevMonth = () => {\n leftDate.value = leftDate.value.subtract(1, 'month')\n if (!props.unlinkPanels) {\n rightDate.value = leftDate.value.add(1, 'month')\n }\n handlePanelChange('month')\n}\n\nconst rightNextYear = () => {\n if (!props.unlinkPanels) {\n leftDate.value = adjustDateByView(\n rightCurrentView.value,\n leftDate.value,\n true\n )\n\n rightDate.value = leftDate.value.add(1, 'month')\n } else {\n rightDate.value = adjustDateByView(\n rightCurrentView.value,\n rightDate.value,\n true\n )\n }\n handlePanelChange('year')\n}\n\nconst rightNextMonth = () => {\n if (!props.unlinkPanels) {\n leftDate.value = leftDate.value.add(1, 'month')\n rightDate.value = leftDate.value.add(1, 'month')\n } else {\n rightDate.value = rightDate.value.add(1, 'month')\n }\n handlePanelChange('month')\n}\n\nconst leftNextYear = () => {\n leftDate.value = adjustDateByView(leftCurrentView.value, leftDate.value, true)\n\n handlePanelChange('year')\n}\n\nconst leftNextMonth = () => {\n leftDate.value = leftDate.value.add(1, 'month')\n handlePanelChange('month')\n}\n\nconst rightPrevYear = () => {\n rightDate.value = adjustDateByView(\n rightCurrentView.value,\n rightDate.value,\n false\n )\n\n handlePanelChange('year')\n}\n\nconst rightPrevMonth = () => {\n rightDate.value = rightDate.value.subtract(1, 'month')\n handlePanelChange('month')\n}\n\nconst enableMonthArrow = computed(() => {\n const nextMonth = (leftMonth.value + 1) % 12\n const yearOffset = leftMonth.value + 1 >= 12 ? 1 : 0\n return (\n props.unlinkPanels &&\n new Date(leftYear.value + yearOffset, nextMonth) <\n new Date(rightYear.value, rightMonth.value)\n )\n})\n\nconst enableYearArrow = computed(() => {\n return (\n props.unlinkPanels &&\n rightYear.value * 12 +\n rightMonth.value -\n (leftYear.value * 12 + leftMonth.value + 1) >=\n 12\n )\n})\n\nconst dateRangeDisabled = useFormDisabled()\n\nconst btnDisabled = computed(() => {\n return !(\n minDate.value &&\n maxDate.value &&\n !rangeState.value.selecting &&\n isValidRange([minDate.value, maxDate.value]) &&\n !dateRangeDisabled.value\n )\n})\n\nconst showTime = computed(\n () => props.type === 'datetime' || props.type === 'datetimerange'\n)\n\nconst formatEmit = (emitDayjs: Dayjs | null, index?: number) => {\n if (!emitDayjs) return\n if (defaultTime) {\n const defaultTimeD = dayjs(\n defaultTime[index as number] || defaultTime\n ).locale(lang.value)\n return defaultTimeD\n .year(emitDayjs.year())\n .month(emitDayjs.month())\n .date(emitDayjs.date())\n }\n return emitDayjs\n}\n\nconst handleRangePick = (\n val: {\n minDate: Dayjs\n maxDate: Dayjs | null\n },\n close = true\n) => {\n const min_ = val.minDate\n const max_ = val.maxDate\n const minDate_ = formatEmit(min_, 0)\n const maxDate_ = formatEmit(max_, 1)\n\n if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n return\n }\n emit('calendar-change', [min_.toDate(), max_ && max_.toDate()])\n maxDate.value = maxDate_\n minDate.value = minDate_\n\n if (!showTime.value && close) {\n close = !minDate_ || !maxDate_\n }\n handleRangeConfirm(close)\n}\n\nconst minTimePickerVisible = ref(false)\nconst maxTimePickerVisible = ref(false)\n\nconst handleMinTimeClose = () => {\n minTimePickerVisible.value = false\n}\n\nconst handleMaxTimeClose = () => {\n maxTimePickerVisible.value = false\n}\n\nconst handleDateInput = (value: string | null, type: ChangeType) => {\n dateUserInput.value[type] = value\n const parsedValueD = dayjs(value, dateFormat.value).locale(lang.value)\n if (parsedValueD.isValid()) {\n if (disabledDate && disabledDate(parsedValueD.toDate())) {\n return\n }\n if (type === 'min') {\n leftDate.value = parsedValueD\n minDate.value = (minDate.value || leftDate.value)\n .year(parsedValueD.year())\n .month(parsedValueD.month())\n .date(parsedValueD.date())\n if (\n !props.unlinkPanels &&\n (!maxDate.value || maxDate.value.isBefore(minDate.value))\n ) {\n rightDate.value = parsedValueD.add(1, 'month')\n maxDate.value = minDate.value.add(1, 'month')\n }\n } else {\n rightDate.value = parsedValueD\n maxDate.value = (maxDate.value || rightDate.value)\n .year(parsedValueD.year())\n .month(parsedValueD.month())\n .date(parsedValueD.date())\n if (\n !props.unlinkPanels &&\n (!minDate.value || minDate.value.isAfter(maxDate.value))\n ) {\n leftDate.value = parsedValueD.subtract(1, 'month')\n minDate.value = maxDate.value.subtract(1, 'month')\n }\n }\n sortDates(minDate.value, maxDate.value)\n handleRangeConfirm(true)\n }\n}\n\nconst handleDateChange = (_: unknown, type: ChangeType) => {\n dateUserInput.value[type] = null\n}\n\nconst handleTimeInput = (value: string | null, type: ChangeType) => {\n timeUserInput.value[type] = value\n const parsedValueD = dayjs(value, timeFormat.value).locale(lang.value)\n\n if (parsedValueD.isValid()) {\n if (type === 'min') {\n minTimePickerVisible.value = true\n minDate.value = (minDate.value || leftDate.value)\n .hour(parsedValueD.hour())\n .minute(parsedValueD.minute())\n .second(parsedValueD.second())\n leftDate.value = minDate.value\n } else {\n maxTimePickerVisible.value = true\n maxDate.value = (maxDate.value || rightDate.value)\n .hour(parsedValueD.hour())\n .minute(parsedValueD.minute())\n .second(parsedValueD.second())\n rightDate.value = maxDate.value\n }\n }\n}\n\nconst handleTimeChange = (_value: string | null, type: ChangeType) => {\n timeUserInput.value[type] = null\n if (type === 'min') {\n leftDate.value = minDate.value!\n minTimePickerVisible.value = false\n if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n maxDate.value = minDate.value\n }\n } else {\n rightDate.value = maxDate.value!\n maxTimePickerVisible.value = false\n if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n minDate.value = maxDate.value\n }\n }\n handleRangeConfirm(true)\n}\n\nconst handleMinTimePick = (value: Dayjs, visible: boolean, first: boolean) => {\n if (timeUserInput.value.min) return\n if (value) {\n minDate.value = (minDate.value || leftDate.value)\n .hour(value.hour())\n .minute(value.minute())\n .second(value.second())\n }\n\n if (!first) {\n minTimePickerVisible.value = visible\n }\n\n if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n maxDate.value = minDate.value\n rightDate.value = value\n nextTick(() => {\n parseValue(props.parsedValue)\n })\n }\n handleRangeConfirm(true)\n}\n\nconst handleMaxTimePick = (\n value: Dayjs | null,\n visible: boolean,\n first: boolean\n) => {\n if (timeUserInput.value.max) return\n if (value) {\n maxDate.value = (maxDate.value || rightDate.value)\n .hour(value.hour())\n .minute(value.minute())\n .second(value.second())\n }\n\n if (!first) {\n maxTimePickerVisible.value = visible\n }\n\n if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n minDate.value = maxDate.value\n }\n handleRangeConfirm(true)\n}\n\nconst onClear = () => {\n handleClear()\n emit('clear')\n}\n\nconst handleClear = () => {\n let valueOnClear = null\n if (pickerBase?.emptyValues) {\n valueOnClear = pickerBase.emptyValues.valueOnClear.value\n }\n leftDate.value = getDefaultValue(unref(defaultValue), {\n lang: unref(lang),\n unit: 'month',\n unlinkPanels: props.unlinkPanels,\n })[0]\n rightDate.value = leftDate.value.add(1, 'month')\n maxDate.value = undefined\n minDate.value = undefined\n\n handleRangeConfirm(true)\n emit('pick', valueOnClear)\n}\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n return correctlyParseUserInput(\n value,\n format.value || '',\n lang.value,\n isDefaultFormat\n )\n}\nfunction sortDates(minDate: Dayjs | undefined, maxDate: Dayjs | undefined) {\n if (props.unlinkPanels && maxDate) {\n const minDateYear = minDate?.year() || 0\n const minDateMonth = minDate?.month() || 0\n const maxDateYear = maxDate.year()\n const maxDateMonth = maxDate.month()\n rightDate.value =\n minDateYear === maxDateYear && minDateMonth === maxDateMonth\n ? maxDate.add(1, unit)\n : maxDate\n } else {\n rightDate.value = leftDate.value.add(1, unit)\n if (maxDate) {\n rightDate.value = rightDate.value\n .hour(maxDate.hour())\n .minute(maxDate.minute())\n .second(maxDate.second())\n }\n }\n}\n\nemit('set-picker-option', ['isValidValue', isValidValue])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n"],"mappings":""}
1
+ {"version":3,"file":"panel-date-range.js","names":[],"sources":["../../../../../../../packages/components/date-picker-panel/src/date-picker-com/panel-date-range.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ppNs.b(),\n drpNs.b(),\n ppNs.is('border', border),\n ppNs.is('disabled', dateRangeDisabled),\n {\n 'has-sidebar': $slots.sidebar || hasShortcuts,\n 'has-time': showTime,\n 'single-panel': singlePanel,\n },\n ]\"\n >\n <div :class=\"ppNs.e('body-wrapper')\">\n <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n <button\n v-for=\"(shortcut, key) in shortcuts\"\n :key=\"key\"\n type=\"button\"\n :disabled=\"dateRangeDisabled\"\n :class=\"ppNs.e('shortcut')\"\n @click=\"handleShortcutClick(shortcut)\"\n >\n {{ shortcut.text }}\n </button>\n </div>\n <div :class=\"ppNs.e('body')\">\n <div v-if=\"showTime\" :class=\"drpNs.e('time-header')\">\n <span :class=\"drpNs.e('editors-wrap')\">\n <span :class=\"drpNs.e('time-picker-wrap')\">\n <el-input\n size=\"small\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.startDate')\"\n :class=\"drpNs.e('editor')\"\n :model-value=\"minVisibleDate\"\n :validate-event=\"false\"\n :readonly=\"!editable\"\n @input=\"(val) => handleDateInput(val, 'min')\"\n @change=\"(val) => handleDateChange(val, 'min')\"\n />\n </span>\n <span\n v-clickoutside=\"handleMinTimeClose\"\n :class=\"drpNs.e('time-picker-wrap')\"\n >\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.startTime')\"\n :model-value=\"minVisibleTime\"\n :validate-event=\"false\"\n :readonly=\"!editable\"\n @focus=\"minTimePickerVisible = true\"\n @input=\"(val) => handleTimeInput(val, 'min')\"\n @change=\"(val) => handleTimeChange(val, 'min')\"\n />\n <time-pick-panel\n :visible=\"minTimePickerVisible\"\n :format=\"timeFormat\"\n datetime-role=\"start\"\n :parsed-value=\"minDate || leftDate\"\n @pick=\"handleMinTimePick\"\n />\n </span>\n </span>\n <span>\n <el-icon><arrow-right /></el-icon>\n </span>\n <span :class=\"drpNs.e('editors-wrap')\" class=\"is-right\">\n <span :class=\"drpNs.e('time-picker-wrap')\">\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.endDate')\"\n :model-value=\"maxVisibleDate\"\n :readonly=\"!minDate || !editable\"\n :validate-event=\"false\"\n @input=\"(val) => handleDateInput(val, 'max')\"\n @change=\"(val) => handleDateChange(val, 'max')\"\n />\n </span>\n <span\n v-clickoutside=\"handleMaxTimeClose\"\n :class=\"drpNs.e('time-picker-wrap')\"\n >\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.endTime')\"\n :model-value=\"maxVisibleTime\"\n :readonly=\"!minDate || !editable\"\n :validate-event=\"false\"\n @focus=\"minDate && (maxTimePickerVisible = true)\"\n @input=\"(val) => handleTimeInput(val, 'max')\"\n @change=\"(val) => handleTimeChange(val, 'max')\"\n />\n <time-pick-panel\n datetime-role=\"end\"\n :visible=\"maxTimePickerVisible\"\n :format=\"timeFormat\"\n :parsed-value=\"maxDate || rightDate\"\n @pick=\"handleMaxTimePick\"\n />\n </span>\n </span>\n </div>\n <div\n :class=\"[\n ppNs.e('content'),\n drpNs.e('content'),\n drpNs.is('left', !singlePanel),\n ]\"\n >\n <div :class=\"drpNs.e('header')\">\n <button\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :aria-label=\"t(`el.datepicker.prevYear`)\"\n class=\"d-arrow-left\"\n :disabled=\"dateRangeDisabled\"\n @click=\"leftPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon>\n <d-arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-show=\"leftCurrentView === 'date'\"\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :aria-label=\"t(`el.datepicker.prevMonth`)\"\n class=\"arrow-left\"\n :disabled=\"dateRangeDisabled\"\n @click=\"leftPrevMonth\"\n >\n <slot name=\"prev-month\">\n <el-icon>\n <arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels || singlePanel\"\n type=\"button\"\n :disabled=\"!enableYearArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.nextYear`)\"\n class=\"d-arrow-right\"\n @click=\"leftNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon>\n <d-arrow-right />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"(unlinkPanels && leftCurrentView === 'date') || singlePanel\"\n type=\"button\"\n :disabled=\"!enableMonthArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableMonthArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.nextMonth`)\"\n class=\"arrow-right\"\n @click=\"leftNextMonth\"\n >\n <slot name=\"next-month\">\n <el-icon>\n <arrow-right />\n </el-icon>\n </slot>\n </button>\n <div>\n <span\n role=\"button\"\n :class=\"drpNs.e('header-label')\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n @keydown.enter=\"showLeftPicker('year')\"\n @click=\"showLeftPicker('year')\"\n >\n {{ leftYearLabel }}\n </span>\n <span\n v-show=\"leftCurrentView === 'date'\"\n role=\"button\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n :class=\"[\n drpNs.e('header-label'),\n { active: leftCurrentView === 'month' },\n ]\"\n @keydown.enter=\"showLeftPicker('month')\"\n @click=\"showLeftPicker('month')\"\n >\n {{ t(`el.datepicker.month${leftDate.month() + 1}`) }}\n </span>\n </div>\n </div>\n <date-table\n v-if=\"leftCurrentView === 'date'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"range\"\n :date=\"leftDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :cell-class-name=\"cellClassName\"\n :show-week-number=\"showWeekNumber\"\n :disabled=\"dateRangeDisabled\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n <year-table\n v-if=\"leftCurrentView === 'year'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"year\"\n :date=\"leftDate\"\n :disabled-date=\"disabledDate\"\n :parsed-value=\"parsedValue\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleLeftYearPick\"\n />\n <month-table\n v-if=\"leftCurrentView === 'month'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"month\"\n :date=\"leftDate\"\n :parsed-value=\"parsedValue\"\n :disabled-date=\"disabledDate\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleLeftMonthPick\"\n />\n </div>\n <div\n v-if=\"!singlePanel\"\n :class=\"[ppNs.e('content'), drpNs.e('content')]\"\n class=\"is-right\"\n >\n <div :class=\"drpNs.e('header')\">\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.prevYear`)\"\n class=\"d-arrow-left\"\n @click=\"rightPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon>\n <d-arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels && rightCurrentView === 'date'\"\n type=\"button\"\n :disabled=\"!enableMonthArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableMonthArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.prevMonth`)\"\n class=\"arrow-left\"\n @click=\"rightPrevMonth\"\n >\n <slot name=\"prev-month\">\n <el-icon>\n <arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n type=\"button\"\n :aria-label=\"t(`el.datepicker.nextYear`)\"\n :class=\"ppNs.e('icon-btn')\"\n :disabled=\"dateRangeDisabled\"\n class=\"d-arrow-right\"\n @click=\"rightNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon>\n <d-arrow-right />\n </el-icon>\n </slot>\n </button>\n <button\n v-show=\"rightCurrentView === 'date'\"\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :disabled=\"dateRangeDisabled\"\n :aria-label=\"t(`el.datepicker.nextMonth`)\"\n class=\"arrow-right\"\n @click=\"rightNextMonth\"\n >\n <slot name=\"next-month\">\n <el-icon>\n <arrow-right />\n </el-icon>\n </slot>\n </button>\n <div>\n <span\n role=\"button\"\n :class=\"drpNs.e('header-label')\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n @keydown.enter=\"showRightPicker('year')\"\n @click=\"showRightPicker('year')\"\n >\n {{ rightYearLabel }}\n </span>\n <span\n v-show=\"rightCurrentView === 'date'\"\n role=\"button\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n :class=\"[\n drpNs.e('header-label'),\n { active: rightCurrentView === 'month' },\n ]\"\n @keydown.enter=\"showRightPicker('month')\"\n @click=\"showRightPicker('month')\"\n >\n {{ t(`el.datepicker.month${rightDate.month() + 1}`) }}\n </span>\n </div>\n </div>\n <date-table\n v-if=\"rightCurrentView === 'date'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"range\"\n :date=\"rightDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :cell-class-name=\"cellClassName\"\n :show-week-number=\"showWeekNumber\"\n :disabled=\"dateRangeDisabled\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n <year-table\n v-if=\"rightCurrentView === 'year'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"year\"\n :date=\"rightDate\"\n :disabled-date=\"disabledDate\"\n :parsed-value=\"parsedValue\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleRightYearPick\"\n />\n <month-table\n v-if=\"rightCurrentView === 'month'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"month\"\n :date=\"rightDate\"\n :parsed-value=\"parsedValue\"\n :disabled-date=\"disabledDate\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleRightMonthPick\"\n />\n </div>\n </div>\n </div>\n <div\n v-if=\"showFooter && showTime && (showConfirm || clearable)\"\n :class=\"ppNs.e('footer')\"\n >\n <el-button\n v-if=\"clearable\"\n text\n size=\"small\"\n :class=\"ppNs.e('link-btn')\"\n @click=\"onClear\"\n >\n {{ t('el.datepicker.clear') }}\n </el-button>\n <el-button\n v-if=\"showConfirm\"\n plain\n size=\"small\"\n :class=\"ppNs.e('link-btn')\"\n :disabled=\"btnDisabled\"\n @click=\"handleRangeConfirm(false)\"\n >\n {{ t('el.datepicker.confirm') }}\n </el-button>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, nextTick, ref, toRef, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport { useLocale } from '@element-plus/hooks'\nimport ElButton from '@element-plus/components/button'\nimport ElInput from '@element-plus/components/input'\nimport {\n DEFAULT_FORMATS_DATE,\n DEFAULT_FORMATS_TIME,\n PICKER_BASE_INJECTION_KEY,\n TimePickPanel,\n extractDateFormat,\n extractTimeFormat,\n} from '@element-plus/components/time-picker'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n ArrowLeft,\n ArrowRight,\n DArrowLeft,\n DArrowRight,\n} from '@element-plus/icons-vue'\nimport { panelDateRangeProps } from '../props/panel-date-range'\nimport { useRangePicker } from '../composables/use-range-picker'\nimport {\n correctlyParseUserInput,\n getDefaultValue,\n isValidRange,\n} from '../utils'\nimport { usePanelDateRange } from '../composables/use-panel-date-range'\nimport { ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY } from '../constants'\nimport YearTable from './basic-year-table.vue'\nimport MonthTable from './basic-month-table.vue'\nimport DateTable from './basic-date-table.vue'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { Ref } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\ntype ChangeType = 'min' | 'max'\ntype UserInput = {\n min: string | null\n max: string | null\n}\n\nconst props = defineProps(panelDateRangeProps)\nconst emit = defineEmits([\n 'pick',\n 'set-picker-option',\n 'calendar-change',\n 'panel-change',\n 'clear',\n])\n\nconst unit = 'month'\n// FIXME: fix the type for ep picker\nconst pickerBase = inject(PICKER_BASE_INJECTION_KEY) as any\nconst isDefaultFormat = inject(\n ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY,\n undefined\n) as any\nconst { disabledDate, cellClassName, defaultTime, clearable } = pickerBase.props\nconst format: Ref<string | undefined> = toRef(pickerBase.props, 'format')\nconst shortcuts = toRef(pickerBase.props, 'shortcuts')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst { lang } = useLocale()\nconst leftDate = ref<Dayjs>(dayjs().locale(lang.value))\nconst rightDate = ref<Dayjs>(dayjs().locale(lang.value).add(1, unit))\n\nconst {\n minDate,\n maxDate,\n rangeState,\n ppNs,\n drpNs,\n handleChangeRange,\n handleRangeConfirm,\n handleShortcutClick,\n onSelect,\n parseValue,\n t,\n} = useRangePicker(props, {\n defaultValue,\n defaultTime,\n leftDate,\n rightDate,\n unit,\n sortDates,\n})\n\nwatch(\n () => props.visible,\n (visible) => {\n if (!visible && rangeState.value.selecting) {\n parseValue(props.parsedValue)\n onSelect(false)\n }\n }\n)\n\nconst dateUserInput = ref<UserInput>({\n min: null,\n max: null,\n})\n\nconst timeUserInput = ref<UserInput>({\n min: null,\n max: null,\n})\n\nconst {\n leftCurrentView,\n rightCurrentView,\n leftCurrentViewRef,\n rightCurrentViewRef,\n leftYear,\n rightYear,\n leftMonth,\n rightMonth,\n leftYearLabel,\n rightYearLabel,\n showLeftPicker,\n showRightPicker,\n handleLeftYearPick,\n handleRightYearPick,\n handleLeftMonthPick,\n handleRightMonthPick,\n handlePanelChange,\n adjustDateByView,\n} = usePanelDateRange(props, emit, leftDate, rightDate)\n\nconst hasShortcuts = computed(() => !!shortcuts.value.length)\n\nconst minVisibleDate = computed(() => {\n if (dateUserInput.value.min !== null) return dateUserInput.value.min\n if (minDate.value) return minDate.value.format(dateFormat.value)\n return ''\n})\n\nconst maxVisibleDate = computed(() => {\n if (dateUserInput.value.max !== null) return dateUserInput.value.max\n if (maxDate.value || minDate.value)\n return (maxDate.value || minDate.value)!.format(dateFormat.value)\n return ''\n})\n\nconst minVisibleTime = computed(() => {\n if (timeUserInput.value.min !== null) return timeUserInput.value.min\n if (minDate.value) return minDate.value.format(timeFormat.value)\n return ''\n})\n\nconst maxVisibleTime = computed(() => {\n if (timeUserInput.value.max !== null) return timeUserInput.value.max\n if (maxDate.value || minDate.value)\n return (maxDate.value || minDate.value)!.format(timeFormat.value)\n return ''\n})\n\nconst timeFormat = computed(() => {\n return (\n props.timeFormat ||\n extractTimeFormat(format.value || '') ||\n DEFAULT_FORMATS_TIME\n )\n})\n\nconst dateFormat = computed(() => {\n return (\n props.dateFormat ||\n extractDateFormat(format.value || '') ||\n DEFAULT_FORMATS_DATE\n )\n})\n\nconst isValidValue = (date: [Dayjs, Dayjs]) => {\n return (\n isValidRange(date) &&\n (disabledDate\n ? !disabledDate(date[0].toDate()) && !disabledDate(date[1].toDate())\n : true)\n )\n}\n\nconst leftPrevYear = () => {\n leftDate.value = adjustDateByView(\n leftCurrentView.value,\n leftDate.value,\n false\n )\n\n if (!props.unlinkPanels) {\n rightDate.value = leftDate.value.add(1, 'month')\n }\n handlePanelChange('year')\n}\n\nconst leftPrevMonth = () => {\n leftDate.value = leftDate.value.subtract(1, 'month')\n if (!props.unlinkPanels) {\n rightDate.value = leftDate.value.add(1, 'month')\n }\n handlePanelChange('month')\n}\n\nconst rightNextYear = () => {\n if (!props.unlinkPanels) {\n leftDate.value = adjustDateByView(\n rightCurrentView.value,\n leftDate.value,\n true\n )\n\n rightDate.value = leftDate.value.add(1, 'month')\n } else {\n rightDate.value = adjustDateByView(\n rightCurrentView.value,\n rightDate.value,\n true\n )\n }\n handlePanelChange('year')\n}\n\nconst rightNextMonth = () => {\n if (!props.unlinkPanels) {\n leftDate.value = leftDate.value.add(1, 'month')\n rightDate.value = leftDate.value.add(1, 'month')\n } else {\n rightDate.value = rightDate.value.add(1, 'month')\n }\n handlePanelChange('month')\n}\n\nconst leftNextYear = () => {\n leftDate.value = adjustDateByView(leftCurrentView.value, leftDate.value, true)\n\n handlePanelChange('year')\n}\n\nconst leftNextMonth = () => {\n leftDate.value = leftDate.value.add(1, 'month')\n handlePanelChange('month')\n}\n\nconst rightPrevYear = () => {\n rightDate.value = adjustDateByView(\n rightCurrentView.value,\n rightDate.value,\n false\n )\n\n handlePanelChange('year')\n}\n\nconst rightPrevMonth = () => {\n rightDate.value = rightDate.value.subtract(1, 'month')\n handlePanelChange('month')\n}\n\nconst enableMonthArrow = computed(() => {\n const nextMonth = (leftMonth.value + 1) % 12\n const yearOffset = leftMonth.value + 1 >= 12 ? 1 : 0\n return (\n props.singlePanel ||\n (props.unlinkPanels &&\n new Date(leftYear.value + yearOffset, nextMonth) <\n new Date(rightYear.value, rightMonth.value))\n )\n})\n\nconst enableYearArrow = computed(() => {\n return (\n props.singlePanel ||\n (props.unlinkPanels &&\n rightYear.value * 12 +\n rightMonth.value -\n (leftYear.value * 12 + leftMonth.value + 1) >=\n 12)\n )\n})\n\nconst dateRangeDisabled = useFormDisabled()\n\nconst btnDisabled = computed(() => {\n return !(\n minDate.value &&\n maxDate.value &&\n !rangeState.value.selecting &&\n isValidRange([minDate.value, maxDate.value]) &&\n !dateRangeDisabled.value\n )\n})\n\nconst showTime = computed(\n () => props.type === 'datetime' || props.type === 'datetimerange'\n)\n\nconst formatEmit = (emitDayjs: Dayjs | null, index?: number) => {\n if (!emitDayjs) return\n if (defaultTime) {\n const defaultTimeD = dayjs(\n defaultTime[index as number] || defaultTime\n ).locale(lang.value)\n return defaultTimeD\n .year(emitDayjs.year())\n .month(emitDayjs.month())\n .date(emitDayjs.date())\n }\n return emitDayjs\n}\n\nconst handleRangePick = (\n val: {\n minDate: Dayjs\n maxDate: Dayjs | null\n },\n close = true\n) => {\n const min_ = val.minDate\n const max_ = val.maxDate\n const minDate_ = formatEmit(min_, 0)\n const maxDate_ = formatEmit(max_, 1)\n\n if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n return\n }\n emit('calendar-change', [min_.toDate(), max_ && max_.toDate()])\n maxDate.value = maxDate_\n minDate.value = minDate_\n\n if (!showTime.value && close) {\n close = !minDate_ || !maxDate_\n }\n handleRangeConfirm(close)\n}\n\nconst minTimePickerVisible = ref(false)\nconst maxTimePickerVisible = ref(false)\n\nconst handleMinTimeClose = () => {\n minTimePickerVisible.value = false\n}\n\nconst handleMaxTimeClose = () => {\n maxTimePickerVisible.value = false\n}\n\nconst handleDateInput = (value: string | null, type: ChangeType) => {\n dateUserInput.value[type] = value\n const parsedValueD = dayjs(value, dateFormat.value).locale(lang.value)\n if (parsedValueD.isValid()) {\n if (disabledDate && disabledDate(parsedValueD.toDate())) {\n return\n }\n if (type === 'min') {\n leftDate.value = parsedValueD\n minDate.value = (minDate.value || leftDate.value)\n .year(parsedValueD.year())\n .month(parsedValueD.month())\n .date(parsedValueD.date())\n if (\n !props.unlinkPanels &&\n (!maxDate.value || maxDate.value.isBefore(minDate.value))\n ) {\n rightDate.value = parsedValueD.add(1, 'month')\n maxDate.value = minDate.value.add(1, 'month')\n }\n } else {\n rightDate.value = parsedValueD\n maxDate.value = (maxDate.value || rightDate.value)\n .year(parsedValueD.year())\n .month(parsedValueD.month())\n .date(parsedValueD.date())\n if (\n !props.unlinkPanels &&\n (!minDate.value || minDate.value.isAfter(maxDate.value))\n ) {\n leftDate.value = parsedValueD.subtract(1, 'month')\n minDate.value = maxDate.value.subtract(1, 'month')\n }\n }\n sortDates(minDate.value, maxDate.value)\n handleRangeConfirm(true)\n }\n}\n\nconst handleDateChange = (_: unknown, type: ChangeType) => {\n dateUserInput.value[type] = null\n}\n\nconst handleTimeInput = (value: string | null, type: ChangeType) => {\n timeUserInput.value[type] = value\n const parsedValueD = dayjs(value, timeFormat.value).locale(lang.value)\n\n if (parsedValueD.isValid()) {\n if (type === 'min') {\n minTimePickerVisible.value = true\n minDate.value = (minDate.value || leftDate.value)\n .hour(parsedValueD.hour())\n .minute(parsedValueD.minute())\n .second(parsedValueD.second())\n leftDate.value = minDate.value\n } else {\n maxTimePickerVisible.value = true\n maxDate.value = (maxDate.value || rightDate.value)\n .hour(parsedValueD.hour())\n .minute(parsedValueD.minute())\n .second(parsedValueD.second())\n rightDate.value = maxDate.value\n }\n }\n}\n\nconst handleTimeChange = (_value: string | null, type: ChangeType) => {\n timeUserInput.value[type] = null\n if (type === 'min') {\n leftDate.value = minDate.value!\n minTimePickerVisible.value = false\n if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n maxDate.value = minDate.value\n }\n } else {\n rightDate.value = maxDate.value!\n maxTimePickerVisible.value = false\n if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n minDate.value = maxDate.value\n }\n }\n handleRangeConfirm(true)\n}\n\nconst handleMinTimePick = (value: Dayjs, visible: boolean, first: boolean) => {\n if (timeUserInput.value.min) return\n if (value) {\n minDate.value = (minDate.value || leftDate.value)\n .hour(value.hour())\n .minute(value.minute())\n .second(value.second())\n }\n\n if (!first) {\n minTimePickerVisible.value = visible\n }\n\n if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n maxDate.value = minDate.value\n rightDate.value = value\n nextTick(() => {\n parseValue(props.parsedValue)\n })\n }\n handleRangeConfirm(true)\n}\n\nconst handleMaxTimePick = (\n value: Dayjs | null,\n visible: boolean,\n first: boolean\n) => {\n if (timeUserInput.value.max) return\n if (value) {\n maxDate.value = (maxDate.value || rightDate.value)\n .hour(value.hour())\n .minute(value.minute())\n .second(value.second())\n }\n\n if (!first) {\n maxTimePickerVisible.value = visible\n }\n\n if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n minDate.value = maxDate.value\n }\n handleRangeConfirm(true)\n}\n\nconst onClear = () => {\n handleClear()\n emit('clear')\n}\n\nconst handleClear = () => {\n let valueOnClear = null\n if (pickerBase?.emptyValues) {\n valueOnClear = pickerBase.emptyValues.valueOnClear.value\n }\n leftDate.value = getDefaultValue(unref(defaultValue), {\n lang: unref(lang),\n unit: 'month',\n unlinkPanels: props.unlinkPanels,\n })[0]\n rightDate.value = leftDate.value.add(1, 'month')\n maxDate.value = undefined\n minDate.value = undefined\n\n handleRangeConfirm(true)\n emit('pick', valueOnClear)\n}\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n return correctlyParseUserInput(\n value,\n format.value || '',\n lang.value,\n isDefaultFormat\n )\n}\nfunction sortDates(minDate: Dayjs | undefined, maxDate: Dayjs | undefined) {\n if (props.unlinkPanels && maxDate) {\n const minDateYear = minDate?.year() || 0\n const minDateMonth = minDate?.month() || 0\n const maxDateYear = maxDate.year()\n const maxDateMonth = maxDate.month()\n rightDate.value =\n minDateYear === maxDateYear && minDateMonth === maxDateMonth\n ? maxDate.add(1, unit)\n : maxDate\n } else {\n rightDate.value = leftDate.value.add(1, unit)\n if (maxDate) {\n rightDate.value = rightDate.value\n .hour(maxDate.hour())\n .minute(maxDate.minute())\n .second(maxDate.second())\n }\n }\n}\n\nemit('set-picker-option', ['isValidValue', isValidValue])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n"],"mappings":""}
@@ -154,10 +154,10 @@ var panel_date_range_vue_vue_type_script_setup_true_lang_default = /* @__PURE__
154
154
  const enableMonthArrow = (0, vue.computed)(() => {
155
155
  const nextMonth = (leftMonth.value + 1) % 12;
156
156
  const yearOffset = leftMonth.value + 1 >= 12 ? 1 : 0;
157
- return props.unlinkPanels && new Date(leftYear.value + yearOffset, nextMonth) < new Date(rightYear.value, rightMonth.value);
157
+ return props.singlePanel || props.unlinkPanels && new Date(leftYear.value + yearOffset, nextMonth) < new Date(rightYear.value, rightMonth.value);
158
158
  });
159
159
  const enableYearArrow = (0, vue.computed)(() => {
160
- return props.unlinkPanels && rightYear.value * 12 + rightMonth.value - (leftYear.value * 12 + leftMonth.value + 1) >= 12;
160
+ return props.singlePanel || props.unlinkPanels && rightYear.value * 12 + rightMonth.value - (leftYear.value * 12 + leftMonth.value + 1) >= 12;
161
161
  });
162
162
  const dateRangeDisabled = require_use_form_common_props.useFormDisabled();
163
163
  const btnDisabled = (0, vue.computed)(() => {
@@ -306,7 +306,8 @@ var panel_date_range_vue_vue_type_script_setup_true_lang_default = /* @__PURE__
306
306
  (0, vue.unref)(ppNs).is("disabled", (0, vue.unref)(dateRangeDisabled)),
307
307
  {
308
308
  "has-sidebar": _ctx.$slots.sidebar || hasShortcuts.value,
309
- "has-time": showTime.value
309
+ "has-time": showTime.value,
310
+ "single-panel": _ctx.singlePanel
310
311
  }
311
312
  ]) }, [(0, vue.createElementVNode)("div", { class: (0, vue.normalizeClass)((0, vue.unref)(ppNs).e("body-wrapper")) }, [
312
313
  (0, vue.renderSlot)(_ctx.$slots, "sidebar", { class: (0, vue.normalizeClass)((0, vue.unref)(ppNs).e("sidebar")) }),
@@ -420,7 +421,11 @@ var panel_date_range_vue_vue_type_script_setup_true_lang_default = /* @__PURE__
420
421
  "parsed-value"
421
422
  ])], 2)), [[(0, vue.unref)(require_index$4.default), handleMaxTimeClose]])], 2)
422
423
  ], 2)) : (0, vue.createCommentVNode)("v-if", true),
423
- (0, vue.createElementVNode)("div", { class: (0, vue.normalizeClass)([[(0, vue.unref)(ppNs).e("content"), (0, vue.unref)(drpNs).e("content")], "is-left"]) }, [
424
+ (0, vue.createElementVNode)("div", { class: (0, vue.normalizeClass)([
425
+ (0, vue.unref)(ppNs).e("content"),
426
+ (0, vue.unref)(drpNs).e("content"),
427
+ (0, vue.unref)(drpNs).is("left", !_ctx.singlePanel)
428
+ ]) }, [
424
429
  (0, vue.createElementVNode)("div", { class: (0, vue.normalizeClass)((0, vue.unref)(drpNs).e("header")) }, [
425
430
  (0, vue.createElementVNode)("button", {
426
431
  type: "button",
@@ -442,7 +447,7 @@ var panel_date_range_vue_vue_type_script_setup_true_lang_default = /* @__PURE__
442
447
  default: (0, vue.withCtx)(() => [(0, vue.createVNode)((0, vue.unref)(_element_plus_icons_vue.ArrowLeft))]),
443
448
  _: 1
444
449
  })])], 10, _hoisted_3), [[vue.vShow, (0, vue.unref)(leftCurrentView) === "date"]]),
445
- _ctx.unlinkPanels ? ((0, vue.openBlock)(), (0, vue.createElementBlock)("button", {
450
+ _ctx.unlinkPanels || _ctx.singlePanel ? ((0, vue.openBlock)(), (0, vue.createElementBlock)("button", {
446
451
  key: 0,
447
452
  type: "button",
448
453
  disabled: !enableYearArrow.value || (0, vue.unref)(dateRangeDisabled),
@@ -453,7 +458,7 @@ var panel_date_range_vue_vue_type_script_setup_true_lang_default = /* @__PURE__
453
458
  default: (0, vue.withCtx)(() => [(0, vue.createVNode)((0, vue.unref)(_element_plus_icons_vue.DArrowRight))]),
454
459
  _: 1
455
460
  })])], 10, _hoisted_4)) : (0, vue.createCommentVNode)("v-if", true),
456
- _ctx.unlinkPanels && (0, vue.unref)(leftCurrentView) === "date" ? ((0, vue.openBlock)(), (0, vue.createElementBlock)("button", {
461
+ _ctx.unlinkPanels && (0, vue.unref)(leftCurrentView) === "date" || _ctx.singlePanel ? ((0, vue.openBlock)(), (0, vue.createElementBlock)("button", {
457
462
  key: 1,
458
463
  type: "button",
459
464
  disabled: !enableMonthArrow.value || (0, vue.unref)(dateRangeDisabled),
@@ -545,7 +550,10 @@ var panel_date_range_vue_vue_type_script_setup_true_lang_default = /* @__PURE__
545
550
  "onPick"
546
551
  ])) : (0, vue.createCommentVNode)("v-if", true)
547
552
  ], 2),
548
- (0, vue.createElementVNode)("div", { class: (0, vue.normalizeClass)([[(0, vue.unref)(ppNs).e("content"), (0, vue.unref)(drpNs).e("content")], "is-right"]) }, [
553
+ !_ctx.singlePanel ? ((0, vue.openBlock)(), (0, vue.createElementBlock)("div", {
554
+ key: 1,
555
+ class: (0, vue.normalizeClass)([[(0, vue.unref)(ppNs).e("content"), (0, vue.unref)(drpNs).e("content")], "is-right"])
556
+ }, [
549
557
  (0, vue.createElementVNode)("div", { class: (0, vue.normalizeClass)((0, vue.unref)(drpNs).e("header")) }, [
550
558
  _ctx.unlinkPanels ? ((0, vue.openBlock)(), (0, vue.createElementBlock)("button", {
551
559
  key: 0,
@@ -669,7 +677,7 @@ var panel_date_range_vue_vue_type_script_setup_true_lang_default = /* @__PURE__
669
677
  "disabled",
670
678
  "onPick"
671
679
  ])) : (0, vue.createCommentVNode)("v-if", true)
672
- ], 2)
680
+ ], 2)) : (0, vue.createCommentVNode)("v-if", true)
673
681
  ], 2)
674
682
  ], 2), _ctx.showFooter && showTime.value && (_ctx.showConfirm || (0, vue.unref)(clearable)) ? ((0, vue.openBlock)(), (0, vue.createElementBlock)("div", {
675
683
  key: 0,
@@ -1 +1 @@
1
- {"version":3,"file":"panel-date-range.vue_vue_type_script_setup_true_lang.js","names":["border","$slots","editable","unlinkPanels","disabled","showWeekNumber","parsedValue","showFooter","showConfirm"],"sources":["../../../../../../../packages/components/date-picker-panel/src/date-picker-com/panel-date-range.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ppNs.b(),\n drpNs.b(),\n ppNs.is('border', border),\n ppNs.is('disabled', dateRangeDisabled),\n {\n 'has-sidebar': $slots.sidebar || hasShortcuts,\n 'has-time': showTime,\n },\n ]\"\n >\n <div :class=\"ppNs.e('body-wrapper')\">\n <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n <button\n v-for=\"(shortcut, key) in shortcuts\"\n :key=\"key\"\n type=\"button\"\n :disabled=\"dateRangeDisabled\"\n :class=\"ppNs.e('shortcut')\"\n @click=\"handleShortcutClick(shortcut)\"\n >\n {{ shortcut.text }}\n </button>\n </div>\n <div :class=\"ppNs.e('body')\">\n <div v-if=\"showTime\" :class=\"drpNs.e('time-header')\">\n <span :class=\"drpNs.e('editors-wrap')\">\n <span :class=\"drpNs.e('time-picker-wrap')\">\n <el-input\n size=\"small\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.startDate')\"\n :class=\"drpNs.e('editor')\"\n :model-value=\"minVisibleDate\"\n :validate-event=\"false\"\n :readonly=\"!editable\"\n @input=\"(val) => handleDateInput(val, 'min')\"\n @change=\"(val) => handleDateChange(val, 'min')\"\n />\n </span>\n <span\n v-clickoutside=\"handleMinTimeClose\"\n :class=\"drpNs.e('time-picker-wrap')\"\n >\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.startTime')\"\n :model-value=\"minVisibleTime\"\n :validate-event=\"false\"\n :readonly=\"!editable\"\n @focus=\"minTimePickerVisible = true\"\n @input=\"(val) => handleTimeInput(val, 'min')\"\n @change=\"(val) => handleTimeChange(val, 'min')\"\n />\n <time-pick-panel\n :visible=\"minTimePickerVisible\"\n :format=\"timeFormat\"\n datetime-role=\"start\"\n :parsed-value=\"minDate || leftDate\"\n @pick=\"handleMinTimePick\"\n />\n </span>\n </span>\n <span>\n <el-icon><arrow-right /></el-icon>\n </span>\n <span :class=\"drpNs.e('editors-wrap')\" class=\"is-right\">\n <span :class=\"drpNs.e('time-picker-wrap')\">\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.endDate')\"\n :model-value=\"maxVisibleDate\"\n :readonly=\"!minDate || !editable\"\n :validate-event=\"false\"\n @input=\"(val) => handleDateInput(val, 'max')\"\n @change=\"(val) => handleDateChange(val, 'max')\"\n />\n </span>\n <span\n v-clickoutside=\"handleMaxTimeClose\"\n :class=\"drpNs.e('time-picker-wrap')\"\n >\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.endTime')\"\n :model-value=\"maxVisibleTime\"\n :readonly=\"!minDate || !editable\"\n :validate-event=\"false\"\n @focus=\"minDate && (maxTimePickerVisible = true)\"\n @input=\"(val) => handleTimeInput(val, 'max')\"\n @change=\"(val) => handleTimeChange(val, 'max')\"\n />\n <time-pick-panel\n datetime-role=\"end\"\n :visible=\"maxTimePickerVisible\"\n :format=\"timeFormat\"\n :parsed-value=\"maxDate || rightDate\"\n @pick=\"handleMaxTimePick\"\n />\n </span>\n </span>\n </div>\n <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-left\">\n <div :class=\"drpNs.e('header')\">\n <button\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :aria-label=\"t(`el.datepicker.prevYear`)\"\n class=\"d-arrow-left\"\n :disabled=\"dateRangeDisabled\"\n @click=\"leftPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon>\n <d-arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-show=\"leftCurrentView === 'date'\"\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :aria-label=\"t(`el.datepicker.prevMonth`)\"\n class=\"arrow-left\"\n :disabled=\"dateRangeDisabled\"\n @click=\"leftPrevMonth\"\n >\n <slot name=\"prev-month\">\n <el-icon>\n <arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.nextYear`)\"\n class=\"d-arrow-right\"\n @click=\"leftNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon>\n <d-arrow-right />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels && leftCurrentView === 'date'\"\n type=\"button\"\n :disabled=\"!enableMonthArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableMonthArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.nextMonth`)\"\n class=\"arrow-right\"\n @click=\"leftNextMonth\"\n >\n <slot name=\"next-month\">\n <el-icon>\n <arrow-right />\n </el-icon>\n </slot>\n </button>\n <div>\n <span\n role=\"button\"\n :class=\"drpNs.e('header-label')\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n @keydown.enter=\"showLeftPicker('year')\"\n @click=\"showLeftPicker('year')\"\n >\n {{ leftYearLabel }}\n </span>\n <span\n v-show=\"leftCurrentView === 'date'\"\n role=\"button\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n :class=\"[\n drpNs.e('header-label'),\n { active: leftCurrentView === 'month' },\n ]\"\n @keydown.enter=\"showLeftPicker('month')\"\n @click=\"showLeftPicker('month')\"\n >\n {{ t(`el.datepicker.month${leftDate.month() + 1}`) }}\n </span>\n </div>\n </div>\n <date-table\n v-if=\"leftCurrentView === 'date'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"range\"\n :date=\"leftDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :cell-class-name=\"cellClassName\"\n :show-week-number=\"showWeekNumber\"\n :disabled=\"dateRangeDisabled\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n <year-table\n v-if=\"leftCurrentView === 'year'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"year\"\n :date=\"leftDate\"\n :disabled-date=\"disabledDate\"\n :parsed-value=\"parsedValue\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleLeftYearPick\"\n />\n <month-table\n v-if=\"leftCurrentView === 'month'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"month\"\n :date=\"leftDate\"\n :parsed-value=\"parsedValue\"\n :disabled-date=\"disabledDate\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleLeftMonthPick\"\n />\n </div>\n <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-right\">\n <div :class=\"drpNs.e('header')\">\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.prevYear`)\"\n class=\"d-arrow-left\"\n @click=\"rightPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon>\n <d-arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels && rightCurrentView === 'date'\"\n type=\"button\"\n :disabled=\"!enableMonthArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableMonthArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.prevMonth`)\"\n class=\"arrow-left\"\n @click=\"rightPrevMonth\"\n >\n <slot name=\"prev-month\">\n <el-icon>\n <arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n type=\"button\"\n :aria-label=\"t(`el.datepicker.nextYear`)\"\n :class=\"ppNs.e('icon-btn')\"\n :disabled=\"dateRangeDisabled\"\n class=\"d-arrow-right\"\n @click=\"rightNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon>\n <d-arrow-right />\n </el-icon>\n </slot>\n </button>\n <button\n v-show=\"rightCurrentView === 'date'\"\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :disabled=\"dateRangeDisabled\"\n :aria-label=\"t(`el.datepicker.nextMonth`)\"\n class=\"arrow-right\"\n @click=\"rightNextMonth\"\n >\n <slot name=\"next-month\">\n <el-icon>\n <arrow-right />\n </el-icon>\n </slot>\n </button>\n <div>\n <span\n role=\"button\"\n :class=\"drpNs.e('header-label')\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n @keydown.enter=\"showRightPicker('year')\"\n @click=\"showRightPicker('year')\"\n >\n {{ rightYearLabel }}\n </span>\n <span\n v-show=\"rightCurrentView === 'date'\"\n role=\"button\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n :class=\"[\n drpNs.e('header-label'),\n { active: rightCurrentView === 'month' },\n ]\"\n @keydown.enter=\"showRightPicker('month')\"\n @click=\"showRightPicker('month')\"\n >\n {{ t(`el.datepicker.month${rightDate.month() + 1}`) }}\n </span>\n </div>\n </div>\n <date-table\n v-if=\"rightCurrentView === 'date'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"range\"\n :date=\"rightDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :cell-class-name=\"cellClassName\"\n :show-week-number=\"showWeekNumber\"\n :disabled=\"dateRangeDisabled\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n <year-table\n v-if=\"rightCurrentView === 'year'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"year\"\n :date=\"rightDate\"\n :disabled-date=\"disabledDate\"\n :parsed-value=\"parsedValue\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleRightYearPick\"\n />\n <month-table\n v-if=\"rightCurrentView === 'month'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"month\"\n :date=\"rightDate\"\n :parsed-value=\"parsedValue\"\n :disabled-date=\"disabledDate\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleRightMonthPick\"\n />\n </div>\n </div>\n </div>\n <div\n v-if=\"showFooter && showTime && (showConfirm || clearable)\"\n :class=\"ppNs.e('footer')\"\n >\n <el-button\n v-if=\"clearable\"\n text\n size=\"small\"\n :class=\"ppNs.e('link-btn')\"\n @click=\"onClear\"\n >\n {{ t('el.datepicker.clear') }}\n </el-button>\n <el-button\n v-if=\"showConfirm\"\n plain\n size=\"small\"\n :class=\"ppNs.e('link-btn')\"\n :disabled=\"btnDisabled\"\n @click=\"handleRangeConfirm(false)\"\n >\n {{ t('el.datepicker.confirm') }}\n </el-button>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, nextTick, ref, toRef, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport { useLocale } from '@element-plus/hooks'\nimport ElButton from '@element-plus/components/button'\nimport ElInput from '@element-plus/components/input'\nimport {\n DEFAULT_FORMATS_DATE,\n DEFAULT_FORMATS_TIME,\n PICKER_BASE_INJECTION_KEY,\n TimePickPanel,\n extractDateFormat,\n extractTimeFormat,\n} from '@element-plus/components/time-picker'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n ArrowLeft,\n ArrowRight,\n DArrowLeft,\n DArrowRight,\n} from '@element-plus/icons-vue'\nimport { panelDateRangeProps } from '../props/panel-date-range'\nimport { useRangePicker } from '../composables/use-range-picker'\nimport {\n correctlyParseUserInput,\n getDefaultValue,\n isValidRange,\n} from '../utils'\nimport { usePanelDateRange } from '../composables/use-panel-date-range'\nimport { ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY } from '../constants'\nimport YearTable from './basic-year-table.vue'\nimport MonthTable from './basic-month-table.vue'\nimport DateTable from './basic-date-table.vue'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { Ref } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\ntype ChangeType = 'min' | 'max'\ntype UserInput = {\n min: string | null\n max: string | null\n}\n\nconst props = defineProps(panelDateRangeProps)\nconst emit = defineEmits([\n 'pick',\n 'set-picker-option',\n 'calendar-change',\n 'panel-change',\n 'clear',\n])\n\nconst unit = 'month'\n// FIXME: fix the type for ep picker\nconst pickerBase = inject(PICKER_BASE_INJECTION_KEY) as any\nconst isDefaultFormat = inject(\n ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY,\n undefined\n) as any\nconst { disabledDate, cellClassName, defaultTime, clearable } = pickerBase.props\nconst format: Ref<string | undefined> = toRef(pickerBase.props, 'format')\nconst shortcuts = toRef(pickerBase.props, 'shortcuts')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst { lang } = useLocale()\nconst leftDate = ref<Dayjs>(dayjs().locale(lang.value))\nconst rightDate = ref<Dayjs>(dayjs().locale(lang.value).add(1, unit))\n\nconst {\n minDate,\n maxDate,\n rangeState,\n ppNs,\n drpNs,\n handleChangeRange,\n handleRangeConfirm,\n handleShortcutClick,\n onSelect,\n parseValue,\n t,\n} = useRangePicker(props, {\n defaultValue,\n defaultTime,\n leftDate,\n rightDate,\n unit,\n sortDates,\n})\n\nwatch(\n () => props.visible,\n (visible) => {\n if (!visible && rangeState.value.selecting) {\n parseValue(props.parsedValue)\n onSelect(false)\n }\n }\n)\n\nconst dateUserInput = ref<UserInput>({\n min: null,\n max: null,\n})\n\nconst timeUserInput = ref<UserInput>({\n min: null,\n max: null,\n})\n\nconst {\n leftCurrentView,\n rightCurrentView,\n leftCurrentViewRef,\n rightCurrentViewRef,\n leftYear,\n rightYear,\n leftMonth,\n rightMonth,\n leftYearLabel,\n rightYearLabel,\n showLeftPicker,\n showRightPicker,\n handleLeftYearPick,\n handleRightYearPick,\n handleLeftMonthPick,\n handleRightMonthPick,\n handlePanelChange,\n adjustDateByView,\n} = usePanelDateRange(props, emit, leftDate, rightDate)\n\nconst hasShortcuts = computed(() => !!shortcuts.value.length)\n\nconst minVisibleDate = computed(() => {\n if (dateUserInput.value.min !== null) return dateUserInput.value.min\n if (minDate.value) return minDate.value.format(dateFormat.value)\n return ''\n})\n\nconst maxVisibleDate = computed(() => {\n if (dateUserInput.value.max !== null) return dateUserInput.value.max\n if (maxDate.value || minDate.value)\n return (maxDate.value || minDate.value)!.format(dateFormat.value)\n return ''\n})\n\nconst minVisibleTime = computed(() => {\n if (timeUserInput.value.min !== null) return timeUserInput.value.min\n if (minDate.value) return minDate.value.format(timeFormat.value)\n return ''\n})\n\nconst maxVisibleTime = computed(() => {\n if (timeUserInput.value.max !== null) return timeUserInput.value.max\n if (maxDate.value || minDate.value)\n return (maxDate.value || minDate.value)!.format(timeFormat.value)\n return ''\n})\n\nconst timeFormat = computed(() => {\n return (\n props.timeFormat ||\n extractTimeFormat(format.value || '') ||\n DEFAULT_FORMATS_TIME\n )\n})\n\nconst dateFormat = computed(() => {\n return (\n props.dateFormat ||\n extractDateFormat(format.value || '') ||\n DEFAULT_FORMATS_DATE\n )\n})\n\nconst isValidValue = (date: [Dayjs, Dayjs]) => {\n return (\n isValidRange(date) &&\n (disabledDate\n ? !disabledDate(date[0].toDate()) && !disabledDate(date[1].toDate())\n : true)\n )\n}\n\nconst leftPrevYear = () => {\n leftDate.value = adjustDateByView(\n leftCurrentView.value,\n leftDate.value,\n false\n )\n\n if (!props.unlinkPanels) {\n rightDate.value = leftDate.value.add(1, 'month')\n }\n handlePanelChange('year')\n}\n\nconst leftPrevMonth = () => {\n leftDate.value = leftDate.value.subtract(1, 'month')\n if (!props.unlinkPanels) {\n rightDate.value = leftDate.value.add(1, 'month')\n }\n handlePanelChange('month')\n}\n\nconst rightNextYear = () => {\n if (!props.unlinkPanels) {\n leftDate.value = adjustDateByView(\n rightCurrentView.value,\n leftDate.value,\n true\n )\n\n rightDate.value = leftDate.value.add(1, 'month')\n } else {\n rightDate.value = adjustDateByView(\n rightCurrentView.value,\n rightDate.value,\n true\n )\n }\n handlePanelChange('year')\n}\n\nconst rightNextMonth = () => {\n if (!props.unlinkPanels) {\n leftDate.value = leftDate.value.add(1, 'month')\n rightDate.value = leftDate.value.add(1, 'month')\n } else {\n rightDate.value = rightDate.value.add(1, 'month')\n }\n handlePanelChange('month')\n}\n\nconst leftNextYear = () => {\n leftDate.value = adjustDateByView(leftCurrentView.value, leftDate.value, true)\n\n handlePanelChange('year')\n}\n\nconst leftNextMonth = () => {\n leftDate.value = leftDate.value.add(1, 'month')\n handlePanelChange('month')\n}\n\nconst rightPrevYear = () => {\n rightDate.value = adjustDateByView(\n rightCurrentView.value,\n rightDate.value,\n false\n )\n\n handlePanelChange('year')\n}\n\nconst rightPrevMonth = () => {\n rightDate.value = rightDate.value.subtract(1, 'month')\n handlePanelChange('month')\n}\n\nconst enableMonthArrow = computed(() => {\n const nextMonth = (leftMonth.value + 1) % 12\n const yearOffset = leftMonth.value + 1 >= 12 ? 1 : 0\n return (\n props.unlinkPanels &&\n new Date(leftYear.value + yearOffset, nextMonth) <\n new Date(rightYear.value, rightMonth.value)\n )\n})\n\nconst enableYearArrow = computed(() => {\n return (\n props.unlinkPanels &&\n rightYear.value * 12 +\n rightMonth.value -\n (leftYear.value * 12 + leftMonth.value + 1) >=\n 12\n )\n})\n\nconst dateRangeDisabled = useFormDisabled()\n\nconst btnDisabled = computed(() => {\n return !(\n minDate.value &&\n maxDate.value &&\n !rangeState.value.selecting &&\n isValidRange([minDate.value, maxDate.value]) &&\n !dateRangeDisabled.value\n )\n})\n\nconst showTime = computed(\n () => props.type === 'datetime' || props.type === 'datetimerange'\n)\n\nconst formatEmit = (emitDayjs: Dayjs | null, index?: number) => {\n if (!emitDayjs) return\n if (defaultTime) {\n const defaultTimeD = dayjs(\n defaultTime[index as number] || defaultTime\n ).locale(lang.value)\n return defaultTimeD\n .year(emitDayjs.year())\n .month(emitDayjs.month())\n .date(emitDayjs.date())\n }\n return emitDayjs\n}\n\nconst handleRangePick = (\n val: {\n minDate: Dayjs\n maxDate: Dayjs | null\n },\n close = true\n) => {\n const min_ = val.minDate\n const max_ = val.maxDate\n const minDate_ = formatEmit(min_, 0)\n const maxDate_ = formatEmit(max_, 1)\n\n if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n return\n }\n emit('calendar-change', [min_.toDate(), max_ && max_.toDate()])\n maxDate.value = maxDate_\n minDate.value = minDate_\n\n if (!showTime.value && close) {\n close = !minDate_ || !maxDate_\n }\n handleRangeConfirm(close)\n}\n\nconst minTimePickerVisible = ref(false)\nconst maxTimePickerVisible = ref(false)\n\nconst handleMinTimeClose = () => {\n minTimePickerVisible.value = false\n}\n\nconst handleMaxTimeClose = () => {\n maxTimePickerVisible.value = false\n}\n\nconst handleDateInput = (value: string | null, type: ChangeType) => {\n dateUserInput.value[type] = value\n const parsedValueD = dayjs(value, dateFormat.value).locale(lang.value)\n if (parsedValueD.isValid()) {\n if (disabledDate && disabledDate(parsedValueD.toDate())) {\n return\n }\n if (type === 'min') {\n leftDate.value = parsedValueD\n minDate.value = (minDate.value || leftDate.value)\n .year(parsedValueD.year())\n .month(parsedValueD.month())\n .date(parsedValueD.date())\n if (\n !props.unlinkPanels &&\n (!maxDate.value || maxDate.value.isBefore(minDate.value))\n ) {\n rightDate.value = parsedValueD.add(1, 'month')\n maxDate.value = minDate.value.add(1, 'month')\n }\n } else {\n rightDate.value = parsedValueD\n maxDate.value = (maxDate.value || rightDate.value)\n .year(parsedValueD.year())\n .month(parsedValueD.month())\n .date(parsedValueD.date())\n if (\n !props.unlinkPanels &&\n (!minDate.value || minDate.value.isAfter(maxDate.value))\n ) {\n leftDate.value = parsedValueD.subtract(1, 'month')\n minDate.value = maxDate.value.subtract(1, 'month')\n }\n }\n sortDates(minDate.value, maxDate.value)\n handleRangeConfirm(true)\n }\n}\n\nconst handleDateChange = (_: unknown, type: ChangeType) => {\n dateUserInput.value[type] = null\n}\n\nconst handleTimeInput = (value: string | null, type: ChangeType) => {\n timeUserInput.value[type] = value\n const parsedValueD = dayjs(value, timeFormat.value).locale(lang.value)\n\n if (parsedValueD.isValid()) {\n if (type === 'min') {\n minTimePickerVisible.value = true\n minDate.value = (minDate.value || leftDate.value)\n .hour(parsedValueD.hour())\n .minute(parsedValueD.minute())\n .second(parsedValueD.second())\n leftDate.value = minDate.value\n } else {\n maxTimePickerVisible.value = true\n maxDate.value = (maxDate.value || rightDate.value)\n .hour(parsedValueD.hour())\n .minute(parsedValueD.minute())\n .second(parsedValueD.second())\n rightDate.value = maxDate.value\n }\n }\n}\n\nconst handleTimeChange = (_value: string | null, type: ChangeType) => {\n timeUserInput.value[type] = null\n if (type === 'min') {\n leftDate.value = minDate.value!\n minTimePickerVisible.value = false\n if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n maxDate.value = minDate.value\n }\n } else {\n rightDate.value = maxDate.value!\n maxTimePickerVisible.value = false\n if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n minDate.value = maxDate.value\n }\n }\n handleRangeConfirm(true)\n}\n\nconst handleMinTimePick = (value: Dayjs, visible: boolean, first: boolean) => {\n if (timeUserInput.value.min) return\n if (value) {\n minDate.value = (minDate.value || leftDate.value)\n .hour(value.hour())\n .minute(value.minute())\n .second(value.second())\n }\n\n if (!first) {\n minTimePickerVisible.value = visible\n }\n\n if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n maxDate.value = minDate.value\n rightDate.value = value\n nextTick(() => {\n parseValue(props.parsedValue)\n })\n }\n handleRangeConfirm(true)\n}\n\nconst handleMaxTimePick = (\n value: Dayjs | null,\n visible: boolean,\n first: boolean\n) => {\n if (timeUserInput.value.max) return\n if (value) {\n maxDate.value = (maxDate.value || rightDate.value)\n .hour(value.hour())\n .minute(value.minute())\n .second(value.second())\n }\n\n if (!first) {\n maxTimePickerVisible.value = visible\n }\n\n if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n minDate.value = maxDate.value\n }\n handleRangeConfirm(true)\n}\n\nconst onClear = () => {\n handleClear()\n emit('clear')\n}\n\nconst handleClear = () => {\n let valueOnClear = null\n if (pickerBase?.emptyValues) {\n valueOnClear = pickerBase.emptyValues.valueOnClear.value\n }\n leftDate.value = getDefaultValue(unref(defaultValue), {\n lang: unref(lang),\n unit: 'month',\n unlinkPanels: props.unlinkPanels,\n })[0]\n rightDate.value = leftDate.value.add(1, 'month')\n maxDate.value = undefined\n minDate.value = undefined\n\n handleRangeConfirm(true)\n emit('pick', valueOnClear)\n}\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n return correctlyParseUserInput(\n value,\n format.value || '',\n lang.value,\n isDefaultFormat\n )\n}\nfunction sortDates(minDate: Dayjs | undefined, maxDate: Dayjs | undefined) {\n if (props.unlinkPanels && maxDate) {\n const minDateYear = minDate?.year() || 0\n const minDateMonth = minDate?.month() || 0\n const maxDateYear = maxDate.year()\n const maxDateMonth = maxDate.month()\n rightDate.value =\n minDateYear === maxDateYear && minDateMonth === maxDateMonth\n ? maxDate.add(1, unit)\n : maxDate\n } else {\n rightDate.value = leftDate.value.add(1, unit)\n if (maxDate) {\n rightDate.value = rightDate.value\n .hour(maxDate.hour())\n .minute(maxDate.minute())\n .second(maxDate.second())\n }\n }\n}\n\nemit('set-picker-option', ['isValidValue', isValidValue])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n"],"mappings":"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"}
1
+ {"version":3,"file":"panel-date-range.vue_vue_type_script_setup_true_lang.js","names":["border","$slots","singlePanel","editable","unlinkPanels","disabled","showWeekNumber","parsedValue","showFooter","showConfirm"],"sources":["../../../../../../../packages/components/date-picker-panel/src/date-picker-com/panel-date-range.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ppNs.b(),\n drpNs.b(),\n ppNs.is('border', border),\n ppNs.is('disabled', dateRangeDisabled),\n {\n 'has-sidebar': $slots.sidebar || hasShortcuts,\n 'has-time': showTime,\n 'single-panel': singlePanel,\n },\n ]\"\n >\n <div :class=\"ppNs.e('body-wrapper')\">\n <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n <button\n v-for=\"(shortcut, key) in shortcuts\"\n :key=\"key\"\n type=\"button\"\n :disabled=\"dateRangeDisabled\"\n :class=\"ppNs.e('shortcut')\"\n @click=\"handleShortcutClick(shortcut)\"\n >\n {{ shortcut.text }}\n </button>\n </div>\n <div :class=\"ppNs.e('body')\">\n <div v-if=\"showTime\" :class=\"drpNs.e('time-header')\">\n <span :class=\"drpNs.e('editors-wrap')\">\n <span :class=\"drpNs.e('time-picker-wrap')\">\n <el-input\n size=\"small\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.startDate')\"\n :class=\"drpNs.e('editor')\"\n :model-value=\"minVisibleDate\"\n :validate-event=\"false\"\n :readonly=\"!editable\"\n @input=\"(val) => handleDateInput(val, 'min')\"\n @change=\"(val) => handleDateChange(val, 'min')\"\n />\n </span>\n <span\n v-clickoutside=\"handleMinTimeClose\"\n :class=\"drpNs.e('time-picker-wrap')\"\n >\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.startTime')\"\n :model-value=\"minVisibleTime\"\n :validate-event=\"false\"\n :readonly=\"!editable\"\n @focus=\"minTimePickerVisible = true\"\n @input=\"(val) => handleTimeInput(val, 'min')\"\n @change=\"(val) => handleTimeChange(val, 'min')\"\n />\n <time-pick-panel\n :visible=\"minTimePickerVisible\"\n :format=\"timeFormat\"\n datetime-role=\"start\"\n :parsed-value=\"minDate || leftDate\"\n @pick=\"handleMinTimePick\"\n />\n </span>\n </span>\n <span>\n <el-icon><arrow-right /></el-icon>\n </span>\n <span :class=\"drpNs.e('editors-wrap')\" class=\"is-right\">\n <span :class=\"drpNs.e('time-picker-wrap')\">\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.endDate')\"\n :model-value=\"maxVisibleDate\"\n :readonly=\"!minDate || !editable\"\n :validate-event=\"false\"\n @input=\"(val) => handleDateInput(val, 'max')\"\n @change=\"(val) => handleDateChange(val, 'max')\"\n />\n </span>\n <span\n v-clickoutside=\"handleMaxTimeClose\"\n :class=\"drpNs.e('time-picker-wrap')\"\n >\n <el-input\n size=\"small\"\n :class=\"drpNs.e('editor')\"\n :disabled=\"rangeState.selecting || dateRangeDisabled\"\n :placeholder=\"t('el.datepicker.endTime')\"\n :model-value=\"maxVisibleTime\"\n :readonly=\"!minDate || !editable\"\n :validate-event=\"false\"\n @focus=\"minDate && (maxTimePickerVisible = true)\"\n @input=\"(val) => handleTimeInput(val, 'max')\"\n @change=\"(val) => handleTimeChange(val, 'max')\"\n />\n <time-pick-panel\n datetime-role=\"end\"\n :visible=\"maxTimePickerVisible\"\n :format=\"timeFormat\"\n :parsed-value=\"maxDate || rightDate\"\n @pick=\"handleMaxTimePick\"\n />\n </span>\n </span>\n </div>\n <div\n :class=\"[\n ppNs.e('content'),\n drpNs.e('content'),\n drpNs.is('left', !singlePanel),\n ]\"\n >\n <div :class=\"drpNs.e('header')\">\n <button\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :aria-label=\"t(`el.datepicker.prevYear`)\"\n class=\"d-arrow-left\"\n :disabled=\"dateRangeDisabled\"\n @click=\"leftPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon>\n <d-arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-show=\"leftCurrentView === 'date'\"\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :aria-label=\"t(`el.datepicker.prevMonth`)\"\n class=\"arrow-left\"\n :disabled=\"dateRangeDisabled\"\n @click=\"leftPrevMonth\"\n >\n <slot name=\"prev-month\">\n <el-icon>\n <arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels || singlePanel\"\n type=\"button\"\n :disabled=\"!enableYearArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.nextYear`)\"\n class=\"d-arrow-right\"\n @click=\"leftNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon>\n <d-arrow-right />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"(unlinkPanels && leftCurrentView === 'date') || singlePanel\"\n type=\"button\"\n :disabled=\"!enableMonthArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableMonthArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.nextMonth`)\"\n class=\"arrow-right\"\n @click=\"leftNextMonth\"\n >\n <slot name=\"next-month\">\n <el-icon>\n <arrow-right />\n </el-icon>\n </slot>\n </button>\n <div>\n <span\n role=\"button\"\n :class=\"drpNs.e('header-label')\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n @keydown.enter=\"showLeftPicker('year')\"\n @click=\"showLeftPicker('year')\"\n >\n {{ leftYearLabel }}\n </span>\n <span\n v-show=\"leftCurrentView === 'date'\"\n role=\"button\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n :class=\"[\n drpNs.e('header-label'),\n { active: leftCurrentView === 'month' },\n ]\"\n @keydown.enter=\"showLeftPicker('month')\"\n @click=\"showLeftPicker('month')\"\n >\n {{ t(`el.datepicker.month${leftDate.month() + 1}`) }}\n </span>\n </div>\n </div>\n <date-table\n v-if=\"leftCurrentView === 'date'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"range\"\n :date=\"leftDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :cell-class-name=\"cellClassName\"\n :show-week-number=\"showWeekNumber\"\n :disabled=\"dateRangeDisabled\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n <year-table\n v-if=\"leftCurrentView === 'year'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"year\"\n :date=\"leftDate\"\n :disabled-date=\"disabledDate\"\n :parsed-value=\"parsedValue\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleLeftYearPick\"\n />\n <month-table\n v-if=\"leftCurrentView === 'month'\"\n ref=\"leftCurrentViewRef\"\n selection-mode=\"month\"\n :date=\"leftDate\"\n :parsed-value=\"parsedValue\"\n :disabled-date=\"disabledDate\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleLeftMonthPick\"\n />\n </div>\n <div\n v-if=\"!singlePanel\"\n :class=\"[ppNs.e('content'), drpNs.e('content')]\"\n class=\"is-right\"\n >\n <div :class=\"drpNs.e('header')\">\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.prevYear`)\"\n class=\"d-arrow-left\"\n @click=\"rightPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon>\n <d-arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels && rightCurrentView === 'date'\"\n type=\"button\"\n :disabled=\"!enableMonthArrow || dateRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableMonthArrow || dateRangeDisabled),\n ]\"\n :aria-label=\"t(`el.datepicker.prevMonth`)\"\n class=\"arrow-left\"\n @click=\"rightPrevMonth\"\n >\n <slot name=\"prev-month\">\n <el-icon>\n <arrow-left />\n </el-icon>\n </slot>\n </button>\n <button\n type=\"button\"\n :aria-label=\"t(`el.datepicker.nextYear`)\"\n :class=\"ppNs.e('icon-btn')\"\n :disabled=\"dateRangeDisabled\"\n class=\"d-arrow-right\"\n @click=\"rightNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon>\n <d-arrow-right />\n </el-icon>\n </slot>\n </button>\n <button\n v-show=\"rightCurrentView === 'date'\"\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n :disabled=\"dateRangeDisabled\"\n :aria-label=\"t(`el.datepicker.nextMonth`)\"\n class=\"arrow-right\"\n @click=\"rightNextMonth\"\n >\n <slot name=\"next-month\">\n <el-icon>\n <arrow-right />\n </el-icon>\n </slot>\n </button>\n <div>\n <span\n role=\"button\"\n :class=\"drpNs.e('header-label')\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n @keydown.enter=\"showRightPicker('year')\"\n @click=\"showRightPicker('year')\"\n >\n {{ rightYearLabel }}\n </span>\n <span\n v-show=\"rightCurrentView === 'date'\"\n role=\"button\"\n aria-live=\"polite\"\n :tabindex=\"disabled ? undefined : 0\"\n :aria-disabled=\"disabled\"\n :class=\"[\n drpNs.e('header-label'),\n { active: rightCurrentView === 'month' },\n ]\"\n @keydown.enter=\"showRightPicker('month')\"\n @click=\"showRightPicker('month')\"\n >\n {{ t(`el.datepicker.month${rightDate.month() + 1}`) }}\n </span>\n </div>\n </div>\n <date-table\n v-if=\"rightCurrentView === 'date'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"range\"\n :date=\"rightDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :cell-class-name=\"cellClassName\"\n :show-week-number=\"showWeekNumber\"\n :disabled=\"dateRangeDisabled\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n <year-table\n v-if=\"rightCurrentView === 'year'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"year\"\n :date=\"rightDate\"\n :disabled-date=\"disabledDate\"\n :parsed-value=\"parsedValue\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleRightYearPick\"\n />\n <month-table\n v-if=\"rightCurrentView === 'month'\"\n ref=\"rightCurrentViewRef\"\n selection-mode=\"month\"\n :date=\"rightDate\"\n :parsed-value=\"parsedValue\"\n :disabled-date=\"disabledDate\"\n :disabled=\"dateRangeDisabled\"\n @pick=\"handleRightMonthPick\"\n />\n </div>\n </div>\n </div>\n <div\n v-if=\"showFooter && showTime && (showConfirm || clearable)\"\n :class=\"ppNs.e('footer')\"\n >\n <el-button\n v-if=\"clearable\"\n text\n size=\"small\"\n :class=\"ppNs.e('link-btn')\"\n @click=\"onClear\"\n >\n {{ t('el.datepicker.clear') }}\n </el-button>\n <el-button\n v-if=\"showConfirm\"\n plain\n size=\"small\"\n :class=\"ppNs.e('link-btn')\"\n :disabled=\"btnDisabled\"\n @click=\"handleRangeConfirm(false)\"\n >\n {{ t('el.datepicker.confirm') }}\n </el-button>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, nextTick, ref, toRef, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport { useLocale } from '@element-plus/hooks'\nimport ElButton from '@element-plus/components/button'\nimport ElInput from '@element-plus/components/input'\nimport {\n DEFAULT_FORMATS_DATE,\n DEFAULT_FORMATS_TIME,\n PICKER_BASE_INJECTION_KEY,\n TimePickPanel,\n extractDateFormat,\n extractTimeFormat,\n} from '@element-plus/components/time-picker'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n ArrowLeft,\n ArrowRight,\n DArrowLeft,\n DArrowRight,\n} from '@element-plus/icons-vue'\nimport { panelDateRangeProps } from '../props/panel-date-range'\nimport { useRangePicker } from '../composables/use-range-picker'\nimport {\n correctlyParseUserInput,\n getDefaultValue,\n isValidRange,\n} from '../utils'\nimport { usePanelDateRange } from '../composables/use-panel-date-range'\nimport { ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY } from '../constants'\nimport YearTable from './basic-year-table.vue'\nimport MonthTable from './basic-month-table.vue'\nimport DateTable from './basic-date-table.vue'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { Ref } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\ntype ChangeType = 'min' | 'max'\ntype UserInput = {\n min: string | null\n max: string | null\n}\n\nconst props = defineProps(panelDateRangeProps)\nconst emit = defineEmits([\n 'pick',\n 'set-picker-option',\n 'calendar-change',\n 'panel-change',\n 'clear',\n])\n\nconst unit = 'month'\n// FIXME: fix the type for ep picker\nconst pickerBase = inject(PICKER_BASE_INJECTION_KEY) as any\nconst isDefaultFormat = inject(\n ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY,\n undefined\n) as any\nconst { disabledDate, cellClassName, defaultTime, clearable } = pickerBase.props\nconst format: Ref<string | undefined> = toRef(pickerBase.props, 'format')\nconst shortcuts = toRef(pickerBase.props, 'shortcuts')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst { lang } = useLocale()\nconst leftDate = ref<Dayjs>(dayjs().locale(lang.value))\nconst rightDate = ref<Dayjs>(dayjs().locale(lang.value).add(1, unit))\n\nconst {\n minDate,\n maxDate,\n rangeState,\n ppNs,\n drpNs,\n handleChangeRange,\n handleRangeConfirm,\n handleShortcutClick,\n onSelect,\n parseValue,\n t,\n} = useRangePicker(props, {\n defaultValue,\n defaultTime,\n leftDate,\n rightDate,\n unit,\n sortDates,\n})\n\nwatch(\n () => props.visible,\n (visible) => {\n if (!visible && rangeState.value.selecting) {\n parseValue(props.parsedValue)\n onSelect(false)\n }\n }\n)\n\nconst dateUserInput = ref<UserInput>({\n min: null,\n max: null,\n})\n\nconst timeUserInput = ref<UserInput>({\n min: null,\n max: null,\n})\n\nconst {\n leftCurrentView,\n rightCurrentView,\n leftCurrentViewRef,\n rightCurrentViewRef,\n leftYear,\n rightYear,\n leftMonth,\n rightMonth,\n leftYearLabel,\n rightYearLabel,\n showLeftPicker,\n showRightPicker,\n handleLeftYearPick,\n handleRightYearPick,\n handleLeftMonthPick,\n handleRightMonthPick,\n handlePanelChange,\n adjustDateByView,\n} = usePanelDateRange(props, emit, leftDate, rightDate)\n\nconst hasShortcuts = computed(() => !!shortcuts.value.length)\n\nconst minVisibleDate = computed(() => {\n if (dateUserInput.value.min !== null) return dateUserInput.value.min\n if (minDate.value) return minDate.value.format(dateFormat.value)\n return ''\n})\n\nconst maxVisibleDate = computed(() => {\n if (dateUserInput.value.max !== null) return dateUserInput.value.max\n if (maxDate.value || minDate.value)\n return (maxDate.value || minDate.value)!.format(dateFormat.value)\n return ''\n})\n\nconst minVisibleTime = computed(() => {\n if (timeUserInput.value.min !== null) return timeUserInput.value.min\n if (minDate.value) return minDate.value.format(timeFormat.value)\n return ''\n})\n\nconst maxVisibleTime = computed(() => {\n if (timeUserInput.value.max !== null) return timeUserInput.value.max\n if (maxDate.value || minDate.value)\n return (maxDate.value || minDate.value)!.format(timeFormat.value)\n return ''\n})\n\nconst timeFormat = computed(() => {\n return (\n props.timeFormat ||\n extractTimeFormat(format.value || '') ||\n DEFAULT_FORMATS_TIME\n )\n})\n\nconst dateFormat = computed(() => {\n return (\n props.dateFormat ||\n extractDateFormat(format.value || '') ||\n DEFAULT_FORMATS_DATE\n )\n})\n\nconst isValidValue = (date: [Dayjs, Dayjs]) => {\n return (\n isValidRange(date) &&\n (disabledDate\n ? !disabledDate(date[0].toDate()) && !disabledDate(date[1].toDate())\n : true)\n )\n}\n\nconst leftPrevYear = () => {\n leftDate.value = adjustDateByView(\n leftCurrentView.value,\n leftDate.value,\n false\n )\n\n if (!props.unlinkPanels) {\n rightDate.value = leftDate.value.add(1, 'month')\n }\n handlePanelChange('year')\n}\n\nconst leftPrevMonth = () => {\n leftDate.value = leftDate.value.subtract(1, 'month')\n if (!props.unlinkPanels) {\n rightDate.value = leftDate.value.add(1, 'month')\n }\n handlePanelChange('month')\n}\n\nconst rightNextYear = () => {\n if (!props.unlinkPanels) {\n leftDate.value = adjustDateByView(\n rightCurrentView.value,\n leftDate.value,\n true\n )\n\n rightDate.value = leftDate.value.add(1, 'month')\n } else {\n rightDate.value = adjustDateByView(\n rightCurrentView.value,\n rightDate.value,\n true\n )\n }\n handlePanelChange('year')\n}\n\nconst rightNextMonth = () => {\n if (!props.unlinkPanels) {\n leftDate.value = leftDate.value.add(1, 'month')\n rightDate.value = leftDate.value.add(1, 'month')\n } else {\n rightDate.value = rightDate.value.add(1, 'month')\n }\n handlePanelChange('month')\n}\n\nconst leftNextYear = () => {\n leftDate.value = adjustDateByView(leftCurrentView.value, leftDate.value, true)\n\n handlePanelChange('year')\n}\n\nconst leftNextMonth = () => {\n leftDate.value = leftDate.value.add(1, 'month')\n handlePanelChange('month')\n}\n\nconst rightPrevYear = () => {\n rightDate.value = adjustDateByView(\n rightCurrentView.value,\n rightDate.value,\n false\n )\n\n handlePanelChange('year')\n}\n\nconst rightPrevMonth = () => {\n rightDate.value = rightDate.value.subtract(1, 'month')\n handlePanelChange('month')\n}\n\nconst enableMonthArrow = computed(() => {\n const nextMonth = (leftMonth.value + 1) % 12\n const yearOffset = leftMonth.value + 1 >= 12 ? 1 : 0\n return (\n props.singlePanel ||\n (props.unlinkPanels &&\n new Date(leftYear.value + yearOffset, nextMonth) <\n new Date(rightYear.value, rightMonth.value))\n )\n})\n\nconst enableYearArrow = computed(() => {\n return (\n props.singlePanel ||\n (props.unlinkPanels &&\n rightYear.value * 12 +\n rightMonth.value -\n (leftYear.value * 12 + leftMonth.value + 1) >=\n 12)\n )\n})\n\nconst dateRangeDisabled = useFormDisabled()\n\nconst btnDisabled = computed(() => {\n return !(\n minDate.value &&\n maxDate.value &&\n !rangeState.value.selecting &&\n isValidRange([minDate.value, maxDate.value]) &&\n !dateRangeDisabled.value\n )\n})\n\nconst showTime = computed(\n () => props.type === 'datetime' || props.type === 'datetimerange'\n)\n\nconst formatEmit = (emitDayjs: Dayjs | null, index?: number) => {\n if (!emitDayjs) return\n if (defaultTime) {\n const defaultTimeD = dayjs(\n defaultTime[index as number] || defaultTime\n ).locale(lang.value)\n return defaultTimeD\n .year(emitDayjs.year())\n .month(emitDayjs.month())\n .date(emitDayjs.date())\n }\n return emitDayjs\n}\n\nconst handleRangePick = (\n val: {\n minDate: Dayjs\n maxDate: Dayjs | null\n },\n close = true\n) => {\n const min_ = val.minDate\n const max_ = val.maxDate\n const minDate_ = formatEmit(min_, 0)\n const maxDate_ = formatEmit(max_, 1)\n\n if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n return\n }\n emit('calendar-change', [min_.toDate(), max_ && max_.toDate()])\n maxDate.value = maxDate_\n minDate.value = minDate_\n\n if (!showTime.value && close) {\n close = !minDate_ || !maxDate_\n }\n handleRangeConfirm(close)\n}\n\nconst minTimePickerVisible = ref(false)\nconst maxTimePickerVisible = ref(false)\n\nconst handleMinTimeClose = () => {\n minTimePickerVisible.value = false\n}\n\nconst handleMaxTimeClose = () => {\n maxTimePickerVisible.value = false\n}\n\nconst handleDateInput = (value: string | null, type: ChangeType) => {\n dateUserInput.value[type] = value\n const parsedValueD = dayjs(value, dateFormat.value).locale(lang.value)\n if (parsedValueD.isValid()) {\n if (disabledDate && disabledDate(parsedValueD.toDate())) {\n return\n }\n if (type === 'min') {\n leftDate.value = parsedValueD\n minDate.value = (minDate.value || leftDate.value)\n .year(parsedValueD.year())\n .month(parsedValueD.month())\n .date(parsedValueD.date())\n if (\n !props.unlinkPanels &&\n (!maxDate.value || maxDate.value.isBefore(minDate.value))\n ) {\n rightDate.value = parsedValueD.add(1, 'month')\n maxDate.value = minDate.value.add(1, 'month')\n }\n } else {\n rightDate.value = parsedValueD\n maxDate.value = (maxDate.value || rightDate.value)\n .year(parsedValueD.year())\n .month(parsedValueD.month())\n .date(parsedValueD.date())\n if (\n !props.unlinkPanels &&\n (!minDate.value || minDate.value.isAfter(maxDate.value))\n ) {\n leftDate.value = parsedValueD.subtract(1, 'month')\n minDate.value = maxDate.value.subtract(1, 'month')\n }\n }\n sortDates(minDate.value, maxDate.value)\n handleRangeConfirm(true)\n }\n}\n\nconst handleDateChange = (_: unknown, type: ChangeType) => {\n dateUserInput.value[type] = null\n}\n\nconst handleTimeInput = (value: string | null, type: ChangeType) => {\n timeUserInput.value[type] = value\n const parsedValueD = dayjs(value, timeFormat.value).locale(lang.value)\n\n if (parsedValueD.isValid()) {\n if (type === 'min') {\n minTimePickerVisible.value = true\n minDate.value = (minDate.value || leftDate.value)\n .hour(parsedValueD.hour())\n .minute(parsedValueD.minute())\n .second(parsedValueD.second())\n leftDate.value = minDate.value\n } else {\n maxTimePickerVisible.value = true\n maxDate.value = (maxDate.value || rightDate.value)\n .hour(parsedValueD.hour())\n .minute(parsedValueD.minute())\n .second(parsedValueD.second())\n rightDate.value = maxDate.value\n }\n }\n}\n\nconst handleTimeChange = (_value: string | null, type: ChangeType) => {\n timeUserInput.value[type] = null\n if (type === 'min') {\n leftDate.value = minDate.value!\n minTimePickerVisible.value = false\n if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n maxDate.value = minDate.value\n }\n } else {\n rightDate.value = maxDate.value!\n maxTimePickerVisible.value = false\n if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n minDate.value = maxDate.value\n }\n }\n handleRangeConfirm(true)\n}\n\nconst handleMinTimePick = (value: Dayjs, visible: boolean, first: boolean) => {\n if (timeUserInput.value.min) return\n if (value) {\n minDate.value = (minDate.value || leftDate.value)\n .hour(value.hour())\n .minute(value.minute())\n .second(value.second())\n }\n\n if (!first) {\n minTimePickerVisible.value = visible\n }\n\n if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n maxDate.value = minDate.value\n rightDate.value = value\n nextTick(() => {\n parseValue(props.parsedValue)\n })\n }\n handleRangeConfirm(true)\n}\n\nconst handleMaxTimePick = (\n value: Dayjs | null,\n visible: boolean,\n first: boolean\n) => {\n if (timeUserInput.value.max) return\n if (value) {\n maxDate.value = (maxDate.value || rightDate.value)\n .hour(value.hour())\n .minute(value.minute())\n .second(value.second())\n }\n\n if (!first) {\n maxTimePickerVisible.value = visible\n }\n\n if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n minDate.value = maxDate.value\n }\n handleRangeConfirm(true)\n}\n\nconst onClear = () => {\n handleClear()\n emit('clear')\n}\n\nconst handleClear = () => {\n let valueOnClear = null\n if (pickerBase?.emptyValues) {\n valueOnClear = pickerBase.emptyValues.valueOnClear.value\n }\n leftDate.value = getDefaultValue(unref(defaultValue), {\n lang: unref(lang),\n unit: 'month',\n unlinkPanels: props.unlinkPanels,\n })[0]\n rightDate.value = leftDate.value.add(1, 'month')\n maxDate.value = undefined\n minDate.value = undefined\n\n handleRangeConfirm(true)\n emit('pick', valueOnClear)\n}\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n return correctlyParseUserInput(\n value,\n format.value || '',\n lang.value,\n isDefaultFormat\n )\n}\nfunction sortDates(minDate: Dayjs | undefined, maxDate: Dayjs | undefined) {\n if (props.unlinkPanels && maxDate) {\n const minDateYear = minDate?.year() || 0\n const minDateMonth = minDate?.month() || 0\n const maxDateYear = maxDate.year()\n const maxDateMonth = maxDate.month()\n rightDate.value =\n minDateYear === maxDateYear && minDateMonth === maxDateMonth\n ? maxDate.add(1, unit)\n : maxDate\n } else {\n rightDate.value = leftDate.value.add(1, unit)\n if (maxDate) {\n rightDate.value = rightDate.value\n .hour(maxDate.hour())\n .minute(maxDate.minute())\n .second(maxDate.second())\n }\n }\n}\n\nemit('set-picker-option', ['isValidValue', isValidValue])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"panel-month-range.js","names":[],"sources":["../../../../../../../packages/components/date-picker-panel/src/date-picker-com/panel-month-range.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ppNs.b(),\n drpNs.b(),\n ppNs.is('border', border),\n ppNs.is('disabled', monthRangeDisabled),\n {\n 'has-sidebar': Boolean($slots.sidebar) || hasShortcuts,\n },\n ]\"\n >\n <div :class=\"ppNs.e('body-wrapper')\">\n <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n <button\n v-for=\"(shortcut, key) in shortcuts\"\n :key=\"key\"\n type=\"button\"\n :class=\"ppNs.e('shortcut')\"\n :disabled=\"monthRangeDisabled\"\n @click=\"handleShortcutClick(shortcut)\"\n >\n {{ shortcut.text }}\n </button>\n </div>\n <div :class=\"ppNs.e('body')\">\n <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-left\">\n <div :class=\"drpNs.e('header')\">\n <button\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n class=\"d-arrow-left\"\n :disabled=\"monthRangeDisabled\"\n @click=\"leftPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon><d-arrow-left /></el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || monthRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || monthRangeDisabled),\n ]\"\n class=\"d-arrow-right\"\n @click=\"leftNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon><d-arrow-right /></el-icon>\n </slot>\n </button>\n <div>{{ leftLabel }}</div>\n </div>\n <month-table\n selection-mode=\"range\"\n :date=\"leftDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :disabled=\"monthRangeDisabled\"\n :cell-class-name=\"cellClassName\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n </div>\n <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-right\">\n <div :class=\"drpNs.e('header')\">\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || monthRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || monthRangeDisabled),\n ]\"\n class=\"d-arrow-left\"\n @click=\"rightPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon><d-arrow-left /></el-icon>\n </slot>\n </button>\n <button\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n class=\"d-arrow-right\"\n :disabled=\"monthRangeDisabled\"\n @click=\"rightNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon><d-arrow-right /></el-icon>\n </slot>\n </button>\n <div>{{ rightLabel }}</div>\n </div>\n <month-table\n selection-mode=\"range\"\n :date=\"rightDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :disabled=\"monthRangeDisabled\"\n :cell-class-name=\"cellClassName\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, ref, toRef, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport ElIcon from '@element-plus/components/icon'\nimport { useLocale } from '@element-plus/hooks'\nimport { DArrowLeft, DArrowRight } from '@element-plus/icons-vue'\nimport { PICKER_BASE_INJECTION_KEY } from '@element-plus/components/time-picker'\nimport {\n correctlyParseUserInput,\n getDefaultValue,\n isValidRange,\n} from '../utils'\nimport {\n panelMonthRangeEmits,\n panelMonthRangeProps,\n} from '../props/panel-month-range'\nimport { useMonthRangeHeader } from '../composables/use-month-range-header'\nimport { useRangePicker } from '../composables/use-range-picker'\nimport { ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY } from '../constants'\nimport MonthTable from './basic-month-table.vue'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { Dayjs } from 'dayjs'\n\ndefineOptions({\n name: 'DatePickerMonthRange',\n})\n\nconst props = defineProps(panelMonthRangeProps)\nconst emit = defineEmits(panelMonthRangeEmits)\nconst unit = 'year'\n\nconst { lang } = useLocale()\nconst pickerBase = inject(PICKER_BASE_INJECTION_KEY) as any\nconst isDefaultFormat = inject(\n ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY,\n undefined\n) as any\nconst { shortcuts, disabledDate, cellClassName } = pickerBase.props\nconst format = toRef(pickerBase.props, 'format')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst leftDate = ref(dayjs().locale(lang.value))\nconst rightDate = ref(dayjs().locale(lang.value).add(1, unit))\n\nconst {\n minDate,\n maxDate,\n rangeState,\n ppNs,\n drpNs,\n\n handleChangeRange,\n handleRangeConfirm,\n handleShortcutClick,\n onSelect,\n parseValue,\n} = useRangePicker(props, {\n defaultValue,\n leftDate,\n rightDate,\n unit,\n sortDates,\n})\n\nconst hasShortcuts = computed(() => !!shortcuts.length)\n\nconst {\n leftPrevYear,\n rightNextYear,\n leftNextYear,\n rightPrevYear,\n leftLabel,\n rightLabel,\n leftYear,\n rightYear,\n} = useMonthRangeHeader({\n unlinkPanels: toRef(props, 'unlinkPanels'),\n leftDate,\n rightDate,\n})\n\nconst enableYearArrow = computed(() => {\n return props.unlinkPanels && rightYear.value > leftYear.value + 1\n})\n\ntype RangePickValue = {\n minDate: Dayjs\n maxDate: Dayjs\n}\n\nconst handleRangePick = (val: RangePickValue, close = true) => {\n // const defaultTime = props.defaultTime || []\n // const minDate_ = modifyWithTimeString(val.minDate, defaultTime[0])\n // const maxDate_ = modifyWithTimeString(val.maxDate, defaultTime[1])\n // todo\n const minDate_ = val.minDate\n const maxDate_ = val.maxDate\n if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n return\n }\n emit('calendar-change', [minDate_.toDate(), maxDate_ && maxDate_.toDate()])\n maxDate.value = maxDate_\n minDate.value = minDate_\n\n if (!close) return\n handleRangeConfirm()\n}\n\nconst handleClear = () => {\n let valueOnClear = null\n if (pickerBase?.emptyValues) {\n valueOnClear = pickerBase.emptyValues.valueOnClear.value\n }\n leftDate.value = getDefaultValue(unref(defaultValue), {\n lang: unref(lang),\n unit: 'year',\n unlinkPanels: props.unlinkPanels,\n })[0]\n rightDate.value = leftDate.value.add(1, 'year')\n emit('pick', valueOnClear)\n}\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n return correctlyParseUserInput(\n value,\n format.value,\n lang.value,\n isDefaultFormat\n )\n}\n\nfunction sortDates(minDate: Dayjs | undefined, maxDate: Dayjs | undefined) {\n if (props.unlinkPanels && maxDate) {\n const minDateYear = minDate?.year() || 0\n const maxDateYear = maxDate.year()\n rightDate.value =\n minDateYear === maxDateYear ? maxDate.add(1, unit) : maxDate\n } else {\n rightDate.value = leftDate.value.add(1, unit)\n }\n}\n\nconst monthRangeDisabled = useFormDisabled()\n\nwatch(\n () => props.visible,\n (visible) => {\n if (!visible && rangeState.value.selecting) {\n parseValue(props.parsedValue)\n onSelect(false)\n }\n }\n)\n\nemit('set-picker-option', ['isValidValue', isValidRange])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n"],"mappings":""}
1
+ {"version":3,"file":"panel-month-range.js","names":[],"sources":["../../../../../../../packages/components/date-picker-panel/src/date-picker-com/panel-month-range.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ppNs.b(),\n drpNs.b(),\n ppNs.is('border', border),\n ppNs.is('disabled', monthRangeDisabled),\n {\n 'has-sidebar': Boolean($slots.sidebar) || hasShortcuts,\n 'single-panel': singlePanel,\n },\n ]\"\n >\n <div :class=\"ppNs.e('body-wrapper')\">\n <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n <button\n v-for=\"(shortcut, key) in shortcuts\"\n :key=\"key\"\n type=\"button\"\n :class=\"ppNs.e('shortcut')\"\n :disabled=\"monthRangeDisabled\"\n @click=\"handleShortcutClick(shortcut)\"\n >\n {{ shortcut.text }}\n </button>\n </div>\n <div :class=\"ppNs.e('body')\">\n <div\n :class=\"[\n ppNs.e('content'),\n drpNs.e('content'),\n drpNs.is('left', !singlePanel),\n ]\"\n >\n <div :class=\"drpNs.e('header')\">\n <button\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n class=\"d-arrow-left\"\n :disabled=\"monthRangeDisabled\"\n @click=\"leftPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon><d-arrow-left /></el-icon>\n </slot>\n </button>\n <button\n v-if=\"unlinkPanels || singlePanel\"\n type=\"button\"\n :disabled=\"!enableYearArrow || monthRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || monthRangeDisabled),\n ]\"\n class=\"d-arrow-right\"\n @click=\"leftNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon><d-arrow-right /></el-icon>\n </slot>\n </button>\n <div>{{ leftLabel }}</div>\n </div>\n <month-table\n selection-mode=\"range\"\n :date=\"leftDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :disabled=\"monthRangeDisabled\"\n :cell-class-name=\"cellClassName\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n </div>\n <div\n v-if=\"!singlePanel\"\n :class=\"[ppNs.e('content'), drpNs.e('content')]\"\n class=\"is-right\"\n >\n <div :class=\"drpNs.e('header')\">\n <button\n v-if=\"unlinkPanels\"\n type=\"button\"\n :disabled=\"!enableYearArrow || monthRangeDisabled\"\n :class=\"[\n ppNs.e('icon-btn'),\n ppNs.is('disabled', !enableYearArrow || monthRangeDisabled),\n ]\"\n class=\"d-arrow-left\"\n @click=\"rightPrevYear\"\n >\n <slot name=\"prev-year\">\n <el-icon><d-arrow-left /></el-icon>\n </slot>\n </button>\n <button\n type=\"button\"\n :class=\"ppNs.e('icon-btn')\"\n class=\"d-arrow-right\"\n :disabled=\"monthRangeDisabled\"\n @click=\"rightNextYear\"\n >\n <slot name=\"next-year\">\n <el-icon><d-arrow-right /></el-icon>\n </slot>\n </button>\n <div>{{ rightLabel }}</div>\n </div>\n <month-table\n selection-mode=\"range\"\n :date=\"rightDate\"\n :min-date=\"minDate\"\n :max-date=\"maxDate\"\n :range-state=\"rangeState\"\n :disabled-date=\"disabledDate\"\n :disabled=\"monthRangeDisabled\"\n :cell-class-name=\"cellClassName\"\n @changerange=\"handleChangeRange\"\n @pick=\"handleRangePick\"\n @select=\"onSelect\"\n />\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, ref, toRef, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport ElIcon from '@element-plus/components/icon'\nimport { useLocale } from '@element-plus/hooks'\nimport { DArrowLeft, DArrowRight } from '@element-plus/icons-vue'\nimport { PICKER_BASE_INJECTION_KEY } from '@element-plus/components/time-picker'\nimport {\n correctlyParseUserInput,\n getDefaultValue,\n isValidRange,\n} from '../utils'\nimport {\n panelMonthRangeEmits,\n panelMonthRangeProps,\n} from '../props/panel-month-range'\nimport { useMonthRangeHeader } from '../composables/use-month-range-header'\nimport { useRangePicker } from '../composables/use-range-picker'\nimport { ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY } from '../constants'\nimport MonthTable from './basic-month-table.vue'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { Dayjs } from 'dayjs'\n\ndefineOptions({\n name: 'DatePickerMonthRange',\n})\n\nconst props = defineProps(panelMonthRangeProps)\nconst emit = defineEmits(panelMonthRangeEmits)\nconst unit = 'year'\n\nconst { lang } = useLocale()\nconst pickerBase = inject(PICKER_BASE_INJECTION_KEY) as any\nconst isDefaultFormat = inject(\n ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY,\n undefined\n) as any\nconst { shortcuts, disabledDate, cellClassName } = pickerBase.props\nconst format = toRef(pickerBase.props, 'format')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst leftDate = ref(dayjs().locale(lang.value))\nconst rightDate = ref(dayjs().locale(lang.value).add(1, unit))\n\nconst {\n minDate,\n maxDate,\n rangeState,\n ppNs,\n drpNs,\n\n handleChangeRange,\n handleRangeConfirm,\n handleShortcutClick,\n onSelect,\n parseValue,\n} = useRangePicker(props, {\n defaultValue,\n leftDate,\n rightDate,\n unit,\n sortDates,\n})\n\nconst hasShortcuts = computed(() => !!shortcuts.length)\n\nconst {\n leftPrevYear,\n rightNextYear,\n leftNextYear,\n rightPrevYear,\n leftLabel,\n rightLabel,\n leftYear,\n rightYear,\n} = useMonthRangeHeader({\n unlinkPanels: toRef(props, 'unlinkPanels'),\n leftDate,\n rightDate,\n})\n\nconst enableYearArrow = computed(() => {\n return (\n props.singlePanel ||\n (props.unlinkPanels && rightYear.value > leftYear.value + 1)\n )\n})\n\ntype RangePickValue = {\n minDate: Dayjs\n maxDate: Dayjs\n}\n\nconst handleRangePick = (val: RangePickValue, close = true) => {\n // const defaultTime = props.defaultTime || []\n // const minDate_ = modifyWithTimeString(val.minDate, defaultTime[0])\n // const maxDate_ = modifyWithTimeString(val.maxDate, defaultTime[1])\n // todo\n const minDate_ = val.minDate\n const maxDate_ = val.maxDate\n if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n return\n }\n emit('calendar-change', [minDate_.toDate(), maxDate_ && maxDate_.toDate()])\n maxDate.value = maxDate_\n minDate.value = minDate_\n\n if (!close) return\n handleRangeConfirm()\n}\n\nconst handleClear = () => {\n let valueOnClear = null\n if (pickerBase?.emptyValues) {\n valueOnClear = pickerBase.emptyValues.valueOnClear.value\n }\n leftDate.value = getDefaultValue(unref(defaultValue), {\n lang: unref(lang),\n unit: 'year',\n unlinkPanels: props.unlinkPanels,\n })[0]\n rightDate.value = leftDate.value.add(1, 'year')\n emit('pick', valueOnClear)\n}\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n return correctlyParseUserInput(\n value,\n format.value,\n lang.value,\n isDefaultFormat\n )\n}\n\nfunction sortDates(minDate: Dayjs | undefined, maxDate: Dayjs | undefined) {\n if (props.unlinkPanels && maxDate) {\n const minDateYear = minDate?.year() || 0\n const maxDateYear = maxDate.year()\n rightDate.value =\n minDateYear === maxDateYear ? maxDate.add(1, unit) : maxDate\n } else {\n rightDate.value = leftDate.value.add(1, unit)\n }\n}\n\nconst monthRangeDisabled = useFormDisabled()\n\nwatch(\n () => props.visible,\n (visible) => {\n if (!visible && rangeState.value.selecting) {\n parseValue(props.parsedValue)\n onSelect(false)\n }\n }\n)\n\nemit('set-picker-option', ['isValidValue', isValidRange])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n"],"mappings":""}