mirror of
https://github.com/comfyanonymous/ComfyUI.git
synced 2025-01-25 15:55:18 +00:00
866 lines
34 KiB
JavaScript
866 lines
34 KiB
JavaScript
|
var __defProp = Object.defineProperty;
|
||
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
||
|
import { k as app, aP as LGraphCanvas, bO as useToastStore, ca as $el, z as LiteGraph } from "./index-DGAbdBYF.js";
|
||
|
const colorPalettes = {
|
||
|
dark: {
|
||
|
id: "dark",
|
||
|
name: "Dark (Default)",
|
||
|
colors: {
|
||
|
node_slot: {
|
||
|
CLIP: "#FFD500",
|
||
|
// bright yellow
|
||
|
CLIP_VISION: "#A8DADC",
|
||
|
// light blue-gray
|
||
|
CLIP_VISION_OUTPUT: "#ad7452",
|
||
|
// rusty brown-orange
|
||
|
CONDITIONING: "#FFA931",
|
||
|
// vibrant orange-yellow
|
||
|
CONTROL_NET: "#6EE7B7",
|
||
|
// soft mint green
|
||
|
IMAGE: "#64B5F6",
|
||
|
// bright sky blue
|
||
|
LATENT: "#FF9CF9",
|
||
|
// light pink-purple
|
||
|
MASK: "#81C784",
|
||
|
// muted green
|
||
|
MODEL: "#B39DDB",
|
||
|
// light lavender-purple
|
||
|
STYLE_MODEL: "#C2FFAE",
|
||
|
// light green-yellow
|
||
|
VAE: "#FF6E6E",
|
||
|
// bright red
|
||
|
NOISE: "#B0B0B0",
|
||
|
// gray
|
||
|
GUIDER: "#66FFFF",
|
||
|
// cyan
|
||
|
SAMPLER: "#ECB4B4",
|
||
|
// very soft red
|
||
|
SIGMAS: "#CDFFCD",
|
||
|
// soft lime green
|
||
|
TAESD: "#DCC274"
|
||
|
// cheesecake
|
||
|
},
|
||
|
litegraph_base: {
|
||
|
BACKGROUND_IMAGE: "",
|
||
|
CLEAR_BACKGROUND_COLOR: "#222",
|
||
|
NODE_TITLE_COLOR: "#999",
|
||
|
NODE_SELECTED_TITLE_COLOR: "#FFF",
|
||
|
NODE_TEXT_SIZE: 14,
|
||
|
NODE_TEXT_COLOR: "#AAA",
|
||
|
NODE_SUBTEXT_SIZE: 12,
|
||
|
NODE_DEFAULT_COLOR: "#333",
|
||
|
NODE_DEFAULT_BGCOLOR: "#353535",
|
||
|
NODE_DEFAULT_BOXCOLOR: "#666",
|
||
|
NODE_DEFAULT_SHAPE: "box",
|
||
|
NODE_BOX_OUTLINE_COLOR: "#FFF",
|
||
|
NODE_BYPASS_BGCOLOR: "#FF00FF",
|
||
|
DEFAULT_SHADOW_COLOR: "rgba(0,0,0,0.5)",
|
||
|
DEFAULT_GROUP_FONT: 24,
|
||
|
WIDGET_BGCOLOR: "#222",
|
||
|
WIDGET_OUTLINE_COLOR: "#666",
|
||
|
WIDGET_TEXT_COLOR: "#DDD",
|
||
|
WIDGET_SECONDARY_TEXT_COLOR: "#999",
|
||
|
LINK_COLOR: "#9A9",
|
||
|
EVENT_LINK_COLOR: "#A86",
|
||
|
CONNECTING_LINK_COLOR: "#AFA",
|
||
|
BADGE_FG_COLOR: "#FFF",
|
||
|
BADGE_BG_COLOR: "#0F1F0F"
|
||
|
},
|
||
|
comfy_base: {
|
||
|
"fg-color": "#fff",
|
||
|
"bg-color": "#202020",
|
||
|
"comfy-menu-bg": "#353535",
|
||
|
"comfy-input-bg": "#222",
|
||
|
"input-text": "#ddd",
|
||
|
"descrip-text": "#999",
|
||
|
"drag-text": "#ccc",
|
||
|
"error-text": "#ff4444",
|
||
|
"border-color": "#4e4e4e",
|
||
|
"tr-even-bg-color": "#222",
|
||
|
"tr-odd-bg-color": "#353535",
|
||
|
"content-bg": "#4e4e4e",
|
||
|
"content-fg": "#fff",
|
||
|
"content-hover-bg": "#222",
|
||
|
"content-hover-fg": "#fff"
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
light: {
|
||
|
id: "light",
|
||
|
name: "Light",
|
||
|
colors: {
|
||
|
node_slot: {
|
||
|
CLIP: "#FFA726",
|
||
|
// orange
|
||
|
CLIP_VISION: "#5C6BC0",
|
||
|
// indigo
|
||
|
CLIP_VISION_OUTPUT: "#8D6E63",
|
||
|
// brown
|
||
|
CONDITIONING: "#EF5350",
|
||
|
// red
|
||
|
CONTROL_NET: "#66BB6A",
|
||
|
// green
|
||
|
IMAGE: "#42A5F5",
|
||
|
// blue
|
||
|
LATENT: "#AB47BC",
|
||
|
// purple
|
||
|
MASK: "#9CCC65",
|
||
|
// light green
|
||
|
MODEL: "#7E57C2",
|
||
|
// deep purple
|
||
|
STYLE_MODEL: "#D4E157",
|
||
|
// lime
|
||
|
VAE: "#FF7043"
|
||
|
// deep orange
|
||
|
},
|
||
|
litegraph_base: {
|
||
|
BACKGROUND_IMAGE: "",
|
||
|
CLEAR_BACKGROUND_COLOR: "lightgray",
|
||
|
NODE_TITLE_COLOR: "#222",
|
||
|
NODE_SELECTED_TITLE_COLOR: "#000",
|
||
|
NODE_TEXT_SIZE: 14,
|
||
|
NODE_TEXT_COLOR: "#444",
|
||
|
NODE_SUBTEXT_SIZE: 12,
|
||
|
NODE_DEFAULT_COLOR: "#F7F7F7",
|
||
|
NODE_DEFAULT_BGCOLOR: "#F5F5F5",
|
||
|
NODE_DEFAULT_BOXCOLOR: "#CCC",
|
||
|
NODE_DEFAULT_SHAPE: "box",
|
||
|
NODE_BOX_OUTLINE_COLOR: "#000",
|
||
|
NODE_BYPASS_BGCOLOR: "#FF00FF",
|
||
|
DEFAULT_SHADOW_COLOR: "rgba(0,0,0,0.1)",
|
||
|
DEFAULT_GROUP_FONT: 24,
|
||
|
WIDGET_BGCOLOR: "#D4D4D4",
|
||
|
WIDGET_OUTLINE_COLOR: "#999",
|
||
|
WIDGET_TEXT_COLOR: "#222",
|
||
|
WIDGET_SECONDARY_TEXT_COLOR: "#555",
|
||
|
LINK_COLOR: "#4CAF50",
|
||
|
EVENT_LINK_COLOR: "#FF9800",
|
||
|
CONNECTING_LINK_COLOR: "#2196F3",
|
||
|
BADGE_FG_COLOR: "#000",
|
||
|
BADGE_BG_COLOR: "#FFF"
|
||
|
},
|
||
|
comfy_base: {
|
||
|
"fg-color": "#222",
|
||
|
"bg-color": "#DDD",
|
||
|
"comfy-menu-bg": "#F5F5F5",
|
||
|
"comfy-input-bg": "#C9C9C9",
|
||
|
"input-text": "#222",
|
||
|
"descrip-text": "#444",
|
||
|
"drag-text": "#555",
|
||
|
"error-text": "#F44336",
|
||
|
"border-color": "#888",
|
||
|
"tr-even-bg-color": "#f9f9f9",
|
||
|
"tr-odd-bg-color": "#fff",
|
||
|
"content-bg": "#e0e0e0",
|
||
|
"content-fg": "#222",
|
||
|
"content-hover-bg": "#adadad",
|
||
|
"content-hover-fg": "#222"
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
solarized: {
|
||
|
id: "solarized",
|
||
|
name: "Solarized",
|
||
|
colors: {
|
||
|
node_slot: {
|
||
|
CLIP: "#2AB7CA",
|
||
|
// light blue
|
||
|
CLIP_VISION: "#6c71c4",
|
||
|
// blue violet
|
||
|
CLIP_VISION_OUTPUT: "#859900",
|
||
|
// olive green
|
||
|
CONDITIONING: "#d33682",
|
||
|
// magenta
|
||
|
CONTROL_NET: "#d1ffd7",
|
||
|
// light mint green
|
||
|
IMAGE: "#5940bb",
|
||
|
// deep blue violet
|
||
|
LATENT: "#268bd2",
|
||
|
// blue
|
||
|
MASK: "#CCC9E7",
|
||
|
// light purple-gray
|
||
|
MODEL: "#dc322f",
|
||
|
// red
|
||
|
STYLE_MODEL: "#1a998a",
|
||
|
// teal
|
||
|
UPSCALE_MODEL: "#054A29",
|
||
|
// dark green
|
||
|
VAE: "#facfad"
|
||
|
// light pink-orange
|
||
|
},
|
||
|
litegraph_base: {
|
||
|
NODE_TITLE_COLOR: "#fdf6e3",
|
||
|
// Base3
|
||
|
NODE_SELECTED_TITLE_COLOR: "#A9D400",
|
||
|
NODE_TEXT_SIZE: 14,
|
||
|
NODE_TEXT_COLOR: "#657b83",
|
||
|
// Base00
|
||
|
NODE_SUBTEXT_SIZE: 12,
|
||
|
NODE_DEFAULT_COLOR: "#094656",
|
||
|
NODE_DEFAULT_BGCOLOR: "#073642",
|
||
|
// Base02
|
||
|
NODE_DEFAULT_BOXCOLOR: "#839496",
|
||
|
// Base0
|
||
|
NODE_DEFAULT_SHAPE: "box",
|
||
|
NODE_BOX_OUTLINE_COLOR: "#fdf6e3",
|
||
|
// Base3
|
||
|
NODE_BYPASS_BGCOLOR: "#FF00FF",
|
||
|
DEFAULT_SHADOW_COLOR: "rgba(0,0,0,0.5)",
|
||
|
DEFAULT_GROUP_FONT: 24,
|
||
|
WIDGET_BGCOLOR: "#002b36",
|
||
|
// Base03
|
||
|
WIDGET_OUTLINE_COLOR: "#839496",
|
||
|
// Base0
|
||
|
WIDGET_TEXT_COLOR: "#fdf6e3",
|
||
|
// Base3
|
||
|
WIDGET_SECONDARY_TEXT_COLOR: "#93a1a1",
|
||
|
// Base1
|
||
|
LINK_COLOR: "#2aa198",
|
||
|
// Solarized Cyan
|
||
|
EVENT_LINK_COLOR: "#268bd2",
|
||
|
// Solarized Blue
|
||
|
CONNECTING_LINK_COLOR: "#859900"
|
||
|
// Solarized Green
|
||
|
},
|
||
|
comfy_base: {
|
||
|
"fg-color": "#fdf6e3",
|
||
|
// Base3
|
||
|
"bg-color": "#002b36",
|
||
|
// Base03
|
||
|
"comfy-menu-bg": "#073642",
|
||
|
// Base02
|
||
|
"comfy-input-bg": "#002b36",
|
||
|
// Base03
|
||
|
"input-text": "#93a1a1",
|
||
|
// Base1
|
||
|
"descrip-text": "#586e75",
|
||
|
// Base01
|
||
|
"drag-text": "#839496",
|
||
|
// Base0
|
||
|
"error-text": "#dc322f",
|
||
|
// Solarized Red
|
||
|
"border-color": "#657b83",
|
||
|
// Base00
|
||
|
"tr-even-bg-color": "#002b36",
|
||
|
"tr-odd-bg-color": "#073642",
|
||
|
"content-bg": "#657b83",
|
||
|
"content-fg": "#fdf6e3",
|
||
|
"content-hover-bg": "#002b36",
|
||
|
"content-hover-fg": "#fdf6e3"
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
arc: {
|
||
|
id: "arc",
|
||
|
name: "Arc",
|
||
|
colors: {
|
||
|
node_slot: {
|
||
|
BOOLEAN: "",
|
||
|
CLIP: "#eacb8b",
|
||
|
CLIP_VISION: "#A8DADC",
|
||
|
CLIP_VISION_OUTPUT: "#ad7452",
|
||
|
CONDITIONING: "#cf876f",
|
||
|
CONTROL_NET: "#00d78d",
|
||
|
CONTROL_NET_WEIGHTS: "",
|
||
|
FLOAT: "",
|
||
|
GLIGEN: "",
|
||
|
IMAGE: "#80a1c0",
|
||
|
IMAGEUPLOAD: "",
|
||
|
INT: "",
|
||
|
LATENT: "#b38ead",
|
||
|
LATENT_KEYFRAME: "",
|
||
|
MASK: "#a3bd8d",
|
||
|
MODEL: "#8978a7",
|
||
|
SAMPLER: "",
|
||
|
SIGMAS: "",
|
||
|
STRING: "",
|
||
|
STYLE_MODEL: "#C2FFAE",
|
||
|
T2I_ADAPTER_WEIGHTS: "",
|
||
|
TAESD: "#DCC274",
|
||
|
TIMESTEP_KEYFRAME: "",
|
||
|
UPSCALE_MODEL: "",
|
||
|
VAE: "#be616b"
|
||
|
},
|
||
|
litegraph_base: {
|
||
|
BACKGROUND_IMAGE: "",
|
||
|
CLEAR_BACKGROUND_COLOR: "#2b2f38",
|
||
|
NODE_TITLE_COLOR: "#b2b7bd",
|
||
|
NODE_SELECTED_TITLE_COLOR: "#FFF",
|
||
|
NODE_TEXT_SIZE: 14,
|
||
|
NODE_TEXT_COLOR: "#AAA",
|
||
|
NODE_SUBTEXT_SIZE: 12,
|
||
|
NODE_DEFAULT_COLOR: "#2b2f38",
|
||
|
NODE_DEFAULT_BGCOLOR: "#242730",
|
||
|
NODE_DEFAULT_BOXCOLOR: "#6e7581",
|
||
|
NODE_DEFAULT_SHAPE: "box",
|
||
|
NODE_BOX_OUTLINE_COLOR: "#FFF",
|
||
|
NODE_BYPASS_BGCOLOR: "#FF00FF",
|
||
|
DEFAULT_SHADOW_COLOR: "rgba(0,0,0,0.5)",
|
||
|
DEFAULT_GROUP_FONT: 22,
|
||
|
WIDGET_BGCOLOR: "#2b2f38",
|
||
|
WIDGET_OUTLINE_COLOR: "#6e7581",
|
||
|
WIDGET_TEXT_COLOR: "#DDD",
|
||
|
WIDGET_SECONDARY_TEXT_COLOR: "#b2b7bd",
|
||
|
LINK_COLOR: "#9A9",
|
||
|
EVENT_LINK_COLOR: "#A86",
|
||
|
CONNECTING_LINK_COLOR: "#AFA"
|
||
|
},
|
||
|
comfy_base: {
|
||
|
"fg-color": "#fff",
|
||
|
"bg-color": "#2b2f38",
|
||
|
"comfy-menu-bg": "#242730",
|
||
|
"comfy-input-bg": "#2b2f38",
|
||
|
"input-text": "#ddd",
|
||
|
"descrip-text": "#b2b7bd",
|
||
|
"drag-text": "#ccc",
|
||
|
"error-text": "#ff4444",
|
||
|
"border-color": "#6e7581",
|
||
|
"tr-even-bg-color": "#2b2f38",
|
||
|
"tr-odd-bg-color": "#242730",
|
||
|
"content-bg": "#6e7581",
|
||
|
"content-fg": "#fff",
|
||
|
"content-hover-bg": "#2b2f38",
|
||
|
"content-hover-fg": "#fff"
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
nord: {
|
||
|
id: "nord",
|
||
|
name: "Nord",
|
||
|
colors: {
|
||
|
node_slot: {
|
||
|
BOOLEAN: "",
|
||
|
CLIP: "#eacb8b",
|
||
|
CLIP_VISION: "#A8DADC",
|
||
|
CLIP_VISION_OUTPUT: "#ad7452",
|
||
|
CONDITIONING: "#cf876f",
|
||
|
CONTROL_NET: "#00d78d",
|
||
|
CONTROL_NET_WEIGHTS: "",
|
||
|
FLOAT: "",
|
||
|
GLIGEN: "",
|
||
|
IMAGE: "#80a1c0",
|
||
|
IMAGEUPLOAD: "",
|
||
|
INT: "",
|
||
|
LATENT: "#b38ead",
|
||
|
LATENT_KEYFRAME: "",
|
||
|
MASK: "#a3bd8d",
|
||
|
MODEL: "#8978a7",
|
||
|
SAMPLER: "",
|
||
|
SIGMAS: "",
|
||
|
STRING: "",
|
||
|
STYLE_MODEL: "#C2FFAE",
|
||
|
T2I_ADAPTER_WEIGHTS: "",
|
||
|
TAESD: "#DCC274",
|
||
|
TIMESTEP_KEYFRAME: "",
|
||
|
UPSCALE_MODEL: "",
|
||
|
VAE: "#be616b"
|
||
|
},
|
||
|
litegraph_base: {
|
||
|
BACKGROUND_IMAGE: "",
|
||
|
CLEAR_BACKGROUND_COLOR: "#212732",
|
||
|
NODE_TITLE_COLOR: "#999",
|
||
|
NODE_SELECTED_TITLE_COLOR: "#e5eaf0",
|
||
|
NODE_TEXT_SIZE: 14,
|
||
|
NODE_TEXT_COLOR: "#bcc2c8",
|
||
|
NODE_SUBTEXT_SIZE: 12,
|
||
|
NODE_DEFAULT_COLOR: "#2e3440",
|
||
|
NODE_DEFAULT_BGCOLOR: "#161b22",
|
||
|
NODE_DEFAULT_BOXCOLOR: "#545d70",
|
||
|
NODE_DEFAULT_SHAPE: "box",
|
||
|
NODE_BOX_OUTLINE_COLOR: "#e5eaf0",
|
||
|
NODE_BYPASS_BGCOLOR: "#FF00FF",
|
||
|
DEFAULT_SHADOW_COLOR: "rgba(0,0,0,0.5)",
|
||
|
DEFAULT_GROUP_FONT: 24,
|
||
|
WIDGET_BGCOLOR: "#2e3440",
|
||
|
WIDGET_OUTLINE_COLOR: "#545d70",
|
||
|
WIDGET_TEXT_COLOR: "#bcc2c8",
|
||
|
WIDGET_SECONDARY_TEXT_COLOR: "#999",
|
||
|
LINK_COLOR: "#9A9",
|
||
|
EVENT_LINK_COLOR: "#A86",
|
||
|
CONNECTING_LINK_COLOR: "#AFA"
|
||
|
},
|
||
|
comfy_base: {
|
||
|
"fg-color": "#e5eaf0",
|
||
|
"bg-color": "#2e3440",
|
||
|
"comfy-menu-bg": "#161b22",
|
||
|
"comfy-input-bg": "#2e3440",
|
||
|
"input-text": "#bcc2c8",
|
||
|
"descrip-text": "#999",
|
||
|
"drag-text": "#ccc",
|
||
|
"error-text": "#ff4444",
|
||
|
"border-color": "#545d70",
|
||
|
"tr-even-bg-color": "#2e3440",
|
||
|
"tr-odd-bg-color": "#161b22",
|
||
|
"content-bg": "#545d70",
|
||
|
"content-fg": "#e5eaf0",
|
||
|
"content-hover-bg": "#2e3440",
|
||
|
"content-hover-fg": "#e5eaf0"
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
github: {
|
||
|
id: "github",
|
||
|
name: "Github",
|
||
|
colors: {
|
||
|
node_slot: {
|
||
|
BOOLEAN: "",
|
||
|
CLIP: "#eacb8b",
|
||
|
CLIP_VISION: "#A8DADC",
|
||
|
CLIP_VISION_OUTPUT: "#ad7452",
|
||
|
CONDITIONING: "#cf876f",
|
||
|
CONTROL_NET: "#00d78d",
|
||
|
CONTROL_NET_WEIGHTS: "",
|
||
|
FLOAT: "",
|
||
|
GLIGEN: "",
|
||
|
IMAGE: "#80a1c0",
|
||
|
IMAGEUPLOAD: "",
|
||
|
INT: "",
|
||
|
LATENT: "#b38ead",
|
||
|
LATENT_KEYFRAME: "",
|
||
|
MASK: "#a3bd8d",
|
||
|
MODEL: "#8978a7",
|
||
|
SAMPLER: "",
|
||
|
SIGMAS: "",
|
||
|
STRING: "",
|
||
|
STYLE_MODEL: "#C2FFAE",
|
||
|
T2I_ADAPTER_WEIGHTS: "",
|
||
|
TAESD: "#DCC274",
|
||
|
TIMESTEP_KEYFRAME: "",
|
||
|
UPSCALE_MODEL: "",
|
||
|
VAE: "#be616b"
|
||
|
},
|
||
|
litegraph_base: {
|
||
|
BACKGROUND_IMAGE: "",
|
||
|
CLEAR_BACKGROUND_COLOR: "#040506",
|
||
|
NODE_TITLE_COLOR: "#999",
|
||
|
NODE_SELECTED_TITLE_COLOR: "#e5eaf0",
|
||
|
NODE_TEXT_SIZE: 14,
|
||
|
NODE_TEXT_COLOR: "#bcc2c8",
|
||
|
NODE_SUBTEXT_SIZE: 12,
|
||
|
NODE_DEFAULT_COLOR: "#161b22",
|
||
|
NODE_DEFAULT_BGCOLOR: "#13171d",
|
||
|
NODE_DEFAULT_BOXCOLOR: "#30363d",
|
||
|
NODE_DEFAULT_SHAPE: "box",
|
||
|
NODE_BOX_OUTLINE_COLOR: "#e5eaf0",
|
||
|
NODE_BYPASS_BGCOLOR: "#FF00FF",
|
||
|
DEFAULT_SHADOW_COLOR: "rgba(0,0,0,0.5)",
|
||
|
DEFAULT_GROUP_FONT: 24,
|
||
|
WIDGET_BGCOLOR: "#161b22",
|
||
|
WIDGET_OUTLINE_COLOR: "#30363d",
|
||
|
WIDGET_TEXT_COLOR: "#bcc2c8",
|
||
|
WIDGET_SECONDARY_TEXT_COLOR: "#999",
|
||
|
LINK_COLOR: "#9A9",
|
||
|
EVENT_LINK_COLOR: "#A86",
|
||
|
CONNECTING_LINK_COLOR: "#AFA"
|
||
|
},
|
||
|
comfy_base: {
|
||
|
"fg-color": "#e5eaf0",
|
||
|
"bg-color": "#161b22",
|
||
|
"comfy-menu-bg": "#13171d",
|
||
|
"comfy-input-bg": "#161b22",
|
||
|
"input-text": "#bcc2c8",
|
||
|
"descrip-text": "#999",
|
||
|
"drag-text": "#ccc",
|
||
|
"error-text": "#ff4444",
|
||
|
"border-color": "#30363d",
|
||
|
"tr-even-bg-color": "#161b22",
|
||
|
"tr-odd-bg-color": "#13171d",
|
||
|
"content-bg": "#30363d",
|
||
|
"content-fg": "#e5eaf0",
|
||
|
"content-hover-bg": "#161b22",
|
||
|
"content-hover-fg": "#e5eaf0"
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
const id = "Comfy.ColorPalette";
|
||
|
const idCustomColorPalettes = "Comfy.CustomColorPalettes";
|
||
|
const defaultColorPaletteId = "dark";
|
||
|
const els = {
|
||
|
select: null
|
||
|
};
|
||
|
const getCustomColorPalettes = /* @__PURE__ */ __name(() => {
|
||
|
return app.ui.settings.getSettingValue(idCustomColorPalettes, {});
|
||
|
}, "getCustomColorPalettes");
|
||
|
const setCustomColorPalettes = /* @__PURE__ */ __name((customColorPalettes) => {
|
||
|
return app.ui.settings.setSettingValue(
|
||
|
idCustomColorPalettes,
|
||
|
customColorPalettes
|
||
|
);
|
||
|
}, "setCustomColorPalettes");
|
||
|
const defaultColorPalette = colorPalettes[defaultColorPaletteId];
|
||
|
const getColorPalette = /* @__PURE__ */ __name((colorPaletteId) => {
|
||
|
if (!colorPaletteId) {
|
||
|
colorPaletteId = app.ui.settings.getSettingValue(id, defaultColorPaletteId);
|
||
|
}
|
||
|
if (colorPaletteId.startsWith("custom_")) {
|
||
|
colorPaletteId = colorPaletteId.substr(7);
|
||
|
let customColorPalettes = getCustomColorPalettes();
|
||
|
if (customColorPalettes[colorPaletteId]) {
|
||
|
return customColorPalettes[colorPaletteId];
|
||
|
}
|
||
|
}
|
||
|
return colorPalettes[colorPaletteId];
|
||
|
}, "getColorPalette");
|
||
|
const setColorPalette = /* @__PURE__ */ __name((colorPaletteId) => {
|
||
|
app.ui.settings.setSettingValue(id, colorPaletteId);
|
||
|
}, "setColorPalette");
|
||
|
app.registerExtension({
|
||
|
name: id,
|
||
|
init() {
|
||
|
LGraphCanvas.prototype.updateBackground = function(image, clearBackgroundColor) {
|
||
|
this._bg_img = new Image();
|
||
|
this._bg_img.name = image;
|
||
|
this._bg_img.src = image;
|
||
|
this._bg_img.onload = () => {
|
||
|
this.draw(true, true);
|
||
|
};
|
||
|
this.background_image = image;
|
||
|
this.clear_background = true;
|
||
|
this.clear_background_color = clearBackgroundColor;
|
||
|
this._pattern = null;
|
||
|
};
|
||
|
},
|
||
|
addCustomNodeDefs(node_defs) {
|
||
|
const sortObjectKeys = /* @__PURE__ */ __name((unordered) => {
|
||
|
return Object.keys(unordered).sort().reduce((obj, key) => {
|
||
|
obj[key] = unordered[key];
|
||
|
return obj;
|
||
|
}, {});
|
||
|
}, "sortObjectKeys");
|
||
|
function getSlotTypes() {
|
||
|
var types = [];
|
||
|
const defs = node_defs;
|
||
|
for (const nodeId in defs) {
|
||
|
const nodeData = defs[nodeId];
|
||
|
var inputs = nodeData["input"]["required"];
|
||
|
if (nodeData["input"]["optional"] !== void 0) {
|
||
|
inputs = Object.assign(
|
||
|
{},
|
||
|
nodeData["input"]["required"],
|
||
|
nodeData["input"]["optional"]
|
||
|
);
|
||
|
}
|
||
|
for (const inputName in inputs) {
|
||
|
const inputData = inputs[inputName];
|
||
|
const type = inputData[0];
|
||
|
if (!Array.isArray(type)) {
|
||
|
types.push(type);
|
||
|
}
|
||
|
}
|
||
|
for (const o in nodeData["output"]) {
|
||
|
const output = nodeData["output"][o];
|
||
|
types.push(output);
|
||
|
}
|
||
|
}
|
||
|
return types;
|
||
|
}
|
||
|
__name(getSlotTypes, "getSlotTypes");
|
||
|
function completeColorPalette(colorPalette) {
|
||
|
var types = getSlotTypes();
|
||
|
for (const type of types) {
|
||
|
if (!colorPalette.colors.node_slot[type]) {
|
||
|
colorPalette.colors.node_slot[type] = "";
|
||
|
}
|
||
|
}
|
||
|
colorPalette.colors.node_slot = sortObjectKeys(
|
||
|
colorPalette.colors.node_slot
|
||
|
);
|
||
|
return colorPalette;
|
||
|
}
|
||
|
__name(completeColorPalette, "completeColorPalette");
|
||
|
const getColorPaletteTemplate = /* @__PURE__ */ __name(async () => {
|
||
|
let colorPalette = {
|
||
|
id: "my_color_palette_unique_id",
|
||
|
name: "My Color Palette",
|
||
|
colors: {
|
||
|
node_slot: {},
|
||
|
litegraph_base: {},
|
||
|
comfy_base: {}
|
||
|
}
|
||
|
};
|
||
|
const defaultColorPalette2 = colorPalettes[defaultColorPaletteId];
|
||
|
for (const key in defaultColorPalette2.colors.litegraph_base) {
|
||
|
if (!colorPalette.colors.litegraph_base[key]) {
|
||
|
colorPalette.colors.litegraph_base[key] = "";
|
||
|
}
|
||
|
}
|
||
|
for (const key in defaultColorPalette2.colors.comfy_base) {
|
||
|
if (!colorPalette.colors.comfy_base[key]) {
|
||
|
colorPalette.colors.comfy_base[key] = "";
|
||
|
}
|
||
|
}
|
||
|
return completeColorPalette(colorPalette);
|
||
|
}, "getColorPaletteTemplate");
|
||
|
const addCustomColorPalette = /* @__PURE__ */ __name(async (colorPalette) => {
|
||
|
if (typeof colorPalette !== "object") {
|
||
|
useToastStore().addAlert("Invalid color palette.");
|
||
|
return;
|
||
|
}
|
||
|
if (!colorPalette.id) {
|
||
|
useToastStore().addAlert("Color palette missing id.");
|
||
|
return;
|
||
|
}
|
||
|
if (!colorPalette.name) {
|
||
|
useToastStore().addAlert("Color palette missing name.");
|
||
|
return;
|
||
|
}
|
||
|
if (!colorPalette.colors) {
|
||
|
useToastStore().addAlert("Color palette missing colors.");
|
||
|
return;
|
||
|
}
|
||
|
if (colorPalette.colors.node_slot && typeof colorPalette.colors.node_slot !== "object") {
|
||
|
useToastStore().addAlert("Invalid color palette colors.node_slot.");
|
||
|
return;
|
||
|
}
|
||
|
const customColorPalettes = getCustomColorPalettes();
|
||
|
customColorPalettes[colorPalette.id] = colorPalette;
|
||
|
setCustomColorPalettes(customColorPalettes);
|
||
|
for (const option of els.select.childNodes) {
|
||
|
if (option.value === "custom_" + colorPalette.id) {
|
||
|
els.select.removeChild(option);
|
||
|
}
|
||
|
}
|
||
|
els.select.append(
|
||
|
$el("option", {
|
||
|
textContent: colorPalette.name + " (custom)",
|
||
|
value: "custom_" + colorPalette.id,
|
||
|
selected: true
|
||
|
})
|
||
|
);
|
||
|
setColorPalette("custom_" + colorPalette.id);
|
||
|
await loadColorPalette(colorPalette);
|
||
|
}, "addCustomColorPalette");
|
||
|
const deleteCustomColorPalette = /* @__PURE__ */ __name(async (colorPaletteId) => {
|
||
|
const customColorPalettes = getCustomColorPalettes();
|
||
|
delete customColorPalettes[colorPaletteId];
|
||
|
setCustomColorPalettes(customColorPalettes);
|
||
|
for (const opt of els.select.childNodes) {
|
||
|
const option = opt;
|
||
|
if (option.value === defaultColorPaletteId) {
|
||
|
option.selected = true;
|
||
|
}
|
||
|
if (option.value === "custom_" + colorPaletteId) {
|
||
|
els.select.removeChild(option);
|
||
|
}
|
||
|
}
|
||
|
setColorPalette(defaultColorPaletteId);
|
||
|
await loadColorPalette(getColorPalette());
|
||
|
}, "deleteCustomColorPalette");
|
||
|
const loadColorPalette = /* @__PURE__ */ __name(async (colorPalette) => {
|
||
|
colorPalette = await completeColorPalette(colorPalette);
|
||
|
if (colorPalette.colors) {
|
||
|
if (colorPalette.colors.node_slot) {
|
||
|
Object.assign(
|
||
|
app.canvas.default_connection_color_byType,
|
||
|
colorPalette.colors.node_slot
|
||
|
);
|
||
|
Object.assign(
|
||
|
LGraphCanvas.link_type_colors,
|
||
|
colorPalette.colors.node_slot
|
||
|
);
|
||
|
}
|
||
|
if (colorPalette.colors.litegraph_base) {
|
||
|
app.canvas.node_title_color = colorPalette.colors.litegraph_base.NODE_TITLE_COLOR;
|
||
|
app.canvas.default_link_color = colorPalette.colors.litegraph_base.LINK_COLOR;
|
||
|
for (const key in colorPalette.colors.litegraph_base) {
|
||
|
if (colorPalette.colors.litegraph_base.hasOwnProperty(key) && LiteGraph.hasOwnProperty(key)) {
|
||
|
LiteGraph[key] = colorPalette.colors.litegraph_base[key];
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if (colorPalette.colors.comfy_base) {
|
||
|
const rootStyle = document.documentElement.style;
|
||
|
for (const key in colorPalette.colors.comfy_base) {
|
||
|
rootStyle.setProperty(
|
||
|
"--" + key,
|
||
|
colorPalette.colors.comfy_base[key]
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
if (colorPalette.colors.litegraph_base.NODE_BYPASS_BGCOLOR) {
|
||
|
app.bypassBgColor = colorPalette.colors.litegraph_base.NODE_BYPASS_BGCOLOR;
|
||
|
}
|
||
|
app.canvas.draw(true, true);
|
||
|
}
|
||
|
}, "loadColorPalette");
|
||
|
const fileInput = $el("input", {
|
||
|
type: "file",
|
||
|
accept: ".json",
|
||
|
style: { display: "none" },
|
||
|
parent: document.body,
|
||
|
onchange: /* @__PURE__ */ __name(() => {
|
||
|
const file = fileInput.files[0];
|
||
|
if (file.type === "application/json" || file.name.endsWith(".json")) {
|
||
|
const reader = new FileReader();
|
||
|
reader.onload = async () => {
|
||
|
await addCustomColorPalette(JSON.parse(reader.result));
|
||
|
};
|
||
|
reader.readAsText(file);
|
||
|
}
|
||
|
}, "onchange")
|
||
|
});
|
||
|
app.ui.settings.addSetting({
|
||
|
id,
|
||
|
category: ["Comfy", "ColorPalette"],
|
||
|
name: "Color Palette",
|
||
|
type: /* @__PURE__ */ __name((name, setter, value) => {
|
||
|
const options = [
|
||
|
...Object.values(colorPalettes).map(
|
||
|
(c) => $el("option", {
|
||
|
textContent: c.name,
|
||
|
value: c.id,
|
||
|
selected: c.id === value
|
||
|
})
|
||
|
),
|
||
|
...Object.values(getCustomColorPalettes()).map(
|
||
|
(c) => $el("option", {
|
||
|
textContent: `${c.name} (custom)`,
|
||
|
value: `custom_${c.id}`,
|
||
|
selected: `custom_${c.id}` === value
|
||
|
})
|
||
|
)
|
||
|
];
|
||
|
els.select = $el(
|
||
|
"select",
|
||
|
{
|
||
|
style: {
|
||
|
marginBottom: "0.15rem",
|
||
|
width: "100%"
|
||
|
},
|
||
|
onchange: /* @__PURE__ */ __name((e) => {
|
||
|
setter(e.target.value);
|
||
|
}, "onchange")
|
||
|
},
|
||
|
options
|
||
|
);
|
||
|
return $el("tr", [
|
||
|
$el("td", [
|
||
|
els.select,
|
||
|
$el(
|
||
|
"div",
|
||
|
{
|
||
|
style: {
|
||
|
display: "grid",
|
||
|
gap: "4px",
|
||
|
gridAutoFlow: "column"
|
||
|
}
|
||
|
},
|
||
|
[
|
||
|
$el("input", {
|
||
|
type: "button",
|
||
|
value: "Export",
|
||
|
onclick: /* @__PURE__ */ __name(async () => {
|
||
|
const colorPaletteId = app.ui.settings.getSettingValue(
|
||
|
id,
|
||
|
defaultColorPaletteId
|
||
|
);
|
||
|
const colorPalette = await completeColorPalette(
|
||
|
getColorPalette(colorPaletteId)
|
||
|
);
|
||
|
const json = JSON.stringify(colorPalette, null, 2);
|
||
|
const blob = new Blob([json], { type: "application/json" });
|
||
|
const url = URL.createObjectURL(blob);
|
||
|
const a = $el("a", {
|
||
|
href: url,
|
||
|
download: colorPaletteId + ".json",
|
||
|
style: { display: "none" },
|
||
|
parent: document.body
|
||
|
});
|
||
|
a.click();
|
||
|
setTimeout(function() {
|
||
|
a.remove();
|
||
|
window.URL.revokeObjectURL(url);
|
||
|
}, 0);
|
||
|
}, "onclick")
|
||
|
}),
|
||
|
$el("input", {
|
||
|
type: "button",
|
||
|
value: "Import",
|
||
|
onclick: /* @__PURE__ */ __name(() => {
|
||
|
fileInput.click();
|
||
|
}, "onclick")
|
||
|
}),
|
||
|
$el("input", {
|
||
|
type: "button",
|
||
|
value: "Template",
|
||
|
onclick: /* @__PURE__ */ __name(async () => {
|
||
|
const colorPalette = await getColorPaletteTemplate();
|
||
|
const json = JSON.stringify(colorPalette, null, 2);
|
||
|
const blob = new Blob([json], { type: "application/json" });
|
||
|
const url = URL.createObjectURL(blob);
|
||
|
const a = $el("a", {
|
||
|
href: url,
|
||
|
download: "color_palette.json",
|
||
|
style: { display: "none" },
|
||
|
parent: document.body
|
||
|
});
|
||
|
a.click();
|
||
|
setTimeout(function() {
|
||
|
a.remove();
|
||
|
window.URL.revokeObjectURL(url);
|
||
|
}, 0);
|
||
|
}, "onclick")
|
||
|
}),
|
||
|
$el("input", {
|
||
|
type: "button",
|
||
|
value: "Delete",
|
||
|
onclick: /* @__PURE__ */ __name(async () => {
|
||
|
let colorPaletteId = app.ui.settings.getSettingValue(
|
||
|
id,
|
||
|
defaultColorPaletteId
|
||
|
);
|
||
|
if (colorPalettes[colorPaletteId]) {
|
||
|
useToastStore().addAlert(
|
||
|
"You cannot delete a built-in color palette."
|
||
|
);
|
||
|
return;
|
||
|
}
|
||
|
if (colorPaletteId.startsWith("custom_")) {
|
||
|
colorPaletteId = colorPaletteId.substr(7);
|
||
|
}
|
||
|
await deleteCustomColorPalette(colorPaletteId);
|
||
|
}, "onclick")
|
||
|
})
|
||
|
]
|
||
|
)
|
||
|
])
|
||
|
]);
|
||
|
}, "type"),
|
||
|
defaultValue: defaultColorPaletteId,
|
||
|
async onChange(value) {
|
||
|
if (!value) {
|
||
|
return;
|
||
|
}
|
||
|
let palette = colorPalettes[value];
|
||
|
if (palette) {
|
||
|
await loadColorPalette(palette);
|
||
|
} else if (value.startsWith("custom_")) {
|
||
|
value = value.substr(7);
|
||
|
let customColorPalettes = getCustomColorPalettes();
|
||
|
if (customColorPalettes[value]) {
|
||
|
palette = customColorPalettes[value];
|
||
|
await loadColorPalette(customColorPalettes[value]);
|
||
|
}
|
||
|
}
|
||
|
let { BACKGROUND_IMAGE, CLEAR_BACKGROUND_COLOR } = palette.colors.litegraph_base;
|
||
|
if (BACKGROUND_IMAGE === void 0 || CLEAR_BACKGROUND_COLOR === void 0) {
|
||
|
const base = colorPalettes["dark"].colors.litegraph_base;
|
||
|
BACKGROUND_IMAGE = base.BACKGROUND_IMAGE;
|
||
|
CLEAR_BACKGROUND_COLOR = base.CLEAR_BACKGROUND_COLOR;
|
||
|
}
|
||
|
app.canvas.updateBackground(BACKGROUND_IMAGE, CLEAR_BACKGROUND_COLOR);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
window.comfyAPI = window.comfyAPI || {};
|
||
|
window.comfyAPI.colorPalette = window.comfyAPI.colorPalette || {};
|
||
|
window.comfyAPI.colorPalette.defaultColorPalette = defaultColorPalette;
|
||
|
window.comfyAPI.colorPalette.getColorPalette = getColorPalette;
|
||
|
export {
|
||
|
defaultColorPalette as d,
|
||
|
getColorPalette as g
|
||
|
};
|
||
|
//# sourceMappingURL=colorPalette-D5oi2-2V.js.map
|