|
|
|
|
|
import { app } from "../../scripts/app.js";
|
|
|
import type {
|
|
|
LGraphCanvas as TLGraphCanvas,
|
|
|
ContextMenuItem,
|
|
|
LGraphNode,
|
|
|
LiteGraph as TLiteGraph,
|
|
|
} from "typings/litegraph.js";
|
|
|
import type { ComfyNodeConstructor, ComfyObjectInfo } from "typings/comfy.js";
|
|
|
import { rgthree } from "./rgthree.js";
|
|
|
import { SERVICE as CONFIG_SERVICE } from "./config_service.js";
|
|
|
|
|
|
declare const LiteGraph: typeof TLiteGraph;
|
|
|
declare const LGraphCanvas: typeof TLGraphCanvas;
|
|
|
|
|
|
function getOutputNodesFromSelected(canvas: TLGraphCanvas) {
|
|
|
return (
|
|
|
(canvas.selected_nodes &&
|
|
|
Object.values(canvas.selected_nodes).filter((n) => {
|
|
|
return (
|
|
|
n.mode != LiteGraph.NEVER &&
|
|
|
((n.constructor as any).nodeData as ComfyObjectInfo)?.output_node
|
|
|
);
|
|
|
})) ||
|
|
|
[]
|
|
|
);
|
|
|
}
|
|
|
|
|
|
function showQueueNodesMenuIfOutputNodesAreSelected(
|
|
|
existingOptions: ContextMenuItem[],
|
|
|
node?: LGraphNode,
|
|
|
) {
|
|
|
if (CONFIG_SERVICE.getConfigValue("features.menu_queue_selected_nodes") != false) {
|
|
|
const canvas = app.canvas as TLGraphCanvas;
|
|
|
const outputNodes = getOutputNodesFromSelected(canvas);
|
|
|
const menuItem = {
|
|
|
content: `Queue Selected Output Nodes (rgthree) `,
|
|
|
className: "rgthree-contextmenu-item",
|
|
|
callback: () => {
|
|
|
rgthree.queueOutputNodes(outputNodes.map((n) => n.id));
|
|
|
},
|
|
|
disabled: !outputNodes.length,
|
|
|
};
|
|
|
|
|
|
let idx = existingOptions.findIndex((o) => o?.content === "Outputs") + 1;
|
|
|
idx = idx || existingOptions.findIndex((o) => o?.content === "Align") + 1;
|
|
|
idx = idx || 3;
|
|
|
existingOptions.splice(idx, 0, menuItem);
|
|
|
}
|
|
|
return existingOptions;
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
app.registerExtension({
|
|
|
name: "rgthree.QueueNode",
|
|
|
async beforeRegisterNodeDef(nodeType: ComfyNodeConstructor, nodeData: ComfyObjectInfo) {
|
|
|
const getExtraMenuOptions = nodeType.prototype.getExtraMenuOptions;
|
|
|
nodeType.prototype.getExtraMenuOptions = function (
|
|
|
canvas: TLGraphCanvas,
|
|
|
options: ContextMenuItem[],
|
|
|
) {
|
|
|
getExtraMenuOptions ? getExtraMenuOptions.apply(this, arguments) : undefined;
|
|
|
showQueueNodesMenuIfOutputNodesAreSelected(options, this);
|
|
|
};
|
|
|
},
|
|
|
|
|
|
async setup() {
|
|
|
const getCanvasMenuOptions = LGraphCanvas.prototype.getCanvasMenuOptions;
|
|
|
LGraphCanvas.prototype.getCanvasMenuOptions = function (...args: any[]) {
|
|
|
const options = getCanvasMenuOptions.apply(this, [...args] as any);
|
|
|
showQueueNodesMenuIfOutputNodesAreSelected(options);
|
|
|
return options;
|
|
|
};
|
|
|
},
|
|
|
});
|
|
|
|