12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- import { getChildrenEdges } from "src/utils/getChildrenEdges";
- import { getOutgoers } from "src/utils/getOutgoers";
- import create from "zustand";
- export interface Graph {
- nodes: NodeData[];
- edges: EdgeData[];
- collapsedNodes: string[];
- collapsedEdges: string[];
- collapsedParents: string[];
- }
- interface GraphActions {
- setGraphValue: (key: keyof Graph, value: any) => void;
- expandNodes: (nodeId: string) => void;
- collapseNodes: (nodeId: string) => void;
- }
- const initialStates: Graph = {
- nodes: [],
- edges: [],
- collapsedNodes: [],
- collapsedEdges: [],
- collapsedParents: [],
- };
- const useGraph = create<Graph & GraphActions>((set, get) => ({
- ...initialStates,
- setGraphValue: (key, value) =>
- set({
- collapsedNodes: [],
- collapsedEdges: [],
- [key]: value,
- }),
- expandNodes: nodeId => {
- const [childrenNodes, matchingNodes] = getOutgoers(
- nodeId,
- get().nodes,
- get().edges,
- get().collapsedParents
- );
- const childrenEdges = getChildrenEdges(childrenNodes, get().edges);
- const nodeIds = childrenNodes.map(node => node.id).concat(matchingNodes);
- const edgeIds = childrenEdges.map(edge => edge.id);
- const collapsedParents = get().collapsedParents.filter(cp => cp !== nodeId);
- const collapsedNodes = get().collapsedNodes.filter(
- nodeId => !nodeIds.includes(nodeId)
- );
- const collapsedEdges = get().collapsedEdges.filter(
- edgeId => !edgeIds.includes(edgeId)
- );
- set({
- collapsedParents,
- collapsedNodes,
- collapsedEdges,
- });
- },
- collapseNodes: nodeId => {
- const [childrenNodes] = getOutgoers(nodeId, get().nodes, get().edges);
- const childrenEdges = getChildrenEdges(childrenNodes, get().edges);
- const nodeIds = childrenNodes.map(node => node.id);
- const edgeIds = childrenEdges.map(edge => edge.id);
- set({
- collapsedParents: get().collapsedParents.concat(nodeId),
- collapsedNodes: get().collapsedNodes.concat(nodeIds),
- collapsedEdges: get().collapsedEdges.concat(edgeIds),
- });
- },
- }));
- export default useGraph;
|