mirror of
https://github.com/lutinglt/gitea-github-theme.git
synced 2025-10-26 13:00:31 +00:00
支持柔和的暗色主题
This commit is contained in:
1
.github/release.md
vendored
1
.github/release.md
vendored
@@ -2,6 +2,7 @@
|
||||
|
||||
- 支持自动颜色主题 (跟随系统)
|
||||
- 支持亮色主题
|
||||
- 支持柔和的暗色主题 (dark-dimmed)
|
||||
|
||||
## 🌈 Style
|
||||
|
||||
|
||||
2
.github/workflows/release.yml
vendored
2
.github/workflows/release.yml
vendored
@@ -20,7 +20,7 @@ jobs:
|
||||
export TZ=Asia/Shanghai
|
||||
TAG="v$(npm run -s version).$(date +%y%m%d%H%M)"
|
||||
cd dist
|
||||
tar -zcf theme-github.tar.gz --remove-files theme-github-auto.css theme-github-light.css theme-github-dark.css
|
||||
tar -zcf theme-github.tar.gz --remove-files theme-github-auto.css theme-github-light.css theme-github-dark.css theme-github-soft-dark.css
|
||||
gh release create "$TAG" * --notes-file .github/release.md --draft -t $TAG
|
||||
env:
|
||||
GH_TOKEN: ${{ github.token }}
|
||||
|
||||
@@ -23,7 +23,7 @@
|
||||
|
||||
```ini
|
||||
[ui]
|
||||
THEMES = gitea-auto, gitea-light, gitea-dark, github-auto, github-light, github-dark
|
||||
THEMES = gitea-auto, gitea-light, gitea-dark, github-auto, github-light, github-dark, github-soft-dark
|
||||
```
|
||||
|
||||
详细请查看 Gitea 文档
|
||||
|
||||
1
TODO.md
1
TODO.md
@@ -4,7 +4,6 @@
|
||||
- issue/PR 列表样式 github 布局
|
||||
- styles/themes 库组件导出整理
|
||||
- defineTheme 颜色生成代码重构
|
||||
- 自动颜色主题生成
|
||||
|
||||
### 其他
|
||||
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
import { saturate } from "polished";
|
||||
import type { Console, Diff, Other } from "src";
|
||||
import { scaleColorLight } from "src/functions";
|
||||
import type { Github } from "src/types";
|
||||
import type { Chroma, Github } from "src/types";
|
||||
import { themeVars } from "src/types/vars";
|
||||
import { defineTheme } from "./color";
|
||||
import type { Theme } from "./theme";
|
||||
@@ -144,7 +144,7 @@ export type GithubColor = {
|
||||
};
|
||||
};
|
||||
|
||||
export function defineGithubTheme(githubColor: GithubColor): Theme {
|
||||
export function defineGithubTheme(githubColor: GithubColor, chroma: Chroma | null = null): Theme {
|
||||
const console: Console = {
|
||||
fg: {
|
||||
self: githubColor.fgColor.default,
|
||||
@@ -394,30 +394,33 @@ export function defineGithubTheme(githubColor: GithubColor): Theme {
|
||||
},
|
||||
},
|
||||
};
|
||||
return defineTheme({
|
||||
isDarkTheme: githubColor.isDarkTheme,
|
||||
primary: githubColor.fgColor.accent,
|
||||
primaryContrast: githubColor.fgColor.default,
|
||||
secondary: githubColor.borderColor.default,
|
||||
red: githubColor.fgColor.danger,
|
||||
orange: githubColor.fgColor.severe,
|
||||
yellow: githubColor.fgColor.attention,
|
||||
olive: githubColor.display.olive.fgColor,
|
||||
green: githubColor.fgColor.success,
|
||||
cyan: githubColor.display.cyan.fgColor,
|
||||
teal: githubColor.display.teal.fgColor,
|
||||
blue: githubColor.fgColor.accent,
|
||||
violet: githubColor.display.indigo.fgColor,
|
||||
purple: githubColor.fgColor.done,
|
||||
pink: githubColor.fgColor.sponsors,
|
||||
brown: githubColor.display.brown.fgColor,
|
||||
black: githubColor.fgColor.black,
|
||||
grey: githubColor.fgColor.neutral,
|
||||
gold: githubColor.display.lemon.fgColor,
|
||||
white: githubColor.fgColor.white,
|
||||
console,
|
||||
diff,
|
||||
other,
|
||||
github,
|
||||
});
|
||||
return defineTheme(
|
||||
{
|
||||
isDarkTheme: githubColor.isDarkTheme,
|
||||
primary: githubColor.fgColor.accent,
|
||||
primaryContrast: githubColor.fgColor.default,
|
||||
secondary: githubColor.borderColor.default,
|
||||
red: githubColor.fgColor.danger,
|
||||
orange: githubColor.fgColor.severe,
|
||||
yellow: githubColor.fgColor.attention,
|
||||
olive: githubColor.display.olive.fgColor,
|
||||
green: githubColor.fgColor.success,
|
||||
cyan: githubColor.display.cyan.fgColor,
|
||||
teal: githubColor.display.teal.fgColor,
|
||||
blue: githubColor.fgColor.accent,
|
||||
violet: githubColor.display.indigo.fgColor,
|
||||
purple: githubColor.fgColor.done,
|
||||
pink: githubColor.fgColor.sponsors,
|
||||
brown: githubColor.display.brown.fgColor,
|
||||
black: githubColor.fgColor.black,
|
||||
grey: githubColor.fgColor.neutral,
|
||||
gold: githubColor.display.lemon.fgColor,
|
||||
white: githubColor.fgColor.white,
|
||||
console,
|
||||
diff,
|
||||
other,
|
||||
github,
|
||||
},
|
||||
chroma
|
||||
);
|
||||
}
|
||||
|
||||
@@ -24,13 +24,13 @@ export default defineGithubTheme({
|
||||
default: "#f0f6fc",
|
||||
disabled: "#656c7699",
|
||||
done: "#ab7df8",
|
||||
muted: "#9198a1",
|
||||
neutral: "#9198a1",
|
||||
severe: "#db6d28",
|
||||
sponsors: "#db61a2",
|
||||
success: "#3fb950",
|
||||
black: "#010409",
|
||||
white: "#ffffff",
|
||||
muted: "#9198a1",
|
||||
},
|
||||
bgColor: {
|
||||
accent: { emphasis: "#1f6feb", muted: "#388bfd1a" },
|
||||
|
||||
@@ -24,13 +24,13 @@ export default defineGithubTheme({
|
||||
default: "#1f2328",
|
||||
disabled: "#818b98",
|
||||
done: "#8250df",
|
||||
muted: "#59636e",
|
||||
neutral: "#59636e",
|
||||
severe: "#bc4c00",
|
||||
sponsors: "#bf3989",
|
||||
success: "#1a7f37",
|
||||
black: "#1f2328",
|
||||
white: "#ffffff",
|
||||
muted: "#59636e",
|
||||
},
|
||||
bgColor: {
|
||||
accent: { emphasis: "#0969da", muted: "#ddf4ff" },
|
||||
|
||||
129
themes/soft-dark.css.ts
Normal file
129
themes/soft-dark.css.ts
Normal file
@@ -0,0 +1,129 @@
|
||||
import { defineGithubTheme } from "src/core/github";
|
||||
import { prettylights2Chroma } from "src/core/prettylights";
|
||||
|
||||
export default defineGithubTheme(
|
||||
{
|
||||
isDarkTheme: true,
|
||||
display: {
|
||||
brown: { fgColor: "#b69a6d" },
|
||||
cyan: { fgColor: "#07ace4" },
|
||||
indigo: { fgColor: "#9899ec" },
|
||||
lemon: { fgColor: "#ba9b12" },
|
||||
olive: { fgColor: "#a2a626" },
|
||||
teal: { fgColor: "#1cb0ab" },
|
||||
},
|
||||
diffBlob: {
|
||||
addtionNum: { bgColor: "#57ab5a4d" },
|
||||
addtionWord: { bgColor: "#46954a66" },
|
||||
deletionNum: { bgColor: "#e5534b4d" },
|
||||
deletionWord: { bgColor: "#e5534b66" },
|
||||
hunkNum: { bgColor: { rest: "#143d79" } },
|
||||
},
|
||||
fgColor: {
|
||||
accent: "#478be6",
|
||||
attention: "#c69026",
|
||||
danger: "#e5534b",
|
||||
default: "#d1d7e0",
|
||||
disabled: "#656c76",
|
||||
done: "#986ee2",
|
||||
muted: "#9198a1",
|
||||
neutral: "#9198a1",
|
||||
severe: "#cc6b2c",
|
||||
sponsors: "#c96198",
|
||||
success: "#57ab5a",
|
||||
black: "#010409",
|
||||
white: "#cdd9e5",
|
||||
},
|
||||
bgColor: {
|
||||
accent: { emphasis: "#316dca", muted: "#4184e41a" },
|
||||
attention: { muted: "#ae7c1426" },
|
||||
success: { emphasis: "#347d39", muted: "#46954a26" },
|
||||
danger: { muted: "#e5534b1a" },
|
||||
done: { emphasis: "#8256d0" },
|
||||
default: "#212830",
|
||||
inset: "#151b23",
|
||||
muted: "#262c36",
|
||||
neutral: { muted: "#656c7633" },
|
||||
},
|
||||
borderColor: {
|
||||
accent: { emphasis: "#316dca" },
|
||||
default: "#3d444d",
|
||||
attention: { emphasis: "#966600" },
|
||||
success: { emphasis: "#347d39" },
|
||||
done: { emphasis: "#8256d0" },
|
||||
muted: "#3d444db3",
|
||||
translucent: "#cdd9e526",
|
||||
},
|
||||
button: {
|
||||
primary: { fgColor: { rest: "#ffffff" }, bgColor: { hover: "#3b8640" } },
|
||||
danger: { fgColor: { rest: "#ea5c53", hover: "#ffffff" }, bgColor: { hover: "#ad2e2c" } },
|
||||
},
|
||||
control: {
|
||||
bgColor: { active: "#3d444d", hover: "#2f3742", rest: "#2a313c" },
|
||||
transparent: { bgColor: { active: "#656c7633", hover: "#656c7626", selected: "#656c761a" } },
|
||||
},
|
||||
shadow: { floating: { small: "#01040966" } },
|
||||
overlay: { backdrop: { bgColor: "#262c3666" } },
|
||||
underlineNav: { borderColor: { active: "#ec775c" } },
|
||||
contribution: {
|
||||
default: {
|
||||
bgColor: { num0: "#2a313c", num1: "#1b4721", num2: "#2b6a30", num3: "#46954a", num4: "#6bc46d" },
|
||||
borderColor: { num0: "#0104090d" },
|
||||
},
|
||||
},
|
||||
},
|
||||
prettylights2Chroma({
|
||||
syntax: {
|
||||
brackethighlighter: {
|
||||
angle: "#9198a1",
|
||||
unmatched: "#e5534b",
|
||||
},
|
||||
carriage: {
|
||||
return: {
|
||||
bg: "#ad2e2c",
|
||||
text: "#f0f6fc",
|
||||
},
|
||||
},
|
||||
comment: "#9198a1",
|
||||
constant: "#6cb6ff",
|
||||
constantOtherReferenceLink: "#96d0ff",
|
||||
entity: "#dcbdfb",
|
||||
entityTag: "#8ddb8c",
|
||||
invalid: {
|
||||
illegal: {
|
||||
bg: "#922323",
|
||||
text: "#f0f6fc",
|
||||
},
|
||||
},
|
||||
keyword: "#f47067",
|
||||
markup: {
|
||||
bold: "#f0f6fc",
|
||||
changed: {
|
||||
bg: "#682d0f",
|
||||
text: "#ffddb0",
|
||||
},
|
||||
deleted: {
|
||||
bg: "#78191b",
|
||||
text: "#ffd8d3",
|
||||
},
|
||||
heading: "#316dca",
|
||||
ignored: {
|
||||
bg: "#255ab2",
|
||||
text: "#f0f6fc",
|
||||
},
|
||||
inserted: {
|
||||
bg: "#1b4721",
|
||||
text: "#b4f1b4",
|
||||
},
|
||||
italic: "#f0f6fc",
|
||||
list: "#eac55f",
|
||||
},
|
||||
metaDiffRange: "#dcbdfb",
|
||||
storageModifierImport: "#f0f6fc",
|
||||
string: "#96d0ff",
|
||||
stringRegexp: "#8ddb8c",
|
||||
sublimelinterGutterMark: "#3d444d",
|
||||
variable: "#f69d50",
|
||||
},
|
||||
})
|
||||
);
|
||||
Reference in New Issue
Block a user