@mui/x-date-pickers 6.5.0 → 6.7.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.
- package/AdapterDateFns/AdapterDateFns.d.ts +6 -0
- package/AdapterDateFns/AdapterDateFns.js +38 -19
- package/AdapterDateFnsJalali/AdapterDateFnsJalali.d.ts +6 -0
- package/AdapterDateFnsJalali/AdapterDateFnsJalali.js +35 -16
- package/AdapterDayjs/AdapterDayjs.d.ts +14 -1
- package/AdapterDayjs/AdapterDayjs.js +143 -25
- package/AdapterLuxon/AdapterLuxon.d.ts +7 -1
- package/AdapterLuxon/AdapterLuxon.js +78 -28
- package/AdapterMoment/AdapterMoment.d.ts +12 -1
- package/AdapterMoment/AdapterMoment.js +103 -13
- package/AdapterMomentHijri/AdapterMomentHijri.d.ts +4 -0
- package/AdapterMomentHijri/AdapterMomentHijri.js +30 -19
- package/AdapterMomentJalaali/AdapterMomentJalaali.d.ts +4 -0
- package/AdapterMomentJalaali/AdapterMomentJalaali.js +30 -19
- package/CHANGELOG.md +150 -2
- package/DateCalendar/DateCalendar.js +2 -2
- package/DateCalendar/DayCalendar.d.ts +1 -1
- package/DateCalendar/PickersCalendarHeader.d.ts +1 -1
- package/DateCalendar/PickersCalendarHeader.js +2 -2
- package/DateCalendar/PickersFadeTransitionGroup.d.ts +1 -1
- package/DateCalendar/PickersSlideTransition.d.ts +1 -1
- package/DateField/DateField.js +6 -0
- package/DateField/DateField.types.d.ts +1 -1
- package/DatePicker/DatePickerToolbar.js +6 -15
- package/DatePicker/shared.d.ts +1 -5
- package/DatePicker/shared.js +1 -16
- package/DateTimeField/DateTimeField.js +6 -0
- package/DateTimeField/DateTimeField.types.d.ts +1 -1
- package/DateTimePicker/DateTimePicker.js +19 -2
- package/DateTimePicker/DateTimePicker.types.d.ts +4 -3
- package/DateTimePicker/DateTimePickerTabs.d.ts +3 -3
- package/DateTimePicker/DateTimePickerTabs.js +6 -5
- package/DateTimePicker/DateTimePickerToolbar.d.ts +5 -4
- package/DateTimePicker/DateTimePickerToolbar.js +46 -22
- package/DateTimePicker/shared.d.ts +6 -6
- package/DayCalendarSkeleton/DayCalendarSkeleton.d.ts +1 -1
- package/DesktopDatePicker/DesktopDatePicker.js +5 -4
- package/DesktopDateTimePicker/DesktopDateTimePicker.js +58 -11
- package/DesktopDateTimePicker/DesktopDateTimePicker.types.d.ts +10 -3
- package/DesktopTimePicker/DesktopTimePicker.js +7 -3
- package/LocalizationProvider/LocalizationProvider.js +1 -0
- package/MobileDatePicker/MobileDatePicker.js +3 -2
- package/MobileDateTimePicker/MobileDateTimePicker.js +5 -1
- package/MobileDateTimePicker/MobileDateTimePicker.types.d.ts +8 -7
- package/MobileTimePicker/MobileTimePicker.js +5 -1
- package/MonthCalendar/MonthCalendar.js +2 -2
- package/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +4 -3
- package/PickersActionBar/PickersActionBar.d.ts +2 -2
- package/PickersLayout/PickersLayout.d.ts +1 -1
- package/PickersShortcuts/PickersShortcuts.d.ts +2 -2
- package/README.md +5 -5
- package/StaticDateTimePicker/StaticDateTimePicker.types.d.ts +1 -1
- package/TimeClock/Clock.d.ts +1 -1
- package/TimeClock/ClockNumber.d.ts +1 -1
- package/TimeClock/ClockNumbers.d.ts +2 -2
- package/TimeClock/ClockPointer.d.ts +1 -1
- package/TimeField/TimeField.js +6 -0
- package/TimeField/TimeField.types.d.ts +1 -1
- package/TimePicker/TimePickerToolbar.d.ts +2 -2
- package/TimePicker/shared.d.ts +1 -1
- package/YearCalendar/YearCalendar.js +2 -2
- package/dateTimeViewRenderers/dateTimeViewRenderers.d.ts +13 -0
- package/dateTimeViewRenderers/dateTimeViewRenderers.js +148 -0
- package/dateTimeViewRenderers/index.d.ts +2 -0
- package/dateTimeViewRenderers/index.js +1 -0
- package/dateTimeViewRenderers/package.json +6 -0
- package/dateViewRenderers/dateViewRenderers.d.ts +3 -2
- package/dateViewRenderers/dateViewRenderers.js +2 -2
- package/icons/index.d.ts +42 -0
- package/{internals/components/icons → icons}/index.js +7 -7
- package/icons/package.json +6 -0
- package/index.d.ts +1 -0
- package/index.js +3 -2
- package/internals/components/DateTimeViewWrapper/DateTimeViewWrapper.d.ts +2 -0
- package/internals/components/DateTimeViewWrapper/DateTimeViewWrapper.js +5 -0
- package/internals/components/DateTimeViewWrapper/index.d.ts +1 -0
- package/internals/components/DateTimeViewWrapper/index.js +1 -0
- package/internals/components/PickersArrowSwitcher/PickersArrowSwitcher.js +3 -3
- package/internals/components/PickersModalDialog.d.ts +1 -1
- package/internals/components/PickersPopper.d.ts +1 -1
- package/internals/components/PickersToolbarButton.d.ts +1 -0
- package/internals/components/PickersToolbarButton.js +8 -3
- package/internals/constants/dimensions.d.ts +1 -0
- package/internals/constants/dimensions.js +2 -1
- package/internals/demo/DemoContainer.d.ts +2 -2
- package/internals/hooks/useDesktopPicker/useDesktopPicker.d.ts +2 -2
- package/internals/hooks/useDesktopPicker/useDesktopPicker.types.d.ts +2 -2
- package/internals/hooks/useField/useField.d.ts +1 -1
- package/internals/hooks/useField/useField.js +8 -3
- package/internals/hooks/useField/useField.types.d.ts +8 -2
- package/internals/hooks/useField/useFieldState.d.ts +1 -1
- package/internals/hooks/useField/useFieldState.js +22 -2
- package/internals/hooks/useMobilePicker/useMobilePicker.d.ts +2 -2
- package/internals/hooks/useMobilePicker/useMobilePicker.types.d.ts +2 -2
- package/internals/hooks/usePicker/usePickerValue.types.d.ts +32 -2
- package/internals/hooks/usePicker/usePickerViews.js +8 -10
- package/internals/hooks/useStaticPicker/useStaticPicker.d.ts +2 -2
- package/internals/hooks/useViews.js +10 -9
- package/internals/index.d.ts +2 -1
- package/internals/index.js +2 -1
- package/internals/models/fields.d.ts +1 -1
- package/internals/utils/date-time-utils.d.ts +6 -0
- package/internals/utils/date-time-utils.js +41 -0
- package/internals/utils/date-utils.d.ts +8 -1
- package/internals/utils/date-utils.js +35 -0
- package/internals/utils/fields.js +1 -1
- package/internals/utils/getDefaultReferenceDate.d.ts +15 -0
- package/internals/utils/getDefaultReferenceDate.js +62 -0
- package/internals/utils/time-utils.d.ts +8 -2
- package/internals/utils/time-utils.js +28 -0
- package/internals/utils/validation/extractValidationProps.d.ts +1 -1
- package/internals/utils/valueManagers.js +21 -3
- package/internals/utils/views.d.ts +2 -3
- package/internals/utils/views.js +6 -2
- package/legacy/AdapterDateFns/AdapterDateFns.js +38 -19
- package/legacy/AdapterDateFnsJalali/AdapterDateFnsJalali.js +35 -16
- package/legacy/AdapterDayjs/AdapterDayjs.js +147 -25
- package/legacy/AdapterLuxon/AdapterLuxon.js +78 -28
- package/legacy/AdapterMoment/AdapterMoment.js +109 -17
- package/legacy/AdapterMomentHijri/AdapterMomentHijri.js +30 -19
- package/legacy/AdapterMomentJalaali/AdapterMomentJalaali.js +30 -19
- package/legacy/DateCalendar/DateCalendar.js +2 -2
- package/legacy/DateCalendar/PickersCalendarHeader.js +2 -2
- package/legacy/DateField/DateField.js +6 -0
- package/legacy/DatePicker/DatePickerToolbar.js +6 -15
- package/legacy/DatePicker/shared.js +1 -15
- package/legacy/DateTimeField/DateTimeField.js +6 -0
- package/legacy/DateTimePicker/DateTimePicker.js +19 -2
- package/legacy/DateTimePicker/DateTimePickerTabs.js +6 -5
- package/legacy/DateTimePicker/DateTimePickerToolbar.js +51 -23
- package/legacy/DesktopDatePicker/DesktopDatePicker.js +5 -4
- package/legacy/DesktopDateTimePicker/DesktopDateTimePicker.js +59 -11
- package/legacy/DesktopTimePicker/DesktopTimePicker.js +7 -3
- package/legacy/LocalizationProvider/LocalizationProvider.js +1 -0
- package/legacy/MobileDatePicker/MobileDatePicker.js +3 -2
- package/legacy/MobileDateTimePicker/MobileDateTimePicker.js +5 -1
- package/legacy/MobileTimePicker/MobileTimePicker.js +5 -1
- package/legacy/MonthCalendar/MonthCalendar.js +2 -2
- package/legacy/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +4 -3
- package/legacy/TimeField/TimeField.js +6 -0
- package/legacy/YearCalendar/YearCalendar.js +2 -2
- package/legacy/dateTimeViewRenderers/dateTimeViewRenderers.js +147 -0
- package/legacy/dateTimeViewRenderers/index.js +1 -0
- package/legacy/dateViewRenderers/dateViewRenderers.js +2 -4
- package/legacy/{internals/components/icons → icons}/index.js +7 -7
- package/legacy/index.js +3 -2
- package/legacy/internals/components/DateTimeViewWrapper/DateTimeViewWrapper.js +5 -0
- package/legacy/internals/components/DateTimeViewWrapper/index.js +1 -0
- package/legacy/internals/components/PickersArrowSwitcher/PickersArrowSwitcher.js +3 -3
- package/legacy/internals/components/PickersToolbarButton.js +7 -2
- package/legacy/internals/constants/dimensions.js +2 -1
- package/legacy/internals/hooks/useField/useField.js +8 -3
- package/legacy/internals/hooks/useField/useFieldState.js +22 -2
- package/legacy/internals/hooks/usePicker/usePickerViews.js +4 -4
- package/legacy/internals/hooks/useViews.js +10 -9
- package/legacy/internals/index.js +2 -1
- package/legacy/internals/utils/date-time-utils.js +39 -0
- package/legacy/internals/utils/date-utils.js +38 -0
- package/legacy/internals/utils/fields.js +1 -1
- package/legacy/internals/utils/getDefaultReferenceDate.js +64 -0
- package/legacy/internals/utils/time-utils.js +29 -0
- package/legacy/internals/utils/valueManagers.js +20 -4
- package/legacy/internals/utils/views.js +7 -5
- package/legacy/locales/deDE.js +2 -2
- package/legacy/locales/index.js +17 -15
- package/legacy/locales/roRO.js +81 -0
- package/legacy/locales/viVN.js +93 -0
- package/legacy/models/index.js +1 -0
- package/legacy/models/timezone.js +1 -0
- package/legacy/tests/describeGregorianAdapter/describeGregorianAdapter.js +16 -1
- package/legacy/tests/describeGregorianAdapter/testCalculations.js +349 -79
- package/legacy/tests/describeGregorianAdapter/testLocalization.js +3 -3
- package/legacy/tests/describeValidation/testDayViewValidation.js +129 -52
- package/legacy/tests/describeValidation/testMinutesViewValidation.js +3 -10
- package/legacy/tests/describeValidation/testMonthViewValidation.js +3 -10
- package/legacy/tests/describeValidation/testYearViewValidation.js +3 -10
- package/legacy/tests/describeValue/describeValue.js +12 -5
- package/legacy/tests/describeValue/testControlledUnControlled.js +19 -4
- package/legacy/tests/describeValue/testPickerActionBar.js +12 -10
- package/legacy/tests/describeValue/testPickerOpenCloseLifeCycle.js +10 -7
- package/legacy/timeViewRenderers/timeViewRenderers.js +1 -1
- package/locales/deDE.js +2 -2
- package/locales/index.d.ts +17 -15
- package/locales/index.js +17 -15
- package/locales/roRO.d.ts +53 -0
- package/locales/roRO.js +63 -0
- package/locales/viVN.d.ts +53 -0
- package/locales/viVN.js +57 -0
- package/models/adapters.d.ts +187 -46
- package/models/fields.d.ts +1 -1
- package/models/index.d.ts +1 -0
- package/models/index.js +1 -0
- package/models/timezone.d.ts +1 -0
- package/models/timezone.js +1 -0
- package/modern/AdapterDateFns/AdapterDateFns.js +38 -19
- package/modern/AdapterDateFnsJalali/AdapterDateFnsJalali.js +35 -16
- package/modern/AdapterDayjs/AdapterDayjs.js +142 -25
- package/modern/AdapterLuxon/AdapterLuxon.js +77 -28
- package/modern/AdapterMoment/AdapterMoment.js +102 -13
- package/modern/AdapterMomentHijri/AdapterMomentHijri.js +30 -19
- package/modern/AdapterMomentJalaali/AdapterMomentJalaali.js +30 -19
- package/modern/DateCalendar/DateCalendar.js +2 -2
- package/modern/DateCalendar/PickersCalendarHeader.js +2 -2
- package/modern/DateField/DateField.js +6 -0
- package/modern/DatePicker/DatePickerToolbar.js +6 -15
- package/modern/DatePicker/shared.js +1 -16
- package/modern/DateTimeField/DateTimeField.js +6 -0
- package/modern/DateTimePicker/DateTimePicker.js +19 -2
- package/modern/DateTimePicker/DateTimePickerTabs.js +6 -5
- package/modern/DateTimePicker/DateTimePickerToolbar.js +46 -22
- package/modern/DesktopDatePicker/DesktopDatePicker.js +5 -4
- package/modern/DesktopDateTimePicker/DesktopDateTimePicker.js +57 -10
- package/modern/DesktopTimePicker/DesktopTimePicker.js +7 -3
- package/modern/LocalizationProvider/LocalizationProvider.js +1 -0
- package/modern/MobileDatePicker/MobileDatePicker.js +3 -2
- package/modern/MobileDateTimePicker/MobileDateTimePicker.js +5 -1
- package/modern/MobileTimePicker/MobileTimePicker.js +5 -1
- package/modern/MonthCalendar/MonthCalendar.js +2 -2
- package/modern/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +4 -3
- package/modern/TimeField/TimeField.js +6 -0
- package/modern/YearCalendar/YearCalendar.js +2 -2
- package/modern/dateTimeViewRenderers/dateTimeViewRenderers.js +147 -0
- package/modern/dateTimeViewRenderers/index.js +1 -0
- package/modern/dateViewRenderers/dateViewRenderers.js +2 -2
- package/modern/{internals/components/icons → icons}/index.js +7 -7
- package/modern/index.js +3 -2
- package/modern/internals/components/DateTimeViewWrapper/DateTimeViewWrapper.js +5 -0
- package/modern/internals/components/DateTimeViewWrapper/index.js +1 -0
- package/modern/internals/components/PickersArrowSwitcher/PickersArrowSwitcher.js +3 -3
- package/modern/internals/components/PickersToolbarButton.js +8 -3
- package/modern/internals/constants/dimensions.js +2 -1
- package/modern/internals/hooks/useField/useField.js +8 -3
- package/modern/internals/hooks/useField/useFieldState.js +22 -2
- package/modern/internals/hooks/usePicker/usePickerViews.js +8 -10
- package/modern/internals/hooks/useViews.js +10 -9
- package/modern/internals/index.js +2 -1
- package/modern/internals/utils/date-time-utils.js +41 -0
- package/modern/internals/utils/date-utils.js +35 -0
- package/modern/internals/utils/fields.js +1 -1
- package/modern/internals/utils/getDefaultReferenceDate.js +58 -0
- package/modern/internals/utils/time-utils.js +28 -0
- package/modern/internals/utils/valueManagers.js +21 -3
- package/modern/internals/utils/views.js +6 -2
- package/modern/locales/deDE.js +2 -2
- package/modern/locales/index.js +17 -15
- package/modern/locales/roRO.js +60 -0
- package/modern/locales/viVN.js +57 -0
- package/modern/models/index.js +1 -0
- package/modern/models/timezone.js +1 -0
- package/modern/tests/describeGregorianAdapter/describeGregorianAdapter.js +13 -1
- package/modern/tests/describeGregorianAdapter/testCalculations.js +347 -79
- package/modern/tests/describeGregorianAdapter/testLocalization.js +3 -3
- package/modern/tests/describeValidation/testDayViewValidation.js +129 -52
- package/modern/tests/describeValidation/testMinutesViewValidation.js +3 -10
- package/modern/tests/describeValidation/testMonthViewValidation.js +3 -10
- package/modern/tests/describeValidation/testYearViewValidation.js +3 -10
- package/modern/tests/describeValue/describeValue.js +13 -4
- package/modern/tests/describeValue/testControlledUnControlled.js +15 -4
- package/modern/tests/describeValue/testPickerActionBar.js +19 -17
- package/modern/tests/describeValue/testPickerOpenCloseLifeCycle.js +10 -7
- package/modern/timeViewRenderers/timeViewRenderers.js +1 -1
- package/node/AdapterDateFns/AdapterDateFns.js +38 -19
- package/node/AdapterDateFnsJalali/AdapterDateFnsJalali.js +35 -16
- package/node/AdapterDayjs/AdapterDayjs.js +142 -25
- package/node/AdapterLuxon/AdapterLuxon.js +77 -28
- package/node/AdapterMoment/AdapterMoment.js +102 -13
- package/node/AdapterMomentHijri/AdapterMomentHijri.js +30 -19
- package/node/AdapterMomentJalaali/AdapterMomentJalaali.js +30 -19
- package/node/DateCalendar/DateCalendar.js +2 -2
- package/node/DateCalendar/PickersCalendarHeader.js +2 -2
- package/node/DateField/DateField.js +6 -0
- package/node/DatePicker/DatePickerToolbar.js +6 -15
- package/node/DatePicker/shared.js +0 -17
- package/node/DateTimeField/DateTimeField.js +6 -0
- package/node/DateTimePicker/DateTimePicker.js +19 -2
- package/node/DateTimePicker/DateTimePickerTabs.js +6 -5
- package/node/DateTimePicker/DateTimePickerToolbar.js +46 -22
- package/node/DesktopDatePicker/DesktopDatePicker.js +4 -3
- package/node/DesktopDateTimePicker/DesktopDateTimePicker.js +59 -12
- package/node/DesktopTimePicker/DesktopTimePicker.js +9 -5
- package/node/LocalizationProvider/LocalizationProvider.js +1 -0
- package/node/MobileDatePicker/MobileDatePicker.js +2 -1
- package/node/MobileDateTimePicker/MobileDateTimePicker.js +7 -3
- package/node/MobileTimePicker/MobileTimePicker.js +7 -3
- package/node/MonthCalendar/MonthCalendar.js +2 -2
- package/node/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +3 -2
- package/node/TimeField/TimeField.js +6 -0
- package/node/YearCalendar/YearCalendar.js +2 -2
- package/node/dateTimeViewRenderers/dateTimeViewRenderers.js +156 -0
- package/node/dateTimeViewRenderers/index.js +12 -0
- package/node/dateViewRenderers/dateViewRenderers.js +3 -3
- package/node/{internals/components/icons → icons}/index.js +15 -15
- package/node/index.js +13 -1
- package/node/internals/components/DateTimeViewWrapper/DateTimeViewWrapper.js +12 -0
- package/node/internals/components/DateTimeViewWrapper/index.js +12 -0
- package/node/internals/components/PickersArrowSwitcher/PickersArrowSwitcher.js +3 -3
- package/node/internals/components/PickersToolbarButton.js +8 -3
- package/node/internals/constants/dimensions.js +4 -2
- package/node/internals/hooks/useField/useField.js +8 -3
- package/node/internals/hooks/useField/useFieldState.js +22 -2
- package/node/internals/hooks/usePicker/usePickerViews.js +8 -10
- package/node/internals/hooks/useViews.js +10 -9
- package/node/internals/index.js +13 -0
- package/node/internals/utils/date-time-utils.js +49 -0
- package/node/internals/utils/date-utils.js +40 -2
- package/node/internals/utils/fields.js +1 -1
- package/node/internals/utils/getDefaultReferenceDate.js +66 -0
- package/node/internals/utils/time-utils.js +32 -2
- package/node/internals/utils/valueManagers.js +21 -2
- package/node/internals/utils/views.js +8 -5
- package/node/locales/deDE.js +2 -2
- package/node/locales/index.js +119 -97
- package/node/locales/roRO.js +67 -0
- package/node/locales/viVN.js +64 -0
- package/node/models/index.js +11 -0
- package/node/models/timezone.js +5 -0
- package/node/tests/describeGregorianAdapter/describeGregorianAdapter.js +13 -1
- package/node/tests/describeGregorianAdapter/testCalculations.js +347 -79
- package/node/tests/describeGregorianAdapter/testLocalization.js +3 -4
- package/node/tests/describeValidation/testDayViewValidation.js +129 -52
- package/node/tests/describeValidation/testMinutesViewValidation.js +3 -10
- package/node/tests/describeValidation/testMonthViewValidation.js +3 -10
- package/node/tests/describeValidation/testYearViewValidation.js +3 -10
- package/node/tests/describeValue/describeValue.js +13 -4
- package/node/tests/describeValue/testControlledUnControlled.js +15 -4
- package/node/tests/describeValue/testPickerActionBar.js +19 -16
- package/node/tests/describeValue/testPickerOpenCloseLifeCycle.js +9 -6
- package/node/timeViewRenderers/timeViewRenderers.js +1 -1
- package/package.json +4 -4
- package/tests/describeGregorianAdapter/describeGregorianAdapter.js +14 -1
- package/tests/describeGregorianAdapter/testCalculations.js +347 -79
- package/tests/describeGregorianAdapter/testLocalization.js +3 -3
- package/tests/describeValidation/testDayViewValidation.js +129 -52
- package/tests/describeValidation/testMinutesViewValidation.js +3 -10
- package/tests/describeValidation/testMonthViewValidation.js +3 -10
- package/tests/describeValidation/testYearViewValidation.js +3 -10
- package/tests/describeValue/describeValue.js +13 -4
- package/tests/describeValue/testControlledUnControlled.js +15 -4
- package/tests/describeValue/testPickerActionBar.js +19 -17
- package/tests/describeValue/testPickerOpenCloseLifeCycle.js +10 -7
- package/timeViewRenderers/timeViewRenderers.d.ts +4 -4
- package/timeViewRenderers/timeViewRenderers.js +1 -1
- package/internals/components/icons/index.d.ts +0 -42
|
@@ -17,33 +17,34 @@ export const testDayViewValidation = (ElementToTest, getOptions) => {
|
|
|
17
17
|
return;
|
|
18
18
|
}
|
|
19
19
|
describe('day view:', () => {
|
|
20
|
-
const defaultProps =
|
|
20
|
+
const defaultProps = {
|
|
21
21
|
onChange: () => {},
|
|
22
22
|
open: true,
|
|
23
23
|
view: 'day',
|
|
24
|
-
reduceAnimations: true
|
|
25
|
-
}, componentFamily.includes('legacy-') ? {
|
|
26
|
-
componentsProps: {
|
|
27
|
-
toolbar: {
|
|
28
|
-
hidden: true
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
} : {
|
|
24
|
+
reduceAnimations: true,
|
|
32
25
|
slotProps: {
|
|
33
26
|
toolbar: {
|
|
34
27
|
hidden: true
|
|
35
28
|
}
|
|
36
29
|
}
|
|
37
|
-
}
|
|
30
|
+
};
|
|
38
31
|
it('should apply shouldDisableDate', function test() {
|
|
39
32
|
render( /*#__PURE__*/_jsx(ElementToTest, _extends({}, defaultProps, {
|
|
40
33
|
value: adapterToUse.date(new Date(2018, 2, 12)),
|
|
41
34
|
shouldDisableDate: date => adapterToUse.isAfter(date, adapterToUse.date(new Date(2018, 2, 10)))
|
|
42
35
|
})));
|
|
43
|
-
expect(screen.
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
expect(screen.
|
|
36
|
+
expect(screen.getByRole('gridcell', {
|
|
37
|
+
name: '9'
|
|
38
|
+
})).not.to.have.attribute('disabled');
|
|
39
|
+
expect(screen.getByRole('gridcell', {
|
|
40
|
+
name: '10'
|
|
41
|
+
})).not.to.have.attribute('disabled');
|
|
42
|
+
expect(screen.getByRole('gridcell', {
|
|
43
|
+
name: '11'
|
|
44
|
+
})).to.have.attribute('disabled');
|
|
45
|
+
expect(screen.getByRole('gridcell', {
|
|
46
|
+
name: '12'
|
|
47
|
+
})).to.have.attribute('disabled');
|
|
47
48
|
});
|
|
48
49
|
it('should apply shouldDisableYear', function test() {
|
|
49
50
|
const {
|
|
@@ -52,16 +53,28 @@ export const testDayViewValidation = (ElementToTest, getOptions) => {
|
|
|
52
53
|
value: adapterToUse.date(new Date(2018, 2, 12)),
|
|
53
54
|
shouldDisableYear: date => adapterToUse.getYear(date) === 2018
|
|
54
55
|
})));
|
|
55
|
-
expect(screen.
|
|
56
|
-
|
|
57
|
-
|
|
56
|
+
expect(screen.getByRole('gridcell', {
|
|
57
|
+
name: '1'
|
|
58
|
+
})).to.have.attribute('disabled');
|
|
59
|
+
expect(screen.getByRole('gridcell', {
|
|
60
|
+
name: '15'
|
|
61
|
+
})).to.have.attribute('disabled');
|
|
62
|
+
expect(screen.getByRole('gridcell', {
|
|
63
|
+
name: '30'
|
|
64
|
+
})).to.have.attribute('disabled');
|
|
58
65
|
setProps({
|
|
59
66
|
value: adapterToUse.date(new Date(2019, 0, 1))
|
|
60
67
|
});
|
|
61
68
|
clock.runToLast();
|
|
62
|
-
expect(screen.
|
|
63
|
-
|
|
64
|
-
|
|
69
|
+
expect(screen.getByRole('gridcell', {
|
|
70
|
+
name: '1'
|
|
71
|
+
})).not.to.have.attribute('disabled');
|
|
72
|
+
expect(screen.getByRole('gridcell', {
|
|
73
|
+
name: '15'
|
|
74
|
+
})).not.to.have.attribute('disabled');
|
|
75
|
+
expect(screen.getByRole('gridcell', {
|
|
76
|
+
name: '30'
|
|
77
|
+
})).not.to.have.attribute('disabled');
|
|
65
78
|
});
|
|
66
79
|
it('should apply shouldDisableMonth', function test() {
|
|
67
80
|
const {
|
|
@@ -70,16 +83,28 @@ export const testDayViewValidation = (ElementToTest, getOptions) => {
|
|
|
70
83
|
value: adapterToUse.date(new Date(2018, 2, 12)),
|
|
71
84
|
shouldDisableMonth: date => adapterToUse.getMonth(date) === 2
|
|
72
85
|
})));
|
|
73
|
-
expect(screen.
|
|
74
|
-
|
|
75
|
-
|
|
86
|
+
expect(screen.getByRole('gridcell', {
|
|
87
|
+
name: '1'
|
|
88
|
+
})).to.have.attribute('disabled');
|
|
89
|
+
expect(screen.getByRole('gridcell', {
|
|
90
|
+
name: '15'
|
|
91
|
+
})).to.have.attribute('disabled');
|
|
92
|
+
expect(screen.getByRole('gridcell', {
|
|
93
|
+
name: '30'
|
|
94
|
+
})).to.have.attribute('disabled');
|
|
76
95
|
setProps({
|
|
77
96
|
value: adapterToUse.date(new Date(2018, 1, 1))
|
|
78
97
|
});
|
|
79
98
|
clock.runToLast();
|
|
80
|
-
expect(screen.
|
|
81
|
-
|
|
82
|
-
|
|
99
|
+
expect(screen.getByRole('gridcell', {
|
|
100
|
+
name: '1'
|
|
101
|
+
})).not.to.have.attribute('disabled');
|
|
102
|
+
expect(screen.getByRole('gridcell', {
|
|
103
|
+
name: '15'
|
|
104
|
+
})).not.to.have.attribute('disabled');
|
|
105
|
+
expect(screen.getByRole('gridcell', {
|
|
106
|
+
name: '28'
|
|
107
|
+
})).not.to.have.attribute('disabled');
|
|
83
108
|
});
|
|
84
109
|
it('should apply disablePast', function test() {
|
|
85
110
|
let now;
|
|
@@ -96,21 +121,27 @@ export const testDayViewValidation = (ElementToTest, getOptions) => {
|
|
|
96
121
|
})));
|
|
97
122
|
const tomorrow = adapterToUse.addDays(now, 1);
|
|
98
123
|
const yesterday = adapterToUse.addDays(now, -1);
|
|
99
|
-
expect(screen.
|
|
124
|
+
expect(screen.getByRole('gridcell', {
|
|
125
|
+
name: adapterToUse.format(now, 'dayOfMonth')
|
|
126
|
+
})).not.to.have.attribute('disabled');
|
|
100
127
|
if (!adapterToUse.isSameMonth(now, tomorrow)) {
|
|
101
128
|
setProps({
|
|
102
129
|
value: tomorrow
|
|
103
130
|
});
|
|
104
131
|
clock.runToLast();
|
|
105
132
|
}
|
|
106
|
-
expect(screen.
|
|
133
|
+
expect(screen.getByRole('gridcell', {
|
|
134
|
+
name: adapterToUse.format(tomorrow, 'dayOfMonth')
|
|
135
|
+
})).not.to.have.attribute('disabled');
|
|
107
136
|
if (!adapterToUse.isSameMonth(yesterday, tomorrow)) {
|
|
108
137
|
setProps({
|
|
109
138
|
value: yesterday
|
|
110
139
|
});
|
|
111
140
|
clock.runToLast();
|
|
112
141
|
}
|
|
113
|
-
expect(screen.
|
|
142
|
+
expect(screen.getByRole('gridcell', {
|
|
143
|
+
name: adapterToUse.format(yesterday, 'dayOfMonth')
|
|
144
|
+
})).to.have.attribute('disabled');
|
|
114
145
|
});
|
|
115
146
|
it('should apply disableFuture', function test() {
|
|
116
147
|
let now;
|
|
@@ -127,32 +158,48 @@ export const testDayViewValidation = (ElementToTest, getOptions) => {
|
|
|
127
158
|
})));
|
|
128
159
|
const tomorrow = adapterToUse.addDays(now, 1);
|
|
129
160
|
const yesterday = adapterToUse.addDays(now, -1);
|
|
130
|
-
expect(screen.
|
|
161
|
+
expect(screen.getByRole('gridcell', {
|
|
162
|
+
name: adapterToUse.format(now, 'dayOfMonth')
|
|
163
|
+
})).not.to.have.attribute('disabled');
|
|
131
164
|
if (!adapterToUse.isSameMonth(now, tomorrow)) {
|
|
132
165
|
setProps({
|
|
133
166
|
value: tomorrow
|
|
134
167
|
});
|
|
135
168
|
clock.runToLast();
|
|
136
169
|
}
|
|
137
|
-
expect(screen.
|
|
170
|
+
expect(screen.getByRole('gridcell', {
|
|
171
|
+
name: adapterToUse.format(tomorrow, 'dayOfMonth')
|
|
172
|
+
})).to.have.attribute('disabled');
|
|
138
173
|
if (!adapterToUse.isSameMonth(yesterday, tomorrow)) {
|
|
139
174
|
setProps({
|
|
140
175
|
value: yesterday
|
|
141
176
|
});
|
|
142
177
|
clock.runToLast();
|
|
143
178
|
}
|
|
144
|
-
expect(screen.
|
|
179
|
+
expect(screen.getByRole('gridcell', {
|
|
180
|
+
name: adapterToUse.format(yesterday, 'dayOfMonth')
|
|
181
|
+
})).not.to.have.attribute('disabled');
|
|
145
182
|
});
|
|
146
183
|
it('should apply minDate', function test() {
|
|
147
184
|
render( /*#__PURE__*/_jsx(ElementToTest, _extends({}, defaultProps, {
|
|
148
185
|
value: adapterToUse.date(new Date(2019, 5, 15)),
|
|
149
186
|
minDate: adapterToUse.date(new Date(2019, 5, 4))
|
|
150
187
|
})));
|
|
151
|
-
expect(screen.
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
expect(screen.
|
|
155
|
-
|
|
188
|
+
expect(screen.getByRole('gridcell', {
|
|
189
|
+
name: '1'
|
|
190
|
+
})).to.have.attribute('disabled');
|
|
191
|
+
expect(screen.getByRole('gridcell', {
|
|
192
|
+
name: '3'
|
|
193
|
+
})).to.have.attribute('disabled');
|
|
194
|
+
expect(screen.getByRole('gridcell', {
|
|
195
|
+
name: '4'
|
|
196
|
+
})).not.to.have.attribute('disabled');
|
|
197
|
+
expect(screen.getByRole('gridcell', {
|
|
198
|
+
name: '5'
|
|
199
|
+
})).not.to.have.attribute('disabled');
|
|
200
|
+
expect(screen.getByRole('gridcell', {
|
|
201
|
+
name: '30'
|
|
202
|
+
})).not.to.have.attribute('disabled');
|
|
156
203
|
expect(screen.getByLabelText('Previous month')).to.have.attribute('disabled');
|
|
157
204
|
expect(screen.getByLabelText('Next month')).not.to.have.attribute('disabled');
|
|
158
205
|
});
|
|
@@ -161,11 +208,21 @@ export const testDayViewValidation = (ElementToTest, getOptions) => {
|
|
|
161
208
|
value: adapterToUse.date(new Date(2019, 5, 15)),
|
|
162
209
|
maxDate: adapterToUse.date(new Date(2019, 5, 4))
|
|
163
210
|
})));
|
|
164
|
-
expect(screen.
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
expect(screen.
|
|
168
|
-
|
|
211
|
+
expect(screen.getByRole('gridcell', {
|
|
212
|
+
name: '1'
|
|
213
|
+
})).not.to.have.attribute('disabled');
|
|
214
|
+
expect(screen.getByRole('gridcell', {
|
|
215
|
+
name: '3'
|
|
216
|
+
})).not.to.have.attribute('disabled');
|
|
217
|
+
expect(screen.getByRole('gridcell', {
|
|
218
|
+
name: '4'
|
|
219
|
+
})).not.to.have.attribute('disabled');
|
|
220
|
+
expect(screen.getByRole('gridcell', {
|
|
221
|
+
name: '5'
|
|
222
|
+
})).to.have.attribute('disabled');
|
|
223
|
+
expect(screen.getByRole('gridcell', {
|
|
224
|
+
name: '30'
|
|
225
|
+
})).to.have.attribute('disabled');
|
|
169
226
|
expect(screen.getByLabelText('Previous month')).not.to.have.attribute('disabled');
|
|
170
227
|
expect(screen.getByLabelText('Next month')).to.have.attribute('disabled');
|
|
171
228
|
});
|
|
@@ -178,11 +235,21 @@ export const testDayViewValidation = (ElementToTest, getOptions) => {
|
|
|
178
235
|
value: adapterToUse.date(new Date(2019, 5, 15)),
|
|
179
236
|
maxDateTime: adapterToUse.date(new Date(2019, 5, 4, 12, 0, 0))
|
|
180
237
|
})));
|
|
181
|
-
expect(screen.
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
expect(screen.
|
|
185
|
-
|
|
238
|
+
expect(screen.getByRole('gridcell', {
|
|
239
|
+
name: '1'
|
|
240
|
+
})).not.to.have.attribute('disabled');
|
|
241
|
+
expect(screen.getByRole('gridcell', {
|
|
242
|
+
name: '3'
|
|
243
|
+
})).not.to.have.attribute('disabled');
|
|
244
|
+
expect(screen.getByRole('gridcell', {
|
|
245
|
+
name: '4'
|
|
246
|
+
})).not.to.have.attribute('disabled');
|
|
247
|
+
expect(screen.getByRole('gridcell', {
|
|
248
|
+
name: '5'
|
|
249
|
+
})).to.have.attribute('disabled');
|
|
250
|
+
expect(screen.getByRole('gridcell', {
|
|
251
|
+
name: '30'
|
|
252
|
+
})).to.have.attribute('disabled');
|
|
186
253
|
});
|
|
187
254
|
it('should apply minDateTime', function test() {
|
|
188
255
|
if (!withDate || !withTime) {
|
|
@@ -193,11 +260,21 @@ export const testDayViewValidation = (ElementToTest, getOptions) => {
|
|
|
193
260
|
value: adapterToUse.date(new Date(2019, 5, 15)),
|
|
194
261
|
minDateTime: adapterToUse.date(new Date(2019, 5, 4, 12, 0, 0))
|
|
195
262
|
})));
|
|
196
|
-
expect(screen.
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
expect(screen.
|
|
200
|
-
|
|
263
|
+
expect(screen.getByRole('gridcell', {
|
|
264
|
+
name: '1'
|
|
265
|
+
})).to.have.attribute('disabled');
|
|
266
|
+
expect(screen.getByRole('gridcell', {
|
|
267
|
+
name: '3'
|
|
268
|
+
})).to.have.attribute('disabled');
|
|
269
|
+
expect(screen.getByRole('gridcell', {
|
|
270
|
+
name: '4'
|
|
271
|
+
})).not.to.have.attribute('disabled');
|
|
272
|
+
expect(screen.getByRole('gridcell', {
|
|
273
|
+
name: '5'
|
|
274
|
+
})).not.to.have.attribute('disabled');
|
|
275
|
+
expect(screen.getByRole('gridcell', {
|
|
276
|
+
name: '30'
|
|
277
|
+
})).not.to.have.attribute('disabled');
|
|
201
278
|
});
|
|
202
279
|
});
|
|
203
280
|
};
|
|
@@ -19,25 +19,18 @@ export const testMinutesViewValidation = (ElementToTest, getOption) => {
|
|
|
19
19
|
return;
|
|
20
20
|
}
|
|
21
21
|
describe('minutes view:', () => {
|
|
22
|
-
const defaultProps =
|
|
22
|
+
const defaultProps = {
|
|
23
23
|
onChange: () => {},
|
|
24
24
|
open: true,
|
|
25
25
|
view: 'minutes',
|
|
26
26
|
openTo: 'minutes',
|
|
27
|
-
reduceAnimations: true
|
|
28
|
-
}, componentFamily.includes('legacy-') ? {
|
|
29
|
-
componentsProps: {
|
|
30
|
-
toolbar: {
|
|
31
|
-
hidden: true
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
} : {
|
|
27
|
+
reduceAnimations: true,
|
|
35
28
|
slotProps: {
|
|
36
29
|
toolbar: {
|
|
37
30
|
hidden: true
|
|
38
31
|
}
|
|
39
32
|
}
|
|
40
|
-
}
|
|
33
|
+
};
|
|
41
34
|
it('should apply shouldDisableTime', function test() {
|
|
42
35
|
render( /*#__PURE__*/_jsx(ElementToTest, _extends({}, defaultProps, {
|
|
43
36
|
value: adapterToUse.date(new Date(2018, 2, 12, 8, 15, 0)),
|
|
@@ -21,22 +21,15 @@ export const testMonthViewValidation = (ElementToTest, getOptions) => {
|
|
|
21
21
|
views: ['month'],
|
|
22
22
|
view: 'month',
|
|
23
23
|
openTo: 'month'
|
|
24
|
-
}, componentFamily !== 'calendar' &&
|
|
24
|
+
}, componentFamily !== 'calendar' && {
|
|
25
25
|
open: true,
|
|
26
|
-
reduceAnimations: true
|
|
27
|
-
}, componentFamily.includes('legacy-') ? {
|
|
28
|
-
componentsProps: {
|
|
29
|
-
toolbar: {
|
|
30
|
-
hidden: true
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
} : {
|
|
26
|
+
reduceAnimations: true,
|
|
34
27
|
slotProps: {
|
|
35
28
|
toolbar: {
|
|
36
29
|
hidden: true
|
|
37
30
|
}
|
|
38
31
|
}
|
|
39
|
-
})
|
|
32
|
+
});
|
|
40
33
|
it('should apply shouldDisableMonth', function test() {
|
|
41
34
|
render( /*#__PURE__*/_jsx(ElementToTest, _extends({}, defaultProps, {
|
|
42
35
|
value: null,
|
|
@@ -20,22 +20,15 @@ export const testYearViewValidation = (ElementToTest, getOptions) => {
|
|
|
20
20
|
views: ['year'],
|
|
21
21
|
view: 'year',
|
|
22
22
|
openTo: 'year'
|
|
23
|
-
}, componentFamily !== 'calendar' &&
|
|
23
|
+
}, componentFamily !== 'calendar' && {
|
|
24
24
|
open: true,
|
|
25
|
-
reduceAnimations: true
|
|
26
|
-
}, componentFamily.includes('legacy-') ? {
|
|
27
|
-
componentsProps: {
|
|
28
|
-
toolbar: {
|
|
29
|
-
hidden: true
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
} : {
|
|
25
|
+
reduceAnimations: true,
|
|
33
26
|
slotProps: {
|
|
34
27
|
toolbar: {
|
|
35
28
|
hidden: true
|
|
36
29
|
}
|
|
37
30
|
}
|
|
38
|
-
})
|
|
31
|
+
});
|
|
39
32
|
it('should apply shouldDisableYear', function test() {
|
|
40
33
|
render( /*#__PURE__*/_jsx(ElementToTest, _extends({}, defaultProps, {
|
|
41
34
|
value: null,
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
+
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
3
|
+
const _excluded = ["hook"];
|
|
2
4
|
import * as React from 'react';
|
|
3
5
|
import createDescribe from '@mui/monorepo/test/utils/createDescribe';
|
|
4
6
|
import { buildFieldInteractions } from 'test/utils/pickers-utils';
|
|
@@ -16,7 +18,12 @@ function innerDescribeValue(ElementToTest, getOptions) {
|
|
|
16
18
|
componentFamily
|
|
17
19
|
} = options;
|
|
18
20
|
function WrappedElementToTest(props) {
|
|
19
|
-
|
|
21
|
+
const {
|
|
22
|
+
hook
|
|
23
|
+
} = props,
|
|
24
|
+
other = _objectWithoutPropertiesLoose(props, _excluded);
|
|
25
|
+
const hookResult = hook == null ? void 0 : hook(props);
|
|
26
|
+
return /*#__PURE__*/_jsx(ElementToTest, _extends({}, defaultProps, other, hookResult));
|
|
20
27
|
}
|
|
21
28
|
let renderWithProps;
|
|
22
29
|
if (componentFamily === 'field' || componentFamily === 'picker') {
|
|
@@ -25,10 +32,12 @@ function innerDescribeValue(ElementToTest, getOptions) {
|
|
|
25
32
|
render,
|
|
26
33
|
Component: ElementToTest
|
|
27
34
|
});
|
|
28
|
-
renderWithProps = props => interactions.renderWithProps(_extends({}, defaultProps, props), componentFamily);
|
|
35
|
+
renderWithProps = (props, hook) => interactions.renderWithProps(_extends({}, defaultProps, props), hook, componentFamily);
|
|
29
36
|
} else {
|
|
30
|
-
renderWithProps = props => {
|
|
31
|
-
const response = render( /*#__PURE__*/_jsx(WrappedElementToTest, _extends({}, props
|
|
37
|
+
renderWithProps = (props, hook) => {
|
|
38
|
+
const response = render( /*#__PURE__*/_jsx(WrappedElementToTest, _extends({}, props, {
|
|
39
|
+
hook: hook
|
|
40
|
+
})));
|
|
32
41
|
return _extends({}, response, {
|
|
33
42
|
input: null,
|
|
34
43
|
selectSection: () => {
|
|
@@ -59,7 +59,7 @@ export const testControlledUnControlled = (ElementToTest, options) => {
|
|
|
59
59
|
});
|
|
60
60
|
assertRenderedValue(newValue);
|
|
61
61
|
// TODO: Clean this exception or change the clock behavior
|
|
62
|
-
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily));
|
|
62
|
+
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily, params));
|
|
63
63
|
if (Array.isArray(newValue)) {
|
|
64
64
|
newValue.forEach((value, index) => {
|
|
65
65
|
expect(onChange.lastCall.args[0][index]).toEqualDateTime(value);
|
|
@@ -70,16 +70,27 @@ export const testControlledUnControlled = (ElementToTest, options) => {
|
|
|
70
70
|
});
|
|
71
71
|
it('should call onChange when updating a value defined with `props.value`', () => {
|
|
72
72
|
const onChange = spy();
|
|
73
|
+
const useControlledElement = props => {
|
|
74
|
+
const [value, setValue] = React.useState((props == null ? void 0 : props.value) || null);
|
|
75
|
+
const handleChange = React.useCallback(newValue => {
|
|
76
|
+
setValue(newValue);
|
|
77
|
+
props == null ? void 0 : props.onChange(newValue);
|
|
78
|
+
}, [props]);
|
|
79
|
+
return {
|
|
80
|
+
value,
|
|
81
|
+
onChange: handleChange
|
|
82
|
+
};
|
|
83
|
+
};
|
|
73
84
|
const {
|
|
74
85
|
selectSection
|
|
75
86
|
} = renderWithProps({
|
|
76
|
-
|
|
87
|
+
value: values[0],
|
|
77
88
|
onChange
|
|
78
|
-
});
|
|
89
|
+
}, useControlledElement);
|
|
79
90
|
const newValue = setNewValue(values[0], {
|
|
80
91
|
selectSection
|
|
81
92
|
});
|
|
82
|
-
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily));
|
|
93
|
+
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily, params));
|
|
83
94
|
if (Array.isArray(newValue)) {
|
|
84
95
|
newValue.forEach((value, index) => {
|
|
85
96
|
expect(onChange.lastCall.args[0][index]).toEqualDateTime(value);
|
|
@@ -1,19 +1,21 @@
|
|
|
1
|
+
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
2
|
+
const _excluded = ["componentFamily", "render", "renderWithProps", "values", "emptyValue", "setNewValue"];
|
|
1
3
|
import * as React from 'react';
|
|
2
4
|
import { expect } from 'chai';
|
|
3
5
|
import { spy } from 'sinon';
|
|
4
6
|
import { screen, userEvent } from '@mui/monorepo/test/utils';
|
|
5
|
-
import { adapterToUse } from 'test/utils/pickers-utils';
|
|
7
|
+
import { adapterToUse, getExpectedOnChangeCount } from 'test/utils/pickers-utils';
|
|
6
8
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
9
|
export const testPickerActionBar = (ElementToTest, options) => {
|
|
8
10
|
const {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
11
|
+
componentFamily,
|
|
12
|
+
render,
|
|
13
|
+
renderWithProps,
|
|
14
|
+
values,
|
|
15
|
+
emptyValue,
|
|
16
|
+
setNewValue
|
|
17
|
+
} = options,
|
|
18
|
+
pickerParams = _objectWithoutPropertiesLoose(options, _excluded);
|
|
17
19
|
if (componentFamily !== 'picker') {
|
|
18
20
|
return;
|
|
19
21
|
}
|
|
@@ -39,7 +41,7 @@ export const testPickerActionBar = (ElementToTest, options) => {
|
|
|
39
41
|
// Clear the date
|
|
40
42
|
userEvent.mousePress(screen.getByText(/clear/i));
|
|
41
43
|
expect(onChange.callCount).to.equal(1);
|
|
42
|
-
if (type === 'date-range') {
|
|
44
|
+
if (pickerParams.type === 'date-range') {
|
|
43
45
|
onChange.lastCall.args[0].forEach((value, index) => {
|
|
44
46
|
expect(value).to.deep.equal(emptyValue[index]);
|
|
45
47
|
});
|
|
@@ -47,7 +49,7 @@ export const testPickerActionBar = (ElementToTest, options) => {
|
|
|
47
49
|
expect(onChange.lastCall.args[0]).to.deep.equal(emptyValue);
|
|
48
50
|
}
|
|
49
51
|
expect(onAccept.callCount).to.equal(1);
|
|
50
|
-
if (type === 'date-range') {
|
|
52
|
+
if (pickerParams.type === 'date-range') {
|
|
51
53
|
onAccept.lastCall.args[0].forEach((value, index) => {
|
|
52
54
|
expect(value).to.deep.equal(emptyValue[index]);
|
|
53
55
|
});
|
|
@@ -109,8 +111,8 @@ export const testPickerActionBar = (ElementToTest, options) => {
|
|
|
109
111
|
|
|
110
112
|
// Cancel the modifications
|
|
111
113
|
userEvent.mousePress(screen.getByText(/cancel/i));
|
|
112
|
-
expect(onChange.callCount).to.equal(
|
|
113
|
-
if (type === 'date-range') {
|
|
114
|
+
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily, pickerParams) + 1);
|
|
115
|
+
if (pickerParams.type === 'date-range') {
|
|
114
116
|
values[0].forEach((value, index) => {
|
|
115
117
|
expect(onChange.lastCall.args[0][index]).toEqualDateTime(value);
|
|
116
118
|
});
|
|
@@ -174,7 +176,7 @@ export const testPickerActionBar = (ElementToTest, options) => {
|
|
|
174
176
|
|
|
175
177
|
// Accept the modifications
|
|
176
178
|
userEvent.mousePress(screen.getByText(/ok/i));
|
|
177
|
-
expect(onChange.callCount).to.equal(
|
|
179
|
+
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily, pickerParams)); // The accepted value as already been committed, don't call onChange again
|
|
178
180
|
expect(onAccept.callCount).to.equal(1);
|
|
179
181
|
expect(onClose.callCount).to.equal(1);
|
|
180
182
|
});
|
|
@@ -245,9 +247,9 @@ export const testPickerActionBar = (ElementToTest, options) => {
|
|
|
245
247
|
}
|
|
246
248
|
}));
|
|
247
249
|
userEvent.mousePress(screen.getByText(/today/i));
|
|
248
|
-
const startOfToday = type === 'date' ? adapterToUse.startOfDay(adapterToUse.date()) : adapterToUse.date();
|
|
250
|
+
const startOfToday = pickerParams.type === 'date' ? adapterToUse.startOfDay(adapterToUse.date()) : adapterToUse.date();
|
|
249
251
|
expect(onChange.callCount).to.equal(1);
|
|
250
|
-
if (type === 'date-range') {
|
|
252
|
+
if (pickerParams.type === 'date-range') {
|
|
251
253
|
onChange.lastCall.args[0].forEach(value => {
|
|
252
254
|
expect(value).toEqualDateTime(startOfToday);
|
|
253
255
|
});
|
|
@@ -255,7 +257,7 @@ export const testPickerActionBar = (ElementToTest, options) => {
|
|
|
255
257
|
expect(onChange.lastCall.args[0]).toEqualDateTime(startOfToday);
|
|
256
258
|
}
|
|
257
259
|
expect(onAccept.callCount).to.equal(1);
|
|
258
|
-
if (type === 'date-range') {
|
|
260
|
+
if (pickerParams.type === 'date-range') {
|
|
259
261
|
onAccept.lastCall.args[0].forEach(value => {
|
|
260
262
|
expect(value).toEqualDateTime(startOfToday);
|
|
261
263
|
});
|
|
@@ -4,7 +4,7 @@ import * as React from 'react';
|
|
|
4
4
|
import { expect } from 'chai';
|
|
5
5
|
import { spy } from 'sinon';
|
|
6
6
|
import { screen, userEvent } from '@mui/monorepo/test/utils';
|
|
7
|
-
import { getTextbox, openPicker } from 'test/utils/pickers-utils';
|
|
7
|
+
import { getExpectedOnChangeCount, getTextbox, openPicker } from 'test/utils/pickers-utils';
|
|
8
8
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
9
9
|
export const testPickerOpenCloseLifeCycle = (ElementToTest, options) => {
|
|
10
10
|
const {
|
|
@@ -70,7 +70,7 @@ export const testPickerOpenCloseLifeCycle = (ElementToTest, options) => {
|
|
|
70
70
|
isOpened: true,
|
|
71
71
|
selectSection
|
|
72
72
|
});
|
|
73
|
-
expect(onChange.callCount).to.equal(
|
|
73
|
+
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily, pickerParams));
|
|
74
74
|
if (pickerParams.type === 'date-range') {
|
|
75
75
|
newValue = setNewValue(newValue, {
|
|
76
76
|
isOpened: true,
|
|
@@ -131,7 +131,7 @@ export const testPickerOpenCloseLifeCycle = (ElementToTest, options) => {
|
|
|
131
131
|
isOpened: true,
|
|
132
132
|
selectSection
|
|
133
133
|
});
|
|
134
|
-
expect(onChange.callCount).to.equal(
|
|
134
|
+
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily, pickerParams));
|
|
135
135
|
if (pickerParams.type === 'date-range') {
|
|
136
136
|
newValue = setNewValue(newValue, {
|
|
137
137
|
isOpened: true,
|
|
@@ -200,7 +200,8 @@ export const testPickerOpenCloseLifeCycle = (ElementToTest, options) => {
|
|
|
200
200
|
isOpened: true,
|
|
201
201
|
selectSection
|
|
202
202
|
});
|
|
203
|
-
|
|
203
|
+
const initialChangeCount = getExpectedOnChangeCount(componentFamily, pickerParams);
|
|
204
|
+
expect(onChange.callCount).to.equal(initialChangeCount);
|
|
204
205
|
if (pickerParams.type === 'date-range') {
|
|
205
206
|
newValue = setNewValue(newValue, {
|
|
206
207
|
isOpened: true,
|
|
@@ -232,7 +233,9 @@ export const testPickerOpenCloseLifeCycle = (ElementToTest, options) => {
|
|
|
232
233
|
expect(onChange.lastCall.args[0][index]).toEqualDateTime(value);
|
|
233
234
|
});
|
|
234
235
|
} else {
|
|
235
|
-
expect(onChange.callCount).to.equal(
|
|
236
|
+
expect(onChange.callCount).to.equal(initialChangeCount + getExpectedOnChangeCount(componentFamily, pickerParams) - (
|
|
237
|
+
// meridiem does not change this time in case of multi section digital clock
|
|
238
|
+
pickerParams.type === 'time' || pickerParams.type === 'date-time' ? 1 : 0));
|
|
236
239
|
expect(onChange.lastCall.args[0]).toEqualDateTime(newValueBis);
|
|
237
240
|
}
|
|
238
241
|
expect(onAccept.callCount).to.equal(0);
|
|
@@ -263,7 +266,7 @@ export const testPickerOpenCloseLifeCycle = (ElementToTest, options) => {
|
|
|
263
266
|
userEvent.keyPress(document.activeElement, {
|
|
264
267
|
key: 'Escape'
|
|
265
268
|
});
|
|
266
|
-
expect(onChange.callCount).to.equal(
|
|
269
|
+
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily, pickerParams));
|
|
267
270
|
expect(onAccept.callCount).to.equal(1);
|
|
268
271
|
if (pickerParams.type === 'date-range') {
|
|
269
272
|
newValue.forEach((value, index) => {
|
|
@@ -324,7 +327,7 @@ export const testPickerOpenCloseLifeCycle = (ElementToTest, options) => {
|
|
|
324
327
|
|
|
325
328
|
// Dismiss the picker
|
|
326
329
|
userEvent.mousePress(document.body);
|
|
327
|
-
expect(onChange.callCount).to.equal(
|
|
330
|
+
expect(onChange.callCount).to.equal(getExpectedOnChangeCount(componentFamily, pickerParams));
|
|
328
331
|
expect(onAccept.callCount).to.equal(1);
|
|
329
332
|
expect(onAccept.lastCall.args[0]).toEqualDateTime(newValue);
|
|
330
333
|
expect(onClose.callCount).to.equal(1);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
1
|
+
import * as React from 'react';
|
|
2
2
|
import { TimeClockProps } from '../TimeClock';
|
|
3
3
|
import { TimeView } from '../models';
|
|
4
4
|
import { DigitalClockProps } from '../DigitalClock';
|
|
@@ -11,6 +11,6 @@ export type TimeViewRendererProps<TView extends TimeViewWithMeridiem, TComponent
|
|
|
11
11
|
onViewChange?: (view: TView) => void;
|
|
12
12
|
views: readonly TView[];
|
|
13
13
|
};
|
|
14
|
-
export declare const renderTimeViewClock: <TDate extends unknown>({ view, onViewChange, focusedView, onFocusedViewChange, views, value, defaultValue, onChange, className, classes, disableFuture, disablePast, minTime, maxTime, shouldDisableTime, shouldDisableClock, minutesStep, ampm, ampmInClock, components, componentsProps, slots, slotProps, readOnly, disabled, sx, autoFocus, showViewSwitcher, disableIgnoringDatePartForTimeValidation, }: TimeViewRendererProps<
|
|
15
|
-
export declare const renderDigitalClockTimeView: <TDate extends unknown>({ view, onViewChange, focusedView, onFocusedViewChange, views, value, defaultValue, onChange, className, classes, disableFuture, disablePast, minTime, maxTime, shouldDisableTime, shouldDisableClock, minutesStep, ampm, components, componentsProps, slots, slotProps, readOnly, disabled, sx, autoFocus, disableIgnoringDatePartForTimeValidation, timeSteps, skipDisabled, }: TimeViewRendererProps<"hours", Omit<DigitalClockProps<TDate>, "timeStep"> & Pick<TimePickerProps<TDate>, "timeSteps">>) => JSX.Element;
|
|
16
|
-
export declare const renderMultiSectionDigitalClockTimeView: <TDate extends unknown>({ view, onViewChange, focusedView, onFocusedViewChange, views, value, defaultValue, onChange, className, classes, disableFuture, disablePast, minTime, maxTime, shouldDisableTime, shouldDisableClock, minutesStep, ampm, components, componentsProps, slots, slotProps, readOnly, disabled, sx, autoFocus, disableIgnoringDatePartForTimeValidation, timeSteps, skipDisabled, }: TimeViewRendererProps<TimeViewWithMeridiem, MultiSectionDigitalClockProps<TDate>>) => JSX.Element;
|
|
14
|
+
export declare const renderTimeViewClock: <TDate extends unknown>({ view, onViewChange, focusedView, onFocusedViewChange, views, value, defaultValue, onChange, className, classes, disableFuture, disablePast, minTime, maxTime, shouldDisableTime, shouldDisableClock, minutesStep, ampm, ampmInClock, components, componentsProps, slots, slotProps, readOnly, disabled, sx, autoFocus, showViewSwitcher, disableIgnoringDatePartForTimeValidation, }: TimeViewRendererProps<TimeView, TimeClockProps<TDate, TimeView>>) => React.JSX.Element;
|
|
15
|
+
export declare const renderDigitalClockTimeView: <TDate extends unknown>({ view, onViewChange, focusedView, onFocusedViewChange, views, value, defaultValue, onChange, className, classes, disableFuture, disablePast, minTime, maxTime, shouldDisableTime, shouldDisableClock, minutesStep, ampm, components, componentsProps, slots, slotProps, readOnly, disabled, sx, autoFocus, disableIgnoringDatePartForTimeValidation, timeSteps, skipDisabled, }: TimeViewRendererProps<"hours", Omit<DigitalClockProps<TDate>, "timeStep"> & Pick<TimePickerProps<TDate>, "timeSteps">>) => React.JSX.Element;
|
|
16
|
+
export declare const renderMultiSectionDigitalClockTimeView: <TDate extends unknown>({ view, onViewChange, focusedView, onFocusedViewChange, views, value, defaultValue, onChange, className, classes, disableFuture, disablePast, minTime, maxTime, shouldDisableTime, shouldDisableClock, minutesStep, ampm, components, componentsProps, slots, slotProps, readOnly, disabled, sx, autoFocus, disableIgnoringDatePartForTimeValidation, timeSteps, skipDisabled, }: TimeViewRendererProps<TimeViewWithMeridiem, MultiSectionDigitalClockProps<TDate>>) => React.JSX.Element;
|
|
@@ -37,7 +37,7 @@ export const renderTimeViewClock = ({
|
|
|
37
37
|
}) => /*#__PURE__*/_jsx(TimeClock, {
|
|
38
38
|
view: view,
|
|
39
39
|
onViewChange: onViewChange,
|
|
40
|
-
focusedView: focusedView,
|
|
40
|
+
focusedView: focusedView && isTimeView(focusedView) ? focusedView : null,
|
|
41
41
|
onFocusedViewChange: onFocusedViewChange,
|
|
42
42
|
views: views.filter(isTimeView),
|
|
43
43
|
value: value,
|