@mui/x-date-pickers-pro 8.0.0-alpha.0 → 8.0.0-alpha.10
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/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.d.ts +1 -1
- package/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.js +1 -1
- package/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/package.json +1 -1
- package/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.d.ts +1 -1
- package/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.js +1 -1
- package/{AdapterDateFnsV3 → AdapterDateFnsV2}/package.json +1 -1
- package/CHANGELOG.md +2215 -119
- package/DateRangeCalendar/DateRangeCalendar.js +18 -14
- package/DateRangePicker/DateRangePicker.js +1 -4
- package/DateRangePicker/DateRangePicker.types.d.ts +6 -2
- package/DateRangePicker/DateRangePickerToolbar.d.ts +2 -3
- package/DateRangePicker/DateRangePickerToolbar.js +33 -53
- package/DateRangePicker/shared.d.ts +4 -3
- package/DateTimeRangePicker/DateTimeRangePicker.js +2 -5
- package/DateTimeRangePicker/DateTimeRangePicker.types.d.ts +1 -2
- package/DateTimeRangePicker/DateTimeRangePickerTabs.d.ts +4 -5
- package/DateTimeRangePicker/DateTimeRangePickerTabs.js +35 -33
- package/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.d.ts +8 -10
- package/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js +8 -6
- package/DateTimeRangePicker/DateTimeRangePickerToolbar.d.ts +2 -5
- package/DateTimeRangePicker/DateTimeRangePickerToolbar.js +85 -123
- package/DateTimeRangePicker/shared.d.ts +6 -5
- package/DesktopDateRangePicker/DesktopDateRangePicker.js +11 -9
- package/DesktopDateRangePicker/DesktopDateRangePicker.types.d.ts +7 -2
- package/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +20 -22
- package/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.types.d.ts +2 -3
- package/MobileDateRangePicker/MobileDateRangePicker.js +4 -8
- package/MobileDateRangePicker/MobileDateRangePicker.types.d.ts +2 -2
- package/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +18 -16
- package/MobileDateTimeRangePicker/MobileDateTimeRangePicker.types.d.ts +2 -3
- package/MultiInputDateRangeField/MultiInputDateRangeField.d.ts +9 -4
- package/MultiInputDateRangeField/MultiInputDateRangeField.js +15 -121
- package/MultiInputDateRangeField/index.d.ts +5 -3
- package/MultiInputDateRangeField/index.js +2 -2
- package/MultiInputDateRangeField/multiInputDateRangeFieldClasses.d.ts +6 -0
- package/MultiInputDateRangeField/multiInputDateRangeFieldClasses.js +4 -0
- package/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.d.ts +9 -4
- package/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.js +15 -121
- package/MultiInputDateTimeRangeField/index.d.ts +5 -3
- package/MultiInputDateTimeRangeField/index.js +2 -2
- package/MultiInputDateTimeRangeField/multiInputDateTimeRangeFieldClasses.d.ts +6 -0
- package/MultiInputDateTimeRangeField/multiInputDateTimeRangeFieldClasses.js +4 -0
- package/MultiInputTimeRangeField/MultiInputTimeRangeField.d.ts +9 -4
- package/MultiInputTimeRangeField/MultiInputTimeRangeField.js +16 -122
- package/MultiInputTimeRangeField/index.d.ts +5 -3
- package/MultiInputTimeRangeField/index.js +2 -2
- package/MultiInputTimeRangeField/multiInputTimeRangeFieldClasses.d.ts +6 -0
- package/MultiInputTimeRangeField/multiInputTimeRangeFieldClasses.js +4 -0
- package/README.md +10 -7
- package/SingleInputDateRangeField/SingleInputDateRangeField.js +23 -33
- package/SingleInputDateRangeField/SingleInputDateRangeField.types.d.ts +6 -16
- package/SingleInputDateRangeField/useSingleInputDateRangeField.d.ts +1 -1
- package/SingleInputDateRangeField/useSingleInputDateRangeField.js +14 -14
- package/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.js +23 -33
- package/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.types.d.ts +6 -17
- package/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.d.ts +1 -1
- package/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +14 -14
- package/SingleInputTimeRangeField/SingleInputTimeRangeField.js +23 -33
- package/SingleInputTimeRangeField/SingleInputTimeRangeField.types.d.ts +6 -17
- package/SingleInputTimeRangeField/useSingleInputTimeRangeField.d.ts +1 -1
- package/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +14 -14
- package/StaticDateRangePicker/StaticDateRangePicker.js +2 -2
- package/StaticDateRangePicker/StaticDateRangePicker.types.d.ts +2 -2
- package/dateRangeViewRenderers/dateRangeViewRenderers.d.ts +2 -2
- package/dateRangeViewRenderers/dateRangeViewRenderers.js +0 -6
- package/hooks/index.d.ts +2 -0
- package/hooks/index.js +2 -0
- package/hooks/package.json +6 -0
- package/hooks/useMultiInputRangeField/index.d.ts +1 -0
- package/hooks/useMultiInputRangeField/index.js +1 -0
- package/hooks/useMultiInputRangeField/useMultiInputRangeField.d.ts +53 -0
- package/hooks/useMultiInputRangeField/useMultiInputRangeField.js +149 -0
- package/hooks/useMultiInputRangeField/useMultiInputRangeFieldSelectedSections.d.ts +17 -0
- package/{modern/internals/hooks/useMultiInputFieldSelectedSections.js → hooks/useMultiInputRangeField/useMultiInputRangeFieldSelectedSections.js} +10 -8
- package/hooks/useMultiInputRangeField/useMultiInputRangeFieldTextFieldProps.d.ts +17 -0
- package/hooks/useMultiInputRangeField/useMultiInputRangeFieldTextFieldProps.js +59 -0
- package/hooks/usePickerRangePositionContext.d.ts +7 -0
- package/hooks/usePickerRangePositionContext.js +15 -0
- package/index.d.ts +2 -0
- package/index.js +4 -2
- package/internals/hooks/models/index.d.ts +1 -1
- package/internals/hooks/models/useRangePicker.d.ts +8 -11
- package/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +70 -102
- package/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.types.d.ts +8 -10
- package/internals/hooks/{useEnrichedRangePickerFieldProps.d.ts → useEnrichedRangePickerField.d.ts} +26 -17
- package/internals/hooks/{useEnrichedRangePickerFieldProps.js → useEnrichedRangePickerField.js} +55 -68
- package/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +59 -82
- package/internals/hooks/useMobileRangePicker/useMobileRangePicker.types.d.ts +7 -9
- package/internals/hooks/useNullablePickerRangePositionContext.d.ts +5 -0
- package/internals/hooks/useNullablePickerRangePositionContext.js +10 -0
- package/internals/hooks/useRangePosition.d.ts +4 -3
- package/internals/hooks/useRangePosition.js +1 -1
- package/internals/hooks/useStaticRangePicker/useStaticRangePicker.d.ts +1 -1
- package/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +18 -31
- package/internals/hooks/useStaticRangePicker/useStaticRangePicker.types.d.ts +6 -12
- package/internals/models/dateTimeRange.d.ts +1 -6
- package/internals/models/fields.d.ts +7 -11
- package/internals/models/index.d.ts +0 -1
- package/internals/models/index.js +0 -1
- package/internals/models/managers.d.ts +3 -0
- package/internals/utils/createMultiInputRangeField/createMultiInputRangeField.d.ts +3 -0
- package/internals/utils/createMultiInputRangeField/createMultiInputRangeField.js +136 -0
- package/internals/utils/createMultiInputRangeField/createMultiInputRangeField.types.d.ts +72 -0
- package/internals/utils/createMultiInputRangeField/index.d.ts +3 -0
- package/internals/utils/createMultiInputRangeField/index.js +2 -0
- package/internals/utils/date-fields-utils.d.ts +6 -6
- package/internals/utils/date-range-manager.d.ts +2 -1
- package/internals/utils/date-range-manager.js +13 -10
- package/internals/utils/releaseInfo.js +1 -1
- package/internals/utils/valueManagers.d.ts +4 -3
- package/internals/utils/valueManagers.js +7 -7
- package/managers/index.d.ts +6 -0
- package/managers/index.js +3 -0
- package/managers/package.json +6 -0
- package/managers/useDateRangeManager.d.ts +15 -0
- package/managers/useDateRangeManager.js +33 -0
- package/managers/useDateTimeRangeManager.d.ts +15 -0
- package/managers/useDateTimeRangeManager.js +33 -0
- package/managers/useTimeRangeManager.d.ts +15 -0
- package/managers/useTimeRangeManager.js +31 -0
- package/models/fields.d.ts +7 -11
- package/models/index.d.ts +1 -2
- package/models/index.js +1 -2
- package/models/range.d.ts +0 -2
- package/modern/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.js +1 -1
- package/modern/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.js +1 -1
- package/modern/DateRangeCalendar/DateRangeCalendar.js +18 -14
- package/modern/DateRangePicker/DateRangePicker.js +1 -4
- package/modern/DateRangePicker/DateRangePickerToolbar.js +33 -53
- package/modern/DateTimeRangePicker/DateTimeRangePicker.js +2 -5
- package/modern/DateTimeRangePicker/DateTimeRangePickerTabs.js +35 -33
- package/modern/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js +8 -6
- package/modern/DateTimeRangePicker/DateTimeRangePickerToolbar.js +85 -123
- package/modern/DesktopDateRangePicker/DesktopDateRangePicker.js +11 -9
- package/modern/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +20 -22
- package/modern/MobileDateRangePicker/MobileDateRangePicker.js +4 -8
- package/modern/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +18 -16
- package/modern/MultiInputDateRangeField/MultiInputDateRangeField.js +15 -121
- package/modern/MultiInputDateRangeField/index.js +2 -2
- package/modern/MultiInputDateRangeField/multiInputDateRangeFieldClasses.js +4 -0
- package/modern/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.js +15 -121
- package/modern/MultiInputDateTimeRangeField/index.js +2 -2
- package/modern/MultiInputDateTimeRangeField/multiInputDateTimeRangeFieldClasses.js +4 -0
- package/modern/MultiInputTimeRangeField/MultiInputTimeRangeField.js +16 -122
- package/modern/MultiInputTimeRangeField/index.js +2 -2
- package/modern/MultiInputTimeRangeField/multiInputTimeRangeFieldClasses.js +4 -0
- package/modern/SingleInputDateRangeField/SingleInputDateRangeField.js +23 -33
- package/modern/SingleInputDateRangeField/useSingleInputDateRangeField.js +14 -14
- package/modern/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.js +23 -33
- package/modern/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +14 -14
- package/modern/SingleInputTimeRangeField/SingleInputTimeRangeField.js +23 -33
- package/modern/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +14 -14
- package/modern/StaticDateRangePicker/StaticDateRangePicker.js +2 -2
- package/modern/dateRangeViewRenderers/dateRangeViewRenderers.js +0 -6
- package/modern/hooks/index.js +2 -0
- package/modern/hooks/useMultiInputRangeField/index.js +1 -0
- package/modern/hooks/useMultiInputRangeField/useMultiInputRangeField.js +149 -0
- package/{internals/hooks/useMultiInputFieldSelectedSections.js → modern/hooks/useMultiInputRangeField/useMultiInputRangeFieldSelectedSections.js} +10 -8
- package/modern/hooks/useMultiInputRangeField/useMultiInputRangeFieldTextFieldProps.js +59 -0
- package/modern/hooks/usePickerRangePositionContext.js +15 -0
- package/modern/index.js +4 -2
- package/modern/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +70 -102
- package/modern/internals/hooks/{useEnrichedRangePickerFieldProps.js → useEnrichedRangePickerField.js} +55 -68
- package/modern/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +59 -82
- package/modern/internals/hooks/useNullablePickerRangePositionContext.js +10 -0
- package/modern/internals/hooks/useRangePosition.js +1 -1
- package/modern/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +18 -31
- package/modern/internals/models/index.js +0 -1
- package/modern/internals/utils/createMultiInputRangeField/createMultiInputRangeField.js +136 -0
- package/modern/internals/utils/createMultiInputRangeField/index.js +2 -0
- package/modern/internals/utils/date-range-manager.js +13 -10
- package/modern/internals/utils/releaseInfo.js +1 -1
- package/modern/internals/utils/valueManagers.js +7 -7
- package/modern/managers/index.js +3 -0
- package/modern/managers/useDateRangeManager.js +33 -0
- package/modern/managers/useDateTimeRangeManager.js +33 -0
- package/modern/managers/useTimeRangeManager.js +31 -0
- package/modern/models/index.js +1 -2
- package/modern/validation/validateDateRange.js +8 -0
- package/modern/validation/validateDateTimeRange.js +4 -0
- package/modern/validation/validateTimeRange.js +8 -0
- package/node/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.js +1 -1
- package/node/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.js +1 -1
- package/node/DateRangeCalendar/DateRangeCalendar.js +17 -13
- package/node/DateRangePicker/DateRangePicker.js +1 -4
- package/node/DateRangePicker/DateRangePickerToolbar.js +31 -51
- package/node/DateTimeRangePicker/DateTimeRangePicker.js +2 -5
- package/node/DateTimeRangePicker/DateTimeRangePickerTabs.js +33 -31
- package/node/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js +8 -6
- package/node/DateTimeRangePicker/DateTimeRangePickerToolbar.js +83 -121
- package/node/DesktopDateRangePicker/DesktopDateRangePicker.js +11 -9
- package/node/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +20 -22
- package/node/MobileDateRangePicker/MobileDateRangePicker.js +4 -8
- package/node/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +18 -16
- package/node/MultiInputDateRangeField/MultiInputDateRangeField.js +14 -124
- package/node/MultiInputDateRangeField/index.js +3 -9
- package/node/MultiInputDateRangeField/multiInputDateRangeFieldClasses.js +12 -0
- package/node/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.js +14 -124
- package/node/MultiInputDateTimeRangeField/index.js +3 -9
- package/node/MultiInputDateTimeRangeField/multiInputDateTimeRangeFieldClasses.js +12 -0
- package/node/MultiInputTimeRangeField/MultiInputTimeRangeField.js +15 -125
- package/node/MultiInputTimeRangeField/index.js +3 -9
- package/node/MultiInputTimeRangeField/multiInputTimeRangeFieldClasses.js +12 -0
- package/node/SingleInputDateRangeField/SingleInputDateRangeField.js +22 -32
- package/node/SingleInputDateRangeField/useSingleInputDateRangeField.js +13 -14
- package/node/SingleInputDateTimeRangeField/SingleInputDateTimeRangeField.js +22 -32
- package/node/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +13 -14
- package/node/SingleInputTimeRangeField/SingleInputTimeRangeField.js +22 -32
- package/node/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +13 -14
- package/node/StaticDateRangePicker/StaticDateRangePicker.js +2 -2
- package/node/dateRangeViewRenderers/dateRangeViewRenderers.js +0 -6
- package/node/hooks/index.js +19 -0
- package/node/hooks/useMultiInputRangeField/index.js +12 -0
- package/node/hooks/useMultiInputRangeField/useMultiInputRangeField.js +155 -0
- package/node/{internals/hooks/useMultiInputFieldSelectedSections.js → hooks/useMultiInputRangeField/useMultiInputRangeFieldSelectedSections.js} +11 -10
- package/node/hooks/useMultiInputRangeField/useMultiInputRangeFieldTextFieldProps.js +66 -0
- package/node/hooks/usePickerRangePositionContext.js +22 -0
- package/node/index.js +23 -1
- package/node/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +70 -102
- package/node/internals/hooks/{useEnrichedRangePickerFieldProps.js → useEnrichedRangePickerField.js} +57 -70
- package/node/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +59 -82
- package/node/internals/hooks/useNullablePickerRangePositionContext.js +16 -0
- package/node/internals/hooks/useRangePosition.js +1 -1
- package/node/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +17 -30
- package/node/internals/models/index.js +0 -11
- package/node/internals/utils/createMultiInputRangeField/createMultiInputRangeField.js +143 -0
- package/node/internals/utils/createMultiInputRangeField/index.js +19 -0
- package/node/internals/utils/date-range-manager.js +13 -10
- package/node/internals/utils/releaseInfo.js +1 -1
- package/node/internals/utils/valueManagers.js +7 -7
- package/node/managers/index.js +26 -0
- package/node/managers/useDateRangeManager.js +40 -0
- package/node/managers/useDateTimeRangeManager.js +40 -0
- package/node/managers/useTimeRangeManager.js +38 -0
- package/node/models/index.js +0 -22
- package/node/validation/validateDateRange.js +8 -0
- package/node/validation/validateDateTimeRange.js +4 -0
- package/node/validation/validateTimeRange.js +8 -0
- package/package.json +8 -8
- package/themeAugmentation/overrides.d.ts +6 -4
- package/themeAugmentation/props.d.ts +2 -2
- package/validation/validateDateRange.d.ts +9 -1
- package/validation/validateDateRange.js +8 -0
- package/validation/validateDateTimeRange.d.ts +6 -2
- package/validation/validateDateTimeRange.js +4 -0
- package/validation/validateTimeRange.d.ts +9 -1
- package/validation/validateTimeRange.js +8 -0
- package/MultiInputDateRangeField/MultiInputDateRangeField.types.d.ts +0 -53
- package/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.types.d.ts +0 -54
- package/MultiInputTimeRangeField/MultiInputTimeRangeField.types.d.ts +0 -54
- package/internals/hooks/useMultiInputFieldSelectedSections.d.ts +0 -21
- package/internals/hooks/useMultiInputRangeField/shared.d.ts +0 -1
- package/internals/hooks/useMultiInputRangeField/shared.js +0 -9
- package/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.d.ts +0 -3
- package/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +0 -111
- package/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.d.ts +0 -3
- package/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +0 -111
- package/internals/hooks/useMultiInputRangeField/useMultiInputRangeField.types.d.ts +0 -11
- package/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.d.ts +0 -3
- package/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +0 -111
- package/internals/models/timeRange.d.ts +0 -6
- package/internals/models/timeRange.js +0 -1
- package/models/dateRange.d.ts +0 -7
- package/models/dateRange.js +0 -1
- package/models/multiInputRangeFieldClasses.d.ts +0 -7
- package/models/multiInputRangeFieldClasses.js +0 -1
- package/modern/MultiInputDateRangeField/MultiInputDateRangeField.types.js +0 -1
- package/modern/MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.types.js +0 -1
- package/modern/MultiInputTimeRangeField/MultiInputTimeRangeField.types.js +0 -1
- package/modern/internals/hooks/useMultiInputRangeField/shared.js +0 -9
- package/modern/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +0 -111
- package/modern/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +0 -111
- package/modern/internals/hooks/useMultiInputRangeField/useMultiInputRangeField.types.js +0 -1
- package/modern/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +0 -111
- package/modern/internals/models/timeRange.js +0 -1
- package/modern/models/dateRange.js +0 -1
- package/modern/models/multiInputRangeFieldClasses.js +0 -1
- package/node/MultiInputTimeRangeField/MultiInputTimeRangeField.types.js +0 -5
- package/node/internals/hooks/useMultiInputRangeField/shared.js +0 -16
- package/node/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +0 -119
- package/node/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +0 -119
- package/node/internals/hooks/useMultiInputRangeField/useMultiInputRangeField.types.js +0 -5
- package/node/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +0 -119
- package/node/internals/models/timeRange.js +0 -5
- package/node/models/dateRange.js +0 -5
- package/node/models/multiInputRangeFieldClasses.js +0 -5
- /package/{MultiInputDateRangeField/MultiInputDateRangeField.types.js → internals/models/managers.js} +0 -0
- /package/{MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.types.js → internals/utils/createMultiInputRangeField/createMultiInputRangeField.types.js} +0 -0
- /package/{MultiInputTimeRangeField/MultiInputTimeRangeField.types.js → modern/internals/models/managers.js} +0 -0
- /package/{internals/hooks/useMultiInputRangeField/useMultiInputRangeField.types.js → modern/internals/utils/createMultiInputRangeField/createMultiInputRangeField.types.js} +0 -0
- /package/node/{MultiInputDateRangeField/MultiInputDateRangeField.types.js → internals/models/managers.js} +0 -0
- /package/node/{MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.types.js → internals/utils/createMultiInputRangeField/createMultiInputRangeField.types.js} +0 -0
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
-
import useEventCallback from '@mui/utils/useEventCallback';
|
|
3
|
-
import { unstable_useDateField as useDateField } from '@mui/x-date-pickers/DateField';
|
|
4
|
-
import { useControlledValueWithTimezone, useDefaultizedDateField } from '@mui/x-date-pickers/internals';
|
|
5
|
-
import { useValidation } from '@mui/x-date-pickers/validation';
|
|
6
|
-
import { validateDateRange } from "../../../validation/index.js";
|
|
7
|
-
import { rangeValueManager } from "../../utils/valueManagers.js";
|
|
8
|
-
import { excludeProps } from "./shared.js";
|
|
9
|
-
import { useMultiInputFieldSelectedSections } from "../useMultiInputFieldSelectedSections.js";
|
|
10
|
-
export const useMultiInputDateRangeField = ({
|
|
11
|
-
sharedProps: inSharedProps,
|
|
12
|
-
startTextFieldProps,
|
|
13
|
-
unstableStartFieldRef,
|
|
14
|
-
endTextFieldProps,
|
|
15
|
-
unstableEndFieldRef
|
|
16
|
-
}) => {
|
|
17
|
-
const sharedProps = useDefaultizedDateField(inSharedProps);
|
|
18
|
-
const {
|
|
19
|
-
value: valueProp,
|
|
20
|
-
defaultValue,
|
|
21
|
-
format,
|
|
22
|
-
formatDensity,
|
|
23
|
-
shouldRespectLeadingZeros,
|
|
24
|
-
onChange,
|
|
25
|
-
disabled,
|
|
26
|
-
readOnly,
|
|
27
|
-
selectedSections,
|
|
28
|
-
onSelectedSectionsChange,
|
|
29
|
-
timezone: timezoneProp,
|
|
30
|
-
enableAccessibleFieldDOMStructure,
|
|
31
|
-
autoFocus
|
|
32
|
-
} = sharedProps;
|
|
33
|
-
const {
|
|
34
|
-
value,
|
|
35
|
-
handleValueChange,
|
|
36
|
-
timezone
|
|
37
|
-
} = useControlledValueWithTimezone({
|
|
38
|
-
name: 'useMultiInputDateRangeField',
|
|
39
|
-
timezone: timezoneProp,
|
|
40
|
-
value: valueProp,
|
|
41
|
-
defaultValue,
|
|
42
|
-
onChange,
|
|
43
|
-
valueManager: rangeValueManager
|
|
44
|
-
});
|
|
45
|
-
const {
|
|
46
|
-
validationError,
|
|
47
|
-
getValidationErrorForNewValue
|
|
48
|
-
} = useValidation({
|
|
49
|
-
props: sharedProps,
|
|
50
|
-
value,
|
|
51
|
-
timezone,
|
|
52
|
-
validator: validateDateRange,
|
|
53
|
-
onError: sharedProps.onError
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
// TODO: Maybe export utility from `useField` instead of copy/pasting the logic
|
|
57
|
-
const buildChangeHandler = index => {
|
|
58
|
-
return (newDate, rawContext) => {
|
|
59
|
-
const newDateRange = index === 0 ? [newDate, value[1]] : [value[0], newDate];
|
|
60
|
-
const context = _extends({}, rawContext, {
|
|
61
|
-
validationError: getValidationErrorForNewValue(newDateRange)
|
|
62
|
-
});
|
|
63
|
-
handleValueChange(newDateRange, context);
|
|
64
|
-
};
|
|
65
|
-
};
|
|
66
|
-
const handleStartDateChange = useEventCallback(buildChangeHandler(0));
|
|
67
|
-
const handleEndDateChange = useEventCallback(buildChangeHandler(1));
|
|
68
|
-
const selectedSectionsResponse = useMultiInputFieldSelectedSections({
|
|
69
|
-
selectedSections,
|
|
70
|
-
onSelectedSectionsChange,
|
|
71
|
-
unstableStartFieldRef,
|
|
72
|
-
unstableEndFieldRef
|
|
73
|
-
});
|
|
74
|
-
const startFieldProps = _extends({
|
|
75
|
-
error: !!validationError[0]
|
|
76
|
-
}, startTextFieldProps, selectedSectionsResponse.start, {
|
|
77
|
-
disabled,
|
|
78
|
-
readOnly,
|
|
79
|
-
format,
|
|
80
|
-
formatDensity,
|
|
81
|
-
shouldRespectLeadingZeros,
|
|
82
|
-
timezone,
|
|
83
|
-
value: valueProp === undefined ? undefined : valueProp[0],
|
|
84
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[0],
|
|
85
|
-
onChange: handleStartDateChange,
|
|
86
|
-
enableAccessibleFieldDOMStructure,
|
|
87
|
-
autoFocus // Do not add on end field.
|
|
88
|
-
});
|
|
89
|
-
const endFieldProps = _extends({
|
|
90
|
-
error: !!validationError[1]
|
|
91
|
-
}, endTextFieldProps, selectedSectionsResponse.end, {
|
|
92
|
-
format,
|
|
93
|
-
formatDensity,
|
|
94
|
-
shouldRespectLeadingZeros,
|
|
95
|
-
disabled,
|
|
96
|
-
readOnly,
|
|
97
|
-
timezone,
|
|
98
|
-
value: valueProp === undefined ? undefined : valueProp[1],
|
|
99
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[1],
|
|
100
|
-
onChange: handleEndDateChange,
|
|
101
|
-
enableAccessibleFieldDOMStructure
|
|
102
|
-
});
|
|
103
|
-
const startDateResponse = useDateField(startFieldProps);
|
|
104
|
-
const endDateResponse = useDateField(endFieldProps);
|
|
105
|
-
|
|
106
|
-
/* TODO: Undo this change when a clearable behavior for multiple input range fields is implemented */
|
|
107
|
-
return {
|
|
108
|
-
startDate: excludeProps(startDateResponse, ['clearable', 'onClear']),
|
|
109
|
-
endDate: excludeProps(endDateResponse, ['clearable', 'onClear'])
|
|
110
|
-
};
|
|
111
|
-
};
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import type { UseMultiInputDateTimeRangeFieldParams } from '../../../MultiInputDateTimeRangeField/MultiInputDateTimeRangeField.types';
|
|
2
|
-
import type { UseMultiInputRangeFieldResponse } from './useMultiInputRangeField.types';
|
|
3
|
-
export declare const useMultiInputDateTimeRangeField: <TEnableAccessibleFieldDOMStructure extends boolean, TTextFieldSlotProps extends {}>({ sharedProps: inSharedProps, startTextFieldProps, unstableStartFieldRef, endTextFieldProps, unstableEndFieldRef, }: UseMultiInputDateTimeRangeFieldParams<TEnableAccessibleFieldDOMStructure, TTextFieldSlotProps>) => UseMultiInputRangeFieldResponse<TEnableAccessibleFieldDOMStructure, TTextFieldSlotProps>;
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
-
import useEventCallback from '@mui/utils/useEventCallback';
|
|
3
|
-
import { unstable_useDateTimeField as useDateTimeField } from '@mui/x-date-pickers/DateTimeField';
|
|
4
|
-
import { useControlledValueWithTimezone, useDefaultizedDateTimeField } from '@mui/x-date-pickers/internals';
|
|
5
|
-
import { useValidation } from '@mui/x-date-pickers/validation';
|
|
6
|
-
import { validateDateTimeRange } from "../../../validation/index.js";
|
|
7
|
-
import { rangeValueManager } from "../../utils/valueManagers.js";
|
|
8
|
-
import { excludeProps } from "./shared.js";
|
|
9
|
-
import { useMultiInputFieldSelectedSections } from "../useMultiInputFieldSelectedSections.js";
|
|
10
|
-
export const useMultiInputDateTimeRangeField = ({
|
|
11
|
-
sharedProps: inSharedProps,
|
|
12
|
-
startTextFieldProps,
|
|
13
|
-
unstableStartFieldRef,
|
|
14
|
-
endTextFieldProps,
|
|
15
|
-
unstableEndFieldRef
|
|
16
|
-
}) => {
|
|
17
|
-
const sharedProps = useDefaultizedDateTimeField(inSharedProps);
|
|
18
|
-
const {
|
|
19
|
-
value: valueProp,
|
|
20
|
-
defaultValue,
|
|
21
|
-
format,
|
|
22
|
-
formatDensity,
|
|
23
|
-
shouldRespectLeadingZeros,
|
|
24
|
-
onChange,
|
|
25
|
-
disabled,
|
|
26
|
-
readOnly,
|
|
27
|
-
selectedSections,
|
|
28
|
-
onSelectedSectionsChange,
|
|
29
|
-
timezone: timezoneProp,
|
|
30
|
-
enableAccessibleFieldDOMStructure,
|
|
31
|
-
autoFocus
|
|
32
|
-
} = sharedProps;
|
|
33
|
-
const {
|
|
34
|
-
value,
|
|
35
|
-
handleValueChange,
|
|
36
|
-
timezone
|
|
37
|
-
} = useControlledValueWithTimezone({
|
|
38
|
-
name: 'useMultiInputDateRangeField',
|
|
39
|
-
timezone: timezoneProp,
|
|
40
|
-
value: valueProp,
|
|
41
|
-
defaultValue,
|
|
42
|
-
onChange,
|
|
43
|
-
valueManager: rangeValueManager
|
|
44
|
-
});
|
|
45
|
-
const {
|
|
46
|
-
validationError,
|
|
47
|
-
getValidationErrorForNewValue
|
|
48
|
-
} = useValidation({
|
|
49
|
-
props: sharedProps,
|
|
50
|
-
value,
|
|
51
|
-
timezone,
|
|
52
|
-
validator: validateDateTimeRange,
|
|
53
|
-
onError: sharedProps.onError
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
// TODO: Maybe export utility from `useField` instead of copy/pasting the logic
|
|
57
|
-
const buildChangeHandler = index => {
|
|
58
|
-
return (newDate, rawContext) => {
|
|
59
|
-
const newDateRange = index === 0 ? [newDate, value[1]] : [value[0], newDate];
|
|
60
|
-
const context = _extends({}, rawContext, {
|
|
61
|
-
validationError: getValidationErrorForNewValue(newDateRange)
|
|
62
|
-
});
|
|
63
|
-
handleValueChange(newDateRange, context);
|
|
64
|
-
};
|
|
65
|
-
};
|
|
66
|
-
const handleStartDateChange = useEventCallback(buildChangeHandler(0));
|
|
67
|
-
const handleEndDateChange = useEventCallback(buildChangeHandler(1));
|
|
68
|
-
const selectedSectionsResponse = useMultiInputFieldSelectedSections({
|
|
69
|
-
selectedSections,
|
|
70
|
-
onSelectedSectionsChange,
|
|
71
|
-
unstableStartFieldRef,
|
|
72
|
-
unstableEndFieldRef
|
|
73
|
-
});
|
|
74
|
-
const startFieldProps = _extends({
|
|
75
|
-
error: !!validationError[0]
|
|
76
|
-
}, startTextFieldProps, selectedSectionsResponse.start, {
|
|
77
|
-
disabled,
|
|
78
|
-
readOnly,
|
|
79
|
-
format,
|
|
80
|
-
formatDensity,
|
|
81
|
-
shouldRespectLeadingZeros,
|
|
82
|
-
timezone,
|
|
83
|
-
value: valueProp === undefined ? undefined : valueProp[0],
|
|
84
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[0],
|
|
85
|
-
onChange: handleStartDateChange,
|
|
86
|
-
enableAccessibleFieldDOMStructure,
|
|
87
|
-
autoFocus // Do not add on end field.
|
|
88
|
-
});
|
|
89
|
-
const endFieldProps = _extends({
|
|
90
|
-
error: !!validationError[1]
|
|
91
|
-
}, endTextFieldProps, selectedSectionsResponse.end, {
|
|
92
|
-
format,
|
|
93
|
-
formatDensity,
|
|
94
|
-
shouldRespectLeadingZeros,
|
|
95
|
-
disabled,
|
|
96
|
-
readOnly,
|
|
97
|
-
timezone,
|
|
98
|
-
value: valueProp === undefined ? undefined : valueProp[1],
|
|
99
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[1],
|
|
100
|
-
onChange: handleEndDateChange,
|
|
101
|
-
enableAccessibleFieldDOMStructure
|
|
102
|
-
});
|
|
103
|
-
const startDateResponse = useDateTimeField(startFieldProps);
|
|
104
|
-
const endDateResponse = useDateTimeField(endFieldProps);
|
|
105
|
-
|
|
106
|
-
/* TODO: Undo this change when a clearable behavior for multiple input range fields is implemented */
|
|
107
|
-
return {
|
|
108
|
-
startDate: excludeProps(startDateResponse, ['clearable', 'onClear']),
|
|
109
|
-
endDate: excludeProps(endDateResponse, ['clearable', 'onClear'])
|
|
110
|
-
};
|
|
111
|
-
};
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { UseFieldResponse } from '@mui/x-date-pickers/internals';
|
|
2
|
-
import { MultiInputFieldRefs } from '../../../models';
|
|
3
|
-
export interface UseMultiInputRangeFieldParams<TSharedProps extends {}, TTextFieldSlotProps extends {}> extends MultiInputFieldRefs {
|
|
4
|
-
sharedProps: TSharedProps;
|
|
5
|
-
startTextFieldProps: TTextFieldSlotProps;
|
|
6
|
-
endTextFieldProps: TTextFieldSlotProps;
|
|
7
|
-
}
|
|
8
|
-
export interface UseMultiInputRangeFieldResponse<TEnableAccessibleFieldDOMStructure extends boolean, TForwardedProps extends {}> {
|
|
9
|
-
startDate: UseFieldResponse<TEnableAccessibleFieldDOMStructure, TForwardedProps>;
|
|
10
|
-
endDate: UseFieldResponse<TEnableAccessibleFieldDOMStructure, TForwardedProps>;
|
|
11
|
-
}
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import type { UseMultiInputTimeRangeFieldParams } from '../../../MultiInputTimeRangeField/MultiInputTimeRangeField.types';
|
|
2
|
-
import type { UseMultiInputRangeFieldResponse } from './useMultiInputRangeField.types';
|
|
3
|
-
export declare const useMultiInputTimeRangeField: <TEnableAccessibleFieldDOMStructure extends boolean, TTextFieldSlotProps extends {}>({ sharedProps: inSharedProps, startTextFieldProps, unstableStartFieldRef, endTextFieldProps, unstableEndFieldRef, }: UseMultiInputTimeRangeFieldParams<TEnableAccessibleFieldDOMStructure, TTextFieldSlotProps>) => UseMultiInputRangeFieldResponse<TEnableAccessibleFieldDOMStructure, TTextFieldSlotProps>;
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
-
import useEventCallback from '@mui/utils/useEventCallback';
|
|
3
|
-
import { unstable_useTimeField as useTimeField } from '@mui/x-date-pickers/TimeField';
|
|
4
|
-
import { useControlledValueWithTimezone, useDefaultizedTimeField } from '@mui/x-date-pickers/internals';
|
|
5
|
-
import { useValidation } from '@mui/x-date-pickers/validation';
|
|
6
|
-
import { validateTimeRange } from "../../../validation/index.js";
|
|
7
|
-
import { rangeValueManager } from "../../utils/valueManagers.js";
|
|
8
|
-
import { excludeProps } from "./shared.js";
|
|
9
|
-
import { useMultiInputFieldSelectedSections } from "../useMultiInputFieldSelectedSections.js";
|
|
10
|
-
export const useMultiInputTimeRangeField = ({
|
|
11
|
-
sharedProps: inSharedProps,
|
|
12
|
-
startTextFieldProps,
|
|
13
|
-
unstableStartFieldRef,
|
|
14
|
-
endTextFieldProps,
|
|
15
|
-
unstableEndFieldRef
|
|
16
|
-
}) => {
|
|
17
|
-
const sharedProps = useDefaultizedTimeField(inSharedProps);
|
|
18
|
-
const {
|
|
19
|
-
value: valueProp,
|
|
20
|
-
defaultValue,
|
|
21
|
-
format,
|
|
22
|
-
formatDensity,
|
|
23
|
-
shouldRespectLeadingZeros,
|
|
24
|
-
onChange,
|
|
25
|
-
disabled,
|
|
26
|
-
readOnly,
|
|
27
|
-
selectedSections,
|
|
28
|
-
onSelectedSectionsChange,
|
|
29
|
-
timezone: timezoneProp,
|
|
30
|
-
enableAccessibleFieldDOMStructure,
|
|
31
|
-
autoFocus
|
|
32
|
-
} = sharedProps;
|
|
33
|
-
const {
|
|
34
|
-
value,
|
|
35
|
-
handleValueChange,
|
|
36
|
-
timezone
|
|
37
|
-
} = useControlledValueWithTimezone({
|
|
38
|
-
name: 'useMultiInputDateRangeField',
|
|
39
|
-
timezone: timezoneProp,
|
|
40
|
-
value: valueProp,
|
|
41
|
-
defaultValue,
|
|
42
|
-
onChange,
|
|
43
|
-
valueManager: rangeValueManager
|
|
44
|
-
});
|
|
45
|
-
const {
|
|
46
|
-
validationError,
|
|
47
|
-
getValidationErrorForNewValue
|
|
48
|
-
} = useValidation({
|
|
49
|
-
props: sharedProps,
|
|
50
|
-
validator: validateTimeRange,
|
|
51
|
-
value,
|
|
52
|
-
timezone,
|
|
53
|
-
onError: sharedProps.onError
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
// TODO: Maybe export utility from `useField` instead of copy/pasting the logic
|
|
57
|
-
const buildChangeHandler = index => {
|
|
58
|
-
return (newDate, rawContext) => {
|
|
59
|
-
const newDateRange = index === 0 ? [newDate, value[1]] : [value[0], newDate];
|
|
60
|
-
const context = _extends({}, rawContext, {
|
|
61
|
-
validationError: getValidationErrorForNewValue(newDateRange)
|
|
62
|
-
});
|
|
63
|
-
handleValueChange(newDateRange, context);
|
|
64
|
-
};
|
|
65
|
-
};
|
|
66
|
-
const handleStartDateChange = useEventCallback(buildChangeHandler(0));
|
|
67
|
-
const handleEndDateChange = useEventCallback(buildChangeHandler(1));
|
|
68
|
-
const selectedSectionsResponse = useMultiInputFieldSelectedSections({
|
|
69
|
-
selectedSections,
|
|
70
|
-
onSelectedSectionsChange,
|
|
71
|
-
unstableStartFieldRef,
|
|
72
|
-
unstableEndFieldRef
|
|
73
|
-
});
|
|
74
|
-
const startFieldProps = _extends({
|
|
75
|
-
error: !!validationError[0]
|
|
76
|
-
}, startTextFieldProps, selectedSectionsResponse.start, {
|
|
77
|
-
disabled,
|
|
78
|
-
readOnly,
|
|
79
|
-
format,
|
|
80
|
-
formatDensity,
|
|
81
|
-
shouldRespectLeadingZeros,
|
|
82
|
-
timezone,
|
|
83
|
-
value: valueProp === undefined ? undefined : valueProp[0],
|
|
84
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[0],
|
|
85
|
-
onChange: handleStartDateChange,
|
|
86
|
-
enableAccessibleFieldDOMStructure,
|
|
87
|
-
autoFocus // Do not add on end field.
|
|
88
|
-
});
|
|
89
|
-
const endFieldProps = _extends({
|
|
90
|
-
error: !!validationError[1]
|
|
91
|
-
}, endTextFieldProps, selectedSectionsResponse.end, {
|
|
92
|
-
format,
|
|
93
|
-
formatDensity,
|
|
94
|
-
shouldRespectLeadingZeros,
|
|
95
|
-
disabled,
|
|
96
|
-
readOnly,
|
|
97
|
-
timezone,
|
|
98
|
-
value: valueProp === undefined ? undefined : valueProp[1],
|
|
99
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[1],
|
|
100
|
-
onChange: handleEndDateChange,
|
|
101
|
-
enableAccessibleFieldDOMStructure
|
|
102
|
-
});
|
|
103
|
-
const startDateResponse = useTimeField(startFieldProps);
|
|
104
|
-
const endDateResponse = useTimeField(endFieldProps);
|
|
105
|
-
|
|
106
|
-
/* TODO: Undo this change when a clearable behavior for multiple input range fields is implemented */
|
|
107
|
-
return {
|
|
108
|
-
startDate: excludeProps(startDateResponse, ['clearable', 'onClear']),
|
|
109
|
-
endDate: excludeProps(endDateResponse, ['clearable', 'onClear'])
|
|
110
|
-
};
|
|
111
|
-
};
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { MakeOptional } from '@mui/x-internals/types';
|
|
2
|
-
import { UseFieldInternalProps, AmPmProps, PickerRangeValue } from '@mui/x-date-pickers/internals';
|
|
3
|
-
import { TimeRangeValidationError, RangeFieldSection, RangeFieldSeparatorProps } from '../../models';
|
|
4
|
-
import type { ExportedValidateTimeRangeProps } from '../../validation/validateTimeRange';
|
|
5
|
-
export interface UseTimeRangeFieldProps<TEnableAccessibleFieldDOMStructure extends boolean> extends MakeOptional<Omit<UseFieldInternalProps<PickerRangeValue, RangeFieldSection, TEnableAccessibleFieldDOMStructure, TimeRangeValidationError>, 'unstableFieldRef'>, 'format'>, RangeFieldSeparatorProps, ExportedValidateTimeRangeProps, AmPmProps {
|
|
6
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/models/dateRange.d.ts
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { MakeOptional } from '@mui/x-internals/types';
|
|
2
|
-
import { UseFieldInternalProps, PickerRangeValue } from '@mui/x-date-pickers/internals';
|
|
3
|
-
import { RangeFieldSection, RangeFieldSeparatorProps } from './fields';
|
|
4
|
-
import { DateRangeValidationError } from './validation';
|
|
5
|
-
import type { ExportedValidateDateRangeProps } from '../validation/validateDateRange';
|
|
6
|
-
export interface UseDateRangeFieldProps<TEnableAccessibleFieldDOMStructure extends boolean> extends MakeOptional<Omit<UseFieldInternalProps<PickerRangeValue, RangeFieldSection, TEnableAccessibleFieldDOMStructure, DateRangeValidationError>, 'unstableFieldRef'>, 'format'>, RangeFieldSeparatorProps, ExportedValidateDateRangeProps {
|
|
7
|
-
}
|
package/models/dateRange.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
/* TODO: remove this when a clearable behavior for multiple input range fields is implemented */
|
|
2
|
-
export const excludeProps = (props, excludedProps) => {
|
|
3
|
-
return Object.keys(props).reduce((acc, key) => {
|
|
4
|
-
if (!excludedProps.includes(key)) {
|
|
5
|
-
acc[key] = props[key];
|
|
6
|
-
}
|
|
7
|
-
return acc;
|
|
8
|
-
}, {});
|
|
9
|
-
};
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
-
import useEventCallback from '@mui/utils/useEventCallback';
|
|
3
|
-
import { unstable_useDateField as useDateField } from '@mui/x-date-pickers/DateField';
|
|
4
|
-
import { useControlledValueWithTimezone, useDefaultizedDateField } from '@mui/x-date-pickers/internals';
|
|
5
|
-
import { useValidation } from '@mui/x-date-pickers/validation';
|
|
6
|
-
import { validateDateRange } from "../../../validation/index.js";
|
|
7
|
-
import { rangeValueManager } from "../../utils/valueManagers.js";
|
|
8
|
-
import { excludeProps } from "./shared.js";
|
|
9
|
-
import { useMultiInputFieldSelectedSections } from "../useMultiInputFieldSelectedSections.js";
|
|
10
|
-
export const useMultiInputDateRangeField = ({
|
|
11
|
-
sharedProps: inSharedProps,
|
|
12
|
-
startTextFieldProps,
|
|
13
|
-
unstableStartFieldRef,
|
|
14
|
-
endTextFieldProps,
|
|
15
|
-
unstableEndFieldRef
|
|
16
|
-
}) => {
|
|
17
|
-
const sharedProps = useDefaultizedDateField(inSharedProps);
|
|
18
|
-
const {
|
|
19
|
-
value: valueProp,
|
|
20
|
-
defaultValue,
|
|
21
|
-
format,
|
|
22
|
-
formatDensity,
|
|
23
|
-
shouldRespectLeadingZeros,
|
|
24
|
-
onChange,
|
|
25
|
-
disabled,
|
|
26
|
-
readOnly,
|
|
27
|
-
selectedSections,
|
|
28
|
-
onSelectedSectionsChange,
|
|
29
|
-
timezone: timezoneProp,
|
|
30
|
-
enableAccessibleFieldDOMStructure,
|
|
31
|
-
autoFocus
|
|
32
|
-
} = sharedProps;
|
|
33
|
-
const {
|
|
34
|
-
value,
|
|
35
|
-
handleValueChange,
|
|
36
|
-
timezone
|
|
37
|
-
} = useControlledValueWithTimezone({
|
|
38
|
-
name: 'useMultiInputDateRangeField',
|
|
39
|
-
timezone: timezoneProp,
|
|
40
|
-
value: valueProp,
|
|
41
|
-
defaultValue,
|
|
42
|
-
onChange,
|
|
43
|
-
valueManager: rangeValueManager
|
|
44
|
-
});
|
|
45
|
-
const {
|
|
46
|
-
validationError,
|
|
47
|
-
getValidationErrorForNewValue
|
|
48
|
-
} = useValidation({
|
|
49
|
-
props: sharedProps,
|
|
50
|
-
value,
|
|
51
|
-
timezone,
|
|
52
|
-
validator: validateDateRange,
|
|
53
|
-
onError: sharedProps.onError
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
// TODO: Maybe export utility from `useField` instead of copy/pasting the logic
|
|
57
|
-
const buildChangeHandler = index => {
|
|
58
|
-
return (newDate, rawContext) => {
|
|
59
|
-
const newDateRange = index === 0 ? [newDate, value[1]] : [value[0], newDate];
|
|
60
|
-
const context = _extends({}, rawContext, {
|
|
61
|
-
validationError: getValidationErrorForNewValue(newDateRange)
|
|
62
|
-
});
|
|
63
|
-
handleValueChange(newDateRange, context);
|
|
64
|
-
};
|
|
65
|
-
};
|
|
66
|
-
const handleStartDateChange = useEventCallback(buildChangeHandler(0));
|
|
67
|
-
const handleEndDateChange = useEventCallback(buildChangeHandler(1));
|
|
68
|
-
const selectedSectionsResponse = useMultiInputFieldSelectedSections({
|
|
69
|
-
selectedSections,
|
|
70
|
-
onSelectedSectionsChange,
|
|
71
|
-
unstableStartFieldRef,
|
|
72
|
-
unstableEndFieldRef
|
|
73
|
-
});
|
|
74
|
-
const startFieldProps = _extends({
|
|
75
|
-
error: !!validationError[0]
|
|
76
|
-
}, startTextFieldProps, selectedSectionsResponse.start, {
|
|
77
|
-
disabled,
|
|
78
|
-
readOnly,
|
|
79
|
-
format,
|
|
80
|
-
formatDensity,
|
|
81
|
-
shouldRespectLeadingZeros,
|
|
82
|
-
timezone,
|
|
83
|
-
value: valueProp === undefined ? undefined : valueProp[0],
|
|
84
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[0],
|
|
85
|
-
onChange: handleStartDateChange,
|
|
86
|
-
enableAccessibleFieldDOMStructure,
|
|
87
|
-
autoFocus // Do not add on end field.
|
|
88
|
-
});
|
|
89
|
-
const endFieldProps = _extends({
|
|
90
|
-
error: !!validationError[1]
|
|
91
|
-
}, endTextFieldProps, selectedSectionsResponse.end, {
|
|
92
|
-
format,
|
|
93
|
-
formatDensity,
|
|
94
|
-
shouldRespectLeadingZeros,
|
|
95
|
-
disabled,
|
|
96
|
-
readOnly,
|
|
97
|
-
timezone,
|
|
98
|
-
value: valueProp === undefined ? undefined : valueProp[1],
|
|
99
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[1],
|
|
100
|
-
onChange: handleEndDateChange,
|
|
101
|
-
enableAccessibleFieldDOMStructure
|
|
102
|
-
});
|
|
103
|
-
const startDateResponse = useDateField(startFieldProps);
|
|
104
|
-
const endDateResponse = useDateField(endFieldProps);
|
|
105
|
-
|
|
106
|
-
/* TODO: Undo this change when a clearable behavior for multiple input range fields is implemented */
|
|
107
|
-
return {
|
|
108
|
-
startDate: excludeProps(startDateResponse, ['clearable', 'onClear']),
|
|
109
|
-
endDate: excludeProps(endDateResponse, ['clearable', 'onClear'])
|
|
110
|
-
};
|
|
111
|
-
};
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
-
import useEventCallback from '@mui/utils/useEventCallback';
|
|
3
|
-
import { unstable_useDateTimeField as useDateTimeField } from '@mui/x-date-pickers/DateTimeField';
|
|
4
|
-
import { useControlledValueWithTimezone, useDefaultizedDateTimeField } from '@mui/x-date-pickers/internals';
|
|
5
|
-
import { useValidation } from '@mui/x-date-pickers/validation';
|
|
6
|
-
import { validateDateTimeRange } from "../../../validation/index.js";
|
|
7
|
-
import { rangeValueManager } from "../../utils/valueManagers.js";
|
|
8
|
-
import { excludeProps } from "./shared.js";
|
|
9
|
-
import { useMultiInputFieldSelectedSections } from "../useMultiInputFieldSelectedSections.js";
|
|
10
|
-
export const useMultiInputDateTimeRangeField = ({
|
|
11
|
-
sharedProps: inSharedProps,
|
|
12
|
-
startTextFieldProps,
|
|
13
|
-
unstableStartFieldRef,
|
|
14
|
-
endTextFieldProps,
|
|
15
|
-
unstableEndFieldRef
|
|
16
|
-
}) => {
|
|
17
|
-
const sharedProps = useDefaultizedDateTimeField(inSharedProps);
|
|
18
|
-
const {
|
|
19
|
-
value: valueProp,
|
|
20
|
-
defaultValue,
|
|
21
|
-
format,
|
|
22
|
-
formatDensity,
|
|
23
|
-
shouldRespectLeadingZeros,
|
|
24
|
-
onChange,
|
|
25
|
-
disabled,
|
|
26
|
-
readOnly,
|
|
27
|
-
selectedSections,
|
|
28
|
-
onSelectedSectionsChange,
|
|
29
|
-
timezone: timezoneProp,
|
|
30
|
-
enableAccessibleFieldDOMStructure,
|
|
31
|
-
autoFocus
|
|
32
|
-
} = sharedProps;
|
|
33
|
-
const {
|
|
34
|
-
value,
|
|
35
|
-
handleValueChange,
|
|
36
|
-
timezone
|
|
37
|
-
} = useControlledValueWithTimezone({
|
|
38
|
-
name: 'useMultiInputDateRangeField',
|
|
39
|
-
timezone: timezoneProp,
|
|
40
|
-
value: valueProp,
|
|
41
|
-
defaultValue,
|
|
42
|
-
onChange,
|
|
43
|
-
valueManager: rangeValueManager
|
|
44
|
-
});
|
|
45
|
-
const {
|
|
46
|
-
validationError,
|
|
47
|
-
getValidationErrorForNewValue
|
|
48
|
-
} = useValidation({
|
|
49
|
-
props: sharedProps,
|
|
50
|
-
value,
|
|
51
|
-
timezone,
|
|
52
|
-
validator: validateDateTimeRange,
|
|
53
|
-
onError: sharedProps.onError
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
// TODO: Maybe export utility from `useField` instead of copy/pasting the logic
|
|
57
|
-
const buildChangeHandler = index => {
|
|
58
|
-
return (newDate, rawContext) => {
|
|
59
|
-
const newDateRange = index === 0 ? [newDate, value[1]] : [value[0], newDate];
|
|
60
|
-
const context = _extends({}, rawContext, {
|
|
61
|
-
validationError: getValidationErrorForNewValue(newDateRange)
|
|
62
|
-
});
|
|
63
|
-
handleValueChange(newDateRange, context);
|
|
64
|
-
};
|
|
65
|
-
};
|
|
66
|
-
const handleStartDateChange = useEventCallback(buildChangeHandler(0));
|
|
67
|
-
const handleEndDateChange = useEventCallback(buildChangeHandler(1));
|
|
68
|
-
const selectedSectionsResponse = useMultiInputFieldSelectedSections({
|
|
69
|
-
selectedSections,
|
|
70
|
-
onSelectedSectionsChange,
|
|
71
|
-
unstableStartFieldRef,
|
|
72
|
-
unstableEndFieldRef
|
|
73
|
-
});
|
|
74
|
-
const startFieldProps = _extends({
|
|
75
|
-
error: !!validationError[0]
|
|
76
|
-
}, startTextFieldProps, selectedSectionsResponse.start, {
|
|
77
|
-
disabled,
|
|
78
|
-
readOnly,
|
|
79
|
-
format,
|
|
80
|
-
formatDensity,
|
|
81
|
-
shouldRespectLeadingZeros,
|
|
82
|
-
timezone,
|
|
83
|
-
value: valueProp === undefined ? undefined : valueProp[0],
|
|
84
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[0],
|
|
85
|
-
onChange: handleStartDateChange,
|
|
86
|
-
enableAccessibleFieldDOMStructure,
|
|
87
|
-
autoFocus // Do not add on end field.
|
|
88
|
-
});
|
|
89
|
-
const endFieldProps = _extends({
|
|
90
|
-
error: !!validationError[1]
|
|
91
|
-
}, endTextFieldProps, selectedSectionsResponse.end, {
|
|
92
|
-
format,
|
|
93
|
-
formatDensity,
|
|
94
|
-
shouldRespectLeadingZeros,
|
|
95
|
-
disabled,
|
|
96
|
-
readOnly,
|
|
97
|
-
timezone,
|
|
98
|
-
value: valueProp === undefined ? undefined : valueProp[1],
|
|
99
|
-
defaultValue: defaultValue === undefined ? undefined : defaultValue[1],
|
|
100
|
-
onChange: handleEndDateChange,
|
|
101
|
-
enableAccessibleFieldDOMStructure
|
|
102
|
-
});
|
|
103
|
-
const startDateResponse = useDateTimeField(startFieldProps);
|
|
104
|
-
const endDateResponse = useDateTimeField(endFieldProps);
|
|
105
|
-
|
|
106
|
-
/* TODO: Undo this change when a clearable behavior for multiple input range fields is implemented */
|
|
107
|
-
return {
|
|
108
|
-
startDate: excludeProps(startDateResponse, ['clearable', 'onClear']),
|
|
109
|
-
endDate: excludeProps(endDateResponse, ['clearable', 'onClear'])
|
|
110
|
-
};
|
|
111
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|