element-plus
Version:
A Component Library for Vue 3
50 lines (49 loc) • 1.47 kB
TypeScript
import type { InjectionKey, Ref } from 'vue';
interface SelectGroupContext {
disabled: boolean;
}
export interface QueryChangeCtx {
query: string;
}
export interface SelectContext {
props: {
multiple?: boolean;
multipleLimit?: number;
valueKey?: string;
modelValue?: string | number | unknown | unknown[];
popperClass?: string;
remote?: boolean;
fitInputWidth?: boolean;
};
queryChange: Ref<QueryChangeCtx>;
groupQueryChange: Ref<string>;
selectWrapper: HTMLElement;
cachedOptions: Map<any, any>;
hoverIndex: number;
optionsCount: number;
filteredOptionsCount: number;
options: Map<any, any>;
optionsArray: any[];
selected: any | any[];
setSelected(): void;
onOptionCreate(vm: SelectOptionProxy): void;
onOptionDestroy(key: number | string | Record<string, any>): void;
handleOptionSelect(vm: unknown, byClick: boolean): void;
}
export declare const selectGroupKey: InjectionKey<SelectGroupContext>;
export declare const selectKey: InjectionKey<SelectContext>;
export interface SelectOptionProxy {
value: string | number | Record<string, string>;
label: string | number;
created: boolean;
disabled: boolean;
currentLabel: string;
itemSelected: boolean;
isDisabled: boolean;
select: SelectContext;
hoverItem: () => void;
visible: boolean;
hover: boolean;
selectOptionClick: () => void;
}
export {};