Style modals to match rest of UI

This commit is contained in:
missionfloyd 2023-04-05 15:56:41 -06:00
parent 30f274bf48
commit 1a74611c6e
2 changed files with 55 additions and 48 deletions

View File

@ -115,14 +115,6 @@ function dragElement(dragEl, settings) {
savePos = value; savePos = value;
}, },
}); });
settings.addSetting({
id: "Comfy.ConfirmClear",
name: "Require confirmation when clearing workflow",
type: "boolean",
defaultValue: true,
});
function dragMouseDown(e) { function dragMouseDown(e) {
e = e || window.event; e = e || window.event;
e.preventDefault(); e.preventDefault();
@ -170,7 +162,7 @@ class ComfyDialog {
$el("p", { $: (p) => (this.textElement = p) }), $el("p", { $: (p) => (this.textElement = p) }),
$el("button", { $el("button", {
type: "button", type: "button",
textContent: "CLOSE", textContent: "Close",
onclick: () => this.close(), onclick: () => this.close(),
}), }),
]), ]),
@ -233,6 +225,7 @@ class ComfySettingsDialog extends ComfyDialog {
}; };
let element; let element;
value = this.getSettingValue(id, defaultValue);
if (typeof type === "function") { if (typeof type === "function") {
element = type(name, setter, value, attrs); element = type(name, setter, value, attrs);
@ -289,6 +282,16 @@ class ComfySettingsDialog extends ComfyDialog {
return element; return element;
}, },
}); });
const self = this;
return {
get value() {
return self.getSettingValue(id, defaultValue);
},
set value(v) {
self.setSettingValue(id, v);
},
};
} }
show() { show() {
@ -410,6 +413,13 @@ export class ComfyUI {
this.history.update(); this.history.update();
}); });
const confirmClear = this.settings.addSetting({
id: "Comfy.ConfirmClear",
name: "Require confirmation when clearing workflow",
type: "boolean",
defaultValue: true,
});
const fileInput = $el("input", { const fileInput = $el("input", {
type: "file", type: "file",
accept: ".json,image/png", accept: ".json,image/png",
@ -517,13 +527,13 @@ export class ComfyUI {
$el("button", { textContent: "Load", onclick: () => fileInput.click() }), $el("button", { textContent: "Load", onclick: () => fileInput.click() }),
$el("button", { textContent: "Refresh", onclick: () => app.refreshComboInNodes() }), $el("button", { textContent: "Refresh", onclick: () => app.refreshComboInNodes() }),
$el("button", { textContent: "Clear", onclick: () => { $el("button", { textContent: "Clear", onclick: () => {
if (localStorage.getItem("Comfy.Settings.Comfy.ConfirmClear") == "false" || confirm("Clear workflow?")) { if (!confirmClear.value || confirm("Clear workflow?")) {
app.clean(); app.clean();
app.graph.clear(); app.graph.clear();
} }
}}), }}),
$el("button", { textContent: "Load Default", onclick: () => { $el("button", { textContent: "Load Default", onclick: () => {
if (localStorage.getItem("Comfy.Settings.Comfy.ConfirmClear") == "false" || confirm("Load default workflow?")) { if (!confirmClear.value || confirm("Load default workflow?")) {
app.loadGraphData() app.loadGraphData()
} }
}}), }}),

View File

@ -39,18 +39,19 @@ body {
position: fixed; /* Stay in place */ position: fixed; /* Stay in place */
z-index: 100; /* Sit on top */ z-index: 100; /* Sit on top */
padding: 30px 30px 10px 30px; padding: 30px 30px 10px 30px;
background-color: #ff0000; /* Modal background */ background-color: #353535; /* Modal background */
color: #ff4444;
box-shadow: 0px 0px 20px #888888; box-shadow: 0px 0px 20px #888888;
border-radius: 10px; border-radius: 10px;
text-align: center;
top: 50%; top: 50%;
left: 50%; left: 50%;
max-width: 80vw; max-width: 80vw;
max-height: 80vh; max-height: 80vh;
transform: translate(-50%, -50%); transform: translate(-50%, -50%);
overflow: hidden; overflow: hidden;
min-width: 60%;
justify-content: center; justify-content: center;
font-family: monospace;
font-size: 15px;
} }
.comfy-modal-content { .comfy-modal-content {
@ -70,23 +71,6 @@ body {
margin: 3px 3px 3px 4px; margin: 3px 3px 3px 4px;
} }
.comfy-modal button {
cursor: pointer;
color: #aaaaaa;
border: none;
background-color: transparent;
font-size: 24px;
font-weight: bold;
width: 100%;
}
.comfy-modal button:hover,
.comfy-modal button:focus {
color: #000;
text-decoration: none;
cursor: pointer;
}
.comfy-menu { .comfy-menu {
width: 200px; width: 200px;
font-size: 15px; font-size: 15px;
@ -109,7 +93,8 @@ body {
box-shadow: 3px 3px 8px rgba(0, 0, 0, 0.4); box-shadow: 3px 3px 8px rgba(0, 0, 0, 0.4);
} }
.comfy-menu button { .comfy-menu button,
.comfy-modal button {
font-size: 20px; font-size: 20px;
} }
@ -130,7 +115,8 @@ body {
.comfy-menu > button, .comfy-menu > button,
.comfy-menu-btns button, .comfy-menu-btns button,
.comfy-menu .comfy-list button { .comfy-menu .comfy-list button,
.comfy-modal button{
color: #ddd; color: #ddd;
background-color: #222; background-color: #222;
border-radius: 8px; border-radius: 8px;
@ -220,11 +206,22 @@ button.comfy-queue-btn {
} }
.comfy-modal.comfy-settings { .comfy-modal.comfy-settings {
background-color: var(--bg-color); text-align: center;
color: var(--fg-color); font-family: sans-serif;
color: #999;
z-index: 99; z-index: 99;
} }
.comfy-modal input,
.comfy-modal select {
color: #ddd;
background-color: #222;
border-radius: 8px;
border-color: #4e4e4e;
border-style: solid;
font-size: inherit;
}
@media only screen and (max-height: 850px) { @media only screen and (max-height: 850px) {
.comfy-menu { .comfy-menu {
top: 0 !important; top: 0 !important;
@ -239,26 +236,26 @@ button.comfy-queue-btn {
} }
.graphdialog { .graphdialog {
min-height: 1em; min-height: 1em;
} }
.graphdialog .name { .graphdialog .name {
font-size: 14px; font-size: 14px;
font-family: sans-serif; font-family: sans-serif;
color: #999999; color: #999999;
} }
.graphdialog button { .graphdialog button {
margin-top: unset; margin-top: unset;
vertical-align: unset; vertical-align: unset;
height: 1.6em; height: 1.6em;
padding-right: 8px; padding-right: 8px;
} }
.graphdialog input, .graphdialog textarea, .graphdialog select { .graphdialog input, .graphdialog textarea, .graphdialog select {
background-color: #222; background-color: #222;
border: 2px solid; border: 2px solid;
border-color: #444444; border-color: #444444;
color: #ddd; color: #ddd;
border-radius: 12px 0 0 12px; border-radius: 12px 0 0 12px;
} }