Fields
The field components let the user input date and time values with a keyboard and refined keyboard navigation.
Introduction
The fields are React components that let you enter a date or time with the keyboard, without using any popover or modal UI. They provide refined navigation through arrow keys and support advanced behaviors like localization and validation.
Fields to edit a single element
DateField
TimeField
DateTimeField
Fields to edit a range
All fields to edit a range are available in a single input version and in a multi input version.
SingleInputDateRangeField
MultiInputDateRangeField
—
MultiInputTimeRangeField
—
MultiInputDateTimeRangeField
—
Usage with the pickers
The picker components (DatePicker
, DestkopDatePicker
, MobileDatePicker
, DateTimePicker
, ...) do not use the field components yet.
New pickers using them will be released in a few months.
Form props
The standard form attributes (disabled
, readOnly
) are supported by all the field components:
Advanced
When is onChange
called?
The field components have an internal state to update the visible value.
It will only call the onChange
callback when all the sections of the modified date are filled.
On single element fields
On a single date field (DateField
/ DateTimeField
/ TimeField
),
onChange
will be called if all the sections are filled.
In the example below, onChange
will not be fired until the date is fully completed:
Value: null
On range fields
On a date range field (SingleInputDateRangeField
/ MultiInputDateRangeField
),
onChange
will be called if all the sections of the date you modified are filled,
even if some sections of the other date are not filled.
In the demo below, changing the value of a start date section will fire onChange
even if the end date is empty.
But changing the value of an end date section will not fire onChange
until the end date is fully completed:
Value: 04/07/2022 – null
Only update when the value is valid
The onChange
callback received a 2nd parameter containing the validation error associated to the current value.
If you only want to update your state when the value is valid, you can ignore any onChange
call with a non-null validationError
.
In the example below, onChange
will only be fired if the date is valid and its year is 2022:
Value: null
Control the selected sections
Use the selectedSections
and onSelectedSectionsChange
props to control which sections are currently being selected.
This prop accepts four formats:
- If a number is provided, the section at this index will be selected.
- If an object with a
startIndex
andendIndex
fields are provided, the sections between those two indexes will be selected. - If a string of type
MuiDateSectionName
is provided, the first section with that name will be selected. - If
null
is provided, no section will be selected