@fe6/water-pro
Version:
An enterprise-class UI design language and Vue-based implementation
118 lines (117 loc) • 6.32 kB
TypeScript
/**
* To match accessibility requirement, we always provide an input in the component.
* Other element will not set `tabIndex` to avoid `onBlur` sequence problem.
* For focused select, we set `aria-live="polite"` to update the accessibility content.
*
* ref:
* - keyboard: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/listbox_role#Keyboard_interactions
*
* New api:
* - listHeight
* - listItemHeight
* - component
*
* Remove deprecated api:
* - multiple
* - tags
* - combobox
* - firstActiveValue
* - dropdownMenuStyle
* - openClassName (Not list in api)
*
* Update:
* - `backfill` only support `combobox` mode
* - `combobox` mode not support `labelInValue` since it's meaningless
* - `getInputElement` only support `combobox` mode
* - `onChange` return OptionData instead of ReactNode
* - `filterOption` `onChange` `onSelect` accept OptionData instead of ReactNode
* - `combobox` mode trigger `onChange` will get `undefined` if no `value` match in Option
* - `combobox` mode not support `optionLabelProp`
*/
import { OptionsType as SelectOptionsType } from './interface';
import { SelectProps } from './generate';
import { DefaultValueType } from './interface/generator';
export declare type ExportedSelectProps<ValueType extends DefaultValueType = DefaultValueType> = SelectProps<SelectOptionsType, ValueType>;
declare const Select: import("vue").DefineComponent<Omit<ExportedSelectProps<DefaultValueType>, "children">, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, import("vue").EmitsOptions, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<{
maxTagPlaceholder: any;
dropdownAlign: any;
} & {
class?: string;
style?: import("vue").CSSProperties;
mode?: import("./interface").Mode;
value?: DefaultValueType;
animation?: string;
onFocus?: (event: Event) => void | ((event: Event) => void)[];
onBlur?: (event: Event) => void | ((event: Event) => void)[];
onChange?: (value: DefaultValueType, option: import("./interface").OptionData | import("./interface").OptionGroupData | SelectOptionsType) => void | ((value: DefaultValueType, option: import("./interface").OptionData | import("./interface").OptionGroupData | SelectOptionsType) => void)[];
onKeydown?: (event: Event) => void | ((event: Event) => void)[];
onKeyup?: (event: Event) => void | ((event: Event) => void)[];
onClick?: (event: Event) => void | ((event: Event) => void)[];
onMousedown?: (event: Event) => void | ((event: Event) => void)[];
onMouseenter?: (event: Event) => void | ((event: Event) => void)[];
onMouseleave?: (event: Event) => void | ((event: Event) => void)[];
onSelect?: (value: import("./interface/generator").RawValueType | import("./interface/generator").LabelValueType, option: import("./interface").OptionData | import("./interface").OptionGroupData) => void | ((value: import("./interface/generator").RawValueType | import("./interface/generator").LabelValueType, option: import("./interface").OptionData | import("./interface").OptionGroupData) => void)[];
prefixCls?: string;
direction?: string;
open?: boolean;
disabled?: boolean;
virtual?: boolean;
id?: string;
options?: SelectOptionsType;
defaultActiveFirstOption?: boolean;
notFoundContent?: import("vue").VNodeChild;
menuItemSelectedIcon?: import("./interface").RenderNode;
searchValue?: string;
labelInValue?: boolean;
optionLabelProp?: string;
optionFilterProp?: string;
filterOption?: boolean | import("./interface/generator").FilterFunc<import("./interface").OptionData | import("./interface").OptionGroupData>;
autofocus?: boolean;
tabindex?: number;
removeIcon?: import("vue").VNodeChild;
maxTagCount?: number;
maxTagTextLength?: number;
tokenSeparators?: string[];
tagRender?: (props: import("./interface/generator").CustomTagProps) => import("vue").VNodeChild;
choiceTransitionName?: string;
placeholder?: import("vue").VNodeChild;
showSearch?: boolean;
onInputKeyDown?: (event: Event) => void | ((event: Event) => void)[];
backfill?: boolean;
onSearch?: (value: string) => void | ((value: string) => void)[];
transitionName?: string;
dropdownStyle?: import("vue").CSSProperties;
dropdownClassName?: string;
dropdownMatchSelectWidth?: number | boolean;
dropdownRender?: import("../_util/type").VueNode;
getPopupContainer?: import("./interface").RenderDOMFunc;
showAction?: ("click" | "focus")[];
defaultValue?: DefaultValueType;
inputValue?: string;
autoClearSearchValue?: boolean;
onClear?: void | (() => void)[];
allowClear?: boolean;
clearIcon?: import("vue").VNodeChild;
showArrow?: boolean;
inputIcon?: import("./interface").RenderNode;
defaultOpen?: boolean;
listHeight?: number;
listItemHeight?: number;
loading?: boolean;
getInputElement?: import("vue").VNodeChild | JSX.Element;
onPopupScroll?: (event: Event) => void | ((event: Event) => void)[];
onDropdownVisibleChange?: (open: boolean) => void;
onDeselect?: (value: import("./interface/generator").RawValueType | import("./interface/generator").LabelValueType, option: import("./interface").OptionData | import("./interface").OptionGroupData) => void | ((value: import("./interface/generator").RawValueType | import("./interface/generator").LabelValueType, option: import("./interface").OptionData | import("./interface").OptionGroupData) => void)[];
internalProps?: {
mark?: string;
onClear?: import("./interface/generator").OnClear;
skipTriggerChange?: boolean;
skipTriggerSelect?: boolean;
onRawSelect?: (value: import("./interface/generator").RawValueType, option: import("./interface").OptionData | import("./interface").OptionGroupData, source: import("./interface/generator").SelectSource) => void;
onRawDeselect?: (value: import("./interface/generator").RawValueType, option: import("./interface").OptionData | import("./interface").OptionGroupData, source: import("./interface/generator").SelectSource) => void;
};
}>, {
maxTagPlaceholder: any;
dropdownAlign: any;
}>;
export default Select;