@mui/x-date-pickers 5.0.0-alpha.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 (616) hide show
  1. package/AdapterDateFns/index.d.ts +1 -0
  2. package/AdapterDateFns/index.js +1 -0
  3. package/AdapterDateFns/package.json +6 -0
  4. package/AdapterDayjs/index.d.ts +1 -0
  5. package/AdapterDayjs/index.js +1 -0
  6. package/AdapterDayjs/package.json +6 -0
  7. package/AdapterLuxon/index.d.ts +1 -0
  8. package/AdapterLuxon/index.js +1 -0
  9. package/AdapterLuxon/package.json +6 -0
  10. package/AdapterMoment/index.d.ts +1 -0
  11. package/AdapterMoment/index.js +1 -0
  12. package/AdapterMoment/package.json +6 -0
  13. package/CHANGELOG.md +3785 -0
  14. package/CalendarPicker/CalendarPicker.d.ts +103 -0
  15. package/CalendarPicker/CalendarPicker.js +390 -0
  16. package/CalendarPicker/DayPicker.d.ts +51 -0
  17. package/CalendarPicker/DayPicker.js +140 -0
  18. package/CalendarPicker/PickersCalendarHeader.d.ts +44 -0
  19. package/CalendarPicker/PickersCalendarHeader.js +162 -0
  20. package/CalendarPicker/PickersFadeTransitionGroup.d.ts +12 -0
  21. package/CalendarPicker/PickersFadeTransitionGroup.js +42 -0
  22. package/CalendarPicker/PickersSlideTransition.d.ts +15 -0
  23. package/CalendarPicker/PickersSlideTransition.js +101 -0
  24. package/CalendarPicker/calendarPickerClasses.d.ts +9 -0
  25. package/CalendarPicker/calendarPickerClasses.js +3 -0
  26. package/CalendarPicker/index.d.ts +5 -0
  27. package/CalendarPicker/index.js +2 -0
  28. package/CalendarPicker/package.json +6 -0
  29. package/CalendarPicker/useCalendarState.d.ts +33 -0
  30. package/CalendarPicker/useCalendarState.js +110 -0
  31. package/CalendarPickerSkeleton/CalendarPickerSkeleton.d.ts +31 -0
  32. package/CalendarPickerSkeleton/CalendarPickerSkeleton.js +119 -0
  33. package/CalendarPickerSkeleton/calendarPickerSkeletonClasses.d.ts +11 -0
  34. package/CalendarPickerSkeleton/calendarPickerSkeletonClasses.js +3 -0
  35. package/CalendarPickerSkeleton/index.d.ts +4 -0
  36. package/CalendarPickerSkeleton/index.js +2 -0
  37. package/CalendarPickerSkeleton/package.json +6 -0
  38. package/ClockPicker/Clock.d.ts +26 -0
  39. package/ClockPicker/Clock.js +262 -0
  40. package/ClockPicker/ClockNumber.d.ts +18 -0
  41. package/ClockPicker/ClockNumber.js +70 -0
  42. package/ClockPicker/ClockNumbers.d.ts +24 -0
  43. package/ClockPicker/ClockNumbers.js +80 -0
  44. package/ClockPicker/ClockPicker.d.ts +138 -0
  45. package/ClockPicker/ClockPicker.js +407 -0
  46. package/ClockPicker/ClockPointer.d.ts +23 -0
  47. package/ClockPicker/ClockPointer.js +102 -0
  48. package/ClockPicker/clockPickerClasses.d.ts +9 -0
  49. package/ClockPicker/clockPickerClasses.js +5 -0
  50. package/ClockPicker/index.d.ts +5 -0
  51. package/ClockPicker/index.js +2 -0
  52. package/ClockPicker/package.json +6 -0
  53. package/ClockPicker/shared.d.ts +4 -0
  54. package/ClockPicker/shared.js +57 -0
  55. package/DatePicker/DatePicker.d.ts +27 -0
  56. package/DatePicker/DatePicker.js +456 -0
  57. package/DatePicker/DatePickerToolbar.d.ts +10 -0
  58. package/DatePicker/DatePickerToolbar.js +81 -0
  59. package/DatePicker/index.d.ts +2 -0
  60. package/DatePicker/index.js +1 -0
  61. package/DatePicker/package.json +6 -0
  62. package/DatePicker/shared.d.ts +47 -0
  63. package/DatePicker/shared.js +54 -0
  64. package/DateTimePicker/DateTimePicker.d.ts +27 -0
  65. package/DateTimePicker/DateTimePicker.js +542 -0
  66. package/DateTimePicker/DateTimePickerTabs.d.ts +12 -0
  67. package/DateTimePicker/DateTimePickerTabs.js +80 -0
  68. package/DateTimePicker/DateTimePickerToolbar.d.ts +6 -0
  69. package/DateTimePicker/DateTimePickerToolbar.js +134 -0
  70. package/DateTimePicker/index.d.ts +2 -0
  71. package/DateTimePicker/index.js +1 -0
  72. package/DateTimePicker/package.json +6 -0
  73. package/DateTimePicker/shared.d.ts +70 -0
  74. package/DateTimePicker/shared.js +58 -0
  75. package/DesktopDatePicker/DesktopDatePicker.d.ts +20 -0
  76. package/DesktopDatePicker/DesktopDatePicker.js +431 -0
  77. package/DesktopDatePicker/index.d.ts +2 -0
  78. package/DesktopDatePicker/index.js +1 -0
  79. package/DesktopDatePicker/package.json +6 -0
  80. package/DesktopDateTimePicker/DesktopDateTimePicker.d.ts +20 -0
  81. package/DesktopDateTimePicker/DesktopDateTimePicker.js +512 -0
  82. package/DesktopDateTimePicker/index.d.ts +2 -0
  83. package/DesktopDateTimePicker/index.js +1 -0
  84. package/DesktopDateTimePicker/package.json +6 -0
  85. package/DesktopTimePicker/DesktopTimePicker.d.ts +20 -0
  86. package/DesktopTimePicker/DesktopTimePicker.js +361 -0
  87. package/DesktopTimePicker/index.d.ts +2 -0
  88. package/DesktopTimePicker/index.js +1 -0
  89. package/DesktopTimePicker/package.json +6 -0
  90. package/LocalizationProvider/LocalizationProvider.d.ts +34 -0
  91. package/LocalizationProvider/LocalizationProvider.js +100 -0
  92. package/LocalizationProvider/index.d.ts +2 -0
  93. package/LocalizationProvider/index.js +1 -0
  94. package/LocalizationProvider/package.json +6 -0
  95. package/MobileDatePicker/MobileDatePicker.d.ts +20 -0
  96. package/MobileDatePicker/MobileDatePicker.js +436 -0
  97. package/MobileDatePicker/index.d.ts +2 -0
  98. package/MobileDatePicker/index.js +1 -0
  99. package/MobileDatePicker/package.json +6 -0
  100. package/MobileDateTimePicker/MobileDateTimePicker.d.ts +20 -0
  101. package/MobileDateTimePicker/MobileDateTimePicker.js +523 -0
  102. package/MobileDateTimePicker/index.d.ts +2 -0
  103. package/MobileDateTimePicker/index.js +1 -0
  104. package/MobileDateTimePicker/package.json +6 -0
  105. package/MobileTimePicker/MobileTimePicker.d.ts +20 -0
  106. package/MobileTimePicker/MobileTimePicker.js +372 -0
  107. package/MobileTimePicker/index.d.ts +2 -0
  108. package/MobileTimePicker/index.js +1 -0
  109. package/MobileTimePicker/package.json +6 -0
  110. package/MonthPicker/MonthPicker.d.ts +41 -0
  111. package/MonthPicker/MonthPicker.js +161 -0
  112. package/MonthPicker/PickersMonth.d.ts +15 -0
  113. package/MonthPicker/PickersMonth.js +70 -0
  114. package/MonthPicker/index.d.ts +4 -0
  115. package/MonthPicker/index.js +2 -0
  116. package/MonthPicker/monthPickerClasses.d.ts +7 -0
  117. package/MonthPicker/monthPickerClasses.js +5 -0
  118. package/MonthPicker/package.json +6 -0
  119. package/PickersDay/PickersDay.d.ts +79 -0
  120. package/PickersDay/PickersDay.js +344 -0
  121. package/PickersDay/index.d.ts +4 -0
  122. package/PickersDay/index.js +2 -0
  123. package/PickersDay/package.json +6 -0
  124. package/PickersDay/pickersDayClasses.d.ts +19 -0
  125. package/PickersDay/pickersDayClasses.js +5 -0
  126. package/README.md +29 -0
  127. package/StaticDatePicker/StaticDatePicker.d.ts +25 -0
  128. package/StaticDatePicker/StaticDatePicker.js +397 -0
  129. package/StaticDatePicker/index.d.ts +2 -0
  130. package/StaticDatePicker/index.js +1 -0
  131. package/StaticDatePicker/package.json +6 -0
  132. package/StaticDateTimePicker/StaticDateTimePicker.d.ts +25 -0
  133. package/StaticDateTimePicker/StaticDateTimePicker.js +484 -0
  134. package/StaticDateTimePicker/index.d.ts +2 -0
  135. package/StaticDateTimePicker/index.js +1 -0
  136. package/StaticDateTimePicker/package.json +6 -0
  137. package/StaticTimePicker/StaticTimePicker.d.ts +25 -0
  138. package/StaticTimePicker/StaticTimePicker.js +332 -0
  139. package/StaticTimePicker/index.d.ts +2 -0
  140. package/StaticTimePicker/index.js +1 -0
  141. package/StaticTimePicker/package.json +6 -0
  142. package/TimePicker/TimePicker.d.ts +27 -0
  143. package/TimePicker/TimePicker.js +395 -0
  144. package/TimePicker/TimePickerToolbar.d.ts +10 -0
  145. package/TimePicker/TimePickerToolbar.js +167 -0
  146. package/TimePicker/index.d.ts +2 -0
  147. package/TimePicker/index.js +1 -0
  148. package/TimePicker/package.json +6 -0
  149. package/TimePicker/shared.d.ts +39 -0
  150. package/TimePicker/shared.js +45 -0
  151. package/TimePicker/timePickerToolbarClasses.d.ts +13 -0
  152. package/TimePicker/timePickerToolbarClasses.js +5 -0
  153. package/YearPicker/PickersYear.d.ts +26 -0
  154. package/YearPicker/PickersYear.js +111 -0
  155. package/YearPicker/YearPicker.d.ts +37 -0
  156. package/YearPicker/YearPicker.js +188 -0
  157. package/YearPicker/index.d.ts +4 -0
  158. package/YearPicker/index.js +2 -0
  159. package/YearPicker/package.json +6 -0
  160. package/YearPicker/yearPickerClasses.d.ts +7 -0
  161. package/YearPicker/yearPickerClasses.js +5 -0
  162. package/index.d.ts +19 -0
  163. package/index.js +24 -0
  164. package/internals/components/CalendarOrClockPicker/CalendarOrClockPicker.d.ts +35 -0
  165. package/internals/components/CalendarOrClockPicker/CalendarOrClockPicker.js +125 -0
  166. package/internals/components/CalendarOrClockPicker/index.d.ts +1 -0
  167. package/internals/components/CalendarOrClockPicker/index.js +1 -0
  168. package/internals/components/KeyboardDateInput.d.ts +3 -0
  169. package/internals/components/KeyboardDateInput.js +58 -0
  170. package/internals/components/PickerStaticWrapper/PickerStaticWrapper.d.ts +14 -0
  171. package/internals/components/PickerStaticWrapper/PickerStaticWrapper.js +57 -0
  172. package/internals/components/PickerStaticWrapper/index.d.ts +4 -0
  173. package/internals/components/PickerStaticWrapper/index.js +2 -0
  174. package/internals/components/PickerStaticWrapper/pickerStaticWrapperClasses.d.ts +7 -0
  175. package/internals/components/PickerStaticWrapper/pickerStaticWrapperClasses.js +5 -0
  176. package/internals/components/PickerViewRoot/PickerViewRoot.d.ts +2 -0
  177. package/internals/components/PickerViewRoot/PickerViewRoot.js +10 -0
  178. package/internals/components/PickerViewRoot/index.d.ts +1 -0
  179. package/internals/components/PickerViewRoot/index.js +1 -0
  180. package/internals/components/PickersArrowSwitcher.d.ts +41 -0
  181. package/internals/components/PickersArrowSwitcher.js +89 -0
  182. package/internals/components/PickersModalDialog.d.ts +46 -0
  183. package/internals/components/PickersModalDialog.js +75 -0
  184. package/internals/components/PickersPopper.d.ts +43 -0
  185. package/internals/components/PickersPopper.js +262 -0
  186. package/internals/components/PickersToolbar.d.ts +15 -0
  187. package/internals/components/PickersToolbar.js +82 -0
  188. package/internals/components/PickersToolbarButton.d.ts +12 -0
  189. package/internals/components/PickersToolbarButton.js +38 -0
  190. package/internals/components/PickersToolbarText.d.ts +7 -0
  191. package/internals/components/PickersToolbarText.js +35 -0
  192. package/internals/components/PureDateInput.d.ts +87 -0
  193. package/internals/components/PureDateInput.js +50 -0
  194. package/internals/components/icons/index.d.ts +48 -0
  195. package/internals/components/icons/index.js +68 -0
  196. package/internals/components/wrappers/DesktopTooltipWrapper.d.ts +3 -0
  197. package/internals/components/wrappers/DesktopTooltipWrapper.js +52 -0
  198. package/internals/components/wrappers/DesktopWrapper.d.ts +15 -0
  199. package/internals/components/wrappers/DesktopWrapper.js +42 -0
  200. package/internals/components/wrappers/MobileWrapper.d.ts +13 -0
  201. package/internals/components/wrappers/MobileWrapper.js +47 -0
  202. package/internals/components/wrappers/ResponsiveWrapper.d.ts +23 -0
  203. package/internals/components/wrappers/ResponsiveWrapper.js +44 -0
  204. package/internals/components/wrappers/WrapperProps.d.ts +13 -0
  205. package/internals/components/wrappers/WrapperProps.js +1 -0
  206. package/internals/components/wrappers/WrapperVariantContext.d.ts +11 -0
  207. package/internals/components/wrappers/WrapperVariantContext.js +12 -0
  208. package/internals/constants/dimensions.d.ts +4 -0
  209. package/internals/constants/dimensions.js +4 -0
  210. package/internals/hooks/date-helpers-hooks.d.ts +16 -0
  211. package/internals/hooks/date-helpers-hooks.js +37 -0
  212. package/internals/hooks/useIsLandscape.d.ts +4 -0
  213. package/internals/hooks/useIsLandscape.js +42 -0
  214. package/internals/hooks/useMaskedInput.d.ts +7 -0
  215. package/internals/hooks/useMaskedInput.js +92 -0
  216. package/internals/hooks/useOpenState.d.ts +9 -0
  217. package/internals/hooks/useOpenState.js +37 -0
  218. package/internals/hooks/usePickerState.d.ts +39 -0
  219. package/internals/hooks/usePickerState.js +117 -0
  220. package/internals/hooks/useUtils.d.ts +6 -0
  221. package/internals/hooks/useUtils.js +20 -0
  222. package/internals/hooks/useViews.d.ts +19 -0
  223. package/internals/hooks/useViews.js +50 -0
  224. package/internals/hooks/validation/useDateTimeValidation.d.ts +8 -0
  225. package/internals/hooks/validation/useDateTimeValidation.js +35 -0
  226. package/internals/hooks/validation/useDateValidation.d.ts +34 -0
  227. package/internals/hooks/validation/useDateValidation.js +42 -0
  228. package/internals/hooks/validation/useTimeValidation.d.ts +32 -0
  229. package/internals/hooks/validation/useTimeValidation.js +42 -0
  230. package/internals/hooks/validation/useValidation.d.ts +21 -0
  231. package/internals/hooks/validation/useValidation.js +19 -0
  232. package/internals/index.d.ts +40 -0
  233. package/internals/index.js +22 -0
  234. package/internals/models/helpers.d.ts +9 -0
  235. package/internals/models/helpers.js +1 -0
  236. package/internals/models/index.d.ts +2 -0
  237. package/internals/models/index.js +2 -0
  238. package/internals/models/muiPickersAdapter.d.ts +2 -0
  239. package/internals/models/muiPickersAdapter.js +1 -0
  240. package/internals/models/parseableDate.d.ts +1 -0
  241. package/internals/models/parseableDate.js +1 -0
  242. package/internals/models/props/basePickerProps.d.ts +79 -0
  243. package/internals/models/props/basePickerProps.js +1 -0
  244. package/internals/models/props/baseToolbarProps.d.ts +23 -0
  245. package/internals/models/props/baseToolbarProps.js +1 -0
  246. package/internals/models/views.d.ts +3 -0
  247. package/internals/models/views.js +1 -0
  248. package/internals/package.json +6 -0
  249. package/internals/utils/date-utils.d.ts +13 -0
  250. package/internals/utils/date-utils.js +67 -0
  251. package/internals/utils/defaultReduceAnimations.d.ts +1 -0
  252. package/internals/utils/defaultReduceAnimations.js +1 -0
  253. package/internals/utils/text-field-helper.d.ts +11 -0
  254. package/internals/utils/text-field-helper.js +66 -0
  255. package/internals/utils/time-utils.d.ts +8 -0
  256. package/internals/utils/time-utils.js +32 -0
  257. package/internals/utils/utils.d.ts +7 -0
  258. package/internals/utils/utils.js +36 -0
  259. package/legacy/AdapterDateFns/index.js +1 -0
  260. package/legacy/AdapterDayjs/index.js +1 -0
  261. package/legacy/AdapterLuxon/index.js +1 -0
  262. package/legacy/AdapterMoment/index.js +1 -0
  263. package/legacy/CalendarPicker/CalendarPicker.js +402 -0
  264. package/legacy/CalendarPicker/DayPicker.js +154 -0
  265. package/legacy/CalendarPicker/PickersCalendarHeader.js +173 -0
  266. package/legacy/CalendarPicker/PickersFadeTransitionGroup.js +42 -0
  267. package/legacy/CalendarPicker/PickersSlideTransition.js +97 -0
  268. package/legacy/CalendarPicker/calendarPickerClasses.js +5 -0
  269. package/legacy/CalendarPicker/index.js +2 -0
  270. package/legacy/CalendarPicker/useCalendarState.js +120 -0
  271. package/legacy/CalendarPickerSkeleton/CalendarPickerSkeleton.js +126 -0
  272. package/legacy/CalendarPickerSkeleton/calendarPickerSkeletonClasses.js +5 -0
  273. package/legacy/CalendarPickerSkeleton/index.js +2 -0
  274. package/legacy/ClockPicker/Clock.js +268 -0
  275. package/legacy/ClockPicker/ClockNumber.js +70 -0
  276. package/legacy/ClockPicker/ClockNumbers.js +83 -0
  277. package/legacy/ClockPicker/ClockPicker.js +454 -0
  278. package/legacy/ClockPicker/ClockPointer.js +130 -0
  279. package/legacy/ClockPicker/clockPickerClasses.js +5 -0
  280. package/legacy/ClockPicker/index.js +2 -0
  281. package/legacy/ClockPicker/shared.js +61 -0
  282. package/legacy/DatePicker/DatePicker.js +455 -0
  283. package/legacy/DatePicker/DatePickerToolbar.js +82 -0
  284. package/legacy/DatePicker/index.js +1 -0
  285. package/legacy/DatePicker/shared.js +58 -0
  286. package/legacy/DateTimePicker/DateTimePicker.js +541 -0
  287. package/legacy/DateTimePicker/DateTimePickerTabs.js +81 -0
  288. package/legacy/DateTimePicker/DateTimePickerToolbar.js +147 -0
  289. package/legacy/DateTimePicker/index.js +1 -0
  290. package/legacy/DateTimePicker/shared.js +59 -0
  291. package/legacy/DesktopDatePicker/DesktopDatePicker.js +434 -0
  292. package/legacy/DesktopDatePicker/index.js +1 -0
  293. package/legacy/DesktopDateTimePicker/DesktopDateTimePicker.js +515 -0
  294. package/legacy/DesktopDateTimePicker/index.js +1 -0
  295. package/legacy/DesktopTimePicker/DesktopTimePicker.js +364 -0
  296. package/legacy/DesktopTimePicker/index.js +1 -0
  297. package/legacy/LocalizationProvider/LocalizationProvider.js +100 -0
  298. package/legacy/LocalizationProvider/index.js +1 -0
  299. package/legacy/MobileDatePicker/MobileDatePicker.js +440 -0
  300. package/legacy/MobileDatePicker/index.js +1 -0
  301. package/legacy/MobileDateTimePicker/MobileDateTimePicker.js +527 -0
  302. package/legacy/MobileDateTimePicker/index.js +1 -0
  303. package/legacy/MobileTimePicker/MobileTimePicker.js +376 -0
  304. package/legacy/MobileTimePicker/index.js +1 -0
  305. package/legacy/MonthPicker/MonthPicker.js +159 -0
  306. package/legacy/MonthPicker/PickersMonth.js +69 -0
  307. package/legacy/MonthPicker/index.js +2 -0
  308. package/legacy/MonthPicker/monthPickerClasses.js +5 -0
  309. package/legacy/PickersDay/PickersDay.js +348 -0
  310. package/legacy/PickersDay/index.js +2 -0
  311. package/legacy/PickersDay/pickersDayClasses.js +5 -0
  312. package/legacy/StaticDatePicker/StaticDatePicker.js +402 -0
  313. package/legacy/StaticDatePicker/index.js +1 -0
  314. package/legacy/StaticDateTimePicker/StaticDateTimePicker.js +489 -0
  315. package/legacy/StaticDateTimePicker/index.js +1 -0
  316. package/legacy/StaticTimePicker/StaticTimePicker.js +336 -0
  317. package/legacy/StaticTimePicker/index.js +1 -0
  318. package/legacy/TimePicker/TimePicker.js +394 -0
  319. package/legacy/TimePicker/TimePickerToolbar.js +175 -0
  320. package/legacy/TimePicker/index.js +1 -0
  321. package/legacy/TimePicker/shared.js +45 -0
  322. package/legacy/TimePicker/timePickerToolbarClasses.js +5 -0
  323. package/legacy/YearPicker/PickersYear.js +114 -0
  324. package/legacy/YearPicker/YearPicker.js +193 -0
  325. package/legacy/YearPicker/index.js +2 -0
  326. package/legacy/YearPicker/yearPickerClasses.js +5 -0
  327. package/legacy/index.js +24 -0
  328. package/legacy/internals/components/CalendarOrClockPicker/CalendarOrClockPicker.js +133 -0
  329. package/legacy/internals/components/CalendarOrClockPicker/index.js +1 -0
  330. package/legacy/internals/components/KeyboardDateInput.js +57 -0
  331. package/legacy/internals/components/PickerStaticWrapper/PickerStaticWrapper.js +56 -0
  332. package/legacy/internals/components/PickerStaticWrapper/index.js +2 -0
  333. package/legacy/internals/components/PickerStaticWrapper/pickerStaticWrapperClasses.js +5 -0
  334. package/legacy/internals/components/PickerViewRoot/PickerViewRoot.js +10 -0
  335. package/legacy/internals/components/PickerViewRoot/index.js +1 -0
  336. package/legacy/internals/components/PickersArrowSwitcher.js +91 -0
  337. package/legacy/internals/components/PickersModalDialog.js +82 -0
  338. package/legacy/internals/components/PickersPopper.js +276 -0
  339. package/legacy/internals/components/PickersToolbar.js +86 -0
  340. package/legacy/internals/components/PickersToolbarButton.js +36 -0
  341. package/legacy/internals/components/PickersToolbarText.js +34 -0
  342. package/legacy/internals/components/PureDateInput.js +52 -0
  343. package/legacy/internals/components/icons/index.js +68 -0
  344. package/legacy/internals/components/wrappers/DesktopTooltipWrapper.js +50 -0
  345. package/legacy/internals/components/wrappers/DesktopWrapper.js +40 -0
  346. package/legacy/internals/components/wrappers/MobileWrapper.js +45 -0
  347. package/legacy/internals/components/wrappers/ResponsiveWrapper.js +43 -0
  348. package/legacy/internals/components/wrappers/WrapperProps.js +1 -0
  349. package/legacy/internals/components/wrappers/WrapperVariantContext.js +12 -0
  350. package/legacy/internals/constants/dimensions.js +4 -0
  351. package/legacy/internals/hooks/date-helpers-hooks.js +35 -0
  352. package/legacy/internals/hooks/useIsLandscape.js +47 -0
  353. package/legacy/internals/hooks/useMaskedInput.js +107 -0
  354. package/legacy/internals/hooks/useOpenState.js +42 -0
  355. package/legacy/internals/hooks/usePickerState.js +147 -0
  356. package/legacy/internals/hooks/useUtils.js +24 -0
  357. package/legacy/internals/hooks/useViews.js +55 -0
  358. package/legacy/internals/hooks/validation/useDateTimeValidation.js +35 -0
  359. package/legacy/internals/hooks/validation/useDateValidation.js +45 -0
  360. package/legacy/internals/hooks/validation/useTimeValidation.js +45 -0
  361. package/legacy/internals/hooks/validation/useValidation.js +17 -0
  362. package/legacy/internals/index.js +22 -0
  363. package/legacy/internals/models/helpers.js +1 -0
  364. package/legacy/internals/models/index.js +2 -0
  365. package/legacy/internals/models/muiPickersAdapter.js +1 -0
  366. package/legacy/internals/models/parseableDate.js +1 -0
  367. package/legacy/internals/models/props/basePickerProps.js +1 -0
  368. package/legacy/internals/models/props/baseToolbarProps.js +1 -0
  369. package/legacy/internals/models/views.js +1 -0
  370. package/legacy/internals/utils/date-utils.js +66 -0
  371. package/legacy/internals/utils/defaultReduceAnimations.js +1 -0
  372. package/legacy/internals/utils/text-field-helper.js +68 -0
  373. package/legacy/internals/utils/time-utils.js +34 -0
  374. package/legacy/internals/utils/utils.js +52 -0
  375. package/legacy/themeAugmentation/index.js +3 -0
  376. package/modern/AdapterDateFns/index.js +1 -0
  377. package/modern/AdapterDayjs/index.js +1 -0
  378. package/modern/AdapterLuxon/index.js +1 -0
  379. package/modern/AdapterMoment/index.js +1 -0
  380. package/modern/CalendarPicker/CalendarPicker.js +390 -0
  381. package/modern/CalendarPicker/DayPicker.js +140 -0
  382. package/modern/CalendarPicker/PickersCalendarHeader.js +162 -0
  383. package/modern/CalendarPicker/PickersFadeTransitionGroup.js +42 -0
  384. package/modern/CalendarPicker/PickersSlideTransition.js +101 -0
  385. package/modern/CalendarPicker/calendarPickerClasses.js +3 -0
  386. package/modern/CalendarPicker/index.js +2 -0
  387. package/modern/CalendarPicker/useCalendarState.js +108 -0
  388. package/modern/CalendarPickerSkeleton/CalendarPickerSkeleton.js +119 -0
  389. package/modern/CalendarPickerSkeleton/calendarPickerSkeletonClasses.js +3 -0
  390. package/modern/CalendarPickerSkeleton/index.js +2 -0
  391. package/modern/ClockPicker/Clock.js +262 -0
  392. package/modern/ClockPicker/ClockNumber.js +70 -0
  393. package/modern/ClockPicker/ClockNumbers.js +80 -0
  394. package/modern/ClockPicker/ClockPicker.js +407 -0
  395. package/modern/ClockPicker/ClockPointer.js +102 -0
  396. package/modern/ClockPicker/clockPickerClasses.js +5 -0
  397. package/modern/ClockPicker/index.js +2 -0
  398. package/modern/ClockPicker/shared.js +57 -0
  399. package/modern/DatePicker/DatePicker.js +456 -0
  400. package/modern/DatePicker/DatePickerToolbar.js +81 -0
  401. package/modern/DatePicker/index.js +1 -0
  402. package/modern/DatePicker/shared.js +54 -0
  403. package/modern/DateTimePicker/DateTimePicker.js +542 -0
  404. package/modern/DateTimePicker/DateTimePickerTabs.js +80 -0
  405. package/modern/DateTimePicker/DateTimePickerToolbar.js +134 -0
  406. package/modern/DateTimePicker/index.js +1 -0
  407. package/modern/DateTimePicker/shared.js +58 -0
  408. package/modern/DesktopDatePicker/DesktopDatePicker.js +431 -0
  409. package/modern/DesktopDatePicker/index.js +1 -0
  410. package/modern/DesktopDateTimePicker/DesktopDateTimePicker.js +512 -0
  411. package/modern/DesktopDateTimePicker/index.js +1 -0
  412. package/modern/DesktopTimePicker/DesktopTimePicker.js +361 -0
  413. package/modern/DesktopTimePicker/index.js +1 -0
  414. package/modern/LocalizationProvider/LocalizationProvider.js +100 -0
  415. package/modern/LocalizationProvider/index.js +1 -0
  416. package/modern/MobileDatePicker/MobileDatePicker.js +436 -0
  417. package/modern/MobileDatePicker/index.js +1 -0
  418. package/modern/MobileDateTimePicker/MobileDateTimePicker.js +523 -0
  419. package/modern/MobileDateTimePicker/index.js +1 -0
  420. package/modern/MobileTimePicker/MobileTimePicker.js +372 -0
  421. package/modern/MobileTimePicker/index.js +1 -0
  422. package/modern/MonthPicker/MonthPicker.js +161 -0
  423. package/modern/MonthPicker/PickersMonth.js +70 -0
  424. package/modern/MonthPicker/index.js +2 -0
  425. package/modern/MonthPicker/monthPickerClasses.js +5 -0
  426. package/modern/PickersDay/PickersDay.js +344 -0
  427. package/modern/PickersDay/index.js +2 -0
  428. package/modern/PickersDay/pickersDayClasses.js +5 -0
  429. package/modern/StaticDatePicker/StaticDatePicker.js +397 -0
  430. package/modern/StaticDatePicker/index.js +1 -0
  431. package/modern/StaticDateTimePicker/StaticDateTimePicker.js +484 -0
  432. package/modern/StaticDateTimePicker/index.js +1 -0
  433. package/modern/StaticTimePicker/StaticTimePicker.js +332 -0
  434. package/modern/StaticTimePicker/index.js +1 -0
  435. package/modern/TimePicker/TimePicker.js +395 -0
  436. package/modern/TimePicker/TimePickerToolbar.js +167 -0
  437. package/modern/TimePicker/index.js +1 -0
  438. package/modern/TimePicker/shared.js +45 -0
  439. package/modern/TimePicker/timePickerToolbarClasses.js +5 -0
  440. package/modern/YearPicker/PickersYear.js +111 -0
  441. package/modern/YearPicker/YearPicker.js +188 -0
  442. package/modern/YearPicker/index.js +2 -0
  443. package/modern/YearPicker/yearPickerClasses.js +5 -0
  444. package/modern/index.js +24 -0
  445. package/modern/internals/components/CalendarOrClockPicker/CalendarOrClockPicker.js +125 -0
  446. package/modern/internals/components/CalendarOrClockPicker/index.js +1 -0
  447. package/modern/internals/components/KeyboardDateInput.js +58 -0
  448. package/modern/internals/components/PickerStaticWrapper/PickerStaticWrapper.js +57 -0
  449. package/modern/internals/components/PickerStaticWrapper/index.js +2 -0
  450. package/modern/internals/components/PickerStaticWrapper/pickerStaticWrapperClasses.js +5 -0
  451. package/modern/internals/components/PickerViewRoot/PickerViewRoot.js +10 -0
  452. package/modern/internals/components/PickerViewRoot/index.js +1 -0
  453. package/modern/internals/components/PickersArrowSwitcher.js +89 -0
  454. package/modern/internals/components/PickersModalDialog.js +75 -0
  455. package/modern/internals/components/PickersPopper.js +262 -0
  456. package/modern/internals/components/PickersToolbar.js +82 -0
  457. package/modern/internals/components/PickersToolbarButton.js +38 -0
  458. package/modern/internals/components/PickersToolbarText.js +35 -0
  459. package/modern/internals/components/PureDateInput.js +50 -0
  460. package/modern/internals/components/icons/index.js +68 -0
  461. package/modern/internals/components/wrappers/DesktopTooltipWrapper.js +50 -0
  462. package/modern/internals/components/wrappers/DesktopWrapper.js +42 -0
  463. package/modern/internals/components/wrappers/MobileWrapper.js +47 -0
  464. package/modern/internals/components/wrappers/ResponsiveWrapper.js +44 -0
  465. package/modern/internals/components/wrappers/WrapperProps.js +1 -0
  466. package/modern/internals/components/wrappers/WrapperVariantContext.js +12 -0
  467. package/modern/internals/constants/dimensions.js +4 -0
  468. package/modern/internals/hooks/date-helpers-hooks.js +37 -0
  469. package/modern/internals/hooks/useIsLandscape.js +42 -0
  470. package/modern/internals/hooks/useMaskedInput.js +92 -0
  471. package/modern/internals/hooks/useOpenState.js +37 -0
  472. package/modern/internals/hooks/usePickerState.js +117 -0
  473. package/modern/internals/hooks/useUtils.js +20 -0
  474. package/modern/internals/hooks/useViews.js +48 -0
  475. package/modern/internals/hooks/validation/useDateTimeValidation.js +35 -0
  476. package/modern/internals/hooks/validation/useDateValidation.js +42 -0
  477. package/modern/internals/hooks/validation/useTimeValidation.js +42 -0
  478. package/modern/internals/hooks/validation/useValidation.js +19 -0
  479. package/modern/internals/index.js +22 -0
  480. package/modern/internals/models/helpers.js +1 -0
  481. package/modern/internals/models/index.js +2 -0
  482. package/modern/internals/models/muiPickersAdapter.js +1 -0
  483. package/modern/internals/models/parseableDate.js +1 -0
  484. package/modern/internals/models/props/basePickerProps.js +1 -0
  485. package/modern/internals/models/props/baseToolbarProps.js +1 -0
  486. package/modern/internals/models/views.js +1 -0
  487. package/modern/internals/utils/date-utils.js +67 -0
  488. package/modern/internals/utils/defaultReduceAnimations.js +1 -0
  489. package/modern/internals/utils/text-field-helper.js +66 -0
  490. package/modern/internals/utils/time-utils.js +32 -0
  491. package/modern/internals/utils/utils.js +36 -0
  492. package/modern/themeAugmentation/index.js +3 -0
  493. package/node/AdapterDateFns/index.js +15 -0
  494. package/node/AdapterDayjs/index.js +15 -0
  495. package/node/AdapterLuxon/index.js +15 -0
  496. package/node/AdapterMoment/index.js +15 -0
  497. package/node/CalendarPicker/CalendarPicker.js +420 -0
  498. package/node/CalendarPicker/DayPicker.js +161 -0
  499. package/node/CalendarPicker/PickersCalendarHeader.js +185 -0
  500. package/node/CalendarPicker/PickersFadeTransitionGroup.js +64 -0
  501. package/node/CalendarPicker/PickersSlideTransition.js +126 -0
  502. package/node/CalendarPicker/calendarPickerClasses.js +14 -0
  503. package/node/CalendarPicker/index.js +27 -0
  504. package/node/CalendarPicker/useCalendarState.js +132 -0
  505. package/node/CalendarPickerSkeleton/CalendarPickerSkeleton.js +142 -0
  506. package/node/CalendarPickerSkeleton/calendarPickerSkeletonClasses.js +14 -0
  507. package/node/CalendarPickerSkeleton/index.js +27 -0
  508. package/node/ClockPicker/Clock.js +285 -0
  509. package/node/ClockPicker/ClockNumber.js +93 -0
  510. package/node/ClockPicker/ClockNumbers.js +98 -0
  511. package/node/ClockPicker/ClockPicker.js +437 -0
  512. package/node/ClockPicker/ClockPointer.js +123 -0
  513. package/node/ClockPicker/clockPickerClasses.js +16 -0
  514. package/node/ClockPicker/index.js +27 -0
  515. package/node/ClockPicker/shared.js +70 -0
  516. package/node/DatePicker/DatePicker.js +477 -0
  517. package/node/DatePicker/DatePickerToolbar.js +105 -0
  518. package/node/DatePicker/index.js +13 -0
  519. package/node/DatePicker/shared.js +73 -0
  520. package/node/DateTimePicker/DateTimePicker.js +562 -0
  521. package/node/DateTimePicker/DateTimePickerTabs.js +100 -0
  522. package/node/DateTimePicker/DateTimePickerToolbar.js +160 -0
  523. package/node/DateTimePicker/index.js +13 -0
  524. package/node/DateTimePicker/shared.js +72 -0
  525. package/node/DesktopDatePicker/DesktopDatePicker.js +456 -0
  526. package/node/DesktopDatePicker/index.js +13 -0
  527. package/node/DesktopDateTimePicker/DesktopDateTimePicker.js +537 -0
  528. package/node/DesktopDateTimePicker/index.js +13 -0
  529. package/node/DesktopTimePicker/DesktopTimePicker.js +386 -0
  530. package/node/DesktopTimePicker/index.js +13 -0
  531. package/node/LocalizationProvider/LocalizationProvider.js +119 -0
  532. package/node/LocalizationProvider/index.js +13 -0
  533. package/node/MobileDatePicker/MobileDatePicker.js +462 -0
  534. package/node/MobileDatePicker/index.js +13 -0
  535. package/node/MobileDateTimePicker/MobileDateTimePicker.js +549 -0
  536. package/node/MobileDateTimePicker/index.js +13 -0
  537. package/node/MobileTimePicker/MobileTimePicker.js +398 -0
  538. package/node/MobileTimePicker/index.js +13 -0
  539. package/node/MonthPicker/MonthPicker.js +184 -0
  540. package/node/MonthPicker/PickersMonth.js +95 -0
  541. package/node/MonthPicker/index.js +27 -0
  542. package/node/MonthPicker/monthPickerClasses.js +16 -0
  543. package/node/PickersDay/PickersDay.js +372 -0
  544. package/node/PickersDay/index.js +27 -0
  545. package/node/PickersDay/pickersDayClasses.js +16 -0
  546. package/node/StaticDatePicker/StaticDatePicker.js +422 -0
  547. package/node/StaticDatePicker/index.js +13 -0
  548. package/node/StaticDateTimePicker/StaticDateTimePicker.js +509 -0
  549. package/node/StaticDateTimePicker/index.js +13 -0
  550. package/node/StaticTimePicker/StaticTimePicker.js +356 -0
  551. package/node/StaticTimePicker/index.js +13 -0
  552. package/node/TimePicker/TimePicker.js +416 -0
  553. package/node/TimePicker/TimePickerToolbar.js +192 -0
  554. package/node/TimePicker/index.js +13 -0
  555. package/node/TimePicker/shared.js +59 -0
  556. package/node/TimePicker/timePickerToolbarClasses.js +16 -0
  557. package/node/YearPicker/PickersYear.js +135 -0
  558. package/node/YearPicker/YearPicker.js +212 -0
  559. package/node/YearPicker/index.js +27 -0
  560. package/node/YearPicker/yearPickerClasses.js +16 -0
  561. package/node/index.js +257 -0
  562. package/node/internals/components/CalendarOrClockPicker/CalendarOrClockPicker.js +151 -0
  563. package/node/internals/components/CalendarOrClockPicker/index.js +13 -0
  564. package/node/internals/components/KeyboardDateInput.js +83 -0
  565. package/node/internals/components/PickerStaticWrapper/PickerStaticWrapper.js +78 -0
  566. package/node/internals/components/PickerStaticWrapper/index.js +27 -0
  567. package/node/internals/components/PickerStaticWrapper/pickerStaticWrapperClasses.js +16 -0
  568. package/node/internals/components/PickerViewRoot/PickerViewRoot.js +20 -0
  569. package/node/internals/components/PickerViewRoot/index.js +13 -0
  570. package/node/internals/components/PickersArrowSwitcher.js +110 -0
  571. package/node/internals/components/PickersModalDialog.js +99 -0
  572. package/node/internals/components/PickersPopper.js +287 -0
  573. package/node/internals/components/PickersToolbar.js +105 -0
  574. package/node/internals/components/PickersToolbarButton.js +59 -0
  575. package/node/internals/components/PickersToolbarText.js +57 -0
  576. package/node/internals/components/PureDateInput.js +70 -0
  577. package/node/internals/components/icons/index.js +88 -0
  578. package/node/internals/components/wrappers/DesktopTooltipWrapper.js +71 -0
  579. package/node/internals/components/wrappers/DesktopWrapper.js +60 -0
  580. package/node/internals/components/wrappers/MobileWrapper.js +65 -0
  581. package/node/internals/components/wrappers/ResponsiveWrapper.js +64 -0
  582. package/node/internals/components/wrappers/WrapperProps.js +5 -0
  583. package/node/internals/components/wrappers/WrapperVariantContext.js +25 -0
  584. package/node/internals/constants/dimensions.js +14 -0
  585. package/node/internals/hooks/date-helpers-hooks.js +55 -0
  586. package/node/internals/hooks/useIsLandscape.js +57 -0
  587. package/node/internals/hooks/useMaskedInput.js +113 -0
  588. package/node/internals/hooks/useOpenState.js +51 -0
  589. package/node/internals/hooks/usePickerState.js +136 -0
  590. package/node/internals/hooks/useUtils.js +40 -0
  591. package/node/internals/hooks/useViews.js +64 -0
  592. package/node/internals/hooks/validation/useDateTimeValidation.js +51 -0
  593. package/node/internals/hooks/validation/useDateValidation.js +54 -0
  594. package/node/internals/hooks/validation/useTimeValidation.js +55 -0
  595. package/node/internals/hooks/validation/useValidation.js +32 -0
  596. package/node/internals/index.js +193 -0
  597. package/node/internals/models/helpers.js +5 -0
  598. package/node/internals/models/index.js +31 -0
  599. package/node/internals/models/muiPickersAdapter.js +5 -0
  600. package/node/internals/models/parseableDate.js +5 -0
  601. package/node/internals/models/props/basePickerProps.js +5 -0
  602. package/node/internals/models/props/baseToolbarProps.js +5 -0
  603. package/node/internals/models/views.js +5 -0
  604. package/node/internals/utils/date-utils.js +79 -0
  605. package/node/internals/utils/defaultReduceAnimations.js +8 -0
  606. package/node/internals/utils/text-field-helper.js +86 -0
  607. package/node/internals/utils/time-utils.js +53 -0
  608. package/node/internals/utils/utils.js +58 -0
  609. package/node/themeAugmentation/index.js +44 -0
  610. package/package.json +78 -0
  611. package/themeAugmentation/components.d.ts +53 -0
  612. package/themeAugmentation/index.d.ts +3 -0
  613. package/themeAugmentation/index.js +3 -0
  614. package/themeAugmentation/overrides.d.ts +27 -0
  615. package/themeAugmentation/package.json +6 -0
  616. package/themeAugmentation/props.d.ts +46 -0
