@mui/x-date-pickers-pro 7.0.0-beta.2 → 7.0.0-beta.5

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 (278) hide show
  1. package/CHANGELOG.md +429 -30
  2. package/DateRangeCalendar/DateRangeCalendar.js +3 -1
  3. package/DateRangeCalendar/DateRangeCalendar.types.d.ts +3 -0
  4. package/DateRangePicker/DateRangePicker.d.ts +1 -1
  5. package/DateRangePicker/DateRangePicker.js +9 -9
  6. package/DateRangePicker/DateRangePicker.types.d.ts +3 -3
  7. package/DateRangePicker/DateRangePickerToolbar.d.ts +5 -2
  8. package/DateRangePicker/DateRangePickerToolbar.js +22 -2
  9. package/DateTimeRangePicker/DateTimeRangePicker.d.ts +1 -1
  10. package/DateTimeRangePicker/DateTimeRangePicker.js +11 -12
  11. package/DateTimeRangePicker/DateTimeRangePicker.types.d.ts +3 -3
  12. package/DateTimeRangePicker/DateTimeRangePickerTabs.js +7 -1
  13. package/DateTimeRangePicker/DateTimeRangePickerToolbar.d.ts +3 -0
  14. package/DateTimeRangePicker/DateTimeRangePickerToolbar.js +45 -9
  15. package/DateTimeRangePicker/shared.js +8 -3
  16. package/DesktopDateRangePicker/DesktopDateRangePicker.d.ts +1 -1
  17. package/DesktopDateRangePicker/DesktopDateRangePicker.js +9 -9
  18. package/DesktopDateRangePicker/DesktopDateRangePicker.types.d.ts +3 -3
  19. package/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.d.ts +1 -1
  20. package/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +11 -12
  21. package/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.types.d.ts +3 -3
  22. package/MobileDateRangePicker/MobileDateRangePicker.d.ts +1 -1
  23. package/MobileDateRangePicker/MobileDateRangePicker.js +9 -9
  24. package/MobileDateRangePicker/MobileDateRangePicker.types.d.ts +3 -3
  25. package/MobileDateTimeRangePicker/MobileDateTimeRangePicker.d.ts +1 -1
  26. package/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +11 -12
  27. package/MobileDateTimeRangePicker/MobileDateTimeRangePicker.types.d.ts +3 -3
  28. package/MultiInputDateRangeField/MultiInputDateRangeField.d.ts +1 -1
  29. package/MultiInputDateRangeField/MultiInputDateRangeField.js +17 -19
  30. package/MultiInputDateRangeField/MultiInputDateRangeField.types.d.ts +11 -14
  31. package/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.d.ts +1 -1
  32. package/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.js +17 -19
  33. package/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.types.d.ts +12 -16
  34. package/MultiInputTimeRangeField/MultiInputTimeRangeField.d.ts +1 -1
  35. package/MultiInputTimeRangeField/MultiInputTimeRangeField.js +17 -19
  36. package/MultiInputTimeRangeField/MultiInputTimeRangeField.types.d.ts +12 -16
  37. package/SingleInputDateRangeField/SingleInputDateRangeField.d.ts +2 -2
  38. package/SingleInputDateRangeField/SingleInputDateRangeField.js +12 -10
  39. package/SingleInputDateRangeField/SingleInputDateRangeField.types.d.ts +11 -14
  40. package/SingleInputDateRangeField/index.d.ts +1 -1
  41. package/SingleInputDateRangeField/useSingleInputDateRangeField.d.ts +2 -3
  42. package/SingleInputDateRangeField/useSingleInputDateRangeField.js +2 -15
  43. package/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.d.ts +2 -2
  44. package/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.js +12 -10
  45. package/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.types.d.ts +12 -15
  46. package/SingleInputDateTimeRangeField/index.d.ts +1 -1
  47. package/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.d.ts +2 -3
  48. package/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +2 -20
  49. package/SingleInputTimeRangeField/SingleInputTimeRangeField.d.ts +2 -2
  50. package/SingleInputTimeRangeField/SingleInputTimeRangeField.js +11 -9
  51. package/SingleInputTimeRangeField/SingleInputTimeRangeField.types.d.ts +12 -15
  52. package/SingleInputTimeRangeField/index.d.ts +1 -1
  53. package/SingleInputTimeRangeField/useSingleInputTimeRangeField.d.ts +2 -3
  54. package/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +2 -14
  55. package/StaticDateRangePicker/StaticDateRangePicker.js +0 -1
  56. package/StaticDateRangePicker/StaticDateRangePicker.types.d.ts +1 -1
  57. package/index.d.ts +0 -1
  58. package/index.js +2 -1
  59. package/internals/hooks/models/useRangePicker.d.ts +5 -5
  60. package/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.d.ts +1 -1
  61. package/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +16 -7
  62. package/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.types.d.ts +5 -5
  63. package/internals/hooks/useEnrichedRangePickerFieldProps.d.ts +15 -15
  64. package/internals/hooks/useEnrichedRangePickerFieldProps.js +37 -40
  65. package/internals/hooks/useMobileRangePicker/useMobileRangePicker.d.ts +1 -1
  66. package/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +18 -9
  67. package/internals/hooks/useMobileRangePicker/useMobileRangePicker.types.d.ts +5 -5
  68. package/internals/hooks/useMultiInputFieldSelectedSections.d.ts +21 -0
  69. package/internals/hooks/useMultiInputFieldSelectedSections.js +43 -0
  70. package/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.d.ts +1 -1
  71. package/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +17 -12
  72. package/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.d.ts +2 -3
  73. package/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +23 -31
  74. package/internals/hooks/useMultiInputRangeField/useMultiInputRangeField.types.d.ts +4 -4
  75. package/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.d.ts +2 -3
  76. package/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +23 -25
  77. package/internals/hooks/useRangePosition.d.ts +2 -4
  78. package/internals/hooks/useRangePosition.js +3 -6
  79. package/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +1 -0
  80. package/internals/hooks/useStaticRangePicker/useStaticRangePicker.types.d.ts +1 -2
  81. package/internals/models/dateRange.d.ts +3 -15
  82. package/internals/models/dateTimeRange.d.ts +4 -6
  83. package/internals/models/index.d.ts +0 -1
  84. package/internals/models/index.js +0 -1
  85. package/internals/models/timeRange.d.ts +3 -6
  86. package/internals/utils/date-fields-utils.d.ts +1 -5
  87. package/internals/utils/releaseInfo.js +1 -1
  88. package/internals/utils/valueManagers.d.ts +1 -2
  89. package/internals/utils/valueManagers.js +11 -6
  90. package/models/fields.d.ts +69 -0
  91. package/models/index.d.ts +1 -0
  92. package/models/index.js +1 -0
  93. package/modern/DateRangeCalendar/DateRangeCalendar.js +3 -1
  94. package/modern/DateRangePicker/DateRangePicker.js +9 -9
  95. package/modern/DateRangePicker/DateRangePickerToolbar.js +22 -2
  96. package/modern/DateTimeRangePicker/DateTimeRangePicker.js +11 -12
  97. package/modern/DateTimeRangePicker/DateTimeRangePickerTabs.js +7 -1
  98. package/modern/DateTimeRangePicker/DateTimeRangePickerToolbar.js +45 -9
  99. package/modern/DateTimeRangePicker/shared.js +7 -2
  100. package/modern/DesktopDateRangePicker/DesktopDateRangePicker.js +9 -9
  101. package/modern/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +11 -12
  102. package/modern/MobileDateRangePicker/MobileDateRangePicker.js +9 -9
  103. package/modern/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +11 -12
  104. package/modern/MultiInputDateRangeField/MultiInputDateRangeField.js +17 -19
  105. package/modern/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.js +17 -19
  106. package/modern/MultiInputTimeRangeField/MultiInputTimeRangeField.js +17 -19
  107. package/modern/SingleInputDateRangeField/SingleInputDateRangeField.js +12 -10
  108. package/modern/SingleInputDateRangeField/useSingleInputDateRangeField.js +2 -14
  109. package/modern/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.js +12 -10
  110. package/modern/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +2 -19
  111. package/modern/SingleInputTimeRangeField/SingleInputTimeRangeField.js +11 -9
  112. package/modern/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +2 -13
  113. package/modern/StaticDateRangePicker/StaticDateRangePicker.js +0 -1
  114. package/modern/index.js +2 -1
  115. package/modern/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +16 -7
  116. package/modern/internals/hooks/useEnrichedRangePickerFieldProps.js +34 -37
  117. package/modern/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +18 -9
  118. package/modern/internals/hooks/useMultiInputFieldSelectedSections.js +40 -0
  119. package/modern/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +17 -12
  120. package/modern/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +23 -30
  121. package/modern/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +23 -24
  122. package/modern/internals/hooks/useRangePosition.js +3 -6
  123. package/modern/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +1 -0
  124. package/modern/internals/models/index.js +0 -1
  125. package/modern/internals/utils/releaseInfo.js +1 -1
  126. package/modern/internals/utils/valueManagers.js +11 -6
  127. package/modern/models/index.js +1 -0
  128. package/node/DateRangeCalendar/DateRangeCalendar.js +3 -1
  129. package/node/DateRangePicker/DateRangePicker.js +9 -9
  130. package/node/DateRangePicker/DateRangePickerToolbar.js +22 -2
  131. package/node/DateTimeRangePicker/DateTimeRangePicker.js +11 -12
  132. package/node/DateTimeRangePicker/DateTimeRangePickerTabs.js +7 -1
  133. package/node/DateTimeRangePicker/DateTimeRangePickerToolbar.js +45 -9
  134. package/node/DateTimeRangePicker/shared.js +7 -2
  135. package/node/DesktopDateRangePicker/DesktopDateRangePicker.js +9 -9
  136. package/node/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +11 -12
  137. package/node/MobileDateRangePicker/MobileDateRangePicker.js +9 -9
  138. package/node/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +13 -14
  139. package/node/MultiInputDateRangeField/MultiInputDateRangeField.js +17 -19
  140. package/node/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.js +17 -19
  141. package/node/MultiInputTimeRangeField/MultiInputTimeRangeField.js +17 -19
  142. package/node/SingleInputDateRangeField/SingleInputDateRangeField.js +12 -10
  143. package/node/SingleInputDateRangeField/useSingleInputDateRangeField.js +2 -16
  144. package/node/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.js +15 -13
  145. package/node/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +2 -21
  146. package/node/SingleInputTimeRangeField/SingleInputTimeRangeField.js +11 -9
  147. package/node/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +2 -15
  148. package/node/StaticDateRangePicker/StaticDateRangePicker.js +0 -1
  149. package/node/index.js +1 -1
  150. package/node/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +16 -7
  151. package/node/internals/hooks/useEnrichedRangePickerFieldProps.js +33 -36
  152. package/node/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +18 -9
  153. package/node/internals/hooks/useMultiInputFieldSelectedSections.js +50 -0
  154. package/node/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +16 -11
  155. package/node/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +23 -31
  156. package/node/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +23 -25
  157. package/node/internals/hooks/useRangePosition.js +3 -8
  158. package/node/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +1 -0
  159. package/node/internals/models/index.js +0 -11
  160. package/node/internals/utils/releaseInfo.js +1 -1
  161. package/node/internals/utils/valueManagers.js +10 -5
  162. package/node/models/index.js +11 -0
  163. package/package.json +5 -5
  164. package/themeAugmentation/props.d.ts +15 -14
  165. package/internals/models/fields.d.ts +0 -49
  166. package/legacy/AdapterDateFns/index.js +0 -1
  167. package/legacy/AdapterDateFnsJalali/index.js +0 -1
  168. package/legacy/AdapterDateFnsV3/index.js +0 -1
  169. package/legacy/AdapterDayjs/index.js +0 -1
  170. package/legacy/AdapterLuxon/index.js +0 -1
  171. package/legacy/AdapterMoment/index.js +0 -1
  172. package/legacy/AdapterMomentHijri/index.js +0 -1
  173. package/legacy/AdapterMomentJalaali/index.js +0 -1
  174. package/legacy/DateRangeCalendar/DateRangeCalendar.js +0 -764
  175. package/legacy/DateRangeCalendar/DateRangeCalendar.types.js +0 -1
  176. package/legacy/DateRangeCalendar/dateRangeCalendarClasses.js +0 -5
  177. package/legacy/DateRangeCalendar/index.js +0 -2
  178. package/legacy/DateRangeCalendar/useDragRange.js +0 -258
  179. package/legacy/DateRangePicker/DateRangePicker.js +0 -334
  180. package/legacy/DateRangePicker/DateRangePicker.types.js +0 -1
  181. package/legacy/DateRangePicker/DateRangePickerToolbar.js +0 -127
  182. package/legacy/DateRangePicker/dateRangePickerToolbarClasses.js +0 -5
  183. package/legacy/DateRangePicker/index.js +0 -3
  184. package/legacy/DateRangePicker/shared.js +0 -33
  185. package/legacy/DateRangePickerDay/DateRangePickerDay.js +0 -366
  186. package/legacy/DateRangePickerDay/dateRangePickerDayClasses.js +0 -5
  187. package/legacy/DateRangePickerDay/index.js +0 -2
  188. package/legacy/DateTimeRangePicker/DateTimeRangePicker.js +0 -413
  189. package/legacy/DateTimeRangePicker/DateTimeRangePicker.types.js +0 -1
  190. package/legacy/DateTimeRangePicker/DateTimeRangePickerTabs.js +0 -191
  191. package/legacy/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js +0 -57
  192. package/legacy/DateTimeRangePicker/DateTimeRangePickerToolbar.js +0 -184
  193. package/legacy/DateTimeRangePicker/dateTimeRangePickerTabsClasses.js +0 -6
  194. package/legacy/DateTimeRangePicker/dateTimeRangePickerToolbarClasses.js +0 -5
  195. package/legacy/DateTimeRangePicker/index.js +0 -5
  196. package/legacy/DateTimeRangePicker/shared.js +0 -54
  197. package/legacy/DesktopDateRangePicker/DesktopDateRangePicker.js +0 -343
  198. package/legacy/DesktopDateRangePicker/DesktopDateRangePicker.types.js +0 -1
  199. package/legacy/DesktopDateRangePicker/index.js +0 -1
  200. package/legacy/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +0 -491
  201. package/legacy/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.types.js +0 -1
  202. package/legacy/DesktopDateTimeRangePicker/DesktopDateTimeRangePickerLayout.js +0 -48
  203. package/legacy/DesktopDateTimeRangePicker/index.js +0 -1
  204. package/legacy/MobileDateRangePicker/MobileDateRangePicker.js +0 -339
  205. package/legacy/MobileDateRangePicker/MobileDateRangePicker.types.js +0 -1
  206. package/legacy/MobileDateRangePicker/index.js +0 -1
  207. package/legacy/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +0 -484
  208. package/legacy/MobileDateTimeRangePicker/MobileDateTimeRangePicker.types.js +0 -1
  209. package/legacy/MobileDateTimeRangePicker/index.js +0 -1
  210. package/legacy/MultiInputDateRangeField/MultiInputDateRangeField.js +0 -316
  211. package/legacy/MultiInputDateRangeField/MultiInputDateRangeField.types.js +0 -1
  212. package/legacy/MultiInputDateRangeField/index.js +0 -2
  213. package/legacy/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.js +0 -357
  214. package/legacy/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.types.js +0 -1
  215. package/legacy/MultiInputDateTimeRangeField/index.js +0 -2
  216. package/legacy/MultiInputTimeRangeField/MultiInputTimeRangeField.js +0 -330
  217. package/legacy/MultiInputTimeRangeField/MultiInputTimeRangeField.types.js +0 -1
  218. package/legacy/MultiInputTimeRangeField/index.js +0 -2
  219. package/legacy/SingleInputDateRangeField/SingleInputDateRangeField.js +0 -307
  220. package/legacy/SingleInputDateRangeField/SingleInputDateRangeField.types.js +0 -1
  221. package/legacy/SingleInputDateRangeField/index.js +0 -2
  222. package/legacy/SingleInputDateRangeField/useSingleInputDateRangeField.js +0 -30
  223. package/legacy/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.js +0 -348
  224. package/legacy/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.types.js +0 -1
  225. package/legacy/SingleInputDateTimeRangeField/index.js +0 -2
  226. package/legacy/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +0 -35
  227. package/legacy/SingleInputTimeRangeField/SingleInputTimeRangeField.js +0 -321
  228. package/legacy/SingleInputTimeRangeField/SingleInputTimeRangeField.types.js +0 -1
  229. package/legacy/SingleInputTimeRangeField/index.js +0 -2
  230. package/legacy/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +0 -29
  231. package/legacy/StaticDateRangePicker/StaticDateRangePicker.js +0 -276
  232. package/legacy/StaticDateRangePicker/StaticDateRangePicker.types.js +0 -1
  233. package/legacy/StaticDateRangePicker/index.js +0 -1
  234. package/legacy/dateRangeViewRenderers/dateRangeViewRenderers.js +0 -87
  235. package/legacy/dateRangeViewRenderers/index.js +0 -1
  236. package/legacy/index.js +0 -52
  237. package/legacy/internals/constants/dimensions.js +0 -5
  238. package/legacy/internals/hooks/models/index.js +0 -1
  239. package/legacy/internals/hooks/models/useRangePicker.js +0 -1
  240. package/legacy/internals/hooks/useDesktopRangePicker/index.js +0 -1
  241. package/legacy/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +0 -154
  242. package/legacy/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.types.js +0 -1
  243. package/legacy/internals/hooks/useEnrichedRangePickerFieldProps.js +0 -258
  244. package/legacy/internals/hooks/useMobileRangePicker/index.js +0 -1
  245. package/legacy/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +0 -144
  246. package/legacy/internals/hooks/useMobileRangePicker/useMobileRangePicker.types.js +0 -1
  247. package/legacy/internals/hooks/useMultiInputRangeField/shared.js +0 -9
  248. package/legacy/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +0 -102
  249. package/legacy/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +0 -115
  250. package/legacy/internals/hooks/useMultiInputRangeField/useMultiInputRangeField.types.js +0 -1
  251. package/legacy/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +0 -109
  252. package/legacy/internals/hooks/useRangePosition.js +0 -39
  253. package/legacy/internals/hooks/useStaticRangePicker/index.js +0 -1
  254. package/legacy/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +0 -76
  255. package/legacy/internals/hooks/useStaticRangePicker/useStaticRangePicker.types.js +0 -1
  256. package/legacy/internals/models/dateRange.js +0 -1
  257. package/legacy/internals/models/dateTimeRange.js +0 -1
  258. package/legacy/internals/models/index.js +0 -5
  259. package/legacy/internals/models/rangePickerProps.js +0 -1
  260. package/legacy/internals/models/timeRange.js +0 -1
  261. package/legacy/internals/utils/date-fields-utils.js +0 -26
  262. package/legacy/internals/utils/date-range-manager.js +0 -65
  263. package/legacy/internals/utils/date-utils.js +0 -12
  264. package/legacy/internals/utils/releaseInfo.js +0 -13
  265. package/legacy/internals/utils/validation/validateDateRange.js +0 -45
  266. package/legacy/internals/utils/validation/validateDateTimeRange.js +0 -45
  267. package/legacy/internals/utils/validation/validateTimeRange.js +0 -32
  268. package/legacy/internals/utils/valueManagers.js +0 -135
  269. package/legacy/locales/index.js +0 -1
  270. package/legacy/models/index.js +0 -3
  271. package/legacy/models/multiInputRangeFieldClasses.js +0 -1
  272. package/legacy/models/range.js +0 -1
  273. package/legacy/models/validation.js +0 -1
  274. package/legacy/themeAugmentation/index.js +0 -4
  275. package/modern/internals/models/fields.js +0 -1
  276. /package/{internals/models → models}/fields.js +0 -0
  277. /package/{legacy/internals → modern}/models/fields.js +0 -0
  278. /package/node/{internals/models → models}/fields.js +0 -0
