@mui/x-date-pickers 6.10.2 → 6.11.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 (138) hide show
  1. package/AdapterDayjs/AdapterDayjs.d.ts +8 -1
  2. package/AdapterDayjs/AdapterDayjs.js +66 -38
  3. package/CHANGELOG.md +92 -0
  4. package/DateCalendar/DateCalendar.d.ts +1 -1
  5. package/DateCalendar/DateCalendar.js +48 -38
  6. package/DateCalendar/DateCalendar.types.d.ts +9 -1
  7. package/DateCalendar/index.d.ts +1 -2
  8. package/DateCalendar/index.js +3 -2
  9. package/DateCalendar/useCalendarState.d.ts +1 -1
  10. package/DateField/DateField.d.ts +1 -1
  11. package/DateField/DateField.js +2 -2
  12. package/DatePicker/DatePicker.d.ts +1 -1
  13. package/DatePicker/DatePickerToolbar.d.ts +1 -1
  14. package/DateTimeField/DateTimeField.d.ts +1 -1
  15. package/DateTimeField/DateTimeField.js +2 -2
  16. package/DateTimePicker/DateTimePicker.d.ts +1 -1
  17. package/DayCalendarSkeleton/DayCalendarSkeleton.d.ts +1 -1
  18. package/DesktopDatePicker/DesktopDatePicker.d.ts +1 -1
  19. package/DesktopDatePicker/DesktopDatePicker.js +2 -2
  20. package/DesktopDateTimePicker/DesktopDateTimePicker.d.ts +1 -1
  21. package/DesktopDateTimePicker/DesktopDateTimePicker.js +2 -2
  22. package/DesktopTimePicker/DesktopTimePicker.d.ts +1 -1
  23. package/DesktopTimePicker/DesktopTimePicker.js +2 -2
  24. package/DigitalClock/DigitalClock.d.ts +1 -1
  25. package/LocalizationProvider/LocalizationProvider.d.ts +1 -1
  26. package/MobileDatePicker/MobileDatePicker.d.ts +1 -1
  27. package/MobileDatePicker/MobileDatePicker.js +2 -2
  28. package/MobileDateTimePicker/MobileDateTimePicker.d.ts +1 -1
  29. package/MobileDateTimePicker/MobileDateTimePicker.js +2 -2
  30. package/MobileTimePicker/MobileTimePicker.d.ts +1 -1
  31. package/MobileTimePicker/MobileTimePicker.js +2 -2
  32. package/MonthCalendar/MonthCalendar.d.ts +1 -1
  33. package/MultiSectionDigitalClock/MultiSectionDigitalClock.d.ts +1 -1
  34. package/MultiSectionDigitalClock/MultiSectionDigitalClockSection.d.ts +1 -1
  35. package/{DateCalendar → PickersCalendarHeader}/PickersCalendarHeader.d.ts +21 -9
  36. package/{DateCalendar → PickersCalendarHeader}/PickersCalendarHeader.js +72 -28
  37. package/PickersCalendarHeader/index.d.ts +4 -0
  38. package/PickersCalendarHeader/index.js +2 -0
  39. package/PickersCalendarHeader/package.json +6 -0
  40. package/PickersDay/PickersDay.d.ts +1 -1
  41. package/StaticDatePicker/StaticDatePicker.d.ts +1 -1
  42. package/StaticDateTimePicker/StaticDateTimePicker.d.ts +1 -1
  43. package/StaticTimePicker/StaticTimePicker.d.ts +1 -1
  44. package/TimeClock/ClockNumbers.d.ts +1 -1
  45. package/TimeClock/TimeClock.d.ts +1 -1
  46. package/TimeField/TimeField.d.ts +1 -1
  47. package/TimeField/TimeField.js +2 -2
  48. package/TimePicker/TimePicker.d.ts +1 -1
  49. package/YearCalendar/YearCalendar.d.ts +2 -2
  50. package/index.js +1 -1
  51. package/internals/components/PickersModalDialog.d.ts +2 -2
  52. package/internals/components/PickersPopper.d.ts +3 -3
  53. package/internals/components/PickersToolbar.d.ts +1 -1
  54. package/internals/hooks/date-helpers-hooks.d.ts +1 -2
  55. package/internals/hooks/useDefaultReduceAnimations.d.ts +2 -0
  56. package/internals/hooks/useDefaultReduceAnimations.js +9 -0
  57. package/internals/hooks/useField/useField.js +9 -4
  58. package/internals/hooks/useField/useField.utils.d.ts +1 -1
  59. package/internals/hooks/useField/useField.utils.js +6 -5
  60. package/internals/index.d.ts +1 -3
  61. package/internals/index.js +1 -2
  62. package/internals/utils/valueManagers.js +1 -1
  63. package/legacy/AdapterDayjs/AdapterDayjs.js +64 -38
  64. package/legacy/DateCalendar/DateCalendar.js +50 -40
  65. package/legacy/DateCalendar/index.js +3 -2
  66. package/legacy/DateField/DateField.js +2 -2
  67. package/legacy/DateTimeField/DateTimeField.js +2 -2
  68. package/legacy/DesktopDatePicker/DesktopDatePicker.js +2 -2
  69. package/legacy/DesktopDateTimePicker/DesktopDateTimePicker.js +2 -2
  70. package/legacy/DesktopTimePicker/DesktopTimePicker.js +2 -2
  71. package/legacy/MobileDatePicker/MobileDatePicker.js +2 -2
  72. package/legacy/MobileDateTimePicker/MobileDateTimePicker.js +2 -2
  73. package/legacy/MobileTimePicker/MobileTimePicker.js +2 -2
  74. package/legacy/{DateCalendar → PickersCalendarHeader}/PickersCalendarHeader.js +57 -13
  75. package/legacy/PickersCalendarHeader/index.js +2 -0
  76. package/legacy/TimeField/TimeField.js +2 -2
  77. package/legacy/index.js +1 -1
  78. package/legacy/internals/hooks/useDefaultReduceAnimations.js +9 -0
  79. package/legacy/internals/hooks/useField/useField.js +9 -4
  80. package/legacy/internals/hooks/useField/useField.utils.js +6 -5
  81. package/legacy/internals/index.js +1 -2
  82. package/legacy/internals/utils/valueManagers.js +1 -1
  83. package/legacy/tests/describeGregorianAdapter/testCalculations.js +63 -16
  84. package/modern/AdapterDayjs/AdapterDayjs.js +65 -38
  85. package/modern/DateCalendar/DateCalendar.js +46 -38
  86. package/modern/DateCalendar/index.js +3 -2
  87. package/modern/DateField/DateField.js +2 -2
  88. package/modern/DateTimeField/DateTimeField.js +2 -2
  89. package/modern/DesktopDatePicker/DesktopDatePicker.js +1 -1
  90. package/modern/DesktopDateTimePicker/DesktopDateTimePicker.js +1 -1
  91. package/modern/DesktopTimePicker/DesktopTimePicker.js +1 -1
  92. package/modern/MobileDatePicker/MobileDatePicker.js +1 -1
  93. package/modern/MobileDateTimePicker/MobileDateTimePicker.js +1 -1
  94. package/modern/MobileTimePicker/MobileTimePicker.js +1 -1
  95. package/modern/{DateCalendar → PickersCalendarHeader}/PickersCalendarHeader.js +72 -28
  96. package/modern/PickersCalendarHeader/index.js +2 -0
  97. package/modern/TimeField/TimeField.js +2 -2
  98. package/modern/index.js +1 -1
  99. package/modern/internals/hooks/useDefaultReduceAnimations.js +9 -0
  100. package/modern/internals/hooks/useField/useField.js +9 -4
  101. package/modern/internals/hooks/useField/useField.utils.js +6 -5
  102. package/modern/internals/index.js +1 -2
  103. package/modern/internals/utils/valueManagers.js +1 -1
  104. package/modern/tests/describeGregorianAdapter/testCalculations.js +63 -16
  105. package/node/AdapterDayjs/AdapterDayjs.js +65 -38
  106. package/node/DateCalendar/DateCalendar.js +52 -44
  107. package/node/DateCalendar/index.js +21 -8
  108. package/node/DateField/DateField.js +2 -2
  109. package/node/DateTimeField/DateTimeField.js +2 -2
  110. package/node/DesktopDatePicker/DesktopDatePicker.js +1 -1
  111. package/node/DesktopDateTimePicker/DesktopDateTimePicker.js +1 -1
  112. package/node/DesktopTimePicker/DesktopTimePicker.js +1 -1
  113. package/node/MobileDatePicker/MobileDatePicker.js +1 -1
  114. package/node/MobileDateTimePicker/MobileDateTimePicker.js +1 -1
  115. package/node/MobileTimePicker/MobileTimePicker.js +1 -1
  116. package/node/{DateCalendar → PickersCalendarHeader}/PickersCalendarHeader.js +73 -29
  117. package/node/PickersCalendarHeader/index.js +19 -0
  118. package/node/TimeField/TimeField.js +2 -2
  119. package/node/index.js +1 -1
  120. package/node/internals/hooks/useDefaultReduceAnimations.js +18 -0
  121. package/node/internals/hooks/useField/useField.js +9 -4
  122. package/node/internals/hooks/useField/useField.utils.js +6 -5
  123. package/node/internals/index.js +7 -14
  124. package/node/internals/utils/valueManagers.js +1 -1
  125. package/node/tests/describeGregorianAdapter/testCalculations.js +61 -16
  126. package/package.json +2 -2
  127. package/tests/describeGregorianAdapter/testCalculations.js +63 -16
  128. package/themeAugmentation/props.d.ts +2 -2
  129. package/internals/utils/defaultReduceAnimations.d.ts +0 -1
  130. package/internals/utils/defaultReduceAnimations.js +0 -1
  131. package/legacy/internals/utils/defaultReduceAnimations.js +0 -1
  132. package/modern/internals/utils/defaultReduceAnimations.js +0 -1
  133. package/node/internals/utils/defaultReduceAnimations.js +0 -8
  134. /package/{DateCalendar → PickersCalendarHeader}/pickersCalendarHeaderClasses.d.ts +0 -0
  135. /package/{DateCalendar → PickersCalendarHeader}/pickersCalendarHeaderClasses.js +0 -0
  136. /package/legacy/{DateCalendar → PickersCalendarHeader}/pickersCalendarHeaderClasses.js +0 -0
  137. /package/modern/{DateCalendar → PickersCalendarHeader}/pickersCalendarHeaderClasses.js +0 -0
  138. /package/node/{DateCalendar → PickersCalendarHeader}/pickersCalendarHeaderClasses.js +0 -0
