From bb9585ccc42f8623680dabfb0977c5fe6f8a9b4b Mon Sep 17 00:00:00 2001 From: MH4GF Date: Thu, 19 Dec 2024 14:34:53 +0900 Subject: [PATCH 1/5] feat: add hover highlighting logic for nodes and edges in highlightNodesAndEdges function --- .../ERDContent/highlightNodesAndEdges.test.ts | 56 ++++++++++++------- .../ERDContent/highlightNodesAndEdges.ts | 33 ++++++++++- .../useSyncHighlightsActiveTableChange.ts | 2 +- 3 files changed, 67 insertions(+), 24 deletions(-) diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts index 518c81739..6b7d426e2 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts @@ -62,11 +62,9 @@ describe(highlightNodesAndEdges, () => { describe('nodes', () => { it('When the users is active, the users and related tables are highlighted', () => { - const { nodes: updatedNodes } = highlightNodesAndEdges( - nodes, - edges, - 'users', - ) + const { nodes: updatedNodes } = highlightNodesAndEdges(nodes, edges, { + activeTableName: 'users', + }) expect(updatedNodes).toEqual([ aTableNode('users', { @@ -89,11 +87,9 @@ describe(highlightNodesAndEdges, () => { }) it('When no active table, no tables are highlighted', () => { - const { nodes: updatedNodes } = highlightNodesAndEdges( - nodes, - edges, - undefined, - ) + const { nodes: updatedNodes } = highlightNodesAndEdges(nodes, edges, { + activeTableName: undefined, + }) expect(updatedNodes).toEqual([ aTableNode('users', { @@ -114,15 +110,37 @@ describe(highlightNodesAndEdges, () => { }), ]) }) + it('When the users is hovered, the users and related tables are highlighted', () => { + const { nodes: updatedNodes } = highlightNodesAndEdges(nodes, edges, { + hoverTableName: 'users', + }) + + expect(updatedNodes).toEqual([ + aTableNode('users', { + data: aTableData('users', { isHighlighted: true }), + }), + aTableNode('posts', { + data: aTableData('posts', { + isHighlighted: true, + highlightedHandles: ['posts-user_id'], + }), + }), + aTableNode('comments'), + aTableNode('comment_users', { + data: aTableData('comment_users', { + isHighlighted: true, + highlightedHandles: ['comment_users-user_id'], + }), + }), + ]) + }) }) describe('edges', () => { it('When the users is active, the users and related edges are highlighted', () => { - const { edges: updatedEdges } = highlightNodesAndEdges( - nodes, - edges, - 'users', - ) + const { edges: updatedEdges } = highlightNodesAndEdges(nodes, edges, { + activeTableName: 'users', + }) expect(updatedEdges).toEqual([ anEdge('users', 'posts', 'users-id', 'posts-user_id', { @@ -143,11 +161,9 @@ describe(highlightNodesAndEdges, () => { }) it('When no active table, no edges are highlighted', () => { - const { edges: updatedEdges } = highlightNodesAndEdges( - nodes, - edges, - undefined, - ) + const { edges: updatedEdges } = highlightNodesAndEdges(nodes, edges, { + activeTableName: undefined, + }) expect(updatedEdges).toEqual([ anEdge('users', 'posts', 'users-id', 'posts-user_id', { diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts index cef0ea4be..707727a19 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts @@ -24,6 +24,25 @@ const isActivelyRelatedNode = ( return edgeMap.get(activeTableName)?.includes(node.data.table.name) ?? false } +const isHoveredNode = ( + hoverTableName: string | undefined, + node: TableNodeType, +): boolean => { + return node.data.table.name === hoverTableName +} + +const isHoverRelatedNode = ( + hoverTableName: string | undefined, + edgeMap: EdgeMap, + node: TableNodeType, +): boolean => { + if (!hoverTableName) { + return false + } + + return edgeMap.get(hoverTableName)?.includes(node.data.table.name) ?? false +} + const isActivelyRelatedEdge = ( activeTableName: string | undefined, edge: Edge, @@ -109,8 +128,12 @@ const unhighlightEdge = (edge: Edge): Edge => ({ export const highlightNodesAndEdges = ( nodes: Node[], edges: Edge[], - activeTableName?: string | undefined, + trigger: { + activeTableName?: string | undefined + hoverTableName?: string | undefined + }, ): { nodes: Node[]; edges: Edge[] } => { + const { activeTableName, hoverTableName } = trigger const edgeMap: EdgeMap = new Map() for (const edge of edges) { const sourceTableName = edge.source @@ -130,9 +153,13 @@ export const highlightNodesAndEdges = ( return activeHighlightNode(node) } - if (isActivelyRelatedNode(activeTableName, edgeMap, node)) { + if ( + isActivelyRelatedNode(activeTableName, edgeMap, node) || + isHoveredNode(hoverTableName, node) || + isHoverRelatedNode(hoverTableName, edgeMap, node) + ) { const highlightedHandles = getHighlightedHandlesForRelatedNode( - activeTableName, + activeTableName ?? hoverTableName, edges, node, ) diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/useSyncHighlightsActiveTableChange.ts b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/useSyncHighlightsActiveTableChange.ts index b0e7bfefe..d1eaebf89 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/useSyncHighlightsActiveTableChange.ts +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/useSyncHighlightsActiveTableChange.ts @@ -21,7 +21,7 @@ export const useSyncHighlightsActiveTableChange = () => { const { nodes: updatedNodes, edges: updatedEdges } = highlightNodesAndEdges( nodes, edges, - tableName, + { activeTableName: tableName }, ) setEdges(updatedEdges) From 352d79d1c13c497bb56969f3302cb2d3ab2a2d69 Mon Sep 17 00:00:00 2001 From: MH4GF Date: Thu, 19 Dec 2024 14:39:30 +0900 Subject: [PATCH 2/5] refactor: rename functions and parameters for clarity in highlightNodesAndEdges logic --- .../ERDContent/highlightNodesAndEdges.ts | 32 ++++++------------- 1 file changed, 10 insertions(+), 22 deletions(-) diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts index 707727a19..4ae30f69b 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts @@ -12,16 +12,16 @@ const isActiveNode = ( return node.data.table.name === activeTableName } -const isActivelyRelatedNode = ( - activeTableName: string | undefined, +const isRelatedNodeToTarget = ( + targetTableName: string | undefined, edgeMap: EdgeMap, node: TableNodeType, ): boolean => { - if (!activeTableName) { + if (!targetTableName) { return false } - return edgeMap.get(activeTableName)?.includes(node.data.table.name) ?? false + return edgeMap.get(targetTableName)?.includes(node.data.table.name) ?? false } const isHoveredNode = ( @@ -31,18 +31,6 @@ const isHoveredNode = ( return node.data.table.name === hoverTableName } -const isHoverRelatedNode = ( - hoverTableName: string | undefined, - edgeMap: EdgeMap, - node: TableNodeType, -): boolean => { - if (!hoverTableName) { - return false - } - - return edgeMap.get(hoverTableName)?.includes(node.data.table.name) ?? false -} - const isActivelyRelatedEdge = ( activeTableName: string | undefined, edge: Edge, @@ -51,11 +39,11 @@ const isActivelyRelatedEdge = ( } const getHighlightedHandlesForRelatedNode = ( - activeTableName: string | undefined, + targetTableName: string | undefined, edges: Edge[], node: TableNodeType, ): string[] => { - if (!activeTableName) { + if (!targetTableName) { return [] } @@ -64,7 +52,7 @@ const getHighlightedHandlesForRelatedNode = ( if ( edge.targetHandle !== undefined && edge.targetHandle !== null && - edge.source === activeTableName && + edge.source === targetTableName && edge.target === node.data.table.name ) { handles.push(edge.targetHandle) @@ -74,7 +62,7 @@ const getHighlightedHandlesForRelatedNode = ( edge.sourceHandle !== undefined && edge.sourceHandle !== null && edge.source === node.data.table.name && - edge.target === activeTableName + edge.target === targetTableName ) { handles.push(edge.sourceHandle) } @@ -154,9 +142,9 @@ export const highlightNodesAndEdges = ( } if ( - isActivelyRelatedNode(activeTableName, edgeMap, node) || + isRelatedNodeToTarget(activeTableName, edgeMap, node) || isHoveredNode(hoverTableName, node) || - isHoverRelatedNode(hoverTableName, edgeMap, node) + isRelatedNodeToTarget(hoverTableName, edgeMap, node) ) { const highlightedHandles = getHighlightedHandlesForRelatedNode( activeTableName ?? hoverTableName, From bf892f48cdd6ca0a3ee82b91c8029333e19e70b1 Mon Sep 17 00:00:00 2001 From: MH4GF Date: Thu, 19 Dec 2024 14:41:58 +0900 Subject: [PATCH 3/5] feat: add test for hover highlighting of users and related edges in highlightNodesAndEdges function --- .../ERDContent/highlightNodesAndEdges.test.ts | 22 +++++++++++++++++++ .../ERDContent/highlightNodesAndEdges.ts | 8 +++---- 2 files changed, 26 insertions(+), 4 deletions(-) diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts index 6b7d426e2..c20f0f26c 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts @@ -182,5 +182,27 @@ describe(highlightNodesAndEdges, () => { ), ]) }) + it('When the users is hovered, the users and related edges are highlighted', () => { + const { edges: updatedEdges } = highlightNodesAndEdges(nodes, edges, { + hoverTableName: 'users', + }) + + expect(updatedEdges).toEqual([ + anEdge('users', 'posts', 'users-id', 'posts-user_id', { + animated: true, + data: { isHighlighted: true }, + }), + anEdge('users', 'comment_users', 'users-id', 'comment_users-user_id', { + animated: true, + data: { isHighlighted: true }, + }), + anEdge( + 'comments', + 'comment_users', + 'comments-id', + 'comment_users-comment_id', + ), + ]) + }) }) }) diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts index 4ae30f69b..b3ee4e18c 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts @@ -31,11 +31,11 @@ const isHoveredNode = ( return node.data.table.name === hoverTableName } -const isActivelyRelatedEdge = ( - activeTableName: string | undefined, +const isRelatedEdgeToTarget = ( + targetTableName: string | undefined, edge: Edge, ): boolean => { - return edge.source === activeTableName || edge.target === activeTableName + return edge.source === targetTableName || edge.target === targetTableName } const getHighlightedHandlesForRelatedNode = ( @@ -158,7 +158,7 @@ export const highlightNodesAndEdges = ( }) const updatedEdges = edges.map((edge) => { - if (isActivelyRelatedEdge(activeTableName, edge)) { + if (isRelatedEdgeToTarget(activeTableName ?? hoverTableName, edge)) { return highlightEdge(edge) } From f3e454aef5926d80a6784778aa641898a992b3cb Mon Sep 17 00:00:00 2001 From: MH4GF Date: Thu, 19 Dec 2024 14:48:12 +0900 Subject: [PATCH 4/5] refactor: integrate highlightNodesAndEdges function for improved node and edge highlighting on hover --- frontend/.changeset/big-impalas-call.md | 6 + .../ERDRenderer/ERDContent/ERDContent.tsx | 202 +++--------------- 2 files changed, 33 insertions(+), 175 deletions(-) create mode 100644 frontend/.changeset/big-impalas-call.md diff --git a/frontend/.changeset/big-impalas-call.md b/frontend/.changeset/big-impalas-call.md new file mode 100644 index 000000000..8a250ea03 --- /dev/null +++ b/frontend/.changeset/big-impalas-call.md @@ -0,0 +1,6 @@ +--- +"@liam-hq/erd-core": patch +"@liam-hq/cli": patch +--- + +refactor: integrate highlightNodesAndEdges function for improved node and edge highlighting on hover diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/ERDContent.tsx b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/ERDContent.tsx index 632d4732f..1f6c16848 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/ERDContent.tsx +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/ERDContent.tsx @@ -1,4 +1,8 @@ -import { updateActiveTableName, useDBStructureStore } from '@/stores' +import { + updateActiveTableName, + useDBStructureStore, + useUserEditingActiveStore, +} from '@/stores' import type { Relationships } from '@liam-hq/db-structure' import { Background, @@ -10,12 +14,13 @@ import { useEdgesState, useNodesState, } from '@xyflow/react' -import { type FC, useCallback, useState } from 'react' +import { type FC, useCallback } from 'react' import styles from './ERDContent.module.css' import { ERDContentProvider, useERDContentContext } from './ERDContentContext' import { RelationshipEdge } from './RelationshipEdge' import { Spinner } from './Spinner' import { TableNode } from './TableNode' +import { highlightNodesAndEdges } from './highlightNodesAndEdges' import { useFitViewWhenActiveTableChange } from './useFitViewWhenActiveTableChange' import { useInitialAutoLayout } from './useInitialAutoLayout' import { useSyncHighlightsActiveTableChange } from './useSyncHighlightsActiveTableChange' @@ -39,18 +44,6 @@ type Props = { | undefined } -const highlightEdge = (edge: Edge): Edge => ({ - ...edge, - animated: true, - data: { ...edge.data, isHighlighted: true }, -}) - -const unhighlightEdge = (edge: Edge): Edge => ({ - ...edge, - animated: false, - data: { ...edge.data, isHighlighted: false }, -}) - export const isRelatedToTable = ( relationships: Relationships, tableName: string, @@ -68,22 +61,6 @@ export const isRelatedToTable = ( ) } -const getHighlightedHandles = ( - edges: Edge[], - targetId: string, - nodeId: string, -) => { - const highlightedTargetHandles = edges - .filter((edge) => edge.source === targetId && edge.target === nodeId) - .map((edge) => edge.targetHandle) - - const highlightedSourceHandles = edges - .filter((edge) => edge.target === targetId && edge.source === nodeId) - .map((edge) => edge.sourceHandle) - - return highlightedTargetHandles.concat(highlightedSourceHandles) || [] -} - export const ERDContentInner: FC = ({ nodes: _nodes, edges: _edges, @@ -95,8 +72,7 @@ export const ERDContentInner: FC = ({ const { state: { loading }, } = useERDContentContext() - // TODO: remove activeNodeId state - const [activeNodeId, setActiveNodeId] = useState(null) + const { tableName: activeTableName } = useUserEditingActiveStore() useUpdateNodeCardinalities(nodes, relationships, setNodes) useInitialAutoLayout() @@ -106,164 +82,40 @@ export const ERDContentInner: FC = ({ useSyncHighlightsActiveTableChange() const handleNodeClick = useCallback((nodeId: string) => { - setActiveNodeId(nodeId) updateActiveTableName(nodeId) }, []) const handlePaneClick = useCallback(() => { - setActiveNodeId(null) updateActiveTableName(undefined) }, []) const handleMouseEnterNode: NodeMouseHandler = useCallback( (_, { id }) => { - const relatedEdges = edges.filter( - (e) => e.source === id || e.target === id, - ) - - const relatedToActiveNodeEdges = edges.filter( - (e) => e.source === activeNodeId || e.target === activeNodeId, - ) - - const updatedEdges = edges.map((e) => { - if (relatedEdges.includes(e)) { - return highlightEdge(e) - } - if (relatedToActiveNodeEdges.includes(e)) { - return highlightEdge(e) - } - return unhighlightEdge(e) - }) - - const updatedNodes = nodes.map((node) => { - if (node.id === id) { - return { ...node, data: { ...node.data, isHighlighted: true } } - } - - const isRelated = isRelatedToTable(relationships, node.id, id) - const isRelatedToActiveNode = - activeNodeId && isRelatedToTable(relationships, node.id, activeNodeId) - - if (isRelated) { - let highlightedHandles = getHighlightedHandles(edges, id, node.id) - if (isRelatedToActiveNode) { - highlightedHandles = highlightedHandles.concat( - getHighlightedHandles(edges, activeNodeId, node.id), - ) - } - - return { - ...node, - data: { - ...node.data, - isHighlighted: true, - highlightedHandles: highlightedHandles, - }, - } - } - if (isRelatedToActiveNode) { - const highlightedHandles = getHighlightedHandles( - edges, - activeNodeId, - node.id, - ).concat(getHighlightedHandles(edges, id, node.id)) - - const isHighlighted = node.id === activeNodeId - - return { - ...node, - data: { - ...node.data, - isHighlighted: isHighlighted, - highlightedHandles: highlightedHandles, - }, - } - } - - return { - ...node, - data: { - ...node.data, - isHighlighted: false, - highlightedHandles: [], - }, - } - }) + const { nodes: updatedNodes, edges: updatedEdges } = + highlightNodesAndEdges(nodes, edges, { + activeTableName, + hoverTableName: id, + }) setEdges(updatedEdges) setNodes(updatedNodes) }, - [edges, nodes, setNodes, setEdges, relationships, activeNodeId], + [edges, nodes, setNodes, setEdges, activeTableName], ) - const handleMouseLeaveNode: NodeMouseHandler = useCallback( - (_, { id }) => { - // If a node is active, do not remove the highlight - if (activeNodeId) { - const relatedEdges = edges.filter( - (e) => e.source === activeNodeId || e.target === activeNodeId, - ) - const updatedEdges = edges.map((e) => - relatedEdges.includes(e) ? highlightEdge(e) : unhighlightEdge(e), - ) - setEdges(updatedEdges) - - const updatedNodes = nodes.map((node) => { - const isRelated = isRelatedToTable( - relationships, - node.id, - activeNodeId, - ) - - if (node.id === activeNodeId || isRelated) { - const highlightedHandles = getHighlightedHandles( - edges, - activeNodeId, - node.id, - ) - - const isHighlighted = node.id === activeNodeId - - return { - ...node, - data: { - ...node.data, - isHighlighted, - highlightedHandles: highlightedHandles, - }, - } - } - - return { - ...node, - data: { - ...node.data, - isHighlighted: false, - highlightedHandles: [], - }, - } - }) - - setNodes(updatedNodes) - } else { - const updatedEdges = edges.map((e) => - e.source === id || e.target === id ? unhighlightEdge(e) : e, - ) - setEdges(updatedEdges) - - const updatedNodes = nodes.map((node) => ({ - ...node, - data: { - ...node.data, - highlightedHandles: [], - isHighlighted: false, - }, - })) - setNodes(updatedNodes) - } - }, - [edges, nodes, setNodes, setEdges, activeNodeId, relationships], - ) + const handleMouseLeaveNode: NodeMouseHandler = useCallback(() => { + const { nodes: updatedNodes, edges: updatedEdges } = highlightNodesAndEdges( + nodes, + edges, + { + activeTableName, + hoverTableName: undefined, + }, + ) + + setEdges(updatedEdges) + setNodes(updatedNodes) + }, [edges, nodes, setNodes, setEdges, activeTableName]) const panOnDrag = [1, 2] From 00a18a7b804ad02fbeddd6e1ef048ac9003a6d9c Mon Sep 17 00:00:00 2001 From: MH4GF Date: Thu, 19 Dec 2024 15:11:26 +0900 Subject: [PATCH 5/5] test: add tests for highlighting users and comments with related nodes and edges in highlightNodesAndEdges function --- .../ERDContent/highlightNodesAndEdges.test.ts | 54 +++++++++++++++++++ .../ERDContent/highlightNodesAndEdges.ts | 5 +- 2 files changed, 58 insertions(+), 1 deletion(-) diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts index c20f0f26c..0aa379260 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.test.ts @@ -134,6 +134,33 @@ describe(highlightNodesAndEdges, () => { }), ]) }) + it('When the users is active, and the comments is hovered, then the users and comments and related tables are highlighted', () => { + const { nodes: updatedNodes } = highlightNodesAndEdges(nodes, edges, { + activeTableName: 'users', + hoverTableName: 'comments', + }) + + expect(updatedNodes).toEqual([ + aTableNode('users', { + data: aTableData('users', { isActiveHighlighted: true }), + }), + aTableNode('posts', { + data: aTableData('posts', { + isHighlighted: true, + highlightedHandles: ['posts-user_id'], + }), + }), + aTableNode('comments', { + data: aTableData('comments', { isHighlighted: true }), + }), + aTableNode('comment_users', { + data: aTableData('comment_users', { + isHighlighted: true, + highlightedHandles: ['comment_users-user_id'], + }), + }), + ]) + }) }) describe('edges', () => { @@ -204,5 +231,32 @@ describe(highlightNodesAndEdges, () => { ), ]) }) + it('When the users is active, and the comments is hovered, then the users and comments and related edges are highlighted', () => { + const { edges: updatedEdges } = highlightNodesAndEdges(nodes, edges, { + activeTableName: 'users', + hoverTableName: 'comments', + }) + + expect(updatedEdges).toEqual([ + anEdge('users', 'posts', 'users-id', 'posts-user_id', { + animated: true, + data: { isHighlighted: true }, + }), + anEdge('users', 'comment_users', 'users-id', 'comment_users-user_id', { + animated: true, + data: { isHighlighted: true }, + }), + anEdge( + 'comments', + 'comment_users', + 'comments-id', + 'comment_users-comment_id', + { + animated: true, + data: { isHighlighted: true }, + }, + ), + ]) + }) }) }) diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts index b3ee4e18c..09916e7b7 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/highlightNodesAndEdges.ts @@ -158,7 +158,10 @@ export const highlightNodesAndEdges = ( }) const updatedEdges = edges.map((edge) => { - if (isRelatedEdgeToTarget(activeTableName ?? hoverTableName, edge)) { + if ( + isRelatedEdgeToTarget(activeTableName, edge) || + isRelatedEdgeToTarget(hoverTableName, edge) + ) { return highlightEdge(edge) }