@@ -1,764 +0,0 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
3
- import _extends from "@babel/runtime/helpers/esm/extends";
4
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
5
- var _excluded = ["value", "defaultValue", "referenceDate", "onChange", "className", "disableFuture", "disablePast", "minDate", "maxDate", "shouldDisableDate", "reduceAnimations", "onMonthChange", "rangePosition", "defaultRangePosition", "onRangePositionChange", "calendars", "currentMonthCalendarPosition", "slots", "slotProps", "loading", "renderLoading", "disableHighlightToday", "readOnly", "disabled", "showDaysOutsideCurrentMonth", "dayOfWeekFormatter", "disableAutoMonthSwitching", "autoFocus", "fixedWeekNumber", "disableDragEditing", "displayWeekNumber", "timezone", "availableRangePositions", "views", "view", "openTo", "onViewChange"],
6
- _excluded2 = ["isDragging", "rangeDragDay", "draggingDatePosition"];
7
- import * as React from 'react';
8
- import PropTypes from 'prop-types';
9
- import clsx from 'clsx';
10
- import useEventCallback from '@mui/utils/useEventCallback';
11
- import useMediaQuery from '@mui/material/useMediaQuery';
12
- import { resolveComponentProps, useSlotProps } from '@mui/base/utils';
13
- import { styled, useThemeProps } from '@mui/material/styles';
14
- import { unstable_composeClasses as composeClasses } from '@mui/utils';
15
- import { Watermark } from '@mui/x-license';
16
- import { PickersCalendarHeader } from '@mui/x-date-pickers/PickersCalendarHeader';
17
- import { applyDefaultDate, DayCalendar, useDefaultReduceAnimations, PickersArrowSwitcher, useCalendarState, useDefaultDates, useLocaleText, useNextMonthDisabled, usePreviousMonthDisabled, useUtils, useNow, DEFAULT_DESKTOP_MODE_MEDIA_QUERY, buildWarning, useControlledValueWithTimezone, useViews } from '@mui/x-date-pickers/internals';
18
- import { getReleaseInfo } from '../internals/utils/releaseInfo';
19
- import { dateRangeCalendarClasses, getDateRangeCalendarUtilityClass } from './dateRangeCalendarClasses';
20
- import { isEndOfRange, isRangeValid, isStartOfRange, isWithinRange } from '../internals/utils/date-utils';
21
- import { calculateRangeChange, calculateRangePreview } from '../internals/utils/date-range-manager';
22
- import { DateRangePickerDay, dateRangePickerDayClasses as dayClasses } from '../DateRangePickerDay';
23
- import { rangeValueManager } from '../internals/utils/valueManagers';
24
- import { useDragRange } from './useDragRange';
25
- import { useRangePosition } from '../internals/hooks/useRangePosition';
26
- import { DAY_RANGE_SIZE, DAY_MARGIN } from '../internals/constants/dimensions';
27
- import { jsx as _jsx } from "react/jsx-runtime";
28
- import { jsxs as _jsxs } from "react/jsx-runtime";
29
- var releaseInfo = getReleaseInfo();
30
- var DateRangeCalendarRoot = styled('div', {
31
- name: 'MuiDateRangeCalendar',
32
- slot: 'Root',
33
- overridesResolver: function overridesResolver(_, styles) {
34
- return styles.root;
35
- }
36
- })({
37
- display: 'flex',
38
- flexDirection: 'row'
39
- });
40
- var DateRangeCalendarMonthContainer = styled('div', {
41
- name: 'MuiDateRangeCalendar',
42
- slot: 'Container',
43
- overridesResolver: function overridesResolver(_, styles) {
44
- return styles.monthContainer;
45
- }
46
- })(function (_ref) {
47
- var theme = _ref.theme;
48
- return {
49
- '&:not(:last-of-type)': {
50
- borderRight: "1px solid ".concat((theme.vars || theme).palette.divider)
51
- }
52
- };
53
- });
54
- var DateRangeCalendarArrowSwitcher = styled(PickersArrowSwitcher)({
55
- padding: '12px 16px 4px 16px',
56
- display: 'flex',
57
- alignItems: 'center',
58
- justifyContent: 'space-between'
59
- });
60
- var weeksContainerHeight = (DAY_RANGE_SIZE + DAY_MARGIN * 2) * 6;
61
- var warnInvalidCurrentMonthCalendarPosition = buildWarning(['The `currentMonthCalendarPosition` prop must be an integer between `1` and the amount of calendars rendered.', 'For example if you have 2 calendars rendered, it should be equal to either 1 or 2.']);
62
- var DayCalendarForRange = styled(DayCalendar)(function (_ref2) {
63
- var theme = _ref2.theme;
64
- return _defineProperty(_defineProperty({
65
- minWidth: 312,
66
- minHeight: weeksContainerHeight
67
- }, "&.".concat(dateRangeCalendarClasses.dayDragging), _defineProperty(_defineProperty({}, "& .".concat(dayClasses.day), {
68
- cursor: 'grabbing'
69
- }), "& .".concat(dayClasses.root, ":not(.").concat(dayClasses.rangeIntervalDayHighlightStart, "):not(.").concat(dayClasses.rangeIntervalDayHighlightEnd, ") .").concat(dayClasses.day, ":not(.").concat(dayClasses.notSelectedDate, ")"), {
70
- // we can't override `PickersDay` background color here, because it's styles take precedence
71
- opacity: 0.6
72
- })), "&:not(.".concat(dateRangeCalendarClasses.dayDragging, ") .").concat(dayClasses.dayOutsideRangeInterval), {
73
- '@media (pointer: fine)': {
74
- '&:hover': {
75
- border: "1px solid ".concat((theme.vars || theme).palette.grey[500])
76
- }
77
- }
78
- });
79
- });
80
- function useDateRangeCalendarDefaultizedProps(props, name) {
81
- var _themeProps$renderLoa, _themeProps$reduceAni, _props$loading, _props$disablePast, _props$disableFuture, _themeProps$openTo, _themeProps$views, _themeProps$calendars, _themeProps$disableDr, _themeProps$available;
82
- var utils = useUtils();
83
- var defaultDates = useDefaultDates();
84
- var defaultReduceAnimations = useDefaultReduceAnimations();
85
- var themeProps = useThemeProps({
86
- props: props,
87
- name: name
88
- });
89
- return _extends({}, themeProps, {
90
- renderLoading: (_themeProps$renderLoa = themeProps.renderLoading) != null ? _themeProps$renderLoa : function () {
91
- return /*#__PURE__*/_jsx("span", {
92
- children: "..."
93
- });
94
- },
95
- reduceAnimations: (_themeProps$reduceAni = themeProps.reduceAnimations) != null ? _themeProps$reduceAni : defaultReduceAnimations,
96
- loading: (_props$loading = props.loading) != null ? _props$loading : false,
97
- disablePast: (_props$disablePast = props.disablePast) != null ? _props$disablePast : false,
98
- disableFuture: (_props$disableFuture = props.disableFuture) != null ? _props$disableFuture : false,
99
- openTo: (_themeProps$openTo = themeProps.openTo) != null ? _themeProps$openTo : 'day',
100
- views: (_themeProps$views = themeProps.views) != null ? _themeProps$views : ['day'],
101
- minDate: applyDefaultDate(utils, themeProps.minDate, defaultDates.minDate),
102
- maxDate: applyDefaultDate(utils, themeProps.maxDate, defaultDates.maxDate),
103
- calendars: (_themeProps$calendars = themeProps.calendars) != null ? _themeProps$calendars : 2,
104
- disableDragEditing: (_themeProps$disableDr = themeProps.disableDragEditing) != null ? _themeProps$disableDr : false,
105
- availableRangePositions: (_themeProps$available = themeProps.availableRangePositions) != null ? _themeProps$available : ['start', 'end']
106
- });
107
- }
108
- var useUtilityClasses = function useUtilityClasses(ownerState) {
109
- var classes = ownerState.classes,
110
- isDragging = ownerState.isDragging;
111
- var slots = {
112
- root: ['root'],
113
- monthContainer: ['monthContainer'],
114
- dayCalendar: [isDragging && 'dayDragging']
115
- };
116
- return composeClasses(slots, getDateRangeCalendarUtilityClass, classes);
117
- };
118
- /**
119
- * Demos:
120
- *
121
- * - [DateRangePicker](https://mui.com/x/react-date-pickers/date-range-picker/)
122
- * - [DateRangeCalendar](https://mui.com/x/react-date-pickers/date-range-calendar/)
123
- *
124
- * API:
125
- *
126
- * - [DateRangeCalendar API](https://mui.com/x/api/date-pickers/date-range-calendar/)
127
- */
128
- var DateRangeCalendar = /*#__PURE__*/React.forwardRef(function DateRangeCalendar(inProps, ref) {
129
- var _slots$calendarHeader;
130
- var props = useDateRangeCalendarDefaultizedProps(inProps, 'MuiDateRangeCalendar');
131
- var shouldHavePreview = useMediaQuery(DEFAULT_DESKTOP_MODE_MEDIA_QUERY, {
132
- defaultMatches: false
133
- });
134
- var valueProp = props.value,
135
- defaultValue = props.defaultValue,
136
- referenceDate = props.referenceDate,
137
- onChange = props.onChange,
138
- className = props.className,
139
- disableFuture = props.disableFuture,
140
- disablePast = props.disablePast,
141
- minDate = props.minDate,
142
- maxDate = props.maxDate,
143
- shouldDisableDate = props.shouldDisableDate,
144
- reduceAnimations = props.reduceAnimations,
145
- onMonthChange = props.onMonthChange,
146
- rangePositionProp = props.rangePosition,
147
- inDefaultRangePosition = props.defaultRangePosition,
148
- inOnRangePositionChange = props.onRangePositionChange,
149
- calendars = props.calendars,
150
- _props$currentMonthCa = props.currentMonthCalendarPosition,
151
- currentMonthCalendarPosition = _props$currentMonthCa === void 0 ? 1 : _props$currentMonthCa,
152
- slots = props.slots,
153
- slotProps = props.slotProps,
154
- loading = props.loading,
155
- renderLoading = props.renderLoading,
156
- disableHighlightToday = props.disableHighlightToday,
157
- readOnly = props.readOnly,
158
- disabled = props.disabled,
159
- showDaysOutsideCurrentMonth = props.showDaysOutsideCurrentMonth,
160
- dayOfWeekFormatter = props.dayOfWeekFormatter,
161
- disableAutoMonthSwitching = props.disableAutoMonthSwitching,
162
- autoFocus = props.autoFocus,
163
- fixedWeekNumber = props.fixedWeekNumber,
164
- disableDragEditing = props.disableDragEditing,
165
- displayWeekNumber = props.displayWeekNumber,
166
- timezoneProp = props.timezone,
167
- availableRangePositions = props.availableRangePositions,
168
- views = props.views,
169
- inView = props.view,
170
- openTo = props.openTo,
171
- onViewChange = props.onViewChange,
172
- other = _objectWithoutProperties(props, _excluded);
173
- var _useControlledValueWi = useControlledValueWithTimezone({
174
- name: 'DateRangeCalendar',
175
- timezone: timezoneProp,
176
- value: valueProp,
177
- defaultValue: defaultValue,
178
- onChange: onChange,
179
- valueManager: rangeValueManager
180
- }),
181
- value = _useControlledValueWi.value,
182
- handleValueChange = _useControlledValueWi.handleValueChange,
183
- timezone = _useControlledValueWi.timezone;
184
- var _useViews = useViews({
185
- view: inView,
186
- views: views,
187
- openTo: openTo,
188
- onChange: handleValueChange,
189
- onViewChange: onViewChange,
190
- autoFocus: autoFocus
191
- }),
192
- setValueAndGoToNextView = _useViews.setValueAndGoToNextView,
193
- view = _useViews.view;
194
- var utils = useUtils();
195
- var localeText = useLocaleText();
196
- var now = useNow(timezone);
197
- var _useRangePosition = useRangePosition({
198
- rangePosition: rangePositionProp,
199
- defaultRangePosition: inDefaultRangePosition,
200
- onRangePositionChange: inOnRangePositionChange
201
- }),
202
- rangePosition = _useRangePosition.rangePosition,
203
- onRangePositionChange = _useRangePosition.onRangePositionChange;
204
- var handleDatePositionChange = useEventCallback(function (position) {
205
- if (rangePosition !== position) {
206
- onRangePositionChange(position);
207
- }
208
- });
209
- var handleSelectedDayChange = useEventCallback(function (newDate, selectionState) {
210
- var allowRangeFlip = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
211
- var _calculateRangeChange = calculateRangeChange({
212
- newDate: newDate,
213
- utils: utils,
214
- range: value,
215
- rangePosition: rangePosition,
216
- allowRangeFlip: allowRangeFlip,
217
- shouldMergeDateAndTime: true
218
- }),
219
- nextSelection = _calculateRangeChange.nextSelection,
220
- newRange = _calculateRangeChange.newRange;
221
- var isNextSectionAvailable = availableRangePositions.includes(nextSelection);
222
- if (isNextSectionAvailable) {
223
- onRangePositionChange(nextSelection);
224
- }
225
- var isFullRangeSelected = rangePosition === 'end' && isRangeValid(utils, newRange);
226
- setValueAndGoToNextView(newRange, isFullRangeSelected || !isNextSectionAvailable ? 'finish' : 'partial', view);
227
- });
228
- var handleDrop = useEventCallback(function (newDate) {
229
- handleSelectedDayChange(newDate, undefined, true);
230
- });
231
- var shouldDisableDragEditing = disableDragEditing || disabled || readOnly;
232
-
233
- // Range going for the start of the start day to the end of the end day.
234
- // This makes sure that `isWithinRange` works with any time in the start and end day.
235
- var valueDayRange = React.useMemo(function () {
236
- return [value[0] == null || !utils.isValid(value[0]) ? value[0] : utils.startOfDay(value[0]), value[1] == null || !utils.isValid(value[1]) ? value[1] : utils.endOfDay(value[1])];
237
- }, [value, utils]);
238
- var _useDragRange = useDragRange({
239
- disableDragEditing: shouldDisableDragEditing,
240
- onDrop: handleDrop,
241
- onDatePositionChange: handleDatePositionChange,
242
- utils: utils,
243
- dateRange: valueDayRange,
244
- timezone: timezone
245
- }),
246
- isDragging = _useDragRange.isDragging,
247
- rangeDragDay = _useDragRange.rangeDragDay,
248
- draggingDatePosition = _useDragRange.draggingDatePosition,
249
- dragEventHandlers = _objectWithoutProperties(_useDragRange, _excluded2);
250
- var ownerState = _extends({}, props, {
251
- isDragging: isDragging
252
- });
253
- var classes = useUtilityClasses(ownerState);
254
- var draggingRange = React.useMemo(function () {
255
- if (!valueDayRange[0] || !valueDayRange[1] || !rangeDragDay) {
256
- return [null, null];
257
- }
258
- var newRange = calculateRangeChange({
259
- utils: utils,
260
- range: valueDayRange,
261
- newDate: rangeDragDay,
262
- rangePosition: rangePosition,
263
- allowRangeFlip: true
264
- }).newRange;
265
- return newRange[0] !== null && newRange[1] !== null ? [utils.startOfDay(newRange[0]), utils.endOfDay(newRange[1])] : newRange;
266
- }, [rangePosition, rangeDragDay, utils, valueDayRange]);
267
- var wrappedShouldDisableDate = React.useMemo(function () {
268
- if (!shouldDisableDate) {
269
- return undefined;
270
- }
271
- return function (dayToTest) {
272
- return shouldDisableDate(dayToTest, draggingDatePosition || rangePosition);
273
- };
274
- }, [shouldDisableDate, rangePosition, draggingDatePosition]);
275
- var _useCalendarState = useCalendarState({
276
- value: value[0] || value[1],
277
- referenceDate: referenceDate,
278
- disableFuture: disableFuture,
279
- disablePast: disablePast,
280
- disableSwitchToMonthOnDayFocus: true,
281
- maxDate: maxDate,
282
- minDate: minDate,
283
- onMonthChange: onMonthChange,
284
- reduceAnimations: reduceAnimations,
285
- shouldDisableDate: wrappedShouldDisableDate,
286
- timezone: timezone
287
- }),
288
- calendarState = _useCalendarState.calendarState,
289
- changeFocusedDay = _useCalendarState.changeFocusedDay,
290
- changeMonth = _useCalendarState.changeMonth,
291
- handleChangeMonth = _useCalendarState.handleChangeMonth,
292
- onMonthSwitchingAnimationEnd = _useCalendarState.onMonthSwitchingAnimationEnd;
293
-
294
- // When disabled, limit the view to the selected date
295
- var minDateWithDisabled = disabled && value[0] || minDate;
296
- var maxDateWithDisabled = disabled && value[1] || maxDate;
297
- var CalendarHeader = (_slots$calendarHeader = slots == null ? void 0 : slots.calendarHeader) != null ? _slots$calendarHeader : PickersCalendarHeader;
298
- var calendarHeaderProps = useSlotProps({
299
- elementType: CalendarHeader,
300
- externalSlotProps: slotProps == null ? void 0 : slotProps.calendarHeader,
301
- additionalProps: {
302
- views: ['day'],
303
- view: 'day',
304
- currentMonth: calendarState.currentMonth,
305
- onMonthChange: function onMonthChange(newMonth, direction) {
306
- return handleChangeMonth({
307
- newMonth: newMonth,
308
- direction: direction
309
- });
310
- },
311
- minDate: minDateWithDisabled,
312
- maxDate: maxDateWithDisabled,
313
- disabled: disabled,
314
- disablePast: disablePast,
315
- disableFuture: disableFuture,
316
- reduceAnimations: reduceAnimations,
317
- slots: slots,
318
- slotProps: slotProps,
319
- timezone: timezone
320
- },
321
- ownerState: props
322
- });
323
- var prevValue = React.useRef(null);
324
- React.useEffect(function () {
325
- var _prevValue$current, _prevValue$current2;
326
- var date = rangePosition === 'start' ? value[0] : value[1];
327
- if (!date || !utils.isValid(date)) {
328
- return;
329
- }
330
- var prevDate = rangePosition === 'start' ? (_prevValue$current = prevValue.current) == null ? void 0 : _prevValue$current[0] : (_prevValue$current2 = prevValue.current) == null ? void 0 : _prevValue$current2[1];
331
- prevValue.current = value;
332
-
333
- // The current date did not change, this call comes either from a `rangePosition` change or a change in the other date.
334
- // In both cases, we don't want to change the visible month(s).
335
- if (disableAutoMonthSwitching && prevDate && utils.isEqual(prevDate, date)) {
336
- return;
337
- }
338
- var displayingMonthRange = calendars - 1;
339
- var currentMonthNumber = utils.getMonth(calendarState.currentMonth);
340
- var requestedMonthNumber = utils.getMonth(date);
341
- if (!utils.isSameYear(calendarState.currentMonth, date) || requestedMonthNumber < currentMonthNumber || requestedMonthNumber > currentMonthNumber + displayingMonthRange) {
342
- var newMonth = rangePosition === 'start' ? date :
343
- // If need to focus end, scroll to the state when "end" is displaying in the last calendar
344
- utils.addMonths(date, -displayingMonthRange);
345
- changeMonth(newMonth);
346
- }
347
- }, [rangePosition, value]); // eslint-disable-line
348
-
349
- var selectNextMonth = React.useCallback(function () {
350
- changeMonth(utils.addMonths(calendarState.currentMonth, 1));
351
- }, [changeMonth, calendarState.currentMonth, utils]);
352
- var selectPreviousMonth = React.useCallback(function () {
353
- changeMonth(utils.addMonths(calendarState.currentMonth, -1));
354
- }, [changeMonth, calendarState.currentMonth, utils]);
355
- var isNextMonthDisabled = useNextMonthDisabled(calendarState.currentMonth, {
356
- disableFuture: disableFuture,
357
- maxDate: maxDate,
358
- timezone: timezone
359
- });
360
- var isPreviousMonthDisabled = usePreviousMonthDisabled(calendarState.currentMonth, {
361
- disablePast: disablePast,
362
- minDate: minDate,
363
- timezone: timezone
364
- });
365
- var baseDateValidationProps = {
366
- disablePast: disablePast,
367
- disableFuture: disableFuture,
368
- maxDate: maxDate,
369
- minDate: minDate
370
- };
371
- var commonViewProps = {
372
- disableHighlightToday: disableHighlightToday,
373
- readOnly: readOnly,
374
- disabled: disabled
375
- };
376
- var _React$useState = React.useState(null),
377
- _React$useState2 = _slicedToArray(_React$useState, 2),
378
- rangePreviewDay = _React$useState2[0],
379
- setRangePreviewDay = _React$useState2[1];
380
- var CalendarTransitionProps = React.useMemo(function () {
381
- return {
382
- onMouseLeave: function onMouseLeave() {
383
- return setRangePreviewDay(null);
384
- }
385
- };
386
- }, []);
387
- var previewingRange = calculateRangePreview({
388
- utils: utils,
389
- range: valueDayRange,
390
- newDate: rangePreviewDay,
391
- rangePosition: rangePosition
392
- });
393
- var handleDayMouseEnter = useEventCallback(function (event, newPreviewRequest) {
394
- if (!isWithinRange(utils, newPreviewRequest, valueDayRange)) {
395
- setRangePreviewDay(newPreviewRequest);
396
- } else {
397
- setRangePreviewDay(null);
398
- }
399
- });
400
- var slotsForDayCalendar = _extends({
401
- day: DateRangePickerDay
402
- }, slots);
403
- var slotPropsForDayCalendar = _extends({}, slotProps, {
404
- day: function day(dayOwnerState) {
405
- var _resolveComponentProp;
406
- var day = dayOwnerState.day;
407
- var isSelectedStartDate = isStartOfRange(utils, day, valueDayRange);
408
- var isSelectedEndDate = isEndOfRange(utils, day, valueDayRange);
409
- var shouldInitDragging = !shouldDisableDragEditing && valueDayRange[0] && valueDayRange[1];
410
- var isElementDraggable = shouldInitDragging && (isSelectedStartDate || isSelectedEndDate);
411
- var datePosition;
412
- if (isSelectedStartDate) {
413
- datePosition = 'start';
414
- } else if (isSelectedEndDate) {
415
- datePosition = 'end';
416
- }
417
- var isStartOfHighlighting = isDragging ? isStartOfRange(utils, day, draggingRange) : isSelectedStartDate;
418
- var isEndOfHighlighting = isDragging ? isEndOfRange(utils, day, draggingRange) : isSelectedEndDate;
419
- return _extends({
420
- isPreviewing: shouldHavePreview ? isWithinRange(utils, day, previewingRange) : false,
421
- isStartOfPreviewing: shouldHavePreview ? isStartOfRange(utils, day, previewingRange) : false,
422
- isEndOfPreviewing: shouldHavePreview ? isEndOfRange(utils, day, previewingRange) : false,
423
- isHighlighting: isWithinRange(utils, day, isDragging ? draggingRange : valueDayRange),
424
- isStartOfHighlighting: isStartOfHighlighting,
425
- isEndOfHighlighting: isDragging ? isEndOfRange(utils, day, draggingRange) : isSelectedEndDate,
426
- onMouseEnter: shouldHavePreview ? handleDayMouseEnter : undefined,
427
- // apply selected styling to the dragging start or end day
428
- isVisuallySelected: dayOwnerState.selected || isDragging && (isStartOfHighlighting || isEndOfHighlighting),
429
- 'data-position': datePosition
430
- }, dragEventHandlers, {
431
- draggable: isElementDraggable ? true : undefined
432
- }, (_resolveComponentProp = resolveComponentProps(slotProps == null ? void 0 : slotProps.day, dayOwnerState)) != null ? _resolveComponentProp : {});
433
- }
434
- });
435
- var calendarMonths = React.useMemo(function () {
436
- return Array.from({
437
- length: calendars
438
- }).map(function (_, index) {
439
- return index;
440
- });
441
- }, [calendars]);
442
- var visibleMonths = React.useMemo(function () {
443
- if (process.env.NODE_ENV !== 'production') {
444
- if (currentMonthCalendarPosition > calendars || currentMonthCalendarPosition < 1) {
445
- warnInvalidCurrentMonthCalendarPosition();
446
- }
447
- }
448
- var firstMonth = utils.addMonths(calendarState.currentMonth, 1 - currentMonthCalendarPosition);
449
- return Array.from({
450
- length: calendars
451
- }).map(function (_, index) {
452
- return utils.addMonths(firstMonth, index);
453
- });
454
- }, [utils, calendarState.currentMonth, calendars, currentMonthCalendarPosition]);
455
- var focusedMonth = React.useMemo(function () {
456
- var _visibleMonths$find;
457
- if (!autoFocus) {
458
- return null;
459
- }
460
-
461
- // The focus priority of the "day" view is as follows:
462
- // 1. Month of the `start` date
463
- // 2. Month of the `end` date
464
- // 3. Month of the current date
465
- // 4. First visible month
466
-
467
- if (value[0] != null) {
468
- return visibleMonths.find(function (month) {
469
- return utils.isSameMonth(month, value[0]);
470
- });
471
- }
472
- if (value[1] != null) {
473
- return visibleMonths.find(function (month) {
474
- return utils.isSameMonth(month, value[1]);
475
- });
476
- }
477
- return (_visibleMonths$find = visibleMonths.find(function (month) {
478
- return utils.isSameMonth(month, now);
479
- })) != null ? _visibleMonths$find : visibleMonths[0];
480
- }, [utils, value, visibleMonths, autoFocus, now]);
481
- return /*#__PURE__*/_jsxs(DateRangeCalendarRoot, _extends({
482
- ref: ref,
483
- className: clsx(className, classes.root),
484
- ownerState: ownerState
485
- }, other, {
486
- children: [/*#__PURE__*/_jsx(Watermark, {
487
- packageName: "x-date-pickers-pro",
488
- releaseInfo: releaseInfo
489
- }), calendarMonths.map(function (month, index) {
490
- var _calendarHeaderProps$;
491
- return /*#__PURE__*/_jsxs(DateRangeCalendarMonthContainer, {
492
- className: classes.monthContainer,
493
- children: [calendars === 1 ? /*#__PURE__*/_jsx(CalendarHeader, _extends({}, calendarHeaderProps)) : /*#__PURE__*/_jsx(DateRangeCalendarArrowSwitcher, {
494
- onGoToPrevious: selectPreviousMonth,
495
- onGoToNext: selectNextMonth,
496
- isPreviousHidden: index !== 0,
497
- isPreviousDisabled: isPreviousMonthDisabled,
498
- previousLabel: localeText.previousMonth,
499
- isNextHidden: index !== calendars - 1,
500
- isNextDisabled: isNextMonthDisabled,
501
- nextLabel: localeText.nextMonth,
502
- slots: slots,
503
- slotProps: slotProps,
504
- children: utils.formatByString(visibleMonths[month], (_calendarHeaderProps$ = calendarHeaderProps.format) != null ? _calendarHeaderProps$ : "".concat(utils.formats.month, " ").concat(utils.formats.year))
505
- }), /*#__PURE__*/_jsx(DayCalendarForRange, _extends({
506
- className: classes.dayCalendar
507
- }, calendarState, baseDateValidationProps, commonViewProps, {
508
- onMonthSwitchingAnimationEnd: onMonthSwitchingAnimationEnd,
509
- onFocusedDayChange: changeFocusedDay,
510
- reduceAnimations: reduceAnimations,
511
- selectedDays: value,
512
- onSelectedDaysChange: handleSelectedDayChange,
513
- currentMonth: visibleMonths[month],
514
- TransitionProps: CalendarTransitionProps,
515
- shouldDisableDate: wrappedShouldDisableDate,
516
- showDaysOutsideCurrentMonth: calendars === 1 && showDaysOutsideCurrentMonth,
517
- dayOfWeekFormatter: dayOfWeekFormatter,
518
- loading: loading,
519
- renderLoading: renderLoading,
520
- slots: slotsForDayCalendar,
521
- slotProps: slotPropsForDayCalendar,
522
- autoFocus: visibleMonths[month] === focusedMonth,
523
- fixedWeekNumber: fixedWeekNumber,
524
- displayWeekNumber: displayWeekNumber,
525
- timezone: timezone
526
- }), index)]
527
- }, month);
528
- })]
529
- }));
530
- });
531
- process.env.NODE_ENV !== "production" ? DateRangeCalendar.propTypes = {
532
- // ----------------------------- Warning --------------------------------
533
- // | These PropTypes are generated from the TypeScript type definitions |
534
- // | To update them edit the TypeScript types and run "yarn proptypes" |
535
- // ----------------------------------------------------------------------
536
- /**
537
- * If `true`, the main element is focused during the first mount.
538
- * This main element is:
539
- * - the element chosen by the visible view if any (i.e: the selected day on the `day` view).
540
- * - the `input` element if there is a field rendered.
541
- */
542
- autoFocus: PropTypes.bool,
543
- /**
544
- * Range positions available for selection.
545
- * This list is checked against when checking if a next range position can be selected.
546
- *
547
- * Used on Date Time Range pickers with current `rangePosition` to force a `finish` selection after just one range position selection.
548
- * @default ['start', 'end']
549
- */
550
- availableRangePositions: PropTypes.arrayOf(PropTypes.oneOf(['end', 'start']).isRequired),
551
- /**
552
- * The number of calendars to render.
553
- * @default 2
554
- */
555
- calendars: PropTypes.oneOf([1, 2, 3]),
556
- classes: PropTypes.object,
557
- className: PropTypes.string,
558
- /**
559
- * Position the current month is rendered in.
560
- * @default 1
561
- */
562
- currentMonthCalendarPosition: PropTypes.oneOf([1, 2, 3]),
563
- /**
564
- * Formats the day of week displayed in the calendar header.
565
- * @param {TDate} date The date of the day of week provided by the adapter.
566
- * @returns {string} The name to display.
567
- * @default (_day: string, date: TDate) => adapter.format(date, 'weekdayShort').charAt(0).toUpperCase()
568
- */
569
- dayOfWeekFormatter: PropTypes.func,
570
- /**
571
- * The initial position in the edited date range.
572
- * Used when the component is not controlled.
573
- * @default 'start'
574
- */
575
- defaultRangePosition: PropTypes.oneOf(['end', 'start']),
576
- /**
577
- * The default selected value.
578
- * Used when the component is not controlled.
579
- */
580
- defaultValue: PropTypes.arrayOf(PropTypes.object),
581
- /**
582
- * If `true`, after selecting `start` date calendar will not automatically switch to the month of `end` date.
583
- * @default false
584
- */
585
- disableAutoMonthSwitching: PropTypes.bool,
586
- /**
587
- * If `true`, the picker and text field are disabled.
588
- * @default false
589
- */
590
- disabled: PropTypes.bool,
591
- /**
592
- * If `true`, editing dates by dragging is disabled.
593
- * @default false
594
- */
595
- disableDragEditing: PropTypes.bool,
596
- /**
597
- * If `true`, disable values after the current date for date components, time for time components and both for date time components.
598
- * @default false
599
- */
600
- disableFuture: PropTypes.bool,
601
- /**
602
- * If `true`, today's date is rendering without highlighting with circle.
603
- * @default false
604
- */
605
- disableHighlightToday: PropTypes.bool,
606
- /**
607
- * If `true`, disable values before the current date for date components, time for time components and both for date time components.
608
- * @default false
609
- */
610
- disablePast: PropTypes.bool,
611
- /**
612
- * If `true`, the week number will be display in the calendar.
613
- */
614
- displayWeekNumber: PropTypes.bool,
615
- /**
616
- * The day view will show as many weeks as needed after the end of the current month to match this value.
617
- * Put it to 6 to have a fixed number of weeks in Gregorian calendars
618
- * @default undefined
619
- */
620
- fixedWeekNumber: PropTypes.number,
621
- /**
622
- * Controlled focused view.
623
- */
624
- focusedView: PropTypes.oneOf(['day']),
625
- /**
626
- * If `true`, calls `renderLoading` instead of rendering the day calendar.
627
- * Can be used to preload information and show it in calendar.
628
- * @default false
629
- */
630
- loading: PropTypes.bool,
631
- /**
632
- * Maximal selectable date.
633
- */
634
- maxDate: PropTypes.object,
635
- /**
636
- * Minimal selectable date.
637
- */
638
- minDate: PropTypes.object,
639
- /**
640
- * Callback fired when the value changes.
641
- * @template TValue The value type. Will be either the same type as `value` or `null`. Can be in `[start, end]` format in case of range value.
642
- * @template TView The view type. Will be one of date or time views.
643
- * @param {TValue} value The new value.
644
- * @param {PickerSelectionState | undefined} selectionState Indicates if the date selection is complete.
645
- * @param {TView | undefined} selectedView Indicates the view in which the selection has been made.
646
- */
647
- onChange: PropTypes.func,
648
- /**
649
- * Callback fired on focused view change.
650
- * @template TView
651
- * @param {TView} view The new view to focus or not.
652
- * @param {boolean} hasFocus `true` if the view should be focused.
653
- */
654
- onFocusedViewChange: PropTypes.func,
655
- /**
656
- * Callback fired on month change.
657
- * @template TDate
658
- * @param {TDate} month The new month.
659
- */
660
- onMonthChange: PropTypes.func,
661
- /**
662
- * Callback fired when the range position changes.
663
- * @param {RangePosition} rangePosition The new range position.
664
- */
665
- onRangePositionChange: PropTypes.func,
666
- /**
667
- * Callback fired on view change.
668
- * @template TView
669
- * @param {TView} view The new view.
670
- */
671
- onViewChange: PropTypes.func,
672
- /**
673
- * The default visible view.
674
- * Used when the component view is not controlled.
675
- * Must be a valid option from `views` list.
676
- */
677
- openTo: PropTypes.oneOf(['day']),
678
- /**
679
- * The position in the currently edited date range.
680
- * Used when the component position is controlled.
681
- */
682
- rangePosition: PropTypes.oneOf(['end', 'start']),
683
- /**
684
- * Make picker read only.
685
- * @default false
686
- */
687
- readOnly: PropTypes.bool,
688
- /**
689
- * If `true`, disable heavy animations.
690
- * @default `@media(prefers-reduced-motion: reduce)` || `navigator.userAgent` matches Android <10 or iOS <13
691
- */
692
- reduceAnimations: PropTypes.bool,
693
- /**
694
- * The date used to generate the new value when both `value` and `defaultValue` are empty.
695
- * @default The closest valid date using the validation props, except callbacks such as `shouldDisableDate`.
696
- */
697
- referenceDate: PropTypes.object,
698
- /**
699
- * Component rendered on the "day" view when `props.loading` is true.
700
- * @returns {React.ReactNode} The node to render when loading.
701
- * @default () => "..."
702
- */
703
- renderLoading: PropTypes.func,
704
- /**
705
- * Disable specific date.
706
- *
707
- * Warning: This function can be called multiple times (e.g. when rendering date calendar, checking if focus can be moved to a certain date, etc.). Expensive computations can impact performance.
708
- *
709
- * @template TDate
710
- * @param {TDate} day The date to test.
711
- * @param {string} position The date to test, 'start' or 'end'.
712
- * @returns {boolean} Returns `true` if the date should be disabled.
713
- */
714
- shouldDisableDate: PropTypes.func,
715
- /**
716
- * If `true`, days outside the current month are rendered:
717
- *
718
- * - if `fixedWeekNumber` is defined, renders days to have the weeks requested.
719
- *
720
- * - if `fixedWeekNumber` is not defined, renders day to fill the first and last week of the current month.
721
- *
722
- * - ignored if `calendars` equals more than `1` on range pickers.
723
- * @default false
724
- */
725
- showDaysOutsideCurrentMonth: PropTypes.bool,
726
- /**
727
- * The props used for each component slot.
728
- * @default {}
729
- */
730
- slotProps: PropTypes.object,
731
- /**
732
- * Overridable component slots.
733
- * @default {}
734
- */
735
- slots: PropTypes.object,
736
- /**
737
- * The system prop that allows defining system overrides as well as additional CSS styles.
738
- */
739
- sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),
740
- /**
741
- * Choose which timezone to use for the value.
742
- * Example: "default", "system", "UTC", "America/New_York".
743
- * If you pass values from other timezones to some props, they will be converted to this timezone before being used.
744
- * @see See the {@link https://mui.com/x/react-date-pickers/timezone/ timezones documentation} for more details.
745
- * @default The timezone of the `value` or `defaultValue` prop is defined, 'default' otherwise.
746
- */
747
- timezone: PropTypes.string,
748
- /**
749
- * The selected value.
750
- * Used when the component is controlled.
751
- */
752
- value: PropTypes.arrayOf(PropTypes.object),
753
- /**
754
- * The visible view.
755
- * Used when the component view is controlled.
756
- * Must be a valid option from `views` list.
757
- */
758
- view: PropTypes.oneOf(['day']),
759
- /**
760
- * Available views.
761
- */
762
- views: PropTypes.arrayOf(PropTypes.oneOf(['day']))
763
- } : void 0;
764
- export { DateRangeCalendar };