1 | import * as React from "react";
|
2 | import { Props } from "../../common/props";
|
3 | import { TreeNodeInfo } from "./treeNode";
|
4 | export declare type TreeEventHandler<T = {}> = (node: TreeNodeInfo<T>, nodePath: number[], e: React.MouseEvent<HTMLElement>) => void;
|
5 | export declare type TreeProps<T = {}> = ITreeProps<T>;
|
6 |
|
7 | export interface ITreeProps<T = {}> extends Props {
|
8 | |
9 |
|
10 |
|
11 | contents: Array<TreeNodeInfo<T>>;
|
12 | |
13 |
|
14 |
|
15 | onNodeClick?: TreeEventHandler<T>;
|
16 | |
17 |
|
18 |
|
19 | onNodeCollapse?: TreeEventHandler<T>;
|
20 | |
21 |
|
22 |
|
23 | onNodeContextMenu?: TreeEventHandler<T>;
|
24 | |
25 |
|
26 |
|
27 |
|
28 |
|
29 | onNodeDoubleClick?: TreeEventHandler<T>;
|
30 | |
31 |
|
32 |
|
33 | onNodeExpand?: TreeEventHandler<T>;
|
34 | |
35 |
|
36 |
|
37 | onNodeMouseEnter?: TreeEventHandler<T>;
|
38 | |
39 |
|
40 |
|
41 | onNodeMouseLeave?: TreeEventHandler<T>;
|
42 | }
|
43 | export declare class Tree<T = {}> extends React.Component<TreeProps<T>> {
|
44 | static displayName: string;
|
45 | static ofType<U>(): new (props: TreeProps<U>) => Tree<U>;
|
46 | static nodeFromPath<U>(path: number[], treeNodes?: Array<TreeNodeInfo<U>>): TreeNodeInfo<U>;
|
47 | private nodeRefs;
|
48 | render(): JSX.Element;
|
49 | |
50 |
|
51 |
|
52 |
|
53 |
|
54 | getNodeContentElement(nodeId: string | number): HTMLElement | undefined;
|
55 | private renderNodes;
|
56 | private handleNodeCollapse;
|
57 | private handleNodeClick;
|
58 | private handleContentRef;
|
59 | private handleNodeContextMenu;
|
60 | private handleNodeDoubleClick;
|
61 | private handleNodeExpand;
|
62 | private handleNodeMouseEnter;
|
63 | private handleNodeMouseLeave;
|
64 | private handlerHelper;
|
65 | }
|