/** * Webpack has bug for import loop, which is not the same behavior as ES module. * When util.js imports the TreeNode for tree generate will cause treeContextTypes be empty. */ import * as React from 'react'; import { IconType, Key, DataEntity, EventDataNode, NodeInstance, DataNode, Direction, BasicDataNode } from './interface'; import { DraggableConfig } from './Tree'; export type NodeMouseEventParams = { event: React.MouseEvent; node: EventDataNode; }; export type NodeDragEventParams = { event: React.DragEvent; node: EventDataNode; }; export type NodeMouseEventHandler = (e: React.MouseEvent, node: EventDataNode) => void; export type NodeDragEventHandler = (e: React.DragEvent, node: NodeInstance, outsideTree?: boolean) => void; export interface TreeContextProps { prefixCls: string; selectable: boolean; showIcon: boolean; icon: IconType; switcherIcon: IconType; draggable?: DraggableConfig; draggingNodeKey?: React.Key; checkable: boolean | React.ReactNode; checkStrictly: boolean; disabled: boolean; keyEntities: Record>; dropLevelOffset?: number; dropContainerKey: Key | null; dropTargetKey: Key | null; dropPosition: -1 | 0 | 1 | null; indent: number | null; dropIndicatorRender: (props: { dropPosition: -1 | 0 | 1; dropLevelOffset: number; indent: any; prefixCls: any; direction: Direction; }) => React.ReactNode; dragOverNodeKey: Key | null; direction: Direction; loadData: (treeNode: EventDataNode) => Promise; filterTreeNode: (treeNode: EventDataNode) => boolean; titleRender?: (node: any) => React.ReactNode; onNodeClick: NodeMouseEventHandler; onNodeDoubleClick: NodeMouseEventHandler; onNodeExpand: NodeMouseEventHandler; onNodeSelect: NodeMouseEventHandler; onNodeCheck: (e: React.MouseEvent, treeNode: EventDataNode, checked: boolean) => void; onNodeLoad: (treeNode: EventDataNode) => void; onNodeMouseEnter: NodeMouseEventHandler; onNodeMouseLeave: NodeMouseEventHandler; onNodeContextMenu: NodeMouseEventHandler; onNodeDragStart: NodeDragEventHandler; onNodeDragEnter: NodeDragEventHandler; onNodeDragOver: NodeDragEventHandler; onNodeDragLeave: NodeDragEventHandler; onNodeDragEnd: NodeDragEventHandler; onNodeDrop: NodeDragEventHandler; } export declare const TreeContext: React.Context | null>;