primevue-mirror/components/lib/datepicker/DatePicker.d.ts

1074 lines
29 KiB
TypeScript
Raw Normal View History

2024-04-18 14:13:33 +00:00
/**
*
* DatePicker is a form component to work with dates.
*
* [Live Demo](https://www.primevue.org/datepicker/)
*
* @module datepicker
*
*/
import { TransitionProps, VNode } from 'vue';
import { ComponentHooks } from '../basecomponent';
import { ButtonPassThroughOptions, ButtonProps } from '../button';
import { InputTextPassThroughOptions } from '../inputtext';
import { PassThroughOptions } from '../passthrough';
import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, HintedString, PassThrough } from '../ts-helpers';
2024-04-18 14:13:33 +00:00
export declare type DatePickerPassThroughOptionType = DatePickerPassThroughAttributes | ((options: DatePickerPassThroughMethodOptions) => DatePickerPassThroughAttributes | string) | string | null | undefined;
export declare type DatePickerPassThroughTransitionType = TransitionProps | ((options: DatePickerPassThroughMethodOptions) => TransitionProps) | undefined;
/**
* Custom passthrough(pt) option method.
*/
export interface DatePickerPassThroughMethodOptions {
/**
* Defines instance.
*/
instance: any;
/**
* Defines valid properties.
*/
props: DatePickerProps;
/**
* Defines current inline state.
*/
state: DatePickerState;
/**
* Defines current options.
*/
context: DatePickerContext;
/**
* Defines valid attributes.
*/
attrs: any;
/**
* Defines parent options.
*/
parent: any;
/**
* Defines passthrough(pt) options in global config.
*/
global: object | undefined;
}
/**
* Custom shared passthrough(pt) option method.
*/
export interface DatePickerSharedPassThroughMethodOptions {
/**
* Defines valid properties.
*/
props: DatePickerProps;
/**
* Defines current inline state.
*/
state: DatePickerState;
}
/**
* Custom DatePicker responsive options metadata.
*/
export interface DatePickerResponsiveOptions {
/**
* Breakpoint for responsive mode. Exp; \@media screen and (max-width: ${breakpoint}) {...}
*/
breakpoint: string;
/**
* The number of visible months on breakpoint.
*/
numMonths: number;
}
/**
* Custom DatePicker month change event.
2024-05-16 14:05:43 +00:00
* @see {@link DatePickerEmitsOptions['month-change']]}
2024-04-18 14:13:33 +00:00
*/
export interface DatePickerMonthChangeEvent {
/**
* New month.
*/
month: number;
/**
* New year.
*/
year: number;
}
/**
* Custom DatePicker year change event.
2024-05-16 14:05:43 +00:00
* @see {@link DatePickerEmitsOptions['year-change']]}
2024-04-18 14:13:33 +00:00
*/
export interface DatePickerYearChangeEvent {
/**
* New month.
*/
month: number;
/**
* New year.
*/
year: number;
}
/**
* Custom DatePicker blur event.
2024-05-16 14:05:43 +00:00
* @see {@link DatePickerEmitsOptions.blur}
2024-04-18 14:13:33 +00:00
*/
export interface DatePickerBlurEvent {
/**
* Browser event
*/
originalEvent: Event;
/**
* Input value
*/
value: string;
}
/**
* Custom passthrough(pt) options.
* @see {@link DatePickerProps.pt}
*/
export interface DatePickerPassThroughOptions {
/**
* Used to pass attributes to the root's DOM element.
2024-04-18 14:13:33 +00:00
*/
root?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the InputText component.
* @see {@link InputTextPassThroughOptions}
*/
2024-05-06 15:23:01 +00:00
pcInput?: InputTextPassThroughOptions<DatePickerSharedPassThroughMethodOptions>;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the dropdown's DOM element.
2024-04-18 14:13:33 +00:00
*/
dropdown?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the dropdown icon's DOM element.
*/
dropdownIcon?: DatePickerPassThroughOptionType;
2024-05-15 08:11:32 +00:00
/**
* Used to pass attributes to the input icon container's DOM element.
2024-05-15 08:11:32 +00:00
*/
inputIconContainer?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the input icon's DOM element.
2024-05-15 08:11:32 +00:00
*/
inputIcon?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the panel's DOM element.
2024-04-18 14:13:33 +00:00
*/
panel?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the calendar container's DOM element.
2024-04-18 14:13:33 +00:00
*/
calendarContainer?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the calendar's DOM element.
2024-04-18 14:13:33 +00:00
*/
calendar?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the header's DOM element.
2024-04-18 14:13:33 +00:00
*/
header?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the previous button's DOM element.
2024-04-18 14:13:33 +00:00
* @see {@link ButtonPassThroughOptions}
*/
2024-05-27 08:48:42 +00:00
pcPrevButton?: ButtonPassThroughOptions<DatePickerSharedPassThroughMethodOptions>;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the title's DOM element.
2024-04-18 14:13:33 +00:00
*/
title?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the view month's DOM element.
2024-04-18 14:13:33 +00:00
*/
2024-06-04 06:44:09 +00:00
selectMonth?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the view year's DOM element.
2024-04-18 14:13:33 +00:00
*/
2024-06-04 06:44:09 +00:00
selectYear?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the decade's DOM element.
2024-04-18 14:13:33 +00:00
*/
decade?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the view day's DOM element.
*/
dayView?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the next button's DOM element.
2024-04-18 14:13:33 +00:00
* @see {@link ButtonPassThroughOptions}
*/
2024-05-06 15:23:01 +00:00
pcNextButton?: ButtonPassThroughOptions<DatePickerSharedPassThroughMethodOptions>;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the container's DOM element.
2024-04-18 14:13:33 +00:00
*/
container?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the table's DOM element.
2024-04-18 14:13:33 +00:00
*/
table?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the table header's DOM element.
2024-04-18 14:13:33 +00:00
*/
tableHeader?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the table header row's DOM element.
2024-04-18 14:13:33 +00:00
*/
tableHeaderRow?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the week header's DOM element.
2024-04-18 14:13:33 +00:00
*/
weekHeader?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the week header label's DOM element.
2024-04-18 14:13:33 +00:00
*/
weekHeaderLabel?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the table header cell's DOM element.
2024-04-18 14:13:33 +00:00
*/
tableHeaderCell?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the week day cell's DOM element.
2024-04-18 14:13:33 +00:00
*/
weekDayCell?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the week day's DOM element.
2024-04-18 14:13:33 +00:00
*/
weekDay?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the table body's DOM element.
2024-04-18 14:13:33 +00:00
*/
tableBody?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the table body row's DOM element.
2024-04-18 14:13:33 +00:00
*/
tableBodyRow?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the week number's DOM element.
2024-04-18 14:13:33 +00:00
*/
weekNumber?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the week label container's DOM element.
2024-04-18 14:13:33 +00:00
*/
weekLabelContainer?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the day cell's DOM element.
2024-04-18 14:13:33 +00:00
*/
dayCell?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the day's DOM element.
2024-04-18 14:13:33 +00:00
*/
day?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the month view's DOM element.
2024-04-18 14:13:33 +00:00
*/
monthView?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the month's DOM element.
2024-04-18 14:13:33 +00:00
*/
month?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the year view's DOM element.
2024-04-18 14:13:33 +00:00
*/
yearView?: DatePickerPassThroughOptionType;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the year's DOM element.
2024-04-18 14:13:33 +00:00
*/
year?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the time picker's DOM element.
2024-04-18 14:13:33 +00:00
*/
timePicker?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the hour picker's DOM element.
2024-04-18 14:13:33 +00:00
*/
hourPicker?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the hour's DOM element.
2024-04-18 14:13:33 +00:00
*/
hour?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the separator container's DOM element.
2024-04-18 14:13:33 +00:00
*/
separatorContainer?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the separator's DOM element.
2024-04-18 14:13:33 +00:00
*/
separator?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the minute picker's DOM element.
2024-04-18 14:13:33 +00:00
*/
minutePicker?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the minute's DOM element.
2024-04-18 14:13:33 +00:00
*/
minute?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the second picker's DOM element.
2024-04-18 14:13:33 +00:00
*/
secondPicker?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the second's DOM element.
2024-04-18 14:13:33 +00:00
*/
second?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the ampm picker's DOM element.
2024-04-18 14:13:33 +00:00
*/
ampmPicker?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the ampm's DOM element.
2024-04-18 14:13:33 +00:00
*/
ampm?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the buttonbar's DOM element.
2024-04-18 14:13:33 +00:00
*/
buttonbar?: DatePickerPassThroughOptionType;
2024-05-06 15:23:01 +00:00
/**
* Used to pass attributes to the increment button's DOM element.
2024-05-06 15:23:01 +00:00
* @see {@link ButtonPassThroughOptions}
*/
pcIncrementButton?: ButtonPassThroughOptions<DatePickerSharedPassThroughMethodOptions>;
/**
* Used to pass attributes to the decrement button's DOM element.
2024-05-06 15:23:01 +00:00
* @see {@link ButtonPassThroughOptions}
*/
pcDecrementButton?: ButtonPassThroughOptions<DatePickerSharedPassThroughMethodOptions>;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the today button's DOM element.
2024-04-18 14:13:33 +00:00
* @see {@link ButtonPassThroughOptions}
*/
2024-05-06 15:23:01 +00:00
pcTodayButton?: ButtonPassThroughOptions<DatePickerSharedPassThroughMethodOptions>;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the clear button's DOM element.
2024-04-18 14:13:33 +00:00
* @see {@link ButtonPassThroughOptions}
*/
2024-05-06 15:23:01 +00:00
pcClearButton?: ButtonPassThroughOptions<DatePickerSharedPassThroughMethodOptions>;
2024-04-18 14:13:33 +00:00
/**
* Used to pass attributes to the aria selected day's DOM element.
2024-04-18 14:13:33 +00:00
*/
hiddenSelectedDay?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the aria month's DOM element.
2024-04-18 14:13:33 +00:00
*/
hiddenMonth?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the aria year's DOM element.
2024-04-18 14:13:33 +00:00
*/
hiddenYear?: DatePickerPassThroughOptionType;
/**
* Used to pass attributes to the datepicker mask's DOM element.
2024-04-18 14:13:33 +00:00
*/
datepickerMask?: DatePickerPassThroughOptionType;
/**
* Used to manage all lifecycle hooks.
* @see {@link BaseComponent.ComponentHooks}
*/
hooks?: ComponentHooks;
/**
* Used to control Vue Transition API.
*/
transition?: DatePickerPassThroughTransitionType;
}
/**
* Custom passthrough attributes for each DOM elements
*/
export interface DatePickerPassThroughAttributes {
[key: string]: any;
}
/**
* Defines current inline state in DatePicker component.
*/
export interface DatePickerState {
/**
* Current month as a number.
*/
currentMonth: number;
/**
* Current year as a number.
*/
currentYear: number;
/**
* Current hour as a number.
*/
currentHour: number;
/**
* Current minute as a number.
*/
currentMinute: number;
/**
* Current second as a number.
*/
currentSecond: number;
/**
* Current pm state as a boolean.
* @defaultValue false
*/
pm: boolean;
/**
* Current focused state as a boolean.
* @defaultValue false
*/
focused: boolean;
/**
* Current overlay visible state as a boolean.
* @defaultValue false
*/
overlayVisible: boolean;
/**
* Current view state as a string.
* @defaultValue 'date'
*/
currentView: string;
}
/**
* Defines current date options in DatePicker component.
*/
export interface DatePickerDateContext {
/**
* Current date.
*/
day: number;
/**
* Current month state.
*/
month: number;
/**
* Current year state.
*/
year: number;
/**
* Current today state of the calendar's day.
*/
today: boolean;
/**
* Selectable state of the day.
*/
selectable: boolean;
}
/**
* Defines current options in DatePicker component.
*/
export interface DatePickerContext {
/**
* Current date.
*/
date: DatePickerDateContext;
/**
* Current today state of the calendar's day.
* @defaultValue false
*/
today: boolean;
/**
* Current other month state of the calendar's day.
*/
otherMonth: boolean;
/**
* Current selected state of the calendar's day or month or year.
* @defaultValue false
*/
selected: boolean;
/**
* Current disabled state of the calendar's day or month or year.
* @defaultValue false
*/
disabled: boolean;
/**
* Current month state.
*/
month: DatePickerMonthOptions;
/**
* Current month index state.
*/
monthIndex: number;
/**
* Current year state.
*/
year: DatePickerYearOptions;
}
/**
* Defines current month options.
*/
export interface DatePickerMonthOptions {
/**
* Month value.
*/
value: string;
/**
* Selectable state of the month.
*/
selectable: boolean;
}
/**
* Defines current year options.
*/
export interface DatePickerYearOptions {
/**
* Year value.
*/
value: number;
/**
* Selectable state of the month.
*/
selectable: boolean;
}
/**
* Defines valid properties in DatePicker component.
*/
export interface DatePickerProps {
/**
* Value of the component.
* @defaultValue null
*/
modelValue?: Date | Array<Date> | Array<Date | null> | undefined | null;
/**
* Defines the quantity of the selection.
* @defaultValue single
*/
selectionMode?: 'single' | 'multiple' | 'range' | undefined;
/**
* Format of the date. Defaults to PrimeVue Locale configuration.
*/
dateFormat?: string | undefined;
/**
* When enabled, displays the datepicker as inline instead of an overlay.
* @defaultValue false
*/
inline?: boolean | undefined;
/**
* Whether to display dates in other months (non-selectable) at the start or end of the current month. To make these days selectable use the selectOtherMonths option.
* @defaultValue true
*/
showOtherMonths?: boolean | undefined;
/**
* Whether days in other months shown before or after the current month are selectable. This only applies if the showOtherMonths option is set to true.
* @defaultValue false
*/
selectOtherMonths?: boolean | undefined;
/**
* When enabled, displays a button with icon next to input.
* @defaultValue false
*/
showIcon?: boolean | undefined;
/**
* Icon position of the component. This only applies if the showIcon option is set to true.
* @defaultValue 'button'
*/
iconDisplay?: 'button' | 'input' | undefined;
/**
* Icon of the datepicker button.
* @deprecated since v3.27.0. Use 'dropdownicon' slot.
*/
icon?: string | undefined;
/**
* Icon to show in the previous button.
2024-05-27 08:48:42 +00:00
* @deprecated since v3.27.0. Use 'previcon' slot.
2024-04-18 14:13:33 +00:00
*/
2024-05-27 08:48:42 +00:00
prevIcon?: string | undefined;
2024-04-18 14:13:33 +00:00
/**
* Icon to show in the next button.
* @deprecated since v3.27.0. Use 'nexticon' slot.
*/
nextIcon?: string | undefined;
/**
* Icon to show in each of the increment buttons.
* @deprecated since v3.27.0. Use 'incrementicon' slot.
*/
incrementIcon?: string | undefined;
/**
* Icon to show in each of the decrement buttons.
* @deprecated since v3.27.0. Use 'decrementicon' slot.
*/
decrementIcon?: string | undefined;
/**
* Number of months to display.
* @defaultValue 1
*/
numberOfMonths?: number | undefined;
/**
* An array of options for responsive design.
*/
responsiveOptions?: DatePickerResponsiveOptions[];
/**
* The breakpoint to define the maximum width boundary for datepicker panel.
* @defaultValue 769px
*/
breakpoint?: string | undefined;
/**
* Type of view to display.
* @defaultValue date
*/
view?: 'date' | 'month' | 'year' | undefined;
/**
* Whether the month should be rendered as a dropdown instead of text.
*
* @deprecated since version 3.9.0, Navigator is always on.
* @defaultValue false
*/
monthNavigator?: boolean | undefined;
/**
* Whether the year should be rendered as a dropdown instead of text.
*
* @deprecated since version 3.9.0, Navigator is always on.
* @defaultValue false
*/
yearNavigator?: boolean | undefined;
/**
* The range of years displayed in the year drop-down in (nnnn:nnnn) format such as (2000:2020).
*
* @deprecated since version 3.9.0, Years are based on decades by default.
* @defaultValue false
*/
yearRange?: string | undefined;
/**
* The minimum selectable date.
*/
minDate?: Date | undefined;
/**
* The maximum selectable date.
*/
maxDate?: Date | undefined;
/**
* Array with dates to disable.
*/
disabledDates?: Date[] | undefined;
/**
* Array with disabled weekday numbers.
*/
disabledDays?: number[] | undefined;
/**
* Maximum number of selectable dates in multiple mode.
*/
maxDateCount?: number | undefined;
/**
* When disabled, datepicker will not be visible with input focus.
* @defaultValue true
*/
showOnFocus?: boolean | undefined;
/**
* Whether to automatically manage layering.
* @defaultValue true
*/
autoZIndex?: boolean | undefined;
/**
* Base zIndex value to use in layering.
* @defaultValue 0
*/
baseZIndex?: number | undefined;
/**
* Whether to display today and clear buttons at the footer.
* @defaultValue false
*/
showButtonBar?: boolean | undefined;
/**
* The cutoff year for determining the century for a date.
* @defaultValue +10
*/
shortYearCutoff?: string | undefined;
/**
* Whether to display timepicker.
* @defaultValue false
*/
showTime?: boolean | undefined;
/**
* Whether to display timepicker only.
* @defaultValue false
*/
timeOnly?: boolean | undefined;
/**
* Specifies hour format.
* @defaultValue 24
*/
hourFormat?: '12' | '24' | undefined;
/**
* Hours to change per step.
* @defaultValue 1
*/
stepHour?: number | undefined;
/**
* Minutes to change per step.
* @defaultValue 1
*/
stepMinute?: number | undefined;
/**
* Seconds to change per step.
* @defaultValue 1
*/
stepSecond?: number | undefined;
/**
* Whether to show the seconds in time picker.
* @defaultValue false
*/
showSeconds?: boolean | undefined;
/**
* Whether to hide the overlay on date selection when showTime is enabled.
* @defaultValue false
*/
hideOnDateTimeSelect?: boolean | undefined;
/**
* Whether to hide the overlay on date selection is completed when selectionMode is range.
* @defaultValue false
*/
hideOnRangeSelection?: boolean | undefined;
/**
* Separator of time selector.
* @defaultValue :
*/
timeSeparator?: string | undefined;
/**
* When enabled, datepicker will show week numbers.
* @defaultValue false
*/
showWeek?: boolean | undefined;
/**
* Whether to allow entering the date manually via typing.
* @defaultValue true
*/
manualInput?: boolean | undefined;
/**
* When present, it specifies that the component should have invalid state style.
* @defaultValue false
*/
invalid?: boolean | undefined;
/**
* When present, it specifies that the component should be disabled.
* @defaultValue false
*/
disabled?: boolean | undefined;
/**
* Specifies the input variant of the component.
* @defaultValue outlined
*/
variant?: 'outlined' | 'filled' | undefined;
/**
* When present, it specifies that an input field is read-only.
* @defaultValue false
*/
readonly?: boolean | undefined;
/**
* Placeholder text for the input.
*/
placeholder?: string | undefined;
/**
* A valid query selector or an HTMLElement to specify where the overlay gets attached.
* @defaultValue body
*/
appendTo?: HintedString<'body' | 'self'> | undefined | HTMLElement;
/**
* Identifier of the element.
*/
id?: string | undefined;
/**
* Identifier of the underlying input element.
*/
inputId?: string | undefined;
/**
* Inline style of the input field.
*/
inputStyle?: object | undefined;
/**
* Style class of the input field.
*/
inputClass?: string | object | undefined;
/**
* Inline style of the overlay panel.
*/
panelStyle?: object | undefined;
/**
* Style class of the overlay panel.
*/
panelClass?: string | object | undefined;
/**
* Used to pass all properties of the ButtonProps to the today button component.
* @type {ButtonProps}
* @defaultValue { severity: 'secondary', text: true, size: 'small' }
*/
todayButtonProps?: object | undefined;
/**
* Used to pass all properties of the ButtonProps to the clear button component.
* @type {ButtonProps}
* @defaultValue { severity: 'secondary', text: true, size: 'small' }
*/
clearButtonProps?: object | undefined;
/**
* Used to pass all properties of the ButtonProps to the navigator button component.
* @type {ButtonProps}
* @defaultValue { severity: 'secondary', text: true }
*/
navigatorButtonProps?: object | undefined;
/**
* Used to pass all properties of the ButtonProps to the timepicker button component.
* @type {ButtonProps}
* @defaultValue { severity: 'secondary', text: true }
*/
timepickerButtonProps?: object | undefined;
/**
* Establishes relationships between the component and label(s) where its value should be one or more element IDs.
*/
ariaLabelledby?: string | undefined;
/**
* Establishes a string value that labels the component.
*/
ariaLabel?: string | undefined;
/**
* It generates scoped CSS variables using design tokens for the component.
*/
dt?: DesignToken<any>;
/**
* Used to pass attributes to DOM elements inside the component.
* @type {DatePickerPassThroughOptions}
*/
pt?: PassThrough<DatePickerPassThroughOptions>;
/**
* Used to configure passthrough(pt) options of the component.
* @type {PassThroughOptions}
*/
ptOptions?: PassThroughOptions;
/**
* When enabled, it removes component related styles in the core.
* @defaultValue false
*/
unstyled?: boolean;
}
/**
* Defines valid options of the date slot in DatePicker component.
*/
export interface DatePickerDateSlotOptions {
/**
* Current date.
*/
day: number;
/**
* Current month state.
*/
month: number;
/**
* Current year state.
*/
year: number;
/**
* Current today state of the calendar's day.
*/
today: boolean;
/**
* Selectable state of the day.
*/
selectable: boolean;
}
/**
* Defines valid slots in DatePicker component.
*/
export interface DatePickerSlots {
/**
* Custom header template of panel.
*/
header(): VNode[];
/**
* Custom footer template of panel.
*/
footer(): VNode[];
/**
* Custom date template.
*/
date(scope: {
/**
* Value of the component.
*/
date: DatePickerDateSlotOptions;
}): VNode[];
/**
* Custom decade template.
*/
decade(scope: {
/**
* An array containing the start and and year of a decade to display at header of the year picker.
*/
years: string[] | undefined;
}): VNode[];
/**
* Custom week header label template.
*/
weekheaderlabel(): VNode[];
/**
* Custom week label template.
* @param {Object} scope - weeklabel slot's params.
*/
weeklabel(scope: {
/**
* Number of the week
*/
weekNumber: number;
}): VNode[];
/**
* Custom dropdown icon template.
* @param {Object} scope - dropdown icon slot's params.
*/
dropdownicon(scope: {
/**
* Style class of the dropdown icon
*/
class: any;
}): VNode[];
/**
* Custom input icon template.
* @param {Object} scope - input icon slot's params.
*/
inputicon(scope: {
/**
* Style class of the input icon
*/
class: any;
/**
* Click callback
*/
clickCallback: () => void;
}): VNode[];
/**
* Custom previous icon template.
* @param {Object} scope - previous icon slot's params.
*/
2024-05-27 08:48:42 +00:00
previcon(scope: {
2024-04-18 14:13:33 +00:00
/**
* Style class of the previous icon
*/
class: any;
}): VNode[];
/**
* Custom next icon template.
* @param {Object} scope - next icon slot's params.
*/
nexticon(scope: {
/**
* Style class of the next icon
*/
class: any;
}): VNode[];
/**
* Custom increment icon template.
* @param {Object} scope - increment icon slot's params.
*/
incrementicon(scope: {
/**
* Style class of the increment icon
*/
class: any;
}): VNode[];
/**
* Custom decrement icon template.
* @param {Object} scope - decrement icon slot's params.
*/
decrementicon(scope: {
/**
* Style class of the decrement icon
*/
class: any;
}): VNode[];
/**
* Custom dropdown button template.
*/
dropdownbutton(scope: {
/**
* Toggle function.
* @param {Event} event - Browser event
*/
toggleCallback: (event: Event) => void;
}): VNode[];
}
/**
* Defines valid emits in DatePicker component.
*/
2024-05-16 14:05:43 +00:00
export interface DatePickerEmitsOptions {
2024-04-18 14:13:33 +00:00
/**
* Emitted when the value changes.
* @param {string | Date | string[] | Date[] | undefined} value - New value.
*/
'update:modelValue'(value: Date | Array<Date> | Array<Date | null> | undefined | null): void;
/**
* Callback to invoke when input field is being typed.
* @param {Event} event - Browser event
*/
input(event: Event): void;
/**
* Callback to invoke when a date is selected.
* @param {Date} value - Selected value.
*/
'date-select'(value: Date): void;
/**
* Callback to invoke when datepicker panel is shown.
*/
show(): void;
/**
* Callback to invoke when datepicker panel is hidden.
*/
hide(): void;
/**
* Callback to invoke when today button is clicked.
* @param {Date} date - Today as a date instance.
*/
'today-click'(date: Date): void;
/**
* Callback to invoke when clear button is clicked.
* @param {Event} event - Browser event.
*/
'clear-click'(event: Event): void;
/**
* Callback to invoke when a month is changed using the navigators.
* @param {DatePickerMonthChangeEvent} event - Custom month change event.
*/
'month-change'(event: DatePickerMonthChangeEvent): void;
/**
* Callback to invoke when a year is changed using the navigators.
* @param {DatePickerYearChangeEvent} event - Custom year change event.
*/
'year-change'(event: DatePickerYearChangeEvent): void;
/**
* Callback to invoke on focus of input field.
* @param {Event} event - Focus event
*/
focus(event: Event): void;
/**
* Callback to invoke on blur of input field.
* @param {DatePickerBlurEvent} event - Blur event
*/
blur(event: DatePickerBlurEvent): void;
/**
* Callback to invoke when a key is pressed.
*/
keydown(event: Event): void;
}
export declare type DatePickerEmits = EmitFn<DatePickerEmitsOptions>;
2024-04-18 14:13:33 +00:00
/**
* **PrimeVue - DatePicker**
*
* _DatePicker is a form component to work with dates._
*
* [Live Demo](https://www.primevue.org/calendar/)
* --- ---
* ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png)
*
* @group Component
*
2024-04-18 14:13:33 +00:00
*/
declare const DatePicker: DefineComponent<DatePickerProps, DatePickerSlots, DatePickerEmits>;
2024-04-18 14:13:33 +00:00
declare module 'vue' {
export interface GlobalComponents {
DatePicker: GlobalComponentConstructor<DatePickerProps, DatePickerSlots, DatePickerEmits>;
2024-04-18 14:13:33 +00:00
}
}
export default DatePicker;