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): 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 {};
|