@mui/x-date-pickers 8.0.0-alpha.0 → 8.0.0-alpha.10

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 (584) hide show
  1. package/AdapterDateFns/AdapterDateFns.d.ts +2 -4
  2. package/AdapterDateFns/AdapterDateFns.js +49 -47
  3. package/AdapterDateFnsBase/AdapterDateFnsBase.d.ts +1 -1
  4. package/AdapterDateFnsJalali/AdapterDateFnsJalali.d.ts +2 -4
  5. package/AdapterDateFnsJalali/AdapterDateFnsJalali.js +48 -46
  6. package/{AdapterDateFnsJalaliV3/AdapterDateFnsJalaliV3.d.ts → AdapterDateFnsJalaliV2/AdapterDateFnsJalaliV2.d.ts} +2 -2
  7. package/{AdapterDateFnsJalaliV3/AdapterDateFnsJalaliV3.js → AdapterDateFnsJalaliV2/AdapterDateFnsJalaliV2.js} +45 -52
  8. package/AdapterDateFnsJalaliV2/index.d.ts +1 -0
  9. package/AdapterDateFnsJalaliV2/index.js +1 -0
  10. package/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/package.json +1 -1
  11. package/{AdapterDateFnsV3/AdapterDateFnsV3.d.ts → AdapterDateFnsV2/AdapterDateFnsV2.d.ts} +2 -2
  12. package/{AdapterDateFnsV3/AdapterDateFnsV3.js → AdapterDateFnsV2/AdapterDateFnsV2.js} +46 -54
  13. package/AdapterDateFnsV2/index.d.ts +1 -0
  14. package/AdapterDateFnsV2/index.js +1 -0
  15. package/{AdapterDateFnsV3 → AdapterDateFnsV2}/package.json +1 -1
  16. package/AdapterDayjs/AdapterDayjs.d.ts +1 -1
  17. package/AdapterLuxon/AdapterLuxon.d.ts +1 -1
  18. package/AdapterMoment/AdapterMoment.d.ts +1 -1
  19. package/AdapterMoment/AdapterMoment.js +10 -0
  20. package/CHANGELOG.md +2215 -119
  21. package/DateCalendar/DateCalendar.js +5 -4
  22. package/DateCalendar/DateCalendar.types.d.ts +2 -1
  23. package/DateCalendar/DayCalendar.js +2 -0
  24. package/DateCalendar/PickersFadeTransitionGroup.d.ts +1 -1
  25. package/DateCalendar/PickersFadeTransitionGroup.js +4 -6
  26. package/DateCalendar/PickersSlideTransition.d.ts +1 -1
  27. package/DateCalendar/PickersSlideTransition.js +12 -5
  28. package/DateCalendar/useCalendarState.d.ts +6 -4
  29. package/DateField/DateField.js +29 -33
  30. package/DateField/DateField.types.d.ts +7 -15
  31. package/DateField/useDateField.d.ts +1 -1
  32. package/DateField/useDateField.js +14 -11
  33. package/DatePicker/DatePicker.js +1 -1
  34. package/DatePicker/DatePicker.types.d.ts +7 -3
  35. package/DatePicker/DatePickerToolbar.d.ts +1 -2
  36. package/DatePicker/DatePickerToolbar.js +17 -45
  37. package/DatePicker/shared.d.ts +6 -5
  38. package/DateTimeField/DateTimeField.js +29 -33
  39. package/DateTimeField/DateTimeField.types.d.ts +7 -16
  40. package/DateTimeField/useDateTimeField.d.ts +1 -1
  41. package/DateTimeField/useDateTimeField.js +14 -11
  42. package/DateTimePicker/DateTimePicker.js +2 -2
  43. package/DateTimePicker/DateTimePicker.types.d.ts +4 -5
  44. package/DateTimePicker/DateTimePickerTabs.d.ts +2 -5
  45. package/DateTimePicker/DateTimePickerTabs.js +15 -20
  46. package/DateTimePicker/DateTimePickerToolbar.d.ts +16 -5
  47. package/DateTimePicker/DateTimePickerToolbar.js +92 -93
  48. package/DateTimePicker/shared.d.ts +8 -8
  49. package/DayCalendarSkeleton/DayCalendarSkeleton.js +10 -19
  50. package/DesktopDatePicker/DesktopDatePicker.js +11 -17
  51. package/DesktopDatePicker/DesktopDatePicker.types.d.ts +7 -3
  52. package/DesktopDateTimePicker/DesktopDateTimePicker.js +17 -27
  53. package/DesktopDateTimePicker/DesktopDateTimePicker.types.d.ts +2 -2
  54. package/DesktopDateTimePicker/DesktopDateTimePickerLayout.d.ts +2 -2
  55. package/DesktopDateTimePicker/DesktopDateTimePickerLayout.js +9 -46
  56. package/DesktopTimePicker/DesktopTimePicker.js +6 -22
  57. package/DesktopTimePicker/DesktopTimePicker.types.d.ts +2 -2
  58. package/DigitalClock/DigitalClock.js +14 -11
  59. package/DigitalClock/DigitalClock.types.d.ts +8 -2
  60. package/MobileDatePicker/MobileDatePicker.js +4 -14
  61. package/MobileDatePicker/MobileDatePicker.types.d.ts +2 -3
  62. package/MobileDateTimePicker/MobileDateTimePicker.js +4 -14
  63. package/MobileDateTimePicker/MobileDateTimePicker.types.d.ts +4 -4
  64. package/MobileTimePicker/MobileTimePicker.js +4 -14
  65. package/MobileTimePicker/MobileTimePicker.types.d.ts +4 -4
  66. package/MonthCalendar/MonthCalendar.d.ts +1 -1
  67. package/MonthCalendar/MonthCalendar.js +32 -11
  68. package/MonthCalendar/MonthCalendar.types.d.ts +2 -2
  69. package/MonthCalendar/MonthCalendarButton.d.ts +24 -0
  70. package/{modern/MonthCalendar/PickersMonth.js → MonthCalendar/MonthCalendarButton.js} +20 -61
  71. package/MonthCalendar/index.d.ts +0 -3
  72. package/MonthCalendar/index.js +1 -2
  73. package/MonthCalendar/monthCalendarClasses.d.ts +7 -1
  74. package/MonthCalendar/monthCalendarClasses.js +1 -1
  75. package/MultiSectionDigitalClock/MultiSectionDigitalClock.js +12 -7
  76. package/MultiSectionDigitalClock/MultiSectionDigitalClock.types.d.ts +6 -6
  77. package/MultiSectionDigitalClock/MultiSectionDigitalClockSection.d.ts +4 -4
  78. package/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +14 -10
  79. package/PickersActionBar/PickersActionBar.d.ts +6 -7
  80. package/PickersActionBar/PickersActionBar.js +26 -17
  81. package/PickersCalendarHeader/PickersCalendarHeader.js +10 -7
  82. package/PickersCalendarHeader/PickersCalendarHeader.types.d.ts +3 -4
  83. package/PickersLayout/PickersLayout.d.ts +7 -5
  84. package/PickersLayout/PickersLayout.js +23 -54
  85. package/PickersLayout/PickersLayout.types.d.ts +20 -22
  86. package/PickersLayout/usePickerLayout.d.ts +5 -4
  87. package/PickersLayout/usePickerLayout.js +26 -57
  88. package/PickersSectionList/PickersSectionList.js +21 -16
  89. package/PickersSectionList/PickersSectionList.types.d.ts +13 -6
  90. package/PickersShortcuts/PickersShortcuts.d.ts +9 -11
  91. package/PickersShortcuts/PickersShortcuts.js +21 -11
  92. package/PickersShortcuts/index.d.ts +1 -1
  93. package/PickersTextField/PickersFilledInput/PickersFilledInput.d.ts +7 -0
  94. package/PickersTextField/PickersFilledInput/PickersFilledInput.js +34 -28
  95. package/PickersTextField/PickersFilledInput/pickersFilledInputClasses.d.ts +1 -1
  96. package/PickersTextField/PickersInput/PickersInput.js +20 -14
  97. package/PickersTextField/PickersInput/pickersInputClasses.d.ts +3 -2
  98. package/PickersTextField/PickersInput/pickersInputClasses.js +1 -1
  99. package/PickersTextField/PickersInputBase/PickersInputBase.d.ts +3 -6
  100. package/PickersTextField/PickersInputBase/PickersInputBase.js +51 -44
  101. package/PickersTextField/PickersInputBase/PickersInputBase.types.d.ts +1 -0
  102. package/PickersTextField/PickersOutlinedInput/Outline.d.ts +0 -1
  103. package/PickersTextField/PickersOutlinedInput/Outline.js +13 -10
  104. package/PickersTextField/PickersOutlinedInput/PickersOutlinedInput.js +8 -14
  105. package/PickersTextField/PickersTextField.js +75 -62
  106. package/PickersTextField/PickersTextField.types.d.ts +43 -4
  107. package/PickersTextField/usePickerTextFieldOwnerState.d.ts +4 -0
  108. package/PickersTextField/usePickerTextFieldOwnerState.js +11 -0
  109. package/README.md +10 -7
  110. package/StaticDatePicker/StaticDatePicker.js +2 -2
  111. package/StaticDatePicker/StaticDatePicker.types.d.ts +2 -3
  112. package/StaticDateTimePicker/StaticDateTimePicker.js +2 -2
  113. package/StaticDateTimePicker/StaticDateTimePicker.types.d.ts +2 -2
  114. package/StaticTimePicker/StaticTimePicker.js +2 -2
  115. package/StaticTimePicker/StaticTimePicker.types.d.ts +2 -2
  116. package/TimeClock/Clock.d.ts +4 -0
  117. package/TimeClock/Clock.js +28 -27
  118. package/TimeClock/ClockNumber.js +15 -11
  119. package/TimeClock/ClockPointer.d.ts +6 -1
  120. package/TimeClock/ClockPointer.js +16 -10
  121. package/TimeClock/TimeClock.js +31 -12
  122. package/TimeField/TimeField.js +28 -32
  123. package/TimeField/TimeField.types.d.ts +7 -16
  124. package/TimeField/useTimeField.d.ts +1 -1
  125. package/TimeField/useTimeField.js +14 -11
  126. package/TimePicker/TimePicker.js +2 -2
  127. package/TimePicker/TimePicker.types.d.ts +4 -5
  128. package/TimePicker/TimePickerToolbar.d.ts +1 -3
  129. package/TimePicker/TimePickerToolbar.js +40 -64
  130. package/TimePicker/shared.d.ts +6 -6
  131. package/YearCalendar/YearCalendar.js +47 -13
  132. package/YearCalendar/YearCalendar.types.d.ts +2 -2
  133. package/YearCalendar/YearCalendarButton.d.ts +23 -0
  134. package/{modern/YearCalendar/PickersYear.js → YearCalendar/YearCalendarButton.js} +20 -59
  135. package/YearCalendar/index.d.ts +0 -3
  136. package/YearCalendar/index.js +1 -2
  137. package/YearCalendar/yearCalendarClasses.d.ts +7 -1
  138. package/YearCalendar/yearCalendarClasses.js +1 -1
  139. package/hooks/index.d.ts +2 -0
  140. package/hooks/index.js +3 -1
  141. package/hooks/useClearableField.d.ts +5 -3
  142. package/hooks/useClearableField.js +4 -2
  143. package/hooks/useIsValidValue.d.ts +7 -0
  144. package/hooks/useIsValidValue.js +11 -0
  145. package/hooks/useParsedFormat.d.ts +9 -7
  146. package/hooks/useParsedFormat.js +11 -13
  147. package/hooks/usePickerActionsContext.d.ts +7 -0
  148. package/hooks/usePickerActionsContext.js +15 -0
  149. package/hooks/usePickerContext.d.ts +5 -1
  150. package/hooks/usePickerContext.js +2 -2
  151. package/hooks/useSplitFieldProps.d.ts +15 -6
  152. package/hooks/useSplitFieldProps.js +8 -3
  153. package/index.d.ts +1 -0
  154. package/index.js +3 -2
  155. package/internals/components/PickerFieldUI.d.ts +133 -0
  156. package/internals/components/PickerFieldUI.js +317 -0
  157. package/internals/components/{PickersPopper.d.ts → PickerPopper/PickerPopper.d.ts} +26 -25
  158. package/{modern/internals/components/PickersPopper.js → internals/components/PickerPopper/PickerPopper.js} +47 -47
  159. package/internals/components/PickerPopper/index.d.ts +4 -0
  160. package/internals/components/PickerPopper/index.js +2 -0
  161. package/internals/components/PickerPopper/pickerPopperClasses.d.ts +9 -0
  162. package/internals/components/PickerPopper/pickerPopperClasses.js +6 -0
  163. package/internals/components/PickerProvider.d.ts +94 -14
  164. package/internals/components/PickerProvider.js +28 -8
  165. package/internals/components/PickersArrowSwitcher/PickersArrowSwitcher.js +12 -11
  166. package/internals/components/PickersArrowSwitcher/PickersArrowSwitcher.types.d.ts +11 -8
  167. package/internals/components/PickersModalDialog.d.ts +1 -3
  168. package/internals/components/PickersModalDialog.js +9 -3
  169. package/internals/components/PickersToolbar.d.ts +2 -3
  170. package/internals/components/PickersToolbar.js +16 -15
  171. package/internals/components/PickersToolbarButton.js +4 -6
  172. package/internals/components/PickersToolbarText.js +11 -13
  173. package/internals/hooks/date-helpers-hooks.js +4 -3
  174. package/internals/hooks/useClockReferenceDate.d.ts +2 -1
  175. package/internals/hooks/useDesktopPicker/useDesktopPicker.d.ts +1 -1
  176. package/internals/hooks/useDesktopPicker/useDesktopPicker.js +36 -121
  177. package/internals/hooks/useDesktopPicker/useDesktopPicker.types.d.ts +16 -38
  178. package/internals/hooks/useField/buildSectionsFromFormat.js +1 -1
  179. package/internals/hooks/useField/index.d.ts +2 -0
  180. package/internals/hooks/useField/index.js +2 -1
  181. package/internals/hooks/useField/useField.d.ts +3 -3
  182. package/internals/hooks/useField/useField.js +17 -4
  183. package/internals/hooks/useField/useField.types.d.ts +56 -49
  184. package/internals/hooks/useField/useField.utils.d.ts +4 -3
  185. package/internals/hooks/useField/useField.utils.js +2 -2
  186. package/internals/hooks/useField/useFieldCharacterEditing.d.ts +6 -5
  187. package/internals/hooks/useField/useFieldInternalPropsWithDefaults.d.ts +15 -0
  188. package/internals/hooks/useField/useFieldInternalPropsWithDefaults.js +47 -0
  189. package/internals/hooks/useField/useFieldState.d.ts +9 -8
  190. package/internals/hooks/useField/useFieldState.js +3 -3
  191. package/internals/hooks/useField/useFieldV6TextField.d.ts +4 -3
  192. package/internals/hooks/useField/useFieldV6TextField.js +5 -2
  193. package/internals/hooks/useField/useFieldV7TextField.js +8 -4
  194. package/internals/hooks/useFieldOwnerState.d.ts +6 -0
  195. package/internals/hooks/useFieldOwnerState.js +16 -0
  196. package/internals/hooks/useMobilePicker/useMobilePicker.d.ts +1 -1
  197. package/internals/hooks/useMobilePicker/useMobilePicker.js +35 -69
  198. package/internals/hooks/useMobilePicker/useMobilePicker.types.d.ts +15 -22
  199. package/internals/hooks/useNullablePickerContext.d.ts +5 -0
  200. package/internals/hooks/useNullablePickerContext.js +10 -0
  201. package/internals/hooks/useOpenState.d.ts +3 -2
  202. package/internals/hooks/useOpenState.js +11 -9
  203. package/internals/hooks/usePicker/index.d.ts +1 -1
  204. package/internals/hooks/usePicker/usePicker.d.ts +3 -4
  205. package/internals/hooks/usePicker/usePicker.js +10 -29
  206. package/internals/hooks/usePicker/usePicker.types.d.ts +11 -11
  207. package/internals/hooks/usePicker/usePickerProvider.d.ts +58 -7
  208. package/internals/hooks/usePicker/usePickerProvider.js +102 -12
  209. package/internals/hooks/usePicker/usePickerValue.d.ts +3 -2
  210. package/internals/hooks/usePicker/usePickerValue.js +100 -218
  211. package/internals/hooks/usePicker/usePickerValue.types.d.ts +135 -79
  212. package/internals/hooks/usePicker/usePickerViews.d.ts +59 -40
  213. package/internals/hooks/usePicker/usePickerViews.js +31 -19
  214. package/internals/hooks/useReduceAnimations.d.ts +2 -0
  215. package/internals/hooks/{useDefaultReduceAnimations.js → useReduceAnimations.js} +5 -2
  216. package/internals/hooks/useStaticPicker/useStaticPicker.d.ts +1 -1
  217. package/internals/hooks/useStaticPicker/useStaticPicker.js +8 -13
  218. package/internals/hooks/useStaticPicker/useStaticPicker.types.d.ts +7 -13
  219. package/internals/hooks/useToolbarOwnerState.d.ts +10 -0
  220. package/internals/hooks/useToolbarOwnerState.js +13 -0
  221. package/internals/hooks/useUtils.d.ts +4 -3
  222. package/internals/hooks/useUtils.js +1 -1
  223. package/internals/hooks/useValueWithTimezone.d.ts +20 -15
  224. package/internals/hooks/useValueWithTimezone.js +13 -1
  225. package/internals/hooks/useViews.d.ts +5 -5
  226. package/internals/index.d.ts +28 -19
  227. package/internals/index.js +13 -8
  228. package/internals/models/common.d.ts +2 -1
  229. package/internals/models/fields.d.ts +8 -24
  230. package/internals/models/index.d.ts +1 -0
  231. package/internals/models/index.js +2 -1
  232. package/internals/models/manager.d.ts +15 -0
  233. package/internals/models/manager.js +1 -0
  234. package/internals/models/pickers.d.ts +1 -0
  235. package/internals/models/pickers.js +1 -0
  236. package/internals/models/props/basePickerProps.d.ts +3 -33
  237. package/internals/models/props/tabs.d.ts +0 -13
  238. package/internals/models/props/time.d.ts +2 -1
  239. package/internals/models/props/toolbar.d.ts +1 -20
  240. package/internals/models/value.d.ts +9 -0
  241. package/internals/utils/date-utils.d.ts +3 -3
  242. package/internals/utils/date-utils.js +1 -1
  243. package/internals/utils/utils.d.ts +3 -0
  244. package/internals/utils/utils.js +11 -1
  245. package/internals/utils/valueManagers.d.ts +4 -3
  246. package/internals/utils/valueManagers.js +4 -4
  247. package/locales/index.d.ts +1 -0
  248. package/locales/index.js +1 -0
  249. package/locales/nbNO.js +15 -19
  250. package/locales/nlNL.js +7 -7
  251. package/locales/roRO.js +15 -18
  252. package/locales/utils/getPickersLocalization.d.ts +0 -7
  253. package/locales/utils/getPickersLocalization.js +0 -13
  254. package/locales/zhTW.d.ts +80 -0
  255. package/locales/zhTW.js +73 -0
  256. package/managers/index.d.ts +6 -0
  257. package/managers/index.js +3 -0
  258. package/managers/package.json +6 -0
  259. package/managers/useDateManager.d.ts +27 -0
  260. package/managers/useDateManager.js +55 -0
  261. package/managers/useDateTimeManager.d.ts +28 -0
  262. package/managers/useDateTimeManager.js +60 -0
  263. package/managers/useTimeManager.d.ts +28 -0
  264. package/managers/useTimeManager.js +51 -0
  265. package/models/adapters.d.ts +5 -5
  266. package/models/common.d.ts +1 -0
  267. package/models/fields.d.ts +33 -10
  268. package/models/index.d.ts +1 -0
  269. package/models/index.js +1 -0
  270. package/models/manager.d.ts +87 -0
  271. package/models/manager.js +1 -0
  272. package/models/pickers.d.ts +25 -0
  273. package/models/validation.d.ts +2 -1
  274. package/modern/AdapterDateFns/AdapterDateFns.js +49 -47
  275. package/modern/AdapterDateFnsJalali/AdapterDateFnsJalali.js +48 -46
  276. package/modern/{AdapterDateFnsJalaliV3/AdapterDateFnsJalaliV3.js → AdapterDateFnsJalaliV2/AdapterDateFnsJalaliV2.js} +45 -52
  277. package/modern/AdapterDateFnsJalaliV2/index.js +1 -0
  278. package/modern/{AdapterDateFnsV3/AdapterDateFnsV3.js → AdapterDateFnsV2/AdapterDateFnsV2.js} +46 -54
  279. package/modern/AdapterDateFnsV2/index.js +1 -0
  280. package/modern/AdapterMoment/AdapterMoment.js +10 -0
  281. package/modern/DateCalendar/DateCalendar.js +5 -4
  282. package/modern/DateCalendar/DayCalendar.js +2 -0
  283. package/modern/DateCalendar/PickersFadeTransitionGroup.js +4 -6
  284. package/modern/DateCalendar/PickersSlideTransition.js +12 -5
  285. package/modern/DateField/DateField.js +29 -33
  286. package/modern/DateField/useDateField.js +14 -11
  287. package/modern/DatePicker/DatePicker.js +1 -1
  288. package/modern/DatePicker/DatePickerToolbar.js +17 -45
  289. package/modern/DateTimeField/DateTimeField.js +29 -33
  290. package/modern/DateTimeField/useDateTimeField.js +14 -11
  291. package/modern/DateTimePicker/DateTimePicker.js +2 -2
  292. package/modern/DateTimePicker/DateTimePickerTabs.js +15 -20
  293. package/modern/DateTimePicker/DateTimePickerToolbar.js +92 -93
  294. package/modern/DayCalendarSkeleton/DayCalendarSkeleton.js +10 -19
  295. package/modern/DesktopDatePicker/DesktopDatePicker.js +11 -17
  296. package/modern/DesktopDateTimePicker/DesktopDateTimePicker.js +17 -27
  297. package/modern/DesktopDateTimePicker/DesktopDateTimePickerLayout.js +9 -46
  298. package/modern/DesktopTimePicker/DesktopTimePicker.js +6 -22
  299. package/modern/DigitalClock/DigitalClock.js +14 -11
  300. package/modern/MobileDatePicker/MobileDatePicker.js +4 -14
  301. package/modern/MobileDateTimePicker/MobileDateTimePicker.js +4 -14
  302. package/modern/MobileTimePicker/MobileTimePicker.js +4 -14
  303. package/modern/MonthCalendar/MonthCalendar.js +32 -11
  304. package/{MonthCalendar/PickersMonth.js → modern/MonthCalendar/MonthCalendarButton.js} +20 -61
  305. package/modern/MonthCalendar/index.js +1 -2
  306. package/modern/MonthCalendar/monthCalendarClasses.js +1 -1
  307. package/modern/MultiSectionDigitalClock/MultiSectionDigitalClock.js +12 -7
  308. package/modern/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +14 -10
  309. package/modern/PickersActionBar/PickersActionBar.js +26 -17
  310. package/modern/PickersCalendarHeader/PickersCalendarHeader.js +10 -7
  311. package/modern/PickersLayout/PickersLayout.js +23 -54
  312. package/modern/PickersLayout/usePickerLayout.js +26 -57
  313. package/modern/PickersSectionList/PickersSectionList.js +21 -16
  314. package/modern/PickersShortcuts/PickersShortcuts.js +21 -11
  315. package/modern/PickersTextField/PickersFilledInput/PickersFilledInput.js +34 -28
  316. package/modern/PickersTextField/PickersInput/PickersInput.js +20 -14
  317. package/modern/PickersTextField/PickersInput/pickersInputClasses.js +1 -1
  318. package/modern/PickersTextField/PickersInputBase/PickersInputBase.js +51 -44
  319. package/modern/PickersTextField/PickersOutlinedInput/Outline.js +13 -10
  320. package/modern/PickersTextField/PickersOutlinedInput/PickersOutlinedInput.js +8 -14
  321. package/modern/PickersTextField/PickersTextField.js +75 -62
  322. package/modern/PickersTextField/usePickerTextFieldOwnerState.js +11 -0
  323. package/modern/StaticDatePicker/StaticDatePicker.js +2 -2
  324. package/modern/StaticDateTimePicker/StaticDateTimePicker.js +2 -2
  325. package/modern/StaticTimePicker/StaticTimePicker.js +2 -2
  326. package/modern/TimeClock/Clock.js +28 -27
  327. package/modern/TimeClock/ClockNumber.js +15 -11
  328. package/modern/TimeClock/ClockPointer.js +16 -10
  329. package/modern/TimeClock/TimeClock.js +31 -12
  330. package/modern/TimeField/TimeField.js +28 -32
  331. package/modern/TimeField/useTimeField.js +14 -11
  332. package/modern/TimePicker/TimePicker.js +2 -2
  333. package/modern/TimePicker/TimePickerToolbar.js +40 -64
  334. package/modern/YearCalendar/YearCalendar.js +47 -13
  335. package/{YearCalendar/PickersYear.js → modern/YearCalendar/YearCalendarButton.js} +20 -59
  336. package/modern/YearCalendar/index.js +1 -2
  337. package/modern/YearCalendar/yearCalendarClasses.js +1 -1
  338. package/modern/hooks/index.js +3 -1
  339. package/modern/hooks/useClearableField.js +4 -2
  340. package/modern/hooks/useIsValidValue.js +11 -0
  341. package/modern/hooks/useParsedFormat.js +11 -13
  342. package/modern/hooks/usePickerActionsContext.js +15 -0
  343. package/modern/hooks/usePickerContext.js +2 -2
  344. package/modern/hooks/useSplitFieldProps.js +8 -3
  345. package/modern/index.js +3 -2
  346. package/modern/internals/components/PickerFieldUI.js +317 -0
  347. package/{internals/components/PickersPopper.js → modern/internals/components/PickerPopper/PickerPopper.js} +47 -47
  348. package/modern/internals/components/PickerPopper/index.js +2 -0
  349. package/modern/internals/components/PickerPopper/pickerPopperClasses.js +6 -0
  350. package/modern/internals/components/PickerProvider.js +28 -8
  351. package/modern/internals/components/PickersArrowSwitcher/PickersArrowSwitcher.js +12 -11
  352. package/modern/internals/components/PickersModalDialog.js +9 -3
  353. package/modern/internals/components/PickersToolbar.js +16 -15
  354. package/modern/internals/components/PickersToolbarButton.js +4 -6
  355. package/modern/internals/components/PickersToolbarText.js +11 -13
  356. package/modern/internals/hooks/date-helpers-hooks.js +4 -3
  357. package/modern/internals/hooks/useDesktopPicker/useDesktopPicker.js +36 -121
  358. package/modern/internals/hooks/useField/buildSectionsFromFormat.js +1 -1
  359. package/modern/internals/hooks/useField/index.js +2 -1
  360. package/modern/internals/hooks/useField/useField.js +17 -4
  361. package/modern/internals/hooks/useField/useField.utils.js +2 -2
  362. package/modern/internals/hooks/useField/useFieldInternalPropsWithDefaults.js +47 -0
  363. package/modern/internals/hooks/useField/useFieldState.js +3 -3
  364. package/modern/internals/hooks/useField/useFieldV6TextField.js +5 -2
  365. package/modern/internals/hooks/useField/useFieldV7TextField.js +8 -4
  366. package/modern/internals/hooks/useFieldOwnerState.js +16 -0
  367. package/modern/internals/hooks/useMobilePicker/useMobilePicker.js +35 -69
  368. package/modern/internals/hooks/useNullablePickerContext.js +10 -0
  369. package/modern/internals/hooks/useOpenState.js +11 -9
  370. package/modern/internals/hooks/usePicker/usePicker.js +10 -29
  371. package/modern/internals/hooks/usePicker/usePickerProvider.js +102 -12
  372. package/modern/internals/hooks/usePicker/usePickerValue.js +100 -218
  373. package/modern/internals/hooks/usePicker/usePickerViews.js +31 -19
  374. package/modern/internals/hooks/{useDefaultReduceAnimations.js → useReduceAnimations.js} +5 -2
  375. package/modern/internals/hooks/useStaticPicker/useStaticPicker.js +8 -13
  376. package/modern/internals/hooks/useToolbarOwnerState.js +13 -0
  377. package/modern/internals/hooks/useUtils.js +1 -1
  378. package/modern/internals/hooks/useValueWithTimezone.js +13 -1
  379. package/modern/internals/index.js +13 -8
  380. package/modern/internals/models/index.js +2 -1
  381. package/modern/internals/models/manager.js +1 -0
  382. package/modern/internals/models/pickers.js +1 -0
  383. package/modern/internals/utils/date-utils.js +1 -1
  384. package/modern/internals/utils/utils.js +11 -1
  385. package/modern/internals/utils/valueManagers.js +4 -4
  386. package/modern/locales/index.js +1 -0
  387. package/modern/locales/nbNO.js +15 -19
  388. package/modern/locales/nlNL.js +7 -7
  389. package/modern/locales/roRO.js +15 -18
  390. package/modern/locales/utils/getPickersLocalization.js +0 -13
  391. package/modern/locales/zhTW.js +73 -0
  392. package/modern/managers/index.js +3 -0
  393. package/modern/managers/useDateManager.js +55 -0
  394. package/modern/managers/useDateTimeManager.js +60 -0
  395. package/modern/managers/useTimeManager.js +51 -0
  396. package/modern/models/index.js +1 -0
  397. package/modern/models/manager.js +1 -0
  398. package/modern/validation/useValidation.js +1 -1
  399. package/modern/validation/validateDate.js +8 -0
  400. package/modern/validation/validateDateTime.js +8 -0
  401. package/modern/validation/validateTime.js +8 -0
  402. package/node/AdapterDateFns/AdapterDateFns.js +97 -97
  403. package/node/AdapterDateFnsJalali/AdapterDateFnsJalali.js +97 -96
  404. package/node/{AdapterDateFnsJalaliV3/AdapterDateFnsJalaliV3.js → AdapterDateFnsJalaliV2/AdapterDateFnsJalaliV2.js} +94 -101
  405. package/node/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.js +1 -1
  406. package/node/AdapterDateFnsV2/AdapterDateFnsV2.js +291 -0
  407. package/node/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.js +1 -1
  408. package/node/AdapterMoment/AdapterMoment.js +10 -0
  409. package/node/DateCalendar/DateCalendar.js +5 -4
  410. package/node/DateCalendar/DayCalendar.js +1 -0
  411. package/node/DateCalendar/PickersFadeTransitionGroup.js +4 -6
  412. package/node/DateCalendar/PickersSlideTransition.js +12 -5
  413. package/node/DateField/DateField.js +29 -33
  414. package/node/DateField/useDateField.js +13 -10
  415. package/node/DatePicker/DatePicker.js +1 -1
  416. package/node/DatePicker/DatePickerToolbar.js +17 -45
  417. package/node/DateTimeField/DateTimeField.js +29 -33
  418. package/node/DateTimeField/useDateTimeField.js +13 -10
  419. package/node/DateTimePicker/DateTimePicker.js +2 -2
  420. package/node/DateTimePicker/DateTimePickerTabs.js +15 -20
  421. package/node/DateTimePicker/DateTimePickerToolbar.js +93 -93
  422. package/node/DayCalendarSkeleton/DayCalendarSkeleton.js +10 -19
  423. package/node/DesktopDatePicker/DesktopDatePicker.js +11 -17
  424. package/node/DesktopDateTimePicker/DesktopDateTimePicker.js +17 -27
  425. package/node/DesktopDateTimePicker/DesktopDateTimePickerLayout.js +10 -47
  426. package/node/DesktopTimePicker/DesktopTimePicker.js +6 -22
  427. package/node/DigitalClock/DigitalClock.js +14 -11
  428. package/node/MobileDatePicker/MobileDatePicker.js +4 -14
  429. package/node/MobileDateTimePicker/MobileDateTimePicker.js +4 -14
  430. package/node/MobileTimePicker/MobileTimePicker.js +4 -14
  431. package/node/MonthCalendar/MonthCalendar.js +32 -11
  432. package/node/MonthCalendar/{PickersMonth.js → MonthCalendarButton.js} +20 -61
  433. package/node/MonthCalendar/index.js +1 -8
  434. package/node/MonthCalendar/monthCalendarClasses.js +1 -1
  435. package/node/MultiSectionDigitalClock/MultiSectionDigitalClock.js +12 -7
  436. package/node/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +13 -10
  437. package/node/PickersActionBar/PickersActionBar.js +28 -19
  438. package/node/PickersCalendarHeader/PickersCalendarHeader.js +10 -7
  439. package/node/PickersLayout/PickersLayout.js +23 -54
  440. package/node/PickersLayout/usePickerLayout.js +30 -61
  441. package/node/PickersSectionList/PickersSectionList.js +21 -16
  442. package/node/PickersShortcuts/PickersShortcuts.js +21 -11
  443. package/node/PickersTextField/PickersFilledInput/PickersFilledInput.js +34 -28
  444. package/node/PickersTextField/PickersInput/PickersInput.js +20 -14
  445. package/node/PickersTextField/PickersInput/pickersInputClasses.js +1 -1
  446. package/node/PickersTextField/PickersInputBase/PickersInputBase.js +51 -44
  447. package/node/PickersTextField/PickersOutlinedInput/Outline.js +13 -10
  448. package/node/PickersTextField/PickersOutlinedInput/PickersOutlinedInput.js +8 -14
  449. package/node/PickersTextField/PickersTextField.js +75 -62
  450. package/node/PickersTextField/usePickerTextFieldOwnerState.js +18 -0
  451. package/node/StaticDatePicker/StaticDatePicker.js +2 -2
  452. package/node/StaticDateTimePicker/StaticDateTimePicker.js +2 -2
  453. package/node/StaticTimePicker/StaticTimePicker.js +2 -2
  454. package/node/TimeClock/Clock.js +28 -27
  455. package/node/TimeClock/ClockNumber.js +15 -11
  456. package/node/TimeClock/ClockPointer.js +15 -10
  457. package/node/TimeClock/TimeClock.js +31 -12
  458. package/node/TimeField/TimeField.js +28 -32
  459. package/node/TimeField/useTimeField.js +13 -10
  460. package/node/TimePicker/TimePicker.js +2 -2
  461. package/node/TimePicker/TimePickerToolbar.js +40 -64
  462. package/node/YearCalendar/YearCalendar.js +46 -12
  463. package/node/YearCalendar/{PickersYear.js → YearCalendarButton.js} +20 -59
  464. package/node/YearCalendar/index.js +1 -8
  465. package/node/YearCalendar/yearCalendarClasses.js +1 -1
  466. package/node/hooks/index.js +15 -1
  467. package/node/hooks/useClearableField.js +4 -2
  468. package/node/hooks/useIsValidValue.js +18 -0
  469. package/node/hooks/useParsedFormat.js +11 -13
  470. package/node/hooks/usePickerActionsContext.js +22 -0
  471. package/node/hooks/usePickerContext.js +5 -4
  472. package/node/hooks/useSplitFieldProps.js +7 -2
  473. package/node/index.js +13 -1
  474. package/node/internals/components/PickerFieldUI.js +329 -0
  475. package/node/internals/components/{PickersPopper.js → PickerPopper/PickerPopper.js} +48 -48
  476. package/node/internals/components/PickerPopper/index.js +25 -0
  477. package/node/internals/components/PickerPopper/pickerPopperClasses.js +14 -0
  478. package/node/internals/components/PickerProvider.js +30 -10
  479. package/node/internals/components/PickersArrowSwitcher/PickersArrowSwitcher.js +12 -11
  480. package/node/internals/components/PickersModalDialog.js +9 -3
  481. package/node/internals/components/PickersToolbar.js +16 -15
  482. package/node/internals/components/PickersToolbarButton.js +4 -6
  483. package/node/internals/components/PickersToolbarText.js +10 -12
  484. package/node/internals/hooks/date-helpers-hooks.js +4 -3
  485. package/node/internals/hooks/useDesktopPicker/useDesktopPicker.js +38 -123
  486. package/node/internals/hooks/useField/buildSectionsFromFormat.js +1 -1
  487. package/node/internals/hooks/useField/index.js +8 -1
  488. package/node/internals/hooks/useField/useField.js +16 -3
  489. package/node/internals/hooks/useField/useField.utils.js +2 -2
  490. package/node/internals/hooks/useField/useFieldInternalPropsWithDefaults.js +56 -0
  491. package/node/internals/hooks/useField/useFieldState.js +3 -3
  492. package/node/internals/hooks/useField/useFieldV6TextField.js +5 -2
  493. package/node/internals/hooks/useField/useFieldV7TextField.js +8 -4
  494. package/node/internals/hooks/useFieldOwnerState.js +24 -0
  495. package/node/internals/hooks/useMobilePicker/useMobilePicker.js +36 -70
  496. package/node/internals/hooks/useNullablePickerContext.js +16 -0
  497. package/node/internals/hooks/useOpenState.js +12 -9
  498. package/node/internals/hooks/usePicker/usePicker.js +10 -29
  499. package/node/internals/hooks/usePicker/usePickerProvider.js +105 -12
  500. package/node/internals/hooks/usePicker/usePickerValue.js +100 -217
  501. package/node/internals/hooks/usePicker/usePickerViews.js +31 -20
  502. package/node/internals/hooks/{useDefaultReduceAnimations.js → useReduceAnimations.js} +7 -4
  503. package/node/internals/hooks/useStaticPicker/useStaticPicker.js +8 -13
  504. package/node/internals/hooks/useToolbarOwnerState.js +21 -0
  505. package/node/internals/hooks/useUtils.js +1 -1
  506. package/node/internals/hooks/useValueWithTimezone.js +13 -1
  507. package/node/internals/index.js +87 -34
  508. package/node/internals/models/index.js +11 -0
  509. package/node/internals/models/manager.js +5 -0
  510. package/node/internals/models/pickers.js +5 -0
  511. package/node/internals/utils/date-utils.js +1 -1
  512. package/node/internals/utils/utils.js +14 -2
  513. package/node/internals/utils/valueManagers.js +4 -4
  514. package/node/locales/index.js +11 -0
  515. package/node/locales/nbNO.js +15 -19
  516. package/node/locales/nlNL.js +7 -7
  517. package/node/locales/roRO.js +15 -18
  518. package/node/locales/utils/getPickersLocalization.js +2 -16
  519. package/node/locales/zhTW.js +79 -0
  520. package/node/managers/index.js +26 -0
  521. package/node/managers/useDateManager.js +63 -0
  522. package/node/managers/useDateTimeManager.js +68 -0
  523. package/node/managers/useTimeManager.js +59 -0
  524. package/node/models/index.js +11 -0
  525. package/node/models/manager.js +5 -0
  526. package/node/validation/useValidation.js +1 -1
  527. package/node/validation/validateDate.js +8 -0
  528. package/node/validation/validateDateTime.js +8 -0
  529. package/node/validation/validateTime.js +8 -0
  530. package/package.json +7 -7
  531. package/themeAugmentation/components.d.ts +3 -11
  532. package/themeAugmentation/overrides.d.ts +5 -7
  533. package/themeAugmentation/props.d.ts +7 -9
  534. package/validation/extractValidationProps.d.ts +1 -1
  535. package/validation/useValidation.d.ts +7 -6
  536. package/validation/useValidation.js +1 -1
  537. package/validation/validateDate.d.ts +12 -3
  538. package/validation/validateDate.js +8 -0
  539. package/validation/validateDateTime.d.ts +12 -4
  540. package/validation/validateDateTime.js +8 -0
  541. package/validation/validateTime.d.ts +12 -3
  542. package/validation/validateTime.js +8 -0
  543. package/AdapterDateFnsJalaliV3/index.d.ts +0 -1
  544. package/AdapterDateFnsJalaliV3/index.js +0 -1
  545. package/AdapterDateFnsV3/index.d.ts +0 -1
  546. package/AdapterDateFnsV3/index.js +0 -1
  547. package/MonthCalendar/PickersMonth.d.ts +0 -28
  548. package/MonthCalendar/pickersMonthClasses.d.ts +0 -13
  549. package/MonthCalendar/pickersMonthClasses.js +0 -5
  550. package/YearCalendar/PickersYear.d.ts +0 -27
  551. package/YearCalendar/pickersYearClasses.d.ts +0 -13
  552. package/YearCalendar/pickersYearClasses.js +0 -5
  553. package/internals/components/pickersPopperClasses.d.ts +0 -9
  554. package/internals/components/pickersPopperClasses.js +0 -5
  555. package/internals/hooks/defaultizedFieldProps.d.ts +0 -18
  556. package/internals/hooks/defaultizedFieldProps.js +0 -40
  557. package/internals/hooks/useDefaultReduceAnimations.d.ts +0 -2
  558. package/internals/hooks/useIsLandscape.d.ts +0 -4
  559. package/internals/hooks/useIsLandscape.js +0 -35
  560. package/internals/hooks/usePicker/usePickerLayoutProps.d.ts +0 -33
  561. package/internals/hooks/usePicker/usePickerLayoutProps.js +0 -34
  562. package/internals/hooks/usePicker/usePickerOwnerState.d.ts +0 -10
  563. package/internals/hooks/usePicker/usePickerOwnerState.js +0 -16
  564. package/internals/utils/convertFieldResponseIntoMuiTextFieldProps.d.ts +0 -3
  565. package/internals/utils/convertFieldResponseIntoMuiTextFieldProps.js +0 -44
  566. package/modern/AdapterDateFnsJalaliV3/index.js +0 -1
  567. package/modern/AdapterDateFnsV3/index.js +0 -1
  568. package/modern/MonthCalendar/pickersMonthClasses.js +0 -5
  569. package/modern/YearCalendar/pickersYearClasses.js +0 -5
  570. package/modern/internals/components/pickersPopperClasses.js +0 -5
  571. package/modern/internals/hooks/defaultizedFieldProps.js +0 -40
  572. package/modern/internals/hooks/useIsLandscape.js +0 -35
  573. package/modern/internals/hooks/usePicker/usePickerLayoutProps.js +0 -34
  574. package/modern/internals/hooks/usePicker/usePickerOwnerState.js +0 -16
  575. package/modern/internals/utils/convertFieldResponseIntoMuiTextFieldProps.js +0 -44
  576. package/node/AdapterDateFnsV3/AdapterDateFnsV3.js +0 -299
  577. package/node/MonthCalendar/pickersMonthClasses.js +0 -12
  578. package/node/YearCalendar/pickersYearClasses.js +0 -12
  579. package/node/internals/components/pickersPopperClasses.js +0 -12
  580. package/node/internals/hooks/defaultizedFieldProps.js +0 -50
  581. package/node/internals/hooks/useIsLandscape.js +0 -43
  582. package/node/internals/hooks/usePicker/usePickerLayoutProps.js +0 -41
  583. package/node/internals/hooks/usePicker/usePickerOwnerState.js +0 -23
  584. package/node/internals/utils/convertFieldResponseIntoMuiTextFieldProps.js +0 -52
