import { App } from 'vue'; declare const OSelect: { new (...args: any[]): import('vue').CreateComponentPublicInstanceWithMixins; }; defaultValue: { type: import('vue').PropType; }; size: { type: import('vue').PropType; }; round: { type: import('vue').PropType; }; color: { type: import('vue').PropType; default: string; }; variant: { type: import('vue').PropType; default: string; }; placeholder: { type: StringConstructor; }; multiple: { type: BooleanConstructor; }; maxTagCount: { type: NumberConstructor; }; clearable: { type: BooleanConstructor; }; disabled: { type: BooleanConstructor; }; trigger: { type: import('vue').PropType; default: string; }; optionPosition: { type: import('vue').PropType; default: string; }; optionWidthMode: { type: import('vue').PropType; default: string; }; optionWrapClass: { type: import('vue').PropType>; }; unmountOnHide: { type: BooleanConstructor; default: boolean; }; transition: { type: StringConstructor; }; loading: { type: BooleanConstructor; }; beforeSelect: { type: import('vue').PropType<(value: string | number, currentValue: import('./types').SelectValueT) => Promise | boolean | string | number>; }; beforeOptionsShow: { type: import('vue').PropType<() => Promise | boolean>; }; beforeOptionsHide: { type: import('vue').PropType<() => Promise | boolean>; }; optionsWrapper: { type: import('vue').PropType; default: string; }; foldLabel: { type: import('vue').PropType<(tags: Array) => string>; }; showFoldTags: { type: import('vue').PropType; default: string; }; optionTitle: { type: StringConstructor; }; noResponsive: { type: BooleanConstructor; }; }>> & Readonly<{ onClear?: ((evt: Event) => any) | undefined; onChange?: ((value: import('./types').SelectValueT) => any) | undefined; "onUpdate:modelValue"?: ((value: import('./types').SelectValueT) => any) | undefined; "onOptions-visible-change"?: ((value: boolean) => any) | undefined; }>, { selectRef: import('vue').Ref; isSelecting: import('vue').Ref; }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & { clear: (evt: Event) => any; change: (value: import('./types').SelectValueT) => any; "update:modelValue": (value: import('./types').SelectValueT) => any; "options-visible-change": (value: boolean) => any; }, import('vue').PublicProps, { color: "normal" | "primary" | "success" | "warning" | "danger"; disabled: boolean; multiple: boolean; trigger: "none" | "click" | "contextmenu" | "focus" | "click-outclick" | "hover" | "hover-outclick"; unmountOnHide: boolean; variant: "solid" | "outline" | "text"; loading: boolean; noResponsive: boolean; clearable: boolean; optionPosition: "left" | "right" | "top" | "bottom" | "br" | "rt" | "tr" | "rb" | "tl" | "bl" | "lt" | "lb"; optionWidthMode: "width" | "auto" | "min-width"; optionsWrapper: string | HTMLElement | null; showFoldTags: boolean | "click" | "hover"; }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, any, any, import('vue').ComponentProvideOptions, { P: {}; B: {}; D: {}; C: {}; M: {}; Defaults: {}; }, Readonly; }; defaultValue: { type: import('vue').PropType; }; size: { type: import('vue').PropType; }; round: { type: import('vue').PropType; }; color: { type: import('vue').PropType; default: string; }; variant: { type: import('vue').PropType; default: string; }; placeholder: { type: StringConstructor; }; multiple: { type: BooleanConstructor; }; maxTagCount: { type: NumberConstructor; }; clearable: { type: BooleanConstructor; }; disabled: { type: BooleanConstructor; }; trigger: { type: import('vue').PropType; default: string; }; optionPosition: { type: import('vue').PropType; default: string; }; optionWidthMode: { type: import('vue').PropType; default: string; }; optionWrapClass: { type: import('vue').PropType>; }; unmountOnHide: { type: BooleanConstructor; default: boolean; }; transition: { type: StringConstructor; }; loading: { type: BooleanConstructor; }; beforeSelect: { type: import('vue').PropType<(value: string | number, currentValue: import('./types').SelectValueT) => Promise | boolean | string | number>; }; beforeOptionsShow: { type: import('vue').PropType<() => Promise | boolean>; }; beforeOptionsHide: { type: import('vue').PropType<() => Promise | boolean>; }; optionsWrapper: { type: import('vue').PropType; default: string; }; foldLabel: { type: import('vue').PropType<(tags: Array) => string>; }; showFoldTags: { type: import('vue').PropType; default: string; }; optionTitle: { type: StringConstructor; }; noResponsive: { type: BooleanConstructor; }; }>> & Readonly<{ onClear?: ((evt: Event) => any) | undefined; onChange?: ((value: import('./types').SelectValueT) => any) | undefined; "onUpdate:modelValue"?: ((value: import('./types').SelectValueT) => any) | undefined; "onOptions-visible-change"?: ((value: boolean) => any) | undefined; }>, { selectRef: import('vue').Ref; isSelecting: import('vue').Ref; }, {}, {}, {}, { color: "normal" | "primary" | "success" | "warning" | "danger"; disabled: boolean; multiple: boolean; trigger: "none" | "click" | "contextmenu" | "focus" | "click-outclick" | "hover" | "hover-outclick"; unmountOnHide: boolean; variant: "solid" | "outline" | "text"; loading: boolean; noResponsive: boolean; clearable: boolean; optionPosition: "left" | "right" | "top" | "bottom" | "br" | "rt" | "tr" | "rb" | "tl" | "bl" | "lt" | "lb"; optionWidthMode: "width" | "auto" | "min-width"; optionsWrapper: string | HTMLElement | null; showFoldTags: boolean | "click" | "hover"; }>; __isFragment?: never; __isTeleport?: never; __isSuspense?: never; } & import('vue').ComponentOptionsBase; }; defaultValue: { type: import('vue').PropType; }; size: { type: import('vue').PropType; }; round: { type: import('vue').PropType; }; color: { type: import('vue').PropType; default: string; }; variant: { type: import('vue').PropType; default: string; }; placeholder: { type: StringConstructor; }; multiple: { type: BooleanConstructor; }; maxTagCount: { type: NumberConstructor; }; clearable: { type: BooleanConstructor; }; disabled: { type: BooleanConstructor; }; trigger: { type: import('vue').PropType; default: string; }; optionPosition: { type: import('vue').PropType; default: string; }; optionWidthMode: { type: import('vue').PropType; default: string; }; optionWrapClass: { type: import('vue').PropType>; }; unmountOnHide: { type: BooleanConstructor; default: boolean; }; transition: { type: StringConstructor; }; loading: { type: BooleanConstructor; }; beforeSelect: { type: import('vue').PropType<(value: string | number, currentValue: import('./types').SelectValueT) => Promise | boolean | string | number>; }; beforeOptionsShow: { type: import('vue').PropType<() => Promise | boolean>; }; beforeOptionsHide: { type: import('vue').PropType<() => Promise | boolean>; }; optionsWrapper: { type: import('vue').PropType; default: string; }; foldLabel: { type: import('vue').PropType<(tags: Array) => string>; }; showFoldTags: { type: import('vue').PropType; default: string; }; optionTitle: { type: StringConstructor; }; noResponsive: { type: BooleanConstructor; }; }>> & Readonly<{ onClear?: ((evt: Event) => any) | undefined; onChange?: ((value: import('./types').SelectValueT) => any) | undefined; "onUpdate:modelValue"?: ((value: import('./types').SelectValueT) => any) | undefined; "onOptions-visible-change"?: ((value: boolean) => any) | undefined; }>, { selectRef: import('vue').Ref; isSelecting: import('vue').Ref; }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & { clear: (evt: Event) => any; change: (value: import('./types').SelectValueT) => any; "update:modelValue": (value: import('./types').SelectValueT) => any; "options-visible-change": (value: boolean) => any; }, string, { color: "normal" | "primary" | "success" | "warning" | "danger"; disabled: boolean; multiple: boolean; trigger: "none" | "click" | "contextmenu" | "focus" | "click-outclick" | "hover" | "hover-outclick"; unmountOnHide: boolean; variant: "solid" | "outline" | "text"; loading: boolean; noResponsive: boolean; clearable: boolean; optionPosition: "left" | "right" | "top" | "bottom" | "br" | "rt" | "tr" | "rb" | "tl" | "bl" | "lt" | "lb"; optionWidthMode: "width" | "auto" | "min-width"; optionsWrapper: string | HTMLElement | null; showFoldTags: boolean | "click" | "hover"; }, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & (new () => { $slots: any; }) & { install(app: App): void; }; export { OSelect }; export * from './types';