diff --git a/browser_tests/colorPalette.spec.ts b/browser_tests/colorPalette.spec.ts new file mode 100644 index 000000000..bd5922d4b --- /dev/null +++ b/browser_tests/colorPalette.spec.ts @@ -0,0 +1,149 @@ +import { expect } from '@playwright/test' +import { comfyPageFixture as test } from './ComfyPage' + +const customColorPalettes = { + obsidian: { + version: 102, + id: 'obsidian', + name: 'Obsidian', + colors: { + node_slot: { + CLIP: '#FFD500', + CLIP_VISION: '#A8DADC', + CLIP_VISION_OUTPUT: '#ad7452', + CONDITIONING: '#FFA931', + CONTROL_NET: '#6EE7B7', + IMAGE: '#64B5F6', + LATENT: '#FF9CF9', + MASK: '#81C784', + MODEL: '#B39DDB', + STYLE_MODEL: '#C2FFAE', + VAE: '#FF6E6E', + TAESD: '#DCC274', + PIPE_LINE: '#7737AA', + PIPE_LINE_SDXL: '#7737AA', + INT: '#29699C', + XYPLOT: '#74DA5D', + X_Y: '#38291f' + }, + litegraph_base: { + BACKGROUND_IMAGE: + '', + CLEAR_BACKGROUND_COLOR: '#222222', + NODE_TITLE_COLOR: 'rgba(255,255,255,.75)', + NODE_SELECTED_TITLE_COLOR: '#FFF', + NODE_TEXT_SIZE: 14, + NODE_TEXT_COLOR: '#b8b8b8', + NODE_SUBTEXT_SIZE: 12, + NODE_DEFAULT_COLOR: 'rgba(0,0,0,.8)', + NODE_DEFAULT_BGCOLOR: 'rgba(22,22,22,.8)', + NODE_DEFAULT_BOXCOLOR: 'rgba(255,255,255,.75)', + NODE_DEFAULT_SHAPE: 'box', + NODE_BOX_OUTLINE_COLOR: '#236692', + DEFAULT_SHADOW_COLOR: 'rgba(0,0,0,0)', + DEFAULT_GROUP_FONT: 24, + WIDGET_BGCOLOR: '#242424', + WIDGET_OUTLINE_COLOR: '#333', + WIDGET_TEXT_COLOR: '#a3a3a8', + WIDGET_SECONDARY_TEXT_COLOR: '#97979c', + LINK_COLOR: '#9A9', + EVENT_LINK_COLOR: '#A86', + CONNECTING_LINK_COLOR: '#AFA' + }, + comfy_base: { + 'fg-color': '#fff', + 'bg-color': '#242424', + 'comfy-menu-bg': 'rgba(24,24,24,.9)', + 'comfy-input-bg': '#262626', + 'input-text': '#ddd', + 'descrip-text': '#999', + 'drag-text': '#ccc', + 'error-text': '#ff4444', + 'border-color': '#29292c', + 'tr-even-bg-color': 'rgba(28,28,28,.9)', + 'tr-odd-bg-color': 'rgba(19,19,19,.9)' + } + } + }, + obsidian_dark: { + version: 102, + id: 'obsidian_dark', + name: 'Obsidian Dark', + colors: { + node_slot: { + CLIP: '#FFD500', + CLIP_VISION: '#A8DADC', + CLIP_VISION_OUTPUT: '#ad7452', + CONDITIONING: '#FFA931', + CONTROL_NET: '#6EE7B7', + IMAGE: '#64B5F6', + LATENT: '#FF9CF9', + MASK: '#81C784', + MODEL: '#B39DDB', + STYLE_MODEL: '#C2FFAE', + VAE: '#FF6E6E', + TAESD: '#DCC274', + PIPE_LINE: '#7737AA', + PIPE_LINE_SDXL: '#7737AA', + INT: '#29699C', + XYPLOT: '#74DA5D', + X_Y: '#38291f' + }, + litegraph_base: { + BACKGROUND_IMAGE: + '', + CLEAR_BACKGROUND_COLOR: '#000', + NODE_TITLE_COLOR: 'rgba(255,255,255,.75)', + NODE_SELECTED_TITLE_COLOR: '#FFF', + NODE_TEXT_SIZE: 14, + NODE_TEXT_COLOR: '#b8b8b8', + NODE_SUBTEXT_SIZE: 12, + NODE_DEFAULT_COLOR: 'rgba(0,0,0,.8)', + NODE_DEFAULT_BGCOLOR: 'rgba(22,22,22,.8)', + NODE_DEFAULT_BOXCOLOR: 'rgba(255,255,255,.75)', + NODE_DEFAULT_SHAPE: 'box', + NODE_BOX_OUTLINE_COLOR: '#236692', + DEFAULT_SHADOW_COLOR: 'rgba(0,0,0,0)', + DEFAULT_GROUP_FONT: 24, + WIDGET_BGCOLOR: '#242424', + WIDGET_OUTLINE_COLOR: '#333', + WIDGET_TEXT_COLOR: '#a3a3a8', + WIDGET_SECONDARY_TEXT_COLOR: '#97979c', + LINK_COLOR: '#9A9', + EVENT_LINK_COLOR: '#A86', + CONNECTING_LINK_COLOR: '#AFA' + }, + comfy_base: { + 'fg-color': '#fff', + 'bg-color': '#242424', + 'comfy-menu-bg': 'rgba(24,24,24,.9)', + 'comfy-input-bg': '#262626', + 'input-text': '#ddd', + 'descrip-text': '#999', + 'drag-text': '#ccc', + 'error-text': '#ff4444', + 'border-color': '#29292c', + 'tr-even-bg-color': 'rgba(28,28,28,.9)', + 'tr-odd-bg-color': 'rgba(19,19,19,.9)' + } + } + } +} + +test.describe('Color Palette', () => { + test.beforeEach(async ({ comfyPage }) => { + await comfyPage.setSetting('Comfy.CustomColorPalettes', customColorPalettes) + }) + + test('Can show custom color palette', async ({ comfyPage }) => { + await comfyPage.setSetting('Comfy.ColorPalette', 'custom_obsidian_dark') + await comfyPage.nextFrame() + await expect(comfyPage.canvas).toHaveScreenshot( + 'custom-color-palette-obsidian-dark.png' + ) + // Reset to default color palette for other tests + await comfyPage.setSetting('Comfy.ColorPalette', 'dark') + await comfyPage.nextFrame() + await expect(comfyPage.canvas).toHaveScreenshot('default-color-palette.png') + }) +}) diff --git a/browser_tests/colorPalette.spec.ts-snapshots/custom-color-palette-obsidian-dark-chromium-2x-linux.png b/browser_tests/colorPalette.spec.ts-snapshots/custom-color-palette-obsidian-dark-chromium-2x-linux.png new file mode 100644 index 000000000..b54486869 Binary files /dev/null and b/browser_tests/colorPalette.spec.ts-snapshots/custom-color-palette-obsidian-dark-chromium-2x-linux.png differ diff --git a/browser_tests/colorPalette.spec.ts-snapshots/custom-color-palette-obsidian-dark-chromium-linux.png b/browser_tests/colorPalette.spec.ts-snapshots/custom-color-palette-obsidian-dark-chromium-linux.png new file mode 100644 index 000000000..5acf7c629 Binary files /dev/null and b/browser_tests/colorPalette.spec.ts-snapshots/custom-color-palette-obsidian-dark-chromium-linux.png differ diff --git a/browser_tests/colorPalette.spec.ts-snapshots/default-color-palette-chromium-2x-linux.png b/browser_tests/colorPalette.spec.ts-snapshots/default-color-palette-chromium-2x-linux.png new file mode 100644 index 000000000..242929e52 Binary files /dev/null and b/browser_tests/colorPalette.spec.ts-snapshots/default-color-palette-chromium-2x-linux.png differ diff --git a/browser_tests/colorPalette.spec.ts-snapshots/default-color-palette-chromium-linux.png b/browser_tests/colorPalette.spec.ts-snapshots/default-color-palette-chromium-linux.png new file mode 100644 index 000000000..f6d7b3540 Binary files /dev/null and b/browser_tests/colorPalette.spec.ts-snapshots/default-color-palette-chromium-linux.png differ