/** * @file Cascader * @author fex */ /// import React from 'react'; import { Option, Options } from './Select'; import type { OptionsControlProps } from 'amis-core'; export type CascaderOption = { text?: string; value?: string | number; valueField?: string; color?: string; disabled?: boolean; children?: Options; className?: string; [key: string]: any; }; export interface CascaderProps extends OptionsControlProps { cascade?: boolean; noResultsText?: string; withChildren?: boolean; onlyChildren?: boolean; hideNodePathLabel?: boolean; mobileUI?: boolean; value?: (number | string)[]; activeColor?: string; optionRender?: ({ option, selected }: { option: CascaderOption; selected: boolean; }) => React.ReactNode; onClose?: () => void; onConfirm?: (param: any) => void; multiple?: boolean; } export type CascaderTab = { options: Options; }; export interface CascaderState { selectedOptions: Options; tabs: Array<{ options: Options; }>; disableConfirm: boolean; activePaths: CascaderOption[]; } export declare class Cascader extends React.Component { static defaultProps: { labelField: string; valueField: string; }; tabsRef: React.RefObject; tabRef: React.RefObject; constructor(props: CascaderProps); componentDidMount(): void; getOptionParent(option: Option): any; dealParentSelect(option: Option, selectedOptions: Options): Options; flattenTreeWithLeafNodes(option: Option): any[]; adjustOptionSelect(option: Option): boolean; getOnlyChildrenSelect(option: Option, selectedOptions?: Option[]): boolean | undefined; getSelectedChildNum(option: Option): number; dealOptionDisable(selectedOptions: Options): void; dealChildrenSelect(option: Option, selectedOptions: Options): Options; getParentTree: (option: Option, arr: Options) => Options; onSelect(option: CascaderOption, tabIndex: number): void; handleExpand(option: Option, tabIndex: number): void; getSubmitOptions(selectedOptions: Options): Options; confirm(): void; getSelectedOptions(): Option[]; renderOption(option: CascaderOption, tabIndex: number): React.JSX.Element; renderOptions(options: Options, tabIndex: number): React.JSX.Element; renderTabs(): React.JSX.Element; render(): React.JSX.Element; } declare const _default: { new (props: Omit & import("packages/amis-core/lib/theme").ThemeOuterProps): { ref: any; childRef(ref: any): void; getWrappedInstance(): any; render(): React.JSX.Element; context: unknown; setState(state: {} | ((prevState: Readonly<{}>, props: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void; forceUpdate(callback?: (() => void) | undefined): void; readonly props: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>; state: Readonly<{}>; refs: { [key: string]: React.ReactInstance; }; componentDidMount?(): void; shouldComponentUpdate?(nextProps: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>, nextState: Readonly<{}>, nextContext: any): boolean; componentWillUnmount?(): void; componentDidCatch?(error: Error, errorInfo: React.ErrorInfo): void; getSnapshotBeforeUpdate?(prevProps: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>, prevState: Readonly<{}>): any; componentDidUpdate?(prevProps: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>, prevState: Readonly<{}>, snapshot?: any): void; componentWillMount?(): void; UNSAFE_componentWillMount?(): void; componentWillReceiveProps?(nextProps: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>, nextContext: any): void; UNSAFE_componentWillReceiveProps?(nextProps: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>, nextContext: any): void; componentWillUpdate?(nextProps: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>, nextState: Readonly<{}>, nextContext: any): void; UNSAFE_componentWillUpdate?(nextProps: Readonly & import("packages/amis-core/lib/theme").ThemeOuterProps>, nextState: Readonly<{}>, nextContext: any): void; }; displayName: string; contextType: React.Context; ComposedComponent: React.ComponentType; } & import("hoist-non-react-statics").NonReactStatics & { ComposedComponent: typeof Cascader; }; export default _default;