From f31ed7d781fb36d9b4debe7287b11badd8d7f75a Mon Sep 17 00:00:00 2001 From: Jules Laplace Date: Tue, 24 Aug 2021 19:07:19 +0200 Subject: add legend, filter visible nodes --- src/views/App.js | 26 +++++++++++++++++++++++--- 1 file changed, 23 insertions(+), 3 deletions(-) (limited to 'src/views/App.js') diff --git a/src/views/App.js b/src/views/App.js index c5a7f83..561523d 100644 --- a/src/views/App.js +++ b/src/views/App.js @@ -5,19 +5,24 @@ import React, { useState, useEffect, useCallback } from "react"; import Detail from "./Detail.js"; +import Legend from "./Legend.js"; import buildGraph from "../graph.js"; export default function App() { const [db, setDb] = useState(null); const [node, setNode] = useState(null); + const [graph, setGraph] = useState(null); + const [selected, setSelected] = useState(null); const [detailVisible, setDetailVisible] = useState(null); useEffect(async () => { const newDb = await loadDB(); setDb(newDb); - buildGraph(newDb, { - click: handleClick, - }); + setGraph( + buildGraph(newDb, { + click: handleClick, + }) + ); }, []); const handleClick = useCallback((node) => { @@ -29,9 +34,24 @@ export default function App() { setDetailVisible(false); }); + const handleSelect = useCallback((category) => { + if (category === selected) { + setSelected(null); + graph.onSelect(null); + } else { + setSelected(category); + graph.onSelect(category); + } + }); + return (
+
); } -- cgit v1.2.3-70-g09d2