UNPKG

2.96 kBTypeScriptView Raw
1import * as React from 'react';
2import type { BaseSelectRef } from 'rc-select';
3import type { TreeSelectProps as RcTreeSelectProps } from 'rc-tree-select';
4import { SHOW_ALL, SHOW_CHILD, SHOW_PARENT, TreeNode } from 'rc-tree-select';
5import type { BaseOptionType, DefaultOptionType } from 'rc-tree-select/lib/TreeSelect';
6import type { SelectCommonPlacement } from '../_util/motion';
7import type { InputStatus } from '../_util/statusUtils';
8import type { Variant } from '../config-provider';
9import type { SizeType } from '../config-provider/SizeContext';
10import type { TreeProps } from '../tree';
11import type { SwitcherIcon } from '../tree/Tree';
12type RawValue = string | number;
13export interface LabeledValue {
14 key?: string;
15 value: RawValue;
16 label: React.ReactNode;
17}
18export type SelectValue = RawValue | RawValue[] | LabeledValue | LabeledValue[];
19export interface TreeSelectProps<ValueType = any, OptionType extends BaseOptionType | DefaultOptionType = DefaultOptionType> extends Omit<RcTreeSelectProps<ValueType, OptionType>, 'showTreeIcon' | 'treeMotion' | 'mode' | 'getInputElement' | 'backfill' | 'treeLine' | 'switcherIcon'> {
20 suffixIcon?: React.ReactNode;
21 size?: SizeType;
22 disabled?: boolean;
23 placement?: SelectCommonPlacement;
24 popupClassName?: string;
25 /** @deprecated Please use `popupClassName` instead */
26 dropdownClassName?: string;
27 /** @deprecated Use `variant` instead. */
28 bordered?: boolean;
29 treeLine?: TreeProps['showLine'];
30 status?: InputStatus;
31 switcherIcon?: SwitcherIcon | RcTreeSelectProps<ValueType, OptionType>['switcherIcon'];
32 rootClassName?: string;
33 [key: `aria-${string}`]: React.AriaAttributes[keyof React.AriaAttributes];
34 /** @deprecated Please use `popupMatchSelectWidth` instead */
35 dropdownMatchSelectWidth?: boolean | number;
36 popupMatchSelectWidth?: boolean | number;
37 /**
38 * @deprecated `showArrow` is deprecated which will be removed in next major version. It will be a
39 * default behavior, you can hide it by setting `suffixIcon` to null.
40 */
41 showArrow?: boolean;
42 /**
43 * @since 5.13.0
44 * @default "outlined"
45 */
46 variant?: Variant;
47}
48declare const TreeSelectRef: <ValueType = any, OptionType extends BaseOptionType | DefaultOptionType = DefaultOptionType>(props: React.PropsWithChildren<TreeSelectProps<ValueType, OptionType>> & React.RefAttributes<BaseSelectRef>) => React.ReactElement;
49type InternalTreeSelectType = typeof TreeSelectRef;
50type CompoundedComponent = InternalTreeSelectType & {
51 displayName?: string;
52 TreeNode: typeof TreeNode;
53 SHOW_ALL: typeof SHOW_ALL;
54 SHOW_PARENT: typeof SHOW_PARENT;
55 SHOW_CHILD: typeof SHOW_CHILD;
56 _InternalPanelDoNotUseOrYouWillBeFired: typeof PurePanel;
57};
58declare const TreeSelect: CompoundedComponent;
59declare const PurePanel: (props: import("../_util/type").AnyObject) => React.JSX.Element;
60export { TreeNode };
61export default TreeSelect;