-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
9957257
commit be0793e
Showing
2 changed files
with
422 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,321 @@ | ||
<html> | ||
<head> | ||
<meta charset="utf-8"> | ||
|
||
<script>function neighbourhoodHighlight(params) { | ||
// console.log("in nieghbourhoodhighlight"); | ||
allNodes = nodes.get({ returnType: "Object" }); | ||
// originalNodes = JSON.parse(JSON.stringify(allNodes)); | ||
// if something is selected: | ||
if (params.nodes.length > 0) { | ||
highlightActive = true; | ||
var i, j; | ||
var selectedNode = params.nodes[0]; | ||
var degrees = 2; | ||
|
||
// mark all nodes as hard to read. | ||
for (let nodeId in allNodes) { | ||
// nodeColors[nodeId] = allNodes[nodeId].color; | ||
allNodes[nodeId].color = "rgba(200,200,200,0.5)"; | ||
if (allNodes[nodeId].hiddenLabel === undefined) { | ||
allNodes[nodeId].hiddenLabel = allNodes[nodeId].label; | ||
allNodes[nodeId].label = undefined; | ||
} | ||
} | ||
var connectedNodes = network.getConnectedNodes(selectedNode); | ||
var allConnectedNodes = []; | ||
|
||
// get the second degree nodes | ||
for (i = 1; i < degrees; i++) { | ||
for (j = 0; j < connectedNodes.length; j++) { | ||
allConnectedNodes = allConnectedNodes.concat( | ||
network.getConnectedNodes(connectedNodes[j]) | ||
); | ||
} | ||
} | ||
|
||
// all second degree nodes get a different color and their label back | ||
for (i = 0; i < allConnectedNodes.length; i++) { | ||
// allNodes[allConnectedNodes[i]].color = "pink"; | ||
allNodes[allConnectedNodes[i]].color = "rgba(150,150,150,0.75)"; | ||
if (allNodes[allConnectedNodes[i]].hiddenLabel !== undefined) { | ||
allNodes[allConnectedNodes[i]].label = | ||
allNodes[allConnectedNodes[i]].hiddenLabel; | ||
allNodes[allConnectedNodes[i]].hiddenLabel = undefined; | ||
} | ||
} | ||
|
||
// all first degree nodes get their own color and their label back | ||
for (i = 0; i < connectedNodes.length; i++) { | ||
// allNodes[connectedNodes[i]].color = undefined; | ||
allNodes[connectedNodes[i]].color = nodeColors[connectedNodes[i]]; | ||
if (allNodes[connectedNodes[i]].hiddenLabel !== undefined) { | ||
allNodes[connectedNodes[i]].label = | ||
allNodes[connectedNodes[i]].hiddenLabel; | ||
allNodes[connectedNodes[i]].hiddenLabel = undefined; | ||
} | ||
} | ||
|
||
// the main node gets its own color and its label back. | ||
// allNodes[selectedNode].color = undefined; | ||
allNodes[selectedNode].color = nodeColors[selectedNode]; | ||
if (allNodes[selectedNode].hiddenLabel !== undefined) { | ||
allNodes[selectedNode].label = allNodes[selectedNode].hiddenLabel; | ||
allNodes[selectedNode].hiddenLabel = undefined; | ||
} | ||
} else if (highlightActive === true) { | ||
// console.log("highlightActive was true"); | ||
// reset all nodes | ||
for (let nodeId in allNodes) { | ||
// allNodes[nodeId].color = "purple"; | ||
allNodes[nodeId].color = nodeColors[nodeId]; | ||
// delete allNodes[nodeId].color; | ||
if (allNodes[nodeId].hiddenLabel !== undefined) { | ||
allNodes[nodeId].label = allNodes[nodeId].hiddenLabel; | ||
allNodes[nodeId].hiddenLabel = undefined; | ||
} | ||
} | ||
highlightActive = false; | ||
} | ||
|
||
// transform the object into an array | ||
var updateArray = []; | ||
if (params.nodes.length > 0) { | ||
for (let nodeId in allNodes) { | ||
if (allNodes.hasOwnProperty(nodeId)) { | ||
// console.log(allNodes[nodeId]); | ||
updateArray.push(allNodes[nodeId]); | ||
} | ||
} | ||
nodes.update(updateArray); | ||
} else { | ||
// console.log("Nothing was selected"); | ||
for (let nodeId in allNodes) { | ||
if (allNodes.hasOwnProperty(nodeId)) { | ||
// console.log(allNodes[nodeId]); | ||
// allNodes[nodeId].color = {}; | ||
updateArray.push(allNodes[nodeId]); | ||
} | ||
} | ||
nodes.update(updateArray); | ||
} | ||
} | ||
|
||
function filterHighlight(params) { | ||
allNodes = nodes.get({ returnType: "Object" }); | ||
// if something is selected: | ||
if (params.nodes.length > 0) { | ||
filterActive = true; | ||
let selectedNodes = params.nodes; | ||
|
||
// hiding all nodes and saving the label | ||
for (let nodeId in allNodes) { | ||
allNodes[nodeId].hidden = true; | ||
if (allNodes[nodeId].savedLabel === undefined) { | ||
allNodes[nodeId].savedLabel = allNodes[nodeId].label; | ||
allNodes[nodeId].label = undefined; | ||
} | ||
} | ||
|
||
for (let i=0; i < selectedNodes.length; i++) { | ||
allNodes[selectedNodes[i]].hidden = false; | ||
if (allNodes[selectedNodes[i]].savedLabel !== undefined) { | ||
allNodes[selectedNodes[i]].label = allNodes[selectedNodes[i]].savedLabel; | ||
allNodes[selectedNodes[i]].savedLabel = undefined; | ||
} | ||
} | ||
|
||
} else if (filterActive === true) { | ||
// reset all nodes | ||
for (let nodeId in allNodes) { | ||
allNodes[nodeId].hidden = false; | ||
if (allNodes[nodeId].savedLabel !== undefined) { | ||
allNodes[nodeId].label = allNodes[nodeId].savedLabel; | ||
allNodes[nodeId].savedLabel = undefined; | ||
} | ||
} | ||
filterActive = false; | ||
} | ||
|
||
// transform the object into an array | ||
var updateArray = []; | ||
if (params.nodes.length > 0) { | ||
for (let nodeId in allNodes) { | ||
if (allNodes.hasOwnProperty(nodeId)) { | ||
updateArray.push(allNodes[nodeId]); | ||
} | ||
} | ||
nodes.update(updateArray); | ||
} else { | ||
for (let nodeId in allNodes) { | ||
if (allNodes.hasOwnProperty(nodeId)) { | ||
updateArray.push(allNodes[nodeId]); | ||
} | ||
} | ||
nodes.update(updateArray); | ||
} | ||
} | ||
|
||
function selectNode(nodes) { | ||
network.selectNodes(nodes); | ||
neighbourhoodHighlight({ nodes: nodes }); | ||
return nodes; | ||
} | ||
|
||
function selectNodes(nodes) { | ||
network.selectNodes(nodes); | ||
filterHighlight({nodes: nodes}); | ||
return nodes; | ||
} | ||
|
||
function highlightFilter(filter) { | ||
let selectedNodes = [] | ||
let selectedProp = filter['property'] | ||
if (filter['item'] === 'node') { | ||
let allNodes = nodes.get({ returnType: "Object" }); | ||
for (let nodeId in allNodes) { | ||
if (allNodes[nodeId][selectedProp] && filter['value'].includes((allNodes[nodeId][selectedProp]).toString())) { | ||
selectedNodes.push(nodeId) | ||
} | ||
} | ||
} | ||
else if (filter['item'] === 'edge'){ | ||
let allEdges = edges.get({returnType: 'object'}); | ||
// check if the selected property exists for selected edge and select the nodes connected to the edge | ||
for (let edge in allEdges) { | ||
if (allEdges[edge][selectedProp] && filter['value'].includes((allEdges[edge][selectedProp]).toString())) { | ||
selectedNodes.push(allEdges[edge]['from']) | ||
selectedNodes.push(allEdges[edge]['to']) | ||
} | ||
} | ||
} | ||
selectNodes(selectedNodes) | ||
}</script> | ||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/vis-network/9.1.2/dist/dist/vis-network.min.css" integrity="sha512-WgxfT5LWjfszlPHXRmBWHkV2eceiWTOBvrKCNbdgDYTHrT2AeLCGbF4sZlZw3UMN3WtL0tGUoIAKsu8mllg/XA==" crossorigin="anonymous" referrerpolicy="no-referrer" /> | ||
<script src="https://cdnjs.cloudflare.com/ajax/libs/vis-network/9.1.2/dist/vis-network.min.js" integrity="sha512-LnvoEWDFrqGHlHmDD2101OrLcbsfkrzoSpvtSQtxK3RMnRV0eOkhhBN2dXHKRrUU8p2DGRTk35n4O8nWSVe1mQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script> | ||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<center> | ||
<h1></h1> | ||
</center> | ||
|
||
<!-- <link rel="stylesheet" href="../node_modules/vis/dist/vis.min.css" type="text/css" /> | ||
<script type="text/javascript" src="../node_modules/vis/dist/vis.js"> </script>--> | ||
<link | ||
href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" | ||
rel="stylesheet" | ||
integrity="sha384-eOJMYsd53ii+scO/bJGFsiCZc+5NDVN2yr8+0RDqr0Ql0h+rP48ckxlpbzKgwra6" | ||
crossorigin="anonymous" | ||
/> | ||
<script | ||
src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js" | ||
integrity="sha384-JEW9xMcG8R+pH31jmWH6WWP0WintQrMb4s7ZOdauHnUtxwoG2vI5DkLtS3qm9Ekf" | ||
crossorigin="anonymous" | ||
></script> | ||
|
||
|
||
<center> | ||
<h1></h1> | ||
</center> | ||
<style type="text/css"> | ||
|
||
#mynetwork { | ||
width: 100%; | ||
height: 600px; | ||
background-color: #ffffff; | ||
border: 1px solid lightgray; | ||
position: relative; | ||
float: left; | ||
} | ||
|
||
|
||
|
||
|
||
|
||
|
||
</style> | ||
</head> | ||
|
||
|
||
<body> | ||
<div class="card" style="width: 100%"> | ||
|
||
|
||
<div id="mynetwork" class="card-body"></div> | ||
</div> | ||
|
||
|
||
|
||
|
||
<script type="text/javascript"> | ||
|
||
// initialize global variables. | ||
var edges; | ||
var nodes; | ||
var allNodes; | ||
var allEdges; | ||
var nodeColors; | ||
var originalNodes; | ||
var network; | ||
var container; | ||
var options, data; | ||
var filter = { | ||
item : '', | ||
property : '', | ||
value : [] | ||
}; | ||
|
||
|
||
|
||
|
||
|
||
// This method is responsible for drawing the graph, returns the drawn network | ||
function drawGraph() { | ||
var container = document.getElementById('mynetwork'); | ||
|
||
|
||
|
||
// parsing and collecting nodes and edges from the python | ||
nodes = new vis.DataSet([{"borderWidth": 3, "color": null, "id": 0, "label": "init", "shape": "dot"}, {"borderWidth": 1, "color": null, "id": 1, "label": "studied", "shape": "dot"}, {"borderWidth": 1, "color": null, "id": 2, "label": "didn\u0027t study", "shape": "dot"}, {"borderWidth": 1, "color": null, "id": 3, "label": "pass test", "shape": "dot"}, {"borderWidth": 1, "color": null, "id": 4, "label": "fail test", "shape": "dot"}, {"color": null, "id": 100000000, "label": "study", "shape": "box"}, {"color": null, "id": 100000001, "label": "don\u0027t study", "shape": "box"}]); | ||
edges = new vis.DataSet([{"arrows": "to", "color": "red", "from": 0, "to": 100000000}, {"arrows": "to", "color": "red", "from": 100000000, "label": "1", "to": 1}, {"arrows": "to", "color": "red", "from": 0, "to": 100000001}, {"arrows": "to", "color": "red", "from": 100000001, "label": "1", "to": 2}, {"arrows": "to", "color": "red", "from": 1, "label": "9/10", "to": 3}, {"arrows": "to", "color": "red", "from": 1, "label": "1/10", "to": 4}, {"arrows": "to", "color": "red", "from": 2, "label": "2/5", "to": 3}, {"arrows": "to", "color": "red", "from": 2, "label": "3/5", "to": 4}, {"arrows": "to", "color": "red", "from": 3, "label": "1", "to": 3}, {"arrows": "to", "color": "red", "from": 4, "label": "1", "to": 4}]); | ||
|
||
nodeColors = {}; | ||
allNodes = nodes.get({ returnType: "Object" }); | ||
for (nodeId in allNodes) { | ||
nodeColors[nodeId] = allNodes[nodeId].color; | ||
} | ||
allEdges = edges.get({ returnType: "Object" }); | ||
// adding nodes and edges to the graph | ||
data = {nodes: nodes, edges: edges}; | ||
|
||
var options = {"nodes": {"color": {"background": "white", "border": "black"}}, "physics": {"barnesHut": {"gravitationalConstant": -22660, "centralGravity": 4.5, "springLength": 50, "springConstant": 0.08, "damping": 0.32, "avoidOverlap": 1}, "minVelocity": 0.75}}; | ||
|
||
|
||
|
||
|
||
|
||
|
||
network = new vis.Network(container, data, options); | ||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
return network; | ||
|
||
} | ||
drawGraph(); | ||
</script> | ||
</body> | ||
</html> |
Oops, something went wrong.