/** * * ListBox is used to select one or more values from a list of items. * * [Live Demo](https://www.primevue.org/listbox/) * * @module listbox * */ import { VNode } from 'vue'; import { ComponentHooks } from '../basecomponent'; import { IconFieldPassThroughOptions } from '../iconfield'; import { InputIconPassThroughOptions } from '../inputicon'; import { InputTextPassThroughOptions } from '../inputtext'; import { PassThroughOptions } from '../passthrough'; import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, HintedString, PassThrough } from '../ts-helpers'; import { VirtualScrollerItemOptions, VirtualScrollerPassThroughOptionType, VirtualScrollerProps } from '../virtualscroller'; export declare type ListboxPassThroughOptionType = ListboxPassThroughAttributes | ((options: ListboxPassThroughMethodOptions) => ListboxPassThroughAttributes | string) | string | null | undefined; /** * Custom passthrough(pt) option method. */ export interface ListboxPassThroughMethodOptions { /** * Defines instance. */ instance: any; /** * Defines valid properties. */ props: ListboxProps; /** * Defines current inline state. */ state: ListboxState; /** * Defines current options. */ context: ListboxContext; /** * Defines valid attributes. */ attrs: any; /** * Defines parent options. */ parent: T; /** * Defines passthrough(pt) options in global config. */ global: object | undefined; } /** * Custom shared passthrough(pt) option method. */ export interface ListboxSharedPassThroughMethodOptions { /** * Defines valid properties. */ props: ListboxProps; /** * Defines current inline state. */ state: ListboxState; } /** * Custom change event. * @see {@link ListboxEmitsOptions.change} */ export interface ListboxChangeEvent { /** * Original event */ originalEvent: Event; /** * Selected option value */ value: any; } /** * Custom double click event. * @see {@link ListboxEmitsOptions.['item-dblclick']} */ export interface ListboxOptionDblClickEvent { /** * Original event */ originalEvent: Event; /** * Selected option value */ value: any; } /** * Custom filter event. * @see {@link ListboxEmitsOptions.filter} */ export interface ListboxFilterEvent { /** * Original event */ originalEvent: Event; /** * Filter value */ value: string; } /** * Custom passthrough(pt) options. * @see {@link ListboxProps.pt} */ export interface ListboxPassThroughOptions { /** * Used to pass attributes to the root's DOM element. */ root?: ListboxPassThroughOptionType; /** * Used to pass attributes to the header's DOM element. */ header?: ListboxPassThroughOptionType; /** * Used to pass attributes to the IconField component. * @see {@link IconFieldPassThroughOptions} */ pcFilterContainer?: IconFieldPassThroughOptions; /** * Used to pass attributes to the InputText component. * @see {@link InputTextPassThroughOptions} */ pcFilter?: InputTextPassThroughOptions; /** * Used to pass attributes to the InputIcon component. * @see {@link InputIconPassThroughOptions} */ pcFilterIconContainer?: InputIconPassThroughOptions; /** * Used to pass attributes to the filter icon's DOM element. */ filterIcon?: ListboxPassThroughOptionType; /** * Used to pass attributes to the list container's DOM element. */ listContainer?: ListboxPassThroughOptionType; /** * Used to pass attributes to the VirtualScroller component. * @see {@link VirtualScrollerPassThroughOptionType} */ virtualScroller?: VirtualScrollerPassThroughOptionType; /** * Used to pass attributes to the list's DOM element. */ list?: ListboxPassThroughOptionType; /** * Used to pass attributes to the option group's DOM element. */ optionGroup?: ListboxPassThroughOptionType; /** * Used to pass attributes to the option's DOM element. */ option?: ListboxPassThroughOptionType; /** * Used to pass attributes to the option check icon's DOM element. */ optionCheckIcon?: ListboxPassThroughOptionType; /** * Used to pass attributes to the option blank icon's DOM element. */ optionBlankIcon?: ListboxPassThroughOptionType; /** * Used to pass attributes to the emptyMessage's DOM element. */ emptyMessage?: ListboxPassThroughOptionType; /** * Used to pass attributes to the hidden first focusable element's DOM element. */ hiddenFirstFocusableEl?: ListboxPassThroughOptionType; /** * Used to pass attributes to the hidden filter result's DOM element. */ hiddenFilterResult?: ListboxPassThroughOptionType; /** * Used to pass attributes to the hidden selected message's DOM element. */ hiddenSelectedMessage?: ListboxPassThroughOptionType; /** * Used to pass attributes to the hidden last focusable element's DOM element. */ hiddenLastFocusableEl?: ListboxPassThroughOptionType; /** * Used to manage all lifecycle hooks. * @see {@link BaseComponent.ComponentHooks} */ hooks?: ComponentHooks; } /** * Custom passthrough attributes for each DOM elements */ export interface ListboxPassThroughAttributes { [key: string]: any; } /** * Defines current inline state in Listbox component. */ export interface ListboxState { /** * Current id state as a string. */ id: string; /** * Current focused state as a boolean. * @defaultValue false */ focused: boolean; /** * Current filter value state as a string. */ filterValue: string; /** * Current focused item index as a number. * @defaultValue -1 */ focusedOptionIndex: number; } /** * Defines current options in Listbox component. */ export interface ListboxContext { /** * Current selection state of the item as a boolean. * @defaultValue false */ selected: boolean; /** * Current focus state of the item as a boolean. * @defaultValue false */ focused: boolean; /** * Current disabled state of the item as a boolean. * @defaultValue false */ disabled: boolean; } /** * Defines valid properties in Listbox component. */ export interface ListboxProps { /** * Value of the component. */ modelValue?: any; /** * An array of selectitems to display as the available options. */ options?: any[] | undefined; /** * Property name or getter function to use as the label of an option. */ optionLabel?: string | ((data: any) => string) | undefined; /** * Property name or getter function to use as the value of an option, defaults to the option itself when not defined. */ optionValue?: string | ((data: any) => any) | undefined; /** * Property name or getter function to use as the disabled flag of an option, defaults to false when not defined. */ optionDisabled?: string | ((data: any) => boolean) | undefined; /** * Property name or getter function to use as the label of an option group. */ optionGroupLabel?: string | ((data: any) => string) | undefined; /** * Property name or getter function that refers to the children options of option group. */ optionGroupChildren?: string | ((data: any) => any[]) | undefined; /** * Inline style of inner list element. */ listStyle?: string | undefined; /** * Height of the viewport, a scrollbar is defined if height of list exceeds this value. * @defaultValue 14rem */ scrollHeight?: string | undefined; /** * When present, it specifies that the component should have invalid state style. * @defaultValue false */ invalid?: boolean | undefined; /** * When specified, disables the component. * @defaultValue false */ disabled?: boolean | undefined; /** * A property to uniquely identify an option. */ dataKey?: string | undefined; /** * When specified, allows selecting multiple values. * @defaultValue false */ multiple?: boolean | undefined; /** * Defines how multiple items can be selected, when true metaKey needs to be pressed to select or unselect an item and when set to false selection of each item can be toggled individually. * On touch enabled devices, metaKeySelection is turned off automatically. * @defaultValue false */ metaKeySelection?: boolean | undefined; /** * When specified, displays a filter input at header. * @defaultValue false */ filter?: boolean | undefined; /** * Placeholder text to show when filter input is empty. */ filterPlaceholder?: string | undefined; /** * Locale to use in filtering. The default locale is the host environment's current locale. */ filterLocale?: string | undefined; /** * Defines the filtering algorithm to use when searching the options. * @defaultValue contains */ filterMatchMode?: HintedString<'contains' | 'startsWith' | 'endsWith'> | undefined; /** * Fields used when filtering the options, defaults to optionLabel. */ filterFields?: string[] | undefined; /** * Whether to use the virtualScroller feature. The properties of VirtualScroller component can be used like an object in it. * @type {VirtualScrollerProps} */ virtualScrollerOptions?: VirtualScrollerProps; /** * Whether to focus on the first visible or selected element. * @defaultValue false */ autoOptionFocus?: boolean | undefined; /** * When enabled, the focused option is selected. * @defaultValue false */ selectOnFocus?: boolean | undefined; /** * When enabled, the focus is placed on the hovered option. * @defaultValue true */ focusOnHover?: boolean | undefined; /** * Whether the selected option will be add highlight class. * @defaultValue true */ highlightOnSelect?: boolean | undefined; /** * Whether the selected option will be shown with a check mark. * @defaultValue false */ checkmark?: boolean | undefined; /** * Text to be displayed in hidden accessible field when filtering returns any results. Defaults to value from PrimeVue locale configuration. * @defaultValue '{0} results are available' */ filterMessage?: string | undefined; /** * Text to be displayed in hidden accessible field when options are selected. Defaults to value from PrimeVue locale configuration. * @defaultValue '{0} items selected' */ selectionMessage?: string | undefined; /** * Text to be displayed in hidden accessible field when any option is not selected. Defaults to value from PrimeVue locale configuration. * @defaultValue No selected item */ emptySelectionMessage?: string | undefined; /** * Text to display when filtering does not return any results. Defaults to value from PrimeVue locale configuration. * @defaultValue No results found */ emptyFilterMessage?: string | undefined; /** * Text to display when there are no options available. Defaults to value from PrimeVue locale configuration. * @defaultValue No results found */ emptyMessage?: string | undefined; /** * Whether to displays rows with alternating colors. * @defaultValue false */ striped?: boolean | undefined; /** * Index of the element in tabbing order. */ tabindex?: number | string | undefined; /** * Icon to display in filter input. */ filterIcon?: string | undefined; /** * Defines a string value that labels an interactive element. */ ariaLabel?: string | undefined; /** * Identifier of the underlying input element. */ ariaLabelledby?: string | undefined; /** * It generates scoped CSS variables using design tokens for the component. */ dt?: DesignToken; /** * Used to pass attributes to DOM elements inside the component. * @type {ListboxPassThroughOptions} */ pt?: PassThrough; /** * 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 slots in Listbox component. */ export interface ListboxSlots { /** * Custom header template. * @param {Object} scope - header slot's params. */ header(scope: { /** * Value of the component */ value: any; /** * Displayed options */ options: any[]; }): VNode[]; /** * Custom footer template. * @param {Object} scope - footer slot's params. */ footer(scope: { /** * Value of the component */ value: any; /** * Displayed options */ options: any[]; }): VNode[]; /** * Custom option template. * @param {Object} scope - option slot's params. */ option(scope: { /** * Option instance */ option: any; /** * Selection state */ selected: boolean; /** * Index of the option */ index: number; }): VNode[]; /** * Custom optiongroup template. * @param {Object} scope - optiongroup slot's params. */ optiongroup(scope: { /** * Option instance */ option: any; /** * Index of the option */ index: number; }): VNode[]; /** * Custom emptyfilter template. */ emptyfilter(): VNode[]; /** * Custom empty template. */ empty(): VNode[]; /** * Custom content template. * @param {Object} scope - content slot's params. */ content(scope: { /** * An array of objects to display for virtualscroller */ items: any; /** * Style class of the component */ styleClass: string; /** * Referance of the content * @param {HTMLElement} el - Element of 'ref' property */ contentRef: (el: any) => void; /** * Options of the items * @param {number} index - Rendered index * @return {VirtualScrollerItemOptions} */ getItemOptions: (index: number) => VirtualScrollerItemOptions; }): VNode[]; /** * Custom loader template. * @param {Object} scope - loader slot's params. */ loader(scope: { /** * Options of the loader items for virtualscroller */ options: any[]; }): VNode[]; /** * Custom filter icon template. * @param {Object} scope - filter icon slot's params. */ filtericon(scope: { /** * Style class of the filter icon */ class: any; }): VNode[]; } /** * Defines valid emits in Listbox component. */ export interface ListboxEmitsOptions { /** * Emitted when the value changes. * @param {*} value - New value. */ 'update:modelValue'(value: any): void; /** * Callback to invoke on value change. * @param {ListboxChangeEvent} event - Custom change event. */ change(event: ListboxChangeEvent): void; /** * Callback to invoke when the component receives focus. * @param {Event} event - Browser event. */ focus(event: Event): void; /** * Callback to invoke when the component loses focus. * @param {Event} event - Browser event. */ blur(event: Event): void; /** * Callback to invoke on filter input. * @param {ListboxFilterEvent} event - Custom filter event. */ filter(event: ListboxFilterEvent): void; /** * Callback to invoke on option double click. * @param {ListboxOptionDblClickEvent} event - Custom option double click event. */ 'item-dblclick'(event: ListboxOptionDblClickEvent): void; /** * Callback to invoke on option double click. * @param {ListboxOptionDblClickEvent} event - Custom option double click event. */ 'option-dblclick'(event: ListboxOptionDblClickEvent): void; } export declare type ListboxEmits = EmitFn; /** * **PrimeVue - Listbox** * * _ListBox is used to select one or more values from a list of items._ * * [Live Demo](https://www.primevue.org/listbox/) * --- --- * ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png) * * @group Component * */ declare const Listbox: DefineComponent; declare module 'vue' { export interface GlobalComponents { Listbox: GlobalComponentConstructor; } } export default Listbox;