@mui/x-date-pickers-pro 5.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (137) hide show
  1. package/CHANGELOG.md +3785 -0
  2. package/DateRangePicker/DateRangePicker.d.ts +66 -0
  3. package/DateRangePicker/DateRangePicker.js +519 -0
  4. package/DateRangePicker/DateRangePickerInput.d.ts +37 -0
  5. package/DateRangePicker/DateRangePickerInput.js +128 -0
  6. package/DateRangePicker/DateRangePickerToolbar.d.ts +15 -0
  7. package/DateRangePicker/DateRangePickerToolbar.js +59 -0
  8. package/DateRangePicker/DateRangePickerView.d.ts +41 -0
  9. package/DateRangePicker/DateRangePickerView.js +179 -0
  10. package/DateRangePicker/DateRangePickerViewDesktop.d.ts +30 -0
  11. package/DateRangePicker/DateRangePickerViewDesktop.js +154 -0
  12. package/DateRangePicker/DateRangePickerViewMobile.d.ts +15 -0
  13. package/DateRangePicker/DateRangePickerViewMobile.js +60 -0
  14. package/DateRangePicker/date-range-manager.d.ts +14 -0
  15. package/DateRangePicker/date-range-manager.js +43 -0
  16. package/DateRangePicker/index.d.ts +3 -0
  17. package/DateRangePicker/index.js +1 -0
  18. package/DateRangePicker/package.json +6 -0
  19. package/DateRangePickerDay/DateRangePickerDay.d.ts +52 -0
  20. package/DateRangePickerDay/DateRangePickerDay.js +290 -0
  21. package/DateRangePickerDay/dateRangePickerDayClasses.d.ts +29 -0
  22. package/DateRangePickerDay/dateRangePickerDayClasses.js +5 -0
  23. package/DateRangePickerDay/index.d.ts +4 -0
  24. package/DateRangePickerDay/index.js +2 -0
  25. package/DateRangePickerDay/package.json +6 -0
  26. package/DesktopDateRangePicker/DesktopDateRangePicker.d.ts +66 -0
  27. package/DesktopDateRangePicker/DesktopDateRangePicker.js +485 -0
  28. package/DesktopDateRangePicker/index.d.ts +2 -0
  29. package/DesktopDateRangePicker/index.js +1 -0
  30. package/DesktopDateRangePicker/package.json +6 -0
  31. package/MobileDateRangePicker/MobileDateRangePicker.d.ts +66 -0
  32. package/MobileDateRangePicker/MobileDateRangePicker.js +495 -0
  33. package/MobileDateRangePicker/index.d.ts +2 -0
  34. package/MobileDateRangePicker/index.js +1 -0
  35. package/MobileDateRangePicker/package.json +6 -0
  36. package/README.md +29 -0
  37. package/StaticDateRangePicker/StaticDateRangePicker.d.ts +69 -0
  38. package/StaticDateRangePicker/StaticDateRangePicker.js +455 -0
  39. package/StaticDateRangePicker/index.d.ts +2 -0
  40. package/StaticDateRangePicker/index.js +1 -0
  41. package/StaticDateRangePicker/package.json +6 -0
  42. package/index.d.ts +7 -0
  43. package/index.js +12 -0
  44. package/internal/hooks/validation/useDateRangeValidation.d.ts +12 -0
  45. package/internal/hooks/validation/useDateRangeValidation.js +27 -0
  46. package/internal/models/dateRange.d.ts +8 -0
  47. package/internal/models/dateRange.js +1 -0
  48. package/internal/models/index.d.ts +1 -0
  49. package/internal/models/index.js +1 -0
  50. package/internal/utils/date-utils.d.ts +7 -0
  51. package/internal/utils/date-utils.js +19 -0
  52. package/internal/utils/releaseInfo.d.ts +1 -0
  53. package/internal/utils/releaseInfo.js +15 -0
  54. package/internal/utils/utils.d.ts +1 -0
  55. package/internal/utils/utils.js +1 -0
  56. package/legacy/DateRangePicker/DateRangePicker.js +528 -0
  57. package/legacy/DateRangePicker/DateRangePickerInput.js +141 -0
  58. package/legacy/DateRangePicker/DateRangePickerToolbar.js +66 -0
  59. package/legacy/DateRangePicker/DateRangePickerView.js +184 -0
  60. package/legacy/DateRangePicker/DateRangePickerViewDesktop.js +172 -0
  61. package/legacy/DateRangePicker/DateRangePickerViewMobile.js +63 -0
  62. package/legacy/DateRangePicker/date-range-manager.js +51 -0
  63. package/legacy/DateRangePicker/index.js +1 -0
  64. package/legacy/DateRangePickerDay/DateRangePickerDay.js +296 -0
  65. package/legacy/DateRangePickerDay/dateRangePickerDayClasses.js +5 -0
  66. package/legacy/DateRangePickerDay/index.js +2 -0
  67. package/legacy/DesktopDateRangePicker/DesktopDateRangePicker.js +494 -0
  68. package/legacy/DesktopDateRangePicker/index.js +1 -0
  69. package/legacy/MobileDateRangePicker/MobileDateRangePicker.js +504 -0
  70. package/legacy/MobileDateRangePicker/index.js +1 -0
  71. package/legacy/StaticDateRangePicker/StaticDateRangePicker.js +465 -0
  72. package/legacy/StaticDateRangePicker/index.js +1 -0
  73. package/legacy/index.js +12 -0
  74. package/legacy/internal/hooks/validation/useDateRangeValidation.js +33 -0
  75. package/legacy/internal/models/dateRange.js +1 -0
  76. package/legacy/internal/models/index.js +1 -0
  77. package/legacy/internal/utils/date-utils.js +22 -0
  78. package/legacy/internal/utils/releaseInfo.js +15 -0
  79. package/legacy/internal/utils/utils.js +1 -0
  80. package/legacy/themeAugmentation/index.js +3 -0
  81. package/modern/DateRangePicker/DateRangePicker.js +519 -0
  82. package/modern/DateRangePicker/DateRangePickerInput.js +124 -0
  83. package/modern/DateRangePicker/DateRangePickerToolbar.js +59 -0
  84. package/modern/DateRangePicker/DateRangePickerView.js +179 -0
  85. package/modern/DateRangePicker/DateRangePickerViewDesktop.js +154 -0
  86. package/modern/DateRangePicker/DateRangePickerViewMobile.js +60 -0
  87. package/modern/DateRangePicker/date-range-manager.js +43 -0
  88. package/modern/DateRangePicker/index.js +1 -0
  89. package/modern/DateRangePickerDay/DateRangePickerDay.js +290 -0
  90. package/modern/DateRangePickerDay/dateRangePickerDayClasses.js +5 -0
  91. package/modern/DateRangePickerDay/index.js +2 -0
  92. package/modern/DesktopDateRangePicker/DesktopDateRangePicker.js +485 -0
  93. package/modern/DesktopDateRangePicker/index.js +1 -0
  94. package/modern/MobileDateRangePicker/MobileDateRangePicker.js +495 -0
  95. package/modern/MobileDateRangePicker/index.js +1 -0
  96. package/modern/StaticDateRangePicker/StaticDateRangePicker.js +455 -0
  97. package/modern/StaticDateRangePicker/index.js +1 -0
  98. package/modern/index.js +12 -0
  99. package/modern/internal/hooks/validation/useDateRangeValidation.js +27 -0
  100. package/modern/internal/models/dateRange.js +1 -0
  101. package/modern/internal/models/index.js +1 -0
  102. package/modern/internal/utils/date-utils.js +19 -0
  103. package/modern/internal/utils/releaseInfo.js +15 -0
  104. package/modern/internal/utils/utils.js +1 -0
  105. package/modern/themeAugmentation/index.js +3 -0
  106. package/node/DateRangePicker/DateRangePicker.js +540 -0
  107. package/node/DateRangePicker/DateRangePickerInput.js +148 -0
  108. package/node/DateRangePicker/DateRangePickerToolbar.js +79 -0
  109. package/node/DateRangePicker/DateRangePickerView.js +206 -0
  110. package/node/DateRangePicker/DateRangePickerViewDesktop.js +175 -0
  111. package/node/DateRangePicker/DateRangePickerViewMobile.js +80 -0
  112. package/node/DateRangePicker/date-range-manager.js +52 -0
  113. package/node/DateRangePicker/index.js +13 -0
  114. package/node/DateRangePickerDay/DateRangePickerDay.js +315 -0
  115. package/node/DateRangePickerDay/dateRangePickerDayClasses.js +16 -0
  116. package/node/DateRangePickerDay/index.js +27 -0
  117. package/node/DesktopDateRangePicker/DesktopDateRangePicker.js +506 -0
  118. package/node/DesktopDateRangePicker/index.js +13 -0
  119. package/node/MobileDateRangePicker/MobileDateRangePicker.js +516 -0
  120. package/node/MobileDateRangePicker/index.js +13 -0
  121. package/node/StaticDateRangePicker/StaticDateRangePicker.js +475 -0
  122. package/node/StaticDateRangePicker/index.js +13 -0
  123. package/node/index.js +105 -0
  124. package/node/internal/hooks/validation/useDateRangeValidation.js +40 -0
  125. package/node/internal/models/dateRange.js +5 -0
  126. package/node/internal/models/index.js +18 -0
  127. package/node/internal/utils/date-utils.js +40 -0
  128. package/node/internal/utils/releaseInfo.js +25 -0
  129. package/node/internal/utils/utils.js +10 -0
  130. package/node/themeAugmentation/index.js +44 -0
  131. package/package.json +77 -0
  132. package/themeAugmentation/components.d.ts +13 -0
  133. package/themeAugmentation/index.d.ts +3 -0
  134. package/themeAugmentation/index.js +3 -0
  135. package/themeAugmentation/overrides.d.ts +13 -0
  136. package/themeAugmentation/package.json +6 -0
  137. package/themeAugmentation/props.d.ts +12 -0
