@mui/x-date-pickers-pro 8.0.0-alpha.5 → 8.0.0-alpha.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (148) hide show
  1. package/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.d.ts +1 -1
  2. package/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.js +1 -1
  3. package/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/package.json +1 -1
  4. package/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.d.ts +1 -1
  5. package/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.js +1 -1
  6. package/{AdapterDateFnsV3 → AdapterDateFnsV2}/package.json +1 -1
  7. package/CHANGELOG.md +206 -1
  8. package/DateRangeCalendar/DateRangeCalendar.js +9 -7
  9. package/DateRangePicker/DateRangePicker.js +1 -1
  10. package/DateRangePicker/DateRangePicker.types.d.ts +5 -0
  11. package/DateRangePicker/DateRangePickerToolbar.d.ts +2 -3
  12. package/DateRangePicker/DateRangePickerToolbar.js +25 -31
  13. package/DateRangePicker/shared.d.ts +1 -1
  14. package/DateTimeRangePicker/DateTimeRangePicker.js +2 -2
  15. package/DateTimeRangePicker/DateTimeRangePickerTabs.d.ts +4 -5
  16. package/DateTimeRangePicker/DateTimeRangePickerTabs.js +25 -24
  17. package/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.d.ts +8 -10
  18. package/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js +7 -5
  19. package/DateTimeRangePicker/DateTimeRangePickerToolbar.d.ts +2 -4
  20. package/DateTimeRangePicker/DateTimeRangePickerToolbar.js +66 -69
  21. package/DateTimeRangePicker/shared.d.ts +2 -2
  22. package/DesktopDateRangePicker/DesktopDateRangePicker.js +9 -3
  23. package/DesktopDateRangePicker/DesktopDateRangePicker.types.d.ts +7 -2
  24. package/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +17 -14
  25. package/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.types.d.ts +2 -3
  26. package/MobileDateRangePicker/MobileDateRangePicker.js +2 -2
  27. package/MobileDateRangePicker/MobileDateRangePicker.types.d.ts +2 -2
  28. package/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +15 -8
  29. package/MobileDateTimeRangePicker/MobileDateTimeRangePicker.types.d.ts +2 -3
  30. package/SingleInputDateRangeField/useSingleInputDateRangeField.d.ts +1 -1
  31. package/SingleInputDateRangeField/useSingleInputDateRangeField.js +13 -14
  32. package/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.d.ts +1 -1
  33. package/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +13 -14
  34. package/SingleInputTimeRangeField/useSingleInputTimeRangeField.d.ts +1 -1
  35. package/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +13 -14
  36. package/StaticDateRangePicker/StaticDateRangePicker.types.d.ts +2 -2
  37. package/dateRangeViewRenderers/dateRangeViewRenderers.d.ts +2 -2
  38. package/dateRangeViewRenderers/dateRangeViewRenderers.js +0 -6
  39. package/hooks/index.d.ts +1 -0
  40. package/hooks/index.js +1 -0
  41. package/hooks/package.json +6 -0
  42. package/hooks/usePickerRangePositionContext.d.ts +7 -0
  43. package/hooks/usePickerRangePositionContext.js +15 -0
  44. package/index.d.ts +2 -0
  45. package/index.js +4 -2
  46. package/internals/hooks/models/useRangePicker.d.ts +4 -4
  47. package/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +35 -53
  48. package/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.types.d.ts +7 -9
  49. package/internals/hooks/useEnrichedRangePickerFieldProps.d.ts +6 -6
  50. package/internals/hooks/useEnrichedRangePickerFieldProps.js +11 -8
  51. package/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +24 -40
  52. package/internals/hooks/useMobileRangePicker/useMobileRangePicker.types.d.ts +7 -9
  53. package/internals/hooks/useMultiInputFieldSelectedSections.d.ts +10 -12
  54. package/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.d.ts +1 -1
  55. package/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +11 -6
  56. package/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.d.ts +2 -2
  57. package/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +12 -7
  58. package/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.d.ts +2 -2
  59. package/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +13 -8
  60. package/internals/hooks/useNullablePickerRangePositionContext.d.ts +5 -0
  61. package/internals/hooks/useNullablePickerRangePositionContext.js +10 -0
  62. package/internals/hooks/useRangePosition.d.ts +1 -1
  63. package/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +14 -24
  64. package/internals/hooks/useStaticRangePicker/useStaticRangePicker.types.d.ts +6 -6
  65. package/internals/utils/date-range-manager.js +2 -1
  66. package/internals/utils/releaseInfo.js +1 -1
  67. package/internals/utils/valueManagers.js +7 -7
  68. package/managers/index.d.ts +6 -0
  69. package/managers/index.js +3 -0
  70. package/managers/package.json +6 -0
  71. package/managers/useDateRangeManager.d.ts +15 -0
  72. package/managers/useDateRangeManager.js +31 -0
  73. package/managers/useDateTimeRangeManager.d.ts +15 -0
  74. package/managers/useDateTimeRangeManager.js +31 -0
  75. package/managers/useTimeRangeManager.d.ts +15 -0
  76. package/managers/useTimeRangeManager.js +29 -0
  77. package/models/range.d.ts +0 -1
  78. package/modern/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.js +1 -1
  79. package/modern/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.js +1 -1
  80. package/modern/DateRangeCalendar/DateRangeCalendar.js +9 -7
  81. package/modern/DateRangePicker/DateRangePicker.js +1 -1
  82. package/modern/DateRangePicker/DateRangePickerToolbar.js +25 -31
  83. package/modern/DateTimeRangePicker/DateTimeRangePicker.js +2 -2
  84. package/modern/DateTimeRangePicker/DateTimeRangePickerTabs.js +25 -24
  85. package/modern/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js +7 -5
  86. package/modern/DateTimeRangePicker/DateTimeRangePickerToolbar.js +66 -69
  87. package/modern/DesktopDateRangePicker/DesktopDateRangePicker.js +9 -3
  88. package/modern/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +17 -14
  89. package/modern/MobileDateRangePicker/MobileDateRangePicker.js +2 -2
  90. package/modern/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +15 -8
  91. package/modern/SingleInputDateRangeField/useSingleInputDateRangeField.js +13 -14
  92. package/modern/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +13 -14
  93. package/modern/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +13 -14
  94. package/modern/dateRangeViewRenderers/dateRangeViewRenderers.js +0 -6
  95. package/modern/hooks/index.js +1 -0
  96. package/modern/hooks/usePickerRangePositionContext.js +15 -0
  97. package/modern/index.js +4 -2
  98. package/modern/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +35 -53
  99. package/modern/internals/hooks/useEnrichedRangePickerFieldProps.js +11 -8
  100. package/modern/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +24 -40
  101. package/modern/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +11 -6
  102. package/modern/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +12 -7
  103. package/modern/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +13 -8
  104. package/modern/internals/hooks/useNullablePickerRangePositionContext.js +10 -0
  105. package/modern/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +14 -24
  106. package/modern/internals/utils/date-range-manager.js +2 -1
  107. package/modern/internals/utils/releaseInfo.js +1 -1
  108. package/modern/internals/utils/valueManagers.js +7 -7
  109. package/modern/managers/index.js +3 -0
  110. package/modern/managers/useDateRangeManager.js +31 -0
  111. package/modern/managers/useDateTimeRangeManager.js +31 -0
  112. package/modern/managers/useTimeRangeManager.js +29 -0
  113. package/node/{AdapterDateFnsJalaliV3 → AdapterDateFnsJalaliV2}/index.js +1 -1
  114. package/node/{AdapterDateFnsV3 → AdapterDateFnsV2}/index.js +1 -1
  115. package/node/DateRangeCalendar/DateRangeCalendar.js +9 -7
  116. package/node/DateRangePicker/DateRangePicker.js +1 -1
  117. package/node/DateRangePicker/DateRangePickerToolbar.js +24 -30
  118. package/node/DateTimeRangePicker/DateTimeRangePicker.js +2 -2
  119. package/node/DateTimeRangePicker/DateTimeRangePickerTabs.js +24 -23
  120. package/node/DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js +7 -5
  121. package/node/DateTimeRangePicker/DateTimeRangePickerToolbar.js +65 -68
  122. package/node/DesktopDateRangePicker/DesktopDateRangePicker.js +9 -3
  123. package/node/DesktopDateTimeRangePicker/DesktopDateTimeRangePicker.js +17 -14
  124. package/node/MobileDateRangePicker/MobileDateRangePicker.js +2 -2
  125. package/node/MobileDateTimeRangePicker/MobileDateTimeRangePicker.js +15 -8
  126. package/node/SingleInputDateRangeField/useSingleInputDateRangeField.js +12 -14
  127. package/node/SingleInputDateTimeRangeField/useSingleInputDateTimeRangeField.js +12 -14
  128. package/node/SingleInputTimeRangeField/useSingleInputTimeRangeField.js +12 -14
  129. package/node/dateRangeViewRenderers/dateRangeViewRenderers.js +0 -6
  130. package/node/hooks/index.js +12 -0
  131. package/node/hooks/usePickerRangePositionContext.js +22 -0
  132. package/node/index.js +23 -1
  133. package/node/internals/hooks/useDesktopRangePicker/useDesktopRangePicker.js +35 -53
  134. package/node/internals/hooks/useEnrichedRangePickerFieldProps.js +11 -8
  135. package/node/internals/hooks/useMobileRangePicker/useMobileRangePicker.js +24 -40
  136. package/node/internals/hooks/useMultiInputRangeField/useMultiInputDateRangeField.js +10 -5
  137. package/node/internals/hooks/useMultiInputRangeField/useMultiInputDateTimeRangeField.js +11 -6
  138. package/node/internals/hooks/useMultiInputRangeField/useMultiInputTimeRangeField.js +12 -7
  139. package/node/internals/hooks/useNullablePickerRangePositionContext.js +16 -0
  140. package/node/internals/hooks/useStaticRangePicker/useStaticRangePicker.js +14 -24
  141. package/node/internals/utils/date-range-manager.js +2 -1
  142. package/node/internals/utils/releaseInfo.js +1 -1
  143. package/node/internals/utils/valueManagers.js +7 -7
  144. package/node/managers/index.js +26 -0
  145. package/node/managers/useDateRangeManager.js +38 -0
  146. package/node/managers/useDateTimeRangeManager.js +38 -0
  147. package/node/managers/useTimeRangeManager.js +36 -0
  148. package/package.json +5 -5
