2023-03-06 09:02:40 +00:00
|
|
|
import { ThemeOverride } from '@chakra-ui/react';
|
|
|
|
import type { StyleFunctionProps } from '@chakra-ui/styled-system';
|
2023-03-06 09:40:59 +00:00
|
|
|
|
2023-03-06 09:02:40 +00:00
|
|
|
import { invokeAIThemeColors } from './colors/invokeAI';
|
|
|
|
import { accordionTheme } from './components/accordion';
|
|
|
|
import { buttonTheme } from './components/button';
|
|
|
|
import { checkboxTheme } from './components/checkbox';
|
|
|
|
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-03-09 09:30:29 +00:00
|
|
|
import { no_scrollbar, scrollbar as _scrollbar } from './components/scrollbar';
|
2023-03-06 09:02:40 +00:00
|
|
|
import { selectTheme } from './components/select';
|
|
|
|
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';
|
|
|
|
|
|
|
|
export const theme: ThemeOverride = {
|
|
|
|
config: {
|
|
|
|
cssVarPrefix: 'invokeai',
|
|
|
|
},
|
|
|
|
styles: {
|
2023-03-06 09:40:59 +00:00
|
|
|
global: (_props: StyleFunctionProps) => ({
|
2023-03-06 09:02:40 +00:00
|
|
|
body: {
|
2023-03-06 09:40:59 +00:00
|
|
|
bg: 'base.900',
|
|
|
|
color: 'base.50',
|
2023-04-17 01:26:10 +00:00
|
|
|
overflow: {
|
|
|
|
base: 'scroll',
|
|
|
|
xl: 'hidden',
|
|
|
|
},
|
2023-03-06 09:02:40 +00:00
|
|
|
},
|
2023-03-09 09:30:29 +00:00
|
|
|
'*': { ...no_scrollbar },
|
2023-03-06 09:02:40 +00:00
|
|
|
}),
|
|
|
|
},
|
|
|
|
direction: 'ltr',
|
|
|
|
fonts: {
|
|
|
|
body: `'Inter', sans-serif`,
|
|
|
|
},
|
2023-04-17 01:26:10 +00:00
|
|
|
breakpoints: {
|
|
|
|
base: '0em', // 0px and onwards
|
|
|
|
sm: '30em', // 480px and onwards
|
|
|
|
md: '48em', // 768px and onwards
|
|
|
|
lg: '62em', // 992px and onwards
|
|
|
|
xl: '80em', // 1280px and onwards
|
|
|
|
'2xl': '96em', // 1536px and onwards
|
|
|
|
},
|
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-04-22 10:29:42 +00:00
|
|
|
nodeSelectedOutline: `0 0 0 2px var(--invokeai-colors-base-500)`,
|
2023-03-06 09:02:40 +00:00
|
|
|
},
|
|
|
|
colors: {
|
|
|
|
...invokeAIThemeColors,
|
|
|
|
},
|
|
|
|
components: {
|
|
|
|
Button: buttonTheme, // Button and IconButton
|
|
|
|
Input: inputTheme,
|
|
|
|
Textarea: textareaTheme,
|
|
|
|
Tabs: tabsTheme,
|
|
|
|
Progress: progressTheme,
|
|
|
|
Accordion: accordionTheme,
|
|
|
|
FormLabel: formLabelTheme,
|
|
|
|
Switch: switchTheme,
|
|
|
|
NumberInput: numberInputTheme,
|
|
|
|
Select: selectTheme,
|
|
|
|
Slider: sliderTheme,
|
|
|
|
Popover: popoverTheme,
|
|
|
|
Modal: modalTheme,
|
|
|
|
Checkbox: checkboxTheme,
|
|
|
|
Menu: menuTheme,
|
|
|
|
Text: textTheme,
|
|
|
|
},
|
|
|
|
};
|