@@ -0,0 +1,485 @@
1
+ import _extends from "@babel/runtime/helpers/esm/extends";
2
+ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3
+ const _excluded = ["calendars", "value", "onChange", "mask", "startText", "endText", "inputFormat", "minDate", "maxDate", "PopperProps", "TransitionComponent"];
4
+ import * as React from 'react';
5
+ import PropTypes from 'prop-types';
6
+ import { useLicenseVerifier } from '@mui/x-license-pro';
7
+ import { useThemeProps } from '@mui/material/styles';
8
+ import { DesktopTooltipWrapper, useDefaultDates, useUtils, usePickerState } from '@mui/x-date-pickers/internals';
9
+ import { DateRangePickerView } from '../DateRangePicker/DateRangePickerView';
10
+ import { DateRangePickerInput } from '../DateRangePicker/DateRangePickerInput';
11
+ import { useDateRangeValidation } from '../internal/hooks/validation/useDateRangeValidation';
12
+ import { parseRangeInputValue } from '../internal/utils/date-utils';
13
+ import { getReleaseInfo } from '../internal/utils/releaseInfo';
14
+ import { jsx as _jsx } from "react/jsx-runtime";
15
+ const releaseInfo = getReleaseInfo();
16
+ const KeyboardDateInputComponent = DateRangePickerInput;
17
+ const rangePickerValueManager = {
18
+ emptyValue: [null, null],
19
+ parseInput: parseRangeInputValue,
20
+ areValuesEqual: (utils, a, b) => utils.isEqual(a[0], b[0]) && utils.isEqual(a[1], b[1])
21
+ };
22
+
23
+ /**
24
+ *
25
+ * Demos:
26
+ *
27
+ * - [Date Range Picker](https://mui.com/components/x/react-date-pickers/date-range-picker/)
28
+ *
29
+ * API:
30
+ *
31
+ * - [DesktopDateRangePicker API](https://mui.com/api/desktop-date-range-picker/)
32
+ */
33
+ export const DesktopDateRangePicker = /*#__PURE__*/React.forwardRef(function DesktopDateRangePicker(inProps, ref) {
34
+ const props = useThemeProps({
35
+ props: inProps,
36
+ name: 'MuiDesktopDateRangePicker'
37
+ });
38
+ useLicenseVerifier('x-date-pickers-pro', releaseInfo);
39
+
40
+ const {
41
+ calendars = 2,
42
+ value,
43
+ onChange,
44
+ mask = '__/__/____',
45
+ startText = 'Start',
46
+ endText = 'End',
47
+ inputFormat: passedInputFormat,
48
+ minDate: minDateProp,
49
+ maxDate: maxDateProp,
50
+ PopperProps,
51
+ TransitionComponent
52
+ } = props,
53
+ other = _objectWithoutPropertiesLoose(props, _excluded);
54
+
55
+ const utils = useUtils();
56
+ const defaultDates = useDefaultDates();
57
+ const minDate = minDateProp ?? defaultDates.minDate;
58
+ const maxDate = maxDateProp ?? defaultDates.maxDate;
59
+ const [currentlySelectingRangeEnd, setCurrentlySelectingRangeEnd] = React.useState('start');
60
+
61
+ const pickerStateProps = _extends({}, other, {
62
+ value,
63
+ onChange
64
+ });
65
+
66
+ const restProps = _extends({}, other, {
67
+ minDate,
68
+ maxDate
69
+ });
70
+
71
+ const {
72
+ pickerProps,
73
+ inputProps,
74
+ wrapperProps
75
+ } = usePickerState(pickerStateProps, rangePickerValueManager);
76
+ const validationError = useDateRangeValidation(props);
77
+
78
+ const DateInputProps = _extends({}, inputProps, restProps, {
79
+ currentlySelectingRangeEnd,
80
+ inputFormat: passedInputFormat || utils.formats.keyboardDate,
81
+ setCurrentlySelectingRangeEnd,
82
+ startText,
83
+ endText,
84
+ mask,
85
+ validationError,
86
+ ref
87
+ });
88
+
89
+ return /*#__PURE__*/_jsx(DesktopTooltipWrapper, _extends({}, wrapperProps, {
90
+ DateInputProps: DateInputProps,
91
+ KeyboardDateInputComponent: KeyboardDateInputComponent,
92
+ PopperProps: PopperProps,
93
+ TransitionComponent: TransitionComponent,
94
+ children: /*#__PURE__*/_jsx(DateRangePickerView, _extends({
95
+ open: wrapperProps.open,
96
+ DateInputProps: DateInputProps,
97
+ calendars: calendars,
98
+ currentlySelectingRangeEnd: currentlySelectingRangeEnd,
99
+ setCurrentlySelectingRangeEnd: setCurrentlySelectingRangeEnd,
100
+ startText: startText,
101
+ endText: endText
102
+ }, pickerProps, restProps))
103
+ }));
104
+ });
105
+ process.env.NODE_ENV !== "production" ? DesktopDateRangePicker.propTypes = {
106
+ // ----------------------------- Warning --------------------------------
107
+ // | These PropTypes are generated from the TypeScript type definitions |
108
+ // | To update them edit the TypeScript types and run "yarn proptypes" |
109
+ // ----------------------------------------------------------------------
110
+
111
+ /**
112
+ * Regular expression to detect "accepted" symbols.
113
+ * @default /\dap/gi
114
+ */
115
+ acceptRegex: PropTypes.instanceOf(RegExp),
116
+
117
+ /**
118
+ * If `true`, `onChange` is fired on click even if the same date is selected.
119
+ * @default false
120
+ */
121
+ allowSameDateSelection: PropTypes.bool,
122
+ autoFocus: PropTypes.bool,
123
+
124
+ /**
125
+ * The number of calendars that render on **desktop**.
126
+ * @default 2
127
+ */
128
+ calendars: PropTypes.oneOf([1, 2, 3]),
129
+ children: PropTypes.node,
130
+
131
+ /**
132
+ * className applied to the root component.
133
+ */
134
+ className: PropTypes.string,
135
+
136
+ /**
137
+ * If `true`, it shows the clear action in the picker dialog.
138
+ * @default false
139
+ */
140
+ clearable: PropTypes.bool,
141
+
142
+ /**
143
+ * Clear text message.
144
+ * @default 'Clear'
145
+ */
146
+ clearText: PropTypes.node,
147
+
148
+ /**
149
+ * The components used for each slot.
150
+ * Either a string to use a HTML element or a component.
151
+ * @default {}
152
+ */
153
+ components: PropTypes.object,
154
+
155
+ /**
156
+ * The props used for each slot inside.
157
+ * @default {}
158
+ */
159
+ componentsProps: PropTypes.object,
160
+
161
+ /**
162
+ * Default calendar month displayed when `value={null}`.
163
+ */
164
+ defaultCalendarMonth: PropTypes.any,
165
+
166
+ /**
167
+ * If `true`, after selecting `start` date calendar will not automatically switch to the month of `end` date.
168
+ * @default false
169
+ */
170
+ disableAutoMonthSwitching: PropTypes.bool,
171
+
172
+ /**
173
+ * If `true` the popup or dialog will immediately close after submitting full date.
174
+ * @default `true` for Desktop, `false` for Mobile (based on the chosen wrapper and `desktopModeMediaQuery` prop).
175
+ */
176
+ disableCloseOnSelect: PropTypes.bool,
177
+
178
+ /**
179
+ * If `true`, the picker and text field are disabled.
180
+ * @default false
181
+ */
182
+ disabled: PropTypes.bool,
183
+
184
+ /**
185
+ * @default false
186
+ */
187
+ disableFuture: PropTypes.bool,
188
+
189
+ /**
190
+ * If `true`, todays date is rendering without highlighting with circle.
191
+ * @default false
192
+ */
193
+ disableHighlightToday: PropTypes.bool,
194
+
195
+ /**
196
+ * Disable mask on the keyboard, this should be used rarely. Consider passing proper mask for your format.
197
+ * @default false
198
+ */
199
+ disableMaskedInput: PropTypes.bool,
200
+
201
+ /**
202
+ * Do not render open picker button (renders only text field with validation).
203
+ * @default false
204
+ */
205
+ disableOpenPicker: PropTypes.bool,
206
+
207
+ /**
208
+ * @default false
209
+ */
210
+ disablePast: PropTypes.bool,
211
+
212
+ /**
213
+ * Text for end input label and toolbar placeholder.
214
+ * @default 'End'
215
+ */
216
+ endText: PropTypes.node,
217
+
218
+ /**
219
+ * Get aria-label text for control that opens picker dialog. Aria-label text must include selected date. @DateIOType
220
+ * @default (value, utils) => `Choose date, selected date is ${utils.format(utils.date(value), 'fullDate')}`
221
+ * @param {ParseableDate<TDateValue>} value The date from which we want to add an aria-text.
222
+ * @param {MuiPickersAdapter<TDateValue>} utils The utils to manipulate the date.
223
+ * @returns {string} The aria-text to render inside the dialog.
224
+ */
225
+ getOpenDialogAriaText: PropTypes.func,
226
+
227
+ /**
228
+ * Get aria-label text for switching between views button.
229
+ * @param {CalendarPickerView} currentView The view from which we want to get the button text.
230
+ * @returns {string} The label of the view.
231
+ */
232
+ getViewSwitchingButtonText: PropTypes.func,
233
+ ignoreInvalidInputs: PropTypes.bool,
234
+
235
+ /**
236
+ * Props to pass to keyboard input adornment.
237
+ */
238
+ InputAdornmentProps: PropTypes.object,
239
+
240
+ /**
241
+ * Format string.
242
+ */
243
+ inputFormat: PropTypes.string,
244
+ InputProps: PropTypes.object,
245
+
246
+ /**
247
+ * Pass a ref to the `input` element.
248
+ */
249
+ inputRef: PropTypes.oneOfType([PropTypes.func, PropTypes.shape({
250
+ current: PropTypes.object
251
+ })]),
252
+ label: PropTypes.node,
253
+
254
+ /**
255
+ * Left arrow icon aria-label text.
256
+ */
257
+ leftArrowButtonText: PropTypes.string,
258
+
259
+ /**
260
+ * If `true` renders `LoadingComponent` in calendar instead of calendar view.
261
+ * Can be used to preload information and show it in calendar.
262
+ * @default false
263
+ */
264
+ loading: PropTypes.bool,
265
+
266
+ /**
267
+ * Custom mask. Can be used to override generate from format. (e.g. `__/__/____ __:__` or `__/__/____ __:__ _M`).
268
+ * @default '__/__/____'
269
+ */
270
+ mask: PropTypes.string,
271
+
272
+ /**
273
+ * Max selectable date. @DateIOType
274
+ * @default defaultMaxDate
275
+ */
276
+ maxDate: PropTypes.any,
277
+
278
+ /**
279
+ * Min selectable date. @DateIOType
280
+ * @default defaultMinDate
281
+ */
282
+ minDate: PropTypes.any,
283
+
284
+ /**
285
+ * Callback fired when date is accepted @DateIOType.
286
+ * @param {TDateValue} date The date that was just accepted.
287
+ */
288
+ onAccept: PropTypes.func,
289
+
290
+ /**
291
+ * Callback fired when the value (the selected date range) changes @DateIOType.
292
+ * @param {DateRange<TDate>} date The new parsed date range.
293
+ * @param {string} keyboardInputValue The current value of the keyboard input.
294
+ */
295
+ onChange: PropTypes.func.isRequired,
296
+
297
+ /**
298
+ * Callback fired when the popup requests to be closed.
299
+ * Use in controlled mode (see open).
300
+ */
301
+ onClose: PropTypes.func,
302
+
303
+ /**
304
+ * Callback that fired when input value or new `value` prop validation returns **new** validation error (or value is valid after error).
305
+ * In case of validation error detected `reason` prop return non-null value and `TextField` must be displayed in `error` state.
306
+ * This can be used to render appropriate form error.
307
+ *
308
+ * [Read the guide](https://next.material-ui-pickers.dev/guides/forms) about form integration and error displaying.
309
+ * @DateIOType
310
+ *
311
+ * @param {TError} reason The reason why the current value is not valid.
312
+ * @param {TDateValue} value The invalid value.
313
+ */
314
+ onError: PropTypes.func,
315
+
316
+ /**
317
+ * Callback firing on month change. @DateIOType
318
+ * @param {TDate} month The new month.
319
+ */
320
+ onMonthChange: PropTypes.func,
321
+
322
+ /**
323
+ * Callback fired when the popup requests to be opened.
324
+ * Use in controlled mode (see open).
325
+ */
326
+ onOpen: PropTypes.func,
327
+
328
+ /**
329
+ * Callback fired on view change.
330
+ * @param {CalendarPickerView} view The new view.
331
+ */
332
+ onViewChange: PropTypes.func,
333
+
334
+ /**
335
+ * Control the popup or dialog open state.
336
+ */
337
+ open: PropTypes.bool,
338
+
339
+ /**
340
+ * Props to pass to keyboard adornment button.
341
+ */
342
+ OpenPickerButtonProps: PropTypes.object,
343
+
344
+ /**
345
+ * Force rendering in particular orientation.
346
+ */
347
+ orientation: PropTypes.oneOf(['landscape', 'portrait']),
348
+
349
+ /**
350
+ * Paper props passed down to [Paper](https://mui.com/api/paper/) component.
351
+ */
352
+ PaperProps: PropTypes.object,
353
+
354
+ /**
355
+ * Popper props passed down to [Popper](https://mui.com/api/popper/) component.
356
+ */
357
+ PopperProps: PropTypes.object,
358
+
359
+ /**
360
+ * Make picker read only.
361
+ * @default false
362
+ */
363
+ readOnly: PropTypes.bool,
364
+
365
+ /**
366
+ * Disable heavy animations.
367
+ * @default typeof navigator !== 'undefined' && /(android)/i.test(navigator.userAgent)
368
+ */
369
+ reduceAnimations: PropTypes.bool,
370
+
371
+ /**
372
+ * Custom renderer for `<DateRangePicker />` days. @DateIOType
373
+ * @example (date, dateRangePickerDayProps) => <DateRangePickerDay {...dateRangePickerDayProps} />
374
+ * @param {TDate} day The day to render.
375
+ * @param {DateRangePickerDayProps<TDate>} dateRangePickerDayProps The props of the day to render.
376
+ * @returns {JSX.Element} The element representing the day.
377
+ */
378
+ renderDay: PropTypes.func,
379
+
380
+ /**
381
+ * The `renderInput` prop allows you to customize the rendered input.
382
+ * The `startProps` and `endProps` arguments of this render prop contains props of [TextField](https://mui.com/api/text-field/#textfield-api),
383
+ * that you need to forward to the range start/end inputs respectively.
384
+ * Pay specific attention to the `ref` and `inputProps` keys.
385
+ * @example
386
+ * ```jsx
387
+ * <DateRangePicker
388
+ * renderInput={(startProps, endProps) => (
389
+ * <React.Fragment>
390
+ * <TextField {...startProps} />
391
+ * <Box sx={{ mx: 2 }}> to </Box>
392
+ * <TextField {...endProps} />
393
+ * </React.Fragment>;
394
+ * )}
395
+ * />
396
+ * ````
397
+ * @param {MuiTextFieldProps} startProps Props that you need to forward to the range start input.
398
+ * @param {MuiTextFieldProps} endProps Props that you need to forward to the range end input.
399
+ * @returns {React.ReactElement} The range input to render.
400
+ */
401
+ renderInput: PropTypes.func.isRequired,
402
+
403
+ /**
404
+ * Component displaying when passed `loading` true.
405
+ * @returns {React.ReactNode} The node to render when loading.
406
+ * @default () => <span data-mui-test="loading-progress">...</span>
407
+ */
408
+ renderLoading: PropTypes.func,
409
+
410
+ /**
411
+ * Custom formatter to be passed into Rifm component.
412
+ * @param {string} str The un-formatted string.
413
+ * @returns {string} The formatted string.
414
+ */
415
+ rifmFormatter: PropTypes.func,
416
+
417
+ /**
418
+ * Right arrow icon aria-label text.
419
+ */
420
+ rightArrowButtonText: PropTypes.string,
421
+
422
+ /**
423
+ * Disable specific date. @DateIOType
424
+ * @param {TDate} day The date to check.
425
+ * @returns {boolean} If `true` the day will be disabled.
426
+ */
427
+ shouldDisableDate: PropTypes.func,
428
+
429
+ /**
430
+ * Disable specific years dynamically.
431
+ * Works like `shouldDisableDate` but for year selection view @DateIOType.
432
+ * @param {TDate} year The year to test.
433
+ * @returns {boolean} Return `true` if the year should be disabled.
434
+ */
435
+ shouldDisableYear: PropTypes.func,
436
+
437
+ /**
438
+ * If `true`, days that have `outsideCurrentMonth={true}` are displayed.
439
+ * @default false
440
+ */
441
+ showDaysOutsideCurrentMonth: PropTypes.bool,
442
+
443
+ /**
444
+ * If `true`, show the toolbar even in desktop mode.
445
+ */
446
+ showToolbar: PropTypes.bool,
447
+
448
+ /**
449
+ * Text for start input label and toolbar placeholder.
450
+ * @default 'Start'
451
+ */
452
+ startText: PropTypes.node,
453
+
454
+ /**
455
+ * Component that will replace default toolbar renderer.
456
+ */
457
+ ToolbarComponent: PropTypes.elementType,
458
+
459
+ /**
460
+ * Date format, that is displaying in toolbar.
461
+ */
462
+ toolbarFormat: PropTypes.string,
463
+
464
+ /**
465
+ * Mobile picker date value placeholder, displaying if `value` === `null`.
466
+ * @default '–'
467
+ */
468
+ toolbarPlaceholder: PropTypes.node,
469
+
470
+ /**
471
+ * Mobile picker title, displaying in the toolbar.
472
+ * @default 'Select date range'
473
+ */
474
+ toolbarTitle: PropTypes.node,
475
+
476
+ /**
477
+ * Custom component for popper [Transition](https://mui.com/components/transitions/#transitioncomponent-prop).
478
+ */
479
+ TransitionComponent: PropTypes.elementType,
480
+
481
+ /**
482
+ * The value of the date range picker.
483
+ */
484
+ value: PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.any, PropTypes.instanceOf(Date), PropTypes.number, PropTypes.string])).isRequired
485
+ } : void 0;
@@ -0,0 +1 @@
1
+ export { DesktopDateRangePicker } from './DesktopDateRangePicker';