From a342e61b9c27fcf45465e02175baee5514da8af2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=BC=A0=E9=91=AB?= Date: Tue, 21 Mar 2023 09:23:00 +0800 Subject: [PATCH] Add preview ref api for Node --- .../src/components/drag-preview-container.tsx | 2 +- .../src/components/provider.tsx | 2 +- .../src/components/row-container.tsx | 4 ++-- .../react-arborist/src/components/tree.tsx | 2 +- packages/react-arborist/src/dnd/drag-hook.ts | 19 ++++++++++++------- .../react-arborist/src/interfaces/tree-api.ts | 3 +-- .../react-arborist/src/types/renderers.ts | 1 + 7 files changed, 19 insertions(+), 14 deletions(-) diff --git a/packages/react-arborist/src/components/drag-preview-container.tsx b/packages/react-arborist/src/components/drag-preview-container.tsx index 1c174fe..56e9076 100644 --- a/packages/react-arborist/src/components/drag-preview-container.tsx +++ b/packages/react-arborist/src/components/drag-preview-container.tsx @@ -1,5 +1,5 @@ import { useDragLayer } from "react-dnd"; -import { useDndContext, useTreeApi } from "../context"; +import { useTreeApi } from "../context"; import { DefaultDragPreview } from "./default-drag-preview"; export function DragPreviewContainer() { diff --git a/packages/react-arborist/src/components/provider.tsx b/packages/react-arborist/src/components/provider.tsx index 60b8899..532309c 100644 --- a/packages/react-arborist/src/components/provider.tsx +++ b/packages/react-arborist/src/components/provider.tsx @@ -57,7 +57,7 @@ export function TreeProvider({ useMemo(() => { updateCount.current += 1; api.update(treeProps); - }, [...Object.values(treeProps), state.nodes.open]); + }, [...Object.values(treeProps), state.nodes.open, state.dnd.parentId]); /* Expose the tree api */ useImperativeHandle(imperativeHandle, () => api); diff --git a/packages/react-arborist/src/components/row-container.tsx b/packages/react-arborist/src/components/row-container.tsx index 2ebcd43..baacfe0 100644 --- a/packages/react-arborist/src/components/row-container.tsx +++ b/packages/react-arborist/src/components/row-container.tsx @@ -35,7 +35,7 @@ export const RowContainer = React.memo(function RowContainer({ const node = useFreshNode(index); const el = useRef(null); - const dragRef = useDragHook(node); + const { dragRef, previewRef } = useDragHook(node); const dropRef = useDropHook(el, node); const innerRef = useCallback( (n: any) => { @@ -76,7 +76,7 @@ export const RowContainer = React.memo(function RowContainer({ return ( - + ); }); diff --git a/packages/react-arborist/src/components/tree.tsx b/packages/react-arborist/src/components/tree.tsx index 82601a7..7ab8240 100644 --- a/packages/react-arborist/src/components/tree.tsx +++ b/packages/react-arborist/src/components/tree.tsx @@ -18,7 +18,7 @@ function TreeComponent( - + { props.renderDragPreview && } ); } diff --git a/packages/react-arborist/src/dnd/drag-hook.ts b/packages/react-arborist/src/dnd/drag-hook.ts index 8e8bb7c..5715f4f 100644 --- a/packages/react-arborist/src/dnd/drag-hook.ts +++ b/packages/react-arborist/src/dnd/drag-hook.ts @@ -1,4 +1,4 @@ -import { useEffect } from "react"; +import { useEffect, useMemo } from "react"; import { ConnectDragSource, useDrag } from "react-dnd"; import { getEmptyImage } from "react-dnd-html5-backend"; import { useTreeApi } from "../context"; @@ -9,7 +9,7 @@ import { actions as dnd } from "../state/dnd-slice"; import { safeRun } from "../utils"; import { ROOT_ID } from "../data/create-root"; -export function useDragHook(node: NodeApi): ConnectDragSource { +export function useDragHook(node: NodeApi) { const tree = useTreeApi(); const ids = tree.selectedIds; const [_, ref, preview] = useDrag( @@ -42,10 +42,15 @@ export function useDragHook(node: NodeApi): ConnectDragSource { }), [ids, node] ); + + useEffect(() => { + if (tree.renderDragPreview) { + preview(getEmptyImage()); + } + }, []); - useEffect(() => { - preview(getEmptyImage()); - }, [preview]); - - return ref; + return { + dragRef: ref, + previewRef: preview, + }; } diff --git a/packages/react-arborist/src/interfaces/tree-api.ts b/packages/react-arborist/src/interfaces/tree-api.ts index e9b6f29..39e51bc 100644 --- a/packages/react-arborist/src/interfaces/tree-api.ts +++ b/packages/react-arborist/src/interfaces/tree-api.ts @@ -15,7 +15,6 @@ import { createRoot, ROOT_ID } from "../data/create-root"; import { actions as visibility } from "../state/open-slice"; import { actions as selection } from "../state/selection-slice"; import { actions as dnd } from "../state/dnd-slice"; -import { DefaultDragPreview } from "../components/default-drag-preview"; import { DefaultContainer } from "../components/default-container"; import { Cursor } from "../dnd/compute-drop"; import { Store } from "redux"; @@ -628,7 +627,7 @@ export class TreeApi { } get renderDragPreview() { - return this.props.renderDragPreview || DefaultDragPreview; + return this.props.renderDragPreview; } get renderCursor() { diff --git a/packages/react-arborist/src/types/renderers.ts b/packages/react-arborist/src/types/renderers.ts index 356ad57..ca7c291 100644 --- a/packages/react-arborist/src/types/renderers.ts +++ b/packages/react-arborist/src/types/renderers.ts @@ -9,6 +9,7 @@ export type NodeRendererProps = { node: NodeApi; tree: TreeApi; dragHandle?: (el: HTMLDivElement | null) => void; + previewHandle?: (el: HTMLDivElement | null) => void; preview?: boolean; };