feat: Network Graph with vis.js
This commit is contained in:
parent
1fa91a7228
commit
4a46cd505d
127
src/Network.tsx
Normal file
127
src/Network.tsx
Normal file
@ -0,0 +1,127 @@
|
||||
import { useEffect, useLayoutEffect, useRef, useState } from 'react';
|
||||
import "vis-network/styles/vis-network.css";
|
||||
import { apiAuth, baseUrl } from './api';
|
||||
import NetworkData, { Edge } from './types';
|
||||
import { Network } from 'vis-network/esnext';
|
||||
import { DataSet, DataView } from "vis-data/esnext";
|
||||
|
||||
const GraphComponent = () => {
|
||||
const graphRef = useRef<HTMLDivElement>(null);
|
||||
const [data, setData] = useState({ nodes: [], edges: [] } as NetworkData);
|
||||
const [loading, setLoading] = useState(true);
|
||||
|
||||
async function loadData() {
|
||||
setLoading(true);
|
||||
await apiAuth("analysis/json", null)
|
||||
.then(json => json as Promise<NetworkData>).then(json => { setData(json) })
|
||||
setLoading(false);
|
||||
}
|
||||
|
||||
useEffect(() => { loadData() }, [])
|
||||
|
||||
var network: Network;
|
||||
|
||||
//function updateEdgeWidths(nodeId: number | string) {
|
||||
// // Get all edges connected to the clicked node
|
||||
// const edges = network.body.edges.getEdges({
|
||||
// filter: (edge: any) => edge.from === nodeId,
|
||||
// });
|
||||
// // Update the width of each edge
|
||||
// edges.forEach((edge: any) => {
|
||||
// network.body.edges.update(edge.id, { width: 5 }); // Change the width to your desired value
|
||||
// });
|
||||
//}
|
||||
|
||||
|
||||
useEffect(() => {
|
||||
var { nodes, edges } = data;
|
||||
if (graphRef.current) {
|
||||
const options = {
|
||||
layout: {
|
||||
randomSeed: null,
|
||||
},
|
||||
interaction: {
|
||||
zoomView: true,
|
||||
},
|
||||
nodes: {
|
||||
shape: 'box',
|
||||
size: 20,
|
||||
font: { size: 24 },
|
||||
},
|
||||
edges: {
|
||||
arrows: "to",
|
||||
color: "black",
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
const edgesFilterValues = {
|
||||
likes: true,
|
||||
dislikes: false,
|
||||
}
|
||||
const edgesFilter = (edge: Edge) => {
|
||||
return edgesFilterValues[edge.relation];
|
||||
};
|
||||
|
||||
//edgeFilters.forEach((filter) =>
|
||||
// filter.addEventListener("change", (e) => {
|
||||
// const { value, checked } = e.target;
|
||||
// edgesFilterValues[value] = checked;
|
||||
// edgesView.refresh();
|
||||
// })
|
||||
//);
|
||||
|
||||
var networkData = {
|
||||
nodes: new DataSet(nodes),
|
||||
edges: new DataView(new DataSet(edges), { filter: edgesFilter })
|
||||
};
|
||||
network = new Network(graphRef.current, networkData, options);
|
||||
|
||||
// Add event listeners for node clicks and drags
|
||||
network.on('click', (params) => {
|
||||
if (params.nodes.length > 0) {
|
||||
console.log(`clicked ${networkData.nodes.getIds().find((nodeId) => nodeId === params.nodes[0])}`);
|
||||
const nodeID = params.nodes[0];
|
||||
//updateEdgeWidths(nodeID);
|
||||
|
||||
if (nodeID !== null) {
|
||||
edges.forEach((edge) => {
|
||||
if (edge.from === nodeID) {
|
||||
edge.color = { opacity: 1, highlight: "red", color: "red" };
|
||||
} else {
|
||||
edge.color = { opacity: 0.2, highlight: "none", color: "#36c" };
|
||||
}
|
||||
});
|
||||
} else {
|
||||
edges.forEach((edge) => {
|
||||
edge.color = { opacity: 0.2, highlight: "none", color: "#36c" };
|
||||
});
|
||||
}
|
||||
//
|
||||
// Update the network with new edge colors
|
||||
if (graphRef.current) {
|
||||
const updatedData = {
|
||||
nodes: new DataSet(nodes),
|
||||
edges: new DataSet(edges),
|
||||
};
|
||||
network.setData(updatedData);
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
network.on('dragEnd', (params) => {
|
||||
if (params.nodes.length > 0) {
|
||||
console.log(`dragged ${networkData.nodes.getIds().find((nodeId) => nodeId === params.nodes[0])}`);
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
}, [loading]);
|
||||
|
||||
|
||||
if (loading) return <span className='loader' />
|
||||
else
|
||||
return <div ref={graphRef} style={{ width: '100%', height: "86vh" }} />;
|
||||
};
|
||||
|
||||
export default GraphComponent;
|
Loading…
x
Reference in New Issue
Block a user