mirror of
https://github.com/comfyanonymous/ComfyUI.git
synced 2025-01-11 18:35:17 +00:00
bc16b70bde
* adds keybinds that interact w/ comfy menu * adds remaining keybinds * adds keybinds to readme and converts to table * ctrl s and o save and open workflow * moves keybinds to sep file, update readme * remap load default, support keycodes * update keybinds table, prepends comfy to ids * escape exits out of modals * modifier keys also use map * adds setting for filename prompt * better handle filename prompt Co-authored-by: missionfloyd <missionfloyd@users.noreply.github.com>
77 lines
2.1 KiB
JavaScript
77 lines
2.1 KiB
JavaScript
import { app } from "/scripts/app.js";
|
|
|
|
const id = "Comfy.Keybinds";
|
|
app.registerExtension({
|
|
name: id,
|
|
init() {
|
|
const keybindListener = function(event) {
|
|
const target = event.composedPath()[0];
|
|
|
|
if (target.tagName === "INPUT" || target.tagName === "TEXTAREA") {
|
|
return;
|
|
}
|
|
|
|
const modifierPressed = event.ctrlKey || event.metaKey;
|
|
|
|
// Queue prompt using ctrl or command + enter
|
|
if (modifierPressed && (event.key === "Enter" || event.keyCode === 13 || event.keyCode === 10)) {
|
|
app.queuePrompt(event.shiftKey ? -1 : 0);
|
|
return;
|
|
}
|
|
|
|
const modifierKeyIdMap = {
|
|
"s": "#comfy-save-button",
|
|
83: "#comfy-save-button",
|
|
"o": "#comfy-file-input",
|
|
79: "#comfy-file-input",
|
|
"Backspace": "#comfy-clear-button",
|
|
8: "#comfy-clear-button",
|
|
"Delete": "#comfy-clear-button",
|
|
46: "#comfy-clear-button",
|
|
"d": "#comfy-load-default-button",
|
|
68: "#comfy-load-default-button",
|
|
};
|
|
|
|
const modifierKeybindId = modifierKeyIdMap[event.key] || modifierKeyIdMap[event.keyCode];
|
|
if (modifierPressed && modifierKeybindId) {
|
|
event.preventDefault();
|
|
|
|
const elem = document.querySelector(modifierKeybindId);
|
|
elem.click();
|
|
return;
|
|
}
|
|
|
|
// Finished Handling all modifier keybinds, now handle the rest
|
|
if (event.ctrlKey || event.altKey || event.metaKey) {
|
|
return;
|
|
}
|
|
|
|
// Close out of modals using escape
|
|
if (event.key === "Escape" || event.keyCode === 27) {
|
|
const modals = document.querySelectorAll(".comfy-modal");
|
|
const modal = Array.from(modals).find(modal => window.getComputedStyle(modal).getPropertyValue("display") !== "none");
|
|
if (modal) {
|
|
modal.style.display = "none";
|
|
}
|
|
}
|
|
|
|
const keyIdMap = {
|
|
"q": "#comfy-view-queue-button",
|
|
81: "#comfy-view-queue-button",
|
|
"h": "#comfy-view-history-button",
|
|
72: "#comfy-view-history-button",
|
|
"r": "#comfy-refresh-button",
|
|
82: "#comfy-refresh-button",
|
|
};
|
|
|
|
const buttonId = keyIdMap[event.key] || keyIdMap[event.keyCode];
|
|
if (buttonId) {
|
|
const button = document.querySelector(buttonId);
|
|
button.click();
|
|
}
|
|
}
|
|
|
|
window.addEventListener("keydown", keybindListener, true);
|
|
}
|
|
});
|