From 4d7f0325044fb8e52712d8ad25c523f9223f1c33 Mon Sep 17 00:00:00 2001 From: Yannick Musafiri Date: Tue, 30 Apr 2024 11:25:01 +0200 Subject: [PATCH 1/2] feat: add node select option --- src/components/cards/Canvas.tsx | 25 +++++++++++++++++-------- src/components/cards/Node.tsx | 18 +++++++++++------- 2 files changed, 28 insertions(+), 15 deletions(-) diff --git a/src/components/cards/Canvas.tsx b/src/components/cards/Canvas.tsx index 55e422f..c4b43c0 100644 --- a/src/components/cards/Canvas.tsx +++ b/src/components/cards/Canvas.tsx @@ -1,6 +1,6 @@ import { parseEdges, parseNodes } from "@/utils/canvas"; -import { useMemo } from "react"; -import ReactFlow from "reactflow"; +import { useCallback, useEffect, useMemo, useState } from "react"; +import ReactFlow, { useEdgesState, useNodesState } from "reactflow"; import "reactflow/dist/style.css"; import { NodeCard } from "./Node"; @@ -13,15 +13,22 @@ const NodeTypes = { }; const CardCanvas = ({ data, blockHeight, columns }: any) => { - const edges = useMemo(() => parseEdges(data), [data]); - const nodes = useMemo( - () => + const [nodes, setNodes, onNodesChange] = useNodesState([]); + const [edges, setEdges, onEdgesChange] = useEdgesState([]); + + const updateData = useCallback(() => { + setEdges(parseEdges(data)); + setNodes( parseNodes(data, { width: columns > 5 ? SINGLE_BLOCK_WIDTH : CONTAINER_WIDTH, height: CONTAINER_HEIGHT, - }), - [data] - ); + }) + ); + }, [data, columns]); + + useEffect(() => { + updateData(); + }, [updateData]); return (
{ zoomOnScroll={false} draggable={false} preventScrolling={false} + onNodesChange={onNodesChange} + onEdgesChange={onEdgesChange} onInit={(instance) => setTimeout(() => instance.fitView(), 100)} >
diff --git a/src/components/cards/Node.tsx b/src/components/cards/Node.tsx index ae7cb16..d814e9a 100644 --- a/src/components/cards/Node.tsx +++ b/src/components/cards/Node.tsx @@ -6,7 +6,9 @@ import { getBgColorClassName, getColorByAccess, getLevel } from "@/utils/nodes"; import Link from "next/link"; import { useHighlight } from "@/hooks/useHighlight"; -export function NodeCard({ data }: any) { +export function NodeCard(props: any) { + const { data, sourcePosition, targetPosition, selected } = props; + console.log(props); const highlighted = useHighlight(data); const { className, access, starColor, summary } = useMemo(() => { @@ -21,11 +23,15 @@ export function NodeCard({ data }: any) { return { access, starColor, summary, className }; }, [data, highlighted]); + const onClick = () => { + if(!selected || !data?.Url) return; + window?.open(data?.Url, '_blank')?.focus(); + } + return (
- - -
+ +

{data.Title}

{data.Author}

@@ -54,9 +60,7 @@ export function NodeCard({ data }: any) {
- - - +
); } From f4bbae3820e02f89a3129c55d62cbe10ef155a03 Mon Sep 17 00:00:00 2001 From: Yannick Musafiri Date: Tue, 30 Apr 2024 18:19:27 +0200 Subject: [PATCH 2/2] chore: cleanup --- src/components/cards/Node.tsx | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/components/cards/Node.tsx b/src/components/cards/Node.tsx index d814e9a..c2587ff 100644 --- a/src/components/cards/Node.tsx +++ b/src/components/cards/Node.tsx @@ -6,9 +6,7 @@ import { getBgColorClassName, getColorByAccess, getLevel } from "@/utils/nodes"; import Link from "next/link"; import { useHighlight } from "@/hooks/useHighlight"; -export function NodeCard(props: any) { - const { data, sourcePosition, targetPosition, selected } = props; - console.log(props); +export function NodeCard({ data, sourcePosition, targetPosition, selected }: any) { const highlighted = useHighlight(data); const { className, access, starColor, summary } = useMemo(() => {