@@ -4,19 +4,27 @@ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWild
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
- exports.PickerPrivateContext = exports.PickerContext = void 0;
7
+ exports.PickerPrivateContext = exports.PickerActionsContext = void 0;
8
8
  exports.PickerProvider = PickerProvider;
9
9
  var React = _interopRequireWildcard(require("react"));
10
10
  var _LocalizationProvider = require("../../LocalizationProvider");
11
+ var _useIsValidValue = require("../../hooks/useIsValidValue");
12
+ var _useFieldInternalPropsWithDefaults = require("../hooks/useField/useFieldInternalPropsWithDefaults");
13
+ var _usePickerContext = require("../../hooks/usePickerContext");
11
14
  var _jsxRuntime = require("react/jsx-runtime");
12
- const PickerContext = exports.PickerContext = /*#__PURE__*/React.createContext(null);
15
+ const PickerActionsContext = exports.PickerActionsContext = /*#__PURE__*/React.createContext(null);
13
16
  const PickerPrivateContext = exports.PickerPrivateContext = /*#__PURE__*/React.createContext({
14
17
  ownerState: {
15
18
  isPickerDisabled: false,
16
19
  isPickerReadOnly: false,
17
20
  isPickerValueEmpty: false,
18
- isPickerOpen: false
19
- }
21
+ isPickerOpen: false,
22
+ pickerVariant: 'desktop',
23
+ pickerOrientation: 'portrait'
24
+ },
25
+ dismissViews: () => {},
26
+ hasUIView: true,
27
+ doesTheCurrentViewHasAnUI: () => true
20
28
  });
