import type { BuildInPlacements } from '@rc-component/trigger/lib/interface'; import type { BaseSelectPropsWithoutPrivate, BaseSelectRef } from 'rc-select'; import type { Placement } from 'rc-select/lib/BaseSelect'; import * as React from 'react'; import Panel from './Panel'; import { SHOW_CHILD, SHOW_PARENT } from './utils/commonUtil'; export interface BaseOptionType { disabled?: boolean; disableCheckbox?: boolean; label?: React.ReactNode; value?: string | number | null; children?: DefaultOptionType[]; } export type DefaultOptionType = BaseOptionType & Record; export interface ShowSearchType { filter?: (inputValue: string, options: OptionType[], fieldNames: FieldNames) => boolean; render?: (inputValue: string, path: OptionType[], prefixCls: string, fieldNames: FieldNames) => React.ReactNode; sort?: (a: OptionType[], b: OptionType[], inputValue: string, fieldNames: FieldNames) => number; matchInputWidth?: boolean; limit?: number | false; } export type ShowCheckedStrategy = typeof SHOW_PARENT | typeof SHOW_CHILD; interface BaseCascaderProps extends Omit { id?: string; prefixCls?: string; fieldNames?: FieldNames; optionRender?: (option: OptionType) => React.ReactNode; children?: React.ReactElement; changeOnSelect?: boolean; displayRender?: (label: string[], selectedOptions?: OptionType[]) => React.ReactNode; checkable?: boolean | React.ReactNode; showCheckedStrategy?: ShowCheckedStrategy; autoClearSearchValue?: boolean; showSearch?: boolean | ShowSearchType; searchValue?: string; onSearch?: (value: string) => void; expandTrigger?: 'hover' | 'click'; options?: OptionType[]; /** @private Internal usage. Do not use in your production. */ dropdownPrefixCls?: string; loadData?: (selectOptions: OptionType[]) => void; /** @deprecated Use `open` instead */ popupVisible?: boolean; /** @deprecated Use `dropdownClassName` instead */ popupClassName?: string; dropdownClassName?: string; dropdownMenuColumnStyle?: React.CSSProperties; /** @deprecated Use `placement` instead */ popupPlacement?: Placement; placement?: Placement; builtinPlacements?: BuildInPlacements; /** @deprecated Use `onDropdownVisibleChange` instead */ onPopupVisibleChange?: (open: boolean) => void; onDropdownVisibleChange?: (open: boolean) => void; expandIcon?: React.ReactNode; loadingIcon?: React.ReactNode; } export interface FieldNames { label?: keyof OptionType; value?: keyof OptionType | ValueField; children?: keyof OptionType; } export type ValueType = keyof OptionType extends ValueField ? unknown extends OptionType['value'] ? OptionType[ValueField] : OptionType['value'] : OptionType[ValueField]; export type GetValueType = false extends Multiple ? ValueType, ValueField>[] : ValueType, ValueField>[][]; export interface CascaderProps extends BaseCascaderProps { checkable?: Multiple; value?: GetValueType; defaultValue?: GetValueType; onChange?: (value: GetValueType, selectOptions: OptionType[]) => void; } export type SingleValueType = (string | number)[]; export type InternalValueType = SingleValueType | SingleValueType[]; export interface InternalFieldNames extends Required { key: string; } export type InternalCascaderProps = Omit & { value?: InternalValueType; defaultValue?: InternalValueType; onChange?: (value: InternalValueType, selectOptions: BaseOptionType[] | BaseOptionType[][]) => void; }; export type CascaderRef = Omit; declare const Cascader: ((props: CascaderProps & { children?: React.ReactNode; } & { ref?: React.Ref | undefined; }) => React.ReactElement) & { displayName?: string | undefined; SHOW_PARENT: typeof SHOW_PARENT; SHOW_CHILD: typeof SHOW_CHILD; Panel: typeof Panel; }; export default Cascader;