Merge branch 'atree' of github.com:hppeng-wynn/hppeng-wynn.github.io into atree
This commit is contained in:
commit
a7be5e15be
5 changed files with 6651 additions and 1682 deletions
File diff suppressed because it is too large
Load diff
File diff suppressed because one or more lines are too long
4160
js/atree_constants_str_old.js
Normal file
4160
js/atree_constants_str_old.js
Normal file
File diff suppressed because it is too large
Load diff
1
js/atree_constants_str_old_min.js
Normal file
1
js/atree_constants_str_old_min.js
Normal file
File diff suppressed because one or more lines are too long
|
@ -18,7 +18,7 @@ function construct_AT(elem, tree) {
|
||||||
atree_map = new Map();
|
atree_map = new Map();
|
||||||
atree_connectors_map = new Map()
|
atree_connectors_map = new Map()
|
||||||
for (let i of tree) {
|
for (let i of tree) {
|
||||||
atree_map.set(i.display_name, {display: i.display, parents: i.parents, connectors: new Map(), active: false});
|
atree_map.set(i.id, {display: i.display, parents: i.parents, connectors: new Map(), active: false});
|
||||||
}
|
}
|
||||||
|
|
||||||
for (let i = 0; i < tree.length; i++) {
|
for (let i = 0; i < tree.length; i++) {
|
||||||
|
@ -33,7 +33,7 @@ function construct_AT(elem, tree) {
|
||||||
}
|
}
|
||||||
|
|
||||||
for (let parent of node.parents) {
|
for (let parent of node.parents) {
|
||||||
missing_rows.push(tree.find(object => {return object.display_name === parent;}).display.row);
|
missing_rows.push(tree.find(object => {return object.id === parent;}).display.row);
|
||||||
}
|
}
|
||||||
for (let missing_row of missing_rows) {
|
for (let missing_row of missing_rows) {
|
||||||
if (document.getElementById("atree-row-" + missing_row) == null) {
|
if (document.getElementById("atree-row-" + missing_row) == null) {
|
||||||
|
@ -63,7 +63,7 @@ function construct_AT(elem, tree) {
|
||||||
|
|
||||||
// create connectors based on parent location
|
// create connectors based on parent location
|
||||||
for (let parent of node.parents) {
|
for (let parent of node.parents) {
|
||||||
atree_map.get(node.display_name).connectors.set(parent, []);
|
atree_map.get(node.id).connectors.set(parent, []);
|
||||||
|
|
||||||
let parent_node = atree_map.get(parent);
|
let parent_node = atree_map.get(parent);
|
||||||
|
|
||||||
|
@ -73,8 +73,8 @@ function construct_AT(elem, tree) {
|
||||||
for (let i = node.display.row - 1; i > parent_node.display.row; i--) {
|
for (let i = node.display.row - 1; i > parent_node.display.row; i--) {
|
||||||
let connector = connect_elem.cloneNode();
|
let connector = connect_elem.cloneNode();
|
||||||
connector.style.backgroundImage = "url('../media/atree/connect_line.png')";
|
connector.style.backgroundImage = "url('../media/atree/connect_line.png')";
|
||||||
atree_map.get(node.display_name).connectors.get(parent).push(i + "," + node.display.col);
|
atree_map.get(node.id).connectors.get(parent).push(i + "," + node.display.col);
|
||||||
atree_connectors_map.get(i + "," + node.display.col).push({connector: connector, type: "line", owner: [node.display_name, parent]});
|
atree_connectors_map.get(i + "," + node.display.col).push({connector: connector, type: "line", owner: [node.id, parent]});
|
||||||
resolve_connector(i + "," + node.display.col, node);
|
resolve_connector(i + "," + node.display.col, node);
|
||||||
}
|
}
|
||||||
// connect horizontally
|
// connect horizontally
|
||||||
|
@ -84,8 +84,8 @@ function construct_AT(elem, tree) {
|
||||||
let connector = connect_elem.cloneNode();
|
let connector = connect_elem.cloneNode();
|
||||||
connector.style.backgroundImage = "url('../media/atree/connect_line.png')";
|
connector.style.backgroundImage = "url('../media/atree/connect_line.png')";
|
||||||
connector.classList.add("rotate-90");
|
connector.classList.add("rotate-90");
|
||||||
atree_map.get(node.display_name).connectors.get(parent).push(parent_node.display.row + "," + i);
|
atree_map.get(node.id).connectors.get(parent).push(parent_node.display.row + "," + i);
|
||||||
atree_connectors_map.get(parent_node.display.row + "," + i).push({connector: connector, type: "line", owner: [node.display_name, parent]});
|
atree_connectors_map.get(parent_node.display.row + "," + i).push({connector: connector, type: "line", owner: [node.id, parent]});
|
||||||
resolve_connector(parent_node.display.row + "," + i, node);
|
resolve_connector(parent_node.display.row + "," + i, node);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,8 +94,8 @@ function construct_AT(elem, tree) {
|
||||||
if (parent_node.display.row != node.display.row && parent_node.display.col != node.display.col) {
|
if (parent_node.display.row != node.display.row && parent_node.display.col != node.display.col) {
|
||||||
let connector = connect_elem.cloneNode();
|
let connector = connect_elem.cloneNode();
|
||||||
connector.style.backgroundImage = "url('../media/atree/connect_angle.png')";
|
connector.style.backgroundImage = "url('../media/atree/connect_angle.png')";
|
||||||
atree_map.get(node.display_name).connectors.get(parent).push(parent_node.display.row + "," + node.display.col);
|
atree_map.get(node.id).connectors.get(parent).push(parent_node.display.row + "," + node.display.col);
|
||||||
atree_connectors_map.get(parent_node.display.row + "," + node.display.col).push({connector: connector, type: "angle", owner: [node.display_name, parent]});
|
atree_connectors_map.get(parent_node.display.row + "," + node.display.col).push({connector: connector, type: "angle", owner: [node.id, parent]});
|
||||||
if (parent_node.display.col > node.display.col) {
|
if (parent_node.display.col > node.display.col) {
|
||||||
connector.classList.add("rotate-180");
|
connector.classList.add("rotate-180");
|
||||||
}
|
}
|
||||||
|
@ -153,7 +153,7 @@ function construct_AT(elem, tree) {
|
||||||
|
|
||||||
node_tooltip = active_tooltip.cloneNode(true);
|
node_tooltip = active_tooltip.cloneNode(true);
|
||||||
|
|
||||||
active_tooltip.id = "atree-ab-" + node.display_name.replaceAll(" ", "");
|
active_tooltip.id = "atree-ab-" + node.id;
|
||||||
|
|
||||||
node_tooltip.style.position = "absolute";
|
node_tooltip.style.position = "absolute";
|
||||||
node_tooltip.style.zIndex = "100";
|
node_tooltip.style.zIndex = "100";
|
||||||
|
@ -163,7 +163,7 @@ function construct_AT(elem, tree) {
|
||||||
|
|
||||||
node_elem.addEventListener('click', function(e) {
|
node_elem.addEventListener('click', function(e) {
|
||||||
if (e.target !== this) {return;};
|
if (e.target !== this) {return;};
|
||||||
let tooltip = document.getElementById("atree-ab-" + node.display_name.replaceAll(" ", ""));
|
let tooltip = document.getElementById("atree-ab-" + node.id);
|
||||||
if (tooltip.style.display == "block") {
|
if (tooltip.style.display == "block") {
|
||||||
tooltip.style.display = "none";
|
tooltip.style.display = "none";
|
||||||
this.classList.remove("atree-selected");
|
this.classList.remove("atree-selected");
|
||||||
|
@ -228,6 +228,7 @@ function atree_same_row(node) {
|
||||||
// draw the connector onto the screen
|
// draw the connector onto the screen
|
||||||
function atree_render_connection() {
|
function atree_render_connection() {
|
||||||
for (let i of atree_connectors_map.keys()) {
|
for (let i of atree_connectors_map.keys()) {
|
||||||
|
if (document.getElementById("atree-row-" + i.split(",")[0]).children[i.split(",")[1]].children.length != 0) {continue;}
|
||||||
if (atree_connectors_map.get(i).length != 0) {
|
if (atree_connectors_map.get(i).length != 0) {
|
||||||
document.getElementById("atree-row-" + i.split(",")[0]).children[i.split(",")[1]].appendChild(atree_connectors_map.get(i)[0].connector);
|
document.getElementById("atree-row-" + i.split(",")[0]).children[i.split(",")[1]].appendChild(atree_connectors_map.get(i)[0].connector);
|
||||||
};
|
};
|
||||||
|
@ -236,10 +237,10 @@ function atree_render_connection() {
|
||||||
|
|
||||||
// toggle the state of a node.
|
// toggle the state of a node.
|
||||||
function atree_toggle_state(node) {
|
function atree_toggle_state(node) {
|
||||||
if (atree_map.get(node.display_name).active) {
|
if (atree_map.get(node.id).active) {
|
||||||
atree_map.get(node.display_name).active = false;
|
atree_map.get(node.id).active = false;
|
||||||
} else {
|
} else {
|
||||||
atree_map.get(node.display_name).active = true;
|
atree_map.get(node.id).active = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue