import { Canvas, Meta, Story, Source, ArgsTable } from '@storybook/addon-docs';
import { DatePicker } from "./index";
import { DateRangePicker } from "./index";
# DatePicker
Cunningham provides a versatile DatePicker component to select or input a date in your form. It uses the headless
UI components provided by [React-Spectrum](https://react-spectrum.adobe.com/react-aria/useDatePicker.html) from Adobe.
> Time features will be available soon.
## Basic
`}
/>
## Default value
You can use the following props to change the default value of the DatePicker component by using the `state` props.
## Range
`}
/>
When using it within a form, you'll access its values using separate inputs for the start and end values. The start input's
name will be the `DateRangePicker`'s name suffixed by `_start` and the end input's name will be the `DateRangePicker`'s name suffixed by `_end`.
Ex: If a `DateRangePicker` is named `"subscription"`, you would access its values as follow:
## States
You can use the following props to change the state of the DatePicker component by using the `state` props.
## Disabled
As a regular input, you can disable it by using the `disabled` props.
## Texts
As the component uses [Field](?path=/story/components-forms-field-doc--page), you can use the `text` props to provide a description of the checkbox.
## Controlled / Non Controlled
Like a native input, you can use the DatePicker component in a controlled or non controlled way. You can see the example below
using the component in a controlled way.
## MinValue / MaxValue
You can pass a date range that are valid using the `minValue` and `maxValue` props.
## Invalid date
When passing an invalid date, for example outside of the valid range, the DatePicker component would render invalid.
## International calendars
When passing a locale value to the DatePicker components, dates would be automatically displayed in the appropriate calendar system.
By default, the DatePicker component uses the CunninghamProvider locale.
## Props
You can see the list of props below.
### DatePicker
### DateRangePicker
## Design tokens
Here are the custom design tokens defined by the datepicker.
| Token | Description |
|--------------- |----------------------------- |
| background-color | Background color of the datepicker |
| border-color | Border color of the datepicker |
| border-color--hover | Border color of the datepicker on mouse hover |
| border-color--focus | Border color of the datepicker when focus |
| border-radius | Border radius of the datepicker |
| border-width | Border width of the datepicker |
| border-radius--hover | Border radius of the datepicker on mouse hover |
| border-radius--focus | Border radius of the datepicker when focused |
| color | Value color |
| font-size | Value font size |
| height | Height of the combo box |
| item-background-color--hover | Background color of the item on mouse hover (months/years menus) |
| item-background-color--selected | Background color of the selected item (months/years menus) |
| item-color | Color of the item (months/years menus) |
| item-font-size | Font size of the item (months/years menus) |
| menu-background-color | Background color of the menu (months/years menus) |
| grid-cell--border-color--today | Border color of the today grid-cell |
| grid-cell--color--today | Value color of the today grid-cell |
| range-selection-background-color | Value color of the selected grid-cells |
See also [Field](?path=/story/components-forms-field-doc--page)