@@ -0,0 +1,70 @@
1
+ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
2
+ import _extends from "@babel/runtime/helpers/esm/extends";
3
+ const _excluded = ["className", "disabled", "index", "inner", "label", "selected"];
4
+ import * as React from 'react';
5
+ import clsx from 'clsx';
6
+ import { styled } from '@mui/material/styles';
7
+ import { generateUtilityClasses } from '@mui/material';
8
+ import { CLOCK_WIDTH, CLOCK_HOUR_WIDTH } from './shared';
9
+ import { jsx as _jsx } from "react/jsx-runtime";
10
+ export const classes = generateUtilityClasses('PrivateClockNumber', ['selected', 'disabled']);
11
+ const ClockNumberRoot = styled('span')(({
12
+ theme,
13
+ ownerState
14
+ }) => _extends({
15
+ height: CLOCK_HOUR_WIDTH,
16
+ width: CLOCK_HOUR_WIDTH,
17
+ position: 'absolute',
18
+ left: `calc((100% - ${CLOCK_HOUR_WIDTH}px) / 2)`,
19
+ display: 'inline-flex',
20
+ justifyContent: 'center',
21
+ alignItems: 'center',
22
+ borderRadius: '50%',
23
+ color: theme.palette.text.primary,
24
+ fontFamily: theme.typography.fontFamily,
25
+ '&:focused': {
26
+ backgroundColor: theme.palette.background.paper
27
+ },
28
+ [`&.${classes.selected}`]: {
29
+ color: theme.palette.primary.contrastText
30
+ },
31
+ [`&.${classes.disabled}`]: {
32
+ pointerEvents: 'none',
33
+ color: theme.palette.text.disabled
34
+ }
35
+ }, ownerState.inner && _extends({}, theme.typography.body2, {
36
+ color: theme.palette.text.secondary
37
+ })));
38
+ /**
39
+ * @ignore - internal component.
40
+ */
41
+
42
+ export function ClockNumber(props) {
43
+ const {
44
+ className,
45
+ disabled,
46
+ index,
47
+ inner,
48
+ label,
49
+ selected
50
+ } = props,
51
+ other = _objectWithoutPropertiesLoose(props, _excluded);
52
+
53
+ const ownerState = props;
54
+ const angle = index % 12 / 12 * Math.PI * 2 - Math.PI / 2;
55
+ const length = (CLOCK_WIDTH - CLOCK_HOUR_WIDTH - 2) / 2 * (inner ? 0.65 : 1);
56
+ const x = Math.round(Math.cos(angle) * length);
57
+ const y = Math.round(Math.sin(angle) * length);
58
+ return /*#__PURE__*/_jsx(ClockNumberRoot, _extends({
59
+ className: clsx(className, selected && classes.selected, disabled && classes.disabled),
60
+ "aria-disabled": disabled ? true : undefined,
61
+ "aria-selected": selected ? true : undefined,
62
+ role: "option",
63
+ style: {
64
+ transform: `translate(${x}px, ${y + (CLOCK_WIDTH - CLOCK_HOUR_WIDTH) / 2}px`
65
+ },
66
+ ownerState: ownerState
67
+ }, other, {
68
+ children: label
69
+ }));
70
+ }
@@ -0,0 +1,80 @@
1
+ import * as React from 'react';
2
+ import { ClockNumber } from './ClockNumber';
3
+ import { jsx as _jsx } from "react/jsx-runtime";
4
+
5
+ /**
6
+ * @ignore - internal component.
7
+ */
8
+ export const getHourNumbers = ({
9
+ ampm,
10
+ date,
11
+ getClockNumberText,
12
+ isDisabled,
13
+ selectedId,
14
+ utils
15
+ }) => {
16
+ const currentHours = date ? utils.getHours(date) : null;
17
+ const hourNumbers = [];
18
+ const startHour = ampm ? 1 : 0;
19
+ const endHour = ampm ? 12 : 23;
20
+
21
+ const isSelected = hour => {
22
+ if (currentHours === null) {
23
+ return false;
24
+ }
25
+
26
+ if (ampm) {
27
+ if (hour === 12) {
28
+ return currentHours === 12 || currentHours === 0;
29
+ }
30
+
31
+ return currentHours === hour || currentHours - 12 === hour;
32
+ }
33
+
34
+ return currentHours === hour;
35
+ };
36
+
37
+ for (let hour = startHour; hour <= endHour; hour += 1) {
38
+ let label = hour.toString();
39
+
40
+ if (hour === 0) {
41
+ label = '00';
42
+ }
43
+
44
+ const inner = !ampm && (hour === 0 || hour > 12);
45
+ label = utils.formatNumber(label);
46
+ const selected = isSelected(hour);
47
+ hourNumbers.push( /*#__PURE__*/_jsx(ClockNumber, {
48
+ id: selected ? selectedId : undefined,
49
+ index: hour,
50
+ inner: inner,
51
+ selected: selected,
52
+ disabled: isDisabled(hour),
53
+ label: label,
54
+ "aria-label": getClockNumberText(label)
55
+ }, hour));
56
+ }
57
+
58
+ return hourNumbers;
59
+ };
60
+ export const getMinutesNumbers = ({
61
+ utils,
62
+ value,
63
+ isDisabled,
64
+ getClockNumberText,
65
+ selectedId
66
+ }) => {
67
+ const f = utils.formatNumber;
68
+ return [[5, f('05')], [10, f('10')], [15, f('15')], [20, f('20')], [25, f('25')], [30, f('30')], [35, f('35')], [40, f('40')], [45, f('45')], [50, f('50')], [55, f('55')], [0, f('00')]].map(([numberValue, label], index) => {
69
+ const selected = numberValue === value;
70
+ return /*#__PURE__*/_jsx(ClockNumber, {
71
+ label: label,
72
+ id: selected ? selectedId : undefined,
73
+ index: index + 1,
74
+ inner: false,
75
+ disabled: isDisabled(numberValue),
76
+ selected: selected,
77
+ "aria-label": getClockNumberText(label)
78
+ }, numberValue);
79
+ });
80
+ };
@@ -0,0 +1,407 @@
1
+ import _extends from "@babel/runtime/helpers/esm/extends";
2
+ import * as React from 'react';
3
+ import clsx from 'clsx';
4
+ import PropTypes from 'prop-types';
5
+ import { unstable_useId as useId } from '@mui/utils';
6
+ import { styled, useThemeProps } from '@mui/material/styles';
7
+ import { unstable_composeClasses as composeClasses } from '@mui/material';
8
+ import { Clock } from './Clock';
9
+ import { pipe } from '../internals/utils/utils';
10
+ import { useUtils, useNow } from '../internals/hooks/useUtils';
11
+ import { getHourNumbers, getMinutesNumbers } from './ClockNumbers';
12
+ import { PickersArrowSwitcher } from '../internals/components/PickersArrowSwitcher';
13
+ import { convertValueToMeridiem, createIsAfterIgnoreDatePart } from '../internals/utils/time-utils';
14
+ import { useViews } from '../internals/hooks/useViews';
15
+ import { useMeridiemMode } from '../internals/hooks/date-helpers-hooks';
16
+ import { getClockPickerUtilityClass } from './clockPickerClasses';
17
+ import { PickerViewRoot } from '../internals/components/PickerViewRoot';
18
+ import { jsx as _jsx } from "react/jsx-runtime";
19
+ import { jsxs as _jsxs } from "react/jsx-runtime";
20
+
21
+ const useUtilityClasses = ownerState => {
22
+ const {
23
+ classes
24
+ } = ownerState;
25
+ const slots = {
26
+ root: ['root'],
27
+ arrowSwitcher: ['arrowSwitcher']
28
+ };
29
+ return composeClasses(slots, getClockPickerUtilityClass, classes);
30
+ };
31
+
32
+ const ClockPickerRoot = styled(PickerViewRoot, {
33
+ name: 'MuiClockPicker',
34
+ slot: 'Root',
35
+ overridesResolver: (props, styles) => styles.root
36
+ })({
37
+ display: 'flex',
38
+ flexDirection: 'column'
39
+ });
40
+ const ClockPickerArrowSwitcher = styled(PickersArrowSwitcher, {
41
+ name: 'MuiClockPicker',
42
+ slot: 'ArrowSwitcher',
43
+ overridesResolver: (props, styles) => styles.arrowSwitcher
44
+ })({
45
+ position: 'absolute',
46
+ right: 12,
47
+ top: 15
48
+ });
49
+
50
+ const defaultGetClockLabelText = (view, time, adapter) => `Select ${view}. ${time === null ? 'No time selected' : `Selected time is ${adapter.format(time, 'fullTime')}`}`;
51
+
52
+ const defaultGetMinutesClockNumberText = minutes => `${minutes} minutes`;
53
+
54
+ const defaultGetHoursClockNumberText = hours => `${hours} hours`;
55
+
56
+ const defaultGetSecondsClockNumberText = seconds => `${seconds} seconds`;
57
+
58
+ /**
59
+ *
60
+ * API:
61
+ *
62
+ * - [ClockPicker API](https://mui.com/api/clock-picker/)
63
+ */
64
+ export const ClockPicker = /*#__PURE__*/React.forwardRef(function ClockPicker(inProps, ref) {
65
+ const props = useThemeProps({
66
+ props: inProps,
67
+ name: 'MuiClockPicker'
68
+ });
69
+ const {
70
+ ampm = false,
71
+ ampmInClock = false,
72
+ autoFocus,
73
+ components,
74
+ componentsProps,
75
+ date,
76
+ disableIgnoringDatePartForTimeValidation = false,
77
+ getClockLabelText = defaultGetClockLabelText,
78
+ getHoursClockNumberText = defaultGetHoursClockNumberText,
79
+ getMinutesClockNumberText = defaultGetMinutesClockNumberText,
80
+ getSecondsClockNumberText = defaultGetSecondsClockNumberText,
81
+ leftArrowButtonText = 'open previous view',
82
+ maxTime,
83
+ minTime,
84
+ minutesStep = 1,
85
+ rightArrowButtonText = 'open next view',
86
+ shouldDisableTime,
87
+ showViewSwitcher,
88
+ onChange,
89
+ view,
90
+ views = ['hours', 'minutes'],
91
+ openTo,
92
+ onViewChange,
93
+ className
94
+ } = props;
95
+ const {
96
+ openView,
97
+ setOpenView,
98
+ nextView,
99
+ previousView,
100
+ handleChangeAndOpenNext
101
+ } = useViews({
102
+ view,
103
+ views,
104
+ openTo,
105
+ onViewChange,
106
+ onChange
107
+ });
108
+ const now = useNow();
109
+ const utils = useUtils();
110
+ const midnight = utils.setSeconds(utils.setMinutes(utils.setHours(now, 0), 0), 0);
111
+ const dateOrMidnight = date || midnight;
112
+ const {
113
+ meridiemMode,
114
+ handleMeridiemChange
115
+ } = useMeridiemMode(dateOrMidnight, ampm, handleChangeAndOpenNext);
116
+ const isTimeDisabled = React.useCallback((rawValue, viewType) => {
117
+ if (date === null) {
118
+ return false;
119
+ }
120
+
121
+ const validateTimeValue = getRequestedTimePoint => {
122
+ const isAfterComparingFn = createIsAfterIgnoreDatePart(disableIgnoringDatePartForTimeValidation, utils);
123
+ return Boolean(minTime && isAfterComparingFn(minTime, getRequestedTimePoint('end')) || maxTime && isAfterComparingFn(getRequestedTimePoint('start'), maxTime) || shouldDisableTime && shouldDisableTime(rawValue, viewType));
124
+ };
125
+
126
+ switch (viewType) {
127
+ case 'hours':
128
+ {
129
+ const hoursWithMeridiem = convertValueToMeridiem(rawValue, meridiemMode, ampm);
130
+ return validateTimeValue(when => pipe(currentDate => utils.setHours(currentDate, hoursWithMeridiem), dateWithHours => utils.setMinutes(dateWithHours, when === 'start' ? 0 : 59), dateWithMinutes => utils.setSeconds(dateWithMinutes, when === 'start' ? 0 : 59))(date));
131
+ }
132
+
133
+ case 'minutes':
134
+ return validateTimeValue(when => pipe(currentDate => utils.setMinutes(currentDate, rawValue), dateWithMinutes => utils.setSeconds(dateWithMinutes, when === 'start' ? 0 : 59))(date));
135
+
136
+ case 'seconds':
137
+ return validateTimeValue(() => utils.setSeconds(date, rawValue));
138
+
139
+ default:
140
+ throw new Error('not supported');
141
+ }
142
+ }, [ampm, date, disableIgnoringDatePartForTimeValidation, maxTime, meridiemMode, minTime, shouldDisableTime, utils]);
143
+ const selectedId = useId();
144
+ const viewProps = React.useMemo(() => {
145
+ switch (openView) {
146
+ case 'hours':
147
+ {
148
+ const handleHoursChange = (value, isFinish) => {
149
+ const valueWithMeridiem = convertValueToMeridiem(value, meridiemMode, ampm);
150
+ handleChangeAndOpenNext(utils.setHours(dateOrMidnight, valueWithMeridiem), isFinish);
151
+ };
152
+
153
+ return {
154
+ onChange: handleHoursChange,
155
+ value: utils.getHours(dateOrMidnight),
156
+ children: getHourNumbers({
157
+ date,
158
+ utils,
159
+ ampm,
160
+ onChange: handleHoursChange,
161
+ getClockNumberText: getHoursClockNumberText,
162
+ isDisabled: value => isTimeDisabled(value, 'hours'),
163
+ selectedId
164
+ })
165
+ };
166
+ }
167
+
168
+ case 'minutes':
169
+ {
170
+ const minutesValue = utils.getMinutes(dateOrMidnight);
171
+
172
+ const handleMinutesChange = (value, isFinish) => {
173
+ handleChangeAndOpenNext(utils.setMinutes(dateOrMidnight, value), isFinish);
174
+ };
175
+
176
+ return {
177
+ value: minutesValue,
178
+ onChange: handleMinutesChange,
179
+ children: getMinutesNumbers({
180
+ utils,
181
+ value: minutesValue,
182
+ onChange: handleMinutesChange,
183
+ getClockNumberText: getMinutesClockNumberText,
184
+ isDisabled: value => isTimeDisabled(value, 'minutes'),
185
+ selectedId
186
+ })
187
+ };
188
+ }
189
+
190
+ case 'seconds':
191
+ {
192
+ const secondsValue = utils.getSeconds(dateOrMidnight);
193
+
194
+ const handleSecondsChange = (value, isFinish) => {
195
+ handleChangeAndOpenNext(utils.setSeconds(dateOrMidnight, value), isFinish);
196
+ };
197
+
198
+ return {
199
+ value: secondsValue,
200
+ onChange: handleSecondsChange,
201
+ children: getMinutesNumbers({
202
+ utils,
203
+ value: secondsValue,
204
+ onChange: handleSecondsChange,
205
+ getClockNumberText: getSecondsClockNumberText,
206
+ isDisabled: value => isTimeDisabled(value, 'seconds'),
207
+ selectedId
208
+ })
209
+ };
210
+ }
211
+
212
+ default:
213
+ throw new Error('You must provide the type for ClockView');
214
+ }
215
+ }, [openView, utils, date, ampm, getHoursClockNumberText, getMinutesClockNumberText, getSecondsClockNumberText, meridiemMode, handleChangeAndOpenNext, dateOrMidnight, isTimeDisabled, selectedId]);
216
+ const ownerState = props;
217
+ const classes = useUtilityClasses(ownerState);
218
+ return /*#__PURE__*/_jsxs(ClockPickerRoot, {
219
+ ref: ref,
220
+ className: clsx(classes.root, className),
221
+ ownerState: ownerState,
222
+ children: [showViewSwitcher && /*#__PURE__*/_jsx(ClockPickerArrowSwitcher, {
223
+ className: classes.arrowSwitcher,
224
+ leftArrowButtonText: leftArrowButtonText,
225
+ rightArrowButtonText: rightArrowButtonText,
226
+ components: components,
227
+ componentsProps: componentsProps,
228
+ onLeftClick: () => setOpenView(previousView),
229
+ onRightClick: () => setOpenView(nextView),
230
+ isLeftDisabled: !previousView,
231
+ isRightDisabled: !nextView,
232
+ ownerState: ownerState
233
+ }), /*#__PURE__*/_jsx(Clock, _extends({
234
+ autoFocus: autoFocus,
235
+ date: date,
236
+ ampmInClock: ampmInClock,
237
+ type: openView,
238
+ ampm: ampm,
239
+ getClockLabelText: getClockLabelText,
240
+ minutesStep: minutesStep,
241
+ isTimeDisabled: isTimeDisabled,
242
+ meridiemMode: meridiemMode,
243
+ handleMeridiemChange: handleMeridiemChange,
244
+ selectedId: selectedId
245
+ }, viewProps))]
246
+ });
247
+ });
248
+ process.env.NODE_ENV !== "production" ? ClockPicker.propTypes = {
249
+ // ----------------------------- Warning --------------------------------
250
+ // | These PropTypes are generated from the TypeScript type definitions |
251
+ // | To update them edit the TypeScript types and run "yarn proptypes" |
252
+ // ----------------------------------------------------------------------
253
+
254
+ /**
255
+ * 12h/24h view for hour selection clock.
256
+ * @default false
257
+ */
258
+ ampm: PropTypes.bool,
259
+
260
+ /**
261
+ * Display ampm controls under the clock (instead of in the toolbar).
262
+ * @default false
263
+ */
264
+ ampmInClock: PropTypes.bool,
265
+
266
+ /**
267
+ * Set to `true` if focus should be moved to clock picker.
268
+ */
269
+ autoFocus: PropTypes.bool,
270
+
271
+ /**
272
+ * Override or extend the styles applied to the component.
273
+ */
274
+ classes: PropTypes.object,
275
+ className: PropTypes.string,
276
+
277
+ /**
278
+ * The components used for each slot.
279
+ * Either a string to use a HTML element or a component.
280
+ */
281
+ components: PropTypes.object,
282
+
283
+ /**
284
+ * The props used for each slot inside.
285
+ */
286
+ componentsProps: PropTypes.object,
287
+
288
+ /**
289
+ * Selected date @DateIOType.
290
+ */
291
+ date: PropTypes.any,
292
+
293
+ /**
294
+ * Do not ignore date part when validating min/max time.
295
+ * @default false
296
+ */
297
+ disableIgnoringDatePartForTimeValidation: PropTypes.bool,
298
+
299
+ /**
300
+ * Accessible text that helps user to understand which time and view is selected.
301
+ * @param {ClockPickerView} view The current view rendered.
302
+ * @param {TDate | null} time The current time.
303
+ * @param {MuiPickersAdapter<TDate>} adapter The current date adapter.
304
+ * @returns {string} The clock label.
305
+ * @default <TDate extends any>(
306
+ * view: ClockView,
307
+ * time: TDate | null,
308
+ * adapter: MuiPickersAdapter<TDate>,
309
+ * ) =>
310
+ * `Select ${view}. ${
311
+ * time === null ? 'No time selected' : `Selected time is ${adapter.format(time, 'fullTime')}`
312
+ * }`
313
+ */
314
+ getClockLabelText: PropTypes.func,
315
+
316
+ /**
317
+ * Get clock number aria-text for hours.
318
+ * @param {string} hours The hours to format.
319
+ * @returns {string} the formatted hours text.
320
+ * @default (hours: string) => `${hours} hours`
321
+ */
322
+ getHoursClockNumberText: PropTypes.func,
323
+
324
+ /**
325
+ * Get clock number aria-text for minutes.
326
+ * @param {string} minutes The minutes to format.
327
+ * @returns {string} the formatted minutes text.
328
+ * @default (minutes: string) => `${minutes} minutes`
329
+ */
330
+ getMinutesClockNumberText: PropTypes.func,
331
+
332
+ /**
333
+ * Get clock number aria-text for seconds.
334
+ * @param {string} seconds The seconds to format.
335
+ * @returns {string} the formatted seconds text.
336
+ * @default (seconds: string) => `${seconds} seconds`
337
+ */
338
+ getSecondsClockNumberText: PropTypes.func,
339
+
340
+ /**
341
+ * Left arrow icon aria-label text.
342
+ * @default 'open previous view'
343
+ */
344
+ leftArrowButtonText: PropTypes.string,
345
+
346
+ /**
347
+ * Max time acceptable time.
348
+ * For input validation date part of passed object will be ignored if `disableIgnoringDatePartForTimeValidation` not specified.
349
+ */
350
+ maxTime: PropTypes.any,
351
+
352
+ /**
353
+ * Min time acceptable time.
354
+ * For input validation date part of passed object will be ignored if `disableIgnoringDatePartForTimeValidation` not specified.
355
+ */
356
+ minTime: PropTypes.any,
357
+
358
+ /**
359
+ * Step over minutes.
360
+ * @default 1
361
+ */
362
+ minutesStep: PropTypes.number,
363
+
364
+ /**
365
+ * On change callback @DateIOType.
366
+ */
367
+ onChange: PropTypes.func.isRequired,
368
+
369
+ /**
370
+ * Callback fired on view change.
371
+ * @param {ClockPickerView} view The new view.
372
+ */
373
+ onViewChange: PropTypes.func,
374
+
375
+ /**
376
+ * Initially open view.
377
+ * @default 'hours'
378
+ */
379
+ openTo: PropTypes.oneOf(['hours', 'minutes', 'seconds']),
380
+
381
+ /**
382
+ * Right arrow icon aria-label text.
383
+ * @default 'open next view'
384
+ */
385
+ rightArrowButtonText: PropTypes.string,
386
+
387
+ /**
388
+ * Dynamically check if time is disabled or not.
389
+ * If returns `false` appropriate time point will ot be acceptable.
390
+ * @param {number} timeValue The value to check.
391
+ * @param {ClockPickerView} clockType The clock type of the timeValue.
392
+ * @returns {boolean} Returns `true` if the time should be disabled
393
+ */
394
+ shouldDisableTime: PropTypes.func,
395
+ showViewSwitcher: PropTypes.bool,
396
+
397
+ /**
398
+ * Controlled open view.
399
+ */
400
+ view: PropTypes.oneOf(['hours', 'minutes', 'seconds']),
401
+
402
+ /**
403
+ * Views for calendar picker.
404
+ * @default ['hours', 'minutes']
405
+ */
406
+ views: PropTypes.arrayOf(PropTypes.oneOf(['hours', 'minutes', 'seconds']).isRequired)
407
+ } : void 0;
@@ -0,0 +1,102 @@
1
+ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
2
+ import _extends from "@babel/runtime/helpers/esm/extends";
3
+ const _excluded = ["className", "hasSelected", "isInner", "type", "value"];
4
+ import * as React from 'react';
5
+ import { styled } from '@mui/material/styles';
6
+ import { CLOCK_WIDTH, CLOCK_HOUR_WIDTH } from './shared';
7
+ import { jsx as _jsx } from "react/jsx-runtime";
8
+ const ClockPointerRoot = styled('div')(({
9
+ theme,
10
+ ownerState
11
+ }) => _extends({
12
+ width: 2,
13
+ backgroundColor: theme.palette.primary.main,
14
+ position: 'absolute',
15
+ left: 'calc(50% - 1px)',
16
+ bottom: '50%',
17
+ transformOrigin: 'center bottom 0px'
18
+ }, ownerState.toAnimateTransform && {
19
+ transition: theme.transitions.create(['transform', 'height'])
20
+ }));
21
+ const ClockPointerThumb = styled('div')(({
22
+ theme,
23
+ ownerState
24
+ }) => _extends({
25
+ width: 4,
26
+ height: 4,
27
+ backgroundColor: theme.palette.primary.contrastText,
28
+ borderRadius: '50%',
29
+ position: 'absolute',
30
+ top: -21,
31
+ left: `calc(50% - ${CLOCK_HOUR_WIDTH / 2}px)`,
32
+ border: `${(CLOCK_HOUR_WIDTH - 4) / 2}px solid ${theme.palette.primary.main}`,
33
+ boxSizing: 'content-box'
34
+ }, ownerState.hasSelected && {
35
+ backgroundColor: theme.palette.primary.main
36
+ }));
37
+ /**
38
+ * @ignore - internal component.
39
+ * TODO: Remove class
40
+ */
41
+
42
+ export class ClockPointer extends React.Component {
43
+ constructor(...args) {
44
+ super(...args);
45
+ this.state = {
46
+ toAnimateTransform: false,
47
+ previousType: undefined
48
+ };
49
+ }
50
+
51
+ render() {
52
+ const _this$props = this.props,
53
+ {
54
+ className,
55
+ isInner,
56
+ type,
57
+ value
58
+ } = _this$props,
59
+ other = _objectWithoutPropertiesLoose(_this$props, _excluded);
60
+
61
+ const ownerState = _extends({}, this.props, this.state);
62
+
63
+ const getAngleStyle = () => {
64
+ const max = type === 'hours' ? 12 : 60;
65
+ let angle = 360 / max * value;
66
+
67
+ if (type === 'hours' && value > 12) {
68
+ angle -= 360; // round up angle to max 360 degrees
69
+ }
70
+
71
+ return {
72
+ height: Math.round((isInner ? 0.26 : 0.4) * CLOCK_WIDTH),
73
+ transform: `rotateZ(${angle}deg)`
74
+ };
75
+ };
76
+
77
+ return /*#__PURE__*/_jsx(ClockPointerRoot, _extends({
78
+ style: getAngleStyle(),
79
+ className: className,
80
+ ownerState: ownerState
81
+ }, other, {
82
+ children: /*#__PURE__*/_jsx(ClockPointerThumb, {
83
+ ownerState: ownerState
84
+ })
85
+ }));
86
+ }
87
+
88
+ }
89
+
90
+ ClockPointer.getDerivedStateFromProps = (nextProps, state) => {
91
+ if (nextProps.type !== state.previousType) {
92
+ return {
93
+ toAnimateTransform: true,
94
+ previousType: nextProps.type
95
+ };
96
+ }
97
+
98
+ return {
99
+ toAnimateTransform: false,
100
+ previousType: nextProps.type
101
+ };
102
+ };
@@ -0,0 +1,5 @@
1
+ import { generateUtilityClass, generateUtilityClasses } from '@mui/material';
2
+ export function getClockPickerUtilityClass(slot) {
3
+ return generateUtilityClass('MuiClockPicker', slot);
4
+ }
5
+ export const clockPickerClasses = generateUtilityClasses('MuiClockPicker', ['root', 'arrowSwitcher']);
@@ -0,0 +1,2 @@
1
+ export { ClockPicker } from './ClockPicker';
2
+ export { clockPickerClasses, getClockPickerUtilityClass } from './clockPickerClasses';