keybinds.js 2.12 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import { app } from "/scripts/app.js";

const id = "Comfy.Keybinds";
app.registerExtension({
	name: id,
	init() {
		const keybindListener = function(event) {
			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;
			}

16
17
18
19
20
21
			const target = event.composedPath()[0];

			if (target.tagName === "INPUT" || target.tagName === "TEXTAREA") {
				return;
			}

22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
			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);
	}
});