| import { app } from "../../../scripts/app.js"; |
| import { api } from "../../../scripts/api.js"; |
|
|
| |
| |
| |
|
|
| app.registerExtension({ |
| name: "pysssss.NodeFinder", |
| setup() { |
| let followExecution = false; |
|
|
| const centerNode = (id) => { |
| if (!followExecution || !id) return; |
| const node = app.graph.getNodeById(id); |
| if (!node) return; |
| app.canvas.centerOnNode(node); |
| }; |
|
|
| api.addEventListener("executing", ({ detail }) => centerNode(detail)); |
|
|
| |
| const orig = LGraphCanvas.prototype.getCanvasMenuOptions; |
| LGraphCanvas.prototype.getCanvasMenuOptions = function () { |
| const options = orig.apply(this, arguments); |
| options.push(null, { |
| content: followExecution ? "Stop following execution" : "Follow execution", |
| callback: () => { |
| if ((followExecution = !followExecution)) { |
| centerNode(app.runningNodeId); |
| } |
| }, |
| }); |
| if (app.runningNodeId) { |
| options.push({ |
| content: "Show executing node", |
| callback: () => { |
| const node = app.graph.getNodeById(app.runningNodeId); |
| if (!node) return; |
| app.canvas.centerOnNode(node); |
| }, |
| }); |
| } |
|
|
| const nodes = app.graph._nodes; |
| const types = nodes.reduce((p, n) => { |
| if (n.type in p) { |
| p[n.type].push(n); |
| } else { |
| p[n.type] = [n]; |
| } |
| return p; |
| }, {}); |
| options.push({ |
| content: "Go to node", |
| has_submenu: true, |
| submenu: { |
| options: Object.keys(types) |
| .sort() |
| .map((t) => ({ |
| content: t, |
| has_submenu: true, |
| submenu: { |
| options: types[t] |
| .sort((a, b) => { |
| return a.pos[0] - b.pos[0]; |
| }) |
| .map((n) => ({ |
| content: `${n.getTitle()} - #${n.id} (${n.pos[0]}, ${n.pos[1]})`, |
| callback: () => { |
| app.canvas.centerOnNode(n); |
| }, |
| })), |
| }, |
| })), |
| }, |
| }); |
|
|
| return options; |
| }; |
| }, |
| }); |
|
|