diff --git a/browser_tests/colorPalette.spec.ts b/browser_tests/colorPalette.spec.ts index 7b0ac58b4..730f94b83 100644 --- a/browser_tests/colorPalette.spec.ts +++ b/browser_tests/colorPalette.spec.ts @@ -1,8 +1,9 @@ import { expect } from '@playwright/test' +import type { Palette } from '../src/types/colorPaletteTypes' import { comfyPageFixture as test } from './fixtures/ComfyPage' -const customColorPalettes = { +const customColorPalettes: Record = { obsidian: { version: 102, id: 'obsidian', @@ -128,6 +129,19 @@ const customColorPalettes = { 'tr-odd-bg-color': 'rgba(19,19,19,.9)' } } + }, + // A custom light theme with fg color red + custom_light: { + id: 'light_red', + name: 'Light Red', + light_theme: true, + colors: { + node_slot: {}, + litegraph_base: {}, + comfy_base: { + 'fg-color': '#ff0000' + } + } } } @@ -142,6 +156,12 @@ test.describe('Color Palette', () => { await expect(comfyPage.canvas).toHaveScreenshot( 'custom-color-palette-obsidian-dark.png' ) + await comfyPage.setSetting('Comfy.ColorPalette', 'light_red') + await comfyPage.nextFrame() + await expect(comfyPage.canvas).toHaveScreenshot( + 'custom-color-palette-light-red.png' + ) + await comfyPage.setSetting('Comfy.ColorPalette', 'dark') await comfyPage.nextFrame() await expect(comfyPage.canvas).toHaveScreenshot('default-color-palette.png') diff --git a/src/assets/palettes/light.json b/src/assets/palettes/light.json index db1ca1c97..52a0a6a57 100644 --- a/src/assets/palettes/light.json +++ b/src/assets/palettes/light.json @@ -14,7 +14,12 @@ "MASK": "#9CCC65", "MODEL": "#7E57C2", "STYLE_MODEL": "#D4E157", - "VAE": "#FF7043" + "VAE": "#FF7043", + "NOISE": "#B0B0B0", + "GUIDER": "#66FFFF", + "SAMPLER": "#ECB4B4", + "SIGMAS": "#CDFFCD", + "TAESD": "#DCC274" }, "litegraph_base": { "BACKGROUND_IMAGE": "", diff --git a/src/constants/coreColorPalettes.ts b/src/constants/coreColorPalettes.ts index b6a70cb81..e65c68de9 100644 --- a/src/constants/coreColorPalettes.ts +++ b/src/constants/coreColorPalettes.ts @@ -4,7 +4,7 @@ import github from '@/assets/palettes/github.json' import light from '@/assets/palettes/light.json' import nord from '@/assets/palettes/nord.json' import solarized from '@/assets/palettes/solarized.json' -import type { ColorPalettes } from '@/types/colorPaletteTypes' +import type { ColorPalettes, CompletedPalette } from '@/types/colorPaletteTypes' export const CORE_COLOR_PALETTES: ColorPalettes = { dark, @@ -15,4 +15,6 @@ export const CORE_COLOR_PALETTES: ColorPalettes = { github } as const -export const DEFAULT_COLOR_PALETTE = dark +export const DEFAULT_COLOR_PALETTE: CompletedPalette = dark +export const DEFAULT_DARK_COLOR_PALETTE: CompletedPalette = dark +export const DEFAULT_LIGHT_COLOR_PALETTE: CompletedPalette = light diff --git a/src/hooks/coreCommandHooks.ts b/src/hooks/coreCommandHooks.ts index 38becbdb0..4d498b85b 100644 --- a/src/hooks/coreCommandHooks.ts +++ b/src/hooks/coreCommandHooks.ts @@ -5,9 +5,12 @@ import { LiteGraph } from '@comfyorg/litegraph' +import { + DEFAULT_DARK_COLOR_PALETTE, + DEFAULT_LIGHT_COLOR_PALETTE +} from '@/constants/coreColorPalettes' import { api } from '@/scripts/api' import { app } from '@/scripts/app' -import { useColorPaletteService } from '@/services/colorPaletteService' import { useDialogService } from '@/services/dialogService' import { useWorkflowService } from '@/services/workflowService' import type { ComfyCommand } from '@/stores/commandStore' @@ -26,7 +29,6 @@ export function useCoreCommands(): ComfyCommand[] { const workflowStore = useWorkflowStore() const dialogService = useDialogService() const colorPaletteStore = useColorPaletteStore() - const colorPaletteService = useColorPaletteService() const getTracker = () => workflowStore.activeWorkflow?.changeTracker const getSelectedNodes = (): LGraphNode[] => { @@ -414,18 +416,18 @@ export function useCoreCommands(): ComfyCommand[] { label: 'Toggle Theme (Dark/Light)', versionAdded: '1.3.12', function: (() => { - let previousDarkTheme: string = 'dark' - let previousLightTheme: string = 'light' + let previousDarkTheme: string = DEFAULT_DARK_COLOR_PALETTE.id + let previousLightTheme: string = DEFAULT_LIGHT_COLOR_PALETTE.id return () => { const settingStore = useSettingStore() const theme = colorPaletteStore.completedActivePalette if (theme.light_theme) { previousLightTheme = theme.id - settingStore.set('Comfy.ColorPalette', previousLightTheme) + settingStore.set('Comfy.ColorPalette', previousDarkTheme) } else { previousDarkTheme = theme.id - settingStore.set('Comfy.ColorPalette', previousDarkTheme) + settingStore.set('Comfy.ColorPalette', previousLightTheme) } } })() diff --git a/src/stores/workspace/colorPaletteStore.ts b/src/stores/workspace/colorPaletteStore.ts index ae09ddfad..3157b7cc9 100644 --- a/src/stores/workspace/colorPaletteStore.ts +++ b/src/stores/workspace/colorPaletteStore.ts @@ -3,7 +3,9 @@ import { computed, ref } from 'vue' import { CORE_COLOR_PALETTES, - DEFAULT_COLOR_PALETTE + DEFAULT_COLOR_PALETTE, + DEFAULT_DARK_COLOR_PALETTE, + DEFAULT_LIGHT_COLOR_PALETTE } from '@/constants/coreColorPalettes' import type { ColorPalettes, @@ -63,20 +65,24 @@ export const useColorPaletteStore = defineStore('colorPalette', () => { palette.colors.comfy_base['comfy-menu-bg'] } + const defaultPalette = palette.light_theme + ? DEFAULT_LIGHT_COLOR_PALETTE + : DEFAULT_DARK_COLOR_PALETTE + return { ...palette, colors: { ...palette.colors, node_slot: { - ...DEFAULT_COLOR_PALETTE.colors.node_slot, + ...defaultPalette.colors.node_slot, ...palette.colors.node_slot }, litegraph_base: { - ...DEFAULT_COLOR_PALETTE.colors.litegraph_base, + ...defaultPalette.colors.litegraph_base, ...palette.colors.litegraph_base }, comfy_base: { - ...DEFAULT_COLOR_PALETTE.colors.comfy_base, + ...defaultPalette.colors.comfy_base, ...palette.colors.comfy_base } }