@@ -2,7 +2,7 @@
2
2
 
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
5
- const _excluded = ["openTo", "rangePosition"];
5
+ const _excluded = ["openTo"];
6
6
  import * as React from 'react';
7
7
  import PropTypes from 'prop-types';
8
8
  import { isDatePickerView, isInternalTimeView, resolveDateTimeFormat, useUtils } from '@mui/x-date-pickers/internals';
@@ -22,15 +22,22 @@ import { useDateTimeRangePickerDefaultizedProps } from "../DateTimeRangePicker/s
22
22
  import { MultiInputDateTimeRangeField } from "../MultiInputDateTimeRangeField/index.js";
23
23
  import { DateTimeRangePickerTimeWrapper } from "../DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js";
24
24
  import { RANGE_VIEW_HEIGHT } from "../internals/constants/dimensions.js";
25
+ import { usePickerRangePositionContext } from "../hooks/index.js";
25
26
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
26
- const rendererInterceptor = function rendererInterceptor(inViewRenderers, popperView, rendererProps) {
27
+ const rendererInterceptor = function RendererInterceptor(props) {
27
28
  const {
28
- openTo,
29
- rangePosition
29
+ viewRenderers,
30
+ popperView,
31
+ rendererProps
32
+ } = props;
33
+ const {
34
+ openTo
30
35
  } = rendererProps,
31
36
  otherProps = _objectWithoutPropertiesLoose(rendererProps, _excluded);
37
+ const {
38
+ rangePosition
39
+ } = usePickerRangePositionContext();
32
40
  const finalProps = _extends({}, otherProps, {
33
- rangePosition,
34
41
  focusedView: null,
35
42
  sx: [{
36
43
  [`&.${multiSectionDigitalClockClasses.root}`]: {
@@ -43,7 +50,7 @@ const rendererInterceptor = function rendererInterceptor(inViewRenderers, popper
43
50
  });
44
51
  const isTimeViewActive = isInternalTimeView(popperView);
45
52
  return /*#__PURE__*/_jsxs(React.Fragment, {
46
- children: [inViewRenderers.day?.(_extends({}, rendererProps, {
53
+ children: [viewRenderers.day?.(_extends({}, rendererProps, {
47
54
  availableRangePositions: [rangePosition],
48
55
  view: !isTimeViewActive ? popperView : 'day',
49
56
  views: rendererProps.views.filter(isDatePickerView),
@@ -59,7 +66,7 @@ const rendererInterceptor = function rendererInterceptor(inViewRenderers, popper
59
66
  view: isTimeViewActive ? popperView : 'hours',
60
67
  views: finalProps.views.filter(isInternalTimeView),
61
68
  openTo: isInternalTimeView(openTo) ? openTo : 'hours',
62
- viewRenderer: inViewRenderers[isTimeViewActive ? popperView : 'hours'],
69
+ viewRenderer: viewRenderers[isTimeViewActive ? popperView : 'hours'],
63
70
  sx: [{
64
71
  gridColumn: 3
65
72
  }, ...finalProps.sx]
@@ -92,7 +99,6 @@ const DesktopDateTimeRangePicker = /*#__PURE__*/React.forwardRef(function Deskto
92
99
  // Need to avoid adding the `meridiem` view when unexpected renderer is specified
93
100
  const shouldHoursRendererContainMeridiemView = viewRenderers.hours?.name === renderMultiSectionDigitalClockTimeView.name;
94
101
  const views = !shouldHoursRendererContainMeridiemView ? defaultizedProps.views.filter(view => view !== 'meridiem') : defaultizedProps.views;
95
- const actionBarActions = defaultizedProps.shouldRenderTimeInASingleColumn ? [] : ['accept'];
96
102
  const props = _extends({}, defaultizedProps, {
97
103
  views,
98
104
  viewRenderers,
@@ -113,10 +119,7 @@ const DesktopDateTimeRangePicker = /*#__PURE__*/React.forwardRef(function Deskto
113
119
  }, defaultizedProps.slotProps?.tabs),
114
120
  toolbar: _extends({
115
121
  hidden: true
116
- }, defaultizedProps.slotProps?.toolbar),
117
- actionBar: ownerState => _extends({
118
- actions: actionBarActions
119
- }, resolveComponentProps(defaultizedProps.slotProps?.actionBar, ownerState))
122
+ }, defaultizedProps.slotProps?.toolbar)
120
123
  })
121
124
  });
122
125
  const {
@@ -154,8 +157,8 @@ DesktopDateTimeRangePicker.propTypes = {
154
157
  calendars: PropTypes.oneOf([1, 2, 3]),
155
158
  className: PropTypes.string,
156
159
  /**
157
- * If `true`, the popover or modal will close after submitting the full date.
158
- * @default `true` for desktop, `false` for mobile (based on the chosen wrapper and `desktopModeMediaQuery` prop).
160
+ * If `true`, the Picker will close after submitting the full date.
161
+ * @default false
159
162
  */
160
163
  closeOnSelect: PropTypes.bool,
161
164
  /**
@@ -74,8 +74,8 @@ MobileDateRangePicker.propTypes = {
74
74
  autoFocus: PropTypes.bool,
75
75
  className: PropTypes.string,
76
76
  /**
77
- * If `true`, the popover or modal will close after submitting the full date.
78
- * @default `true` for desktop, `false` for mobile (based on the chosen wrapper and `desktopModeMediaQuery` prop).
77
+ * If `true`, the Picker will close after submitting the full date.
78
+ * @default false
79
79
  */
80
80
  closeOnSelect: PropTypes.bool,
81
81
  /**
@@ -2,7 +2,7 @@
2
2
 
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
5
- const _excluded = ["view", "openTo", "rangePosition"];
5
+ const _excluded = ["view", "openTo"];
6
6
  import * as React from 'react';
7
7
  import PropTypes from 'prop-types';
8
8
  import { refType } from '@mui/utils';
@@ -20,16 +20,23 @@ import { useDateTimeRangePickerDefaultizedProps } from "../DateTimeRangePicker/s
20
20
  import { MultiInputDateTimeRangeField } from "../MultiInputDateTimeRangeField/index.js";
21
21
  import { DateTimeRangePickerTimeWrapper } from "../DateTimeRangePicker/DateTimeRangePickerTimeWrapper.js";
22
22
  import { RANGE_VIEW_HEIGHT } from "../internals/constants/dimensions.js";
23
+ import { usePickerRangePositionContext } from "../hooks/index.js";
23
24
  import { jsx as _jsx } from "react/jsx-runtime";
24
- const rendererInterceptor = function rendererInterceptor(inViewRenderers, popperView, rendererProps) {
25
+ const rendererInterceptor = function RendererInterceptor(props) {
26
+ const {
27
+ viewRenderers,
28
+ popperView,
29
+ rendererProps
30
+ } = props;
31
+ const {
32
+ rangePosition
33
+ } = usePickerRangePositionContext();
25
34
  const {
26
35
  view,
27
- openTo,
28
- rangePosition
36
+ openTo
29
37
  } = rendererProps,
30
38
  otherRendererProps = _objectWithoutPropertiesLoose(rendererProps, _excluded);
31
39
  const finalProps = _extends({}, otherRendererProps, {
32
- rangePosition,
33
40
  focusedView: null,
34
41
  sx: [{
35
42
  width: DIALOG_WIDTH,
@@ -53,7 +60,7 @@ const rendererInterceptor = function rendererInterceptor(inViewRenderers, popper
53
60
  }]
54
61
  });
55
62
  const isTimeView = isInternalTimeView(popperView);
56
- const viewRenderer = inViewRenderers[popperView];
63
+ const viewRenderer = viewRenderers[popperView];
57
64
  if (!viewRenderer) {
58
65
  return null;
59
66
  }
@@ -148,8 +155,8 @@ MobileDateTimeRangePicker.propTypes = {
148
155
  autoFocus: PropTypes.bool,
149
156
  className: PropTypes.string,
150
157
  /**
151
- * If `true`, the popover or modal will close after submitting the full date.
152
- * @default `true` for desktop, `false` for mobile (based on the chosen wrapper and `desktopModeMediaQuery` prop).
158
+ * If `true`, the Picker will close after submitting the full date.
159
+ * @default false
153
160
  */
154
161
  closeOnSelect: PropTypes.bool,
155
162
  /**
@@ -1,25 +1,24 @@
1
1
  'use client';
2
2
 
3
- import * as React from 'react';
4
- import { useField, useDefaultizedDateField } from '@mui/x-date-pickers/internals';
3
+ import { useField, useFieldInternalPropsWithDefaults } from '@mui/x-date-pickers/internals';
5
4
  import { useSplitFieldProps } from '@mui/x-date-pickers/hooks';
6
- import { rangeValueManager, getRangeFieldValueManager } from "../internals/utils/valueManagers.js";
7
- import { validateDateRange } from "../validation/index.js";
8
- export const useSingleInputDateRangeField = inProps => {
9
- const props = useDefaultizedDateField(inProps);
5
+ import { useDateRangeManager } from "../managers/index.js";
6
+ export const useSingleInputDateRangeField = props => {
7
+ const manager = useDateRangeManager(props);
10
8
  const {
11
9
  forwardedProps,
12
10
  internalProps
13
11
  } = useSplitFieldProps(props, 'date');
14
- const fieldValueManager = React.useMemo(() => getRangeFieldValueManager({
15
- dateSeparator: internalProps.dateSeparator
16
- }), [internalProps.dateSeparator]);
12
+ const internalPropsWithDefaults = useFieldInternalPropsWithDefaults({
13
+ manager,
14
+ internalProps
15
+ });
17
16
  return useField({
18
17
  forwardedProps,
19
- internalProps,
20
- valueManager: rangeValueManager,
21
- fieldValueManager,
22
- validator: validateDateRange,
23
- valueType: 'date'
18
+ internalProps: internalPropsWithDefaults,
19
+ valueManager: manager.internal_valueManager,
20
+ fieldValueManager: manager.internal_fieldValueManager,
21
+ validator: manager.validator,
22
+ valueType: manager.valueType
24
23
  });
25
24
  };
@@ -1,25 +1,24 @@
1
1
  'use client';
2
2
 
3
- import * as React from 'react';
4
- import { useField, useDefaultizedDateTimeField } from '@mui/x-date-pickers/internals';
3
+ import { useField, useFieldInternalPropsWithDefaults } from '@mui/x-date-pickers/internals';
5
4
  import { useSplitFieldProps } from '@mui/x-date-pickers/hooks';
6
- import { rangeValueManager, getRangeFieldValueManager } from "../internals/utils/valueManagers.js";
7
- import { validateDateTimeRange } from "../validation/index.js";
8
- export const useSingleInputDateTimeRangeField = inProps => {
9
- const props = useDefaultizedDateTimeField(inProps);
5
+ import { useDateTimeRangeManager } from "../managers/index.js";
6
+ export const useSingleInputDateTimeRangeField = props => {
7
+ const manager = useDateTimeRangeManager(props);
10
8
  const {
11
9
  forwardedProps,
12
10
  internalProps
13
11
  } = useSplitFieldProps(props, 'date-time');
14
- const fieldValueManager = React.useMemo(() => getRangeFieldValueManager({
15
- dateSeparator: internalProps.dateSeparator
16
- }), [internalProps.dateSeparator]);
12
+ const internalPropsWithDefaults = useFieldInternalPropsWithDefaults({
13
+ manager,
14
+ internalProps
15
+ });
17
16
  return useField({
18
17
  forwardedProps,
19
- internalProps,
20
- valueManager: rangeValueManager,
21
- fieldValueManager,
22
- validator: validateDateTimeRange,
23
- valueType: 'date-time'
18
+ internalProps: internalPropsWithDefaults,
19
+ valueManager: manager.internal_valueManager,
20
+ fieldValueManager: manager.internal_fieldValueManager,
21
+ validator: manager.validator,
22
+ valueType: manager.valueType
24
23
  });
25
24
  };
@@ -1,25 +1,24 @@
1
1
  'use client';
2
2
 
3
- import * as React from 'react';
4
- import { useField, useDefaultizedTimeField } from '@mui/x-date-pickers/internals';
3
+ import { useField, useFieldInternalPropsWithDefaults } from '@mui/x-date-pickers/internals';
5
4
  import { useSplitFieldProps } from '@mui/x-date-pickers/hooks';
6
- import { rangeValueManager, getRangeFieldValueManager } from "../internals/utils/valueManagers.js";
7
- import { validateTimeRange } from "../validation/index.js";
8
- export const useSingleInputTimeRangeField = inProps => {
9
- const props = useDefaultizedTimeField(inProps);
5
+ import { useTimeRangeManager } from "../managers/index.js";
6
+ export const useSingleInputTimeRangeField = props => {
7
+ const manager = useTimeRangeManager(props);
10
8
  const {
11
9
  forwardedProps,
12
10
  internalProps
13
11
  } = useSplitFieldProps(props, 'time');
14
- const fieldValueManager = React.useMemo(() => getRangeFieldValueManager({
15
- dateSeparator: internalProps.dateSeparator
16
- }), [internalProps.dateSeparator]);
12
+ const internalPropsWithDefaults = useFieldInternalPropsWithDefaults({
13
+ manager,
14
+ internalProps
15
+ });
17
16
  return useField({
18
17
  forwardedProps,
19
- internalProps,
20
- valueManager: rangeValueManager,
21
- fieldValueManager,
22
- validator: validateTimeRange,
23
- valueType: 'time'
18
+ internalProps: internalPropsWithDefaults,
19
+ valueManager: manager.internal_valueManager,
20
+ fieldValueManager: manager.internal_fieldValueManager,
21
+ validator: manager.validator,
22
+ valueType: manager.valueType
24
23
  });
25
24
  };
@@ -19,9 +19,6 @@ export const renderDateRangeViewCalendar = ({
19
19
  shouldDisableDate,
20
20
  reduceAnimations,
21
21
  onMonthChange,
22
- rangePosition,
23
- defaultRangePosition,
24
- onRangePositionChange,
25
22
  calendars,
26
23
  currentMonthCalendarPosition,
27
24
  slots,
@@ -58,9 +55,6 @@ export const renderDateRangeViewCalendar = ({
58
55
  shouldDisableDate: shouldDisableDate,
59
56
  reduceAnimations: reduceAnimations,
60
57
  onMonthChange: onMonthChange,
61
- rangePosition: rangePosition,
62
- defaultRangePosition: defaultRangePosition,
63
- onRangePositionChange: onRangePositionChange,
64
58
  calendars: calendars,
65
59
  currentMonthCalendarPosition: currentMonthCalendarPosition,
66
60
  slots: slots,
@@ -0,0 +1 @@
1
+ export { usePickerRangePositionContext } from "./usePickerRangePositionContext.js";
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+
3
+ import * as React from 'react';
4
+ export const PickerRangePositionContext = /*#__PURE__*/React.createContext(null);
5
+
6
+ /**
7
+ * Returns information about the range position of the picker that wraps the current component.
8
+ */
9
+ export function usePickerRangePositionContext() {
10
+ const value = React.useContext(PickerRangePositionContext);
11
+ if (value == null) {
12
+ throw new Error(['MUI X: The `usePickerRangePositionContext` can only be called in components that are used inside a picker component'].join('\n'));
13
+ }
14
+ return value;
15
+ }
package/modern/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @mui/x-date-pickers-pro v8.0.0-alpha.5
2
+ * @mui/x-date-pickers-pro v8.0.0-alpha.7
3
3
  *
4
4
  * @license MUI X Commercial
5
5
  * This source code is licensed under the commercial license found in the
@@ -32,4 +32,6 @@ export * from "./MobileDateTimeRangePicker/index.js";
32
32
  // View renderers
33
33
  export * from "./dateRangeViewRenderers/index.js";
34
34
  export * from "./models/index.js";
35
- export * from "./validation/index.js";
35
+ export * from "./hooks/index.js";
36
+ export * from "./validation/index.js";
37
+ export * from "./managers/index.js";
@@ -9,6 +9,7 @@ import { executeInTheNextEventLoopTick, getActiveElement, usePicker, PickersPopp
9
9
  import { useEnrichedRangePickerFieldProps } from "../useEnrichedRangePickerFieldProps.js";
10
10
  import { getReleaseInfo } from "../../utils/releaseInfo.js";
11
11
  import { useRangePosition } from "../useRangePosition.js";
12
+ import { PickerRangePositionContext } from "../../../hooks/usePickerRangePositionContext.js";
12
13
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
14
  const releaseInfo = getReleaseInfo();
14
15
  export const useDesktopRangePicker = _ref => {
@@ -46,22 +47,16 @@ export const useDesktopRangePicker = _ref => {
46
47
  const singleInputFieldRef = React.useRef(null);
47
48
  const initialView = React.useRef(props.openTo ?? null);
48
49
  const fieldType = slots.field.fieldType ?? 'multi-input';
49
- const {
50
- rangePosition,
51
- onRangePositionChange
52
- } = useRangePosition(props, fieldType === 'single-input' ? singleInputFieldRef : undefined);
50
+ const rangePositionResponse = useRangePosition(props, fieldType === 'single-input' ? singleInputFieldRef : undefined);
53
51
  let fieldRef;
54
52
  if (fieldType === 'single-input') {
55
53
  fieldRef = singleInputFieldRef;
56
- } else if (rangePosition === 'start') {
54
+ } else if (rangePositionResponse.rangePosition === 'start') {
57
55
  fieldRef = startFieldRef;
58
56
  } else {
59
57
  fieldRef = endFieldRef;
60
58
  }
61
59
  const {
62
- open,
63
- actions,
64
- layoutProps,
65
60
  providerProps,
66
61
  renderCurrentView,
67
62
  shouldRestoreFocus,
@@ -72,15 +67,11 @@ export const useDesktopRangePicker = _ref => {
72
67
  variant: 'desktop',
73
68
  autoFocusView: false,
74
69
  fieldRef,
75
- localeText,
76
- additionalViewProps: {
77
- rangePosition,
78
- onRangePositionChange
79
- }
70
+ localeText
80
71
  }));
81
72
  React.useEffect(() => {
82
- if (layoutProps.view) {
83
- initialView.current = layoutProps.view;
73
+ if (providerProps.contextValue.view) {
74
+ initialView.current = providerProps.contextValue.view;
84
75
  }
85
76
  // eslint-disable-next-line react-hooks/exhaustive-deps
86
77
  }, []);
@@ -89,7 +80,9 @@ export const useDesktopRangePicker = _ref => {
89
80
  if (fieldContainerRef.current?.contains(getActiveElement(document)) || popperRef.current?.contains(getActiveElement(document))) {
90
81
  return;
91
82
  }
92
- actions.onDismiss();
83
+
84
+ // This direct access to `providerProps` will go away once the range fields stop having their views in a tooltip.
85
+ providerProps.privateContextValue.dismissViews();
93
86
  });
94
87
  };
95
88
  const Field = slots.field;
@@ -121,18 +114,17 @@ export const useDesktopRangePicker = _ref => {
121
114
  }),
122
115
  ownerState
123
116
  });
124
- const enrichedFieldProps = useEnrichedRangePickerFieldProps({
117
+ const enrichedFieldProps = useEnrichedRangePickerFieldProps(_extends({
125
118
  variant: 'desktop',
126
119
  fieldType,
127
- open,
128
- actions,
120
+ // These direct access to `providerProps` will go away once the range fields handle the picker opening
121
+ open: providerProps.contextValue.open,
122
+ setOpen: providerProps.contextValue.setOpen,
129
123
  readOnly,
130
124
  disableOpenPicker,
131
125
  label,
132
126
  localeText,
133
127
  onBlur: handleBlur,
134
- rangePosition,
135
- onRangePositionChange,
136
128
  pickerSlotProps: slotProps,
137
129
  pickerSlots: slots,
138
130
  fieldProps,
@@ -140,40 +132,30 @@ export const useDesktopRangePicker = _ref => {
140
132
  startFieldRef,
141
133
  endFieldRef,
142
134
  singleInputFieldRef,
143
- currentView: layoutProps.view !== props.openTo ? layoutProps.view : undefined,
144
- initialView: initialView.current ?? undefined,
145
- onViewChange: layoutProps.onViewChange
146
- });
147
- const slotPropsForLayout = _extends({}, slotProps, {
148
- tabs: _extends({}, slotProps?.tabs, {
149
- rangePosition,
150
- onRangePositionChange
151
- }),
152
- toolbar: _extends({}, slotProps?.toolbar, {
153
- rangePosition,
154
- onRangePositionChange
155
- })
156
- });
135
+ currentView: providerProps.contextValue.view !== props.openTo ? providerProps.contextValue.view : undefined,
136
+ initialView: initialView.current ?? undefined
137
+ }, rangePositionResponse));
157
138
  const Layout = slots?.layout ?? PickersLayout;
158
- const renderPicker = () => /*#__PURE__*/_jsxs(PickerProvider, _extends({}, providerProps, {
159
- children: [/*#__PURE__*/_jsx(Field, _extends({}, enrichedFieldProps)), /*#__PURE__*/_jsx(PickersPopper, _extends({
160
- role: "tooltip",
161
- placement: "bottom-start",
162
- containerRef: popperRef,
163
- anchorEl: anchorRef.current,
164
- onBlur: handleBlur
165
- }, actions, {
166
- open: open,
167
- slots: slots,
168
- slotProps: slotProps,
169
- shouldRestoreFocus: shouldRestoreFocus,
170
- reduceAnimations: reduceAnimations,
171
- children: /*#__PURE__*/_jsx(Layout, _extends({}, layoutProps, slotProps?.layout, {
139
+ const renderPicker = () => /*#__PURE__*/_jsx(PickerProvider, _extends({}, providerProps, {
140
+ children: /*#__PURE__*/_jsxs(PickerRangePositionContext.Provider, {
141
+ value: rangePositionResponse,
142
+ children: [/*#__PURE__*/_jsx(Field, _extends({}, enrichedFieldProps)), /*#__PURE__*/_jsx(PickersPopper, {
143
+ role: "tooltip",
144
+ placement: "bottom-start",
145
+ containerRef: popperRef,
146
+ anchorEl: anchorRef.current,
147
+ onBlur: handleBlur,
172
148
  slots: slots,
173
- slotProps: slotPropsForLayout,
174
- children: renderCurrentView()
175
- }))
176
- }))]
149
+ slotProps: slotProps,
150
+ shouldRestoreFocus: shouldRestoreFocus,
151
+ reduceAnimations: reduceAnimations,
152
+ children: /*#__PURE__*/_jsx(Layout, _extends({}, slotProps?.layout, {
153
+ slots: slots,
154
+ slotProps: slotProps,
155
+ children: renderCurrentView()
156
+ }))
157
+ })]
158
+ })
177
159
  }));
178
160
  return {
179
161
  renderPicker
@@ -10,7 +10,7 @@ import { onSpaceOrEnter } from '@mui/x-date-pickers/internals';
10
10
  const useMultiInputFieldSlotProps = ({
11
11
  variant,
12
12
  open,
13
- actions,
13
+ setOpen,
14
14
  readOnly,
15
15
  labelId,
16
16
  disableOpenPicker,
@@ -24,7 +24,7 @@ const useMultiInputFieldSlotProps = ({
24
24
  anchorRef,
25
25
  currentView,
26
26
  initialView,
27
- onViewChange,
27
+ setView,
28
28
  startFieldRef,
29
29
  endFieldRef
30
30
  }) => {
@@ -54,21 +54,23 @@ const useMultiInputFieldSlotProps = ({
54
54
  event.stopPropagation();
55
55
  onRangePositionChange('start');
56
56
  if (!readOnly && !disableOpenPicker) {
57
- actions.onOpen(event);
57
+ event.preventDefault();
58
+ setOpen(true);
58
59
  }
59
60
  };
60
61
  const openRangeEndSelection = event => {
61
62
  event.stopPropagation();
62
63
  onRangePositionChange('end');
63
64
  if (!readOnly && !disableOpenPicker) {
64
- actions.onOpen(event);
65
+ event.preventDefault();
66
+ setOpen(true);
65
67
  }
66
68
  };
67
69
  const handleFocusStart = () => {
68
70
  if (open) {
69
71
  onRangePositionChange('start');
70
72
  if (previousRangePosition.current !== 'start' && initialView) {
71
- onViewChange?.(initialView);
73
+ setView?.(initialView);
72
74
  }
73
75
  }
74
76
  };
@@ -76,7 +78,7 @@ const useMultiInputFieldSlotProps = ({
76
78
  if (open) {
77
79
  onRangePositionChange('end');
78
80
  if (previousRangePosition.current !== 'end' && initialView) {
79
- onViewChange?.(initialView);
81
+ setView?.(initialView);
80
82
  }
81
83
  }
82
84
  };
@@ -148,7 +150,7 @@ const useMultiInputFieldSlotProps = ({
148
150
  const useSingleInputFieldSlotProps = ({
149
151
  variant,
150
152
  open,
151
- actions,
153
+ setOpen,
152
154
  readOnly,
153
155
  labelId,
154
156
  disableOpenPicker,
@@ -197,7 +199,8 @@ const useSingleInputFieldSlotProps = ({
197
199
  const openPicker = event => {
198
200
  event.stopPropagation();
199
201
  if (!readOnly && !disableOpenPicker) {
200
- actions.onOpen(event);
202
+ event.preventDefault();
203
+ setOpen(true);
201
204
  }
202
205
  };
203
206
  const slots = _extends({}, fieldProps.slots, {