mirror of
https://github.com/toeverything/AFFiNE.git
synced 2025-01-01 01:32:36 +03:00
feat: add affine next theme (#1867)
This commit is contained in:
parent
b2ff6e379c
commit
778f76dfed
@ -75,6 +75,7 @@ __metadata:
|
|||||||
clsx: ^1.2.1
|
clsx: ^1.2.1
|
||||||
concurrently: ^8.0.1
|
concurrently: ^8.0.1
|
||||||
jest-mock: ^29.5.0
|
jest-mock: ^29.5.0
|
||||||
|
kebab-case: ^1.0.2
|
||||||
lit: ^2.7.2
|
lit: ^2.7.2
|
||||||
react: ^18.2.0
|
react: ^18.2.0
|
||||||
react-dnd: ^16.0.1
|
react-dnd: ^16.0.1
|
||||||
@ -12289,6 +12290,13 @@ __metadata:
|
|||||||
languageName: node
|
languageName: node
|
||||||
linkType: hard
|
linkType: hard
|
||||||
|
|
||||||
|
"kebab-case@npm:^1.0.2":
|
||||||
|
version: 1.0.2
|
||||||
|
resolution: "kebab-case@npm:1.0.2"
|
||||||
|
checksum: bf01164e11c544ee9b3aa1a91c2e7d6aa6b3356b834a5e885d43f36db14aae5d347cd4a298a566133321b82fde6bac6b597f148ac19bfd3d3fc81e1034a79729
|
||||||
|
languageName: node
|
||||||
|
linkType: hard
|
||||||
|
|
||||||
"keyv@npm:^4.0.0":
|
"keyv@npm:^4.0.0":
|
||||||
version: 4.5.2
|
version: 4.5.2
|
||||||
resolution: "keyv@npm:4.5.2"
|
resolution: "keyv@npm:4.5.2"
|
||||||
|
@ -1,11 +1,19 @@
|
|||||||
import type { AffineTheme, ThemeProviderProps } from '@affine/component';
|
import type {
|
||||||
|
AffineNextCssVariables,
|
||||||
|
AffineNextLightColorScheme,
|
||||||
|
AffineTheme,
|
||||||
|
ThemeProviderProps,
|
||||||
|
} from '@affine/component';
|
||||||
import {
|
import {
|
||||||
getDarkTheme,
|
getDarkTheme,
|
||||||
getLightTheme,
|
getLightTheme,
|
||||||
globalThemeVariables,
|
globalThemeVariables,
|
||||||
|
nextDarkColorScheme,
|
||||||
|
nextLightColorScheme,
|
||||||
ThemeProvider as AffineThemeProvider,
|
ThemeProvider as AffineThemeProvider,
|
||||||
} from '@affine/component';
|
} from '@affine/component';
|
||||||
import { GlobalStyles } from '@mui/material';
|
import { GlobalStyles } from '@mui/material';
|
||||||
|
import kebabCase from 'kebab-case';
|
||||||
import { ThemeProvider as NextThemeProvider, useTheme } from 'next-themes';
|
import { ThemeProvider as NextThemeProvider, useTheme } from 'next-themes';
|
||||||
import type { PropsWithChildren } from 'react';
|
import type { PropsWithChildren } from 'react';
|
||||||
import type React from 'react';
|
import type React from 'react';
|
||||||
@ -15,7 +23,15 @@ import { useCurrentMode } from '../hooks/current/use-current-mode';
|
|||||||
|
|
||||||
const ThemeInjector = memo<{
|
const ThemeInjector = memo<{
|
||||||
themeStyle: AffineTheme;
|
themeStyle: AffineTheme;
|
||||||
}>(function ThemeInjector({ themeStyle }) {
|
nextThemeStyle: AffineNextLightColorScheme;
|
||||||
|
}>(function ThemeInjector({ themeStyle, nextThemeStyle }) {
|
||||||
|
const injectAffineNextTheme = useMemo(() => {
|
||||||
|
return Object.entries(nextThemeStyle).reduce((variables, [key, value]) => {
|
||||||
|
variables[`--affine-${kebabCase(key)}` as keyof AffineNextCssVariables] =
|
||||||
|
value;
|
||||||
|
return variables;
|
||||||
|
}, {} as AffineNextCssVariables);
|
||||||
|
}, [nextThemeStyle]);
|
||||||
return (
|
return (
|
||||||
<GlobalStyles
|
<GlobalStyles
|
||||||
styles={{
|
styles={{
|
||||||
@ -24,6 +40,7 @@ const ThemeInjector = memo<{
|
|||||||
// },
|
// },
|
||||||
':root': {
|
':root': {
|
||||||
...globalThemeVariables(themeStyle),
|
...globalThemeVariables(themeStyle),
|
||||||
|
...injectAffineNextTheme,
|
||||||
},
|
},
|
||||||
html: {
|
html: {
|
||||||
fontFamily: themeStyle.font.family,
|
fontFamily: themeStyle.font.family,
|
||||||
@ -56,6 +73,9 @@ const ThemeProviderInner = memo<React.PropsWithChildren>(
|
|||||||
>
|
>
|
||||||
<ThemeInjector
|
<ThemeInjector
|
||||||
themeStyle={deferTheme === 'dark' ? darkThemeStyle : themeStyle}
|
themeStyle={deferTheme === 'dark' ? darkThemeStyle : themeStyle}
|
||||||
|
nextThemeStyle={
|
||||||
|
deferTheme === 'dark' ? nextDarkColorScheme : nextLightColorScheme
|
||||||
|
}
|
||||||
/>
|
/>
|
||||||
{children}
|
{children}
|
||||||
</AffineThemeProvider>
|
</AffineThemeProvider>
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
"@radix-ui/react-avatar": "^1.0.2",
|
"@radix-ui/react-avatar": "^1.0.2",
|
||||||
"@toeverything/hooks": "workspace:*",
|
"@toeverything/hooks": "workspace:*",
|
||||||
"clsx": "^1.2.1",
|
"clsx": "^1.2.1",
|
||||||
|
"kebab-case": "^1.0.2",
|
||||||
"lit": "^2.7.2",
|
"lit": "^2.7.2",
|
||||||
"react": "^18.2.0",
|
"react": "^18.2.0",
|
||||||
"react-dnd": "^16.0.1",
|
"react-dnd": "^16.0.1",
|
||||||
|
153
packages/component/src/styles/color-scheme.ts
Normal file
153
packages/component/src/styles/color-scheme.ts
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
type Kebab<
|
||||||
|
T extends string,
|
||||||
|
A extends string = ''
|
||||||
|
> = T extends `${infer F}${infer R}`
|
||||||
|
? Kebab<R, `${A}${F extends Lowercase<F> ? '' : '-'}${Lowercase<F>}`>
|
||||||
|
: A;
|
||||||
|
|
||||||
|
export type AffineNextLightColorScheme = typeof nextLightColorScheme;
|
||||||
|
|
||||||
|
export type AffineNextCssVariables = {
|
||||||
|
[Key in `--affine-${Kebab<keyof AffineNextLightColorScheme>}`]: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Refs: https://github.com/toeverything/AFFiNE/issues/1796
|
||||||
|
export const nextLightColorScheme = {
|
||||||
|
brandColor: 'rgb(84, 56, 255)',
|
||||||
|
tertiaryColor: 'rgb(243, 240, 255)',
|
||||||
|
primaryColor: 'rgb(84, 56, 255)',
|
||||||
|
secondaryColor: 'rgb(125, 145, 255)',
|
||||||
|
backgroundSuccessColor: 'rgb(255, 255, 255)',
|
||||||
|
backgroundErrorColor: 'rgba(255, 255, 255, 0.2)',
|
||||||
|
backgroundProcessingColor: 'rgb(255, 255, 255)',
|
||||||
|
backgroundWarningColor: 'rgb(255, 255, 255)',
|
||||||
|
backgroundPrimaryColor: 'rgb(255, 255, 255)',
|
||||||
|
backgroundOverlayPanelColor: 'rgb(251, 251, 252)',
|
||||||
|
backgroundSecondaryColor: 'rgb(251, 250, 252)',
|
||||||
|
backgroundTertiaryColor: 'rgb(233, 233, 236)',
|
||||||
|
backgroundCodeBlock: 'rgb(250, 251, 253)',
|
||||||
|
backgroundModalColor: 'rgba(0, 0, 0, 0.6)',
|
||||||
|
textPrimaryColor: 'rgb(66, 65, 73)',
|
||||||
|
textSecondaryColor: 'rgb(142, 141, 145)',
|
||||||
|
textDisableColor: 'rgb(169, 169, 173)',
|
||||||
|
textEmphasisColor: 'rgb(84, 56, 255)',
|
||||||
|
hoverColor: 'rgba(0, 0, 0, 0.04)',
|
||||||
|
linkColor: 'rgb(125, 145, 255)',
|
||||||
|
quoteColor: 'rgb(100, 95, 130)',
|
||||||
|
iconColor: 'rgb(119, 117, 125)',
|
||||||
|
iconSecondary: 'rgba(119, 117, 125, 0.6)',
|
||||||
|
borderColor: 'rgb(227, 226, 228)',
|
||||||
|
dividerColor: 'rgb(227, 226, 228)',
|
||||||
|
placeholderColor: 'rgb(192, 191, 193)',
|
||||||
|
edgelessGridColor: 'rgb(230, 230, 230)',
|
||||||
|
successColor: 'rgb(16, 203, 134)',
|
||||||
|
warningColor: 'rgb(255, 99, 31)',
|
||||||
|
errorColor: 'rgb(235, 67, 53)',
|
||||||
|
processingColor: 'rgb(39, 118, 255)',
|
||||||
|
black10: 'rgba(0, 0, 0, 0.1)',
|
||||||
|
black30: 'rgba(0, 0, 0, 0.3)',
|
||||||
|
black50: 'rgba(0, 0, 0, 0.5)',
|
||||||
|
black60: 'rgba(0, 0, 0, 0.6)',
|
||||||
|
black80: 'rgba(0, 0, 0, 0.8)',
|
||||||
|
black90: 'rgba(0, 0, 0, 0.9)',
|
||||||
|
black: 'rgb(0, 0, 0)',
|
||||||
|
white10: 'rgba(255, 255, 255, 0.1)',
|
||||||
|
white30: 'rgba(255, 255, 255, 0.3)',
|
||||||
|
white50: 'rgba(255, 255, 255, 0.5)',
|
||||||
|
white60: 'rgba(255, 255, 255, 0.6)',
|
||||||
|
white80: 'rgba(255, 255, 255, 0.8)',
|
||||||
|
white90: 'rgba(255, 255, 255, 0.9)',
|
||||||
|
white: 'rgb(255, 255, 255)',
|
||||||
|
tagWhite: 'rgb(245, 245, 245)',
|
||||||
|
tagGray: 'rgb(227, 226, 224)',
|
||||||
|
tagRed: 'rgb(255, 225, 225)',
|
||||||
|
tagOrange: 'rgb(255, 234, 202)',
|
||||||
|
tagYellow: 'rgb(255, 244, 216)',
|
||||||
|
tagGreen: 'rgb(223, 244, 232)',
|
||||||
|
tagTeal: 'rgb(223, 244, 243)',
|
||||||
|
tagBlue: 'rgb(225, 239, 255)',
|
||||||
|
tagPurple: 'rgb(243, 240, 255)',
|
||||||
|
tagPink: 'rgb(252, 232, 255)',
|
||||||
|
paletteYellow: 'rgb(255, 232, 56)',
|
||||||
|
paletteOrange: 'rgb(255, 175, 56)',
|
||||||
|
paletteTangerine: 'rgb(255, 99, 31)',
|
||||||
|
paletteRed: 'rgb(252, 63, 85)',
|
||||||
|
paletteMagenta: 'rgb(255, 56, 179)',
|
||||||
|
palettePurple: 'rgb(182, 56, 255)',
|
||||||
|
paletteNavy: 'rgb(59, 37, 204)',
|
||||||
|
paletteBlue: 'rgb(79, 144, 255)',
|
||||||
|
paletteGreen: 'rgb(16, 203, 134)',
|
||||||
|
paletteGrey: 'rgb(153, 153, 153)',
|
||||||
|
paletteWhite: 'rgb(255, 255, 255)',
|
||||||
|
paletteBlack: 'rgb(0, 0, 0)',
|
||||||
|
};
|
||||||
|
|
||||||
|
export const nextDarkColorScheme = {
|
||||||
|
brandColor: 'rgb(84, 56, 255)',
|
||||||
|
primaryColor: 'rgb(118, 95, 254)',
|
||||||
|
secondaryColor: 'rgb(144, 150, 245)',
|
||||||
|
tertiaryColor: 'rgb(30, 30, 30)',
|
||||||
|
hoverColor: 'rgba(255, 255, 255, 0.1)',
|
||||||
|
iconColor: 'rgb(168, 168, 160)',
|
||||||
|
iconSecondary: 'rgba(168,168,160,0.6)',
|
||||||
|
borderColor: 'rgb(57, 57, 57)',
|
||||||
|
dividerColor: 'rgb(114, 114, 114)',
|
||||||
|
placeholderColor: 'rgb(62, 62, 63)',
|
||||||
|
quoteColor: 'rgb(147, 144, 163)',
|
||||||
|
linkColor: 'rgb(185, 191, 227)',
|
||||||
|
edgelessGridColor: 'rgb(49, 49, 49)',
|
||||||
|
successColor: 'rgb(77, 213, 181)',
|
||||||
|
warningColor: 'rgb(255, 123, 77)',
|
||||||
|
errorColor: 'rgb(212, 140, 130)',
|
||||||
|
processingColor: 'rgb(195, 215, 255)',
|
||||||
|
textEmphasisColor: 'rgb(208, 205, 220)',
|
||||||
|
textPrimaryColor: 'rgb(234, 234, 234)',
|
||||||
|
textSecondaryColor: 'rgb(156, 156, 160)',
|
||||||
|
textDisableColor: 'rgb(119, 117, 125)',
|
||||||
|
black10: 'rgba(255, 255, 255, 0.1)',
|
||||||
|
black30: 'rgba(255, 255, 255, 0.3)',
|
||||||
|
black50: 'rgba(255, 255, 255, 0.5)',
|
||||||
|
black60: 'rgba(255, 255, 255, 0.6)',
|
||||||
|
black80: 'rgba(255, 255, 255, 0.8)',
|
||||||
|
black90: 'rgba(255, 255, 255, 0.9)',
|
||||||
|
black: 'rgb(255, 255, 255)',
|
||||||
|
white10: 'rgba(0, 0, 0, 0.1)',
|
||||||
|
white30: 'rgba(0, 0, 0, 0.3)',
|
||||||
|
white50: 'rgba(0, 0, 0, 0.5)',
|
||||||
|
white60: 'rgba(0, 0, 0, 0.6)',
|
||||||
|
white80: 'rgba(0, 0, 0, 0.8)',
|
||||||
|
white90: 'rgba(0, 0, 0, 0.9)',
|
||||||
|
white: 'rgb(0, 0, 0)',
|
||||||
|
backgroundCodeBlock: 'rgb(41, 44, 51)',
|
||||||
|
backgroundTertiaryColor: 'rgb(30, 30, 30)',
|
||||||
|
backgroundProcessingColor: 'rgb(255, 255, 255)',
|
||||||
|
backgroundErrorColor: 'rgb(255, 255, 255)',
|
||||||
|
backgroundWarningColor: 'rgb(255, 255, 255)',
|
||||||
|
backgroundSuccessColor: 'rgb(255, 255, 255)',
|
||||||
|
backgroundPrimaryColor: 'rgb(20, 20, 20)',
|
||||||
|
backgroundSecondaryColor: 'rgb(32, 32, 32)',
|
||||||
|
backgroundModalColor: 'rgba(0, 0, 0, 0.8)',
|
||||||
|
backgroundOverlayPanelColor: 'rgb(30, 30, 30)',
|
||||||
|
tagBlue: 'rgb(10, 84, 170)',
|
||||||
|
tagGreen: 'rgb(55, 135, 79)',
|
||||||
|
tagTeal: 'rgb(33, 145, 138)',
|
||||||
|
tagWhite: 'rgb(84, 84, 84)',
|
||||||
|
tagPurple: 'rgb(59, 38, 141)',
|
||||||
|
tagRed: 'rgb(139, 63, 63)',
|
||||||
|
tagPink: 'rgb(194, 132, 132)',
|
||||||
|
tagYellow: 'rgb(187, 165, 61)',
|
||||||
|
tagOrange: 'rgb(231, 161, 58)',
|
||||||
|
tagGray: 'rgb(41, 41, 41)',
|
||||||
|
paletteYellow: 'rgb(255, 232, 56)',
|
||||||
|
paletteOrange: 'rgb(255, 175, 56)',
|
||||||
|
paletteTangerine: 'rgb(255, 99, 31)',
|
||||||
|
paletteRed: 'rgb(252, 63, 85)',
|
||||||
|
paletteMagenta: 'rgb(255, 56, 179)',
|
||||||
|
palettePurple: 'rgb(182, 56, 255)',
|
||||||
|
paletteNavy: 'rgb(59, 37, 204)',
|
||||||
|
paletteBlue: 'rgb(79, 144, 255)',
|
||||||
|
paletteGreen: 'rgb(16, 203, 134)',
|
||||||
|
paletteGrey: 'rgb(153, 153, 153)',
|
||||||
|
paletteWhite: 'rgb(255, 255, 255)',
|
||||||
|
paletteBlack: 'rgb(0, 0, 0)',
|
||||||
|
} satisfies AffineNextLightColorScheme;
|
@ -1,3 +1,4 @@
|
|||||||
|
export * from './color-scheme';
|
||||||
export * from './helper';
|
export * from './helper';
|
||||||
export * from './styled';
|
export * from './styled';
|
||||||
export * from './theme';
|
export * from './theme';
|
||||||
|
@ -156,6 +156,9 @@ export const getDarkTheme = (
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated these theme will be removed in the future
|
||||||
|
*/
|
||||||
export const globalThemeVariables: (
|
export const globalThemeVariables: (
|
||||||
theme: AffineTheme
|
theme: AffineTheme
|
||||||
) => AffineThemeCSSVariables = theme => {
|
) => AffineThemeCSSVariables = theme => {
|
||||||
|
@ -75,6 +75,7 @@ __metadata:
|
|||||||
clsx: ^1.2.1
|
clsx: ^1.2.1
|
||||||
concurrently: ^8.0.1
|
concurrently: ^8.0.1
|
||||||
jest-mock: ^29.5.0
|
jest-mock: ^29.5.0
|
||||||
|
kebab-case: ^1.0.2
|
||||||
lit: ^2.7.2
|
lit: ^2.7.2
|
||||||
react: ^18.2.0
|
react: ^18.2.0
|
||||||
react-dnd: ^16.0.1
|
react-dnd: ^16.0.1
|
||||||
@ -14130,6 +14131,13 @@ __metadata:
|
|||||||
languageName: node
|
languageName: node
|
||||||
linkType: hard
|
linkType: hard
|
||||||
|
|
||||||
|
"kebab-case@npm:^1.0.2":
|
||||||
|
version: 1.0.2
|
||||||
|
resolution: "kebab-case@npm:1.0.2"
|
||||||
|
checksum: bf01164e11c544ee9b3aa1a91c2e7d6aa6b3356b834a5e885d43f36db14aae5d347cd4a298a566133321b82fde6bac6b597f148ac19bfd3d3fc81e1034a79729
|
||||||
|
languageName: node
|
||||||
|
linkType: hard
|
||||||
|
|
||||||
"keyv@npm:^4.5.2":
|
"keyv@npm:^4.5.2":
|
||||||
version: 4.5.2
|
version: 4.5.2
|
||||||
resolution: "keyv@npm:4.5.2"
|
resolution: "keyv@npm:4.5.2"
|
||||||
|
Loading…
Reference in New Issue
Block a user