@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,454 @@
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
+ var useUtilityClasses = function useUtilityClasses(ownerState) {
22
+ var classes = ownerState.classes;
23
+ var slots = {
24
+ root: ['root'],
25
+ arrowSwitcher: ['arrowSwitcher']
26
+ };
27
+ return composeClasses(slots, getClockPickerUtilityClass, classes);
28
+ };
29
+
30
+ var ClockPickerRoot = styled(PickerViewRoot, {
31
+ name: 'MuiClockPicker',
32
+ slot: 'Root',
33
+ overridesResolver: function overridesResolver(props, styles) {
34
+ return styles.root;
35
+ }
36
+ })({
37
+ display: 'flex',
38
+ flexDirection: 'column'
39
+ });
40
+ var ClockPickerArrowSwitcher = styled(PickersArrowSwitcher, {
41
+ name: 'MuiClockPicker',
42
+ slot: 'ArrowSwitcher',
43
+ overridesResolver: function overridesResolver(props, styles) {
44
+ return styles.arrowSwitcher;
45
+ }
46
+ })({
47
+ position: 'absolute',
48
+ right: 12,
49
+ top: 15
50
+ });
51
+
52
+ var defaultGetClockLabelText = function defaultGetClockLabelText(view, time, adapter) {
53
+ return "Select ".concat(view, ". ").concat(time === null ? 'No time selected' : "Selected time is ".concat(adapter.format(time, 'fullTime')));
54
+ };
55
+
56
+ var defaultGetMinutesClockNumberText = function defaultGetMinutesClockNumberText(minutes) {
57
+ return "".concat(minutes, " minutes");
58
+ };
59
+
60
+ var defaultGetHoursClockNumberText = function defaultGetHoursClockNumberText(hours) {
61
+ return "".concat(hours, " hours");
62
+ };
63
+
64
+ var defaultGetSecondsClockNumberText = function defaultGetSecondsClockNumberText(seconds) {
65
+ return "".concat(seconds, " seconds");
66
+ };
67
+
68
+ /**
69
+ *
70
+ * API:
71
+ *
72
+ * - [ClockPicker API](https://mui.com/api/clock-picker/)
73
+ */
74
+ export var ClockPicker = /*#__PURE__*/React.forwardRef(function ClockPicker(inProps, ref) {
75
+ var props = useThemeProps({
76
+ props: inProps,
77
+ name: 'MuiClockPicker'
78
+ });
79
+ var _props$ampm = props.ampm,
80
+ ampm = _props$ampm === void 0 ? false : _props$ampm,
81
+ _props$ampmInClock = props.ampmInClock,
82
+ ampmInClock = _props$ampmInClock === void 0 ? false : _props$ampmInClock,
83
+ autoFocus = props.autoFocus,
84
+ components = props.components,
85
+ componentsProps = props.componentsProps,
86
+ date = props.date,
87
+ _props$disableIgnorin = props.disableIgnoringDatePartForTimeValidation,
88
+ disableIgnoringDatePartForTimeValidation = _props$disableIgnorin === void 0 ? false : _props$disableIgnorin,
89
+ _props$getClockLabelT = props.getClockLabelText,
90
+ getClockLabelText = _props$getClockLabelT === void 0 ? defaultGetClockLabelText : _props$getClockLabelT,
91
+ _props$getHoursClockN = props.getHoursClockNumberText,
92
+ getHoursClockNumberText = _props$getHoursClockN === void 0 ? defaultGetHoursClockNumberText : _props$getHoursClockN,
93
+ _props$getMinutesCloc = props.getMinutesClockNumberText,
94
+ getMinutesClockNumberText = _props$getMinutesCloc === void 0 ? defaultGetMinutesClockNumberText : _props$getMinutesCloc,
95
+ _props$getSecondsCloc = props.getSecondsClockNumberText,
96
+ getSecondsClockNumberText = _props$getSecondsCloc === void 0 ? defaultGetSecondsClockNumberText : _props$getSecondsCloc,
97
+ _props$leftArrowButto = props.leftArrowButtonText,
98
+ leftArrowButtonText = _props$leftArrowButto === void 0 ? 'open previous view' : _props$leftArrowButto,
99
+ maxTime = props.maxTime,
100
+ minTime = props.minTime,
101
+ _props$minutesStep = props.minutesStep,
102
+ minutesStep = _props$minutesStep === void 0 ? 1 : _props$minutesStep,
103
+ _props$rightArrowButt = props.rightArrowButtonText,
104
+ rightArrowButtonText = _props$rightArrowButt === void 0 ? 'open next view' : _props$rightArrowButt,
105
+ shouldDisableTime = props.shouldDisableTime,
106
+ showViewSwitcher = props.showViewSwitcher,
107
+ onChange = props.onChange,
108
+ view = props.view,
109
+ _props$views = props.views,
110
+ views = _props$views === void 0 ? ['hours', 'minutes'] : _props$views,
111
+ openTo = props.openTo,
112
+ onViewChange = props.onViewChange,
113
+ className = props.className;
114
+
115
+ var _useViews = useViews({
116
+ view: view,
117
+ views: views,
118
+ openTo: openTo,
119
+ onViewChange: onViewChange,
120
+ onChange: onChange
121
+ }),
122
+ openView = _useViews.openView,
123
+ setOpenView = _useViews.setOpenView,
124
+ nextView = _useViews.nextView,
125
+ previousView = _useViews.previousView,
126
+ handleChangeAndOpenNext = _useViews.handleChangeAndOpenNext;
127
+
128
+ var now = useNow();
129
+ var utils = useUtils();
130
+ var midnight = utils.setSeconds(utils.setMinutes(utils.setHours(now, 0), 0), 0);
131
+ var dateOrMidnight = date || midnight;
132
+
133
+ var _useMeridiemMode = useMeridiemMode(dateOrMidnight, ampm, handleChangeAndOpenNext),
134
+ meridiemMode = _useMeridiemMode.meridiemMode,
135
+ handleMeridiemChange = _useMeridiemMode.handleMeridiemChange;
136
+
137
+ var isTimeDisabled = React.useCallback(function (rawValue, viewType) {
138
+ if (date === null) {
139
+ return false;
140
+ }
141
+
142
+ var validateTimeValue = function validateTimeValue(getRequestedTimePoint) {
143
+ var isAfterComparingFn = createIsAfterIgnoreDatePart(disableIgnoringDatePartForTimeValidation, utils);
144
+ return Boolean(minTime && isAfterComparingFn(minTime, getRequestedTimePoint('end')) || maxTime && isAfterComparingFn(getRequestedTimePoint('start'), maxTime) || shouldDisableTime && shouldDisableTime(rawValue, viewType));
145
+ };
146
+
147
+ switch (viewType) {
148
+ case 'hours':
149
+ {
150
+ var hoursWithMeridiem = convertValueToMeridiem(rawValue, meridiemMode, ampm);
151
+ return validateTimeValue(function (when) {
152
+ return pipe(function (currentDate) {
153
+ return utils.setHours(currentDate, hoursWithMeridiem);
154
+ }, function (dateWithHours) {
155
+ return utils.setMinutes(dateWithHours, when === 'start' ? 0 : 59);
156
+ }, function (dateWithMinutes) {
157
+ return utils.setSeconds(dateWithMinutes, when === 'start' ? 0 : 59);
158
+ })(date);
159
+ });
160
+ }
161
+
162
+ case 'minutes':
163
+ return validateTimeValue(function (when) {
164
+ return pipe(function (currentDate) {
165
+ return utils.setMinutes(currentDate, rawValue);
166
+ }, function (dateWithMinutes) {
167
+ return utils.setSeconds(dateWithMinutes, when === 'start' ? 0 : 59);
168
+ })(date);
169
+ });
170
+
171
+ case 'seconds':
172
+ return validateTimeValue(function () {
173
+ return utils.setSeconds(date, rawValue);
174
+ });
175
+
176
+ default:
177
+ throw new Error('not supported');
178
+ }
179
+ }, [ampm, date, disableIgnoringDatePartForTimeValidation, maxTime, meridiemMode, minTime, shouldDisableTime, utils]);
180
+ var selectedId = useId();
181
+ var viewProps = React.useMemo(function () {
182
+ switch (openView) {
183
+ case 'hours':
184
+ {
185
+ var handleHoursChange = function handleHoursChange(value, isFinish) {
186
+ var valueWithMeridiem = convertValueToMeridiem(value, meridiemMode, ampm);
187
+ handleChangeAndOpenNext(utils.setHours(dateOrMidnight, valueWithMeridiem), isFinish);
188
+ };
189
+
190
+ return {
191
+ onChange: handleHoursChange,
192
+ value: utils.getHours(dateOrMidnight),
193
+ children: getHourNumbers({
194
+ date: date,
195
+ utils: utils,
196
+ ampm: ampm,
197
+ onChange: handleHoursChange,
198
+ getClockNumberText: getHoursClockNumberText,
199
+ isDisabled: function isDisabled(value) {
200
+ return isTimeDisabled(value, 'hours');
201
+ },
202
+ selectedId: selectedId
203
+ })
204
+ };
205
+ }
206
+
207
+ case 'minutes':
208
+ {
209
+ var minutesValue = utils.getMinutes(dateOrMidnight);
210
+
211
+ var handleMinutesChange = function handleMinutesChange(value, isFinish) {
212
+ handleChangeAndOpenNext(utils.setMinutes(dateOrMidnight, value), isFinish);
213
+ };
214
+
215
+ return {
216
+ value: minutesValue,
217
+ onChange: handleMinutesChange,
218
+ children: getMinutesNumbers({
219
+ utils: utils,
220
+ value: minutesValue,
221
+ onChange: handleMinutesChange,
222
+ getClockNumberText: getMinutesClockNumberText,
223
+ isDisabled: function isDisabled(value) {
224
+ return isTimeDisabled(value, 'minutes');
225
+ },
226
+ selectedId: selectedId
227
+ })
228
+ };
229
+ }
230
+
231
+ case 'seconds':
232
+ {
233
+ var secondsValue = utils.getSeconds(dateOrMidnight);
234
+
235
+ var handleSecondsChange = function handleSecondsChange(value, isFinish) {
236
+ handleChangeAndOpenNext(utils.setSeconds(dateOrMidnight, value), isFinish);
237
+ };
238
+
239
+ return {
240
+ value: secondsValue,
241
+ onChange: handleSecondsChange,
242
+ children: getMinutesNumbers({
243
+ utils: utils,
244
+ value: secondsValue,
245
+ onChange: handleSecondsChange,
246
+ getClockNumberText: getSecondsClockNumberText,
247
+ isDisabled: function isDisabled(value) {
248
+ return isTimeDisabled(value, 'seconds');
249
+ },
250
+ selectedId: selectedId
251
+ })
252
+ };
253
+ }
254
+
255
+ default:
256
+ throw new Error('You must provide the type for ClockView');
257
+ }
258
+ }, [openView, utils, date, ampm, getHoursClockNumberText, getMinutesClockNumberText, getSecondsClockNumberText, meridiemMode, handleChangeAndOpenNext, dateOrMidnight, isTimeDisabled, selectedId]);
259
+ var ownerState = props;
260
+ var classes = useUtilityClasses(ownerState);
261
+ return /*#__PURE__*/_jsxs(ClockPickerRoot, {
262
+ ref: ref,
263
+ className: clsx(classes.root, className),
264
+ ownerState: ownerState,
265
+ children: [showViewSwitcher && /*#__PURE__*/_jsx(ClockPickerArrowSwitcher, {
266
+ className: classes.arrowSwitcher,
267
+ leftArrowButtonText: leftArrowButtonText,
268
+ rightArrowButtonText: rightArrowButtonText,
269
+ components: components,
270
+ componentsProps: componentsProps,
271
+ onLeftClick: function onLeftClick() {
272
+ return setOpenView(previousView);
273
+ },
274
+ onRightClick: function onRightClick() {
275
+ return setOpenView(nextView);
276
+ },
277
+ isLeftDisabled: !previousView,
278
+ isRightDisabled: !nextView,
279
+ ownerState: ownerState
280
+ }), /*#__PURE__*/_jsx(Clock, _extends({
281
+ autoFocus: autoFocus,
282
+ date: date,
283
+ ampmInClock: ampmInClock,
284
+ type: openView,
285
+ ampm: ampm,
286
+ getClockLabelText: getClockLabelText,
287
+ minutesStep: minutesStep,
288
+ isTimeDisabled: isTimeDisabled,
289
+ meridiemMode: meridiemMode,
290
+ handleMeridiemChange: handleMeridiemChange,
291
+ selectedId: selectedId
292
+ }, viewProps))]
293
+ });
294
+ });
295
+ process.env.NODE_ENV !== "production" ? ClockPicker.propTypes = {
296
+ // ----------------------------- Warning --------------------------------
297
+ // | These PropTypes are generated from the TypeScript type definitions |
298
+ // | To update them edit the TypeScript types and run "yarn proptypes" |
299
+ // ----------------------------------------------------------------------
300
+
301
+ /**
302
+ * 12h/24h view for hour selection clock.
303
+ * @default false
304
+ */
305
+ ampm: PropTypes.bool,
306
+
307
+ /**
308
+ * Display ampm controls under the clock (instead of in the toolbar).
309
+ * @default false
310
+ */
311
+ ampmInClock: PropTypes.bool,
312
+
313
+ /**
314
+ * Set to `true` if focus should be moved to clock picker.
315
+ */
316
+ autoFocus: PropTypes.bool,
317
+
318
+ /**
319
+ * Override or extend the styles applied to the component.
320
+ */
321
+ classes: PropTypes.object,
322
+ className: PropTypes.string,
323
+
324
+ /**
325
+ * The components used for each slot.
326
+ * Either a string to use a HTML element or a component.
327
+ */
328
+ components: PropTypes.object,
329
+
330
+ /**
331
+ * The props used for each slot inside.
332
+ */
333
+ componentsProps: PropTypes.object,
334
+
335
+ /**
336
+ * Selected date @DateIOType.
337
+ */
338
+ date: PropTypes.any,
339
+
340
+ /**
341
+ * Do not ignore date part when validating min/max time.
342
+ * @default false
343
+ */
344
+ disableIgnoringDatePartForTimeValidation: PropTypes.bool,
345
+
346
+ /**
347
+ * Accessible text that helps user to understand which time and view is selected.
348
+ * @param {ClockPickerView} view The current view rendered.
349
+ * @param {TDate | null} time The current time.
350
+ * @param {MuiPickersAdapter<TDate>} adapter The current date adapter.
351
+ * @returns {string} The clock label.
352
+ * @default <TDate extends any>(
353
+ * view: ClockView,
354
+ * time: TDate | null,
355
+ * adapter: MuiPickersAdapter<TDate>,
356
+ * ) =>
357
+ * `Select ${view}. ${
358
+ * time === null ? 'No time selected' : `Selected time is ${adapter.format(time, 'fullTime')}`
359
+ * }`
360
+ */
361
+ getClockLabelText: PropTypes.func,
362
+
363
+ /**
364
+ * Get clock number aria-text for hours.
365
+ * @param {string} hours The hours to format.
366
+ * @returns {string} the formatted hours text.
367
+ * @default (hours: string) => `${hours} hours`
368
+ */
369
+ getHoursClockNumberText: PropTypes.func,
370
+
371
+ /**
372
+ * Get clock number aria-text for minutes.
373
+ * @param {string} minutes The minutes to format.
374
+ * @returns {string} the formatted minutes text.
375
+ * @default (minutes: string) => `${minutes} minutes`
376
+ */
377
+ getMinutesClockNumberText: PropTypes.func,
378
+
379
+ /**
380
+ * Get clock number aria-text for seconds.
381
+ * @param {string} seconds The seconds to format.
382
+ * @returns {string} the formatted seconds text.
383
+ * @default (seconds: string) => `${seconds} seconds`
384
+ */
385
+ getSecondsClockNumberText: PropTypes.func,
386
+
387
+ /**
388
+ * Left arrow icon aria-label text.
389
+ * @default 'open previous view'
390
+ */
391
+ leftArrowButtonText: PropTypes.string,
392
+
393
+ /**
394
+ * Max time acceptable time.
395
+ * For input validation date part of passed object will be ignored if `disableIgnoringDatePartForTimeValidation` not specified.
396
+ */
397
+ maxTime: PropTypes.any,
398
+
399
+ /**
400
+ * Min time acceptable time.
401
+ * For input validation date part of passed object will be ignored if `disableIgnoringDatePartForTimeValidation` not specified.
402
+ */
403
+ minTime: PropTypes.any,
404
+
405
+ /**
406
+ * Step over minutes.
407
+ * @default 1
408
+ */
409
+ minutesStep: PropTypes.number,
410
+
411
+ /**
412
+ * On change callback @DateIOType.
413
+ */
414
+ onChange: PropTypes.func.isRequired,
415
+
416
+ /**
417
+ * Callback fired on view change.
418
+ * @param {ClockPickerView} view The new view.
419
+ */
420
+ onViewChange: PropTypes.func,
421
+
422
+ /**
423
+ * Initially open view.
424
+ * @default 'hours'
425
+ */
426
+ openTo: PropTypes.oneOf(['hours', 'minutes', 'seconds']),
427
+
428
+ /**
429
+ * Right arrow icon aria-label text.
430
+ * @default 'open next view'
431
+ */
432
+ rightArrowButtonText: PropTypes.string,
433
+
434
+ /**
435
+ * Dynamically check if time is disabled or not.
436
+ * If returns `false` appropriate time point will ot be acceptable.
437
+ * @param {number} timeValue The value to check.
438
+ * @param {ClockPickerView} clockType The clock type of the timeValue.
439
+ * @returns {boolean} Returns `true` if the time should be disabled
440
+ */
441
+ shouldDisableTime: PropTypes.func,
442
+ showViewSwitcher: PropTypes.bool,
443
+
444
+ /**
445
+ * Controlled open view.
446
+ */
447
+ view: PropTypes.oneOf(['hours', 'minutes', 'seconds']),
448
+
449
+ /**
450
+ * Views for calendar picker.
451
+ * @default ['hours', 'minutes']
452
+ */
453
+ views: PropTypes.arrayOf(PropTypes.oneOf(['hours', 'minutes', 'seconds']).isRequired)
454
+ } : void 0;
@@ -0,0 +1,130 @@
1
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
2
+ import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
3
+ import _createClass from "@babel/runtime/helpers/esm/createClass";
4
+ import _inherits from "@babel/runtime/helpers/esm/inherits";
5
+ import _possibleConstructorReturn from "@babel/runtime/helpers/esm/possibleConstructorReturn";
6
+ import _getPrototypeOf from "@babel/runtime/helpers/esm/getPrototypeOf";
7
+ import _extends from "@babel/runtime/helpers/esm/extends";
8
+ var _excluded = ["className", "hasSelected", "isInner", "type", "value"];
9
+
10
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
11
+
12
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
13
+
14
+ import * as React from 'react';
15
+ import { styled } from '@mui/material/styles';
16
+ import { CLOCK_WIDTH, CLOCK_HOUR_WIDTH } from './shared';
17
+ import { jsx as _jsx } from "react/jsx-runtime";
18
+ var ClockPointerRoot = styled('div')(function (_ref) {
19
+ var theme = _ref.theme,
20
+ ownerState = _ref.ownerState;
21
+ return _extends({
22
+ width: 2,
23
+ backgroundColor: theme.palette.primary.main,
24
+ position: 'absolute',
25
+ left: 'calc(50% - 1px)',
26
+ bottom: '50%',
27
+ transformOrigin: 'center bottom 0px'
28
+ }, ownerState.toAnimateTransform && {
29
+ transition: theme.transitions.create(['transform', 'height'])
30
+ });
31
+ });
32
+ var ClockPointerThumb = styled('div')(function (_ref2) {
33
+ var theme = _ref2.theme,
34
+ ownerState = _ref2.ownerState;
35
+ return _extends({
36
+ width: 4,
37
+ height: 4,
38
+ backgroundColor: theme.palette.primary.contrastText,
39
+ borderRadius: '50%',
40
+ position: 'absolute',
41
+ top: -21,
42
+ left: "calc(50% - ".concat(CLOCK_HOUR_WIDTH / 2, "px)"),
43
+ border: "".concat((CLOCK_HOUR_WIDTH - 4) / 2, "px solid ").concat(theme.palette.primary.main),
44
+ boxSizing: 'content-box'
45
+ }, ownerState.hasSelected && {
46
+ backgroundColor: theme.palette.primary.main
47
+ });
48
+ });
49
+ /**
50
+ * @ignore - internal component.
51
+ * TODO: Remove class
52
+ */
53
+
54
+ export var ClockPointer = /*#__PURE__*/function (_React$Component) {
55
+ _inherits(ClockPointer, _React$Component);
56
+
57
+ var _super = _createSuper(ClockPointer);
58
+
59
+ function ClockPointer() {
60
+ var _this;
61
+
62
+ _classCallCheck(this, ClockPointer);
63
+
64
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
65
+ args[_key] = arguments[_key];
66
+ }
67
+
68
+ _this = _super.call.apply(_super, [this].concat(args));
69
+ _this.state = {
70
+ toAnimateTransform: false,
71
+ previousType: undefined
72
+ };
73
+ return _this;
74
+ }
75
+
76
+ _createClass(ClockPointer, [{
77
+ key: "render",
78
+ value: function render() {
79
+ var _this$props = this.props,
80
+ className = _this$props.className,
81
+ hasSelected = _this$props.hasSelected,
82
+ isInner = _this$props.isInner,
83
+ type = _this$props.type,
84
+ value = _this$props.value,
85
+ other = _objectWithoutProperties(_this$props, _excluded);
86
+
87
+ var ownerState = _extends({}, this.props, this.state);
88
+
89
+ var getAngleStyle = function getAngleStyle() {
90
+ var max = type === 'hours' ? 12 : 60;
91
+ var angle = 360 / max * value;
92
+
93
+ if (type === 'hours' && value > 12) {
94
+ angle -= 360; // round up angle to max 360 degrees
95
+ }
96
+
97
+ return {
98
+ height: Math.round((isInner ? 0.26 : 0.4) * CLOCK_WIDTH),
99
+ transform: "rotateZ(".concat(angle, "deg)")
100
+ };
101
+ };
102
+
103
+ return /*#__PURE__*/_jsx(ClockPointerRoot, _extends({
104
+ style: getAngleStyle(),
105
+ className: className,
106
+ ownerState: ownerState
107
+ }, other, {
108
+ children: /*#__PURE__*/_jsx(ClockPointerThumb, {
109
+ ownerState: ownerState
110
+ })
111
+ }));
112
+ }
113
+ }]);
114
+
115
+ return ClockPointer;
116
+ }(React.Component);
117
+
118
+ ClockPointer.getDerivedStateFromProps = function (nextProps, state) {
119
+ if (nextProps.type !== state.previousType) {
120
+ return {
121
+ toAnimateTransform: true,
122
+ previousType: nextProps.type
123
+ };
124
+ }
125
+
126
+ return {
127
+ toAnimateTransform: false,
128
+ previousType: nextProps.type
129
+ };
130
+ };
@@ -0,0 +1,5 @@
1
+ import { generateUtilityClass, generateUtilityClasses } from '@mui/material';
2
+ export function getClockPickerUtilityClass(slot) {
3
+ return generateUtilityClass('MuiClockPicker', slot);
4
+ }
5
+ export var clockPickerClasses = generateUtilityClasses('MuiClockPicker', ['root', 'arrowSwitcher']);
@@ -0,0 +1,2 @@
1
+ export { ClockPicker } from './ClockPicker';
2
+ export { clockPickerClasses, getClockPickerUtilityClass } from './clockPickerClasses';
@@ -0,0 +1,61 @@
1
+ export var CLOCK_WIDTH = 220;
2
+ export var CLOCK_HOUR_WIDTH = 36;
3
+ var clockCenter = {
4
+ x: CLOCK_WIDTH / 2,
5
+ y: CLOCK_WIDTH / 2
6
+ };
7
+ var baseClockPoint = {
8
+ x: clockCenter.x,
9
+ y: 0
10
+ };
11
+ var cx = baseClockPoint.x - clockCenter.x;
12
+ var cy = baseClockPoint.y - clockCenter.y;
13
+
14
+ var rad2deg = function rad2deg(rad) {
15
+ return rad * (180 / Math.PI);
16
+ };
17
+
18
+ var getAngleValue = function getAngleValue(step, offsetX, offsetY) {
19
+ var x = offsetX - clockCenter.x;
20
+ var y = offsetY - clockCenter.y;
21
+ var atan = Math.atan2(cx, cy) - Math.atan2(x, y);
22
+ var deg = rad2deg(atan);
23
+ deg = Math.round(deg / step) * step;
24
+ deg %= 360;
25
+ var value = Math.floor(deg / step) || 0;
26
+ var delta = Math.pow(x, 2) + Math.pow(y, 2);
27
+ var distance = Math.sqrt(delta);
28
+ return {
29
+ value: value,
30
+ distance: distance
31
+ };
32
+ };
33
+
34
+ export var getMinutes = function getMinutes(offsetX, offsetY) {
35
+ var step = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;
36
+ var angleStep = step * 6;
37
+
38
+ var _getAngleValue = getAngleValue(angleStep, offsetX, offsetY),
39
+ value = _getAngleValue.value;
40
+
41
+ value = value * step % 60;
42
+ return value;
43
+ };
44
+ export var getHours = function getHours(offsetX, offsetY, ampm) {
45
+ var _getAngleValue2 = getAngleValue(30, offsetX, offsetY),
46
+ value = _getAngleValue2.value,
47
+ distance = _getAngleValue2.distance;
48
+
49
+ var hour = value || 12;
50
+
51
+ if (!ampm) {
52
+ if (distance < CLOCK_WIDTH / 2 - CLOCK_HOUR_WIDTH) {
53
+ hour += 12;
54
+ hour %= 24;
55
+ }
56
+ } else {
57
+ hour %= 12;
58
+ }
59
+
60
+ return hour;
61
+ };