import { GraphNode } from 'bob-the-algorithm'; import { useMemo } from 'react'; import { ConvertedResult } from '../../utils/graph'; import { format } from 'date-fns'; type PlanProps = { id: string; output: ConvertedResult; }; type NodeProps = { node: GraphNode; output: ConvertedResult; }; const Node = ({ node, output }: NodeProps) => { const planable = useMemo(() => { return node.planable ? output.result.planables.find((n) => n.id === node.planable) : null; }, [node, output]); const time = useMemo(() => { const start = new Date(node.time); const end = new Date(start.getTime() + node.duration); return ( {format(start, 'HH:mm')} - {format(end, 'HH:mm')} ); }, [node.duration, node.time]); if (planable) { return (