21
29
 
22
30
  /**
@@ -29,17 +37,29 @@ const PickerPrivateContext = exports.PickerPrivateContext = /*#__PURE__*/React.c
29
37
  function PickerProvider(props) {
30
38
  const {
31
39
  contextValue,
40
+ actionsContextValue,
32
41
  privateContextValue,
42
+ fieldPrivateContextValue,
43
+ isValidContextValue,
33
44
  localeText,
34
45
  children
35
46
  } = props;
36
- return /*#__PURE__*/(0, _jsxRuntime.jsx)(PickerContext.Provider, {
47
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_usePickerContext.PickerContext.Provider, {
37
48
  value: contextValue,
38
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(PickerPrivateContext.Provider, {
39
- value: privateContextValue,
40
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_LocalizationProvider.LocalizationProvider, {
41
- localeText: localeText,
42
- children: children
49
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(PickerActionsContext.Provider, {
50
+ value: actionsContextValue,
51
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(PickerPrivateContext.Provider, {
52
+ value: privateContextValue,
53
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_useFieldInternalPropsWithDefaults.PickerFieldPrivateContext.Provider, {
54
+ value: fieldPrivateContextValue,
55
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_useIsValidValue.IsValidValueContext.Provider, {
56
+ value: isValidContextValue,
57
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_LocalizationProvider.LocalizationProvider, {
58
+ localeText: localeText,
59
+ children: children
60
+ })
61
+ })
62
+ })
43
63
  })
44
64
  })
45
65
  });
@@ -18,8 +18,9 @@ var _useSlotProps3 = _interopRequireDefault(require("@mui/utils/useSlotProps"));
18
18
  var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
19
19
  var _icons = require("../../../icons");
20
20
  var _pickersArrowSwitcherClasses = require("./pickersArrowSwitcherClasses");
21
+ var _usePickerPrivateContext = require("../../hooks/usePickerPrivateContext");
21
22
  var _jsxRuntime = require("react/jsx-runtime");
22
- const _excluded = ["children", "className", "slots", "slotProps", "isNextDisabled", "isNextHidden", "onGoToNext", "nextLabel", "isPreviousDisabled", "isPreviousHidden", "onGoToPrevious", "previousLabel", "labelId"],
23
+ const _excluded = ["children", "className", "slots", "slotProps", "isNextDisabled", "isNextHidden", "onGoToNext", "nextLabel", "isPreviousDisabled", "isPreviousHidden", "onGoToPrevious", "previousLabel", "labelId", "classes"],
23
24
  _excluded2 = ["ownerState"],
24
25
  _excluded3 = ["ownerState"];
25
26
  const PickersArrowSwitcherRoot = (0, _styles.styled)('div', {
@@ -45,17 +46,14 @@ const PickersArrowSwitcherButton = (0, _styles.styled)(_IconButton.default, {
45
46
  })({
46
47
  variants: [{
47
48
  props: {
48
- hidden: true
49
+ isButtonHidden: true
49
50
  },
50
51
  style: {
51
52
  visibility: 'hidden'
52
53
  }
53
54
  }]
54
55
  });
55
- const useUtilityClasses = ownerState => {
56
- const {
57
- classes
58
- } = ownerState;
56
+ const useUtilityClasses = classes => {
59
57
  const slots = {
60
58
  root: ['root'],
61
59
  spacer: ['spacer'],
@@ -86,11 +84,14 @@ const PickersArrowSwitcher = exports.PickersArrowSwitcher = /*#__PURE__*/React.f
86
84
  isPreviousHidden,
87
85
  onGoToPrevious,
88
86
  previousLabel,
89
- labelId
87
+ labelId,
88
+ classes: classesProp
90
89
  } = props,
91
90
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
92
- const ownerState = props;
93
- const classes = useUtilityClasses(ownerState);
91
+ const {
92
+ ownerState
93
+ } = (0, _usePickerPrivateContext.usePickerPrivateContext)();
94
+ const classes = useUtilityClasses(classesProp);
94
95
  const nextProps = {
95
96
  isDisabled: isNextDisabled,
96
97
  isHidden: isNextHidden,
@@ -116,7 +117,7 @@ const PickersArrowSwitcher = exports.PickersArrowSwitcher = /*#__PURE__*/React.f
116
117
  onClick: previousProps.goTo
117
118
  },
118
119
  ownerState: (0, _extends2.default)({}, ownerState, {
119
- hidden: previousProps.isHidden
120
+ isButtonHidden: previousProps.isHidden ?? false
120
121
  }),
121
122
  className: (0, _clsx.default)(classes.button, classes.previousIconButton)
122
123
  });
@@ -133,7 +134,7 @@ const PickersArrowSwitcher = exports.PickersArrowSwitcher = /*#__PURE__*/React.f
133
134
  onClick: nextProps.goTo
134
135
  },
135
136
  ownerState: (0, _extends2.default)({}, ownerState, {
136
- hidden: nextProps.isHidden
137
+ isButtonHidden: nextProps.isHidden ?? false
137
138
  }),
138
139
  className: (0, _clsx.default)(classes.button, classes.nextIconButton)
139
140
  });
@@ -13,6 +13,8 @@ var _Fade = _interopRequireDefault(require("@mui/material/Fade"));
13
13
  var _Dialog = _interopRequireWildcard(require("@mui/material/Dialog"));
14
14
  var _styles = require("@mui/material/styles");
15
15
  var _dimensions = require("../constants/dimensions");
16
+ var _hooks = require("../../hooks");
17
+ var _usePickerPrivateContext = require("../hooks/usePickerPrivateContext");
16
18
  var _jsxRuntime = require("react/jsx-runtime");
17
19
  const PickersModalDialogRoot = (0, _styles.styled)(_Dialog.default)({
18
20
  [`& .${_Dialog.dialogClasses.container}`]: {
@@ -31,16 +33,20 @@ const PickersModalDialogContent = (0, _styles.styled)(_DialogContent.default)({
31
33
  function PickersModalDialog(props) {
32
34
  const {
33
35
  children,
34
- onDismiss,
35
- open,
36
36
  slots,
37
37
  slotProps
38
38
  } = props;
39
+ const {
40
+ open
41
+ } = (0, _hooks.usePickerContext)();
42
+ const {
43
+ dismissViews
44
+ } = (0, _usePickerPrivateContext.usePickerPrivateContext)();
39
45
  const Dialog = slots?.dialog ?? PickersModalDialogRoot;
40
46
  const Transition = slots?.mobileTransition ?? _Fade.default;
41
47
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(Dialog, (0, _extends2.default)({
42
48
  open: open,
43
- onClose: onDismiss
49
+ onClose: dismissViews
44
50
  }, slotProps?.dialog, {
45
51
  TransitionComponent: Transition,
46
52
  TransitionProps: slotProps?.mobileTransition,
@@ -13,18 +13,15 @@ var _clsx = _interopRequireDefault(require("clsx"));
13
13
  var _Typography = _interopRequireDefault(require("@mui/material/Typography"));
14
14
  var _styles = require("@mui/material/styles");
15
15
  var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses"));
16
+ var _createStyled = require("@mui/system/createStyled");
16
17
  var _pickersToolbarClasses = require("./pickersToolbarClasses");
18
+ var _useToolbarOwnerState = require("../hooks/useToolbarOwnerState");
17
19
  var _jsxRuntime = require("react/jsx-runtime");
18
- const _excluded = ["children", "className", "toolbarTitle", "hidden", "titleId", "isLandscape", "classes", "landscapeDirection"];
19
- const useUtilityClasses = ownerState => {
20
- const {
21
- classes,
22
- isLandscape
23
- } = ownerState;
20
+ const _excluded = ["children", "className", "classes", "toolbarTitle", "hidden", "titleId", "classes", "landscapeDirection"];
21
+ const useUtilityClasses = classes => {
24
22
  const slots = {
25
23
  root: ['root'],
26
- content: ['content'],
27
- penIconButton: ['penIconButton', isLandscape && 'penIconButtonLandscape']
24
+ content: ['content']
28
25
  };
29
26
  return (0, _composeClasses.default)(slots, _pickersToolbarClasses.getPickersToolbarUtilityClass, classes);
30
27
  };
@@ -42,7 +39,7 @@ const PickersToolbarRoot = (0, _styles.styled)('div', {
42
39
  padding: theme.spacing(2, 3),
43
40
  variants: [{
44
41
  props: {
45
- isLandscape: true
42
+ pickerOrientation: 'landscape'
46
43
  },
47
44
  style: {
48
45
  height: 'auto',
@@ -56,7 +53,8 @@ const PickersToolbarRoot = (0, _styles.styled)('div', {
56
53
  const PickersToolbarContent = (0, _styles.styled)('div', {
57
54
  name: 'MuiPickersToolbar',
58
55
  slot: 'Content',
59
- overridesResolver: (props, styles) => styles.content
56
+ overridesResolver: (props, styles) => styles.content,
57
+ shouldForwardProp: prop => (0, _createStyled.shouldForwardProp)(prop) && prop !== 'landscapeDirection'
60
58
  })({
61
59
  display: 'flex',
62
60
  flexWrap: 'wrap',
@@ -67,7 +65,7 @@ const PickersToolbarContent = (0, _styles.styled)('div', {
67
65
  flexDirection: 'row',
68
66
  variants: [{
69
67
  props: {
70
- isLandscape: true
68
+ pickerOrientation: 'landscape'
71
69
  },
72
70
  style: {
73
71
  justifyContent: 'flex-start',
@@ -76,7 +74,7 @@ const PickersToolbarContent = (0, _styles.styled)('div', {
76
74
  }
77
75
  }, {
78
76
  props: {
79
- isLandscape: true,
77
+ pickerOrientation: 'landscape',
80
78
  landscapeDirection: 'row'
81
79
  },
82
80
  style: {
@@ -92,13 +90,15 @@ const PickersToolbar = exports.PickersToolbar = /*#__PURE__*/React.forwardRef(fu
92
90
  const {
93
91
  children,
94
92
  className,
93
+ classes: classesProp,
95
94
  toolbarTitle,
96
95
  hidden,
97
- titleId
96
+ titleId,
97
+ landscapeDirection
98
98
  } = props,
99
99
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
100
- const ownerState = props;
101
- const classes = useUtilityClasses(ownerState);
100
+ const ownerState = (0, _useToolbarOwnerState.useToolbarOwnerState)();
101
+ const classes = useUtilityClasses(classesProp);
102
102
  if (hidden) {
103
103
  return null;
104
104
  }
@@ -115,6 +115,7 @@ const PickersToolbar = exports.PickersToolbar = /*#__PURE__*/React.forwardRef(fu
115
115
  }), /*#__PURE__*/(0, _jsxRuntime.jsx)(PickersToolbarContent, {
116
116
  className: classes.content,
117
117
  ownerState: ownerState,
118
+ landscapeDirection: landscapeDirection,
118
119
  children: children
119
120
  })]
120
121
  }));
@@ -16,11 +16,8 @@ var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses"
16
16
  var _PickersToolbarText = require("./PickersToolbarText");
17
17
  var _pickersToolbarClasses = require("./pickersToolbarClasses");
18
18
  var _jsxRuntime = require("react/jsx-runtime");
19
- const _excluded = ["align", "className", "selected", "typographyClassName", "value", "variant", "width"];
20
- const useUtilityClasses = ownerState => {
21
- const {
22
- classes
23
- } = ownerState;
19
+ const _excluded = ["align", "className", "classes", "selected", "typographyClassName", "value", "variant", "width"];
20
+ const useUtilityClasses = classes => {
24
21
  const slots = {
25
22
  root: ['root']
26
23
  };
@@ -43,6 +40,7 @@ const PickersToolbarButton = exports.PickersToolbarButton = /*#__PURE__*/React.f
43
40
  const {
44
41
  align,
45
42
  className,
43
+ classes: classesProp,
46
44
  selected,
47
45
  typographyClassName,
48
46
  value,
@@ -50,7 +48,7 @@ const PickersToolbarButton = exports.PickersToolbarButton = /*#__PURE__*/React.f
50
48
  width
51
49
  } = props,
52
50
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
53
- const classes = useUtilityClasses(props);
51
+ const classes = useUtilityClasses(classesProp);
54
52
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(PickersToolbarButtonRoot, (0, _extends2.default)({
55
53
  variant: "text",
56
54
  ref: ref,
@@ -15,29 +15,23 @@ var _styles = require("@mui/material/styles");
15
15
  var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses"));
16
16
  var _pickersToolbarTextClasses = require("./pickersToolbarTextClasses");
17
17
  var _jsxRuntime = require("react/jsx-runtime");
18
- const _excluded = ["className", "selected", "value"];
19
- const useUtilityClasses = ownerState => {
20
- const {
21
- classes,
22
- selected
23
- } = ownerState;
18
+ const _excluded = ["className", "classes", "selected", "value"];
19
+ const useUtilityClasses = classes => {
24
20
  const slots = {
25
- root: ['root', selected && 'selected']
21
+ root: ['root']
26
22
  };
27
23
  return (0, _composeClasses.default)(slots, _pickersToolbarTextClasses.getPickersToolbarTextUtilityClass, classes);
28
24
  };
29
25
  const PickersToolbarTextRoot = (0, _styles.styled)(_Typography.default, {
30
26
  name: 'MuiPickersToolbarText',
31
27
  slot: 'Root',
32
- overridesResolver: (_, styles) => [styles.root, {
33
- [`&.${_pickersToolbarTextClasses.pickersToolbarTextClasses.selected}`]: styles.selected
34
- }]
28
+ overridesResolver: (_, styles) => [styles.root]
35
29
  })(({
36
30
  theme
37
31
  }) => ({
38
32
  transition: theme.transitions.create('color'),
39
33
  color: (theme.vars || theme).palette.text.secondary,
40
- [`&.${_pickersToolbarTextClasses.pickersToolbarTextClasses.selected}`]: {
34
+ [`&[data-selected]`]: {
41
35
  color: (theme.vars || theme).palette.text.primary
42
36
  }
43
37
  }));
@@ -48,14 +42,18 @@ const PickersToolbarText = exports.PickersToolbarText = /*#__PURE__*/React.forwa
48
42
  });
49
43
  const {
50
44
  className,
45
+ classes: classesProp,
46
+ selected,
51
47
  value
52
48
  } = props,
53
49
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
54
- const classes = useUtilityClasses(props);
50
+ const classes = useUtilityClasses(classesProp);
55
51
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(PickersToolbarTextRoot, (0, _extends2.default)({
56
52
  ref: ref,
57
53
  className: (0, _clsx.default)(classes.root, className),
58
54
  component: "span"
55
+ }, selected && {
56
+ 'data-selected': true
59
57
  }, other, {
60
58
  children: value
61
59
  }));
@@ -36,11 +36,12 @@ function usePreviousMonthDisabled(month, {
36
36
  }
37
37
  function useMeridiemMode(date, ampm, onChange, selectionState) {
38
38
  const utils = (0, _useUtils.useUtils)();
39
- const meridiemMode = (0, _timeUtils.getMeridiem)(date, utils);
39
+ const cleanDate = React.useMemo(() => !utils.isValid(date) ? null : date, [utils, date]);
40
+ const meridiemMode = (0, _timeUtils.getMeridiem)(cleanDate, utils);
40
41
  const handleMeridiemChange = React.useCallback(mode => {
41
- const timeWithMeridiem = date == null ? null : (0, _timeUtils.convertToMeridiem)(date, mode, Boolean(ampm), utils);
42
+ const timeWithMeridiem = cleanDate == null ? null : (0, _timeUtils.convertToMeridiem)(cleanDate, mode, Boolean(ampm), utils);
42
43
  onChange(timeWithMeridiem, selectionState ?? 'partial');
43
- }, [ampm, date, onChange, selectionState, utils]);
44
+ }, [ampm, cleanDate, onChange, selectionState, utils]);
44
45
  return {
45
46
  meridiemMode,
46
47
  handleMeridiemChange
@@ -9,19 +9,17 @@ exports.useDesktopPicker = void 0;
9
9
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
10
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
11
11
  var React = _interopRequireWildcard(require("react"));
12
- var _useSlotProps3 = _interopRequireDefault(require("@mui/utils/useSlotProps"));
13
- var _InputAdornment = _interopRequireDefault(require("@mui/material/InputAdornment"));
14
- var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
12
+ var _useSlotProps2 = _interopRequireDefault(require("@mui/utils/useSlotProps"));
15
13
  var _useForkRef = _interopRequireDefault(require("@mui/utils/useForkRef"));
16
14
  var _useId = _interopRequireDefault(require("@mui/utils/useId"));
17
- var _PickersPopper = require("../../components/PickersPopper");
15
+ var _PickerPopper = require("../../components/PickerPopper/PickerPopper");
18
16
  var _usePicker = require("../usePicker");
19
17
  var _PickersLayout = require("../../../PickersLayout");
20
18
  var _PickerProvider = require("../../components/PickerProvider");
19
+ var _PickerFieldUI = require("../../components/PickerFieldUI");
21
20
  var _jsxRuntime = require("react/jsx-runtime");
22
- const _excluded = ["props", "getOpenDialogAriaText"],
23
- _excluded2 = ["ownerState"],
24
- _excluded3 = ["ownerState"];
21
+ const _excluded = ["props"],
22
+ _excluded2 = ["ownerState"];
25
23
  /**
26
24
  * Hook managing all the single-date desktop pickers:
27
25
  * - DesktopDatePicker
@@ -30,130 +28,48 @@ const _excluded = ["props", "getOpenDialogAriaText"],
30
28
  */
31
29
  const useDesktopPicker = _ref => {
32
30
  let {
33
- props,
34
- getOpenDialogAriaText
31
+ props
35
32
  } = _ref,
36
33
  pickerParams = (0, _objectWithoutPropertiesLoose2.default)(_ref, _excluded);
37
34
  const {
38
35
  slots,
39
36
  slotProps: innerSlotProps,
40
- className,
41
- sx,
42
- format,
43
- formatDensity,
44
- enableAccessibleFieldDOMStructure,
45
- selectedSections,
46
- onSelectedSectionsChange,
47
- timezone,
48
- name,
49
37
  label,
50
38
  inputRef,
51
39
  readOnly,
52
- disabled,
53
40
  autoFocus,
54
- localeText,
55
- reduceAnimations
41
+ localeText
56
42
  } = props;
57
- const containerRef = React.useRef(null);
58
43
  const fieldRef = React.useRef(null);
59
44
  const labelId = (0, _useId.default)();
60
45
  const isToolbarHidden = innerSlotProps?.toolbar?.hidden ?? false;
61
46
  const {
62
- open,
63
- actions,
64
- hasUIView,
65
- layoutProps,
66
47
  providerProps,
67
48
  renderCurrentView,
68
- shouldRestoreFocus,
69
- fieldProps: pickerFieldProps,
70
49
  ownerState
71
50
  } = (0, _usePicker.usePicker)((0, _extends2.default)({}, pickerParams, {
72
51
  props,
73
52
  fieldRef,
74
53
  localeText,
75
54
  autoFocusView: true,
76
- additionalViewProps: {},
77
- wrapperVariant: 'desktop'
55
+ variant: 'desktop'
78
56
  }));
79
- const InputAdornment = slots.inputAdornment ?? _InputAdornment.default;
80
- const _useSlotProps = (0, _useSlotProps3.default)({
81
- elementType: InputAdornment,
82
- externalSlotProps: innerSlotProps?.inputAdornment,
83
- additionalProps: {
84
- position: 'end'
85
- },
86
- ownerState
87
- }),
88
- inputAdornmentProps = (0, _objectWithoutPropertiesLoose2.default)(_useSlotProps, _excluded2);
89
- const OpenPickerButton = slots.openPickerButton ?? _IconButton.default;
90
- const _useSlotProps2 = (0, _useSlotProps3.default)({
91
- elementType: OpenPickerButton,
92
- externalSlotProps: innerSlotProps?.openPickerButton,
93
- additionalProps: {
94
- disabled: disabled || readOnly,
95
- onClick: open ? actions.onClose : actions.onOpen,
96
- 'aria-label': getOpenDialogAriaText(pickerFieldProps.value),
97
- edge: inputAdornmentProps.position
98
- },
99
- ownerState
100
- }),
101
- openPickerButtonProps = (0, _objectWithoutPropertiesLoose2.default)(_useSlotProps2, _excluded3);
102
- const OpenPickerIcon = slots.openPickerIcon;
103
- const openPickerIconProps = (0, _useSlotProps3.default)({
104
- elementType: OpenPickerIcon,
105
- externalSlotProps: innerSlotProps?.openPickerIcon,
106
- ownerState
107
- });
108
57
  const Field = slots.field;
109
- const fieldProps = (0, _useSlotProps3.default)({
110
- elementType: Field,
111
- externalSlotProps: innerSlotProps?.field,
112
- additionalProps: (0, _extends2.default)({
113
- // Internal props
114
- readOnly,
115
- disabled,
116
- format,
117
- formatDensity,
118
- enableAccessibleFieldDOMStructure,
119
- selectedSections,
120
- onSelectedSectionsChange,
121
- timezone,
122
- autoFocus: autoFocus && !props.open
123
- }, pickerFieldProps, {
124
- // onChange and value
125
-
126
- // Forwarded props
127
- className,
128
- sx,
129
- label,
130
- name,
131
- focused: open ? true : undefined
132
- }, isToolbarHidden && {
133
- id: labelId
134
- }, !!inputRef && {
135
- inputRef
58
+ const _useSlotProps = (0, _useSlotProps2.default)({
59
+ elementType: Field,
60
+ externalSlotProps: innerSlotProps?.field,
61
+ additionalProps: (0, _extends2.default)({
62
+ // Internal props
63
+ readOnly,
64
+ autoFocus: autoFocus && !props.open,
65
+ // Forwarded props
66
+ focused: providerProps.contextValue.open ? true : undefined
67
+ }, isToolbarHidden && {
68
+ id: labelId
69
+ }),
70
+ ownerState
136
71
  }),
137
- ownerState
138
- });
139
-
140
- // TODO: Move to `useSlotProps` when https://github.com/mui/material-ui/pull/35088 will be merged
141
- if (hasUIView) {
142
- fieldProps.InputProps = (0, _extends2.default)({}, fieldProps.InputProps, {
143
- ref: containerRef
144
- }, !props.disableOpenPicker && {
145
- [`${inputAdornmentProps.position}Adornment`]: /*#__PURE__*/(0, _jsxRuntime.jsx)(InputAdornment, (0, _extends2.default)({}, inputAdornmentProps, {
146
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(OpenPickerButton, (0, _extends2.default)({}, openPickerButtonProps, {
147
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(OpenPickerIcon, (0, _extends2.default)({}, openPickerIconProps))
148
- }))
149
- }))
150
- });
151
- }
152
- const slotsForField = (0, _extends2.default)({
153
- textField: slots.textField,
154
- clearIcon: slots.clearIcon,
155
- clearButton: slots.clearButton
156
- }, fieldProps.slots);
72
+ fieldProps = (0, _objectWithoutPropertiesLoose2.default)(_useSlotProps, _excluded2);
157
73
  const Layout = slots.layout ?? _PickersLayout.PickersLayout;
158
74
  let labelledById = labelId;
159
75
  if (isToolbarHidden) {
@@ -171,28 +87,27 @@ const useDesktopPicker = _ref => {
171
87
  'aria-labelledby': labelledById
172
88
  }, innerSlotProps?.popper)
173
89
  });
90
+
91
+ // TODO: This `as any` will go away once the field ref is handled by the context.
174
92
  const handleFieldRef = (0, _useForkRef.default)(fieldRef, fieldProps.unstableFieldRef);
175
- const renderPicker = () => /*#__PURE__*/(0, _jsxRuntime.jsxs)(_PickerProvider.PickerProvider, (0, _extends2.default)({}, providerProps, {
176
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(Field, (0, _extends2.default)({}, fieldProps, {
177
- slots: slotsForField,
178
- slotProps: slotProps,
179
- unstableFieldRef: handleFieldRef
180
- })), /*#__PURE__*/(0, _jsxRuntime.jsx)(_PickersPopper.PickersPopper, (0, _extends2.default)({
181
- role: "dialog",
182
- placement: "bottom-start",
183
- anchorEl: containerRef.current
184
- }, actions, {
185
- open: open,
93
+ const renderPicker = () => /*#__PURE__*/(0, _jsxRuntime.jsx)(_PickerProvider.PickerProvider, (0, _extends2.default)({}, providerProps, {
94
+ children: /*#__PURE__*/(0, _jsxRuntime.jsxs)(_PickerFieldUI.PickerFieldUIContextProvider, {
186
95
  slots: slots,
187
96
  slotProps: slotProps,
188
- shouldRestoreFocus: shouldRestoreFocus,
189
- reduceAnimations: reduceAnimations,
190
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(Layout, (0, _extends2.default)({}, layoutProps, slotProps?.layout, {
97
+ inputRef: inputRef,
98
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(Field, (0, _extends2.default)({}, fieldProps, {
99
+ unstableFieldRef: handleFieldRef
100
+ })), /*#__PURE__*/(0, _jsxRuntime.jsx)(_PickerPopper.PickerPopper, {
101
+ role: "dialog",
191
102
  slots: slots,
192
103
  slotProps: slotProps,
193
- children: renderCurrentView()
194
- }))
195
- }))]
104
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(Layout, (0, _extends2.default)({}, slotProps?.layout, {
105
+ slots: slots,
106
+ slotProps: slotProps,
107
+ children: renderCurrentView()
108
+ }))
109
+ })]
110
+ })
196
111
  }));
197
112
  return {
198
113
  renderPicker
@@ -120,7 +120,7 @@ const createSection = ({
120
120
  const sectionConfig = (0, _useField.getDateSectionConfigFromFormatToken)(utils, token);
121
121
  const hasLeadingZerosInFormat = (0, _useField.doesSectionFormatHaveLeadingZeros)(utils, sectionConfig.contentType, sectionConfig.type, token);
122
122
  const hasLeadingZerosInInput = shouldRespectLeadingZeros ? hasLeadingZerosInFormat : sectionConfig.contentType === 'digit';
123
- const isValidDate = date != null && utils.isValid(date);
123
+ const isValidDate = utils.isValid(date);
124
124
  let sectionValue = isValidDate ? utils.formatByString(date, token) : '';
125
125
  let maxLength = null;
126
126
  if (hasLeadingZerosInInput) {
@@ -21,5 +21,12 @@ Object.defineProperty(exports, "useField", {
21
21
  return _useField.useField;
22
22
  }
23
23
  });
24
+ Object.defineProperty(exports, "useFieldInternalPropsWithDefaults", {
25
+ enumerable: true,
26
+ get: function () {
27
+ return _useFieldInternalPropsWithDefaults.useFieldInternalPropsWithDefaults;
28
+ }
29
+ });
24
30
  var _useField = require("./useField");
25
- var _useField2 = require("./useField.utils");
31
+ var _useField2 = require("./useField.utils");
32
+ var _useFieldInternalPropsWithDefaults = require("./useFieldInternalPropsWithDefaults");
@@ -27,7 +27,8 @@ const useField = params => {
27
27
  minutesStep,
28
28
  enableAccessibleFieldDOMStructure = true,
29
29
  disabled = false,
30
- readOnly = false
30
+ readOnly = false,
31
+ autoFocus = false
31
32
  },
32
33
  forwardedProps: {
33
34
  onKeyDown,
@@ -37,7 +38,8 @@ const useField = params => {
37
38
  },
38
39
  fieldValueManager,
39
40
  valueManager,
40
- validator
41
+ validator,
42
+ getOpenPickerButtonAriaLabel: getOpenDialogAriaText
41
43
  } = params;
42
44
  const isRtl = (0, _RtlProvider.useRtl)();
43
45
  const stateResponse = (0, _useFieldState.useFieldState)(params);
@@ -149,6 +151,11 @@ const useField = params => {
149
151
  if (readOnly || activeSectionIndex == null) {
150
152
  break;
151
153
  }
154
+
155
+ // if all sections are selected, mark the currently editing one as selected
156
+ if (parsedSelectedSections === 'all') {
157
+ setSelectedSections(activeSectionIndex);
158
+ }
152
159
  const activeSection = state.sections[activeSectionIndex];
153
160
  const activeDateManager = fieldValueManager.getActiveDateManager(utils, state, activeSection);
154
161
  const newSectionValue = (0, _useField.adjustSectionValue)(utils, timezone, activeSection, event.key, sectionsValueBoundaries, localizedDigits, activeDateManager.date, {
@@ -224,9 +231,15 @@ const useField = params => {
224
231
  error: inputError,
225
232
  clearable: Boolean(clearable && !areAllSectionsEmpty && !readOnly && !disabled)
226
233
  };
234
+ const localizationContext = (0, _useUtils.useLocalizationContext)();
235
+ const openPickerAriaLabel = React.useMemo(() => getOpenDialogAriaText((0, _extends2.default)({}, localizationContext, {
236
+ value: state.value
237
+ })), [getOpenDialogAriaText, state.value, localizationContext]);
227
238
  const commonAdditionalProps = {
228
239
  disabled,
229
- readOnly
240
+ readOnly,
241
+ autoFocus,
242
+ openPickerAriaLabel
230
243
  };
231
244
  return (0, _extends2.default)({}, params.forwardedProps, commonForwardedProps, commonAdditionalProps, returnedValue);
232
245
  };
@@ -383,7 +383,7 @@ const getSectionsBoundaries = (utils, localizedDigits, timezone) => {
383
383
  currentDate
384
384
  }) => ({
385
385
  minimum: 1,
386
- maximum: currentDate != null && utils.isValid(currentDate) ? utils.getDaysInMonth(currentDate) : maxDaysInMonth,
386
+ maximum: utils.isValid(currentDate) ? utils.getDaysInMonth(currentDate) : maxDaysInMonth,
387
387
  longestMonth: longestMonth
388
388
  }),
389
389
  weekDay: ({
@@ -534,7 +534,7 @@ const mergeDateIntoReferenceDate = (utils, dateToTransferFrom, sections, referen
534
534
  exports.mergeDateIntoReferenceDate = mergeDateIntoReferenceDate;
535
535
  const isAndroid = () => navigator.userAgent.toLowerCase().includes('android');
536
536
 
537
- // TODO v8: Remove if we drop the v6 TextField approach.
537
+ // TODO v9: Remove
538
538
  exports.isAndroid = isAndroid;
539
539
  const getSectionOrder = (sections, shouldApplyRTL) => {
540
540
  const neighbors = {};