|
import { app } from "../../../scripts/app.js";
|
|
|
|
app.registerExtension({
|
|
name: "pysssss.GraphArrange",
|
|
setup(app) {
|
|
const orig = LGraphCanvas.prototype.getCanvasMenuOptions;
|
|
LGraphCanvas.prototype.getCanvasMenuOptions = function () {
|
|
const options = orig.apply(this, arguments);
|
|
options.push({ content: "Arrange (float left)", callback: () => graph.arrange() });
|
|
options.push({
|
|
content: "Arrange (float right)",
|
|
callback: () => {
|
|
(function () {
|
|
var margin = 50;
|
|
var layout;
|
|
|
|
const nodes = this.computeExecutionOrder(false, true);
|
|
const columns = [];
|
|
|
|
|
|
for (let i = nodes.length - 1; i >= 0; i--) {
|
|
const node = nodes[i];
|
|
let max = null;
|
|
for (const out of node.outputs || []) {
|
|
if (out.links) {
|
|
for (const link of out.links) {
|
|
const outNode = app.graph.getNodeById(app.graph.links[link].target_id);
|
|
if (!outNode) continue;
|
|
var l = outNode._level - 1;
|
|
if (max === null) max = l;
|
|
else if (l < max) max = l;
|
|
}
|
|
}
|
|
}
|
|
if (max != null) node._level = max;
|
|
}
|
|
|
|
for (let i = 0; i < nodes.length; ++i) {
|
|
const node = nodes[i];
|
|
const col = node._level || 1;
|
|
if (!columns[col]) {
|
|
columns[col] = [];
|
|
}
|
|
columns[col].push(node);
|
|
}
|
|
|
|
let x = margin;
|
|
|
|
for (let i = 0; i < columns.length; ++i) {
|
|
const column = columns[i];
|
|
if (!column) {
|
|
continue;
|
|
}
|
|
column.sort((a, b) => {
|
|
var as = !(a.type === "SaveImage" || a.type === "PreviewImage");
|
|
var bs = !(b.type === "SaveImage" || b.type === "PreviewImage");
|
|
var r = as - bs;
|
|
if (r === 0) r = (a.inputs?.length || 0) - (b.inputs?.length || 0);
|
|
if (r === 0) r = (a.outputs?.length || 0) - (b.outputs?.length || 0);
|
|
return r;
|
|
});
|
|
let max_size = 100;
|
|
let y = margin + LiteGraph.NODE_TITLE_HEIGHT;
|
|
for (let j = 0; j < column.length; ++j) {
|
|
const node = column[j];
|
|
node.pos[0] = layout == LiteGraph.VERTICAL_LAYOUT ? y : x;
|
|
node.pos[1] = layout == LiteGraph.VERTICAL_LAYOUT ? x : y;
|
|
const max_size_index = layout == LiteGraph.VERTICAL_LAYOUT ? 1 : 0;
|
|
if (node.size[max_size_index] > max_size) {
|
|
max_size = node.size[max_size_index];
|
|
}
|
|
const node_size_index = layout == LiteGraph.VERTICAL_LAYOUT ? 0 : 1;
|
|
y += node.size[node_size_index] + margin + LiteGraph.NODE_TITLE_HEIGHT + j;
|
|
}
|
|
|
|
|
|
for (let j = 0; j < column.length; ++j) {
|
|
const node = column[j];
|
|
node.pos[0] += max_size - node.size[0];
|
|
}
|
|
x += max_size + margin;
|
|
}
|
|
|
|
this.setDirtyCanvas(true, true);
|
|
}).apply(app.graph);
|
|
},
|
|
});
|
|
return options;
|
|
};
|
|
},
|
|
});
|
|
|