From f843a99746a2c37f73eeadab4da20aea064300d3 Mon Sep 17 00:00:00 2001 From: hoshinotsuyoshi Date: Mon, 16 Dec 2024 18:35:26 +0900 Subject: [PATCH] Optimize TableColumn component by caching relationship checks - Introduced useMemo to cache `isSource` and `targetCardinality` computations. --- .../TableColumn/TableColumn.tsx | 27 ++++++++++++------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/TableNode/TableColumnList/TableColumn/TableColumn.tsx b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/TableNode/TableColumnList/TableColumn/TableColumn.tsx index bf7ad46e2..851547897 100644 --- a/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/TableNode/TableColumnList/TableColumn/TableColumn.tsx +++ b/frontend/packages/erd-core/src/components/ERDRenderer/ERDContent/TableNode/TableColumnList/TableColumn/TableColumn.tsx @@ -2,6 +2,7 @@ import type { Column, Relationships, Table } from '@liam-hq/db-structure' import { DiamondFillIcon, DiamondIcon, KeyRound } from '@liam-hq/ui' import { Handle, Position } from '@xyflow/react' import clsx from 'clsx' +import { useMemo } from 'react' import type { FC } from 'react' import { match } from 'ts-pattern' import { Cardinality } from './Cardinality' @@ -25,15 +26,23 @@ export const TableColumn: FC = ({ }) => { const handleId = `${table.name}-${column.name}` - const isSource = Object.values(relationships).some( - (relationship) => - relationship.primaryTableName === table.name && - relationship.primaryColumnName === column.name, - ) - const targetCardinality = Object.values(relationships).find( - ({ foreignTableName, foreignColumnName }) => - foreignTableName === table.name && foreignColumnName === column.name, - )?.cardinality + const { sourceColumns, targetCardinalities } = useMemo(() => { + const sourceColumns: Set = new Set() + const targetCardinalities: Record = {} + + for (const relationship of Object.values(relationships)) { + const sourceKey = `${relationship.primaryTableName}-${relationship.primaryColumnName}` + sourceColumns.add(sourceKey) + + const targetKey = `${relationship.foreignTableName}-${relationship.foreignColumnName}` + targetCardinalities[targetKey] = relationship.cardinality + } + + return { sourceColumns, targetCardinalities } + }, [relationships]) + + const isSource = sourceColumns.has(handleId) + const targetCardinality = targetCardinalities[handleId] return (