5.0 KiB
Calendar
Demos
Selecting a single date
Click to select a single date by default.
Selecting multiple dates or a date range
You can select multiple date with the multiple prop set to true and can select a date range with the range prop set to true.
Selecting multiple date ranges
When multiple and range are both set to true, you can select multiple date ranges. You can configure the number of month panels with the panel prop. The way we merge newly selected ranges into those are already select are that, if you start select on a unselected date, the range will be selected and if start on a selected one, the range will be unselected.
API
Props
| Name | Type | Default | Description |
|---|---|---|---|
type |
string= |
'date' |
The type of the calendar. Available values include 'date' / 'month' / 'year', denoting date/month/year view respectively. When the value is not 'date', multiple and range will be ignored. |
multiple |
boolean= |
false |
Whether users can select multiple dates (date ranges). |
range |
boolean= |
false |
Whether users can select a date range (date ranges). |
selected |
`Date | Array=` | - |
panel |
number= |
1 |
The number of month panel displayed. |
today |
Date= |
new Date() |
The date of “today”. |
week-start |
number= |
calendar.weekStart |
The start of a week. Can be globally configured. |
fill-month |
boolean= |
true |
Whether to show dates of previous and next month in current panel when there's only one month panel. |
date-class |
`string | Array | Object |
disabled-date |
function(Date, Date=): boolean= |
() => false |
Used to customize whether the specified date is disabled or not. The first parameter is the date to be used to determine if the date is disabled. When in the range selection process and a date is already selected, it is passed as the second parameter. |
disabled |
boolean= |
false |
Whether the calendar is disabled. |
readonly |
boolean= |
false |
Whether the calendar is read-only. |
^^^selected
:::badges
v-model
:::
Selected date(s) or date range(s). Data type differs according to multiple and range.
+++Value types
multiple |
range |
Type |
|---|---|---|
false |
false |
Date |
true |
false |
Array<Date> |
false |
true |
[Date, Date] |
true |
true |
Array<[Date, Date]> |
| +++ | ||
| ^^^ |
Slots
| Name | Description |
|---|---|
before |
Customizable area before the content of the month panel(s). |
after |
Customizable area after the content of the month panel(s). |
date |
[^slot-date] |
^^^slot-date The content of each date cell. Displays the corresponding day of month by default.
+++Slot props
| Name | Type | Description |
|---|---|---|
year |
number |
The full representation of year. |
month |
number |
Month of a year, starting from 0 as January. |
date |
number |
The day of month. |
| +++ | ||
| ^^^ |
Events
| Name | Description |
|---|---|
select |
[^event-select] |
selectstart |
Triggered when selecting a date range and a start date is selected. The callback parameter list is (picking: Date), being the selected start date. |
selectprogress |
[^event-selectprogress] |
viewchange |
Triggered when the month of the month panel changes. The callback parameter list is (month: Object<{year: number, month: number}>), representing the current year and month of the first month panel. |
^^^event-select
:::badges
v-model
:::
Triggered when selection change. The callback parameter list is (selected). The type of selected is the same as the selected prop.
^^^
^^^event-selectprogress
Triggered when selecting a date range and an end date is marked with pointer/keyboard interaction, and for each time the end date changes. The callback parameter list is (picking), with picking being the marked date range. The type of picking depends on the value of the multiple prop.
+++Parameters types
multiple |
Type |
|---|---|
false |
[Date, Date] |
true |
Array<[Date, Date]> |
| +++ | |
| ^^^ |
Configs
| Key | Type | Default | Description |
|---|---|---|---|
calendar.weekStart |
number |
1 |
The start of a week, with Monday being 1 and Sunday being 7. |
Icons
| Name | Description |
|---|---|
prev |
Previous page. |
next |
Next page. |
expand |
Expand dropdowns. |