Skip to content

Commit

Permalink
refa: remove view
Browse files Browse the repository at this point in the history
  • Loading branch information
Myllaume committed Sep 15, 2024
1 parent 63b4480 commit b5cd943
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 27 deletions.
38 changes: 19 additions & 19 deletions core/frontend/graph.js
Original file line number Diff line number Diff line change
Expand Up @@ -433,6 +433,8 @@ function hideNodesAll() {
}));
}

let highlightedNodes = [];

/**
* Apply highlightColor (from config) to somes nodes and their links
* @param {string[]|number[]} nodeIds - List of nodes ids
Expand All @@ -447,27 +449,27 @@ function highlightNodes(nodeIds) {
links.nodes().forEach((elt) => elt.classList.add('highlight'));
});

View.highlightedNodes = View.highlightedNodes.concat(nodeIds);
highlightedNodes = highlightedNodes.concat(nodeIds);
}

/**
* remove highlightColor from all highlighted nodes and their links
*/

function unlightNodes() {
if (View.highlightedNodes.length === 0) {
if (highlightedNodes.length === 0) {
return;
}

View.highlightedNodes
highlightedNodes
.filter((nodeId) => graph.hasNode(nodeId))
.forEach((nodeId) => {
const { links, node } = getNodeNetwork(nodeId);
node.node().classList.remove('highlight');
links.nodes().forEach((elt) => elt.classList.remove('highlight'));
});

View.highlightedNodes = [];
highlightedNodes = [];
}

/**
Expand Down Expand Up @@ -513,7 +515,7 @@ function translate() {
const screenWidth = window.innerWidth;
const screenHeight = window.innerHeight;

const { x, y, zoom } = View.position;
const { x, y, zoom } = position;

const screenMin = d3.min([screenHeight, screenWidth]);

Expand Down Expand Up @@ -554,35 +556,34 @@ window.addEventListener('resize', () => {
zoomInterval = Math.log2(density);
});

const position = { x: 0, y: 0, zoom: 1 };

const zoom = d3
.zoom()
.scaleExtent([zoomMin, zoomMax])
.on('zoom', (e) => {
const { x, y, k } = e.transform;
View.position.x = x || 0;
View.position.y = y || 0;
View.position.zoom = k || 1;
position.x = x || 0;
position.y = y || 0;
position.zoom = k || 1;
translate();
});

svg.call(zoom);

function zoomMore() {
zoom.scaleTo(svg, View.position.zoom + zoomInterval);
zoom.scaleTo(svg, position.zoom + zoomInterval);
}

function zoomLess() {
zoom.scaleTo(svg, View.position.zoom - zoomInterval);
zoom.scaleTo(svg, position.zoom - zoomInterval);
}

function zoomReset() {
View.position.zoom = 1;
View.position.x = 0;
View.position.y = 0;
svg.call(
zoom.transform,
d3.zoomIdentity.translate(View.position.y, View.position.x).scale(View.position.zoom),
);
position.zoom = 1;
position.x = 0;
position.y = 0;
svg.call(zoom.transform, d3.zoomIdentity.translate(position.y, position.x).scale(position.zoom));
translate();
}

Expand Down Expand Up @@ -612,8 +613,7 @@ function zoomToNode(nodeId) {
const meanX = d3.mean(nodes, (d) => d.x);
const meanY = d3.mean(nodes, (d) => d.y);

const zoomScale =
View.position.zoom === 1 ? View.position.zoom + zoomInterval * 2 : View.position.zoom;
const zoomScale = position.zoom === 1 ? position.zoom + zoomInterval * 2 : position.zoom;

svg.call(
zoom.transform,
Expand Down
8 changes: 0 additions & 8 deletions core/frontend/view.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,3 @@
export default class View {
static highlightedNodes = [];

static focusMode = false;

static position = { x: 0, y: 0, zoom: 1 };
}

window.addEventListener('DOMContentLoaded', () => {
document.getElementById('view-save').addEventListener('click', () => {
const url = new URL(window.location);
Expand Down

0 comments on commit b5cd943

Please sign in to comment.