2023-03-06 09:02:40 +00:00
|
|
|
import { ThemeOverride } from '@chakra-ui/react';
|
2023-03-06 09:40:59 +00:00
|
|
|
|
2023-06-29 18:04:42 +00:00
|
|
|
import { InvokeAIColors } from './colors/colors';
|
2023-03-06 09:02:40 +00:00
|
|
|
import { accordionTheme } from './components/accordion';
|
|
|
|
import { buttonTheme } from './components/button';
|
|
|
|
import { checkboxTheme } from './components/checkbox';
|
2023-07-20 11:48:28 +00:00
|
|
|
import { editableTheme } from './components/editable';
|
2023-03-06 09:02:40 +00:00
|
|
|
import { formLabelTheme } from './components/formLabel';
|
|
|
|
import { inputTheme } from './components/input';
|
|
|
|
import { menuTheme } from './components/menu';
|
|
|
|
import { modalTheme } from './components/modal';
|
|
|
|
import { numberInputTheme } from './components/numberInput';
|
|
|
|
import { popoverTheme } from './components/popover';
|
|
|
|
import { progressTheme } from './components/progress';
|
2023-06-29 18:04:42 +00:00
|
|
|
import { no_scrollbar } from './components/scrollbar';
|
2023-03-06 09:02:40 +00:00
|
|
|
import { selectTheme } from './components/select';
|
2023-07-18 08:35:20 +00:00
|
|
|
import { skeletonTheme } from './components/skeleton';
|
2023-03-06 09:02:40 +00:00
|
|
|
import { sliderTheme } from './components/slider';
|
|
|
|
import { switchTheme } from './components/switch';
|
|
|
|
import { tabsTheme } from './components/tabs';
|
|
|
|
import { textTheme } from './components/text';
|
|
|
|
import { textareaTheme } from './components/textarea';
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
import { tooltipTheme } from './components/tooltip';
|
2023-03-06 09:02:40 +00:00
|
|
|
|
|
|
|
export const theme: ThemeOverride = {
|
|
|
|
config: {
|
|
|
|
cssVarPrefix: 'invokeai',
|
2023-05-12 07:43:14 +00:00
|
|
|
initialColorMode: 'dark',
|
|
|
|
useSystemColorMode: false,
|
2023-03-06 09:02:40 +00:00
|
|
|
},
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
layerStyles: {
|
|
|
|
body: {
|
|
|
|
bg: 'base.50',
|
|
|
|
color: 'base.900',
|
|
|
|
'.chakra-ui-dark &': { bg: 'base.900', color: 'base.50' },
|
|
|
|
},
|
|
|
|
first: {
|
|
|
|
bg: 'base.100',
|
|
|
|
color: 'base.900',
|
|
|
|
'.chakra-ui-dark &': { bg: 'base.850', color: 'base.100' },
|
|
|
|
},
|
|
|
|
second: {
|
|
|
|
bg: 'base.200',
|
|
|
|
color: 'base.900',
|
|
|
|
'.chakra-ui-dark &': { bg: 'base.800', color: 'base.100' },
|
|
|
|
},
|
|
|
|
},
|
2023-03-06 09:02:40 +00:00
|
|
|
styles: {
|
2023-06-29 18:09:14 +00:00
|
|
|
global: () => ({
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
layerStyle: 'body',
|
2023-03-09 09:30:29 +00:00
|
|
|
'*': { ...no_scrollbar },
|
2023-03-06 09:02:40 +00:00
|
|
|
}),
|
|
|
|
},
|
|
|
|
direction: 'ltr',
|
|
|
|
fonts: {
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
body: `'Inter Variable', sans-serif`,
|
2023-04-17 01:26:10 +00:00
|
|
|
},
|
2023-03-06 09:02:40 +00:00
|
|
|
shadows: {
|
|
|
|
light: {
|
|
|
|
accent: `0 0 10px 0 var(--invokeai-colors-accent-300)`,
|
|
|
|
accentHover: `0 0 10px 0 var(--invokeai-colors-accent-400)`,
|
|
|
|
ok: `0 0 7px var(--invokeai-colors-ok-600)`,
|
|
|
|
working: `0 0 7px var(--invokeai-colors-working-600)`,
|
|
|
|
error: `0 0 7px var(--invokeai-colors-error-600)`,
|
|
|
|
},
|
|
|
|
dark: {
|
|
|
|
accent: `0 0 10px 0 var(--invokeai-colors-accent-600)`,
|
|
|
|
accentHover: `0 0 10px 0 var(--invokeai-colors-accent-500)`,
|
|
|
|
ok: `0 0 7px var(--invokeai-colors-ok-400)`,
|
|
|
|
working: `0 0 7px var(--invokeai-colors-working-400)`,
|
|
|
|
error: `0 0 7px var(--invokeai-colors-error-400)`,
|
|
|
|
},
|
2023-07-03 14:09:18 +00:00
|
|
|
selected: {
|
|
|
|
light:
|
|
|
|
'0px 0px 0px 1px var(--invokeai-colors-base-150), 0px 0px 0px 4px var(--invokeai-colors-accent-400)',
|
2023-07-20 11:48:28 +00:00
|
|
|
dark: '0px 0px 0px 1px var(--invokeai-colors-base-900), 0px 0px 0px 4px var(--invokeai-colors-accent-500)',
|
2023-07-03 14:09:18 +00:00
|
|
|
},
|
2023-07-20 11:32:34 +00:00
|
|
|
hoverSelected: {
|
|
|
|
light:
|
|
|
|
'0px 0px 0px 1px var(--invokeai-colors-base-150), 0px 0px 0px 4px var(--invokeai-colors-accent-500)',
|
2023-07-21 10:02:54 +00:00
|
|
|
dark: '0px 0px 0px 1px var(--invokeai-colors-base-900), 0px 0px 0px 4px var(--invokeai-colors-accent-400)',
|
2023-07-20 11:32:34 +00:00
|
|
|
},
|
|
|
|
hoverUnselected: {
|
|
|
|
light:
|
2023-07-21 10:02:54 +00:00
|
|
|
'0px 0px 0px 1px var(--invokeai-colors-base-150), 0px 0px 0px 3px var(--invokeai-colors-accent-500)',
|
|
|
|
dark: '0px 0px 0px 1px var(--invokeai-colors-base-900), 0px 0px 0px 3px var(--invokeai-colors-accent-400)',
|
2023-07-20 11:32:34 +00:00
|
|
|
},
|
2023-07-18 08:35:20 +00:00
|
|
|
nodeSelectedOutline: `0 0 0 2px var(--invokeai-colors-accent-450)`,
|
2023-03-06 09:02:40 +00:00
|
|
|
},
|
2023-06-29 18:04:42 +00:00
|
|
|
colors: InvokeAIColors,
|
2023-03-06 09:02:40 +00:00
|
|
|
components: {
|
|
|
|
Button: buttonTheme, // Button and IconButton
|
|
|
|
Input: inputTheme,
|
2023-07-20 11:32:34 +00:00
|
|
|
Editable: editableTheme,
|
2023-03-06 09:02:40 +00:00
|
|
|
Textarea: textareaTheme,
|
|
|
|
Tabs: tabsTheme,
|
|
|
|
Progress: progressTheme,
|
|
|
|
Accordion: accordionTheme,
|
|
|
|
FormLabel: formLabelTheme,
|
|
|
|
Switch: switchTheme,
|
|
|
|
NumberInput: numberInputTheme,
|
|
|
|
Select: selectTheme,
|
2023-07-03 14:09:18 +00:00
|
|
|
Skeleton: skeletonTheme,
|
2023-03-06 09:02:40 +00:00
|
|
|
Slider: sliderTheme,
|
|
|
|
Popover: popoverTheme,
|
|
|
|
Modal: modalTheme,
|
|
|
|
Checkbox: checkboxTheme,
|
|
|
|
Menu: menuTheme,
|
|
|
|
Text: textTheme,
|
feat(ui): remove themes, add hand-crafted dark and light modes
Themes are very fun but due to the differences in perceived saturation and lightness across the
the color spectrum, it's impossible to have have multiple themes that look great without hand-
crafting *every* shade for *every* theme. We've ended up with 4 OK themes (well, 3, because the
light theme was pretty bad).
I've removed the themes and added color mode support. There is now a single dark and light mode,
each with their own color palette and the classic grey / purple / yellow invoke colors that
@blessedcoolant first designed.
I've re-styled almost everything except the model manager and lightbox, which I keep forgetting
to work on.
One new concept is the Chakra `layerStyle`. This lets us define "layers" - think body, first layer,
second layer, etc - that can be applied on various components. By defining layers, we can be more
consistent about the z-axis and its relationship to color and lightness.
2023-06-26 14:12:33 +00:00
|
|
|
Tooltip: tooltipTheme,
|
2023-03-06 09:02:40 +00:00
|
|
|
},
|
|
|
|
};
|