From f1551d70d5932c7b91a3b1b7bcc9b3b695986630 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A0=D0=B0=D1=81=D1=83=D0=BB?= Date: Thu, 26 Dec 2024 03:51:37 +0300 Subject: [PATCH] feat: fixed nodes alignment --- .../Graph/Cubes/SelectionDataNodes/index.tsx | 54 ++++++++----------- 1 file changed, 23 insertions(+), 31 deletions(-) diff --git a/src/components/Universe/Graph/Cubes/SelectionDataNodes/index.tsx b/src/components/Universe/Graph/Cubes/SelectionDataNodes/index.tsx index 930036a8a..fd6c2ac75 100644 --- a/src/components/Universe/Graph/Cubes/SelectionDataNodes/index.tsx +++ b/src/components/Universe/Graph/Cubes/SelectionDataNodes/index.tsx @@ -11,7 +11,7 @@ import { Connections } from './Connections' import { Node as GraphNode } from './Node' const radius = 50 -const MAX_LENGTH = 5 +const MAX_LENGTH = 7 type GraphData = { links: Link[] @@ -40,40 +40,34 @@ export const SelectionDataNodes = memo(() => { const oldNodes = pathGraph?.nodes || [] - // Combine `oldNodes` and `selectionData.nodes` for position calculations - const combinedNodes = [...oldNodes, ...selectionData.nodes] + // Filter out nodes that already exist in oldNodes + const newNodes = selectionData.nodes.filter((i) => !oldNodes.some((n) => n.ref_id === i.ref_id)) - // Calculate the angular spacing considering both old and new nodes - const totalNodes = combinedNodes.length - const thetaSpan = (Math.PI * 2) / totalNodes // Angle between points - - const nodes = selectionData.nodes.map((node, index) => { - // Check if the node exists in oldNodes - const existingNode = oldNodes.find((oldNode) => oldNode.ref_id === node.ref_id) - - if (existingNode) { - // Retain the old node's position - return existingNode - } + // Find the start position from oldNodes + const startPositionNode = oldNodes.find((i) => i.x !== 0 || i.y !== 0) + const startPosition = startPositionNode ? { x: startPositionNode.x, y: startPositionNode.y } : { x: 0, y: 0 } - // Calculate new position for nodes not in oldNodes - const theta = thetaSpan * (oldNodes.length + index) // Offset by oldNodes count - const x = node.ref_id === selectedNode?.ref_id ? 0 : Math.cos(theta) * radius - const y = node.ref_id === selectedNode?.ref_id ? 0 : Math.sin(theta) * radius - const z = node.ref_id === selectedNode?.ref_id ? 0 : 0 + // Calculate the starting angle (theta) for the start position + const startTheta = Math.atan2(startPosition.y, startPosition.x) - return { ...node, x, y, z } - }) + // Total nodes including both old and new ones + const totalNodes = oldNodes.length + newNodes.length - 1 + const thetaSpan = (Math.PI * 2) / totalNodes // Angle between points - // Retain old nodes with their original positions - const retainedOldNodes = oldNodes.filter( - (oldNode) => !selectionData.nodes.some((node) => node.ref_id === oldNode.ref_id), - ) + const nodes = [ + ...oldNodes, + ...newNodes.map((node, index) => { + // Calculate angular position for the new node + const theta = startTheta + thetaSpan * (index + 1) // Start adding from startTheta + const x = node.ref_id === selectedNode?.ref_id ? 0 : Math.cos(theta) * radius + const y = node.ref_id === selectedNode?.ref_id ? 0 : Math.sin(theta) * radius + const z = node.ref_id === selectedNode?.ref_id ? 0 : 0 - // Merge the calculated nodes with retained old nodes - const mergedNodes = [...nodes, ...retainedOldNodes] + return { ...node, x, y, z } + }), + ] - return { nodes: mergedNodes, links: selectionData.links } + return { nodes, links: selectionData.links } }, [selectionData, selectedNode, pathGraph?.nodes]) const graphData: GraphData = useMemo(() => { @@ -81,8 +75,6 @@ export const SelectionDataNodes = memo(() => { return newData } - console.log(pathGraph) - if (pathGraph) { return { nodes: pathGraph.nodes,