@mui/x-date-pickers 6.2.0 → 6.3.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 +109 -0
- package/AdapterDateFns/AdapterDateFns.js +598 -0
- package/AdapterDateFns/index.d.ts +1 -13
- package/AdapterDateFns/index.js +1 -149
- package/AdapterDateFnsJalali/AdapterDateFnsJalali.d.ts +109 -0
- package/AdapterDateFnsJalali/AdapterDateFnsJalali.js +610 -0
- package/AdapterDateFnsJalali/index.d.ts +1 -13
- package/AdapterDateFnsJalali/index.js +1 -149
- package/AdapterDayjs/AdapterDayjs.d.ts +53 -53
- package/AdapterDayjs/AdapterDayjs.js +146 -111
- package/AdapterLuxon/AdapterLuxon.d.ts +108 -0
- package/AdapterLuxon/AdapterLuxon.js +513 -0
- package/AdapterLuxon/index.d.ts +1 -14
- package/AdapterLuxon/index.js +1 -111
- package/AdapterMoment/AdapterMoment.d.ts +110 -0
- package/AdapterMoment/AdapterMoment.js +416 -0
- package/AdapterMoment/index.d.ts +1 -21
- package/AdapterMoment/index.js +1 -99
- package/AdapterMomentHijri/AdapterMomentHijri.d.ts +67 -0
- package/AdapterMomentHijri/AdapterMomentHijri.js +269 -0
- package/AdapterMomentHijri/index.d.ts +1 -18
- package/AdapterMomentHijri/index.js +1 -74
- package/AdapterMomentJalaali/AdapterMomentJalaali.d.ts +74 -0
- package/AdapterMomentJalaali/AdapterMomentJalaali.js +276 -0
- package/AdapterMomentJalaali/index.d.ts +1 -22
- package/AdapterMomentJalaali/index.js +1 -87
- package/CHANGELOG.md +118 -1
- package/DateCalendar/DateCalendar.types.d.ts +1 -1
- package/DateCalendar/DayCalendar.d.ts +1 -1
- package/DateCalendar/DayCalendar.js +1 -1
- package/DateCalendar/PickersCalendarHeader.d.ts +1 -1
- package/DateCalendar/useCalendarState.js +1 -1
- package/DateCalendar/useIsDateDisabled.d.ts +2 -0
- package/DateCalendar/useIsDateDisabled.js +27 -0
- package/DateField/DateField.js +20 -3
- package/DateField/DateField.types.d.ts +2 -2
- package/DateField/useDateField.js +4 -2
- package/DatePicker/DatePickerToolbar.js +1 -1
- package/DateTimeField/DateTimeField.js +21 -3
- package/DateTimeField/DateTimeField.types.d.ts +3 -2
- package/DateTimeField/useDateTimeField.js +4 -2
- package/DateTimePicker/DateTimePicker.js +1 -0
- package/DateTimePicker/shared.d.ts +6 -5
- package/DesktopDatePicker/DesktopDatePicker.js +2 -1
- package/DesktopDateTimePicker/DesktopDateTimePicker.js +3 -1
- package/DesktopTimePicker/DesktopTimePicker.js +51 -8
- package/DesktopTimePicker/DesktopTimePicker.types.d.ts +12 -4
- package/DigitalClock/DigitalClock.d.ts +7 -0
- package/DigitalClock/DigitalClock.js +397 -0
- package/DigitalClock/DigitalClock.types.d.ts +47 -0
- package/DigitalClock/digitalClockClasses.d.ts +11 -0
- package/DigitalClock/digitalClockClasses.js +6 -0
- package/DigitalClock/index.d.ts +4 -0
- package/DigitalClock/index.js +2 -0
- package/DigitalClock/package.json +6 -0
- package/LocalizationProvider/LocalizationProvider.d.ts +1 -1
- package/LocalizationProvider/LocalizationProvider.js +1 -1
- package/MobileDatePicker/MobileDatePicker.js +2 -1
- package/MobileDateTimePicker/MobileDateTimePicker.js +3 -1
- package/MobileTimePicker/MobileTimePicker.js +3 -1
- package/MobileTimePicker/MobileTimePicker.types.d.ts +8 -7
- package/MonthCalendar/MonthCalendar.types.d.ts +1 -1
- package/MultiSectionDigitalClock/MultiSectionDigitalClock.d.ts +7 -0
- package/MultiSectionDigitalClock/MultiSectionDigitalClock.js +479 -0
- package/MultiSectionDigitalClock/MultiSectionDigitalClock.types.d.ts +57 -0
- package/MultiSectionDigitalClock/MultiSectionDigitalClock.utils.d.ts +22 -0
- package/MultiSectionDigitalClock/MultiSectionDigitalClock.utils.js +65 -0
- package/MultiSectionDigitalClock/MultiSectionDigitalClockSection.d.ts +28 -0
- package/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +151 -0
- package/MultiSectionDigitalClock/index.d.ts +7 -0
- package/MultiSectionDigitalClock/index.js +3 -0
- package/MultiSectionDigitalClock/multiSectionDigitalClockClasses.d.ts +7 -0
- package/MultiSectionDigitalClock/multiSectionDigitalClockClasses.js +6 -0
- package/MultiSectionDigitalClock/multiSectionDigitalClockSectionClasses.d.ts +9 -0
- package/MultiSectionDigitalClock/multiSectionDigitalClockSectionClasses.js +6 -0
- package/MultiSectionDigitalClock/package.json +6 -0
- package/PickersDay/PickersDay.js +4 -1
- package/PickersLayout/PickersLayout.d.ts +2 -2
- package/PickersLayout/PickersLayout.js +2 -2
- package/PickersLayout/PickersLayout.types.d.ts +7 -8
- package/PickersLayout/usePickerLayout.d.ts +2 -2
- package/README.md +0 -9
- package/StaticDatePicker/StaticDatePicker.js +1 -0
- package/StaticDateTimePicker/StaticDateTimePicker.js +5 -3
- package/StaticTimePicker/StaticTimePicker.js +5 -3
- package/StaticTimePicker/StaticTimePicker.types.d.ts +1 -1
- package/TimeClock/TimeClock.js +35 -12
- package/TimeClock/TimeClock.types.d.ts +4 -67
- package/TimeField/TimeField.js +21 -3
- package/TimeField/TimeField.types.d.ts +3 -2
- package/TimeField/useTimeField.js +4 -2
- package/TimePicker/TimePicker.js +25 -2
- package/TimePicker/TimePicker.types.d.ts +4 -3
- package/TimePicker/TimePickerToolbar.d.ts +2 -2
- package/TimePicker/TimePickerToolbar.js +2 -2
- package/TimePicker/shared.d.ts +9 -7
- package/YearCalendar/YearCalendar.types.d.ts +1 -1
- package/dateViewRenderers/dateViewRenderers.d.ts +2 -2
- package/index.d.ts +2 -0
- package/index.js +4 -1
- package/internals/components/PickersToolbar.d.ts +3 -3
- package/internals/constants/dimensions.d.ts +1 -0
- package/internals/constants/dimensions.js +2 -1
- package/internals/demo/DemoContainer.js +4 -1
- package/internals/hooks/date-helpers-hooks.d.ts +3 -2
- package/internals/hooks/date-helpers-hooks.js +3 -3
- package/internals/hooks/useDesktopPicker/useDesktopPicker.d.ts +2 -2
- package/internals/hooks/useDesktopPicker/useDesktopPicker.js +15 -15
- package/internals/hooks/useDesktopPicker/useDesktopPicker.types.d.ts +7 -6
- package/internals/hooks/useField/useField.js +12 -11
- package/internals/hooks/useField/useField.types.d.ts +19 -5
- package/internals/hooks/useField/useField.utils.d.ts +9 -6
- package/internals/hooks/useField/useField.utils.js +60 -34
- package/internals/hooks/useField/useFieldCharacterEditing.js +18 -10
- package/internals/hooks/useField/useFieldState.js +5 -4
- package/internals/hooks/useIsLandscape.d.ts +2 -2
- package/internals/hooks/useMobilePicker/useMobilePicker.d.ts +2 -2
- package/internals/hooks/useMobilePicker/useMobilePicker.js +10 -10
- package/internals/hooks/useMobilePicker/useMobilePicker.types.d.ts +7 -6
- package/internals/hooks/usePicker/usePicker.d.ts +4 -3
- package/internals/hooks/usePicker/usePicker.js +2 -0
- package/internals/hooks/usePicker/usePicker.types.d.ts +6 -5
- package/internals/hooks/usePicker/usePickerLayoutProps.d.ts +5 -6
- package/internals/hooks/usePicker/usePickerValue.d.ts +2 -2
- package/internals/hooks/usePicker/usePickerValue.js +10 -12
- package/internals/hooks/usePicker/usePickerValue.types.d.ts +5 -3
- package/internals/hooks/usePicker/usePickerViews.d.ts +11 -11
- package/internals/hooks/useStaticPicker/useStaticPicker.d.ts +2 -2
- package/internals/hooks/useStaticPicker/useStaticPicker.js +10 -10
- package/internals/hooks/useStaticPicker/useStaticPicker.types.d.ts +6 -5
- package/internals/hooks/{validation/useValidation.d.ts → useValidation.d.ts} +1 -1
- package/internals/hooks/{validation/useValidation.js → useValidation.js} +1 -1
- package/internals/hooks/useViews.d.ts +8 -6
- package/internals/hooks/useViews.js +29 -13
- package/internals/index.d.ts +7 -7
- package/internals/index.js +5 -5
- package/internals/models/common.d.ts +3 -0
- package/internals/models/index.d.ts +1 -0
- package/internals/models/index.js +2 -1
- package/internals/models/props/basePickerProps.d.ts +3 -3
- package/internals/models/props/clock.d.ts +88 -0
- package/internals/models/props/tabs.d.ts +2 -2
- package/internals/models/props/toolbar.d.ts +3 -3
- package/internals/{hooks/validation/models.d.ts → models/validation.d.ts} +2 -5
- package/internals/models/validation.js +1 -0
- package/internals/utils/time-utils.d.ts +7 -7
- package/internals/utils/time-utils.js +2 -1
- package/internals/{hooks/validation/useDateValidation.d.ts → utils/validation/validateDate.d.ts} +2 -3
- package/internals/{hooks/validation/useDateValidation.js → utils/validation/validateDate.js} +1 -27
- package/internals/{hooks/validation/useDateTimeValidation.d.ts → utils/validation/validateDateTime.d.ts} +3 -3
- package/{modern/internals/hooks/validation/useDateTimeValidation.js → internals/utils/validation/validateDateTime.js} +2 -2
- package/internals/{hooks/validation/useTimeValidation.d.ts → utils/validation/validateTime.d.ts} +2 -2
- package/{modern/internals/hooks/validation/useTimeValidation.js → internals/utils/validation/validateTime.js} +1 -1
- package/internals/utils/valueManagers.js +1 -1
- package/internals/utils/views.d.ts +3 -2
- package/legacy/AdapterDateFns/AdapterDateFns.js +606 -0
- package/legacy/AdapterDateFns/index.js +1 -165
- package/legacy/AdapterDateFnsJalali/AdapterDateFnsJalali.js +620 -0
- package/legacy/AdapterDateFnsJalali/index.js +1 -165
- package/legacy/AdapterDayjs/AdapterDayjs.js +146 -111
- package/legacy/AdapterLuxon/AdapterLuxon.js +524 -0
- package/legacy/AdapterLuxon/index.js +1 -127
- package/legacy/AdapterMoment/AdapterMoment.js +422 -0
- package/legacy/AdapterMoment/index.js +1 -115
- package/legacy/AdapterMomentHijri/AdapterMomentHijri.js +284 -0
- package/legacy/AdapterMomentHijri/index.js +1 -90
- package/legacy/AdapterMomentJalaali/AdapterMomentJalaali.js +291 -0
- package/legacy/AdapterMomentJalaali/index.js +1 -103
- package/legacy/DateCalendar/DayCalendar.js +1 -1
- package/legacy/DateCalendar/useCalendarState.js +1 -1
- package/legacy/DateCalendar/useIsDateDisabled.js +28 -0
- package/legacy/DateField/DateField.js +20 -3
- package/legacy/DateField/useDateField.js +4 -2
- package/legacy/DatePicker/DatePickerToolbar.js +1 -1
- package/legacy/DateTimeField/DateTimeField.js +21 -3
- package/legacy/DateTimeField/useDateTimeField.js +4 -2
- package/legacy/DateTimePicker/DateTimePicker.js +1 -0
- package/legacy/DesktopDatePicker/DesktopDatePicker.js +2 -1
- package/legacy/DesktopDateTimePicker/DesktopDateTimePicker.js +3 -1
- package/legacy/DesktopTimePicker/DesktopTimePicker.js +52 -8
- package/legacy/DigitalClock/DigitalClock.js +419 -0
- package/legacy/DigitalClock/DigitalClock.types.js +1 -0
- package/legacy/DigitalClock/digitalClockClasses.js +6 -0
- package/legacy/DigitalClock/index.js +2 -0
- package/legacy/LocalizationProvider/LocalizationProvider.js +1 -1
- package/legacy/MobileDatePicker/MobileDatePicker.js +2 -1
- package/legacy/MobileDateTimePicker/MobileDateTimePicker.js +3 -1
- package/legacy/MobileTimePicker/MobileTimePicker.js +3 -1
- package/legacy/MultiSectionDigitalClock/MultiSectionDigitalClock.js +508 -0
- package/legacy/MultiSectionDigitalClock/MultiSectionDigitalClock.types.js +1 -0
- package/legacy/MultiSectionDigitalClock/MultiSectionDigitalClock.utils.js +65 -0
- package/legacy/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +157 -0
- package/legacy/MultiSectionDigitalClock/index.js +3 -0
- package/legacy/MultiSectionDigitalClock/multiSectionDigitalClockClasses.js +6 -0
- package/legacy/MultiSectionDigitalClock/multiSectionDigitalClockSectionClasses.js +6 -0
- package/legacy/PickersDay/PickersDay.js +3 -1
- package/legacy/PickersLayout/PickersLayout.js +2 -2
- package/legacy/StaticDatePicker/StaticDatePicker.js +1 -0
- package/legacy/StaticDateTimePicker/StaticDateTimePicker.js +5 -3
- package/legacy/StaticTimePicker/StaticTimePicker.js +5 -3
- package/legacy/TimeClock/TimeClock.js +35 -12
- package/legacy/TimeField/TimeField.js +21 -3
- package/legacy/TimeField/useTimeField.js +4 -2
- package/legacy/TimePicker/TimePicker.js +25 -2
- package/legacy/TimePicker/TimePickerToolbar.js +2 -2
- package/legacy/index.js +4 -1
- package/legacy/internals/constants/dimensions.js +2 -1
- package/legacy/internals/demo/DemoContainer.js +4 -1
- package/legacy/internals/hooks/date-helpers-hooks.js +3 -3
- package/legacy/internals/hooks/useDesktopPicker/useDesktopPicker.js +10 -11
- package/legacy/internals/hooks/useField/useField.js +11 -10
- package/legacy/internals/hooks/useField/useField.utils.js +58 -34
- package/legacy/internals/hooks/useField/useFieldCharacterEditing.js +18 -10
- package/legacy/internals/hooks/useField/useFieldState.js +7 -5
- package/legacy/internals/hooks/useMobilePicker/useMobilePicker.js +5 -6
- package/legacy/internals/hooks/usePicker/usePicker.js +2 -0
- package/legacy/internals/hooks/usePicker/usePickerValue.js +10 -14
- package/legacy/internals/hooks/useStaticPicker/useStaticPicker.js +7 -8
- package/legacy/internals/hooks/{validation/useValidation.js → useValidation.js} +1 -1
- package/legacy/internals/hooks/useViews.js +30 -14
- package/legacy/internals/index.js +5 -5
- package/legacy/internals/models/index.js +2 -1
- package/legacy/internals/models/props/clock.js +1 -0
- package/legacy/internals/models/validation.js +1 -0
- package/legacy/internals/utils/time-utils.js +2 -1
- package/legacy/internals/{hooks/validation/useDateValidation.js → utils/validation/validateDate.js} +1 -28
- package/legacy/internals/{hooks/validation/useDateTimeValidation.js → utils/validation/validateDateTime.js} +2 -2
- package/legacy/internals/{hooks/validation/useTimeValidation.js → utils/validation/validateTime.js} +1 -1
- package/legacy/internals/utils/valueManagers.js +2 -2
- package/legacy/locales/beBY.js +5 -3
- package/legacy/locales/caES.js +6 -1
- package/legacy/locales/csCZ.js +6 -4
- package/legacy/locales/daDK.js +6 -2
- package/legacy/locales/deDE.js +6 -2
- package/legacy/locales/enUS.js +4 -0
- package/legacy/locales/esES.js +6 -1
- package/legacy/locales/faIR.js +11 -1
- package/legacy/locales/fiFI.js +6 -1
- package/legacy/locales/frFR.js +6 -1
- package/legacy/locales/heIL.js +6 -1
- package/legacy/locales/huHU.js +6 -2
- package/legacy/locales/index.js +1 -0
- package/legacy/locales/isIS.js +11 -1
- package/legacy/locales/itIT.js +6 -1
- package/legacy/locales/jaJP.js +6 -2
- package/legacy/locales/koKR.js +6 -1
- package/legacy/locales/kzKZ.js +6 -2
- package/legacy/locales/nbNO.js +11 -1
- package/legacy/locales/nlNL.js +11 -1
- package/legacy/locales/plPL.js +11 -1
- package/legacy/locales/ptBR.js +11 -1
- package/legacy/locales/ruRU.js +6 -2
- package/legacy/locales/svSE.js +11 -1
- package/legacy/locales/trTR.js +22 -7
- package/legacy/locales/ukUA.js +11 -1
- package/legacy/locales/urPK.js +11 -1
- package/legacy/locales/zhCN.js +44 -23
- package/legacy/models/common.js +1 -0
- package/legacy/models/index.js +2 -1
- package/legacy/tests/describeAdapters/describeAdapters.js +1 -3
- package/legacy/tests/describeGregorianAdapter/describeGregorianAdapter.js +3 -1
- package/legacy/tests/describeGregorianAdapter/testCalculations.js +29 -26
- package/legacy/tests/describeGregorianAdapter/testLocalization.js +2 -2
- package/legacy/tests/describeHijriAdapter/describeHijriAdapter.js +23 -0
- package/legacy/tests/describeHijriAdapter/describeHijriAdapter.types.js +1 -0
- package/legacy/tests/describeHijriAdapter/index.js +1 -0
- package/legacy/tests/describeHijriAdapter/testCalculations.js +94 -0
- package/legacy/tests/describeHijriAdapter/testLocalization.js +12 -0
- package/legacy/tests/describeJalaliAdapter/describeJalaliAdapter.js +25 -0
- package/legacy/tests/describeJalaliAdapter/describeJalaliAdapter.types.js +1 -0
- package/legacy/tests/describeJalaliAdapter/index.js +1 -0
- package/legacy/tests/describeJalaliAdapter/testCalculations.js +82 -0
- package/legacy/tests/describeJalaliAdapter/testLocalization.js +12 -0
- package/legacy/tests/describePicker/describePicker.js +159 -0
- package/legacy/tests/describePicker/describePicker.types.js +1 -0
- package/legacy/tests/describePicker/index.js +1 -0
- package/legacy/tests/describeValue/describeValue.js +1 -1
- package/legacy/tests/describeValue/testControlledUnControlled.js +8 -9
- package/legacy/tests/describeValue/testPickerActionBar.js +46 -13
- package/legacy/tests/describeValue/testPickerOpenCloseLifeCycle.js +0 -5
- package/legacy/timeViewRenderers/index.js +1 -1
- package/legacy/timeViewRenderers/timeViewRenderers.js +132 -4
- package/locales/beBY.d.ts +4 -2
- package/locales/beBY.js +3 -3
- package/locales/caES.d.ts +4 -2
- package/locales/caES.js +4 -1
- package/locales/csCZ.d.ts +4 -2
- package/locales/csCZ.js +4 -4
- package/locales/daDK.d.ts +4 -2
- package/locales/daDK.js +4 -2
- package/locales/deDE.d.ts +4 -2
- package/locales/deDE.js +4 -2
- package/locales/enUS.d.ts +3 -2
- package/locales/enUS.js +2 -0
- package/locales/esES.d.ts +4 -2
- package/locales/esES.js +4 -1
- package/locales/faIR.d.ts +4 -2
- package/locales/faIR.js +9 -1
- package/locales/fiFI.d.ts +4 -2
- package/locales/fiFI.js +4 -1
- package/locales/frFR.d.ts +4 -2
- package/locales/frFR.js +4 -1
- package/locales/heIL.d.ts +4 -2
- package/locales/heIL.js +4 -1
- package/locales/huHU.d.ts +4 -2
- package/locales/huHU.js +4 -2
- package/locales/index.d.ts +1 -0
- package/locales/index.js +1 -0
- package/locales/isIS.d.ts +4 -2
- package/locales/isIS.js +9 -1
- package/locales/itIT.d.ts +4 -2
- package/locales/itIT.js +4 -1
- package/locales/jaJP.d.ts +4 -2
- package/locales/jaJP.js +4 -2
- package/locales/koKR.d.ts +4 -2
- package/locales/koKR.js +4 -1
- package/locales/kzKZ.d.ts +4 -2
- package/locales/kzKZ.js +4 -2
- package/locales/nbNO.d.ts +4 -2
- package/locales/nbNO.js +9 -1
- package/locales/nlNL.d.ts +8 -7
- package/locales/nlNL.js +9 -1
- package/locales/plPL.d.ts +4 -2
- package/locales/plPL.js +9 -1
- package/locales/ptBR.d.ts +4 -2
- package/locales/ptBR.js +9 -1
- package/locales/ruRU.d.ts +4 -2
- package/locales/ruRU.js +4 -2
- package/locales/svSE.d.ts +4 -2
- package/locales/svSE.js +9 -1
- package/locales/trTR.d.ts +4 -2
- package/locales/trTR.js +14 -7
- package/locales/ukUA.d.ts +4 -2
- package/locales/ukUA.js +9 -1
- package/locales/urPK.d.ts +4 -2
- package/locales/urPK.js +9 -1
- package/locales/utils/getPickersLocalization.d.ts +3 -2
- package/locales/utils/pickersLocaleTextApi.d.ts +5 -3
- package/locales/zhCN.d.ts +4 -2
- package/locales/zhCN.js +22 -23
- package/models/adapters.d.ts +7 -6
- package/models/common.d.ts +5 -0
- package/models/common.js +1 -0
- package/models/fields.d.ts +20 -2
- package/models/index.d.ts +1 -0
- package/models/index.js +2 -1
- package/modern/AdapterDateFns/AdapterDateFns.js +597 -0
- package/modern/AdapterDateFns/index.js +1 -149
- package/modern/AdapterDateFnsJalali/AdapterDateFnsJalali.js +608 -0
- package/modern/AdapterDateFnsJalali/index.js +1 -148
- package/modern/AdapterDayjs/AdapterDayjs.js +146 -111
- package/modern/AdapterLuxon/AdapterLuxon.js +512 -0
- package/modern/AdapterLuxon/index.js +1 -111
- package/modern/AdapterMoment/AdapterMoment.js +416 -0
- package/modern/AdapterMoment/index.js +1 -99
- package/modern/AdapterMomentHijri/AdapterMomentHijri.js +269 -0
- package/modern/AdapterMomentHijri/index.js +1 -74
- package/modern/AdapterMomentJalaali/AdapterMomentJalaali.js +276 -0
- package/modern/AdapterMomentJalaali/index.js +1 -87
- package/modern/DateCalendar/DayCalendar.js +1 -1
- package/modern/DateCalendar/useCalendarState.js +1 -1
- package/modern/DateCalendar/useIsDateDisabled.js +27 -0
- package/modern/DateField/DateField.js +20 -3
- package/modern/DateField/useDateField.js +4 -2
- package/modern/DatePicker/DatePickerToolbar.js +1 -1
- package/modern/DateTimeField/DateTimeField.js +21 -3
- package/modern/DateTimeField/useDateTimeField.js +4 -2
- package/modern/DateTimePicker/DateTimePicker.js +1 -0
- package/modern/DesktopDatePicker/DesktopDatePicker.js +2 -1
- package/modern/DesktopDateTimePicker/DesktopDateTimePicker.js +3 -1
- package/modern/DesktopTimePicker/DesktopTimePicker.js +50 -7
- package/modern/DigitalClock/DigitalClock.js +396 -0
- package/modern/DigitalClock/DigitalClock.types.js +1 -0
- package/modern/DigitalClock/digitalClockClasses.js +6 -0
- package/modern/DigitalClock/index.js +2 -0
- package/modern/LocalizationProvider/LocalizationProvider.js +1 -1
- package/modern/MobileDatePicker/MobileDatePicker.js +2 -1
- package/modern/MobileDateTimePicker/MobileDateTimePicker.js +3 -1
- package/modern/MobileTimePicker/MobileTimePicker.js +3 -1
- package/modern/MultiSectionDigitalClock/MultiSectionDigitalClock.js +479 -0
- package/modern/MultiSectionDigitalClock/MultiSectionDigitalClock.types.js +1 -0
- package/modern/MultiSectionDigitalClock/MultiSectionDigitalClock.utils.js +65 -0
- package/modern/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +149 -0
- package/modern/MultiSectionDigitalClock/index.js +3 -0
- package/modern/MultiSectionDigitalClock/multiSectionDigitalClockClasses.js +6 -0
- package/modern/MultiSectionDigitalClock/multiSectionDigitalClockSectionClasses.js +6 -0
- package/modern/PickersDay/PickersDay.js +4 -1
- package/modern/PickersLayout/PickersLayout.js +2 -2
- package/modern/StaticDatePicker/StaticDatePicker.js +1 -0
- package/modern/StaticDateTimePicker/StaticDateTimePicker.js +5 -3
- package/modern/StaticTimePicker/StaticTimePicker.js +5 -3
- package/modern/TimeClock/TimeClock.js +35 -12
- package/modern/TimeField/TimeField.js +21 -3
- package/modern/TimeField/useTimeField.js +4 -2
- package/modern/TimePicker/TimePicker.js +25 -2
- package/modern/TimePicker/TimePickerToolbar.js +2 -2
- package/modern/index.js +4 -1
- package/modern/internals/constants/dimensions.js +2 -1
- package/modern/internals/demo/DemoContainer.js +4 -1
- package/modern/internals/hooks/date-helpers-hooks.js +3 -3
- package/modern/internals/hooks/useDesktopPicker/useDesktopPicker.js +15 -15
- package/modern/internals/hooks/useField/useField.js +12 -11
- package/modern/internals/hooks/useField/useField.utils.js +60 -34
- package/modern/internals/hooks/useField/useFieldCharacterEditing.js +18 -10
- package/modern/internals/hooks/useField/useFieldState.js +5 -4
- package/modern/internals/hooks/useMobilePicker/useMobilePicker.js +10 -10
- package/modern/internals/hooks/usePicker/usePicker.js +2 -0
- package/modern/internals/hooks/usePicker/usePickerValue.js +10 -12
- package/modern/internals/hooks/useStaticPicker/useStaticPicker.js +10 -10
- package/modern/internals/hooks/{validation/useValidation.js → useValidation.js} +1 -1
- package/modern/internals/hooks/useViews.js +29 -13
- package/modern/internals/index.js +5 -5
- package/modern/internals/models/index.js +2 -1
- package/modern/internals/models/props/clock.js +1 -0
- package/modern/internals/models/validation.js +1 -0
- package/modern/internals/utils/time-utils.js +2 -1
- package/modern/internals/{hooks/validation/useDateValidation.js → utils/validation/validateDate.js} +1 -27
- package/{internals/hooks/validation/useDateTimeValidation.js → modern/internals/utils/validation/validateDateTime.js} +2 -2
- package/{internals/hooks/validation/useTimeValidation.js → modern/internals/utils/validation/validateTime.js} +1 -1
- package/modern/internals/utils/valueManagers.js +1 -1
- package/modern/locales/beBY.js +3 -3
- package/modern/locales/caES.js +4 -1
- package/modern/locales/csCZ.js +4 -4
- package/modern/locales/daDK.js +4 -2
- package/modern/locales/deDE.js +4 -2
- package/modern/locales/enUS.js +2 -0
- package/modern/locales/esES.js +4 -1
- package/modern/locales/faIR.js +9 -1
- package/modern/locales/fiFI.js +4 -1
- package/modern/locales/frFR.js +4 -1
- package/modern/locales/heIL.js +4 -1
- package/modern/locales/huHU.js +4 -2
- package/modern/locales/index.js +1 -0
- package/modern/locales/isIS.js +9 -1
- package/modern/locales/itIT.js +4 -1
- package/modern/locales/jaJP.js +4 -2
- package/modern/locales/koKR.js +4 -1
- package/modern/locales/kzKZ.js +4 -2
- package/modern/locales/nbNO.js +9 -1
- package/modern/locales/nlNL.js +9 -1
- package/modern/locales/plPL.js +9 -1
- package/modern/locales/ptBR.js +9 -1
- package/modern/locales/ruRU.js +4 -2
- package/modern/locales/svSE.js +9 -1
- package/modern/locales/trTR.js +14 -7
- package/modern/locales/ukUA.js +9 -1
- package/modern/locales/urPK.js +9 -1
- package/modern/locales/zhCN.js +22 -23
- package/modern/models/common.js +1 -0
- package/modern/models/index.js +2 -1
- package/modern/tests/describeAdapters/describeAdapters.js +1 -3
- package/modern/tests/describeGregorianAdapter/describeGregorianAdapter.js +3 -1
- package/modern/tests/describeGregorianAdapter/testCalculations.js +29 -26
- package/modern/tests/describeGregorianAdapter/testLocalization.js +2 -2
- package/modern/tests/describeHijriAdapter/describeHijriAdapter.js +23 -0
- package/modern/tests/describeHijriAdapter/describeHijriAdapter.types.js +1 -0
- package/modern/tests/describeHijriAdapter/index.js +1 -0
- package/modern/tests/describeHijriAdapter/testCalculations.js +91 -0
- package/modern/tests/describeHijriAdapter/testLocalization.js +13 -0
- package/modern/tests/describeJalaliAdapter/describeJalaliAdapter.js +25 -0
- package/modern/tests/describeJalaliAdapter/describeJalaliAdapter.types.js +1 -0
- package/modern/tests/describeJalaliAdapter/index.js +1 -0
- package/modern/tests/describeJalaliAdapter/testCalculations.js +83 -0
- package/modern/tests/describeJalaliAdapter/testLocalization.js +13 -0
- package/modern/tests/describePicker/describePicker.js +162 -0
- package/modern/tests/describePicker/describePicker.types.js +1 -0
- package/modern/tests/describePicker/index.js +1 -0
- package/modern/tests/describeValue/describeValue.js +1 -1
- package/modern/tests/describeValue/testControlledUnControlled.js +8 -9
- package/modern/tests/describeValue/testPickerActionBar.js +46 -13
- package/modern/tests/describeValue/testPickerOpenCloseLifeCycle.js +0 -5
- package/modern/timeViewRenderers/index.js +1 -1
- package/modern/timeViewRenderers/timeViewRenderers.js +130 -2
- package/node/AdapterDateFns/AdapterDateFns.js +607 -0
- package/node/AdapterDateFns/index.js +6 -152
- package/node/AdapterDateFnsJalali/AdapterDateFnsJalali.js +618 -0
- package/node/AdapterDateFnsJalali/index.js +6 -151
- package/node/AdapterDayjs/AdapterDayjs.js +146 -111
- package/node/AdapterLuxon/AdapterLuxon.js +521 -0
- package/node/AdapterLuxon/index.js +6 -114
- package/node/AdapterMoment/AdapterMoment.js +425 -0
- package/node/AdapterMoment/index.js +6 -102
- package/node/AdapterMomentHijri/AdapterMomentHijri.js +278 -0
- package/node/AdapterMomentHijri/index.js +6 -77
- package/node/AdapterMomentJalaali/AdapterMomentJalaali.js +285 -0
- package/node/AdapterMomentJalaali/index.js +6 -90
- package/node/DateCalendar/DayCalendar.js +2 -2
- package/node/DateCalendar/useCalendarState.js +2 -2
- package/node/{internals/hooks/validation/useDateValidation.js → DateCalendar/useIsDateDisabled.js} +4 -37
- package/node/DateField/DateField.js +20 -3
- package/node/DateField/useDateField.js +5 -3
- package/node/DatePicker/DatePickerToolbar.js +1 -1
- package/node/DateTimeField/DateTimeField.js +21 -3
- package/node/DateTimeField/useDateTimeField.js +5 -3
- package/node/DateTimePicker/DateTimePicker.js +1 -0
- package/node/DesktopDatePicker/DesktopDatePicker.js +3 -2
- package/node/DesktopDateTimePicker/DesktopDateTimePicker.js +4 -2
- package/node/DesktopTimePicker/DesktopTimePicker.js +51 -8
- package/node/DigitalClock/DigitalClock.js +406 -0
- package/node/DigitalClock/digitalClockClasses.js +15 -0
- package/node/DigitalClock/index.js +25 -0
- package/node/LocalizationProvider/LocalizationProvider.js +1 -1
- package/node/MobileDatePicker/MobileDatePicker.js +3 -2
- package/node/MobileDateTimePicker/MobileDateTimePicker.js +4 -2
- package/node/MobileTimePicker/MobileTimePicker.js +4 -2
- package/node/MultiSectionDigitalClock/MultiSectionDigitalClock.js +489 -0
- package/node/MultiSectionDigitalClock/MultiSectionDigitalClock.types.js +5 -0
- package/node/MultiSectionDigitalClock/MultiSectionDigitalClock.utils.js +73 -0
- package/node/MultiSectionDigitalClock/MultiSectionDigitalClockSection.js +159 -0
- package/node/MultiSectionDigitalClock/index.js +32 -0
- package/node/MultiSectionDigitalClock/multiSectionDigitalClockClasses.js +15 -0
- package/node/MultiSectionDigitalClock/multiSectionDigitalClockSectionClasses.js +15 -0
- package/node/PickersDay/PickersDay.js +4 -1
- package/node/PickersLayout/PickersLayout.js +2 -2
- package/node/StaticDatePicker/StaticDatePicker.js +1 -0
- package/node/StaticDateTimePicker/StaticDateTimePicker.js +5 -3
- package/node/StaticTimePicker/StaticTimePicker.js +5 -3
- package/node/TimeClock/TimeClock.js +35 -12
- package/node/TimeField/TimeField.js +21 -3
- package/node/TimeField/useTimeField.js +5 -3
- package/node/TimePicker/TimePicker.js +25 -2
- package/node/TimePicker/TimePickerToolbar.js +2 -2
- package/node/index.js +25 -1
- package/node/internals/constants/dimensions.js +4 -2
- package/node/internals/demo/DemoContainer.js +4 -1
- package/node/internals/hooks/date-helpers-hooks.js +3 -3
- package/node/internals/hooks/useDesktopPicker/useDesktopPicker.js +15 -15
- package/node/internals/hooks/useField/useField.js +12 -11
- package/node/internals/hooks/useField/useField.utils.js +63 -36
- package/node/internals/hooks/useField/useFieldCharacterEditing.js +17 -9
- package/node/internals/hooks/useField/useFieldState.js +5 -4
- package/node/internals/hooks/useMobilePicker/useMobilePicker.js +10 -10
- package/node/internals/hooks/usePicker/usePicker.js +2 -0
- package/node/internals/hooks/usePicker/usePickerValue.js +10 -12
- package/node/internals/hooks/useStaticPicker/useStaticPicker.js +10 -10
- package/node/internals/hooks/{validation/useValidation.js → useValidation.js} +1 -1
- package/node/internals/hooks/useViews.js +29 -13
- package/node/internals/index.js +9 -9
- package/node/internals/models/index.js +11 -0
- package/node/internals/models/props/clock.js +5 -0
- package/node/internals/models/validation.js +5 -0
- package/node/internals/utils/time-utils.js +2 -1
- package/node/internals/utils/validation/validateDate.js +40 -0
- package/node/internals/{hooks/validation/useDateTimeValidation.js → utils/validation/validateDateTime.js} +4 -4
- package/node/internals/{hooks/validation/useTimeValidation.js → utils/validation/validateTime.js} +1 -1
- package/node/internals/utils/valueManagers.js +1 -1
- package/node/locales/beBY.js +3 -3
- package/node/locales/caES.js +4 -1
- package/node/locales/csCZ.js +4 -2
- package/node/locales/daDK.js +4 -1
- package/node/locales/deDE.js +4 -1
- package/node/locales/enUS.js +2 -0
- package/node/locales/esES.js +4 -1
- package/node/locales/faIR.js +9 -1
- package/node/locales/fiFI.js +4 -1
- package/node/locales/frFR.js +4 -1
- package/node/locales/heIL.js +4 -1
- package/node/locales/huHU.js +4 -1
- package/node/locales/index.js +11 -0
- package/node/locales/isIS.js +9 -1
- package/node/locales/itIT.js +4 -1
- package/node/locales/jaJP.js +4 -1
- package/node/locales/koKR.js +4 -1
- package/node/locales/kzKZ.js +4 -1
- package/node/locales/nbNO.js +9 -1
- package/node/locales/nlNL.js +9 -1
- package/node/locales/plPL.js +9 -1
- package/node/locales/ptBR.js +9 -1
- package/node/locales/ruRU.js +4 -1
- package/node/locales/svSE.js +9 -1
- package/node/locales/trTR.js +14 -7
- package/node/locales/ukUA.js +9 -1
- package/node/locales/urPK.js +9 -1
- package/node/locales/zhCN.js +22 -23
- package/node/models/common.js +5 -0
- package/node/models/index.js +11 -0
- package/node/tests/describeAdapters/describeAdapters.js +1 -3
- package/node/tests/describeGregorianAdapter/describeGregorianAdapter.js +3 -1
- package/node/tests/describeGregorianAdapter/testCalculations.js +29 -26
- package/node/tests/describeGregorianAdapter/testLocalization.js +2 -2
- package/node/tests/describeHijriAdapter/describeHijriAdapter.js +31 -0
- package/node/tests/describeHijriAdapter/describeHijriAdapter.types.js +5 -0
- package/node/tests/describeHijriAdapter/index.js +12 -0
- package/node/tests/describeHijriAdapter/testCalculations.js +98 -0
- package/node/tests/describeHijriAdapter/testLocalization.js +20 -0
- package/node/tests/describeJalaliAdapter/describeJalaliAdapter.js +33 -0
- package/node/tests/describeJalaliAdapter/describeJalaliAdapter.types.js +5 -0
- package/node/tests/describeJalaliAdapter/index.js +12 -0
- package/node/tests/describeJalaliAdapter/testCalculations.js +90 -0
- package/node/tests/describeJalaliAdapter/testLocalization.js +20 -0
- package/node/tests/describePicker/describePicker.js +173 -0
- package/node/tests/describePicker/describePicker.types.js +5 -0
- package/node/tests/describePicker/index.js +12 -0
- package/node/tests/describeValue/describeValue.js +1 -1
- package/node/tests/describeValue/testControlledUnControlled.js +8 -9
- package/node/tests/describeValue/testPickerActionBar.js +46 -13
- package/node/tests/describeValue/testPickerOpenCloseLifeCycle.js +0 -5
- package/node/timeViewRenderers/index.js +12 -0
- package/node/timeViewRenderers/timeViewRenderers.js +134 -4
- package/package.json +3 -10
- package/tests/describeAdapters/describeAdapters.js +1 -3
- package/tests/describeGregorianAdapter/describeGregorianAdapter.js +3 -1
- package/tests/describeGregorianAdapter/testCalculations.js +29 -26
- package/tests/describeGregorianAdapter/testLocalization.js +2 -2
- package/tests/describeHijriAdapter/describeHijriAdapter.js +23 -0
- package/tests/describeHijriAdapter/describeHijriAdapter.types.js +1 -0
- package/tests/describeHijriAdapter/index.js +1 -0
- package/tests/describeHijriAdapter/testCalculations.js +91 -0
- package/tests/describeHijriAdapter/testLocalization.js +13 -0
- package/tests/describeJalaliAdapter/describeJalaliAdapter.js +25 -0
- package/tests/describeJalaliAdapter/describeJalaliAdapter.types.js +1 -0
- package/tests/describeJalaliAdapter/index.js +1 -0
- package/tests/describeJalaliAdapter/testCalculations.js +83 -0
- package/tests/describeJalaliAdapter/testLocalization.js +13 -0
- package/tests/describePicker/describePicker.js +162 -0
- package/tests/describePicker/describePicker.types.js +1 -0
- package/tests/describePicker/index.js +1 -0
- package/tests/describeValue/describeValue.js +1 -1
- package/tests/describeValue/testControlledUnControlled.js +8 -9
- package/tests/describeValue/testPickerActionBar.js +46 -13
- package/tests/describeValue/testPickerOpenCloseLifeCycle.js +0 -5
- package/themeAugmentation/components.d.ts +12 -0
- package/themeAugmentation/overrides.d.ts +8 -0
- package/themeAugmentation/props.d.ts +8 -0
- package/timeViewRenderers/index.d.ts +1 -1
- package/timeViewRenderers/index.js +1 -1
- package/timeViewRenderers/timeViewRenderers.d.ts +11 -4
- package/timeViewRenderers/timeViewRenderers.js +130 -2
- /package/{internals/hooks/validation/models.js → DigitalClock/DigitalClock.types.js} +0 -0
- /package/{legacy/internals/hooks/validation/models.js → MultiSectionDigitalClock/MultiSectionDigitalClock.types.js} +0 -0
- /package/{modern/internals/hooks/validation/models.js → internals/models/props/clock.js} +0 -0
- /package/internals/utils/{validation.d.ts → validation/extractValidationProps.d.ts} +0 -0
- /package/internals/utils/{validation.js → validation/extractValidationProps.js} +0 -0
- /package/legacy/internals/utils/{validation.js → validation/extractValidationProps.js} +0 -0
- /package/modern/internals/utils/{validation.js → validation/extractValidationProps.js} +0 -0
- /package/node/{internals/hooks/validation/models.js → DigitalClock/DigitalClock.types.js} +0 -0
- /package/node/internals/utils/{validation.js → validation/extractValidationProps.js} +0 -0
|
@@ -8,6 +8,7 @@ var React = _interopRequireWildcard(require("react"));
|
|
|
8
8
|
var _chai = require("chai");
|
|
9
9
|
var _sinon = require("sinon");
|
|
10
10
|
var _utils = require("@mui/monorepo/test/utils");
|
|
11
|
+
var _pickersUtils = require("test/utils/pickers-utils");
|
|
11
12
|
var _jsxRuntime = require("react/jsx-runtime");
|
|
12
13
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
13
14
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
@@ -18,17 +19,11 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
18
19
|
values,
|
|
19
20
|
emptyValue,
|
|
20
21
|
setNewValue,
|
|
21
|
-
variant,
|
|
22
22
|
type
|
|
23
23
|
} = getOptions();
|
|
24
24
|
if (componentFamily !== 'picker') {
|
|
25
25
|
return;
|
|
26
26
|
}
|
|
27
|
-
|
|
28
|
-
// No view to test
|
|
29
|
-
if (variant === 'desktop' && type === 'time') {
|
|
30
|
-
return;
|
|
31
|
-
}
|
|
32
27
|
describe('Picker action bar', () => {
|
|
33
28
|
describe('clear action', () => {
|
|
34
29
|
it('should call onClose, onChange with empty value and onAccept with empty value', () => {
|
|
@@ -41,7 +36,7 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
41
36
|
onClose: onClose,
|
|
42
37
|
defaultValue: values[0],
|
|
43
38
|
open: true,
|
|
44
|
-
|
|
39
|
+
slotProps: {
|
|
45
40
|
actionBar: {
|
|
46
41
|
actions: ['clear']
|
|
47
42
|
}
|
|
@@ -77,7 +72,7 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
77
72
|
onAccept: onAccept,
|
|
78
73
|
onClose: onClose,
|
|
79
74
|
open: true,
|
|
80
|
-
|
|
75
|
+
slotProps: {
|
|
81
76
|
actionBar: {
|
|
82
77
|
actions: ['clear']
|
|
83
78
|
}
|
|
@@ -103,7 +98,7 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
103
98
|
onClose: onClose,
|
|
104
99
|
open: true,
|
|
105
100
|
value: values[0],
|
|
106
|
-
|
|
101
|
+
slotProps: {
|
|
107
102
|
actionBar: {
|
|
108
103
|
actions: ['cancel']
|
|
109
104
|
}
|
|
@@ -139,7 +134,7 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
139
134
|
onClose: onClose,
|
|
140
135
|
open: true,
|
|
141
136
|
value: values[0],
|
|
142
|
-
|
|
137
|
+
slotProps: {
|
|
143
138
|
actionBar: {
|
|
144
139
|
actions: ['cancel']
|
|
145
140
|
}
|
|
@@ -165,7 +160,7 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
165
160
|
onClose: onClose,
|
|
166
161
|
open: true,
|
|
167
162
|
defaultValue: values[0],
|
|
168
|
-
|
|
163
|
+
slotProps: {
|
|
169
164
|
actionBar: {
|
|
170
165
|
actions: ['accept']
|
|
171
166
|
}
|
|
@@ -194,7 +189,7 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
194
189
|
onClose: onClose,
|
|
195
190
|
open: true,
|
|
196
191
|
defaultValue: values[0],
|
|
197
|
-
|
|
192
|
+
slotProps: {
|
|
198
193
|
actionBar: {
|
|
199
194
|
actions: ['accept']
|
|
200
195
|
}
|
|
@@ -218,7 +213,7 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
218
213
|
onClose: onClose,
|
|
219
214
|
open: true,
|
|
220
215
|
value: values[0],
|
|
221
|
-
|
|
216
|
+
slotProps: {
|
|
222
217
|
actionBar: {
|
|
223
218
|
actions: ['accept']
|
|
224
219
|
}
|
|
@@ -233,6 +228,44 @@ const testPickerActionBar = (ElementToTest, getOptions) => {
|
|
|
233
228
|
(0, _chai.expect)(onClose.callCount).to.equal(1);
|
|
234
229
|
});
|
|
235
230
|
});
|
|
231
|
+
describe('today action', () => {
|
|
232
|
+
it("should call onClose, onChange with today's value and onAccept with today's value", () => {
|
|
233
|
+
const onChange = (0, _sinon.spy)();
|
|
234
|
+
const onAccept = (0, _sinon.spy)();
|
|
235
|
+
const onClose = (0, _sinon.spy)();
|
|
236
|
+
render( /*#__PURE__*/(0, _jsxRuntime.jsx)(ElementToTest, {
|
|
237
|
+
onChange: onChange,
|
|
238
|
+
onAccept: onAccept,
|
|
239
|
+
onClose: onClose,
|
|
240
|
+
defaultValue: values[0],
|
|
241
|
+
open: true,
|
|
242
|
+
slotProps: {
|
|
243
|
+
actionBar: {
|
|
244
|
+
actions: ['today']
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
}));
|
|
248
|
+
_utils.userEvent.mousePress(_utils.screen.getByText(/today/i));
|
|
249
|
+
const startOfToday = type === 'date' ? _pickersUtils.adapterToUse.startOfDay(_pickersUtils.adapterToUse.date()) : _pickersUtils.adapterToUse.date();
|
|
250
|
+
(0, _chai.expect)(onChange.callCount).to.equal(1);
|
|
251
|
+
if (type === 'date-range') {
|
|
252
|
+
onChange.lastCall.args[0].forEach(value => {
|
|
253
|
+
(0, _chai.expect)(value).toEqualDateTime(startOfToday);
|
|
254
|
+
});
|
|
255
|
+
} else {
|
|
256
|
+
(0, _chai.expect)(onChange.lastCall.args[0]).toEqualDateTime(startOfToday);
|
|
257
|
+
}
|
|
258
|
+
(0, _chai.expect)(onAccept.callCount).to.equal(1);
|
|
259
|
+
if (type === 'date-range') {
|
|
260
|
+
onAccept.lastCall.args[0].forEach(value => {
|
|
261
|
+
(0, _chai.expect)(value).toEqualDateTime(startOfToday);
|
|
262
|
+
});
|
|
263
|
+
} else {
|
|
264
|
+
(0, _chai.expect)(onAccept.lastCall.args[0]).toEqualDateTime(startOfToday);
|
|
265
|
+
}
|
|
266
|
+
(0, _chai.expect)(onClose.callCount).to.equal(1);
|
|
267
|
+
});
|
|
268
|
+
});
|
|
236
269
|
});
|
|
237
270
|
};
|
|
238
271
|
exports.testPickerActionBar = testPickerActionBar;
|
|
@@ -27,11 +27,6 @@ const testPickerOpenCloseLifeCycle = (ElementToTest, getOptions) => {
|
|
|
27
27
|
if (componentFamily !== 'picker') {
|
|
28
28
|
return;
|
|
29
29
|
}
|
|
30
|
-
|
|
31
|
-
// No view to test
|
|
32
|
-
if (pickerParams.variant === 'desktop' && pickerParams.type === 'time') {
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
30
|
const viewWrapperRole = pickerParams.type === 'date-range' && pickerParams.variant === 'desktop' ? 'tooltip' : 'dialog';
|
|
36
31
|
describe('Picker open / close lifecycle', () => {
|
|
37
32
|
it('should not open on mount if `props.open` is false', () => {
|
|
@@ -3,6 +3,18 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
+
Object.defineProperty(exports, "renderDigitalClockTimeView", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function () {
|
|
9
|
+
return _timeViewRenderers.renderDigitalClockTimeView;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
Object.defineProperty(exports, "renderMultiSectionDigitalClockTimeView", {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
get: function () {
|
|
15
|
+
return _timeViewRenderers.renderMultiSectionDigitalClockTimeView;
|
|
16
|
+
}
|
|
17
|
+
});
|
|
6
18
|
Object.defineProperty(exports, "renderTimeViewClock", {
|
|
7
19
|
enumerable: true,
|
|
8
20
|
get: function () {
|
|
@@ -3,16 +3,20 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.renderTimeViewClock = void 0;
|
|
6
|
+
exports.renderTimeViewClock = exports.renderMultiSectionDigitalClockTimeView = exports.renderDigitalClockTimeView = void 0;
|
|
7
7
|
var React = _interopRequireWildcard(require("react"));
|
|
8
8
|
var _TimeClock = require("../TimeClock");
|
|
9
|
+
var _DigitalClock = require("../DigitalClock");
|
|
10
|
+
var _MultiSectionDigitalClock = require("../MultiSectionDigitalClock");
|
|
11
|
+
var _timeUtils = require("../internals/utils/time-utils");
|
|
9
12
|
var _jsxRuntime = require("react/jsx-runtime");
|
|
10
13
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
11
14
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
12
|
-
const isTimePickerView = view => view === 'hours' || view === 'minutes' || view === 'seconds';
|
|
13
15
|
const renderTimeViewClock = ({
|
|
14
16
|
view,
|
|
15
17
|
onViewChange,
|
|
18
|
+
focusedView,
|
|
19
|
+
onFocusedViewChange,
|
|
16
20
|
views,
|
|
17
21
|
value,
|
|
18
22
|
defaultValue,
|
|
@@ -41,7 +45,9 @@ const renderTimeViewClock = ({
|
|
|
41
45
|
}) => /*#__PURE__*/(0, _jsxRuntime.jsx)(_TimeClock.TimeClock, {
|
|
42
46
|
view: view,
|
|
43
47
|
onViewChange: onViewChange,
|
|
44
|
-
|
|
48
|
+
focusedView: focusedView,
|
|
49
|
+
onFocusedViewChange: onFocusedViewChange,
|
|
50
|
+
views: views.filter(_timeUtils.isTimeView),
|
|
45
51
|
value: value,
|
|
46
52
|
defaultValue: defaultValue,
|
|
47
53
|
onChange: onChange,
|
|
@@ -67,4 +73,128 @@ const renderTimeViewClock = ({
|
|
|
67
73
|
showViewSwitcher: showViewSwitcher,
|
|
68
74
|
disableIgnoringDatePartForTimeValidation: disableIgnoringDatePartForTimeValidation
|
|
69
75
|
});
|
|
70
|
-
exports.renderTimeViewClock = renderTimeViewClock;
|
|
76
|
+
exports.renderTimeViewClock = renderTimeViewClock;
|
|
77
|
+
const renderDigitalClockTimeView = ({
|
|
78
|
+
view,
|
|
79
|
+
onViewChange,
|
|
80
|
+
focusedView,
|
|
81
|
+
onFocusedViewChange,
|
|
82
|
+
views,
|
|
83
|
+
value,
|
|
84
|
+
defaultValue,
|
|
85
|
+
onChange,
|
|
86
|
+
className,
|
|
87
|
+
classes,
|
|
88
|
+
disableFuture,
|
|
89
|
+
disablePast,
|
|
90
|
+
minTime,
|
|
91
|
+
maxTime,
|
|
92
|
+
shouldDisableTime,
|
|
93
|
+
shouldDisableClock,
|
|
94
|
+
minutesStep,
|
|
95
|
+
ampm,
|
|
96
|
+
components,
|
|
97
|
+
componentsProps,
|
|
98
|
+
slots,
|
|
99
|
+
slotProps,
|
|
100
|
+
readOnly,
|
|
101
|
+
disabled,
|
|
102
|
+
sx,
|
|
103
|
+
autoFocus,
|
|
104
|
+
disableIgnoringDatePartForTimeValidation,
|
|
105
|
+
timeSteps,
|
|
106
|
+
skipDisabled
|
|
107
|
+
}) => /*#__PURE__*/(0, _jsxRuntime.jsx)(_DigitalClock.DigitalClock, {
|
|
108
|
+
view: view,
|
|
109
|
+
onViewChange: onViewChange,
|
|
110
|
+
focusedView: focusedView,
|
|
111
|
+
onFocusedViewChange: onFocusedViewChange,
|
|
112
|
+
views: views.filter(_timeUtils.isTimeView),
|
|
113
|
+
value: value,
|
|
114
|
+
defaultValue: defaultValue,
|
|
115
|
+
onChange: onChange,
|
|
116
|
+
className: className,
|
|
117
|
+
classes: classes,
|
|
118
|
+
disableFuture: disableFuture,
|
|
119
|
+
disablePast: disablePast,
|
|
120
|
+
minTime: minTime,
|
|
121
|
+
maxTime: maxTime,
|
|
122
|
+
shouldDisableTime: shouldDisableTime,
|
|
123
|
+
shouldDisableClock: shouldDisableClock,
|
|
124
|
+
minutesStep: minutesStep,
|
|
125
|
+
ampm: ampm,
|
|
126
|
+
components: components,
|
|
127
|
+
componentsProps: componentsProps,
|
|
128
|
+
slots: slots,
|
|
129
|
+
slotProps: slotProps,
|
|
130
|
+
readOnly: readOnly,
|
|
131
|
+
disabled: disabled,
|
|
132
|
+
sx: sx,
|
|
133
|
+
autoFocus: autoFocus,
|
|
134
|
+
disableIgnoringDatePartForTimeValidation: disableIgnoringDatePartForTimeValidation,
|
|
135
|
+
timeStep: timeSteps?.minutes,
|
|
136
|
+
skipDisabled: skipDisabled
|
|
137
|
+
});
|
|
138
|
+
exports.renderDigitalClockTimeView = renderDigitalClockTimeView;
|
|
139
|
+
const renderMultiSectionDigitalClockTimeView = ({
|
|
140
|
+
view,
|
|
141
|
+
onViewChange,
|
|
142
|
+
focusedView,
|
|
143
|
+
onFocusedViewChange,
|
|
144
|
+
views,
|
|
145
|
+
value,
|
|
146
|
+
defaultValue,
|
|
147
|
+
onChange,
|
|
148
|
+
className,
|
|
149
|
+
classes,
|
|
150
|
+
disableFuture,
|
|
151
|
+
disablePast,
|
|
152
|
+
minTime,
|
|
153
|
+
maxTime,
|
|
154
|
+
shouldDisableTime,
|
|
155
|
+
shouldDisableClock,
|
|
156
|
+
minutesStep,
|
|
157
|
+
ampm,
|
|
158
|
+
components,
|
|
159
|
+
componentsProps,
|
|
160
|
+
slots,
|
|
161
|
+
slotProps,
|
|
162
|
+
readOnly,
|
|
163
|
+
disabled,
|
|
164
|
+
sx,
|
|
165
|
+
autoFocus,
|
|
166
|
+
disableIgnoringDatePartForTimeValidation,
|
|
167
|
+
timeSteps,
|
|
168
|
+
skipDisabled
|
|
169
|
+
}) => /*#__PURE__*/(0, _jsxRuntime.jsx)(_MultiSectionDigitalClock.MultiSectionDigitalClock, {
|
|
170
|
+
view: view,
|
|
171
|
+
onViewChange: onViewChange,
|
|
172
|
+
focusedView: focusedView,
|
|
173
|
+
onFocusedViewChange: onFocusedViewChange,
|
|
174
|
+
views: views.filter(_timeUtils.isTimeView),
|
|
175
|
+
value: value,
|
|
176
|
+
defaultValue: defaultValue,
|
|
177
|
+
onChange: onChange,
|
|
178
|
+
className: className,
|
|
179
|
+
classes: classes,
|
|
180
|
+
disableFuture: disableFuture,
|
|
181
|
+
disablePast: disablePast,
|
|
182
|
+
minTime: minTime,
|
|
183
|
+
maxTime: maxTime,
|
|
184
|
+
shouldDisableTime: shouldDisableTime,
|
|
185
|
+
shouldDisableClock: shouldDisableClock,
|
|
186
|
+
minutesStep: minutesStep,
|
|
187
|
+
ampm: ampm,
|
|
188
|
+
components: components,
|
|
189
|
+
componentsProps: componentsProps,
|
|
190
|
+
slots: slots,
|
|
191
|
+
slotProps: slotProps,
|
|
192
|
+
readOnly: readOnly,
|
|
193
|
+
disabled: disabled,
|
|
194
|
+
sx: sx,
|
|
195
|
+
autoFocus: autoFocus,
|
|
196
|
+
disableIgnoringDatePartForTimeValidation: disableIgnoringDatePartForTimeValidation,
|
|
197
|
+
timeSteps: timeSteps,
|
|
198
|
+
skipDisabled: skipDisabled
|
|
199
|
+
});
|
|
200
|
+
exports.renderMultiSectionDigitalClockTimeView = renderMultiSectionDigitalClockTimeView;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mui/x-date-pickers",
|
|
3
|
-
"version": "6.
|
|
3
|
+
"version": "6.3.0",
|
|
4
4
|
"description": "The community edition of the date picker components (MUI X).",
|
|
5
5
|
"author": "MUI Team",
|
|
6
6
|
"main": "./node/index.js",
|
|
@@ -34,14 +34,7 @@
|
|
|
34
34
|
},
|
|
35
35
|
"dependencies": {
|
|
36
36
|
"@babel/runtime": "^7.21.0",
|
|
37
|
-
"@
|
|
38
|
-
"@date-io/date-fns": "^2.16.0",
|
|
39
|
-
"@date-io/date-fns-jalali": "^2.16.0",
|
|
40
|
-
"@date-io/hijri": "^2.16.1",
|
|
41
|
-
"@date-io/jalaali": "^2.16.1",
|
|
42
|
-
"@date-io/luxon": "^2.16.1",
|
|
43
|
-
"@date-io/moment": "^2.16.1",
|
|
44
|
-
"@mui/utils": "^5.11.13",
|
|
37
|
+
"@mui/utils": "^5.12.0",
|
|
45
38
|
"@types/react-transition-group": "^4.4.5",
|
|
46
39
|
"clsx": "^1.2.1",
|
|
47
40
|
"prop-types": "^15.8.1",
|
|
@@ -59,7 +52,7 @@
|
|
|
59
52
|
"luxon": "^3.0.2",
|
|
60
53
|
"moment": "^2.29.4",
|
|
61
54
|
"moment-hijri": "^2.1.2",
|
|
62
|
-
"moment-jalaali": "^0.7.4 || ^0.8.0 || ^0.9.0",
|
|
55
|
+
"moment-jalaali": "^0.7.4 || ^0.8.0 || ^0.9.0 || ^0.10.0",
|
|
63
56
|
"react": "^17.0.2 || ^18.0.0",
|
|
64
57
|
"react-dom": "^17.0.2 || ^18.0.0"
|
|
65
58
|
},
|
|
@@ -20,9 +20,7 @@ function innerDescribeAdapters(title, FieldComponent, testRunner) {
|
|
|
20
20
|
render: pickerRendererResponse.render,
|
|
21
21
|
Component: FieldComponent
|
|
22
22
|
});
|
|
23
|
-
testRunner(_extends({
|
|
24
|
-
adapterName
|
|
25
|
-
}, pickerRendererResponse, fieldInteractions));
|
|
23
|
+
testRunner(_extends({}, pickerRendererResponse, fieldInteractions));
|
|
26
24
|
});
|
|
27
25
|
});
|
|
28
26
|
}
|
|
@@ -5,7 +5,9 @@ import { testLocalization } from './testLocalization';
|
|
|
5
5
|
import { testFormat } from './testFormat';
|
|
6
6
|
export const TEST_DATE_ISO = '2018-10-30T11:44:00.000Z';
|
|
7
7
|
function innerGregorianDescribeAdapter(Adapter, params) {
|
|
8
|
-
const adapter = new Adapter({
|
|
8
|
+
const adapter = new Adapter({
|
|
9
|
+
locale: params.locale
|
|
10
|
+
});
|
|
9
11
|
describe(adapter.lib, () => {
|
|
10
12
|
const testSuitParams = _extends({}, params, {
|
|
11
13
|
adapter,
|
|
@@ -87,100 +87,103 @@ export const testCalculations = ({
|
|
|
87
87
|
it('Method: endOfDay', () => {
|
|
88
88
|
expect(adapter.formatByString(adapter.endOfDay(testDate), formatDateTime)).to.equal('2018-10-30 23:59:59');
|
|
89
89
|
});
|
|
90
|
-
it('Method:getPreviousMonth', () => {
|
|
90
|
+
it('Method: getPreviousMonth', () => {
|
|
91
91
|
expect(adapter.formatByString(adapter.getPreviousMonth(testDate), formatDateTime)).to.equal('2018-09-30 11:44:00');
|
|
92
92
|
});
|
|
93
|
-
it('Method:getMonthArray', () => {
|
|
93
|
+
it('Method: getMonthArray', () => {
|
|
94
94
|
expect(adapter.getMonthArray(testDate).map(date => adapter.formatByString(date, formatDateTime))).to.deep.equal(['2018-01-01 00:00:00', '2018-02-01 00:00:00', '2018-03-01 00:00:00', '2018-04-01 00:00:00', '2018-05-01 00:00:00', '2018-06-01 00:00:00', '2018-07-01 00:00:00', '2018-08-01 00:00:00', '2018-09-01 00:00:00', '2018-10-01 00:00:00', '2018-11-01 00:00:00', '2018-12-01 00:00:00']);
|
|
95
95
|
});
|
|
96
|
-
it('Method:getNextMonth', () => {
|
|
96
|
+
it('Method: getNextMonth', () => {
|
|
97
97
|
expect(adapter.formatByString(adapter.getNextMonth(testDate), formatDateTime)).to.equal('2018-11-30 11:44:00');
|
|
98
98
|
});
|
|
99
|
-
it('Method:getHours', () => {
|
|
99
|
+
it('Method: getHours', () => {
|
|
100
100
|
expect(adapter.getHours(testDate)).to.equal(new Date(testDateISO).getHours());
|
|
101
101
|
});
|
|
102
|
-
it('Method:getMinutes', () => {
|
|
102
|
+
it('Method: getMinutes', () => {
|
|
103
103
|
expect(adapter.getMinutes(testDate)).to.equal(44);
|
|
104
104
|
});
|
|
105
|
-
it('Method:getSeconds', () => {
|
|
105
|
+
it('Method: getSeconds', () => {
|
|
106
106
|
expect(adapter.getSeconds(testDate)).to.equal(0);
|
|
107
107
|
});
|
|
108
|
-
it('Method:getDate', () => {
|
|
108
|
+
it('Method: getDate', () => {
|
|
109
109
|
expect(adapter.getDate(testDate)).to.equal(30);
|
|
110
110
|
});
|
|
111
|
-
it('Method:getYear', () => {
|
|
111
|
+
it('Method: getYear', () => {
|
|
112
112
|
expect(adapter.getYear(testDate)).to.equal(2018);
|
|
113
113
|
});
|
|
114
|
-
it('Method:getMonth', () => {
|
|
114
|
+
it('Method: getMonth', () => {
|
|
115
115
|
expect(adapter.getMonth(testDate)).to.equal(9);
|
|
116
116
|
});
|
|
117
|
-
it('Method:getDaysInMonth', () => {
|
|
117
|
+
it('Method: getDaysInMonth', () => {
|
|
118
118
|
expect(adapter.getDaysInMonth(testDate)).to.equal(31);
|
|
119
119
|
});
|
|
120
|
-
it('Method:setMonth', () => {
|
|
120
|
+
it('Method: setMonth', () => {
|
|
121
121
|
const updatedTime = adapter.formatByString(adapter.setMonth(testDate, 4), formatDateTime);
|
|
122
122
|
expect(updatedTime).to.equal('2018-05-30 11:44:00');
|
|
123
123
|
});
|
|
124
|
-
it('Method:setHours', () => {
|
|
124
|
+
it('Method: setHours', () => {
|
|
125
125
|
const updatedTime = adapter.formatByString(adapter.setHours(testDate, 0), formatDateTime);
|
|
126
126
|
expect(updatedTime).to.equal('2018-10-30 00:44:00');
|
|
127
127
|
});
|
|
128
|
-
it('Method:setMinutes', () => {
|
|
128
|
+
it('Method: setMinutes', () => {
|
|
129
129
|
const updatedTime = adapter.formatByString(adapter.setMinutes(testDate, 12), formatDateTime);
|
|
130
130
|
expect(updatedTime).to.equal('2018-10-30 11:12:00');
|
|
131
131
|
});
|
|
132
|
-
it('Method:setMinutes', () => {
|
|
132
|
+
it('Method: setMinutes', () => {
|
|
133
133
|
const updatedTime = adapter.formatByString(adapter.setMinutes(testDate, 12), formatDateTime);
|
|
134
134
|
expect(updatedTime).to.equal('2018-10-30 11:12:00');
|
|
135
135
|
});
|
|
136
|
-
it('Method:setYear', () => {
|
|
136
|
+
it('Method: setYear', () => {
|
|
137
137
|
const updatedTime = adapter.formatByString(adapter.setYear(testDate, 2011), formatDateTime);
|
|
138
138
|
expect(updatedTime).to.equal('2011-10-30 11:44:00');
|
|
139
139
|
});
|
|
140
|
-
it('Method:setDate', () => {
|
|
140
|
+
it('Method: setDate', () => {
|
|
141
141
|
const updatedTime = adapter.formatByString(adapter.setDate(testDate, 15), formatDateTime);
|
|
142
142
|
expect(updatedTime).to.equal('2018-10-15 11:44:00');
|
|
143
143
|
});
|
|
144
|
-
it('Method:setSeconds', () => {
|
|
144
|
+
it('Method: setSeconds', () => {
|
|
145
145
|
const updatedValue = adapter.formatByString(adapter.setSeconds(testDate, 11), formatDateTime);
|
|
146
146
|
expect(updatedValue).to.equal('2018-10-30 11:44:11');
|
|
147
147
|
});
|
|
148
|
-
it('Method:isAfter', () => {
|
|
148
|
+
it('Method: isAfter', () => {
|
|
149
149
|
expect(adapter.isAfter(adapter.date(), testDate)).to.equal(true);
|
|
150
150
|
expect(adapter.isAfter(testDate, adapter.date())).to.equal(false);
|
|
151
151
|
});
|
|
152
|
-
it('Method:isBefore', () => {
|
|
152
|
+
it('Method: isBefore', () => {
|
|
153
153
|
expect(adapter.isBefore(testDate, adapter.date())).to.equal(true);
|
|
154
154
|
expect(adapter.isBefore(adapter.date(), testDate)).to.equal(false);
|
|
155
155
|
});
|
|
156
|
-
it('Method:isAfterDay', () => {
|
|
156
|
+
it('Method: isAfterDay', () => {
|
|
157
157
|
const nextDay = adapter.addDays(testDate, 1);
|
|
158
158
|
expect(adapter.isAfterDay(nextDay, testDate)).to.equal(true);
|
|
159
159
|
expect(adapter.isAfterDay(testDate, nextDay)).to.equal(false);
|
|
160
160
|
});
|
|
161
|
-
it('Method:isBeforeDay', () => {
|
|
161
|
+
it('Method: isBeforeDay', () => {
|
|
162
162
|
const previousDay = adapter.addDays(testDate, -1);
|
|
163
163
|
expect(adapter.isBeforeDay(testDate, previousDay)).to.equal(false);
|
|
164
164
|
expect(adapter.isBeforeDay(previousDay, testDate)).to.equal(true);
|
|
165
165
|
});
|
|
166
|
-
it('Method:isAfterYear', () => {
|
|
166
|
+
it('Method: isAfterYear', () => {
|
|
167
167
|
const nextYear = adapter.setYear(testDate, 2019);
|
|
168
168
|
expect(adapter.isAfterYear(nextYear, testDate)).to.equal(true);
|
|
169
169
|
expect(adapter.isAfterYear(testDate, nextYear)).to.equal(false);
|
|
170
170
|
});
|
|
171
|
-
it('Method:isBeforeYear', () => {
|
|
171
|
+
it('Method: isBeforeYear', () => {
|
|
172
172
|
const previousYear = adapter.setYear(testDate, 2017);
|
|
173
173
|
expect(adapter.isBeforeYear(testDate, previousYear)).to.equal(false);
|
|
174
174
|
expect(adapter.isBeforeYear(previousYear, testDate)).to.equal(true);
|
|
175
175
|
});
|
|
176
|
-
it('Method:getWeekArray', () => {
|
|
176
|
+
it('Method: getWeekArray', () => {
|
|
177
177
|
const weekArray = adapter.getWeekArray(testDate);
|
|
178
178
|
expect(weekArray).to.have.length(5);
|
|
179
179
|
weekArray.forEach(week => {
|
|
180
180
|
expect(week).to.have.length(7);
|
|
181
181
|
});
|
|
182
182
|
});
|
|
183
|
-
it('Method:
|
|
183
|
+
it('Method: getWeekNumber', () => {
|
|
184
|
+
expect(adapter.getWeekNumber(testDate)).to.equal(44);
|
|
185
|
+
});
|
|
186
|
+
it('Method: getYearRange', () => {
|
|
184
187
|
const yearRange = adapter.getYearRange(testDate, adapter.setYear(testDate, 2124));
|
|
185
188
|
expect(yearRange).to.have.length(107);
|
|
186
189
|
expect(adapter.getYear(yearRange[yearRange.length - 1])).to.equal(2124);
|
|
@@ -190,7 +193,7 @@ export const testCalculations = ({
|
|
|
190
193
|
it('Method: getDiff', () => {
|
|
191
194
|
expect(adapter.getDiff(testDate, adapter.date('2018-10-29T11:44:00.000Z'))).to.equal(86400000);
|
|
192
195
|
expect(adapter.getDiff(testDate, adapter.date('2018-10-31T11:44:00.000Z'))).to.equal(-86400000);
|
|
193
|
-
expect(adapter.getDiff(testDate, '2018-10-31T11:44:00.000Z')).to.equal(-86400000);
|
|
196
|
+
expect(adapter.getDiff(testDate, adapter.date('2018-10-31T11:44:00.000Z'))).to.equal(-86400000);
|
|
194
197
|
|
|
195
198
|
// With units
|
|
196
199
|
expect(adapter.getDiff(testDate, adapter.date('2017-09-29T11:44:00.000Z'), 'years')).to.equal(1);
|
|
@@ -10,7 +10,7 @@ export const testLocalization = ({
|
|
|
10
10
|
expect(adapter.getMeridiemText('pm')).to.equal('PM');
|
|
11
11
|
});
|
|
12
12
|
it('Method: getFormatHelperText', () => {
|
|
13
|
-
expect(adapter.getFormatHelperText(adapter.formats.keyboardDate)).to.equal('mm/dd/yyyy');
|
|
14
|
-
expect(adapter.getFormatHelperText(adapter.formats.keyboardDateTime12h)).to.equal('mm/dd/yyyy hh:mm (a|p)m');
|
|
13
|
+
expect(adapter.getFormatHelperText(adapter.formats.keyboardDate)).to.equal(adapter.lib === 'luxon' ? 'm/d/yyyy' : 'mm/dd/yyyy');
|
|
14
|
+
expect(adapter.getFormatHelperText(adapter.formats.keyboardDateTime12h)).to.equal(adapter.lib === 'luxon' ? 'm/d/yyyy hh:mm (a|p)m' : 'mm/dd/yyyy hh:mm (a|p)m');
|
|
15
15
|
});
|
|
16
16
|
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
+
import createDescribe from '@mui/monorepo/test/utils/createDescribe';
|
|
3
|
+
import { testCalculations } from './testCalculations';
|
|
4
|
+
import { testLocalization } from './testLocalization';
|
|
5
|
+
import { TEST_DATE_ISO } from '../describeGregorianAdapter';
|
|
6
|
+
function innerJalaliDescribeAdapter(Adapter, params) {
|
|
7
|
+
const adapter = new Adapter();
|
|
8
|
+
describe(adapter.lib, () => {
|
|
9
|
+
const testSuitParams = _extends({}, params, {
|
|
10
|
+
adapter,
|
|
11
|
+
testDate: adapter.date(TEST_DATE_ISO)
|
|
12
|
+
});
|
|
13
|
+
if (params.before) {
|
|
14
|
+
before(params.before);
|
|
15
|
+
}
|
|
16
|
+
if (params.after) {
|
|
17
|
+
after(params.after);
|
|
18
|
+
}
|
|
19
|
+
testCalculations(testSuitParams);
|
|
20
|
+
testLocalization(testSuitParams);
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
export const describeHijriAdapter = createDescribe('Adapter methods', innerJalaliDescribeAdapter);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { describeHijriAdapter } from './describeHijriAdapter';
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
import { TEST_DATE_ISO } from '../describeGregorianAdapter';
|
|
3
|
+
export const testCalculations = ({
|
|
4
|
+
adapter,
|
|
5
|
+
testDate
|
|
6
|
+
}) => {
|
|
7
|
+
it('Method: date', () => {
|
|
8
|
+
expect(adapter.date(null)).to.equal(null);
|
|
9
|
+
});
|
|
10
|
+
it('Method: parse', () => {
|
|
11
|
+
expect(adapter.parse('', 'iYYYY/iM/iD')).to.equal(null);
|
|
12
|
+
expect(adapter.parse('01/01/1395', 'iYYYY/iM/iD')).not.to.equal(null);
|
|
13
|
+
});
|
|
14
|
+
it('Method: isEqual', () => {
|
|
15
|
+
const anotherDate = adapter.date(TEST_DATE_ISO);
|
|
16
|
+
expect(adapter.isEqual(testDate, anotherDate)).to.equal(true);
|
|
17
|
+
expect(adapter.isEqual(null, null)).to.equal(true);
|
|
18
|
+
});
|
|
19
|
+
it('Method: isAfterYear', () => {
|
|
20
|
+
const afterYear = adapter.addYears(testDate, 2);
|
|
21
|
+
expect(adapter.isAfterYear(afterYear, testDate)).to.equal(true);
|
|
22
|
+
});
|
|
23
|
+
it('Method: isBeforeYear', () => {
|
|
24
|
+
const afterYear = adapter.addYears(testDate, 2);
|
|
25
|
+
expect(adapter.isBeforeYear(testDate, afterYear)).to.equal(true);
|
|
26
|
+
});
|
|
27
|
+
it('Method: startOfYear', () => {
|
|
28
|
+
expect(adapter.startOfYear(testDate)).toEqualDateTime(new Date('2018-09-11T00:00:00.000Z'));
|
|
29
|
+
});
|
|
30
|
+
it('Method: startOfMonth', () => {
|
|
31
|
+
expect(adapter.startOfMonth(testDate)).toEqualDateTime(new Date('2018-10-10T00:00:00.000Z'));
|
|
32
|
+
});
|
|
33
|
+
it('Method: endOfYear', () => {
|
|
34
|
+
expect(adapter.endOfYear(testDate)).toEqualDateTime(new Date('2019-08-30T23:59:59.999Z'));
|
|
35
|
+
});
|
|
36
|
+
it('Method: endOfMonth', () => {
|
|
37
|
+
expect(adapter.endOfMonth(testDate)).toEqualDateTime(new Date('2018-11-08T23:59:59.999Z'));
|
|
38
|
+
});
|
|
39
|
+
it('Method: getYear', () => {
|
|
40
|
+
expect(adapter.getYear(testDate)).to.equal(1440);
|
|
41
|
+
});
|
|
42
|
+
it('Method: getMonth', () => {
|
|
43
|
+
expect(adapter.getMonth(testDate)).to.equal(1);
|
|
44
|
+
});
|
|
45
|
+
it('Method: getDate', () => {
|
|
46
|
+
expect(adapter.getDate(testDate)).to.equal(21);
|
|
47
|
+
});
|
|
48
|
+
it('Method: setYear', () => {
|
|
49
|
+
expect(adapter.setYear(testDate, 1441)).toEqualDateTime(new Date('2019-10-20T11:44:00.000Z'));
|
|
50
|
+
});
|
|
51
|
+
it('Method: setDate', () => {
|
|
52
|
+
expect(adapter.setDate(testDate, 22)).toEqualDateTime(new Date('2018-10-31T11:44:00.000Z'));
|
|
53
|
+
});
|
|
54
|
+
it('Method: getNextMonth', () => {
|
|
55
|
+
expect(adapter.getNextMonth(testDate)).toEqualDateTime(new Date('2018-11-29T11:44:00.000Z'));
|
|
56
|
+
});
|
|
57
|
+
it('Method: getPreviousMonth', () => {
|
|
58
|
+
expect(adapter.getPreviousMonth(testDate)).toEqualDateTime(new Date('2018-10-01T11:44:00.000Z'));
|
|
59
|
+
});
|
|
60
|
+
it('Method: getWeekdays', () => {
|
|
61
|
+
expect(adapter.getWeekdays()).to.deep.equal(['ح', 'ن', 'ث', 'ر', 'خ', 'ج', 'س']);
|
|
62
|
+
});
|
|
63
|
+
it('Method: getWeekArray', () => {
|
|
64
|
+
const weekArray = adapter.getWeekArray(testDate);
|
|
65
|
+
const expectedDate = new Date('2018-10-07T00:00:00.000Z');
|
|
66
|
+
weekArray.forEach(week => {
|
|
67
|
+
week.forEach(day => {
|
|
68
|
+
expect(day).toEqualDateTime(expectedDate);
|
|
69
|
+
expectedDate.setDate(expectedDate.getDate() + 1);
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
it('Method: getWeekNumber', () => {
|
|
74
|
+
expect(adapter.getWeekNumber(testDate)).to.equal(8);
|
|
75
|
+
});
|
|
76
|
+
describe('Method: getYearRange', () => {
|
|
77
|
+
it('Minimum limit', () => {
|
|
78
|
+
const anotherYear = adapter.setYear(testDate, 1355);
|
|
79
|
+
expect(() => adapter.getYearRange(anotherYear, testDate)).to.throw('min date must be on or after 1356-01-01 H (1937-03-14)');
|
|
80
|
+
});
|
|
81
|
+
it('Maximum limit', () => {
|
|
82
|
+
const anotherYear = adapter.setYear(testDate, 1500);
|
|
83
|
+
expect(() => adapter.getYearRange(testDate, anotherYear)).to.throw('max date must be on or before 1499-12-29 H (2076-11-26)');
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
it('Method: getYearRange', () => {
|
|
87
|
+
const anotherDate = adapter.setYear(testDate, 1445);
|
|
88
|
+
const yearRange = adapter.getYearRange(testDate, anotherDate);
|
|
89
|
+
expect(yearRange).to.have.length(6);
|
|
90
|
+
});
|
|
91
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
export const testLocalization = ({
|
|
3
|
+
adapter
|
|
4
|
+
}) => {
|
|
5
|
+
it('Method: formatNumber', () => {
|
|
6
|
+
expect(adapter.formatNumber('1')).to.equal('١');
|
|
7
|
+
expect(adapter.formatNumber('2')).to.equal('٢');
|
|
8
|
+
});
|
|
9
|
+
it('Method: getMeridiemText', () => {
|
|
10
|
+
expect(adapter.getMeridiemText('am')).to.equal('ص');
|
|
11
|
+
expect(adapter.getMeridiemText('pm')).to.equal('م');
|
|
12
|
+
});
|
|
13
|
+
};
|