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

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