Description
The DatePicker component should be used whenever there is to enter a single date or a date range/period with a start and end date.
Date Object
The DatePicker operates with a default JavaScript Date instance as well as string (ISO 8601) like start_date="2019-05-05"
(yyyy-MM-dd).
For more DatePicker examples, have a look at this CodeSandbox.
Demos
English (US) is not included in Eufemia by default. You can include it like:
import enUS from '@dnb/eufemia/shared/locales/en-US'<EufemiaProvider locale={enUS} ...>App</EufemiaProvider>
Range DatePicker
Code Editor
<DatePickerlabel="DatePicker:"start_date="2019-04-01"end_date="2019-05-17"range={true}show_input={true}on_change={({ start_date, end_date }) => {console.log('on_change', start_date, end_date)}}on_submit={({ start_date, end_date }) => {console.log('on_submit', start_date, end_date)}}on_cancel={({ start_date, end_date }) => {console.log('on_cancel', start_date, end_date)}}shortcuts={[{title: 'Set date period',start_date: '1969-07-15',end_date: '1969-08-15',},{title: 'Today',start_date: new Date(),},{title: 'This week',start_date: startOfWeek(new Date()),end_date: lastDayOfWeek(new Date()),},{close_on_select: true,title: 'This month',start_date: startOfMonth(new Date()),end_date: lastDayOfMonth(new Date()),},{title: 'Relative +3 days',start_date: ({ start_date }) => start_date || new Date(),end_date: ({ end_date }) => addDays(end_date || new Date(), 3),},]}/>
Default DatePicker
Code Editor
<DatePickerlabel="DatePicker:"date="2019-05-05"return_format="dd-MM-yyyy"on_change={({ date }) => {console.log('on_change', date)}}on_show={({ date }) => {console.log('on_show', date)}}/>
Default DatePicker with Input
Code Editor
<DatePickerlabel="DatePicker:"date={new Date()}show_input={true}show_cancel_button={true}show_reset_button={true}on_change={({ date }) => {console.log('on_change', date)}}on_cancel={({ date }) => {console.log('on_cancel', date)}}/>
Hidden Nav:
Code Editor
<DatePickerlabel="DatePicker:"date="2022/05/05"min_date="2022/05/01"max_date="2022/05/17"date_format="yyyy/MM/dd"return_format="dd/MM/yyyy"hide_navigation={true}hide_days={true}on_change={({ date }) => {console.log('on_change', date)}}on_hide={({ date }) => {console.log('on_hide', date)}}/>
Show month only
Code Editor
<DatePickerlabel="DatePicker:"date="05/02/2019"date_format="MM/dd/yyyy"only_month={true}/>
With info message
Please select a valid date
Code Editor
<DatePickerlabel="DatePicker:"date={new Date()}show_input={true}status="Please select a valid date"status_state="info"/>
With suffix
Code Editor
<DatePickerlabel="DatePicker:"date={new Date()}show_inputsuffix={<HelpButton title="Modal Title">Modal content</HelpButton>}/>
Linked DatePickers
Code Editor
<DatePicker label="DatePicker:" range link show_input />
DatePicker with error status
Please select a valid date
Code Editor
<DatePickerlabel="DatePicker:"date="2019-05-05"hide_navigation={true}status="Please select a valid date"/>
DatePicker with error
Code Editor
<DatePickerlabel="DatePicker:"date="2019-05-05"show_input={true}show_submit_button={true}stretch={true}status={<span>Status message with <b>HTML</b> inside</span>}/>
DatePicker with error status
Code Editor
<DatePickerlabel="DatePicker:"date={new Date()}hide_navigation={true}status="error"/>
Opened DatePicker
Also used for screenshot tests.
Code Editor
<DatePickeropened={true}prevent_close={true}disable_autofocus={true}range={true}start_date="2019-05-05"end_date="2019-06-05"/>