mirror of
				https://github.com/lutinglt/gitea-github-theme.git
				synced 2025-10-26 13:00:31 +00:00 
			
		
		
		
	颜色变量计算&颜色主题迁移
This commit is contained in:
		
							
								
								
									
										324
									
								
								src/core/color.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										324
									
								
								src/core/color.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,324 @@ | ||||
| import { rgba } from "polished"; | ||||
| import { scaleColorLight } from "src/functions"; | ||||
| import type { Ansi, Based, Console, Diff, Message, Named, Primary, Secondary } from "src/types"; | ||||
| import { themeVars } from "src/types/vars"; | ||||
| import type { Theme } from "./theme"; | ||||
|  | ||||
| interface ColorTheme { | ||||
|   isDarkTheme: boolean; | ||||
|   primary: string; | ||||
|   primaryContrast: string; | ||||
|   secondary: string; | ||||
|   red: string; | ||||
|   orange: string; | ||||
|   yellow: string; | ||||
|   olive: string; | ||||
|   green: string; | ||||
|   teal: string; | ||||
|   blue: string; | ||||
|   violet: string; | ||||
|   purple: string; | ||||
|   pink: string; | ||||
|   brown: string; | ||||
|   black: string; | ||||
|   grey: string; | ||||
|   gold: string; | ||||
|   white: string; | ||||
|   console: Console; | ||||
|   diff: Diff; | ||||
|   based: Based; | ||||
| } | ||||
|  | ||||
| /** 定义颜色, 用于生成颜色主题 | ||||
|  * @example | ||||
|  * 文件名: `color-dark.css.ts` | ||||
|  * import type { Primary } from "src/types"; | ||||
|  * import { defineTheme, themeVars } from "src"; | ||||
|  * | ||||
|  * const primary: Primary = { | ||||
|  *   self: "#ffffff", | ||||
|  *   contrast: themeVars.color.white, | ||||
|  *   ... | ||||
|  * } | ||||
|  * | ||||
|  * export default defineTheme({ | ||||
|  *   isDarkTheme: "true", | ||||
|  *   color: { | ||||
|  *     primary, | ||||
|  *     ... | ||||
|  *   } | ||||
|  * }) | ||||
|  */ | ||||
| export function defineTheme(theme: ColorTheme): Theme { | ||||
|   const lighten = theme.isDarkTheme ? -1 : 1; | ||||
|  | ||||
|   const primary: Primary = { | ||||
|     self: theme.primary, | ||||
|     contrast: theme.primaryContrast, | ||||
|     dark: { | ||||
|       num1: scaleColorLight(theme.primary, -3 * lighten), | ||||
|       num2: scaleColorLight(theme.primary, -6 * lighten), | ||||
|       num3: scaleColorLight(theme.primary, -9 * lighten), | ||||
|       num4: scaleColorLight(theme.primary, -12 * lighten), | ||||
|       num5: scaleColorLight(theme.primary, -15 * lighten), | ||||
|       num6: scaleColorLight(theme.primary, -18 * lighten), | ||||
|       num7: scaleColorLight(theme.primary, -21 * lighten), | ||||
|     }, | ||||
|     light: { | ||||
|       num1: scaleColorLight(theme.primary, 3 * lighten), | ||||
|       num2: scaleColorLight(theme.primary, 6 * lighten), | ||||
|       num3: scaleColorLight(theme.primary, 9 * lighten), | ||||
|       num4: scaleColorLight(theme.primary, 12 * lighten), | ||||
|       num5: scaleColorLight(theme.primary, 15 * lighten), | ||||
|       num6: scaleColorLight(theme.primary, 18 * lighten), | ||||
|       num7: scaleColorLight(theme.primary, 21 * lighten), | ||||
|     }, | ||||
|     alpha: { | ||||
|       num10: rgba(theme.primary, 0.1), | ||||
|       num20: rgba(theme.primary, 0.2), | ||||
|       num30: rgba(theme.primary, 0.3), | ||||
|       num40: rgba(theme.primary, 0.4), | ||||
|       num50: rgba(theme.primary, 0.5), | ||||
|       num60: rgba(theme.primary, 0.6), | ||||
|       num70: rgba(theme.primary, 0.7), | ||||
|       num80: rgba(theme.primary, 0.8), | ||||
|       num90: rgba(theme.primary, 0.9), | ||||
|     }, | ||||
|     hover: theme.isDarkTheme ? themeVars.color.primary.light.num1 : themeVars.color.primary.dark.num1, | ||||
|     active: theme.isDarkTheme ? themeVars.color.primary.light.num2 : themeVars.color.primary.dark.num2, | ||||
|   }; | ||||
|  | ||||
|   const secondary: Secondary = { | ||||
|     self: theme.secondary, | ||||
|     dark: { | ||||
|       num1: scaleColorLight(theme.secondary, -3 * lighten), | ||||
|       num2: scaleColorLight(theme.secondary, -6 * lighten), | ||||
|       num3: scaleColorLight(theme.secondary, -9 * lighten), | ||||
|       num4: scaleColorLight(theme.secondary, -12 * lighten), | ||||
|       num5: scaleColorLight(theme.secondary, -15 * lighten), | ||||
|       num6: scaleColorLight(theme.secondary, -18 * lighten), | ||||
|       num7: scaleColorLight(theme.secondary, -21 * lighten), | ||||
|       num8: scaleColorLight(theme.secondary, -24 * lighten), | ||||
|       num9: scaleColorLight(theme.secondary, -27 * lighten), | ||||
|       num10: scaleColorLight(theme.secondary, -30 * lighten), | ||||
|       num11: scaleColorLight(theme.secondary, -33 * lighten), | ||||
|       num12: scaleColorLight(theme.secondary, -36 * lighten), | ||||
|       num13: scaleColorLight(theme.secondary, -39 * lighten), | ||||
|     }, | ||||
|     light: { | ||||
|       num1: scaleColorLight(theme.secondary, 3 * lighten), | ||||
|       num2: scaleColorLight(theme.secondary, 6 * lighten), | ||||
|       num3: scaleColorLight(theme.secondary, 9 * lighten), | ||||
|       num4: scaleColorLight(theme.secondary, 12 * lighten), | ||||
|     }, | ||||
|     alpha: { | ||||
|       num10: rgba(theme.secondary, 0.1), | ||||
|       num20: rgba(theme.secondary, 0.2), | ||||
|       num30: rgba(theme.secondary, 0.3), | ||||
|       num40: rgba(theme.secondary, 0.4), | ||||
|       num50: rgba(theme.secondary, 0.5), | ||||
|       num60: rgba(theme.secondary, 0.6), | ||||
|       num70: rgba(theme.secondary, 0.7), | ||||
|       num80: rgba(theme.secondary, 0.8), | ||||
|       num90: rgba(theme.secondary, 0.9), | ||||
|     }, | ||||
|     button: themeVars.color.secondary.dark.num4, | ||||
|     hover: theme.isDarkTheme ? themeVars.color.secondary.dark.num3 : themeVars.color.secondary.dark.num5, | ||||
|     active: theme.isDarkTheme ? themeVars.color.secondary.dark.num2 : themeVars.color.secondary.dark.num6, | ||||
|   }; | ||||
|  | ||||
|   const named: Named = { | ||||
|     red: { | ||||
|       self: theme.red, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.red, 10) : scaleColorLight(theme.red, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.red, -10), | ||||
|         num2: scaleColorLight(theme.red, -20), | ||||
|       }, | ||||
|       badge: { | ||||
|         self: theme.red, | ||||
|         bg: rgba(theme.red, 0.1), | ||||
|         hover: { | ||||
|           bg: rgba(theme.red, 0.3), | ||||
|         }, | ||||
|       }, | ||||
|     }, | ||||
|     orange: { | ||||
|       self: theme.orange, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.orange, 10) : scaleColorLight(theme.orange, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.orange, -10), | ||||
|         num2: scaleColorLight(theme.orange, -20), | ||||
|       }, | ||||
|       badge: { | ||||
|         self: theme.orange, | ||||
|         bg: rgba(theme.orange, 0.1), | ||||
|         hover: { | ||||
|           bg: rgba(theme.orange, 0.3), | ||||
|         }, | ||||
|       }, | ||||
|     }, | ||||
|     yellow: { | ||||
|       self: theme.yellow, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.yellow, 10) : scaleColorLight(theme.yellow, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.yellow, -10), | ||||
|         num2: scaleColorLight(theme.yellow, -20), | ||||
|       }, | ||||
|       badge: { | ||||
|         self: theme.yellow, | ||||
|         bg: rgba(theme.yellow, 0.1), | ||||
|         hover: { | ||||
|           bg: rgba(theme.yellow, 0.3), | ||||
|         }, | ||||
|       }, | ||||
|     }, | ||||
|     olive: { | ||||
|       self: theme.olive, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.olive, 10) : scaleColorLight(theme.olive, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.olive, -10), | ||||
|         num2: scaleColorLight(theme.olive, -20), | ||||
|       }, | ||||
|     }, | ||||
|     green: { | ||||
|       self: theme.green, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.green, 10) : scaleColorLight(theme.green, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.green, -10), | ||||
|         num2: scaleColorLight(theme.green, -20), | ||||
|       }, | ||||
|       badge: { | ||||
|         self: theme.green, | ||||
|         bg: rgba(theme.green, 0.1), | ||||
|         hover: { | ||||
|           bg: rgba(theme.green, 0.3), | ||||
|         }, | ||||
|       }, | ||||
|     }, | ||||
|     teal: { | ||||
|       self: theme.teal, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.teal, 10) : scaleColorLight(theme.teal, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.teal, -10), | ||||
|         num2: scaleColorLight(theme.teal, -20), | ||||
|       }, | ||||
|     }, | ||||
|     blue: { | ||||
|       self: theme.blue, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.blue, 10) : scaleColorLight(theme.blue, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.blue, -10), | ||||
|         num2: scaleColorLight(theme.blue, -20), | ||||
|       }, | ||||
|     }, | ||||
|     violet: { | ||||
|       self: theme.violet, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.violet, 10) : scaleColorLight(theme.violet, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.violet, -10), | ||||
|         num2: scaleColorLight(theme.violet, -20), | ||||
|       }, | ||||
|     }, | ||||
|     purple: { | ||||
|       self: theme.purple, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.purple, 10) : scaleColorLight(theme.purple, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.purple, -10), | ||||
|         num2: scaleColorLight(theme.purple, -20), | ||||
|       }, | ||||
|     }, | ||||
|     pink: { | ||||
|       self: theme.pink, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.pink, 10) : scaleColorLight(theme.pink, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.pink, -10), | ||||
|         num2: scaleColorLight(theme.pink, -20), | ||||
|       }, | ||||
|     }, | ||||
|     brown: { | ||||
|       self: theme.brown, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.brown, 10) : scaleColorLight(theme.brown, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.brown, -10), | ||||
|         num2: scaleColorLight(theme.brown, -20), | ||||
|       }, | ||||
|     }, | ||||
|     black: { | ||||
|       self: theme.black, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.black, 10) : scaleColorLight(theme.black, 25), | ||||
|       dark: { | ||||
|         num1: scaleColorLight(theme.black, -10), | ||||
|         num2: scaleColorLight(theme.black, -20), | ||||
|       }, | ||||
|     }, | ||||
|     grey: { | ||||
|       self: theme.grey, | ||||
|       light: theme.isDarkTheme ? scaleColorLight(theme.grey, 10) : scaleColorLight(theme.grey, 25), | ||||
|     }, | ||||
|     gold: theme.gold, | ||||
|     white: theme.white, | ||||
|   }; | ||||
|  | ||||
|   const message: Message = { | ||||
|     error: { | ||||
|       bg: { | ||||
|         self: rgba(theme.red, 0.1), | ||||
|         active: rgba(theme.red, 0.5), | ||||
|         hover: rgba(theme.red, 0.3), | ||||
|       }, | ||||
|       border: scaleColorLight(theme.red, 30 * lighten), | ||||
|       text: theme.red, | ||||
|     }, | ||||
|     success: { | ||||
|       bg: rgba(theme.green, 0.1), | ||||
|       border: scaleColorLight(theme.green, 30 * lighten), | ||||
|       text: theme.green, | ||||
|     }, | ||||
|     warning: { | ||||
|       bg: rgba(theme.yellow, 0.1), | ||||
|       border: scaleColorLight(theme.yellow, 30 * lighten), | ||||
|       text: theme.yellow, | ||||
|     }, | ||||
|     info: { | ||||
|       bg: rgba(theme.blue, 0.1), | ||||
|       border: scaleColorLight(theme.blue, 30 * lighten), | ||||
|       text: theme.blue, | ||||
|     }, | ||||
|   }; | ||||
|  | ||||
|   const ansi: Ansi = { | ||||
|     black: themeVars.color.black.self, | ||||
|     red: themeVars.color.red.self, | ||||
|     green: themeVars.color.green.self, | ||||
|     yellow: themeVars.color.yellow.self, | ||||
|     blue: themeVars.color.blue.self, | ||||
|     magenta: themeVars.color.pink.self, | ||||
|     cyan: themeVars.color.teal.self, | ||||
|     white: themeVars.color.console.fg.subtle, | ||||
|     bright: { | ||||
|       black: themeVars.color.black.light, | ||||
|       red: themeVars.color.red.light, | ||||
|       green: themeVars.color.green.light, | ||||
|       yellow: themeVars.color.yellow.light, | ||||
|       blue: themeVars.color.blue.light, | ||||
|       magenta: themeVars.color.pink.light, | ||||
|       cyan: themeVars.color.teal.light, | ||||
|       white: themeVars.color.console.fg.self, | ||||
|     }, | ||||
|   }; | ||||
|  | ||||
|   return { | ||||
|     isDarkTheme: theme.isDarkTheme.toString(), | ||||
|     color: { | ||||
|       primary, | ||||
|       secondary, | ||||
|       ...named, | ||||
|       ansi, | ||||
|       console: theme.console, | ||||
|       diff: theme.diff, | ||||
|       ...message, | ||||
|       ...theme.based, | ||||
|     }, | ||||
|   }; | ||||
| } | ||||
| @@ -2,7 +2,7 @@ import { createGlobalTheme, globalStyle } from "@vanilla-extract/css"; | ||||
| import { otherThemeVars, themeVars } from "src/types/vars"; | ||||
| import type { MapLeafNodes, WithOptionalLayer } from "./types"; | ||||
|  | ||||
| type Theme = WithOptionalLayer<MapLeafNodes<typeof themeVars, string>>; | ||||
| export type Theme = WithOptionalLayer<MapLeafNodes<typeof themeVars, string>>; | ||||
|  | ||||
| function stringToBoolean(str: string, name: string): boolean { | ||||
|   try { | ||||
| @@ -13,27 +13,6 @@ function stringToBoolean(str: string, name: string): boolean { | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** 定义主题, 用于生成颜色主题 | ||||
|  * @example | ||||
|  * 文件名: `color-dark.css.ts` | ||||
|  * import type { Primary } from "src/types"; | ||||
|  * import { defineTheme, themeVars } from "src"; | ||||
|  * | ||||
|  * const primary: Primary = { | ||||
|  *   self: "#000000", | ||||
|  *   contrast: themeVars.color.white, | ||||
|  *   ... | ||||
|  * } | ||||
|  * | ||||
|  * export default defineTheme({ | ||||
|  *   isDarkTheme: "true", | ||||
|  *   color: { | ||||
|  *     primary, | ||||
|  *     ... | ||||
|  *   } | ||||
|  * }) | ||||
|  */ | ||||
| export const defineTheme = (theme: Theme) => theme; | ||||
| export function createTheme(theme: Theme): void { | ||||
|   createGlobalTheme(":root", themeVars, theme); | ||||
|   createGlobalTheme(":root", otherThemeVars, { | ||||
| @@ -42,7 +21,7 @@ export function createTheme(theme: Theme): void { | ||||
|     }, | ||||
|   }); | ||||
|   globalStyle(":root", { | ||||
|     accentColor: themeVars.color.blue, | ||||
|     accentColor: themeVars.color.accent, | ||||
|     colorScheme: stringToBoolean(theme.isDarkTheme, "isDarkTheme") ? "dark" : "light", | ||||
|   }); | ||||
| } | ||||
|   | ||||
| @@ -1,3 +1,4 @@ | ||||
| export { css } from "@linaria/core"; | ||||
| export { defineTheme } from "./core/theme"; | ||||
| export { defineTheme } from "./core/color"; | ||||
| export type { Based, Console, Diff } from "./types"; | ||||
| export { themeVars } from "./types/vars"; | ||||
|   | ||||
| @@ -28,13 +28,13 @@ export const based = { | ||||
|   }, | ||||
|   /** 输入框 */ | ||||
|   input: { | ||||
|     text: null, | ||||
|     background: null, | ||||
|     toggleBackgound: "color-input-toggle-background", | ||||
|     border: { | ||||
|       self: null, | ||||
|       hover: null, | ||||
|     }, | ||||
|     text: null, | ||||
|     toggleBackgound: "color-input-toggle-background", | ||||
|   }, | ||||
|   light: { | ||||
|     self: null, | ||||
| @@ -86,12 +86,8 @@ export const based = { | ||||
|   label: { | ||||
|     text: null, | ||||
|     bg: null, | ||||
|     hover: { | ||||
|       bg: null, | ||||
|     }, | ||||
|     active: { | ||||
|       bg: null, | ||||
|     }, | ||||
|     hoverBg: "color-label-hover-bg", | ||||
|     activeBg: "color-label-active-bg", | ||||
|   }, | ||||
|   accent: null, | ||||
|   smallAccent: "color-small-accent", | ||||
|   | ||||
| @@ -2,5 +2,5 @@ export { based } from "./based"; | ||||
| export { ansi, console } from "./console"; | ||||
| export { diff } from "./diff"; | ||||
| export { primary, secondary } from "./main"; | ||||
| export { error, info, success, warning } from "./message"; | ||||
| export { message } from "./message"; | ||||
| export { named } from "./named"; | ||||
|   | ||||
| @@ -4,7 +4,7 @@ const msg = { | ||||
|   text: null, | ||||
| }; | ||||
|  | ||||
| export const error = { | ||||
| const error = { | ||||
|   ...msg, | ||||
|   bg: { | ||||
|     self: null, | ||||
| @@ -13,13 +13,20 @@ export const error = { | ||||
|   }, | ||||
| }; | ||||
|  | ||||
| export const success = { | ||||
| const success = { | ||||
|   ...msg, | ||||
| }; | ||||
|  | ||||
| export const warning = { | ||||
| const warning = { | ||||
|   ...msg, | ||||
| }; | ||||
| export const info = { | ||||
| const info = { | ||||
|   ...msg, | ||||
| }; | ||||
|  | ||||
| export const message = { | ||||
|   error, | ||||
|   success, | ||||
|   warning, | ||||
|   info, | ||||
| }; | ||||
|   | ||||
| @@ -4,3 +4,8 @@ import * as color from "./color"; | ||||
| export type Primary = MapLeafNodes<typeof color.primary, string>; | ||||
| export type Secondary = MapLeafNodes<typeof color.secondary, string>; | ||||
| export type Named = MapLeafNodes<typeof color.named, string>; | ||||
| export type Message = MapLeafNodes<typeof color.message, string>; | ||||
| export type Ansi = MapLeafNodes<typeof color.ansi, string>; | ||||
| export type Console = MapLeafNodes<typeof color.console, string>; | ||||
| export type Diff = MapLeafNodes<typeof color.diff, string>; | ||||
| export type Based = MapLeafNodes<typeof color.based, string>; | ||||
|   | ||||
| @@ -14,19 +14,14 @@ const vars = { | ||||
|   /** 用于标识当前是否为暗色主题: `"true"` 暗色 `"false"` 亮色 */ | ||||
|   isDarkTheme: "is-dark-theme", | ||||
|   color: { | ||||
|     ...color.message, | ||||
|     ...color.based, | ||||
|     ...color.named, | ||||
|     primary: color.primary, | ||||
|     secondary: color.secondary, | ||||
|     self: { | ||||
|       ...color.based, | ||||
|       ...color.named, | ||||
|     }, | ||||
|     ansi: color.ansi, | ||||
|     console: color.console, | ||||
|     diff: color.diff, | ||||
|     error: color.error, | ||||
|     success: color.success, | ||||
|     warning: color.warning, | ||||
|     info: color.info, | ||||
|   }, | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -1,2 +0,0 @@ | ||||
| import "styles/test"; | ||||
| import "styles/t1"; | ||||
| @@ -1,20 +0,0 @@ | ||||
| import { css, themeVars } from "src"; | ||||
|  | ||||
| export const setting_global = css` | ||||
|   .user-main-content, | ||||
|   .repo-setting-content, | ||||
|   .user-setting-content, | ||||
|   .org-setting-content, | ||||
|   .admin-setting-content { | ||||
|     .ui.right { | ||||
|       .ui.primary.button.tiny { | ||||
|         color: #fff; | ||||
|         background-color: #238636; | ||||
|         &:hover { | ||||
|           background-color: #29903b; | ||||
|           border-color: ${themeVars.color.primary.light.num1}; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| @@ -1,22 +0,0 @@ | ||||
| import { css, themeVars } from "src"; | ||||
| import { scaleColorLight } from "src/functions"; | ||||
|  | ||||
| const red = "#cc4848"; | ||||
|  | ||||
| export const setting_global = css` | ||||
|   @use "sass:color"; | ||||
|   .lines-num span:after { | ||||
|     color: ${themeVars.color.primary.hover}; | ||||
|   } | ||||
|   .ui.cards > .card, | ||||
|   .ui.card { | ||||
|     > .extra a:not(.ui):hover { | ||||
|       color: ${scaleColorLight(red, 10)}; | ||||
|       background-color: color.scale(#cc4848, $lightness: 10%); | ||||
|     } | ||||
|     .text { | ||||
|       color: ${scaleColorLight(red, -20)}; | ||||
|       background-color: color.scale(#cc4848, $lightness: -20%); | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| @@ -1,13 +0,0 @@ | ||||
| import { defineTheme } from "src"; | ||||
| import dark_theme from "themes/dark"; | ||||
|  | ||||
| export default defineTheme({ | ||||
|   ...dark_theme, | ||||
|   color: { | ||||
|     ...dark_theme.color, | ||||
|     primary: { | ||||
|       ...dark_theme.color.primary, | ||||
|       hover: "pink", | ||||
|     }, | ||||
|   }, | ||||
| }); | ||||
| @@ -1,52 +1,172 @@ | ||||
| import type { Primary } from "src/types"; | ||||
| import type { Based, Console, Diff } from "src"; | ||||
| import { defineTheme, themeVars } from "src"; | ||||
|  | ||||
| const dark = { | ||||
|   num1: "#739cb3", | ||||
|   num2: "#40aaff", | ||||
|   num3: "#92b4c4", | ||||
|   num4: "#a1bbcd", | ||||
|   num5: "#cfddc1", | ||||
|   num6: "#e7eee0", | ||||
|   num7: "#f8faf6", | ||||
| const console: Console = { | ||||
|   fg: { | ||||
|     self: "#f0f6fc", | ||||
|     subtle: "#9198a1", | ||||
|   }, | ||||
|   bg: "#010409", | ||||
|   border: "#2b3139", | ||||
|   active: { | ||||
|     bg: "#2a313c", | ||||
|   }, | ||||
|   hover: { | ||||
|     bg: "#15191f", | ||||
|   }, | ||||
|   menu: { | ||||
|     bg: themeVars.color.body, | ||||
|     border: themeVars.color.light.border, | ||||
|   }, | ||||
| }; | ||||
|  | ||||
| const light = { | ||||
|   num1: themeVars.color.primary.self, | ||||
|   num2: "#437aad", | ||||
|   num3: "#415b8b", | ||||
|   num4: "#25425a", | ||||
|   num5: "#223546", | ||||
|   num6: "#131923", | ||||
|   num7: "#06090b", | ||||
| const diff: Diff = { | ||||
|   added: { | ||||
|     linenum: { | ||||
|       bg: "#1c4428", | ||||
|     }, | ||||
|     row: { | ||||
|       bg: "#12261e", | ||||
|       border: "#314a37", | ||||
|     }, | ||||
|     word: { | ||||
|       bg: "#1d572d", | ||||
|     }, | ||||
|   }, | ||||
|   removed: { | ||||
|     linenum: { | ||||
|       bg: "#542426", | ||||
|     }, | ||||
|     row: { | ||||
|       bg: "#25171c", | ||||
|       border: "#634343", | ||||
|     }, | ||||
|     word: { | ||||
|       bg: "#792e2d", | ||||
|     }, | ||||
|   }, | ||||
|   moved: { | ||||
|     row: { | ||||
|       bg: "#818044", | ||||
|       border: "#bcca6f", | ||||
|     }, | ||||
|   }, | ||||
|   inactive: "#353846", | ||||
| }; | ||||
|  | ||||
| const alpha = { | ||||
|   num10: "#3683c019", | ||||
|   num20: "#3683c033", | ||||
|   num30: "#3683c04b", | ||||
|   num40: "#3683c066", | ||||
|   num50: "#3683c080", | ||||
|   num60: "#3683c099", | ||||
|   num70: "#3683c0b3", | ||||
|   num80: "#3683c0cc", | ||||
|   num90: "#3683c0e1", | ||||
| }; | ||||
|  | ||||
| const primary: Primary = { | ||||
|   self: themeVars.color.blue, | ||||
|   contrast: "#fff", | ||||
|   dark, | ||||
|   light, | ||||
|   alpha, | ||||
|   hover: light.num1, | ||||
|   active: light.num2, | ||||
| const based: Based = { | ||||
|   git: "#f05133", | ||||
|   body: "#0d1117", | ||||
|   box: { | ||||
|     header: "#151b23", | ||||
|     body: { | ||||
|       self: "#0d1117", | ||||
|       highlight: "#262c36", | ||||
|     }, | ||||
|   }, | ||||
|   text: { | ||||
|     self: "#dce2e7", | ||||
|     dark: "#dbe0ea", | ||||
|     light: { | ||||
|       self: "#a6aab5", | ||||
|       num1: "rgb(125, 133, 144)", | ||||
|       num2: "#8a8e99", | ||||
|       num3: "#707687", | ||||
|     }, | ||||
|   }, | ||||
|   footer: "#010409", | ||||
|   timeline: "#4c525e", | ||||
|   input: { | ||||
|     text: "#d5dbe6", | ||||
|     background: "#2c2f35", | ||||
|     toggleBackgound: "#454a57", | ||||
|     border: { | ||||
|       self: themeVars.color.light.border, | ||||
|       hover: themeVars.color.light.border, | ||||
|     }, | ||||
|   }, | ||||
|   light: { | ||||
|     self: "#00000028", | ||||
|     mimicEnabled: "rgba(0, 0, 0, calc(40 / 255 * 222 / 255 / var(--opacity-disabled)))", | ||||
|     border: "#3d444d", | ||||
|   }, | ||||
|   hover: { | ||||
|     self: "#656c7633", | ||||
|     opaque: "#656c7666", | ||||
|   }, | ||||
|   active: "#161a21", | ||||
|   menu: "#0d1117", | ||||
|   card: "#0d1117", | ||||
|   markup: { | ||||
|     tableRow: "#ffffff06", | ||||
|     code: { | ||||
|       block: "#ffffff16", | ||||
|       inline: "#ffffff26", | ||||
|     }, | ||||
|   }, | ||||
|   button: "#212830", | ||||
|   codeBg: "#0d1117", | ||||
|   shadow: { | ||||
|     self: "#00000060", | ||||
|     opaque: "#00000080", | ||||
|   }, | ||||
|   secondaryBg: "#ffffff26", | ||||
|   expandButton: "#3c404d", | ||||
|   placeholderText: "#8a8e99", | ||||
|   editorLineHighlight: themeVars.color.primary.light.num5, | ||||
|   projectColumnBg: themeVars.color.secondary.light.num2, | ||||
|   caret: themeVars.color.text.self, | ||||
|   reaction: { | ||||
|     bg: "#ffffff12", | ||||
|     hoverBg: themeVars.color.primary.light.num4, | ||||
|     activeBg: themeVars.color.primary.light.num5, | ||||
|   }, | ||||
|   tooltip: { | ||||
|     text: "#fff", | ||||
|     bg: "#000000f0", | ||||
|   }, | ||||
|   nav: { | ||||
|     bg: "#010409", | ||||
|     hoverBg: themeVars.color.hover.self, | ||||
|     text: themeVars.color.text.self, | ||||
|   }, | ||||
|   secondaryNavBg: "#181c20", | ||||
|   label: { | ||||
|     text: "#fff", | ||||
|     bg: "#7c84974b", | ||||
|     hoverBg: "#7c8497a0", | ||||
|     activeBg: "#7c8497", | ||||
|   }, | ||||
|   accent: themeVars.color.primary.light.num1, | ||||
|   smallAccent: themeVars.color.primary.light.num5, | ||||
|   highlight: { | ||||
|     bg: "#87651e", | ||||
|     fg: "#352c1c", | ||||
|   }, | ||||
|   overlayBackdrop: "#080808c0", | ||||
| }; | ||||
|  | ||||
| export default defineTheme({ | ||||
|   isDarkTheme: "true", | ||||
|   color: { | ||||
|     blue: "blue", | ||||
|     primary: primary, | ||||
|   }, | ||||
|   isDarkTheme: true, | ||||
|   primary: "#4493f8", | ||||
|   primaryContrast: "#fff", | ||||
|   secondary: "#3d444d", | ||||
|   red: "#da3737", | ||||
|   orange: "#f17a2b", | ||||
|   yellow: "#f3c640", | ||||
|   olive: "#c8df36", | ||||
|   green: "#39d353", | ||||
|   teal: "#69d4cf", | ||||
|   blue: "#4493f8", | ||||
|   violet: "#754ad3", | ||||
|   purple: "#8957e5", | ||||
|   pink: "#e04b9f", | ||||
|   brown: "#a86d45", | ||||
|   black: "#141516", | ||||
|   grey: "#505665", | ||||
|   gold: "#b1983b", | ||||
|   white: "#ffffff", | ||||
|   console, | ||||
|   diff, | ||||
|   based, | ||||
| }); | ||||
|   | ||||
| @@ -1,268 +0,0 @@ | ||||
| /* Made by Luting ^-^ */ | ||||
| :root { | ||||
|   --is-dark-theme: true; | ||||
|   --border-radius: 6px; | ||||
|  | ||||
|   --color-primary: var(--color-blue); | ||||
|   --color-primary-contrast: #fff; | ||||
|   --color-primary-dark-1: #739cb3; | ||||
|   --color-primary-dark-2: #40aaff; | ||||
|   --color-primary-dark-3: #92b4c4; | ||||
|   --color-primary-dark-4: #a1bbcd; | ||||
|   --color-primary-dark-5: #cfddc1; | ||||
|   --color-primary-dark-6: #e7eee0; | ||||
|   --color-primary-dark-7: #f8faf6; | ||||
|   --color-primary-light-1: var(--color-blue); | ||||
|   --color-primary-light-2: #437aad; | ||||
|   --color-primary-light-3: #415b8b; | ||||
|   --color-primary-light-4: #25425a; | ||||
|   --color-primary-light-5: #223546; | ||||
|   --color-primary-light-6: #131923; | ||||
|   --color-primary-light-7: #06090b; | ||||
|   --color-primary-alpha-10: #3683c019; | ||||
|   --color-primary-alpha-20: #3683c033; | ||||
|   --color-primary-alpha-30: #3683c04b; | ||||
|   --color-primary-alpha-40: #3683c066; | ||||
|   --color-primary-alpha-50: #3683c080; | ||||
|   --color-primary-alpha-60: #3683c099; | ||||
|   --color-primary-alpha-70: #3683c0b3; | ||||
|   --color-primary-alpha-80: #3683c0cc; | ||||
|   --color-primary-alpha-90: #3683c0e1; | ||||
|   --color-primary-hover: var(--color-primary-light-1); | ||||
|   --color-primary-active: var(--color-primary-light-2); | ||||
|  | ||||
|   --color-secondary: #3d444d; | ||||
|   --color-secondary-dark-1: #505665; | ||||
|   --color-secondary-dark-2: #5b6273; | ||||
|   --color-secondary-dark-3: #71798e; | ||||
|   --color-secondary-dark-4: #7f8699; | ||||
|   --color-secondary-dark-5: #8c93a4; | ||||
|   --color-secondary-dark-6: #9aa0af; | ||||
|   --color-secondary-dark-7: #a8adba; | ||||
|   --color-secondary-dark-8: #c4c7d0; | ||||
|   --color-secondary-dark-9: #dfe1e6; | ||||
|   --color-secondary-dark-10: #edeef1; | ||||
|   --color-secondary-dark-11: #fbfbfc; | ||||
|   --color-secondary-dark-12: #eeeff2; | ||||
|   --color-secondary-dark-13: #fbfbfc; | ||||
|   --color-secondary-light-1: #373b46; | ||||
|   --color-secondary-light-2: #292c34; | ||||
|   --color-secondary-light-3: #1c1e23; | ||||
|   --color-secondary-light-4: #0e0f11; | ||||
|   --color-secondary-alpha-10: #2c2f35; | ||||
|   --color-secondary-alpha-20: #2c2f3533; | ||||
|   --color-secondary-alpha-30: #2c2f354b; | ||||
|   --color-secondary-alpha-40: #2c2f3566; | ||||
|   --color-secondary-alpha-50: #ffffff28; | ||||
|   --color-secondary-alpha-60: #161b22; | ||||
|   --color-secondary-alpha-70: #2c2f35b3; | ||||
|   --color-secondary-alpha-80: #2c2f35cc; | ||||
|   --color-secondary-alpha-90: #2c2f35e1; | ||||
|  | ||||
|   --color-red: #da3737; | ||||
|   --color-orange: #f17a2b; | ||||
|   --color-yellow: #f3c640; | ||||
|   --color-olive: #c8df36; | ||||
|   --color-green: #39d353; | ||||
|   --color-teal: #69d4cf; | ||||
|   --color-blue: #4493f8; | ||||
|   --color-violet: #754ad3; | ||||
|   --color-purple: #8957e5; | ||||
|   --color-pink: #e04b9f; | ||||
|   --color-brown: #a86d45; | ||||
|   --color-black: #141516; | ||||
|   --color-grey: #797c85; | ||||
|   --color-gold: #d4b74c; | ||||
|   --color-white: #ffffff; | ||||
|  | ||||
|   --color-red-light: #d15a5a; | ||||
|   --color-orange-light: #f6a066; | ||||
|   --color-yellow-light: #eaaf03; | ||||
|   --color-olive-light: #abc016; | ||||
|   --color-green-light: #93b373; | ||||
|   --color-teal-light: #00b6ad; | ||||
|   --color-blue-light: #4e96cc; | ||||
|   --color-violet-light: #9b79e4; | ||||
|   --color-purple-light: #ba6ad5; | ||||
|   --color-pink-light: #d74397; | ||||
|   --color-brown-light: #b08061; | ||||
|   --color-black-light: #3f4555; | ||||
|  | ||||
|   --color-red-dark-1: #c23636; | ||||
|   --color-orange-dark-1: #f38236; | ||||
|   --color-yellow-dark-1: #b88a03; | ||||
|   --color-olive-dark-1: #839311; | ||||
|   --color-green-dark-1: #238636; | ||||
|   --color-teal-dark-1: #00837c; | ||||
|   --color-blue-dark-1: #347cb3; | ||||
|   --color-violet-dark-1: #7b4edb; | ||||
|   --color-purple-dark-1: #a742c9; | ||||
|   --color-pink-dark-1: #be297d; | ||||
|   --color-brown-dark-1: #94674a; | ||||
|   --color-black-dark-1: #292d38; | ||||
|  | ||||
|   --color-red-dark-2: #ad3030; | ||||
|   --color-orange-dark-2: #f16e17; | ||||
|   --color-yellow-dark-2: #a37a02; | ||||
|   --color-olive-dark-2: #74820f; | ||||
|   --color-green-dark-2: #6c8c4c; | ||||
|   --color-teal-dark-2: #00746e; | ||||
|   --color-blue-dark-2: #2e6e9f; | ||||
|   --color-violet-dark-2: #6733d6; | ||||
|   --color-purple-dark-2: #9834b9; | ||||
|   --color-pink-dark-2: #a9246f; | ||||
|   --color-brown-dark-2: #835b42; | ||||
|   --color-black-dark-2: #252832; | ||||
|  | ||||
|   --color-ansi-black: var(--color-black); | ||||
|   --color-ansi-red: var(--color-red); | ||||
|   --color-ansi-green: var(--color-green); | ||||
|   --color-ansi-yellow: var(--color-yellow); | ||||
|   --color-ansi-blue: var(--color-blue); | ||||
|   --color-ansi-magenta: var(--color-pink); | ||||
|   --color-ansi-cyan: var(--color-teal); | ||||
|   --color-ansi-white: var(--color-console-fg-subtle); | ||||
|   --color-ansi-bright-black: var(--color-black-light); | ||||
|   --color-ansi-bright-red: var(--color-red-light); | ||||
|   --color-ansi-bright-green: var(--color-green-light); | ||||
|   --color-ansi-bright-yellow: var(--color-yellow-light); | ||||
|   --color-ansi-bright-blue: var(--color-blue-light); | ||||
|   --color-ansi-bright-magenta: var(--color-pink-light); | ||||
|   --color-ansi-bright-cyan: var(--color-teal-light); | ||||
|   --color-ansi-bright-white: var(--color-console-fg); | ||||
|  | ||||
|   --color-console-fg: #f0f6fc; | ||||
|   --color-console-fg-subtle: #9198a1; | ||||
|   --color-console-bg: #010409; | ||||
|   --color-console-border: #2b3139; | ||||
|   --color-console-active-bg: #2a313c; | ||||
|   --color-console-hover-bg: #15191f; | ||||
|   --color-console-menu-bg: var(--color-body); | ||||
|   --color-console-menu-border: var(--color-light-border); | ||||
|  | ||||
|   --color-grey: #505665; | ||||
|   --color-grey-light: #a1a6b7; | ||||
|   --color-gold: #b1983b; | ||||
|   --color-white: #fff; | ||||
|  | ||||
|   --color-diff-removed-word-bg: #792e2d; | ||||
|   --color-diff-added-word-bg: #1d572d; | ||||
|   --color-diff-removed-row-bg: #25171c; | ||||
|   --color-diff-moved-row-bg: #818044; | ||||
|   --color-diff-added-row-bg: #12261e; | ||||
|   --color-diff-removed-row-border: #634343; | ||||
|   --color-diff-moved-row-border: #bcca6f; | ||||
|   --color-diff-added-row-border: #314a37; | ||||
|   --color-diff-inactive: #353846; | ||||
|  | ||||
|   --color-error-border: #792e2e; | ||||
|   --color-error-bg: #26181d; | ||||
|   --color-error-bg-active: #744; | ||||
|   --color-error-bg-hover: #633; | ||||
|   --color-error-text: #f85149; | ||||
|  | ||||
|   --color-success-border: #1d572d; | ||||
|   --color-success-bg: #12261e; | ||||
|   --color-success-text: #39d353; | ||||
|  | ||||
|   --color-warning-border: #624711; | ||||
|   --color-warning-bg: #272115; | ||||
|   --color-warning-text: #fbbd08; | ||||
|  | ||||
|   --color-info-border: #214a81; | ||||
|   --color-info-bg: #121d2f; | ||||
|   --color-info-text: #4493f8; | ||||
|  | ||||
|   --color-red-badge: #db2828; | ||||
|   --color-red-badge-bg: #db28281a; | ||||
|   --color-red-badge-hover-bg: #db28284d; | ||||
|  | ||||
|   --color-green-badge: #39d353; | ||||
|   --color-green-badge-bg: #12261e; | ||||
|   --color-green-badge-hover-bg: #153d22; | ||||
|  | ||||
|   --color-yellow-badge: #fbbd08; | ||||
|   --color-yellow-badge-bg: #fbbd081a; | ||||
|   --color-yellow-badge-hover-bg: #fbbd084d; | ||||
|  | ||||
|   --color-orange-badge: #f2711c; | ||||
|   --color-orange-badge-bg: #f2711c1a; | ||||
|   --color-orange-badge-hover-bg: #f2711c4d; | ||||
|  | ||||
|   --color-git: #f05133; | ||||
|   --color-body: #0d1117; | ||||
|  | ||||
|   --color-box-header: #151b23; | ||||
|   --color-box-body: #0d1117; | ||||
|   --color-box-body-highlight: #262c36; | ||||
|  | ||||
|   --color-text-dark: #dbe0ea; | ||||
|   --color-text: #dce2e7; | ||||
|   --color-text-light: #a6aab5; | ||||
|   --color-text-light-1: rgb(125, 133, 144); | ||||
|   --color-text-light-2: #8a8e99; | ||||
|   --color-text-light-3: #707687; | ||||
|  | ||||
|   --color-footer: #010409; | ||||
|   --color-timeline: #4c525e; | ||||
|  | ||||
|   --color-input-text: #d5dbe6; | ||||
|   --color-input-background: #2c2f35; | ||||
|   --color-input-toggle-background: #454a57; | ||||
|   --color-input-border: var(--color-light-border); | ||||
|   --color-input-border-hover: var(--color-light-border); | ||||
|  | ||||
|   --color-light: #00000028; | ||||
|   --color-light-mimic-enabled: rgba(0, 0, 0, calc(40 / 255 * 222 / 255 / var(--opacity-disabled))); | ||||
|   --color-light-border: #3d444d; | ||||
|  | ||||
|   --color-hover: #656c7633; | ||||
|   --color-hover-opaque: ; | ||||
|  | ||||
|   --color-active: #161a21; | ||||
|   --color-menu: #0d1117; | ||||
|   --color-card: #0d1117; | ||||
|   --color-markup-table-row: #ffffff06; | ||||
|   --color-markup-code-block: #ffffff16; | ||||
|   --color-markup-code-inline: ; | ||||
|  | ||||
|   --color-button: #212830; | ||||
|   --color-code-bg: #0d1117; | ||||
|  | ||||
|   --color-shadow: #00000060; | ||||
|   --color-shadow-opaque: ; | ||||
|  | ||||
|   --color-secondary-bg: #ffffff26; | ||||
|  | ||||
|   --color-expand-button: #3c404d; | ||||
|   --color-placeholder-text: #8a8e99; | ||||
|   --color-editor-line-highlight: var(--color-primary-light-5); | ||||
|   --color-project-column-bg: var(--color-secondary-light-2); | ||||
|  | ||||
|   --color-caret: var(--color-text); | ||||
|  | ||||
|   --color-reaction-bg: #ffffff12; | ||||
|   --color-reaction-hover-bg: var(--color-primary-light-4); | ||||
|   --color-reaction-active-bg: var(--color-primary-light-5); | ||||
|  | ||||
|   --color-tooltip-text: #fff; | ||||
|   --color-tooltip-bg: #000000f0; | ||||
|  | ||||
|   --color-nav-bg: #010409; | ||||
|   --color-nav-hover-bg: var(--color-hover); | ||||
|   --color-nav-text: ; | ||||
|   --color-secondary-nav-bg: ; | ||||
|  | ||||
|   --color-label-text: #fff; | ||||
|   --color-label-bg: #7c84974b; | ||||
|   --color-label-hover-bg: #7c8497a0; | ||||
|   --color-label-active-bg: #7c8497; | ||||
|   --color-accent: var(--color-primary-light-1); | ||||
|   --color-small-accent: var(--color-primary-light-5); | ||||
|  | ||||
|   --color-highlight-bg: ; | ||||
|   --color-highlight-fg: ; | ||||
|   --color-overlay-backdrop: ; | ||||
|   accent-color: var(--color-accent); | ||||
|   color-scheme: dark; | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 lutinglt
					lutinglt