2021-08-17 06:36:46 +00:00
|
|
|
/**
|
|
|
|
* 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 type { ComputedRef, InjectionKey, PropType } from 'vue';
|
|
|
|
import { inject } from 'vue';
|
|
|
|
import { computed } from 'vue';
|
|
|
|
import { defineComponent, provide } from 'vue';
|
|
|
|
import type { VueNode } from '../_util/type';
|
|
|
|
import type {
|
|
|
|
IconType,
|
|
|
|
Key,
|
|
|
|
DataEntity,
|
|
|
|
EventDataNode,
|
|
|
|
NodeInstance,
|
|
|
|
DataNode,
|
|
|
|
Direction,
|
|
|
|
} from './interface';
|
|
|
|
|
|
|
|
export type NodeMouseEventParams = {
|
|
|
|
event: MouseEvent;
|
|
|
|
node: EventDataNode;
|
|
|
|
};
|
|
|
|
export type NodeDragEventParams = {
|
|
|
|
event: MouseEvent;
|
|
|
|
node: EventDataNode;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type NodeMouseEventHandler = (e: MouseEvent, node: EventDataNode) => void;
|
|
|
|
export type NodeDragEventHandler = (
|
|
|
|
e: MouseEvent,
|
|
|
|
node: NodeInstance,
|
|
|
|
outsideTree?: boolean,
|
|
|
|
) => void;
|
|
|
|
|
|
|
|
export interface TreeContextProps {
|
|
|
|
prefixCls: string;
|
|
|
|
selectable: boolean;
|
|
|
|
showIcon: boolean;
|
|
|
|
icon: IconType;
|
|
|
|
switcherIcon: IconType;
|
|
|
|
draggable: ((node: DataNode) => boolean) | boolean;
|
|
|
|
checkable: boolean | VueNode;
|
|
|
|
checkStrictly: boolean;
|
|
|
|
disabled: boolean;
|
|
|
|
keyEntities: Record<Key, DataEntity>;
|
|
|
|
// for details see comment in Tree.state (Tree.tsx)
|
|
|
|
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: number | null;
|
|
|
|
prefixCls: string;
|
|
|
|
direction: Direction;
|
|
|
|
}) => VueNode;
|
|
|
|
dragOverNodeKey: Key | null;
|
|
|
|
direction: Direction;
|
|
|
|
|
|
|
|
loadData: (treeNode: EventDataNode) => Promise<void>;
|
|
|
|
filterTreeNode: (treeNode: EventDataNode) => boolean;
|
|
|
|
titleRender?: (node: DataNode) => VueNode;
|
|
|
|
|
|
|
|
onNodeClick: NodeMouseEventHandler;
|
|
|
|
onNodeDoubleClick: NodeMouseEventHandler;
|
|
|
|
onNodeExpand: NodeMouseEventHandler;
|
|
|
|
onNodeSelect: NodeMouseEventHandler;
|
|
|
|
onNodeCheck: (e: 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;
|
2021-08-17 14:52:28 +00:00
|
|
|
slots: Record<string, any>;
|
2021-08-17 06:36:46 +00:00
|
|
|
}
|
|
|
|
const TreeContextKey: InjectionKey<ComputedRef<TreeContextProps>> = Symbol('TreeContextKey');
|
|
|
|
|
|
|
|
export const TreeContext = defineComponent({
|
2021-08-17 14:03:49 +00:00
|
|
|
name: 'TreeContext',
|
2021-08-17 06:36:46 +00:00
|
|
|
props: {
|
|
|
|
value: { type: Object as PropType<TreeContextProps> },
|
|
|
|
},
|
|
|
|
setup(props, { slots }) {
|
|
|
|
provide(
|
|
|
|
TreeContextKey,
|
|
|
|
computed(() => props.value),
|
|
|
|
);
|
2021-08-17 14:03:49 +00:00
|
|
|
return () => slots.default?.();
|
2021-08-17 06:36:46 +00:00
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
export const useInjectTreeContext = () => {
|
|
|
|
return inject(
|
|
|
|
TreeContextKey,
|
|
|
|
computed(() => ({} as TreeContextProps)),
|
|
|
|
);
|
|
|
|
};
|