@@ -12,7 +12,7 @@ import { extractValidationProps } from '../internals/utils/validation/extractVal
12
12
  import { renderDateViewCalendar } from '../dateViewRenderers';
13
13
  import { resolveDateFormat } from '../internals/utils/date-utils';
14
14
  const DesktopDatePicker = /*#__PURE__*/React.forwardRef(function DesktopDatePicker(inProps, ref) {
15
- var _defaultizedProps$yea, _defaultizedProps$slo2;
15
+ var _defaultizedProps$yea, _defaultizedProps$slo2, _props$localeText$ope, _props$localeText;
16
16
  const localeText = useLocaleText();
17
17
  const utils = useUtils();
18
18
 
@@ -51,7 +51,7 @@ const DesktopDatePicker = /*#__PURE__*/React.forwardRef(function DesktopDatePick
51
51
  props,
52
52
  valueManager: singleItemValueManager,
53
53
  valueType: 'date',
54
- getOpenDialogAriaText: localeText.openDatePickerDialogue,
54
+ getOpenDialogAriaText: (_props$localeText$ope = (_props$localeText = props.localeText) == null ? void 0 : _props$localeText.openDatePickerDialogue) != null ? _props$localeText$ope : localeText.openDatePickerDialogue,
55
55
  validator: validateDate
56
56
  });
57
57
  return renderPicker();
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { DesktopDateTimePickerProps } from './DesktopDateTimePicker.types';
3
- type DesktopDateTimePickerComponent = (<TDate>(props: DesktopDateTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type DesktopDateTimePickerComponent = (<TDate>(props: DesktopDateTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const DesktopDateTimePicker: DesktopDateTimePickerComponent;
@@ -14,7 +14,7 @@ import { useDesktopPicker } from '../internals/hooks/useDesktopPicker';
14
14
  import { extractValidationProps } from '../internals/utils/validation/extractValidationProps';
15
15
  import { resolveDateTimeFormat } from '../internals/utils/date-time-utils';
16
16
  const DesktopDateTimePicker = /*#__PURE__*/React.forwardRef(function DesktopDateTimePicker(inProps, ref) {
17
- var _defaultizedProps$amp, _defaultizedProps$yea, _defaultizedProps$slo2, _defaultizedProps$slo3, _defaultizedProps$slo4;
17
+ var _defaultizedProps$amp, _defaultizedProps$yea, _defaultizedProps$slo2, _defaultizedProps$slo3, _defaultizedProps$slo4, _props$localeText$ope, _props$localeText;
18
18
  const localeText = useLocaleText();
19
19
  const utils = useUtils();
20
20
 
@@ -87,7 +87,7 @@ const DesktopDateTimePicker = /*#__PURE__*/React.forwardRef(function DesktopDate
87
87
  props,
88
88
  valueManager: singleItemValueManager,
89
89
  valueType: 'date-time',
90
- getOpenDialogAriaText: localeText.openDatePickerDialogue,
90
+ getOpenDialogAriaText: (_props$localeText$ope = (_props$localeText = props.localeText) == null ? void 0 : _props$localeText.openDatePickerDialogue) != null ? _props$localeText$ope : localeText.openDatePickerDialogue,
91
91
  validator: validateDateTime
92
92
  });
93
93
  return renderPicker();
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { DesktopTimePickerProps } from './DesktopTimePicker.types';
3
- type DesktopTimePickerComponent = (<TDate>(props: DesktopTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type DesktopTimePickerComponent = (<TDate>(props: DesktopTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const DesktopTimePicker: DesktopTimePickerComponent;
@@ -13,7 +13,7 @@ import { extractValidationProps } from '../internals/utils/validation/extractVal
13
13
  import { renderDigitalClockTimeView, renderMultiSectionDigitalClockTimeView } from '../timeViewRenderers';
14
14
  import { resolveTimeFormat } from '../internals/utils/time-utils';
15
15
  const DesktopTimePicker = /*#__PURE__*/React.forwardRef(function DesktopTimePicker(inProps, ref) {
16
- var _defaultizedProps$thr, _defaultizedProps$amp, _viewRenderers$hours, _defaultizedProps$slo2, _defaultizedProps$slo3;
16
+ var _defaultizedProps$thr, _defaultizedProps$amp, _viewRenderers$hours, _defaultizedProps$slo2, _defaultizedProps$slo3, _props$localeText$ope, _props$localeText;
17
17
  const localeText = useLocaleText();
18
18
  const utils = useUtils();
19
19
 
@@ -74,7 +74,7 @@ const DesktopTimePicker = /*#__PURE__*/React.forwardRef(function DesktopTimePick
74
74
  props,
75
75
  valueManager: singleItemValueManager,
76
76
  valueType: 'time',
77
- getOpenDialogAriaText: localeText.openTimePickerDialogue,
77
+ getOpenDialogAriaText: (_props$localeText$ope = (_props$localeText = props.localeText) == null ? void 0 : _props$localeText.openTimePickerDialogue) != null ? _props$localeText$ope : localeText.openTimePickerDialogue,
78
78
  validator: validateTime
79
79
  });
80
80
  return renderPicker();
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { DigitalClockProps } from './DigitalClock.types';
3
- type DigitalClockComponent = (<TDate>(props: DigitalClockProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type DigitalClockComponent = (<TDate>(props: DigitalClockProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  export declare const DigitalClock: DigitalClockComponent;
@@ -38,7 +38,7 @@ export interface LocalizationProviderProps<TDate, TLocale> {
38
38
  */
39
39
  localeText?: PickersInputLocaleText<TDate>;
40
40
  }
41
- type LocalizationProviderComponent = (<TDate, TLocale>(props: LocalizationProviderProps<TDate, TLocale>) => JSX.Element) & {
41
+ type LocalizationProviderComponent = (<TDate, TLocale>(props: LocalizationProviderProps<TDate, TLocale>) => React.JSX.Element) & {
42
42
  propTypes?: any;
43
43
  };
44
44
  /**
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { MobileDatePickerProps } from './MobileDatePicker.types';
3
- type MobileDatePickerComponent = (<TDate>(props: MobileDatePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type MobileDatePickerComponent = (<TDate>(props: MobileDatePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const MobileDatePicker: MobileDatePickerComponent;
@@ -11,7 +11,7 @@ import { singleItemValueManager } from '../internals/utils/valueManagers';
11
11
  import { renderDateViewCalendar } from '../dateViewRenderers';
12
12
  import { resolveDateFormat } from '../internals/utils/date-utils';
13
13
  const MobileDatePicker = /*#__PURE__*/React.forwardRef(function MobileDatePicker(inProps, ref) {
14
- var _defaultizedProps$slo2;
14
+ var _defaultizedProps$slo2, _props$localeText$ope, _props$localeText;
15
15
  const localeText = useLocaleText();
16
16
  const utils = useUtils();
17
17
 
@@ -48,7 +48,7 @@ const MobileDatePicker = /*#__PURE__*/React.forwardRef(function MobileDatePicker
48
48
  props,
49
49
  valueManager: singleItemValueManager,
50
50
  valueType: 'date',
51
- getOpenDialogAriaText: localeText.openDatePickerDialogue,
51
+ getOpenDialogAriaText: (_props$localeText$ope = (_props$localeText = props.localeText) == null ? void 0 : _props$localeText.openDatePickerDialogue) != null ? _props$localeText$ope : localeText.openDatePickerDialogue,
52
52
  validator: validateDate
53
53
  });
54
54
  return renderPicker();
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { MobileDateTimePickerProps } from './MobileDateTimePicker.types';
3
- type MobileDateTimePickerComponent = (<TDate>(props: MobileDateTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type MobileDateTimePickerComponent = (<TDate>(props: MobileDateTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const MobileDateTimePicker: MobileDateTimePickerComponent;
@@ -13,7 +13,7 @@ import { renderDateViewCalendar } from '../dateViewRenderers';
13
13
  import { renderTimeViewClock } from '../timeViewRenderers';
14
14
  import { resolveDateTimeFormat } from '../internals/utils/date-time-utils';
15
15
  const MobileDateTimePicker = /*#__PURE__*/React.forwardRef(function MobileDateTimePicker(inProps, ref) {
16
- var _defaultizedProps$amp, _defaultizedProps$slo2, _defaultizedProps$slo3;
16
+ var _defaultizedProps$amp, _defaultizedProps$slo2, _defaultizedProps$slo3, _props$localeText$ope, _props$localeText;
17
17
  const localeText = useLocaleText();
18
18
  const utils = useUtils();
19
19
 
@@ -59,7 +59,7 @@ const MobileDateTimePicker = /*#__PURE__*/React.forwardRef(function MobileDateTi
59
59
  props,
60
60
  valueManager: singleItemValueManager,
61
61
  valueType: 'date-time',
62
- getOpenDialogAriaText: localeText.openDatePickerDialogue,
62
+ getOpenDialogAriaText: (_props$localeText$ope = (_props$localeText = props.localeText) == null ? void 0 : _props$localeText.openDatePickerDialogue) != null ? _props$localeText$ope : localeText.openDatePickerDialogue,
63
63
  validator: validateDateTime
64
64
  });
65
65
  return renderPicker();
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { MobileTimePickerProps } from './MobileTimePicker.types';
3
- type MobileTimePickerComponent = (<TDate>(props: MobileTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type MobileTimePickerComponent = (<TDate>(props: MobileTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const MobileTimePicker: MobileTimePickerComponent;
@@ -12,7 +12,7 @@ import { extractValidationProps } from '../internals/utils/validation/extractVal
12
12
  import { renderTimeViewClock } from '../timeViewRenderers';
13
13
  import { resolveTimeFormat } from '../internals/utils/time-utils';
14
14
  const MobileTimePicker = /*#__PURE__*/React.forwardRef(function MobileTimePicker(inProps, ref) {
15
- var _defaultizedProps$amp, _defaultizedProps$slo2;
15
+ var _defaultizedProps$amp, _defaultizedProps$slo2, _props$localeText$ope, _props$localeText;
16
16
  const localeText = useLocaleText();
17
17
  const utils = useUtils();
18
18
 
@@ -52,7 +52,7 @@ const MobileTimePicker = /*#__PURE__*/React.forwardRef(function MobileTimePicker
52
52
  props,
53
53
  valueManager: singleItemValueManager,
54
54
  valueType: 'time',
55
- getOpenDialogAriaText: localeText.openTimePickerDialogue,
55
+ getOpenDialogAriaText: (_props$localeText$ope = (_props$localeText = props.localeText) == null ? void 0 : _props$localeText.openTimePickerDialogue) != null ? _props$localeText$ope : localeText.openTimePickerDialogue,
56
56
  validator: validateTime
57
57
  });
58
58
  return renderPicker();
@@ -2,7 +2,7 @@ import * as React from 'react';
2
2
  import { DefaultizedProps } from '../internals/models/helpers';
3
3
  import { MonthCalendarProps } from './MonthCalendar.types';
4
4
  export declare function useMonthCalendarDefaultizedProps<TDate>(props: MonthCalendarProps<TDate>, name: string): DefaultizedProps<MonthCalendarProps<TDate>, 'minDate' | 'maxDate' | 'disableFuture' | 'disablePast'>;
5
- type MonthCalendarComponent = (<TDate>(props: MonthCalendarProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
5
+ type MonthCalendarComponent = (<TDate>(props: MonthCalendarProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
6
6
  propTypes?: any;
7
7
  };
8
8
  export declare const MonthCalendar: MonthCalendarComponent;
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { MultiSectionDigitalClockProps } from './MultiSectionDigitalClock.types';
3
- type MultiSectionDigitalClockComponent = (<TDate>(props: MultiSectionDigitalClockProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type MultiSectionDigitalClockComponent = (<TDate>(props: MultiSectionDigitalClockProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  export declare const MultiSectionDigitalClock: MultiSectionDigitalClockComponent;
@@ -18,7 +18,7 @@ export interface MultiSectionDigitalClockSectionProps<TValue> extends ExportedMu
18
18
  skipDisabled?: boolean;
19
19
  role?: string;
20
20
  }
21
- type MultiSectionDigitalClockSectionComponent = <TValue>(props: MultiSectionDigitalClockSectionProps<TValue> & React.RefAttributes<HTMLUListElement>) => JSX.Element & {
21
+ type MultiSectionDigitalClockSectionComponent = <TValue>(props: MultiSectionDigitalClockSectionProps<TValue> & React.RefAttributes<HTMLUListElement>) => React.JSX.Element & {
22
22
  propTypes?: any;
23
23
  };
24
24
  /**
@@ -1,14 +1,15 @@
1
1
  import * as React from 'react';
2
+ import { SxProps, Theme } from '@mui/material/styles';
2
3
  import { SlotComponentProps } from '@mui/base/utils';
3
4
  import IconButton from '@mui/material/IconButton';
4
5
  import SvgIcon from '@mui/material/SvgIcon';
5
- import { SlideDirection } from './PickersSlideTransition';
6
- import { DateComponentValidationProps } from '../internals/utils/validation/validateDate';
6
+ import { SlideDirection } from '../DateCalendar/PickersSlideTransition';
7
7
  import { ExportedPickersArrowSwitcherProps, PickersArrowSwitcherSlotsComponent, PickersArrowSwitcherSlotsComponentsProps } from '../internals/components/PickersArrowSwitcher';
8
+ import { MonthValidationOptions } from '../internals/hooks/date-helpers-hooks';
8
9
  import { DateView } from '../models';
9
10
  import { PickersCalendarHeaderClasses } from './pickersCalendarHeaderClasses';
10
11
  import { UncapitalizeObjectKeys } from '../internals/utils/slots-migration';
11
- export type ExportedCalendarHeaderProps<TDate> = Pick<PickersCalendarHeaderProps<TDate>, 'classes'>;
12
+ export type ExportedPickersCalendarHeaderProps<TDate> = Pick<PickersCalendarHeaderProps<TDate>, 'classes' | 'slots' | 'slotProps'>;
12
13
  export interface PickersCalendarHeaderSlotsComponent extends PickersArrowSwitcherSlotsComponent {
13
14
  /**
14
15
  * Button displayed to switch between different calendar views.
@@ -28,7 +29,7 @@ export interface PickersCalendarHeaderSlotsComponentsProps<TDate> extends Picker
28
29
  switchViewButton?: SlotComponentProps<typeof IconButton, PickersCalendarHeaderComponentsPropsOverrides, PickersCalendarHeaderOwnerState<TDate>>;
29
30
  switchViewIcon?: SlotComponentProps<typeof SvgIcon, PickersCalendarHeaderComponentsPropsOverrides, undefined>;
30
31
  }
31
- export interface PickersCalendarHeaderProps<TDate> extends ExportedPickersArrowSwitcherProps, DateComponentValidationProps<TDate> {
32
+ export interface PickersCalendarHeaderProps<TDate> extends ExportedPickersArrowSwitcherProps, MonthValidationOptions<TDate> {
32
33
  /**
33
34
  * Overridable component slots.
34
35
  * @default {}
@@ -47,10 +48,21 @@ export interface PickersCalendarHeaderProps<TDate> extends ExportedPickersArrowS
47
48
  reduceAnimations: boolean;
48
49
  onViewChange?: (view: DateView) => void;
49
50
  labelId?: string;
51
+ /**
52
+ * Override or extend the styles applied to the component.
53
+ */
50
54
  classes?: Partial<PickersCalendarHeaderClasses>;
55
+ /**
56
+ * className applied to the root element.
57
+ */
58
+ className?: string;
59
+ /**
60
+ * The system prop that allows defining system overrides as well as additional CSS styles.
61
+ */
62
+ sx?: SxProps<Theme>;
51
63
  }
52
- /**
53
- * @ignore - do not document.
54
- */
55
- export declare function PickersCalendarHeader<TDate>(inProps: PickersCalendarHeaderProps<TDate>): React.JSX.Element | null;
56
- export {};
64
+ type PickersCalendarHeaderComponent = (<TDate>(props: PickersCalendarHeaderProps<TDate> & React.RefAttributes<HTMLButtonElement>) => React.JSX.Element) & {
65
+ propTypes?: any;
66
+ };
67
+ declare const PickersCalendarHeader: PickersCalendarHeaderComponent;
68
+ export { PickersCalendarHeader };
@@ -1,14 +1,17 @@
1
1
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
2
2
  import _extends from "@babel/runtime/helpers/esm/extends";
3
- const _excluded = ["ownerState"];
3
+ const _excluded = ["slots", "slotProps", "currentMonth", "disabled", "disableFuture", "disablePast", "maxDate", "minDate", "onMonthChange", "onViewChange", "view", "reduceAnimations", "views", "labelId", "className", "timezone"],
4
+ _excluded2 = ["ownerState"];
4
5
  import * as React from 'react';
6
+ import PropTypes from 'prop-types';
7
+ import clsx from 'clsx';
5
8
  import Fade from '@mui/material/Fade';
6
9
  import { styled, useThemeProps } from '@mui/material/styles';
7
10
  import { useSlotProps } from '@mui/base/utils';
8
11
  import { unstable_composeClasses as composeClasses } from '@mui/utils';
9
12
  import IconButton from '@mui/material/IconButton';
10
13
  import { useLocaleText, useUtils } from '../internals/hooks/useUtils';
11
- import { PickersFadeTransitionGroup } from './PickersFadeTransitionGroup';
14
+ import { PickersFadeTransitionGroup } from '../DateCalendar/PickersFadeTransitionGroup';
12
15
  import { ArrowDropDownIcon } from '../icons';
13
16
  import { PickersArrowSwitcher } from '../internals/components/PickersArrowSwitcher';
14
17
  import { usePreviousMonthDisabled, useNextMonthDisabled } from '../internals/hooks/date-helpers-hooks';
@@ -91,11 +94,7 @@ const PickersCalendarHeaderSwitchViewIcon = styled(ArrowDropDownIcon, {
91
94
  transition: theme.transitions.create('transform'),
92
95
  transform: 'rotate(0deg)'
93
96
  }));
94
-
95
- /**
96
- * @ignore - do not document.
97
- */
98
- export function PickersCalendarHeader(inProps) {
97
+ const PickersCalendarHeader = /*#__PURE__*/React.forwardRef(function PickersCalendarHeader(inProps, ref) {
99
98
  var _slots$switchViewButt, _slots$switchViewIcon;
100
99
  const localeText = useLocaleText();
101
100
  const utils = useUtils();
@@ -104,22 +103,24 @@ export function PickersCalendarHeader(inProps) {
104
103
  name: 'MuiPickersCalendarHeader'
105
104
  });
106
105
  const {
107
- slots,
108
- slotProps,
109
- currentMonth: month,
110
- disabled,
111
- disableFuture,
112
- disablePast,
113
- maxDate,
114
- minDate,
115
- onMonthChange,
116
- onViewChange,
117
- view,
118
- reduceAnimations,
119
- views,
120
- labelId,
121
- timezone
122
- } = props;
106
+ slots,
107
+ slotProps,
108
+ currentMonth: month,
109
+ disabled,
110
+ disableFuture,
111
+ disablePast,
112
+ maxDate,
113
+ minDate,
114
+ onMonthChange,
115
+ onViewChange,
116
+ view,
117
+ reduceAnimations,
118
+ views,
119
+ labelId,
120
+ className,
121
+ timezone
122
+ } = props,
123
+ other = _objectWithoutPropertiesLoose(props, _excluded);
123
124
  const ownerState = props;
124
125
  const classes = useUtilityClasses(props);
125
126
  const SwitchViewButton = (_slots$switchViewButt = slots == null ? void 0 : slots.switchViewButton) != null ? _slots$switchViewButt : PickersCalendarHeaderSwitchViewButton;
@@ -141,7 +142,7 @@ export function PickersCalendarHeader(inProps) {
141
142
  ownerState: undefined,
142
143
  className: classes.switchViewIcon
143
144
  }),
144
- switchViewIconProps = _objectWithoutPropertiesLoose(_useSlotProps, _excluded);
145
+ switchViewIconProps = _objectWithoutPropertiesLoose(_useSlotProps, _excluded2);
145
146
  const selectNextMonth = () => onMonthChange(utils.addMonths(month, 1), 'left');
146
147
  const selectPreviousMonth = () => onMonthChange(utils.addMonths(month, -1), 'right');
147
148
  const isNextMonthDisabled = useNextMonthDisabled(month, {
@@ -171,9 +172,10 @@ export function PickersCalendarHeader(inProps) {
171
172
  if (views.length === 1 && views[0] === 'year') {
172
173
  return null;
173
174
  }
174
- return /*#__PURE__*/_jsxs(PickersCalendarHeaderRoot, {
175
+ return /*#__PURE__*/_jsxs(PickersCalendarHeaderRoot, _extends({}, other, {
175
176
  ownerState: ownerState,
176
- className: classes.root,
177
+ className: clsx(className, classes.root),
178
+ ref: ref,
177
179
  children: [/*#__PURE__*/_jsxs(PickersCalendarHeaderLabelContainer, {
178
180
  role: "presentation",
179
181
  onClick: handleToggleView,
@@ -207,5 +209,47 @@ export function PickersCalendarHeader(inProps) {
207
209
  nextLabel: localeText.nextMonth
208
210
  })
209
211
  })]
210
- });
211
- }
212
+ }));
213
+ });
214
+ process.env.NODE_ENV !== "production" ? PickersCalendarHeader.propTypes = {
215
+ // ----------------------------- Warning --------------------------------
216
+ // | These PropTypes are generated from the TypeScript type definitions |
217
+ // | To update them edit the TypeScript types and run "yarn proptypes" |
218
+ // ----------------------------------------------------------------------
219
+ /**
220
+ * Override or extend the styles applied to the component.
221
+ */
222
+ classes: PropTypes.object,
223
+ /**
224
+ * className applied to the root element.
225
+ */
226
+ className: PropTypes.string,
227
+ currentMonth: PropTypes.any.isRequired,
228
+ disabled: PropTypes.bool,
229
+ disableFuture: PropTypes.bool,
230
+ disablePast: PropTypes.bool,
231
+ labelId: PropTypes.string,
232
+ maxDate: PropTypes.any.isRequired,
233
+ minDate: PropTypes.any.isRequired,
234
+ onMonthChange: PropTypes.func.isRequired,
235
+ onViewChange: PropTypes.func,
236
+ reduceAnimations: PropTypes.bool.isRequired,
237
+ /**
238
+ * The props used for each component slot.
239
+ * @default {}
240
+ */
241
+ slotProps: PropTypes.object,
242
+ /**
243
+ * Overridable component slots.
244
+ * @default {}
245
+ */
246
+ slots: PropTypes.object,
247
+ /**
248
+ * The system prop that allows defining system overrides as well as additional CSS styles.
249
+ */
250
+ sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),
251
+ timezone: PropTypes.string.isRequired,
252
+ view: PropTypes.oneOf(['day', 'month', 'year']).isRequired,
253
+ views: PropTypes.arrayOf(PropTypes.oneOf(['day', 'month', 'year']).isRequired).isRequired
254
+ } : void 0;
255
+ export { PickersCalendarHeader };
@@ -0,0 +1,4 @@
1
+ export { pickersCalendarHeaderClasses } from './pickersCalendarHeaderClasses';
2
+ export type { PickersCalendarHeaderClassKey, PickersCalendarHeaderClasses, } from './pickersCalendarHeaderClasses';
3
+ export { PickersCalendarHeader } from './PickersCalendarHeader';
4
+ export type { PickersCalendarHeaderProps, PickersCalendarHeaderSlotsComponent, PickersCalendarHeaderSlotsComponentsProps, ExportedPickersCalendarHeaderProps, } from './PickersCalendarHeader';
@@ -0,0 +1,2 @@
1
+ export { pickersCalendarHeaderClasses } from './pickersCalendarHeaderClasses';
2
+ export { PickersCalendarHeader } from './PickersCalendarHeader';
@@ -0,0 +1,6 @@
1
+ {
2
+ "sideEffects": false,
3
+ "module": "./index.js",
4
+ "main": "../node/PickersCalendarHeader/index.js",
5
+ "types": "./index.d.ts"
6
+ }
@@ -70,7 +70,7 @@ export interface PickersDayProps<TDate> extends ExportedPickersDayProps, Omit<Ex
70
70
  */
71
71
  today?: boolean;
72
72
  }
73
- type PickersDayComponent = (<TDate>(props: PickersDayProps<TDate> & React.RefAttributes<HTMLButtonElement>) => JSX.Element) & {
73
+ type PickersDayComponent = (<TDate>(props: PickersDayProps<TDate> & React.RefAttributes<HTMLButtonElement>) => React.JSX.Element) & {
74
74
  propTypes?: any;
75
75
  };
76
76
  /**
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { StaticDatePickerProps } from './StaticDatePicker.types';
3
- type StaticDatePickerComponent = (<TDate>(props: StaticDatePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type StaticDatePickerComponent = (<TDate>(props: StaticDatePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const StaticDatePicker: StaticDatePickerComponent;
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { StaticDateTimePickerProps } from './StaticDateTimePicker.types';
3
- type StaticDateTimePickerComponent = (<TDate>(props: StaticDateTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type StaticDateTimePickerComponent = (<TDate>(props: StaticDateTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const StaticDateTimePicker: StaticDateTimePickerComponent;
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { StaticTimePickerProps } from './StaticTimePicker.types';
3
- type StaticTimePickerComponent = (<TDate>(props: StaticTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type StaticTimePickerComponent = (<TDate>(props: StaticTimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const StaticTimePicker: StaticTimePickerComponent;
@@ -17,7 +17,7 @@ interface GetHourNumbersOptions<TDate> {
17
17
  /**
18
18
  * @ignore - internal component.
19
19
  */
20
- export declare const getHourNumbers: <TDate extends unknown>({ ampm, value, getClockNumberText, isDisabled, selectedId, utils, }: GetHourNumbersOptions<TDate>) => JSX.Element[];
20
+ export declare const getHourNumbers: <TDate extends unknown>({ ampm, value, getClockNumberText, isDisabled, selectedId, utils, }: GetHourNumbersOptions<TDate>) => React.JSX.Element[];
21
21
  export declare const getMinutesNumbers: <TDate extends unknown>({ utils, value, isDisabled, getClockNumberText, selectedId, }: Omit<GetHourNumbersOptions<TDate>, "value" | "ampm"> & {
22
22
  value: number;
23
23
  }) => React.JSX.Element[];
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { TimeClockProps } from './TimeClock.types';
3
- type TimeClockComponent = (<TDate>(props: TimeClockProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type TimeClockComponent = (<TDate>(props: TimeClockProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  /**
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { TimeFieldProps } from './TimeField.types';
3
- type TimeFieldComponent = (<TDate>(props: TimeFieldProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type TimeFieldComponent = (<TDate>(props: TimeFieldProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const TimeField: TimeFieldComponent;
@@ -39,8 +39,8 @@ const TimeField = /*#__PURE__*/React.forwardRef(function TimeField(inProps, ref)
39
39
  textFieldProps = _objectWithoutPropertiesLoose(_useSlotProps, _excluded2);
40
40
 
41
41
  // TODO: Remove when mui/material-ui#35088 will be merged
42
- textFieldProps.inputProps = _extends({}, textFieldProps.inputProps, inputProps);
43
- textFieldProps.InputProps = _extends({}, textFieldProps.InputProps, InputProps);
42
+ textFieldProps.inputProps = _extends({}, inputProps, textFieldProps.inputProps);
43
+ textFieldProps.InputProps = _extends({}, InputProps, textFieldProps.InputProps);
44
44
  const _useTimeField = useTimeField({
45
45
  props: textFieldProps,
46
46
  inputRef: externalInputRef
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { TimePickerProps } from './TimePicker.types';
3
- type TimePickerComponent = (<TDate>(props: TimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
3
+ type TimePickerComponent = (<TDate>(props: TimePickerProps<TDate> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  declare const TimePicker: TimePickerComponent;
@@ -1,6 +1,6 @@
1
- /// <reference types="react" />
1
+ import * as React from 'react';
2
2
  import { YearCalendarProps } from './YearCalendar.types';
3
- type YearCalendarComponent = (<TDate>(props: YearCalendarProps<TDate>) => JSX.Element) & {
3
+ type YearCalendarComponent = (<TDate>(props: YearCalendarProps<TDate>) => React.JSX.Element) & {
4
4
  propTypes?: any;
5
5
  };
6
6
  export declare const YearCalendar: YearCalendarComponent;
package/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @mui/x-date-pickers v6.10.2
2
+ * @mui/x-date-pickers v6.11.0
3
3
  *
4
4
  * @license MIT
5
5
  * This source code is licensed under the MIT license found in the
@@ -12,12 +12,12 @@ export interface PickersModalDialogSlotsComponent {
12
12
  Dialog?: React.ElementType<MuiDialogProps>;
13
13
  /**
14
14
  * Custom component for the paper rendered inside the mobile picker's Dialog.
15
- * @default Paper from @mui/material
15
+ * @default Paper from '@mui/material'.
16
16
  */
17
17
  MobilePaper?: React.JSXElementConstructor<MuiPaperProps>;
18
18
  /**
19
19
  * Custom component for the mobile dialog [Transition](https://mui.com/material-ui/transitions/).
20
- * @default Fade from @mui/material
20
+ * @default Fade from '@mui/material'.
21
21
  */
22
22
  MobileTransition?: React.JSXElementConstructor<MuiTransitionProps>;
23
23
  }
@@ -15,17 +15,17 @@ export interface PickersPopperSlotsComponent {
15
15
  DesktopPaper?: React.JSXElementConstructor<MuiPaperProps>;
16
16
  /**
17
17
  * Custom component for the desktop popper [Transition](https://mui.com/material-ui/transitions/).
18
- * @default Grow from @mui/material
18
+ * @default Grow from '@mui/material'.
19
19
  */
20
20
  DesktopTransition?: React.JSXElementConstructor<MuiTransitionProps>;
21
21
  /**
22
22
  * Custom component for trapping the focus inside the views on desktop.
23
- * @default TrapFocus from @mui/material
23
+ * @default TrapFocus from '@mui/material'.
24
24
  */
25
25
  DesktopTrapFocus?: React.JSXElementConstructor<MuiTrapFocusProps>;
26
26
  /**
27
27
  * Custom component for the popper inside which the views are rendered on desktop.
28
- * @default Popper from @mui/material
28
+ * @default Popper from '@mui/material'.
29
29
  */
30
30
  Popper?: React.ElementType<MuiPopperProps>;
31
31
  }
@@ -8,7 +8,7 @@ export interface PickersToolbarProps<TValue, TView extends DateOrTimeViewWithMer
8
8
  toolbarTitle: React.ReactNode;
9
9
  classes?: Partial<PickersToolbarClasses>;
10
10
  }
11
- type PickersToolbarComponent = (<TValue, TView extends DateOrTimeViewWithMeridiem>(props: React.PropsWithChildren<PickersToolbarProps<TValue, TView>> & React.RefAttributes<HTMLDivElement>) => JSX.Element) & {
11
+ type PickersToolbarComponent = (<TValue, TView extends DateOrTimeViewWithMeridiem>(props: React.PropsWithChildren<PickersToolbarProps<TValue, TView>> & React.RefAttributes<HTMLDivElement>) => React.JSX.Element) & {
12
12
  propTypes?: any;
13
13
  };
14
14
  export declare const PickersToolbar: PickersToolbarComponent;
@@ -1,7 +1,7 @@
1
1
  import { PickerOnChangeFn } from './useViews';
2
2
  import { PickerSelectionState } from './usePicker';
3
3
  import { PickersTimezone } from '../../models';
4
- interface MonthValidationOptions<TDate> {
4
+ export interface MonthValidationOptions<TDate> {
5
5
  disablePast?: boolean;
6
6
  disableFuture?: boolean;
7
7
  minDate: TDate;
@@ -14,4 +14,3 @@ export declare function useMeridiemMode<TDate>(date: TDate | null, ampm: boolean
14
14
  meridiemMode: import("../utils/time-utils").Meridiem | null;
15
15
  handleMeridiemChange: (mode: 'am' | 'pm') => void;
16
16
  };
17
- export {};
@@ -0,0 +1,2 @@
1
+ export declare const defaultReduceAnimations: boolean;
2
+ export declare const useDefaultReduceAnimations: () => boolean;
@@ -0,0 +1,9 @@
1
+ import useMediaQuery from '@mui/material/useMediaQuery';
2
+ const PREFERS_REDUCED_MOTION = '@media (prefers-reduced-motion: reduce)';
3
+ export const defaultReduceAnimations = typeof navigator !== 'undefined' && /(android)/i.test(navigator.userAgent);
4
+ export const useDefaultReduceAnimations = () => {
5
+ const prefersReduced = useMediaQuery(PREFERS_REDUCED_MOTION, {
6
+ defaultMatches: false
7
+ });
8
+ return prefersReduced || defaultReduceAnimations;
9
+ };