import * as React from 'react'; import { AbstractSelectProps } from '../select'; export type TreeNode = TreeNodeNormal | TreeNodeSimpleMode; export interface TreeNodeNormal { value: string; /** * @deprecated Please use `title` instead. */ label?: React.ReactNode; title?: React.ReactNode; key: string; isLeaf?: boolean; disabled?: boolean; disableCheckbox?: boolean; selectable?: boolean; children?: TreeNodeNormal[]; } export interface TreeNodeSimpleMode { /* It is possible to change `id` and `pId` prop keys using TreeDataSimpleMode so those keys can be anything */ [key: string]: string | boolean | React.ReactNode; } export interface TreeDataSimpleMode { id?: string; pId?: string; rootPId?: string; } export interface TreeSelectProps extends AbstractSelectProps { value?: string | Array; defaultValue?: string | Array; multiple?: boolean; maxTagCount?: number; onSelect?: (value: any) => void; onChange?: (value: any, label: any) => void; onSearch?: (value: any) => void; searchPlaceholder?: string; dropdownStyle?: React.CSSProperties; treeDefaultExpandAll?: boolean; treeCheckable?: boolean | React.ReactNode; treeDefaultExpandedKeys?: Array; filterTreeNode?: (inputValue: string, treeNode: any) => boolean | boolean; treeNodeFilterProp?: string; treeNodeLabelProp?: string; treeData?: Array; treeDataSimpleMode?: boolean | TreeDataSimpleMode; loadData?: (node: any) => void; showCheckedStrategy?: 'SHOW_ALL' | 'SHOW_PARENT' | 'SHOW_CHILD'; labelInValue?: boolean; treeCheckStrictly?: boolean; getPopupContainer?: (triggerNode: Element) => HTMLElement; }