mirror of
https://github.com/comfyanonymous/ComfyUI.git
synced 2025-01-12 19:05:16 +00:00
90aebb6c86
* menu * wip * wip * wip * wip * wip * workflow saving/loading * Support inserting workflows Move buttosn to top of lists * fix session storage implement renaming * temp * refactor, better workflow instance management * wip * progress on progress * added send to workflow various fixes * Support multiple image loaders * Support dynamic size breakpoints based on content * various fixes add close unsaved warning * Add filtering tree * prevent renaming unsaved * fix zindex on hover * fix top offset * use filename as workflow name * resize on setting change * hide element until it is drawn * remove glow * Fix export name * Fix test, revert accidental changes to groupNode * Fix colors on all themes * show hover items on smaller screen (mobile) * remove debugging code * dialog fix * Dont reorder open workflows Allow elements around canvas * Toggle body display on setting change * Fix menu disappearing on chrome * Increase delay when typing, remove margin on Safari, fix dialog location * Fix overflow issue on iOS * Add reset view button Prevent view changes causing history entries * Bottom menu wip * Various fixes * Fix merge * Fix breaking old menu position * Fix merge adding restore view to loadGraphData
94 lines
2.4 KiB
JavaScript
94 lines
2.4 KiB
JavaScript
// @ts-check
|
|
|
|
import { ComfyButton } from "../components/button.js";
|
|
import { $el } from "../../ui.js";
|
|
import { api } from "../../api.js";
|
|
import { ComfySplitButton } from "../components/splitButton.js";
|
|
import { ComfyQueueOptions } from "./queueOptions.js";
|
|
import { prop } from "../../utils.js";
|
|
|
|
export class ComfyQueueButton {
|
|
element = $el("div.comfyui-queue-button");
|
|
#internalQueueSize = 0;
|
|
|
|
queuePrompt = async (e) => {
|
|
this.#internalQueueSize += this.queueOptions.batchCount;
|
|
// Hold shift to queue front
|
|
await this.app.queuePrompt(-e.shiftKey, this.queueOptions.batchCount);
|
|
};
|
|
|
|
constructor(app) {
|
|
this.app = app;
|
|
this.queueSizeElement = $el("span.comfyui-queue-count", {
|
|
textContent: "?",
|
|
});
|
|
|
|
const queue = new ComfyButton({
|
|
content: $el("div", [
|
|
$el("span", {
|
|
textContent: "Queue",
|
|
}),
|
|
this.queueSizeElement,
|
|
]),
|
|
icon: "play",
|
|
classList: "comfyui-button",
|
|
action: this.queuePrompt,
|
|
});
|
|
|
|
this.queueOptions = new ComfyQueueOptions(app);
|
|
|
|
const btn = new ComfySplitButton(
|
|
{
|
|
primary: queue,
|
|
mode: "click",
|
|
position: "absolute",
|
|
horizontal: "right",
|
|
},
|
|
this.queueOptions.element
|
|
);
|
|
btn.element.classList.add("primary");
|
|
this.element.append(btn.element);
|
|
|
|
this.autoQueueMode = prop(this, "autoQueueMode", "", () => {
|
|
switch (this.autoQueueMode) {
|
|
case "instant":
|
|
queue.icon = "infinity";
|
|
break;
|
|
case "change":
|
|
queue.icon = "auto-mode";
|
|
break;
|
|
default:
|
|
queue.icon = "play";
|
|
break;
|
|
}
|
|
});
|
|
|
|
this.queueOptions.addEventListener("autoQueueMode", (e) => (this.autoQueueMode = e["detail"]));
|
|
|
|
api.addEventListener("graphChanged", () => {
|
|
if (this.autoQueueMode === "change") {
|
|
if (this.#internalQueueSize) {
|
|
this.graphHasChanged = true;
|
|
} else {
|
|
this.graphHasChanged = false;
|
|
this.queuePrompt();
|
|
}
|
|
}
|
|
});
|
|
|
|
api.addEventListener("status", ({ detail }) => {
|
|
this.#internalQueueSize = detail?.exec_info?.queue_remaining;
|
|
if (this.#internalQueueSize != null) {
|
|
this.queueSizeElement.textContent = this.#internalQueueSize > 99 ? "99+" : this.#internalQueueSize + "";
|
|
this.queueSizeElement.title = `${this.#internalQueueSize} prompts in queue`;
|
|
if (!this.#internalQueueSize && !app.lastExecutionError) {
|
|
if (this.autoQueueMode === "instant" || (this.autoQueueMode === "change" && this.graphHasChanged)) {
|
|
this.graphHasChanged = false;
|
|
this.queuePrompt();
|
|
}
|
|
}
|
|
}
|
|
});
|
|
}
|
|
}
|