Compare commits

...

85 Commits

Author SHA1 Message Date
lutinglt
796c6f1519 同步差异对比页面文件名标题栏样式 2025-09-07 11:00:53 +08:00
lutinglt
f9d63e6fd1 同步用户菜单样式 2025-09-07 10:31:54 +08:00
lutinglt
08f662497b 同步订阅页面样式 2025-09-06 21:23:47 +08:00
lutinglt
c4bff9fdc1 修复仓库克隆点星按钮高度 2025-09-06 20:53:43 +08:00
lutinglt
a48963c43d 同步置顶 Issue 样式 2025-09-06 20:35:55 +08:00
lutinglt
7366813f02 修复提交列表尾行圆角 2025-09-06 20:08:06 +08:00
lutinglt
dc3047f16a 同步顶部工单等仪表板样式 2025-09-06 19:59:48 +08:00
lutinglt
e0518a2986 同步里程碑页面样式 2025-09-06 16:20:40 +08:00
lutinglt
39727c789b 缩小发布标题和内容的间隔 2025-09-05 17:02:36 +08:00
lutinglt
3c21a98fee 优化发布页面布局和下载列表样式 2025-09-04 20:03:34 +08:00
lutinglt
9bce3797a6 修复文件预览时文件树有边框过粗 2025-08-30 15:37:58 +08:00
lutinglt
9d3e738723 微调一些标签的字体大小 2025-08-29 12:11:15 +08:00
lutinglt
86ac3b73ba 略微减小导航栏创建仓库菜单按钮内的图标间隔 2025-08-25 16:25:29 +08:00
lutinglt
09a4bbdc07 取消修改编辑器字体大小, 避免光标错位 2025-08-23 11:55:33 +08:00
lutinglt
68d632a6b3 update readme 2025-08-19 00:51:02 +08:00
lutinglt
2b5962e1c2 update readme 2025-08-19 00:49:40 +08:00
lutinglt
7cd7a48d17 修复后台管理的运维管理面板的样式 2025-08-17 16:18:57 +08:00
lutinglt
ebc6463c30 修复登录二次验证页面内容位置 2025-08-17 10:46:52 +08:00
lutinglt
77c3842a43 修复登录二次验证页面内容位置 2025-08-17 10:39:50 +08:00
lutinglt
d311072ca0 update readme 2025-08-16 22:50:00 +08:00
lutinglt
8b4102d8d9 同步查看代码文件内容时的样式 2025-08-16 22:33:16 +08:00
lutinglt
73b5397d77 优化文件树的顶部和底部间隔 2025-08-16 20:58:10 +08:00
lutinglt
134c383cdb 优化查看代码文件内容时的体验 2025-08-16 20:51:07 +08:00
lutinglt
c6e73000bd 修复仓库中文 README 时的按钮下划线长度 2025-08-16 13:03:56 +08:00
lutinglt
dbf3547ad5 change default readme 2025-08-16 12:23:43 +08:00
lutinglt
5235dae367 更新英文截图 2025-08-16 12:19:11 +08:00
lutinglt
a9df7a31e1 README_EN 2025-08-16 12:03:10 +08:00
lutinglt
dd6e97be1d update readme 2025-08-15 10:53:02 +08:00
lutinglt
29f983cce6 update readme 2025-08-15 10:51:24 +08:00
鲁汀
fca10130a3 Create FUNDING.yml 2025-08-15 10:45:15 +08:00
lutinglt
8676816342 修复红绿色盲主题的代码高亮色 2025-08-15 09:15:13 +08:00
lutinglt
9bcea89fcb update readme 2025-08-14 23:31:41 +08:00
lutinglt
26deec78ff format code 2025-08-14 21:24:03 +08:00
lutinglt
ffb7fa810b 发布时的主题顺序 2025-08-14 20:51:56 +08:00
lutinglt
2083d3026b version 2025-08-14 20:37:00 +08:00
lutinglt
5037e46447 beta 2025-08-14 20:10:48 +08:00
lutinglt
cd2f7579b1 色盲主题打包 2025-08-14 20:02:57 +08:00
lutinglt
1b237b12f3 update readme 2025-08-14 19:59:57 +08:00
lutinglt
a8453a87a5 支持色盲主题 2025-08-14 19:59:08 +08:00
lutinglt
6aef26cdc8 重叠边框线, 避免过粗 2025-08-14 00:10:46 +08:00
lutinglt
a4c94cb34d 重叠边框线, 避免过粗 2025-08-14 00:09:38 +08:00
lutinglt
8c45f44309 查看代码文件页面文件树头部有时不会固定住 2025-08-13 23:35:03 +08:00
lutinglt
1c9b02ea88 查看代码文件页面路径栏有时内容不会居中 2025-08-13 22:44:19 +08:00
lutinglt
61313d5644 ci tag 2025-08-13 22:39:10 +08:00
lutinglt
d7722cde2f update md 2025-08-13 22:33:53 +08:00
lutinglt
e3366a8406 filetree 默认高度 2025-08-13 22:32:47 +08:00
lutinglt
f6fc6a9702 🎉 release 2025-08-13 22:17:12 +08:00
lutinglt
12d5636fb7 同步查看代码文件页面样式 2025-08-13 22:03:41 +08:00
lutinglt
10c06dad60 仪表板时间 2025-08-13 19:53:27 +08:00
lutinglt
c80dd09828 时间追踪 2025-08-13 18:09:27 +08:00
lutinglt
8f2f45406a 同步 Issue/PR 列表样式 2025-08-13 16:45:53 +08:00
lutinglt
c46d9333ff fix org 2025-08-13 12:13:18 +08:00
lutinglt
7039041d9d 同步编辑器字体大小 2025-08-13 11:34:48 +08:00
lutinglt
9949bdc7bd 优化仪表板样式 & 同步代码编辑器背景色 2025-08-13 11:20:01 +08:00
lutinglt
1b81b6ad93 优化仪表板仓库/组织列表样式, 好看多了, 愿称之为神之一手 2025-08-12 22:32:31 +08:00
lutinglt
62bc2afa2a 同步 Issue/PR 详细页面侧边栏样式 2025-08-12 20:57:03 +08:00
lutinglt
60e873b0e0 同步用户点星仓库列表样式 2025-08-12 16:05:38 +08:00
lutinglt
00737f5203 优化标签样式 2025-08-12 15:34:53 +08:00
lutinglt
a90b72896b 优化热力图和动态样式 2025-08-12 14:43:05 +08:00
lutinglt
f90c488d45 优化消息右上角小图标样式 2025-08-12 11:06:32 +08:00
lutinglt
56c284aec2 同步登录/注册页面样式 2025-08-12 10:29:32 +08:00
lutinglt
0df107a166 优化创建仓库/迁移仓库/创建组织页面的样式与设置页面的样式一致 2025-08-12 09:47:43 +08:00
lutinglt
c5c1ca4a6b fix height 2025-08-12 00:27:23 +08:00
lutinglt
6bbc304a7c 激活字体颜色白色 2025-08-12 00:20:47 +08:00
lutinglt
5c95add059 同步分页菜单样式 2025-08-12 00:16:38 +08:00
lutinglt
2efaeead6b 同步仓库代码文件页 README 导航栏样式 2025-08-11 23:29:48 +08:00
lutinglt
29122e946c 修复顶部导航栏工单管理/请求合并页面搜索框旁的选择下拉框按钮内容过窄 2025-08-11 22:55:05 +08:00
lutinglt
81be016be3 略微增加仓库代码文件列表的单行高度 2025-08-11 22:41:24 +08:00
lutinglt
2ffdf501b3 修复用户公开活动页动态布局问题 2025-08-11 18:12:51 +08:00
lutinglt
9f2e5df49c 代码整理 2025-08-11 17:56:39 +08:00
lutinglt
00eda68f00 修复 Action 作业步骤页面标题选中时滚动固定的高度问题 2025-08-11 17:39:58 +08:00
lutinglt
fc4e6f43bb todo 2025-08-11 09:55:30 +08:00
lutinglt
1f01495a10 update 2025-08-11 09:52:43 +08:00
lutinglt
eae2961989 update contributing 2025-08-11 09:52:18 +08:00
lutinglt
563c20f2cc update todo 2025-08-11 09:45:32 +08:00
lutinglt
058e1b89ee update todo 2025-08-11 09:44:31 +08:00
lutinglt
c431fbadb4 update todo 2025-08-11 09:42:24 +08:00
lutinglt
74254a3f80 update readme 2025-08-11 09:31:57 +08:00
lutinglt
8118706706 update readme 2025-08-11 09:30:01 +08:00
lutinglt
ffbfccd7dc update md 2025-08-11 09:26:10 +08:00
lutinglt
1d8dfdb82b update markdown 2025-08-10 23:04:19 +08:00
lutinglt
11422f3b05 udpate contributing 2025-08-10 23:02:25 +08:00
lutinglt
cca5e4e435 update contributing 2025-08-10 22:58:38 +08:00
lutinglt
780c72919d update README 2025-08-10 22:43:39 +08:00
lutinglt
dc4eff2bd7 update contributing.md 2025-08-10 21:46:30 +08:00
73 changed files with 2389 additions and 803 deletions

View File

@@ -1,4 +1,8 @@
# 开发模式下编译的主题 (开发模式仅编译单个主题)
DEV_THEME=dark DEV_THEME=dark
# 把编译后的主题上传到服务器的服务器名称, 通过 SCP 上传
SSH_SERVER=localhost SSH_SERVER=localhost
# 上传到服务器的用户名称, 不支持密码, 请确保有 SSH 免密登录权限
SSH_USER=root SSH_USER=root
# 上传到服务器的主题路径, 请使用绝对路径
GITEA_THEME_PATH=/data/gitea/public/assets/css/ GITEA_THEME_PATH=/data/gitea/public/assets/css/

15
.github/FUNDING.yml vendored Normal file
View File

@@ -0,0 +1,15 @@
# These are supported funding model platforms
github: # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
patreon: # Replace with a single Patreon username
open_collective: # Replace with a single Open Collective username
ko_fi: # Replace with a single Ko-fi username
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
liberapay: # Replace with a single Liberapay username
issuehunt: # Replace with a single IssueHunt username
lfx_crowdfunding: # Replace with a single LFX Crowdfunding project-name e.g., cloud-foundry
polar: # Replace with a single Polar username
buy_me_a_coffee: # Replace with a single Buy Me a Coffee username
thanks_dev: # Replace with a single thanks.dev username
custom: ['https://afdian.com/a/luting']

View File

@@ -1,11 +1,17 @@
## ✨ Feature ### 🎉
### ✨ Feature
#### CSS 变量 #### CSS 变量
## 🌈 Style ### 🌈 Style
#### 更符合 GitHub 风格 ##### 更符合 GitHub 风格
## 🎈 Perf ### 🐞 Fix
## 🐞 Fix ## 📃 English
#### CSS Variable
##### More GitHub-like style

53
.github/release.md vendored
View File

@@ -1,21 +1,48 @@
## ✨ Feature ### ✨ Feature
- 支持自动颜色主题 (跟随系统) #### CSS 变量
- 支持亮色主题
- 支持柔和的暗色主题 (dark-dimmed)
## 🌈 Style - 新增 `--custom-user-menu-width` 变量, 用于设置用户菜单的宽度
#### 更符合 GitHub 风格 ### 🌈 Style
- 同步查看文件内容时的代码高亮色 (由于词法分析器的差异和解析问题, 只能实现大概相似, 目前观察到在 TypeScript 下词法分析器表现非常糟糕) - 优化小型按钮的高度
- 一些列表栏的元素位置居中
## 🎈 Perf ##### 更符合 GitHub 风格
- 优化差异对比的代码折叠/展开按钮的高度和动画效果 - 同步查看代码文件内容时的样式
- 优化查看代码文件内容时的体验 (去掉了一些底部元素, 优化滚动体验)
- 略微减小导航栏创建仓库菜单按钮内的图标间隔
- 微调一些标签的字体大小
- 优化发布页面布局和下载列表样式
- 同步里程碑页面样式
- 同步顶部工单等仪表板样式
- 同步置顶 Issue 样式
- 同步订阅页面样式
- 同步用户菜单样式
- 优化下拉菜单样式
- 同步差异对比页面文件名标题栏样式
## 🐞 Fix ### 🐞 Fix
- 修复仓库页面与探索页面下仓库主题标签字重不一致的问题 - 修复红绿色盲主题的代码高亮色
- 修复发布页面下的分支按钮点击时高度变化问题 - 修复仓库中文 README 时的按钮下划线长度
- 修复首页/登录页/注册页下导航栏右侧按钮样式问题 #10 - 修复登录二次验证页面内容位置
- 修复后台管理的运维管理面板的样式
- 取消修改编辑器字体大小, 避免光标错位
- 修复文件预览时文件树右边框过粗
- 修复提交列表尾行圆角
## 📃 English (From AI)
### 🌈 Style
##### More GitHub-like style
- Improved code file viewing experience (scrolling to bottom no longer causes file tree content overlap)
### 🐞 Fix
- Fixed code highlight colors for red-green color blindness theme
- Fixed button underline length for Chinese README in repositories

View File

@@ -18,8 +18,10 @@ jobs:
- name: Create release - name: Create release
run: | run: |
export TZ=Asia/Shanghai export TZ=Asia/Shanghai
TAG="v$(npm run -s version).$(date +%y%m%d%H%M)" TAG="v$(npm run -s version)"
tar -zcf dist/theme-github.tar.gz --remove-files dist/theme-github-auto.css dist/theme-github-light.css dist/theme-github-dark.css dist/theme-github-soft-dark.css tar -zcf dist/theme-github-base.tar.gz --remove-files dist/theme-github-auto.css dist/theme-github-light.css dist/theme-github-dark.css dist/theme-github-soft-dark.css
tar -zcf dist/theme-github-colorblind.tar.gz --remove-files dist/theme-github-colorblind-auto.css dist/theme-github-colorblind-light.css dist/theme-github-colorblind-dark.css
tar -zcf dist/theme-github-colorblind-tritanopia.tar.gz --remove-files dist/theme-github-tritanopia-auto.css dist/theme-github-tritanopia-light.css dist/theme-github-tritanopia-dark.css
gh release create "$TAG" dist/* --notes-file .github/release.md --draft -t $TAG gh release create "$TAG" dist/* --notes-file .github/release.md --draft -t $TAG
env: env:
GH_TOKEN: ${{ github.token }} GH_TOKEN: ${{ github.token }}

View File

@@ -1,7 +1,171 @@
# 贡献指南
## 目录结构
| 目录 | 说明 | | 目录 | 说明 |
| ----------------- | ---------------------------- | | ----------------- | ---------------------------- |
| styles | 元素 GitHub 风格 | | src | 主题生成框架与辅助工具的包 |
| styles/components | 具体页面的元素单独风格 | | src/core | 主题生成框架 |
| styles/public | 适用大部分页面的元素默认风格 | | src/functions | 主题辅助工具 |
| src/types | 主题的颜色变量定义 |
| styles | 主题样式 |
| styles/components | 具体页面的元素的样式 |
| styles/public | 基础元素或跨页面的元素的样式 |
| themes | 颜色主题 | | themes | 颜色主题 |
| themes/\<theme> | 具体颜色主题自己的颜色或风格 |
## 贡献说明
不推荐主题样式贡献, 因为 Gitea 主题最终是由单个 CSS 文件提供, 所以会有先后顺序覆盖, 样式影响广泛等问题.
开发者每个人的思路不一样, 审核很难看出这些问题, 会极大增加维护难度.
如果确定理解了 Gitea 的样式布局和我的思路, 请先提交 Issue 确认工作量和预期效果, 然后再开发提交 PR.
如果认为有更好的思路, 欢迎提交 Issue.
> [!IMPORTANT]
>
> 提交 PR 时, 请执行 `npm run commit`
## 开发环境
主题仅依赖于 Node.js 环境, 请确保你的环境中已经安装了 Node.js, 推荐使用 Node.js 20 或以上版本.
请使用 VSCode 开发, 并安装仓库中推荐的插件.
如果不喜欢多余的插件, 请务必安装 `vscode-styled-components` 插件, 此插件用于渲染和检查 TypeScript 中的 CSS 模板字符串.
推荐使用 VSCode 1.102.0 版本以上开发, 此版本以上提供 TypeScript 代码中 16 进制颜色的支持.
## 开发流程
### 安装依赖
```bash
npm install
```
### 设置环境变量
在项目根目录下创建 `.env` 文件, 变量参考 `.env.example` 文件.
环境变量用于发送编译后的主题到服务器上, 快速预览主题.
### 编译主题
编译开发中的主题
```bash
npm run dev
```
编译所有主题
```bash
npm run build
```
格式化项目中的代码
```bash
npm run format
```
用于 PR, 检查并编译项目中的所有代码并进行格式化
```bash
npm run commit
```
## 开发规范
`src`, `styles`, `themes` 为项目的主目录, 主目录下的第一个目录为模块.
主目录或主目录下模块互相引用时, 请使用绝对路径, 例如 `import { defineTheme } from "src"`
模块下的文件互相引用时, 请使用相对路径, 例如 `import { defineTheme } from "./theme"`
## 颜色主题贡献
颜色主题名称格式: `主题名称-dark.css.ts``主题名称-light.css.ts`, 分别表示深色和亮色主题.
如果主题有深色和亮色模式, 会自动生成自动颜色主题, 不需要手动添加.
项目接受自定义主题并会附加到发布的版本中, 但项目所有者不参与维护和审核.
请在颜色主题文件头部附加自己的作者信息, 方便 Issue 提问者找到你 `@`.
推荐使用 `import { defineTheme, type ThemeColor } from "src"` 导入主题生成框架, 声明主题颜色, 然后使用 `defineTheme`
函数生成主题所有 CSS 变量, defineTheme 中设置了一些经过计算得到的 Gitea 变量可以减少工作量, 具体请查看函数说明和定义.
颜色计算函数可以从 `src/functions` 导入, 例如 `import { scaleColorLight } from "src/functions"`, 或者使用 `polished` 库.
例: `themes/主题名称-dark.css.ts`
```ts
/**
* @author 你的名字
* @description 主题描述
*/
import { defineTheme, type ThemeColor } from "src";
export const 主题名称DarkColors: ThemeColor = {
...
}
export default defineTheme(主题名称DarkColors);
// 使用其他主题颜色作为基础
import dark from "themes/dark";
import { darkColors } from "themes/dark";
export const 主题名称DarkColors: ThemeColor = darkColors;
export default defineTheme({
...dark,
...
});
```
如果不需要自定义代码高亮色, 则不传递 chroma 参数, 框架会自动根据主题的暗色或亮色生成代码高亮色.
如果需要完全自定义每个 Gitea 变量, 请导入 `import type { Theme } from "src"`
例: `themes/主题名称-dark.css.ts`
```ts
/**
* @author 你的名字
* @description 主题描述
*/
import type { Theme, Chroma, Primary, Secondary, ... } from "src";
export const primary: Primary = ...;
export const secondary: Secondary =...;
export const chroma: Chroma =...;
...
export default theme: Theme = {
primary,
secondary,
chroma,
...
};
```
完成主题颜色开发后, 请在某个仓库的代码文件列表页, 打开 Code 菜单选择 Tea Cli 进行截图, 并放入 `screenshots`
目录下, 截图名与主题名相同. (推荐克隆本仓库, 避免泄露个人隐私)
然后将截图信息添加到 `README.md` 文件中, 可以在折叠部分中添加自己的说明.
主题颜色复用案例可以参考本主题的色盲主题.
## 主题样式贡献
主题样式使用 TypeScript 的 css 模板字符串开发, 该模板字符串会经过 sass 预处理器处理, 支持 SCSS 语法并且主题只接受 SCSS 嵌套语法, 请不要使用 CSS 语法, 如果一定要用请说明原因.
请尽量不要使用 SCSS 的函数, `vscode-styled-components` 插件会报错, 请使用 TypeScript 相关库处理, 比如主题自带的
`polished` 库.
推荐需要使用复杂处理时, 提取逻辑到 `src/functions` 目录下的函数中, 然后在 `src/styles` 目录下的样式文件中使用.
主题样式中使用到的所有颜色必须使用颜色变量, 颜色变量导入 `import { themeVars } from "src/types/vars"`
涉及到主题自己的颜色变量 `${themeVars.github.xxx}`, 在使用时请将使用的文件和变量添加到对应变量的注释中
`src/types/color/github`
小型圆角(6px)请使用全局圆角变量, 圆角变量导入 `import { otherThemeVars } from "src/types/vars"`
`${otherThemeVars.border.radius}`

101
README.md
View File

@@ -1,13 +1,23 @@
# gitea-github-theme <p align="center">
中文 |
<a href="./README_EN.md">English</a>
</p>
尽量保持与 GitHub 相同样式的 Gitea 主题 # Gitea GitHub Theme
### 主题说明 ## 版本号说明
添加了短暂的过渡动画优化体验(与 GitHub Code 克隆列表动画一致) 主题版本号与 Gitea 版本号保持一致
推荐搭配文件图标浏览器插件一起使用更佳 Gitea 版本号格式: `1.大版本号.小版本号`
[github-file-explorer-icons](https://github.com/catppuccin/github-file-explorer-icons)
Gitea 理论上小版本号变更不会修改前端布局, 所以主题的小版本号适用于所有 Gitea 大版本号相同的 Gitea 版本.
比如: 主题版本 `1.24.5` 适用于 Gitea 版本 `>=1.24.0` `<1.25.0`
仅维护项目发布中的最新的 Gitea 版本, 其他旧版本主题不接受 Issue 和 PR.
> 开发阶段的主题版本号格式: `1.大版本号.小版本号.时间戳`
## 安装 ## 安装
@@ -15,7 +25,10 @@
2. 修改 `gitea/conf/app.ini`,并将 CSS 文件名去掉 `theme-` 的名称附加到 `[ui]` 下的 `THEMES` 末尾 2. 修改 `gitea/conf/app.ini`,并将 CSS 文件名去掉 `theme-` 的名称附加到 `[ui]` 下的 `THEMES` 末尾
3. 重启 Gitea 3. 重启 Gitea
4. 在设置中查看主题 4. 在设置中查看主题
5. 自动颜色主题需要亮色和暗色的主题文件
> [!IMPORTANT]
>
> 自动颜色主题需要亮色和暗色的主题文件
例: 主题文件名为 `theme-github-dark.css`,则添加 `github-dark``THEMES` 末尾 例: 主题文件名为 `theme-github-dark.css`,则添加 `github-dark``THEMES` 末尾
@@ -29,6 +42,39 @@ THEMES = gitea-auto, gitea-light, gitea-dark, github-auto, github-light, github-
详细请查看 Gitea 文档 详细请查看 Gitea 文档
[Gitea docs](https://docs.gitea.com/next/administration/customizing-gitea#customizing-the-look-of-gitea) [Gitea docs](https://docs.gitea.com/next/administration/customizing-gitea#customizing-the-look-of-gitea)
## 截图
### 基本主题
```ini
THEMES = github-auto, github-light, github-dark, github-soft-dark
```
<details open>
<summary>Base</summary>
<h4>theme-github-light.css</h4>
<img src="screenshots/light.png"/>
<h4>theme-github-dark.css</h4>
<img src="screenshots/dark.png"/>
<h4>theme-github-soft-dark.css</h4>
<img src="screenshots/soft-dark.png"/>
</details>
### 色盲主题 ( Beta )
```ini
THEMES = github-colorblind-auto, github-colorblind-light, github-colorblind-dark
THEMES = github-tritanopia-auto, github-tritanopia-light, github-tritanopia-dark
```
<details>
<summary>Colorblind & Tritanopia (红绿色盲 & 蓝色盲)</summary>
<h4>theme-github-colorblind-light.css & theme-github-tritanopia-light.css</h4>
<img src="screenshots/colorblind-light.png"/>
<h4>theme-github-colorblind-dark.css & theme-github-tritanopia-dark.css</h4>
<img src="screenshots/colorblind-dark.png"/>
</details>
## 自定义 CSS 变量 ## 自定义 CSS 变量
可以根据自己的偏好自定义主题的一部分样式 可以根据自己的偏好自定义主题的一部分样式
@@ -54,31 +100,32 @@ THEMES = gitea-auto, gitea-light, gitea-dark, github-auto, github-light, github-
### CSS 变量 ### CSS 变量
| 变量名 | 描述 | 默认 | Github | 推荐 | 最小 | 最大 | | 变量名 | 描述 | 默认 | Github | 推荐 | 最小 | 最大 |
| :-------------------------------- | :-------------------------- | :----- | :----- | :---- | :----- | :----- | | :-------------------------------- | :-------------------------- | :---- | :----- | :---- | :------- | :---- |
| --custom-clone-menu-width | 克隆菜单宽度 | Gitea | 332px | 200px | 150px | 400px | | --custom-clone-menu-width | 克隆按钮的菜单宽度 | Gitea | 332px | 200px | 150px | 400px |
| --custom-explore-repolist-columns | 探索页面的仓库列表列数 | 2 | 2 | 2 | | | | --custom-user-menu-width | 用户菜单的宽度 | 192px | 256px | | 内容宽度 | 320px |
| --custom-explore-userlist-columns | 探索页面的用户/组织列表列数 | 3 | 1 | 2/3 | | | | --custom-explore-repolist-columns | 探索页面的仓库列表列数 | 2 | 2 | 2 | | |
| --custom-user-repolist-columns | 用户页面的仓库列表列数 | 2 | 2 | 1/2 | | | | --custom-explore-userlist-columns | 探索页面的用户/组织列表列数 | 3 | 1 | 2/3 | | |
| --custom-org-repolist-columns | 组织页面的仓库列表列数 | 1 | 1 | 1/2 | | | | --custom-user-repolist-columns | 用户页面的仓库列表列数 | 2 | 2 | 1/2 | | |
| --custom-org-userlist-columns | 组织页面的用户列表列数 | 2 | 1 | 1/2 | | | | --custom-org-repolist-columns | 组织页面的仓库列表列数 | 1 | 1 | 1/2 | | |
| --custom-org-userlist-columns | 组织页面的用户列表列数 | 2 | 1 | 1/2 | | |
## 截图 ## 使用开发中的主题
![仓库](screenshots/repo.png) 也许你会想使用开发中的主题, 而不是发布的主题
![仓库文件列表](screenshots/file_list.png) 请确保你已经安装了 Node.js 环境, 推荐使用 Node.js 20 或以上版本
![仓库发布](screenshots/release.png) ```bash
git clone https://github.com/lutinglt/gitea-github-theme.git
cd gitea-github-theme
npm install
npm run build
```
![仓库提交](screenshots/commit.png) 编译完成后, 会在 `dist` 目录下生成主题文件, 你可以将主题文件放入 `gitea/public/assets/css` 目录下, 然后在
`gitea/conf/app.ini` 中添加主题名称到 `THEMES` 末尾
![Actions](screenshots/actions.png)
![Action](screenshots/action.png)
![Dispatch](screenshots/dispatch.png)
## 贡献 ## 贡献
欢迎提交 Issue 或 Pull Request 请查看 [CONTRIBUTING](CONTRIBUTING.md)

135
README_EN.md Normal file
View File

@@ -0,0 +1,135 @@
<p align="center">
<a href="./README.md">中文</a> |
English
</p>
# Gitea GitHub Theme
## Version Number Explanation
The theme version number is kept consistent with the Gitea version number
Gitea version number format: `1.major.minor`
Theoretically, minor version changes in Gitea do not modify the frontend layout, so the minor version of the theme is
applicable to all Gitea versions with the same major version number.
For example: Theme version `1.24.5` is applicable to Gitea versions `>=1.24.0` `<1.25.0`
Only the latest released Gitea version is maintained. Issues and PRs for other older theme versions will not be
accepted.
> Development stage theme version number format: `1.major.minor.timestamp`
## Installation
1. Download the latest CSS theme file from the release page and place it in the `gitea/public/assets/css` directory
2. Modify `gitea/conf/app.ini` and append the CSS filename without the `theme-` prefix to the end of `THEMES` under the
`[ui]` section
3. Restart Gitea
4. Check the theme in the settings
> [!IMPORTANT]
>
> Automatic color theme requires both light and dark theme files
Example: If the theme filename is `theme-github-dark.css`, add `github-dark` to the end of `THEMES`
Example `gitea/conf/app.ini`:
```ini
[ui]
THEMES = gitea-auto, gitea-light, gitea-dark, github-auto, github-light, github-dark, github-soft-dark
```
For details, please refer to the Gitea documentation
[Gitea docs](https://docs.gitea.com/next/administration/customizing-gitea#customizing-the-look-of-gitea)
## Screenshots
### Basic Themes
```ini
THEMES = github-auto, github-light, github-dark, github-soft-dark
```
<details open>
<summary>Base</summary>
<h4>theme-github-light.css</h4>
<img src="screenshots/en/light.png"/>
<h4>theme-github-dark.css</h4>
<img src="screenshots/en/dark.png"/>
<h4>theme-github-soft-dark.css</h4>
<img src="screenshots/en/soft-dark.png"/>
</details>
### Colorblind Themes (Beta)
```ini
THEMES = github-colorblind-auto, github-colorblind-light, github-colorblind-dark
THEMES = github-tritanopia-auto, github-tritanopia-light, github-tritanopia-dark
```
<details>
<summary>Colorblind & Tritanopia</summary>
<h4>theme-github-colorblind-light.css & theme-github-tritanopia-light.css</h4>
<img src="screenshots/en/colorblind-light.png"/>
<h4>theme-github-colorblind-dark.css & theme-github-tritanopia-dark.css</h4>
<img src="screenshots/en/colorblind-dark.png"/>
</details>
## Custom CSS Variables
You can customize parts of the theme style according to your preferences
### Usage Method
Add the following code at the beginning or end of the theme's CSS file
```css
:root {
--custom-clone-menu-width: 150px;
...
}
```
> [!IMPORTANT]
>
> Please ensure to add custom variables in the `:root` selector, otherwise they will not take effect
>
> Variables are separated by `;`
>
> It is recommended to place custom variables in a separate file and append them to the theme file using shell commands
> or other methods
### CSS Variables
| Variable Name | Description | Default | Github | Recommend | Min | Max |
| :-------------------------------- | :------------------------------------------------------- | :------ | :----- | :-------- | :------------ | :---- |
| --custom-clone-menu-width | Clone button menu width | Gitea | 332px | 200px | 150px | 400px |
| --custom-user-menu-width | User menu width | 192px | 200px | | Content Width | 320px |
| --custom-explore-repolist-columns | Number of repository list columns on explore page | 2 | 2 | 2 | | |
| --custom-explore-userlist-columns | Number of user/organization list columns on explore page | 3 | 1 | 2/3 | | |
| --custom-user-repolist-columns | Number of repository list columns on user page | 2 | 2 | 1/2 | | |
| --custom-org-repolist-columns | Number of repository list columns on organization page | 1 | 1 | 1/2 | | |
| --custom-org-userlist-columns | Number of user list columns on organization page | 2 | 1 | 1/2 | | |
## Using Development Version of the Theme
You might want to use the development version of the theme instead of the released version
Please ensure you have Node.js environment installed, Node.js 20 or above is recommended
```bash
git clone https://github.com/lutinglt/gitea-github-theme.git
cd gitea-github-theme
npm install
npm run build
```
After compilation, theme files will be generated in the `dist` directory. You can place the theme files into the
`gitea/public/assets/css` directory, then add the theme name to the end of `THEMES` in `gitea/conf/app.ini`
## Contribution
Please refer to [CONTRIBUTING](CONTRIBUTING.md)

11
TODO.md
View File

@@ -1,11 +0,0 @@
### 重大
- gitea issue 默认标签颜色匹配使用 github 样式
- issue/PR 列表样式 github 布局
- styles/themes 库组件导出整理
- defineTheme 颜色生成代码重构
### 其他
- README 更新/截图更新
- CONTRIBUTING 更新

View File

@@ -1,7 +1,7 @@
{ {
"name": "gitea-github-theme", "name": "gitea-github-theme",
"version": "1.24.4", "version": "1.24.6",
"description": "A theme to make Gitea look and feel like GitHub", "description": "A sophisticated theme to make Gitea look and feel like GitHub",
"type": "module", "type": "module",
"scripts": { "scripts": {
"dev": "vite build --mode dev", "dev": "vite build --mode dev",

BIN
screenshots/action.png vendored

Binary file not shown.

Before

Width:  |  Height:  |  Size: 109 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 176 KiB

BIN
screenshots/colorblind-dark.png vendored Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 260 KiB

BIN
screenshots/colorblind-light.png vendored Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 259 KiB

BIN
screenshots/commit.png vendored

Binary file not shown.

Before

Width:  |  Height:  |  Size: 394 KiB

BIN
screenshots/dark.png vendored Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 260 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 111 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 278 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 278 KiB

BIN
screenshots/en/dark.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 278 KiB

BIN
screenshots/en/light.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 278 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 279 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 343 KiB

BIN
screenshots/light.png vendored Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 259 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 187 KiB

BIN
screenshots/repo.png vendored

Binary file not shown.

Before

Width:  |  Height:  |  Size: 211 KiB

BIN
screenshots/soft-dark.png vendored Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 261 KiB

64
src/core/chroma.ts Normal file
View File

@@ -0,0 +1,64 @@
import { prettylights2Chroma, type prettylightsColor } from "./prettylights";
export const lightPrettylights: prettylightsColor = {
syntax: {
brackethighlighter: { angle: "#59636e", unmatched: "#82071e" },
carriage: { return: { bg: "#cf222e", text: "#f6f8fa" } },
comment: "#59636e",
constant: "#0550ae",
constantOtherReferenceLink: "#0a3069",
entity: "#6639ba",
entityTag: "#0550ae",
invalid: { illegal: { bg: "#82071e", text: "#f6f8fa" } },
keyword: "#cf222e",
markup: {
bold: "#1f2328",
changed: { bg: "#ffd8b5", text: "#953800" },
deleted: { bg: "#ffebe9", text: "#82071e" },
heading: "#0550ae",
ignored: { bg: "#0550ae", text: "#d1d9e0" },
inserted: { bg: "#dafbe1", text: "#116329" },
italic: "#1f2328",
list: "#3b2300",
},
metaDiffRange: "#8250df",
storageModifierImport: "#1f2328",
string: "#0a3069",
stringRegexp: "#116329",
sublimelinterGutterMark: "#818b98",
variable: "#953800",
},
};
export const darkPrettylights: prettylightsColor = {
syntax: {
brackethighlighter: { angle: "#9198a1", unmatched: "#f85149" },
carriage: { return: { bg: "#b62324", text: "#f0f6fc" } },
comment: "#9198a1",
constant: "#79c0ff",
constantOtherReferenceLink: "#a5d6ff",
entity: "#d2a8ff",
entityTag: "#7ee787",
invalid: { illegal: { bg: "#8e1519", text: "#f0f6fc" } },
keyword: "#ff7b72",
markup: {
bold: "#f0f6fc",
changed: { bg: "#5a1e02", text: "#ffdfb6" },
deleted: { bg: "#67060c", text: "#ffdcd7" },
heading: "#1f6feb",
ignored: { bg: "#1158c7", text: "#f0f6fc" },
inserted: { bg: "#033a16", text: "#aff5b4" },
italic: "#f0f6fc",
list: "#f2cc60",
},
metaDiffRange: "#d2a8ff",
storageModifierImport: "#f0f6fc",
string: "#a5d6ff",
stringRegexp: "#7ee787",
sublimelinterGutterMark: "#3d444d",
variable: "#ffa657",
},
};
export const defaultLightChroma = prettylights2Chroma(lightPrettylights);
export const defaultDarkChroma = prettylights2Chroma(darkPrettylights);

View File

@@ -2,10 +2,10 @@ import { rgba, saturate } from "polished";
import { scaleColorLight } from "src/functions"; import { scaleColorLight } from "src/functions";
import type { Ansi, Chroma, Console, Diff, Github, Message, Named, Other, Primary, Secondary } from "src/types"; import type { Ansi, Chroma, Console, Diff, Github, Message, Named, Other, Primary, Secondary } from "src/types";
import { themeVars } from "src/types/vars"; import { themeVars } from "src/types/vars";
import { prettylightsDark, prettylightsLight } from "./prettylights"; import { defaultDarkChroma, defaultLightChroma } from "./chroma";
import type { Theme } from "./theme"; import type { Theme } from "./theme";
type ThemeColor = { export type ThemeColor = {
/** 用于标识当前是否为暗色主题: `true` 暗色 `false` 亮色 */ /** 用于标识当前是否为暗色主题: `true` 暗色 `false` 亮色 */
isDarkTheme: boolean; isDarkTheme: boolean;
/** 主色调(强调色) */ /** 主色调(强调色) */
@@ -14,38 +14,41 @@ type ThemeColor = {
primaryContrast: string; primaryContrast: string;
/** 副色调(边框色) */ /** 副色调(边框色) */
secondary: string; secondary: string;
/** 色 */ /** 基础颜色 */
red: string; base: {
/** 色 */ /** 色 */
orange: string; red: string;
/** 色 */ /** 色 */
yellow: string; orange: string;
/** 黄绿色/橄榄色 */ /** 黄色 */
olive: string; yellow: string;
/** 绿色 */ /** 黄绿色/橄榄色 */
green: string; olive: string;
/** 绿色/青色(偏绿) */ /** 绿色 */
teal: string; green: string;
/** 蓝绿色/青色(偏) */ /** 蓝绿色/青色(偏绿) */
cyan: string; teal: string;
/** 蓝 */ /** 蓝绿色/青色(偏蓝) */
blue: string; cyan: string;
/** 蓝紫色/紫罗兰色 */ /** 蓝色 */
violet: string; blue: string;
/** 色 */ /** 蓝紫色/紫罗兰色 */
purple: string; violet: string;
/** 粉红色 */ /** 色 */
pink: string; purple: string;
/** 色 */ /** 粉红色 */
brown: string; pink: string;
/** 色 */ /** 色 */
black: string; brown: string;
/** 色 */ /** 色 */
grey: string; black: string;
/** 色 */ /** 色 */
gold: string; grey: string;
/** 色 */ /** 色 */
white: string; gold: string;
/** 白色 */
white: string;
};
/** Action 日志 */ /** Action 日志 */
console: Console; console: Console;
/** 提交代码对比 */ /** 提交代码对比 */
@@ -59,7 +62,7 @@ type ThemeColor = {
/** 定义颜色, 用于生成颜色主题 /** 定义颜色, 用于生成颜色主题
* @example * @example
* 文件名: "dark.css.ts" * 文件名: "dark.css.ts"
* import type { Console, Diff, Other } from "src/types"; * import type { Console, Diff, Other, Github } from "src/types";
* import { defineTheme, themeVars } from "src"; * import { defineTheme, themeVars } from "src";
* *
* const console: Console = { * const console: Console = {
@@ -78,9 +81,10 @@ type ThemeColor = {
* console, * console,
* diff, * diff,
* other, * other,
* github,
* }) * })
*/ */
export function defineTheme(themeColor: ThemeColor, chroma: Chroma | null = null): Theme { export function defineTheme(themeColor: ThemeColor, chroma?: Chroma): Theme {
const brightDir = themeColor.isDarkTheme ? -1 : 1; const brightDir = themeColor.isDarkTheme ? -1 : 1;
const primary: Primary = { const primary: Primary = {
@@ -160,161 +164,187 @@ export function defineTheme(themeColor: ThemeColor, chroma: Chroma | null = null
const named: Named = { const named: Named = {
red: { red: {
self: themeColor.red, self: themeColor.base.red,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.red, 15) : scaleColorLight(themeColor.red, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.red, 15)
: scaleColorLight(themeColor.base.red, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.red, -10), num1: scaleColorLight(themeColor.base.red, -10),
num2: scaleColorLight(themeColor.red, -20), num2: scaleColorLight(themeColor.base.red, -20),
}, },
badge: { badge: {
self: themeColor.red, self: themeColor.base.red,
bg: rgba(themeColor.red, 0.1), bg: rgba(themeColor.base.red, 0.1),
hover: { hover: {
bg: rgba(themeColor.red, 0.3), bg: rgba(themeColor.base.red, 0.3),
}, },
}, },
}, },
orange: { orange: {
self: themeColor.orange, self: themeColor.base.orange,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.orange, 15) : scaleColorLight(themeColor.orange, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.orange, 15)
: scaleColorLight(themeColor.base.orange, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.orange, -10), num1: scaleColorLight(themeColor.base.orange, -10),
num2: scaleColorLight(themeColor.orange, -20), num2: scaleColorLight(themeColor.base.orange, -20),
}, },
badge: { badge: {
self: themeColor.orange, self: themeColor.base.orange,
bg: rgba(themeColor.orange, 0.1), bg: rgba(themeColor.base.orange, 0.1),
hover: { hover: {
bg: rgba(themeColor.orange, 0.3), bg: rgba(themeColor.base.orange, 0.3),
}, },
}, },
}, },
yellow: { yellow: {
self: themeColor.yellow, self: themeColor.base.yellow,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.yellow, 15) : scaleColorLight(themeColor.yellow, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.yellow, 15)
: scaleColorLight(themeColor.base.yellow, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.yellow, -10), num1: scaleColorLight(themeColor.base.yellow, -10),
num2: scaleColorLight(themeColor.yellow, -20), num2: scaleColorLight(themeColor.base.yellow, -20),
}, },
badge: { badge: {
self: themeColor.yellow, self: themeColor.base.yellow,
bg: rgba(themeColor.yellow, 0.1), bg: rgba(themeColor.base.yellow, 0.1),
hover: { hover: {
bg: rgba(themeColor.yellow, 0.3), bg: rgba(themeColor.base.yellow, 0.3),
}, },
}, },
}, },
olive: { olive: {
self: themeColor.olive, self: themeColor.base.olive,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.olive, 15) : scaleColorLight(themeColor.olive, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.olive, 15)
: scaleColorLight(themeColor.base.olive, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.olive, -10), num1: scaleColorLight(themeColor.base.olive, -10),
num2: scaleColorLight(themeColor.olive, -20), num2: scaleColorLight(themeColor.base.olive, -20),
}, },
}, },
green: { green: {
self: themeColor.green, self: themeColor.base.green,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.green, 15) : scaleColorLight(themeColor.green, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.green, 15)
: scaleColorLight(themeColor.base.green, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.green, -10), num1: scaleColorLight(themeColor.base.green, -10),
num2: scaleColorLight(themeColor.green, -20), num2: scaleColorLight(themeColor.base.green, -20),
}, },
badge: { badge: {
self: themeColor.green, self: themeColor.base.green,
bg: rgba(themeColor.green, 0.1), bg: rgba(themeColor.base.green, 0.1),
hover: { hover: {
bg: rgba(themeColor.green, 0.3), bg: rgba(themeColor.base.green, 0.3),
}, },
}, },
}, },
teal: { teal: {
self: themeColor.teal, self: themeColor.base.teal,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.teal, 15) : scaleColorLight(themeColor.teal, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.teal, 15)
: scaleColorLight(themeColor.base.teal, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.teal, -10), num1: scaleColorLight(themeColor.base.teal, -10),
num2: scaleColorLight(themeColor.teal, -20), num2: scaleColorLight(themeColor.base.teal, -20),
}, },
}, },
blue: { blue: {
self: themeColor.blue, self: themeColor.base.blue,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.blue, 15) : scaleColorLight(themeColor.blue, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.blue, 15)
: scaleColorLight(themeColor.base.blue, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.blue, -10), num1: scaleColorLight(themeColor.base.blue, -10),
num2: scaleColorLight(themeColor.blue, -20), num2: scaleColorLight(themeColor.base.blue, -20),
}, },
}, },
violet: { violet: {
self: themeColor.violet, self: themeColor.base.violet,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.violet, 15) : scaleColorLight(themeColor.violet, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.violet, 15)
: scaleColorLight(themeColor.base.violet, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.violet, -10), num1: scaleColorLight(themeColor.base.violet, -10),
num2: scaleColorLight(themeColor.violet, -20), num2: scaleColorLight(themeColor.base.violet, -20),
}, },
}, },
purple: { purple: {
self: themeColor.purple, self: themeColor.base.purple,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.purple, 15) : scaleColorLight(themeColor.purple, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.purple, 15)
: scaleColorLight(themeColor.base.purple, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.purple, -10), num1: scaleColorLight(themeColor.base.purple, -10),
num2: scaleColorLight(themeColor.purple, -20), num2: scaleColorLight(themeColor.base.purple, -20),
}, },
}, },
pink: { pink: {
self: themeColor.pink, self: themeColor.base.pink,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.pink, 15) : scaleColorLight(themeColor.pink, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.pink, 15)
: scaleColorLight(themeColor.base.pink, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.pink, -10), num1: scaleColorLight(themeColor.base.pink, -10),
num2: scaleColorLight(themeColor.pink, -20), num2: scaleColorLight(themeColor.base.pink, -20),
}, },
}, },
brown: { brown: {
self: themeColor.brown, self: themeColor.base.brown,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.brown, 15) : scaleColorLight(themeColor.brown, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.brown, 15)
: scaleColorLight(themeColor.base.brown, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.brown, -10), num1: scaleColorLight(themeColor.base.brown, -10),
num2: scaleColorLight(themeColor.brown, -20), num2: scaleColorLight(themeColor.base.brown, -20),
}, },
}, },
black: { black: {
self: themeColor.black, self: themeColor.base.black,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.black, 15) : scaleColorLight(themeColor.black, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.black, 15)
: scaleColorLight(themeColor.base.black, 25),
dark: { dark: {
num1: scaleColorLight(themeColor.black, -10), num1: scaleColorLight(themeColor.base.black, -10),
num2: scaleColorLight(themeColor.black, -20), num2: scaleColorLight(themeColor.base.black, -20),
}, },
}, },
grey: { grey: {
self: themeColor.grey, self: themeColor.base.grey,
light: themeColor.isDarkTheme ? scaleColorLight(themeColor.grey, 15) : scaleColorLight(themeColor.grey, 25), light: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.grey, 15)
: scaleColorLight(themeColor.base.grey, 25),
}, },
gold: themeColor.gold, gold: themeColor.base.gold,
white: themeColor.white, white: themeColor.base.white,
}; };
const message: Message = { const message: Message = {
error: { error: {
bg: { bg: {
self: rgba(themeColor.red, 0.1), self: rgba(themeColor.base.red, 0.1),
active: rgba(themeColor.red, 0.5), active: rgba(themeColor.base.red, 0.5),
hover: rgba(themeColor.red, 0.3), hover: rgba(themeColor.base.red, 0.3),
}, },
border: rgba(themeColor.red, 0.4), border: rgba(themeColor.base.red, 0.4),
text: saturate(0.2, themeColor.red), // 饱和度提高 text: saturate(0.2, themeColor.base.red), // 饱和度提高
}, },
success: { success: {
bg: rgba(themeColor.green, 0.1), bg: rgba(themeColor.base.green, 0.1),
border: rgba(themeColor.green, 0.4), border: rgba(themeColor.base.green, 0.4),
text: saturate(0.2, themeColor.green), text: saturate(0.2, themeColor.base.green),
}, },
warning: { warning: {
bg: rgba(themeColor.yellow, 0.1), bg: rgba(themeColor.base.yellow, 0.1),
border: rgba(themeColor.yellow, 0.4), border: rgba(themeColor.base.yellow, 0.4),
text: saturate(0.2, themeColor.yellow), text: saturate(0.2, themeColor.base.yellow),
}, },
info: { info: {
bg: rgba(themeColor.blue, 0.1), bg: rgba(themeColor.base.blue, 0.1),
border: rgba(themeColor.blue, 0.4), border: rgba(themeColor.base.blue, 0.4),
text: saturate(0.2, themeColor.blue), text: saturate(0.2, themeColor.base.blue),
}, },
}; };
@@ -325,7 +355,7 @@ export function defineTheme(themeColor: ThemeColor, chroma: Chroma | null = null
yellow: themeVars.color.yellow.self, yellow: themeVars.color.yellow.self,
blue: themeVars.color.blue.self, blue: themeVars.color.blue.self,
magenta: themeVars.color.pink.self, magenta: themeVars.color.pink.self,
cyan: themeColor.cyan, cyan: themeColor.base.cyan,
white: themeVars.color.console.fg.subtle, white: themeVars.color.console.fg.subtle,
bright: { bright: {
black: themeVars.color.black.light, black: themeVars.color.black.light,
@@ -334,14 +364,16 @@ export function defineTheme(themeColor: ThemeColor, chroma: Chroma | null = null
yellow: themeVars.color.yellow.light, yellow: themeVars.color.yellow.light,
blue: themeVars.color.blue.light, blue: themeVars.color.blue.light,
magenta: themeVars.color.pink.light, magenta: themeVars.color.pink.light,
cyan: themeColor.isDarkTheme ? scaleColorLight(themeColor.cyan, 10) : scaleColorLight(themeColor.cyan, 25), cyan: themeColor.isDarkTheme
? scaleColorLight(themeColor.base.cyan, 10)
: scaleColorLight(themeColor.base.cyan, 25),
white: themeVars.color.console.fg.self, white: themeVars.color.console.fg.self,
}, },
}; };
return { return {
isDarkTheme: themeColor.isDarkTheme.toString(), isDarkTheme: themeColor.isDarkTheme.toString(),
chroma: chroma || (themeColor.isDarkTheme ? prettylightsDark : prettylightsLight), chroma: chroma || (themeColor.isDarkTheme ? defaultDarkChroma : defaultLightChroma),
color: { color: {
primary, primary,
secondary, secondary,

View File

@@ -1,10 +1,9 @@
import { saturate } from "polished"; import { saturate } from "polished";
import type { Console, Diff, Other } from "src"; import type { Console, Diff, Other } from "src";
import { scaleColorLight } from "src/functions"; import { scaleColorLight } from "src/functions";
import type { Chroma, Github } from "src/types"; import type { Github } from "src/types";
import { themeVars } from "src/types/vars"; import { themeVars } from "src/types/vars";
import { defineTheme } from "./color"; import { type ThemeColor } from "./color";
import type { Theme } from "./theme";
export type GithubColor = { export type GithubColor = {
isDarkTheme: boolean; isDarkTheme: boolean;
@@ -39,112 +38,45 @@ export type GithubColor = {
muted: string; muted: string;
}; };
bgColor: { bgColor: {
accent: { accent: { emphasis: string; muted: string };
emphasis: string; attention: { muted: string };
muted: string; success: { emphasis: string; muted: string };
}; danger: { muted: string };
attention: { done: { emphasis: string };
muted: string;
};
success: {
emphasis: string;
muted: string;
};
danger: {
muted: string;
};
done: {
emphasis: string;
};
default: string; default: string;
inset: string; inset: string;
muted: string; muted: string;
neutral: { neutral: { muted: string };
muted: string;
};
}; };
borderColor: { borderColor: {
accent: { accent: { emphasis: string };
emphasis: string; attention: { emphasis: string };
};
attention: {
emphasis: string;
};
default: string; default: string;
success: { success: { emphasis: string };
emphasis: string; done: { emphasis: string };
};
done: {
emphasis: string;
};
muted: string; muted: string;
translucent: string; translucent: string;
}; };
button: { button: {
primary: { primary: { fgColor: { rest: string }; bgColor: { hover: string } };
fgColor: { danger: { fgColor: { rest: string; hover: string }; bgColor: { hover: string } };
rest: string;
};
bgColor: {
hover: string;
};
};
danger: {
fgColor: {
rest: string;
hover: string;
};
bgColor: {
hover: string;
};
};
}; };
control: { control: {
bgColor: { bgColor: { active: string; hover: string; rest: string };
active: string; transparent: { bgColor: { active: string; hover: string; selected: string } };
hover: string;
rest: string;
};
transparent: {
bgColor: {
active: string;
hover: string;
selected: string;
};
};
};
shadow: {
floating: {
small: string;
};
};
overlay: {
backdrop: {
bgColor: string;
};
};
underlineNav: {
borderColor: {
active: string;
};
}; };
shadow: { floating: { small: string } };
overlay: { backdrop: { bgColor: string } };
underlineNav: { borderColor: { active: string } };
contribution: { contribution: {
default: { default: {
bgColor: { bgColor: { num0: string; num1: string; num2: string; num3: string; num4: string };
num0: string; borderColor: { num0: string };
num1: string;
num2: string;
num3: string;
num4: string;
};
borderColor: {
num0: string;
};
}; };
}; };
}; };
export function defineGithubTheme(githubColor: GithubColor, chroma: Chroma | null = null): Theme { export function github2ThemeColor(githubColor: GithubColor): ThemeColor {
const console: Console = { const console: Console = {
fg: { fg: {
self: githubColor.fgColor.default, self: githubColor.fgColor.default,
@@ -394,12 +326,12 @@ export function defineGithubTheme(githubColor: GithubColor, chroma: Chroma | nul
}, },
}, },
}; };
return defineTheme( return {
{ isDarkTheme: githubColor.isDarkTheme,
isDarkTheme: githubColor.isDarkTheme, primary: githubColor.fgColor.accent,
primary: githubColor.fgColor.accent, primaryContrast: githubColor.fgColor.default,
primaryContrast: githubColor.fgColor.default, secondary: githubColor.borderColor.default,
secondary: githubColor.borderColor.default, base: {
red: githubColor.fgColor.danger, red: githubColor.fgColor.danger,
orange: githubColor.fgColor.severe, orange: githubColor.fgColor.severe,
yellow: githubColor.fgColor.attention, yellow: githubColor.fgColor.attention,
@@ -416,11 +348,10 @@ export function defineGithubTheme(githubColor: GithubColor, chroma: Chroma | nul
grey: githubColor.fgColor.neutral, grey: githubColor.fgColor.neutral,
gold: githubColor.display.lemon.fgColor, gold: githubColor.display.lemon.fgColor,
white: githubColor.fgColor.white, white: githubColor.fgColor.white,
console,
diff,
other,
github,
}, },
chroma console,
); diff,
other,
github,
};
} }

View File

@@ -2,47 +2,22 @@ import type { Chroma } from "src/types";
export type prettylightsColor = { export type prettylightsColor = {
syntax: { syntax: {
brackethighlighter: { brackethighlighter: { angle: string; unmatched: string };
angle: string; carriage: { return: { bg: string; text: string } };
unmatched: string;
};
carriage: {
return: {
bg: string;
text: string;
};
};
comment: string; comment: string;
constant: string; constant: string;
constantOtherReferenceLink: string; constantOtherReferenceLink: string;
entity: string; entity: string;
entityTag: string; entityTag: string;
invalid: { invalid: { illegal: { bg: string; text: string } };
illegal: {
bg: string;
text: string;
};
};
keyword: string; keyword: string;
markup: { markup: {
bold: string; bold: string;
changed: { changed: { bg: string; text: string };
bg: string; deleted: { bg: string; text: string };
text: string;
};
deleted: {
bg: string;
text: string;
};
heading: string; heading: string;
ignored: { ignored: { bg: string; text: string };
bg: string; inserted: { bg: string; text: string };
text: string;
};
inserted: {
bg: string;
text: string;
};
italic: string; italic: string;
list: string; list: string;
}; };
@@ -98,7 +73,7 @@ export function prettylights2Chroma(prettylights: prettylightsColor): Chroma {
string: { string: {
self: prettylights.syntax.string, self: prettylights.syntax.string,
affix: prettylights.syntax.string, affix: prettylights.syntax.string,
backtick: prettylights.syntax.string, backtick: prettylights.syntax.constant,
char: prettylights.syntax.string, char: prettylights.syntax.string,
delimiter: prettylights.syntax.string, delimiter: prettylights.syntax.string,
doc: prettylights.syntax.comment, doc: prettylights.syntax.comment,
@@ -150,113 +125,3 @@ export function prettylights2Chroma(prettylights: prettylightsColor): Chroma {
}, },
}; };
} }
export const prettylightsDark = prettylights2Chroma({
syntax: {
brackethighlighter: {
angle: "#9198a1",
unmatched: "#f85149",
},
carriage: {
return: {
bg: "#b62324",
text: "#f0f6fc",
},
},
comment: "#9198a1",
constant: "#79c0ff",
constantOtherReferenceLink: "#a5d6ff",
entity: "#d2a8ff",
entityTag: "#7ee787",
invalid: {
illegal: {
bg: "#8e1519",
text: "#f0f6fc",
},
},
keyword: "#ff7b72",
markup: {
bold: "#f0f6fc",
changed: {
bg: "#5a1e02",
text: "#ffdfb6",
},
deleted: {
bg: "#67060c",
text: "#ffdcd7",
},
heading: "#1f6feb",
ignored: {
bg: "#1158c7",
text: "#f0f6fc",
},
inserted: {
bg: "#033a16",
text: "#aff5b4",
},
italic: "#f0f6fc",
list: "#f2cc60",
},
metaDiffRange: "#d2a8ff",
storageModifierImport: "#f0f6fc",
string: "#a5d6ff",
stringRegexp: "#7ee787",
sublimelinterGutterMark: "#3d444d",
variable: "#ffa657",
}
})
export const prettylightsLight = prettylights2Chroma({
syntax: {
brackethighlighter: {
angle: "#59636e",
unmatched: "#82071e",
},
carriage: {
return: {
bg: "#cf222e",
text: "#f6f8fa",
},
},
comment: "#59636e",
constant: "#0550ae",
constantOtherReferenceLink: "#0a3069",
entity: "#6639ba",
entityTag: "#0550ae",
invalid: {
illegal: {
bg: "#82071e",
text: "#f6f8fa",
},
},
keyword: "#cf222e",
markup: {
bold: "#1f2328",
changed: {
bg: "#ffd8b5",
text: "#953800",
},
deleted: {
bg: "#ffebe9",
text: "#82071e",
},
heading: "#0550ae",
ignored: {
bg: "#0550ae",
text: "#d1d9e0",
},
inserted: {
bg: "#dafbe1",
text: "#116329",
},
italic: "#1f2328",
list: "#3b2300",
},
metaDiffRange: "#8250df",
storageModifierImport: "#1f2328",
string: "#0a3069",
stringRegexp: "#116329",
sublimelinterGutterMark: "#818b98",
variable: "#953800",
}
})

View File

@@ -39,9 +39,7 @@ export function createTheme(theme: Theme): void {
} }
createGlobalTheme(":root", themeVars, theme); createGlobalTheme(":root", themeVars, theme);
createGlobalTheme(":root", otherThemeVars, { createGlobalTheme(":root", otherThemeVars, {
border: { border: { radius: "6px" },
radius: "6px",
},
color: { color: {
git: "#f05133", git: "#f05133",
light: { light: {

View File

@@ -1,6 +1,12 @@
import type { CSSVarFunction } from "src/core/types"; import type { CSSVarFunction } from "src/core/types";
type CSSFallbackVar = `var(--${string}, ${string})`; type CSSFallbackVar = `var(--${string}, ${string})`;
/**
* 设置 CSS 变量的回退值
* @param cssvar `var(--${string})`
* @param fallback
* @returns `var(--${string}, fallback)`
*/
export function fallbackVar(cssvar: CSSVarFunction, fallback: string): CSSFallbackVar { export function fallbackVar(cssvar: CSSVarFunction, fallback: string): CSSFallbackVar {
const var_name = cssvar.replace("var(--", "").replace(")", ""); const var_name = cssvar.replace("var(--", "").replace(")", "");
return `var(--${var_name}, ${fallback})`; return `var(--${var_name}, ${fallback})`;

View File

@@ -1,3 +1,5 @@
export { defineTheme } from "./core/color"; export { defaultDarkChroma, defaultLightChroma } from "./core/chroma";
export type { Console, Diff, Other } from "./types"; export { defineTheme, type ThemeColor } from "./core/color";
export { themeVars } from "./types/vars"; export type { Theme } from "./core/theme";
export type { Ansi, Chroma, Console, Diff, Github, Message, Named, Other, Primary, Secondary } from "./types";
export { otherThemeVars, themeVars } from "./types/vars";

View File

@@ -29,6 +29,7 @@ export const github = {
* @release `releaseTagMenu` 顶部栏左侧按钮激活背景色 * @release `releaseTagMenu` 顶部栏左侧按钮激活背景色
* @navbar `navbarRight` 头像管理员标识背景颜色 * @navbar `navbarRight` 头像管理员标识背景颜色
* @dropdown `dropdown` emoji 的悬停背景色 * @dropdown `dropdown` emoji 的悬停背景色
* @menu `paginationMenu` 分页菜单的激活背景色
*/ */
emphasis: null, emphasis: null,
/** 暗淡的背景颜色 /** 暗淡的背景颜色
@@ -175,6 +176,10 @@ export const github = {
* @menu `menu` 菜单项的悬停背景颜色 * @menu `menu` 菜单项的悬停背景颜色
* @repo `repoHeader` 仓库标题的悬停背景颜色 * @repo `repoHeader` 仓库标题的悬停背景颜色
* @commit `commit` 提交信息的 Action 按钮的悬停背景颜色 * @commit `commit` 提交信息的 Action 按钮的悬停背景颜色
* @filelist `repoFiles` README 栏的按钮的悬停背景颜色
* @issue `issueSidebar` 操作按钮的悬停背景颜色
* @issue `issueList` 头部菜单左侧开启关闭菜单的悬停背景颜色
* @dashboard `dashboard` 仓库列表项目的悬停背景颜色
*/ */
hover: null, hover: null,
}, },
@@ -194,6 +199,7 @@ export const github = {
/** 下划线导航栏的边框颜色 /** 下划线导航栏的边框颜色
* @clone `clone` 按钮组的按钮下划线颜色 * @clone `clone` 按钮组的按钮下划线颜色
* @menu `secondaryMenu` 二级菜单按钮的下划线颜色 * @menu `secondaryMenu` 二级菜单按钮的下划线颜色
* @filelist `repoFiles` README 栏的左边按钮下划线颜色
*/ */
active: null, active: null,
}, },
@@ -201,17 +207,17 @@ export const github = {
/** 热力图 */ /** 热力图 */
contribution: { contribution: {
default: { default: {
/** 热力图方块的颜色 */
bgColor: { bgColor: {
num0: null, num0: null,
num1: null, num1: null,
num2: null, num2: null,
num3: null, num3: null,
num4: null, num4: null,
/** github 无此颜色需自行计算 /** github 无此颜色需自行计算 */
* @example 可参考这个颜色 `--color-prettylights-syntax-string-regexp`
*/
num5: null, num5: null,
}, },
/** 热力图方块的内边框颜色 */
borderColor: { borderColor: {
num0: null, num0: null,
num1: null, num1: null,

View File

@@ -1,12 +1,4 @@
const num = { const num = { num1: null, num2: null, num3: null, num4: null, num5: null, num6: null, num7: null };
num1: null,
num2: null,
num3: null,
num4: null,
num5: null,
num6: null,
num7: null,
};
const alpha = { const alpha = {
num10: null, num10: null,
@@ -20,33 +12,12 @@ const alpha = {
num90: null, num90: null,
}; };
export const primary = { export const primary = { self: null, contrast: null, dark: num, light: num, alpha: alpha, hover: null, active: null };
self: null,
contrast: null,
dark: num,
light: num,
alpha: alpha,
hover: null,
active: null,
};
export const secondary = { export const secondary = {
self: null, self: null,
dark: { dark: { num8: null, num9: null, num10: null, num11: null, num12: null, num13: null, ...num },
num8: null, light: { num1: null, num2: null, num3: null, num4: null },
num9: null,
num10: null,
num11: null,
num12: null,
num13: null,
...num,
},
light: {
num1: null,
num2: null,
num3: null,
num4: null,
},
alpha: alpha, alpha: alpha,
button: null, button: null,
hover: null, hover: null,

View File

@@ -1,32 +1,8 @@
const msg = { const msg = { bg: null, border: null, text: null };
bg: null,
border: null,
text: null,
};
const error = { const error = { ...msg, bg: { self: null, active: null, hover: null } };
...msg, const success = { ...msg };
bg: { const warning = { ...msg };
self: null, const info = { ...msg };
active: null,
hover: null,
},
};
const success = { export const message = { error, success, warning, info };
...msg,
};
const warning = {
...msg,
};
const info = {
...msg,
};
export const message = {
error,
success,
warning,
info,
};

View File

@@ -1,11 +1,4 @@
const baseColor = { const baseColor = { self: null, light: null, dark: { num1: null, num2: null } };
self: null,
light: null,
dark: {
num1: null,
num2: null,
},
};
const commitColor = { const commitColor = {
/** 提交哈希值颜色 */ /** 提交哈希值颜色 */
@@ -23,26 +16,14 @@ const commitColor = {
export const named = { export const named = {
/** 红色/提交警告签名颜色 */ /** 红色/提交警告签名颜色 */
red: { red: { ...commitColor, ...baseColor },
...commitColor,
...baseColor,
},
/** 橙色/提交未匹配签名颜色 */ /** 橙色/提交未匹配签名颜色 */
orange: { orange: { ...commitColor, ...baseColor },
...commitColor,
...baseColor,
},
/** 黄色/提交未信任签名颜色 */ /** 黄色/提交未信任签名颜色 */
yellow: { yellow: { ...commitColor, ...baseColor },
...commitColor,
...baseColor,
},
olive: baseColor, olive: baseColor,
/** 绿色/提交信任签名颜色 */ /** 绿色/提交信任签名颜色 */
green: { green: { ...commitColor, ...baseColor },
...commitColor,
...baseColor,
},
teal: baseColor, teal: baseColor,
blue: baseColor, blue: baseColor,
violet: baseColor, violet: baseColor,
@@ -50,10 +31,7 @@ export const named = {
pink: baseColor, pink: baseColor,
brown: baseColor, brown: baseColor,
black: baseColor, black: baseColor,
grey: { grey: { self: null, light: null },
self: null,
light: null,
},
gold: null, gold: null,
white: null, white: null,
}; };

View File

@@ -8,9 +8,7 @@ function varMapper(prefix: string | null = null) {
path = path.map(item => item.replace(/^num/, "")); path = path.map(item => item.replace(/^num/, ""));
value = path.join("-"); value = path.join("-");
} }
if (prefix) { if (prefix) value = `${prefix}-${value}`;
value = `${prefix}-${value}`;
}
return value; return value;
}; };
} }
@@ -32,26 +30,14 @@ const vars = {
github: color.github, github: color.github,
}; };
const otherVars = { const otherVars = { border: { radius: null }, color: { ...color.otherAuto } };
border: {
radius: null,
},
color: {
...color.otherAuto,
},
};
const customVars = { const customVars = {
cloneMenuWidth: "clone-menu-width", cloneMenuWidth: "clone-menu-width",
explore: { userMenuWidth: "user-menu-width",
repolistColumns: "explore-repolist-columns", explore: { repolistColumns: "explore-repolist-columns", userlistColumns: "explore-userlist-columns" },
userlistColumns: "explore-userlist-columns",
},
userRepolistColumns: "user-repolist-columns", userRepolistColumns: "user-repolist-columns",
org: { org: { repolistColumns: "org-repolist-columns", userlistColumns: "org-userlist-columns" },
repolistColumns: "org-repolist-columns",
userlistColumns: "org-userlist-columns",
},
}; };
export const themeVars = createGlobalThemeContract(vars, varMapper()); export const themeVars = createGlobalThemeContract(vars, varMapper());

View File

@@ -203,7 +203,7 @@ export const actionViewRight = css`
.job-info-header { .job-info-header {
padding: 16px 12px 16px 24px; padding: 16px 12px 16px 24px;
height: auto; height: 80px;
.job-info-header-title { .job-info-header-title {
color: ${themeVars.github.fgColor.accent}; color: ${themeVars.github.fgColor.accent};
@@ -220,6 +220,11 @@ export const actionViewRight = css`
color: ${themeVars.color.console.fg.subtle}; color: ${themeVars.color.console.fg.subtle};
padding: 8px 10px; padding: 8px 10px;
&.selected {
// 滚动时固定在顶部的高度与 job-info-header 高度相同
top: 80px;
}
&.step-expandable:hover { &.step-expandable:hover {
color: ${themeVars.color.console.fg.subtle}; color: ${themeVars.color.console.fg.subtle};
} }

View File

@@ -42,13 +42,24 @@ export const commit = css`
color: ${themeVars.color.text.light.num1}; color: ${themeVars.color.text.light.num1};
} }
} }
// 整行悬停色 tr {
tr:hover { // 整行悬停色
background-color: ${themeVars.color.hover.opaque}; &:hover {
} background-color: ${themeVars.color.hover.opaque};
// 偶数行悬停色 }
tr:nth-child(2n):hover { // 偶数行悬停色
background-color: ${themeVars.color.hover.opaque} !important; &:nth-child(2n):hover {
background-color: ${themeVars.color.hover.opaque} !important;
}
// 尾行圆角
&:last-child {
td:first-child {
border-bottom-left-radius: ${otherThemeVars.border.radius};
}
td:last-child {
border-bottom-right-radius: ${otherThemeVars.border.radius};
}
}
} }
} }
} }

View File

@@ -1,15 +1,122 @@
import { css } from "src/types/vars"; import { css, otherThemeVars, themeVars } from "src/types/vars";
export const dashboard = css` export const dashboard = css`
.page-content.dashboard { // 首页仪表板, 避免选中管理员后台的维护管理面板
// 动态的右侧 svg 图标 .page-content.dashboard.feeds {
.flex-item .flex-item-trailing svg {
height: 20px;
width: 20px;
}
// 仓库列表的仓库/组织切换按钮 // 仓库列表的仓库/组织切换按钮
.ui.two.item.menu { .ui.two.item.menu {
background-color: unset; box-shadow: ${themeVars.github.shadow.floating.small};
border: unset;
border-radius: 12px;
margin-bottom: 8px;
> .item {
&:first-child {
border-radius: 12px 0 0 12px;
}
&:last-child {
border-radius: 0 12px 12px 0;
}
}
}
// 仓库/组织列表标题
.ui.top.attached.header {
border: 0;
font-size: 20px;
font-weight: 400;
background-color: unset !important;
margin-bottom: 0.25rem;
}
// 仓库/组织列表
.ui.attached.segment {
background-color: ${themeVars.color.menu};
border: unset !important;
box-shadow: ${themeVars.github.shadow.floating.small};
&.repos-search {
border-top-left-radius: 12px;
border-top-right-radius: 12px;
}
&.table {
&:last-child {
border-bottom-left-radius: 12px !important;
border-bottom-right-radius: 12px !important;
}
ul {
padding: 8px;
li {
border-radius: ${otherThemeVars.border.radius};
&:not(:last-child) {
border-bottom: 0;
}
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover};
}
a.muted:hover {
color: inherit;
text-decoration-line: none;
}
}
}
}
}
// 组织列表
.ui.tab.dashboard-orgs .ui.attached.segment.table {
border-top-left-radius: 12px;
border-top-right-radius: 12px;
}
}
`;
export const dashboardIssues = css`
.page-content.dashboard.issues {
.list-header {
background-color: ${themeVars.color.box.header};
border: 1px solid ${themeVars.color.light.border};
border-bottom: 0;
border-top-left-radius: ${otherThemeVars.border.radius};
border-top-right-radius: ${otherThemeVars.border.radius};
height: 54px;
padding: 16px 8px;
.list-header-toggle {
align-items: center;
border: 0;
> .item {
background: unset !important;
border-radius: ${otherThemeVars.border.radius};
color: ${themeVars.color.text.light.num1};
padding: 0px 8px;
height: 30px;
&:before {
display: none;
}
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover} !important;
}
&.active {
color: ${themeVars.color.text.self};
font-weight: 700;
}
}
}
.list-header-filters {
> .item {
border-radius: ${otherThemeVars.border.radius};
color: ${themeVars.color.text.light.num1};
padding: 0px 12px;
height: 32px;
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover};
}
}
}
}
}
`;
// 避免手机/平板下菜单错位
export const issueListMobile = css`
@media (max-width: 767.98px) {
.page-content.dashboard.issues .list-header {
height: auto;
} }
} }
`; `;

View File

@@ -31,14 +31,42 @@ export const diff = css`
.code-expander-button { .code-expander-button {
color: ${themeVars.color.text.light.num1}; color: ${themeVars.color.text.light.num1};
height: 28px !important; height: 28px !important;
&:hover { &:hover {
background: ${themeVars.github.bgColor.accent.emphasis}; background: ${themeVars.github.bgColor.accent.emphasis};
color: ${themeVars.color.white} color: ${themeVars.color.white};
} }
} }
/* 行号居中 */ /* 行号居中 */
.lines-num { .lines-num {
text-align: center !important; text-align: center !important;
} }
// 差异对比文件盒子
.diff-file-box {
// 差异对比文件头
.diff-file-header {
// 文件名
.diff-file-name {
font-weight: 400;
.fold-file.btn svg {
min-width: 16px;
min-height: 16px;
height: 16px;
width: 16px;
}
.diff-stats-bar {
height: 8px;
}
> div,
.file-link {
font-size: 12px;
}
}
// 操作按钮
.diff-file-header-actions {
color: ${themeVars.color.text.light.num1};
font-size: 12px;
font-weight: 400;
}
}
}
`; `;

View File

@@ -0,0 +1,14 @@
import { css, themeVars } from "src/types/vars";
export const monaco = css`
.monaco-editor {
--vscode-editor-background: ${themeVars.color.body} !important;
--vscode-editorGutter-background: ${themeVars.color.body} !important;
// 滚动时固定在顶部的行
.sticky-widget {
background: ${themeVars.color.body} !important;
box-shadow: 0 1px 0 ${themeVars.color.secondary.self} !important;
width: 100% !important;
}
}
`;

View File

@@ -13,7 +13,8 @@ export const repoList = css`
.page-content.user.profile > .ui.container > .ui.stackable > .ui.twelve, .page-content.user.profile > .ui.container > .ui.stackable > .ui.twelve,
// 探索 // 探索
.page-content.explore.repositories > .ui.container { .page-content.explore.repositories > .ui.container {
> .flex-list { // 排除用户的公开活动页
> .flex-list:not(#activity-feed) {
display: grid; display: grid;
> .flex-item { > .flex-item {
border: 1px solid ${themeVars.color.light.border}; border: 1px solid ${themeVars.color.light.border};
@@ -37,10 +38,6 @@ export const repoList = css`
&:not(a) { &:not(a) {
color: ${themeVars.color.text.light.num1}; color: ${themeVars.color.text.light.num1};
} }
// 仓库类型和状态标签
> .label-list .label {
padding: 3px 6px;
}
} }
// 仓库语言, 星标 // 仓库语言, 星标
> .flex-item-trailing { > .flex-item-trailing {
@@ -77,7 +74,8 @@ export const repoList = css`
gap: min(${orgRepoVar} * 8px, 16px); gap: min(${orgRepoVar} * 8px, 16px);
} }
// 用户 // 用户
.page-content.user.profile > .ui.container > .ui.stackable > .ui.twelve > .flex-list { // 排除用户的公开活动页
.page-content.user.profile > .ui.container > .ui.stackable > .ui.twelve > .flex-list:not(#activity-feed) {
grid-template-columns: repeat(${userRepoVar}, 1fr); grid-template-columns: repeat(${userRepoVar}, 1fr);
gap: min(${userRepoVar} * 8px, 16px); gap: min(${userRepoVar} * 8px, 16px);
} }
@@ -111,7 +109,6 @@ export const userList = css`
// 用户标签 // 用户标签
> .label { > .label {
font-size: 12px; font-size: 12px;
padding: 3px 6px;
} }
} }
// 用户描述 // 用户描述
@@ -152,7 +149,8 @@ export const mobileList = css`
.page-content.organization.members >.ui.container, .page-content.organization.members >.ui.container,
// 探索的用户和组织列表 // 探索的用户和组织列表
.page-content.explore.users >.ui.container { .page-content.explore.users >.ui.container {
> .flex-list { // 排除用户的公开活动页
> .flex-list:not(#activity-feed) {
grid-template-columns: 1fr; grid-template-columns: 1fr;
gap: 8px; gap: 8px;
} }

View File

@@ -1,4 +1,4 @@
import { css, themeVars } from "src/types/vars"; import { css, otherThemeVars, themeVars } from "src/types/vars";
// 文件列表页面下的分支按钮 // 文件列表页面下的分支按钮
export const branchButton = css` export const branchButton = css`
@@ -75,6 +75,7 @@ export const repoFiles = css`
// 文件列表 // 文件列表
.repo-file-item { .repo-file-item {
.repo-file-cell { .repo-file-cell {
height: 40px;
&.name { &.name {
display: flex; display: flex;
align-items: center; align-items: center;
@@ -87,6 +88,41 @@ export const repoFiles = css`
} }
} }
} }
#readme {
.file-header {
background: ${themeVars.color.body};
svg {
color: ${themeVars.color.text.light.num1};
}
.file-header-left {
padding: 6px 8px !important;
// 伪元素宽度等于按钮宽度而不是父元素宽度
position: relative;
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover};
border-radius: ${otherThemeVars.border.radius};
}
&:after {
content: "";
background: ${themeVars.github.underlineNav.borderColor.active};
border-radius: ${otherThemeVars.border.radius};
bottom: -8px;
left: 0;
height: 2px;
position: absolute;
width: 100%;
}
a.muted:hover {
color: inherit;
text-decoration-line: none;
}
}
.file-header-right:hover {
background: ${themeVars.github.control.transparent.bgColor.hover};
border-radius: ${otherThemeVars.border.radius};
}
}
}
} }
`; `;
@@ -112,15 +148,179 @@ export const repoFilesMobile = css`
// 仓库打开文件时的视图 // 仓库打开文件时的视图
export const repoFileView = css` export const repoFileView = css`
// 隐藏主内容的下内容和页脚, 避免滚动文件树时滚动条遮挡
body > .full.height:has(.repo-view-file-tree-container) {
padding-bottom: 0;
+ .page-footer {
display: none;
}
}
.page-content.repository.file.list { .page-content.repository.file.list {
&:has(.repo-view-file-tree-container) {
// 取消下间隔优化观看体验
.secondary-nav {
margin-bottom: 0 !important;
.ui.tabs.divider {
margin-bottom: 0;
}
}
}
> .ui.container.fluid {
max-width: calc(100% - calc(2 * 16px));
}
.repo-view-container { .repo-view-container {
position: sticky;
top: 0;
// 左侧文件树
.repo-view-file-tree-container {
height: calc(100vh - 64px); // 减去头部高度
// 固定头部
position: sticky;
top: 0;
&:after {
content: "";
position: absolute;
top: 0;
right: 0;
width: 1px;
height: calc(100% + 64px); // 头部高度
background: ${themeVars.color.secondary.self};
}
> .repo-button-row {
align-content: center;
background: ${themeVars.color.body};
font-size: 16px;
height: 64px;
margin: 0;
// 固定头部, 早期父元素有多余的页脚和内容高度导致滚动时无法固定, 修复后也可保留此属性无需删除
position: sticky;
top: 0;
&:after {
content: "";
position: absolute;
top: 64px;
left: -16px;
width: calc(100% + 16px);
height: 1px;
background: ${themeVars.color.secondary.self};
}
.ui.compact.icon.button {
border: 0;
}
}
.view-file-tree-items {
margin-right: 0;
padding: 12px 16px 8px 0;
}
}
// 右侧文件视图内容 // 右侧文件视图内容
.repo-view-content { .repo-view-content {
padding-bottom: 40px;
.repo-button-row {
align-content: center;
background: ${themeVars.color.box.header};
border: 1px solid ${themeVars.color.secondary.self};
border-radius: ${otherThemeVars.border.radius};
margin: 16px 0;
height: 46px;
min-height: 46px;
padding: 8px;
position: sticky;
top: 0;
z-index: 1;
.ui.button {
min-height: 32px;
}
// 打开文件树按钮
.repo-view-file-tree-toggle-show {
background: initial;
border-color: #0000;
padding: 0;
min-width: 32px;
}
// 分支选择按钮
.branch-dropdown-button {
padding: 0 12px;
}
// 路径
.repo-path {
gap: 4px;
.section {
&:first-child,
&.active {
font-weight: 600;
}
}
.btn {
svg {
margin-left: 4px;
color: ${themeVars.color.text.light.num1};
}
}
}
}
.non-diff-file-content {
// 避免分支菜单遮挡
position: relative;
z-index: 0;
h4.file-header {
padding: 8px 12px !important;
position: sticky;
// 重叠边框线, 避免过粗
top: 45px;
z-index: 1;
.file-header-left {
color: ${themeVars.color.text.light.num1};
font-size: 12px;
}
.file-header-right {
// 按钮组
> .ui.buttons {
margin: 0 8px 0 0 !important; // 完全不知道为什么浏览器最终效果没生效, 只能 !important 了
.ui.mini.button {
min-height: 28px;
height: 28px;
font-size: 12px;
padding: 0 8px;
}
}
// 右侧操作按钮
> .btn-octicon {
display: flex;
align-items: center;
background: ${themeVars.color.button};
border: 1px solid ${themeVars.color.light.border};
height: 28px;
padding: 0 8px;
svg {
color: ${themeVars.color.text.light.num1};
}
&:first-of-type {
border-top-left-radius: ${otherThemeVars.border.radius};
border-bottom-left-radius: ${otherThemeVars.border.radius};
}
&:last-of-type {
border-top-right-radius: ${otherThemeVars.border.radius};
border-bottom-right-radius: ${otherThemeVars.border.radius};
}
&:hover {
background: ${themeVars.color.hover.self};
color: ${themeVars.color.text.light.num1};
}
}
}
}
}
// 头部提交信息 // 头部提交信息
#repo-file-commit-box { .ui.segment#repo-file-commit-box {
padding: 8px 12px; padding: 8px 12px;
margin-bottom: 16px !important;
min-height: 46px;
> .latest-commit { > .latest-commit {
gap: 8px; gap: 8px;
.commit-summary {
color: ${themeVars.color.text.light.num1};
}
} }
// 右侧提交时间 // 右侧提交时间
> .age { > .age {
@@ -133,6 +333,24 @@ export const repoFileView = css`
} }
`; `;
// 避免手机/平板下路径容器过长导致换行, 取消固定
export const repoFileViewMobile = css`
@media (max-width: 1023.98px) {
.page-content.repository.file.list .repo-view-container .repo-view-content {
.repo-button-row {
height: auto;
position: static;
z-index: 0;
}
.non-diff-file-content {
h4.file-header {
top: 0;
}
}
}
}
`;
// 仓库代码布局调整, 侧边栏宽度调整 // 仓库代码布局调整, 侧边栏宽度调整
export const repoGrid = css` export const repoGrid = css`
.repo-grid-filelist-sidebar { .repo-grid-filelist-sidebar {

View File

@@ -1,50 +1,88 @@
import { css, themeVars } from "src/types/vars"; import { css, otherThemeVars, themeVars } from "src/types/vars";
export const heatmap = css` export const heatmap = css`
.vch__container { #user-heatmap {
// 覆盖热力图和图例的背景色 .total-contributions {
.vch__day__square, left: 25px + 20px;
.vch__legend__wrapper rect { bottom: 0 + 12px;
// 圆角 }
rx: 2.5px; .total-contributions,
ry: 2.5px; .vch__legend-right {
// hover 时的圆角 color: ${themeVars.color.text.light.num1};
border-radius: 0.75px; }
// 宽度和高度可以用来控制间隔 .vch__container {
width: 9px; padding: 12px 20px;
height: 9px; border: 1px solid ${themeVars.color.secondary.self};
// 边框 border-radius: ${otherThemeVars.border.radius};
outline: 0.5px solid ${themeVars.github.contribution.default.borderColor.num0}; // 覆盖热力图和图例的背景色
// 边框向内偏移 .vch__day__square,
outline-offset: -0.5px; .vch__legend__wrapper rect {
// 圆角
rx: 2.5px;
ry: 2.5px;
// hover 时的圆角
border-radius: 0.75px;
// 宽度和高度可以用来控制间隔
width: 9px;
height: 9px;
// 边框
outline: 0.5px solid ${themeVars.github.contribution.default.borderColor.num0};
// 边框向内偏移
outline-offset: -0.5px;
&[style="fill: var(--color-secondary-alpha-60);"] { &[style="fill: var(--color-secondary-alpha-60);"] {
fill: ${themeVars.github.contribution.default.bgColor.num0} !important; fill: ${themeVars.github.contribution.default.bgColor.num0} !important;
} }
&[style="fill: var(--color-primary-light-4);"] { &[style="fill: var(--color-primary-light-4);"] {
fill: ${themeVars.github.contribution.default.bgColor.num1} !important; fill: ${themeVars.github.contribution.default.bgColor.num1} !important;
outline-color: ${themeVars.github.contribution.default.borderColor.num1}; outline-color: ${themeVars.github.contribution.default.borderColor.num1};
} }
&[style="fill: var(--color-primary-light-2);"] { &[style="fill: var(--color-primary-light-2);"] {
fill: ${themeVars.github.contribution.default.bgColor.num2} !important; fill: ${themeVars.github.contribution.default.bgColor.num2} !important;
outline-color: ${themeVars.github.contribution.default.borderColor.num2}; outline-color: ${themeVars.github.contribution.default.borderColor.num2};
} }
&[style="fill: var(--color-primary);"] { &[style="fill: var(--color-primary);"] {
fill: ${themeVars.github.contribution.default.bgColor.num3} !important; fill: ${themeVars.github.contribution.default.bgColor.num3} !important;
outline-color: ${themeVars.github.contribution.default.borderColor.num3}; outline-color: ${themeVars.github.contribution.default.borderColor.num3};
} }
&[style="fill: var(--color-primary-dark-2);"] { &[style="fill: var(--color-primary-dark-2);"] {
fill: ${themeVars.github.contribution.default.bgColor.num4} !important; fill: ${themeVars.github.contribution.default.bgColor.num4} !important;
outline-color: ${themeVars.github.contribution.default.borderColor.num4}; outline-color: ${themeVars.github.contribution.default.borderColor.num4};
} }
&[style="fill: var(--color-primary-dark-4);"] { &[style="fill: var(--color-primary-dark-4);"] {
fill: ${themeVars.github.contribution.default.bgColor.num5} !important; fill: ${themeVars.github.contribution.default.bgColor.num5} !important;
outline-color: ${themeVars.github.contribution.default.borderColor.num5}; outline-color: ${themeVars.github.contribution.default.borderColor.num5};
}
}
}
}
`;
// 动态
export const activity = css`
#activity-feed {
.flex-item {
gap: 12px;
padding: 16px 0;
&:first-child {
padding-top: 6px;
}
> .flex-item-main {
gap: 8px !important;
relative-time {
color: ${themeVars.color.text.light.num1};
}
}
// 动态的右侧 svg 图标
.flex-item-trailing svg {
height: 20px;
width: 20px;
} }
} }
} }

View File

@@ -1,13 +1,20 @@
import "./actions"; import "./actions";
import "./chroma";
import "./clone"; import "./clone";
import "./commit"; import "./commit";
import "./dashboard"; import "./dashboard";
import "./diff"; import "./diff";
import "./editor";
import "./explore"; import "./explore";
import "./filelist"; import "./filelist";
import "./heatmap"; import "./heatmap";
import "./issue"; import "./issue";
import "./milestones";
import "./newrepo"; import "./newrepo";
import "./notification";
import "./org";
import "./release"; import "./release";
import "./repo"; import "./repo";
import "./setting"; import "./setting";
import "./signin";
import "./user";

View File

@@ -1,6 +1,184 @@
import { css, otherThemeVars, themeVars } from "src/types/vars"; import { css, otherThemeVars, themeVars } from "src/types/vars";
import { activeItemAfterStyle } from "styles/public/menu"; import { activeItemAfterStyle } from "styles/public/menu";
// 工单&PR 列表
export const issueList = css`
// 仓库页面的里程碑列表菜单栏
.page-content.repository.milestones,
.page-content.repository.milestone-issue-list,
.page-content.repository.issue-list {
// 头部筛选菜单栏
.issue-list-toolbar {
align-items: center;
align-content: center;
background-color: ${themeVars.color.box.header};
border: 1px solid ${themeVars.color.light.border};
border-bottom: 0;
border-top-left-radius: ${otherThemeVars.border.radius};
border-top-right-radius: ${otherThemeVars.border.radius};
height: 48px;
padding: 8px;
.issue-list-toolbar-left {
// 复选框
input {
margin: 0 8px !important;
}
> .ui.compact.menu {
align-items: center;
border: 0;
> .item {
background: unset !important;
border-radius: ${otherThemeVars.border.radius};
color: ${themeVars.color.text.light.num1};
padding: 0px 8px;
height: 30px;
&:before {
display: none;
}
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover} !important;
}
&.active {
color: ${themeVars.color.text.self};
font-weight: 700;
}
}
}
}
.issue-list-toolbar-right > .ui.menu {
align-items: center;
> .item {
color: ${themeVars.color.text.light.num1};
}
> .ui.button {
padding: 0 12px;
height: 32px;
}
}
}
}
// 里程碑详细页面的 Issue 列表
.page-content.repository.milestone-issue-list,
// 顶部仪表板的 Issue 列表
.page-content.dashboard.issues,
// 用户订阅的 Issue 列表
.page-content.user.notification,
// 仓库 Issue 列表
.page-content.repository.issue-list {
.flex-list#issue-list {
border: 1px solid ${themeVars.color.light.border};
border-bottom-left-radius: ${otherThemeVars.border.radius};
border-bottom-right-radius: ${otherThemeVars.border.radius};
> .flex-item {
align-items: center;
padding: 0;
&:last-child {
border-bottom-left-radius: ${otherThemeVars.border.radius};
border-bottom-right-radius: ${otherThemeVars.border.radius};
}
&:hover {
background-color: ${themeVars.color.hover.opaque};
}
> .flex-item-icon {
display: flex;
gap: 4px;
margin-left: 16px;
// 复选框
input {
background: unset;
margin-top: 14px;
margin-right: 8px !important;
}
svg {
margin-top: 14px;
}
}
> .flex-item-main {
gap: 4px;
.flex-item-header {
padding-top: 8px;
}
.flex-item-body {
font-size: 12px;
padding-bottom: 8px;
}
}
> .flex-item-trailing {
margin-right: 32px;
}
}
}
}
// 里程碑列表
// [TODO] 暂时排除项目的列表
.page-content.repository.milestones:not(.projects) .milestone-list {
border: 1px solid ${themeVars.color.light.border};
border-bottom-left-radius: ${otherThemeVars.border.radius};
border-bottom-right-radius: ${otherThemeVars.border.radius};
.milestone-card {
padding: 8px 16px 10px 16px;
.milestone-header {
h3 {
font-size: 16px;
font-weight: 500;
}
div span {
font-size: 14px;
font-weight: 600;
}
}
}
.milestone-toolbar {
font-size: 12px;
.group > a {
font-size: 13px;
}
}
}
`;
// 避免手机/平板下菜单错位
export const issueListMobile = css`
@media (max-width: 1023.98px) {
.page-content.repository.milestones,
.page-content.repository.milestone-issue-list,
.page-content.repository.issue-list {
.issue-list-toolbar {
height: auto;
}
}
}
`;
// 置顶 Issue
export const issuePins = css`
#issue-pins {
gap: 12px;
margin-bottom: 14px;
.issue-card {
padding: 16px 12px;
.content {
.issue-card-title {
font-size: 16px;
font-weight: 600;
}
svg {
color: ${themeVars.color.text.light.num1};
height: 100%;
margin-right: 3px;
}
.meta {
font-size: 12px;
padding-top: 4px;
}
}
.issue-card-bottom {
display: none;
}
}
}
`;
export const button = css` export const button = css`
.issue-content-left .field.footer { .issue-content-left .field.footer {
// 关闭工单按钮 // 关闭工单按钮
@@ -18,6 +196,11 @@ export const button = css`
color: ${themeVars.github.fgColor.success}; color: ${themeVars.github.fgColor.success};
} }
} }
// 工单&PR标题右侧按钮
.repository.view.issue .issue-title-buttons > .ui.button {
padding: 0 12px;
height: 32px;
}
`; `;
export const babel = css` export const babel = css`
@@ -103,6 +286,7 @@ export const comment = css`
} }
.comment-header { .comment-header {
padding: 4px 4px 4px 16px; padding: 4px 4px 4px 16px;
min-height: 38px;
} }
.comment-header-right { .comment-header-right {
> .item, > .item,
@@ -330,3 +514,111 @@ export const timeline = css`
} }
} }
`; `;
const sidebarPadding = {
padding: "4px 8px",
};
// 侧边栏
export const issueSidebar = css`
.issue-content {
gap: 24px;
.issue-content-right {
border: 0;
font-size: 12px;
padding: 0;
.ui.button {
font-size: 12px;
}
.ui.form,
a.fixed-text.muted,
span.text,
// 列表项为空时的文字
span.item.empty-list,
p {
color: ${themeVars.color.text.light.num1};
font-size: 12px;
}
.ui.dropdown.select-branch,
.ui.form,
a.fixed-text.muted,
span.text,
.ui.watching > div,
.ui.depending > div,
.flex-text-block,
.ui.list,
p {
${sidebarPadding};
}
.issue-sidebar-combo {
.ui.dropdown > a.fixed-text.muted {
align-items: center;
border-radius: ${otherThemeVars.border.radius};
text-decoration-line: none;
height: 28px;
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover};
}
}
.ui.list {
margin-top: 0 !important;
margin-bottom: 0 !important;
}
}
// 时间追踪
> div:not([class]):not([id]) > .ui.dropdown.jump > a.fixed-text.muted {
align-items: center;
border-radius: ${otherThemeVars.border.radius};
text-decoration-line: none;
height: 28px;
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover};
}
}
// 选中日期颜色
.ui.form .due-date {
color: ${themeVars.color.text.self};
}
.divider {
margin: 12px 0 12px 8px;
width: calc(100% - 16px);
}
// 订阅按钮
.ui.watching .ui.button {
padding: 0px 8px;
height: 28px;
svg {
margin: 0 !important;
}
}
// PIN 按钮
.form-fetch-action.single-button-form .ui.button,
// 底部操作按钮
.ui.show-modal.button {
border: 0;
background: unset;
font-weight: 400;
${sidebarPadding};
// 好像是浏览器 BUG, 最后不生效, 必须 !important
margin: 0 !important;
justify-content: left;
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover};
}
}
.ui.show-modal.button[data-modal="#sidebar-delete-issue"] {
color: ${themeVars.color.red.self};
svg {
color: ${themeVars.color.red.self};
}
&:hover {
background-color: ${themeVars.color.red.badge.bg};
color: ${themeVars.color.red.light};
svg {
color: ${themeVars.color.red.light};
}
}
}
}
}
`;

View File

@@ -0,0 +1,59 @@
import { css, themeVars } from "src/types/vars";
export const milestone = css`
// 里程碑头部
.milestone-header {
gap: 16px;
// 进度条
progress {
height: 5px;
width: 300px;
max-width: 80vw;
}
}
// 里程碑 Issue 列表的进度条
.milestone-progress-big {
height: 8px;
}
// 里程碑 Issue 列表
.page-content.repository.milestone-issue-list {
> .ui.container {
> .flex-text-block:first-child {
margin-bottom: 16px;
> h1 {
font-size: 32px;
font-weight: 600;
line-height: 48px;
word-break: keep-all;
}
+ .tw-flex {
flex-direction: row !important;
align-items: center;
gap: 8px !important;
padding-top: 8px;
padding-bottom: 10px;
font-size: 14px;
color: ${themeVars.color.text.light.num1};
strong {
color: ${themeVars.color.text.self};
}
> .flex-text-block {
gap: 8px !important;
}
}
}
> .divider {
border-top-color: #0000;
}
}
}
`;
// 避免手机/平板下菜单错位
export const milestoneMobile = css`
@media (max-width: 767.98px) {
.page-content.repository.milestone-issue-list > .ui.container > .flex-text-block:first-child + .tw-flex {
flex-direction: column !important;
}
}
`;

View File

@@ -0,0 +1,63 @@
import { css, otherThemeVars, themeVars } from "src/types/vars";
// 用户订阅/关注页面
export const notification = css`
.page-content.user.notification {
> .ui.container {
> .ui.attached.segment {
border: 0;
padding: 0;
> .divider {
display: none;
}
// 订阅列表
&:has(#issue-list) {
> .tw-flex {
align-items: center;
align-content: center;
background-color: ${themeVars.color.box.header};
border: 1px solid ${themeVars.color.light.border};
border-bottom: 0;
border-top-left-radius: ${otherThemeVars.border.radius};
border-top-right-radius: ${otherThemeVars.border.radius};
height: 52px;
padding: 8px;
// 左侧菜单
> .tw-flex:first-child > .ui.compact.menu {
align-items: center;
border: 0;
> .item {
background: unset !important;
border-radius: ${otherThemeVars.border.radius};
color: ${themeVars.color.text.light.num1};
padding: 0px 8px;
height: 30px;
&:before {
display: none;
}
&:hover {
background: ${themeVars.github.control.transparent.bgColor.hover} !important;
}
&.active {
color: ${themeVars.color.text.self};
font-weight: 700;
}
}
}
// 右侧菜单
> .tw-flex:last-child > .ui.menu {
align-items: center;
> .item {
color: ${themeVars.color.text.light.num1};
}
> .ui.button {
padding: 0 12px;
height: 32px;
}
}
}
}
}
}
}
`;

21
styles/components/org.ts Normal file
View File

@@ -0,0 +1,21 @@
import { css, themeVars } from "src/types/vars";
export const org = css`
.page-content.organization {
#org-info {
.ui.header {
// 组织页面的 RSS 订阅按钮
.ui.label.button {
padding: 4px 16px;
.svg {
width: 20px;
min-width: 20px;
}
&:hover {
border-color: ${themeVars.color.light.border};
}
}
}
}
}
`;

View File

@@ -73,21 +73,72 @@ export const releases = css`
} }
// 右侧发布详细信息 // 右侧发布详细信息
.segment.detail { .segment.detail {
padding: 16px;
.svg { .svg {
color: ${themeVars.color.text.light.num1}; color: ${themeVars.color.text.light.num1};
} }
// 标题
.release-list-title {
font-size: 32px;
gap: 16px;
}
// 提交信息
p.text.grey { p.text.grey {
margin: 16px 0; display: flex;
gap: 6px;
flex-wrap: wrap;
margin: 24px 0 0 0;
span {
word-break: break-word;
}
.time { .time {
color: ${themeVars.color.text.self}; color: ${themeVars.color.text.self};
} }
} }
// 发布内容
.markup { .markup {
> *:first-child { > *:first-child {
margin-top: 16px !important; margin-top: 24px !important;
} }
> *:last-child { }
margin-bottom: 16px !important; // 分割线
.divider {
position: relative;
left: -16px;
width: calc(100% + 32px);
border-top-width: 1.5px;
margin: 24px 0 16px 0;
}
// 下载列表
.download {
summary {
font-size: 18px;
font-weight: 600;
margin-top: 16px;
&::marker {
font-size: 14px;
}
}
.attachment-list {
margin-top: 16px;
.item {
align-items: center;
line-height: 17px;
padding: 8px 16px;
.flex-text-inline {
gap: 8px;
}
// 只选中左侧文件名称
strong.flex-text-inline:hover {
text-decoration: underline !important;
}
.attachment-right-info {
color: ${themeVars.color.text.light.num1};
.svg {
height: 28px;
}
}
}
} }
} }
} }

View File

@@ -76,33 +76,3 @@ export const label = css`
} }
} }
`; `;
// 设置右面板的内容
export const content = css`
.user-main-content,
.repo-setting-content,
.user-setting-content,
.org-setting-content,
.admin-setting-content {
.ui.top.attached.header {
border: 0;
font-size: 1.5rem;
font-weight: 400;
background-color: unset !important;
margin-bottom: 0.25rem;
}
.ui.attached.segment {
background-color: unset;
border-radius: 0.5rem !important;
}
.ui.attached.segment:not(.error) {
border: 1px solid ${themeVars.color.light.border} !important;
}
.ui.attached.segment.error {
border: 1px solid ${themeVars.color.error.border} !important;
}
}
`;

View File

@@ -0,0 +1,53 @@
import { css } from "src/types/vars";
// 注册/登录界面
export const signIn = css`
.page-content.user.signin {
.ui.grid {
justify-content: center;
> .column {
width: 384px;
padding: 16px;
> .ui.container {
max-width: unset;
}
}
}
.ui.top.attached.header {
border: 0;
font-size: 20px;
font-weight: 600;
background-color: unset !important;
text-align: center;
padding: 16px;
}
.ui.attached.segment {
border: 0;
padding: 16px 0 0 0;
.field:not(.inline) {
label {
font-size: 14px;
font-weight: 600;
}
input {
background: unset;
padding: 5px 12px;
height: 40px;
font-size: 16px;
}
}
.button {
height: 40px;
}
}
.ui.top.attached.header.segment {
font-size: 14px;
font-weight: 400;
gap: 16px;
.signin-passkey {
font-weight: 500;
}
}
}
`;

62
styles/components/user.ts Normal file
View File

@@ -0,0 +1,62 @@
import { css, themeVars } from "src/types/vars";
// 用户点星仓库列表
export const stars = css`
.page-content.user.profile {
.stars {
> .flex-list {
> .flex-item {
padding: 24px 0;
&:first-child {
padding-top: 14px;
}
// 仓库头像
> .flex-item-leading {
img,
svg {
color: ${themeVars.color.text.light.num1};
}
}
// 仓库信息
> .flex-item-main {
// 仓库标题
> .flex-item-header {
// 仓库名称
> .flex-item-title {
font-size: 20px;
gap: 8px;
// 仓库中间的间隔线
&:not(a) {
color: ${themeVars.color.primary.self};
}
}
// 仓库语言, 星标
> .flex-item-trailing {
color: ${themeVars.color.text.light.num1};
gap: 16px;
font-size: 12px;
> .flex-text-inline .color-icon {
width: 12px;
height: 12px;
margin-right: 0 !important;
}
}
}
// 描述和更新时间
> .flex-item-body {
margin-top: 10px;
// 更新时间
&:last-child {
font-size: 12px;
}
}
// 主题标签
> .label-list {
margin-top: 10px;
}
}
}
}
}
}
`;

36
styles/public/attached.ts Normal file
View File

@@ -0,0 +1,36 @@
import { css, otherThemeVars, themeVars } from "src/types/vars";
export const attached = css`
// 设置右面板的内容
.user-main-content,
.repo-setting-content,
.user-setting-content,
.org-setting-content,
.admin-setting-content,
// 新建页面内容
.page-content.repository.new-repo,
.page-content.repository.new.migrate,
.page-content.repository.new.fork,
.page-content.organization.new.org {
.ui.top.attached.header {
border: 0;
font-size: 20px;
font-weight: 400;
background-color: unset !important;
margin-bottom: 0.25rem;
}
.ui.attached.segment {
background-color: unset;
border-radius: ${otherThemeVars.border.radius} !important;
}
.ui.attached.segment:not(.error) {
border: 1px solid ${themeVars.color.light.border} !important;
}
.ui.attached.segment.error {
border: 1px solid ${themeVars.color.error.border} !important;
}
}
`;

View File

@@ -91,9 +91,17 @@ export const redButton = css`
// 修复按钮高度 // 修复按钮高度
export const fixButtonHeight = css` export const fixButtonHeight = css`
// 修复一些主色调或者其他小按钮的高度避免过高
.ui.small.buttons .button, .ui.small.buttons .button,
.ui.ui.ui.ui.small.button { .ui.ui.ui.ui.small.button {
min-height: 26px; min-height: 26px;
height: 32px;
}
// 修复因上面小按钮高度导致仓库星标克隆等按钮高度过高
.ui.labeled.button > .label,
.ui.ui.ui.ui.small.button.compact {
height: 28px;
min-height: 28px;
} }
.ui.tiny.buttons .button, .ui.tiny.buttons .button,
.ui.ui.ui.ui.tiny.button { .ui.ui.ui.ui.tiny.button {

View File

@@ -16,19 +16,18 @@ export const dropdown = css`
> .item:not(.tw-hidden) { > .item:not(.tw-hidden) {
display: flex !important; display: flex !important;
align-items: center; align-items: center;
gap: 0.5rem; padding: 6px 8px !important;
padding: 8px 10px !important;
border-radius: ${otherThemeVars.border.radius} !important; border-radius: ${otherThemeVars.border.radius} !important;
&:not(.emoji) { &:not(.emoji) {
margin: 0 0.5rem; margin: 0 8px;
} }
&:not(.emoji):first-of-type { &:not(.emoji):first-of-type {
margin-top: 0.5rem; margin-top: 8px;
} }
// 不知道为什么提交差异对比页面操作中的 cherrypick 按钮无法被选中 // 不知道为什么提交差异对比页面操作中的 cherrypick 按钮无法被选中
&.cherry-pick-button, &.cherry-pick-button,
&:not(.emoji):last-of-type { &:not(.emoji):last-of-type {
margin-bottom: 0.5rem; margin-bottom: 8px;
} }
&:hover { &:hover {
background-color: ${themeVars.github.control.transparent.bgColor.hover} !important; background-color: ${themeVars.github.control.transparent.bgColor.hover} !important;
@@ -46,9 +45,17 @@ export const dropdown = css`
${activeItemAfterStyle}; ${activeItemAfterStyle};
} }
} }
svg {
margin-top: 2px;
margin-right: 8px;
}
// 复选框对齐
.ui.checkbox input[type="checkbox"] {
height: 100%;
}
} }
> .divider { > .divider {
margin: 0.5rem 0; margin: 8px 0;
} }
&:after { &:after {
display: none !important; display: none !important;
@@ -59,7 +66,7 @@ export const dropdown = css`
.ui.dropdown:not(.upward), .ui.dropdown:not(.upward),
.ui.menu .ui.dropdown:not(.upward) { .ui.menu .ui.dropdown:not(.upward) {
.menu { .menu {
margin-top: 0.35em !important; margin-top: 4px !important;
} }
} }
// 向上弹出的下拉菜单向上偏移 // 向上弹出的下拉菜单向上偏移
@@ -67,7 +74,7 @@ export const dropdown = css`
.ui.menu .ui.dropdown.upward { .ui.menu .ui.dropdown.upward {
.menu { .menu {
animation: ${animationUp}; animation: ${animationUp};
margin-bottom: 0.35em !important; margin-bottom: 4px !important;
} }
} }
// 修复下拉菜单元素溢出问题 // 修复下拉菜单元素溢出问题
@@ -120,6 +127,10 @@ export const selectionDropdown = css`
${activeItemAfterStyle}; ${activeItemAfterStyle};
} }
} }
// 修复顶部导航栏工单管理/请求合并页面搜索框旁的选择下拉框按钮内容过窄
.list-header-search .ui.action.input > .dropdown.small {
padding: 8px 40px 8px 16px;
}
// 发布版本页面的分支按钮, 覆盖 Gitea 的样式, 避免按钮元素高度不一致 // 发布版本页面的分支按钮, 覆盖 Gitea 的样式, 避免按钮元素高度不一致
.repository.new.release .target .selection.dropdown { .repository.new.release .target .selection.dropdown {
padding-top: 8px; padding-top: 8px;

View File

@@ -5,7 +5,6 @@ import "./radius"; // 圆角, 此样式为基础样式, 确保在其他样式之
import "./transition"; // 过渡效果 import "./transition"; // 过渡效果
import "./text"; // 文本或 SVG 的基本颜色 import "./text"; // 文本或 SVG 的基本颜色
import "./button"; // 按钮 import "./button"; // 按钮
import "./chroma"; // 代码高亮
import "./dropdown"; // 下拉框 import "./dropdown"; // 下拉框
import "./input"; // 输入框 import "./input"; // 输入框
import "./label"; // 标签 import "./label"; // 标签
@@ -13,3 +12,5 @@ import "./menu"; // 菜单
import "./modal"; // 弹窗 import "./modal"; // 弹窗
import "./tippy"; // 提示框 import "./tippy"; // 提示框
import "./navbar"; // 导航栏 import "./navbar"; // 导航栏
import "./attached"; // 附加样式
import "./other"; // 其他样式

View File

@@ -67,6 +67,12 @@ export const label = css`
} }
} }
} }
.ui.small.label {
font-size: 12px;
}
.ui.mini.label {
font-size: 10px;
}
`; `;
// 提交中的 SHA 标签 // 提交中的 SHA 标签
@@ -166,12 +172,19 @@ export const taskStatusLabel = css`
// 仓库标签 (私有/公开/内部) // 仓库标签 (私有/公开/内部)
export const repoLabel = css` export const repoLabel = css`
span, span,
// 用户切换面板的标签
.org-visibility div { .org-visibility div {
&.ui.basic.label { &.ui.basic.label {
background-color: unset; background-color: unset;
color: ${themeVars.color.text.light.num1}; color: ${themeVars.color.text.light.num1};
font-size: 12px;
font-weight: 500;
padding: 3px 6px;
} }
} }
.org-visibility span.ui.basic.label {
font-size: 14px;
}
`; `;
// 软件包列表 // 软件包列表

View File

@@ -193,3 +193,46 @@ export const secondaryMenu = css`
} }
} }
`; `;
// 分页菜单
export const paginationMenu = css`
.ui.borderless.pagination.menu {
align-items: center;
background-color: unset;
border: 0;
gap: 4px;
.item {
border-radius: ${otherThemeVars.border.radius};
min-width: 32px;
min-height: 32px;
height: 32px;
justify-content: center;
// 避免一些 hover 效果调整内容
padding: 5px 10px !important;
&.active {
background: ${themeVars.github.bgColor.accent.emphasis};
color: ${themeVars.color.white};
}
// 设置透明边框线避免 hover 时元素大小变化
&:not(.active) {
border: 1px solid #ffffff00;
&:hover {
background: unset;
border-color: ${themeVars.color.secondary.self};
}
}
&.navigation {
&:not(.disabled) {
span,
svg {
color: ${themeVars.color.primary.self};
}
}
// 对齐文字
svg {
margin-top: 2px;
}
}
}
}
`;

View File

@@ -1,4 +1,5 @@
import { css, otherThemeVars, themeVars } from "src/types/vars"; import { fallbackVar } from "src/functions";
import { css, customThemeVars, otherThemeVars, themeVars } from "src/types/vars";
export const navbarRight = css` export const navbarRight = css`
#navbar { #navbar {
@@ -35,7 +36,7 @@ export const navbarRight = css`
grid-auto-flow: column; grid-auto-flow: column;
align-items: center; align-items: center;
> svg { > svg {
margin-right: 8px; margin-right: 4px;
} }
// 三角号纠正高度保持居中 // 三角号纠正高度保持居中
.not-mobile { .not-mobile {
@@ -77,14 +78,45 @@ export const navbarRight = css`
left: 22px; left: 22px;
} }
} }
// 通知和计时器的圆点
a.item {
.notification_count,
.header-stopwatch-dot {
background-color: ${themeVars.github.bgColor.accent.emphasis};
border-radius: 25px;
color: ${themeVars.color.white};
font-size: 8px;
font-weight: 600;
top: -14px;
left: 12px;
}
}
}
// 用户菜单
.navbar-right .user-menu {
width: ${fallbackVar(customThemeVars.userMenuWidth, "192px")};
max-width: 320px;
> .header {
font-size: 14px;
font-weight: 400;
margin: 0;
padding: 16px 16px 8px 16px;
strong {
font-weight: 600;
}
}
> .divider {
margin: 8px;
width: calc(100% - 16px);
}
} }
} }
// 手机下的创建菜单按钮 // 手机下的创建菜单按钮
@media (max-width: 767.98px) { @media (max-width: 767.98px) {
#navbar .navbar-right > .item:not(:last-child) { #navbar .navbar-right:has(.user-menu) > .item:not(:last-child) {
display: none; display: none;
} }
#navbar.navbar-menu-open .navbar-right > .item:not(:last-child) { #navbar.navbar-menu-open .navbar-right:has(.user-menu) > .item:not(:last-child) {
display: grid; display: grid;
} }
} }

9
styles/public/other.ts Normal file
View File

@@ -0,0 +1,9 @@
import { css } from "src/types/vars";
// 一些列表头, 比如工单的搜索标签里程碑栏
export const listHeader = css`
.list-header {
align-items: center;
align-content: center;
}
`;

View File

@@ -2,6 +2,18 @@ import { css } from "src/types/vars";
// 简单的渐变过渡 // 简单的渐变过渡
export const transition = css` export const transition = css`
// 差异对比的代码折叠按钮
.code-expander-button,
// 仓库 README 头部的按钮
.file-header-left,
.file-header-right,
// 仪表板仓库列表
.ui.attached.segment.table ul li,
// Issue 列表
.issue-list-toolbar .item,
.flex-list#issue-list > .flex-item,
// 分页菜单
.ui.borderless.pagination.menu .item,
// 迁移的元素 // 迁移的元素
#navbar .item, #navbar .item,
.header-wrapper .ui.tabular.menu .item, .header-wrapper .ui.tabular.menu .item,
@@ -9,8 +21,6 @@ export const transition = css`
.job-step-logs, .job-step-logs,
.job-brief-item, .job-brief-item,
.repo-file-cell, .repo-file-cell,
// 差异对比的代码折叠按钮
.code-expander-button,
.tippy-box .flex-items-block .item, .tippy-box .flex-items-block .item,
.clone-panel-tab .item, .clone-panel-tab .item,
.ui.form select, .ui.form select,

View File

@@ -0,0 +1,74 @@
import { defineTheme, type Chroma, type ThemeColor } from "src";
import { github2ThemeColor, type GithubColor } from "src/core/github";
import { prettylights2Chroma, type prettylightsColor } from "src/core/prettylights";
import { darkGithubColors } from "themes/dark";
export const colorblindDarkGithubColors: GithubColor = {
isDarkTheme: true,
display: darkGithubColors.display,
diffBlob: {
addtionNum: { bgColor: "#58a6ff4d" },
addtionWord: { bgColor: "#388bfd66" },
deletionNum: { bgColor: "#db6d284d" },
deletionWord: { bgColor: "#db6d2866" },
hunkNum: { bgColor: { rest: "#2f3742" } },
},
fgColor: {
...darkGithubColors.fgColor,
danger: "#f0883e",
success: "#58a6ff",
},
bgColor: {
...darkGithubColors.bgColor,
danger: { muted: "#db6d281a" },
success: { emphasis: "#1f6feb", muted: "#388bfd33" },
},
borderColor: {
...darkGithubColors.borderColor,
success: { emphasis: "#1f6feb" },
},
button: {
primary: { fgColor: { rest: "#ffffff" }, bgColor: { hover: "#2a7aef" } },
danger: { fgColor: { rest: "#f0883e", hover: "#ffffff" }, bgColor: { hover: "#9b4215" } },
},
control: darkGithubColors.control,
shadow: darkGithubColors.shadow,
overlay: darkGithubColors.overlay,
underlineNav: darkGithubColors.underlineNav,
contribution: darkGithubColors.contribution,
};
export const colorblindDarkPrettylights: prettylightsColor = {
syntax: {
brackethighlighter: { angle: "#9198a1", unmatched: "#db6d28" },
carriage: { return: { bg: "#9b4215", text: "#f0f6fc" } },
comment: "#9198a1",
constant: "#79c0ff",
constantOtherReferenceLink: "#a5d6ff",
entity: "#d2a8ff",
entityTag: "#a5d6ff",
invalid: { illegal: { bg: "#762d0a", text: "#f0f6fc" } },
keyword: "#f0883e",
markup: {
bold: "#f0f6fc",
changed: { bg: "#5a1e02", text: "#ffdfb6" },
deleted: { bg: "#5a1e02", text: "#ffdfb6" },
heading: "#1f6feb",
ignored: { bg: "#1158c7", text: "#f0f6fc" },
inserted: { bg: "#0c2d6b", text: "#cae8ff" },
italic: "#f0f6fc",
list: "#f2cc60",
},
metaDiffRange: "#d2a8ff",
storageModifierImport: "#f0f6fc",
string: "#a5d6ff",
stringRegexp: "#a5d6ff",
sublimelinterGutterMark: "#3d444d",
variable: "#ffa657",
},
};
export const colorblindDarkColors: ThemeColor = github2ThemeColor(colorblindDarkGithubColors);
export const colorblindDarkChroma: Chroma = prettylights2Chroma(colorblindDarkPrettylights);
export default defineTheme(colorblindDarkColors, colorblindDarkChroma);

View File

@@ -0,0 +1,74 @@
import { defineTheme, type Chroma, type ThemeColor } from "src";
import { github2ThemeColor, type GithubColor } from "src/core/github";
import { prettylights2Chroma, type prettylightsColor } from "src/core/prettylights";
import { lightGithubColors } from "themes/light";
export const colorblindLightGithubColors: GithubColor = {
isDarkTheme: false,
display: lightGithubColors.display,
diffBlob: {
addtionNum: { bgColor: "#b6e3ff" },
addtionWord: { bgColor: "#b6e3ff" },
deletionNum: { bgColor: "#ffd8b5" },
deletionWord: { bgColor: "#ffd8b5" },
hunkNum: { bgColor: { rest: "#e6eaef" } },
},
fgColor: {
...lightGithubColors.fgColor,
danger: "#bc4c00",
success: "#0969da",
},
bgColor: {
...lightGithubColors.bgColor,
danger: { muted: "#fff1e5" },
success: { emphasis: "#0969da", muted: "#ddf4ff" },
},
borderColor: {
...lightGithubColors.borderColor,
success: { emphasis: "#0969da" },
},
button: {
primary: { fgColor: { rest: "#ffffff" }, bgColor: { hover: "#0864d1" } },
danger: { fgColor: { rest: "#bc4c00", hover: "#ffffff" }, bgColor: { hover: "#bc4c00" } },
},
control: lightGithubColors.control,
shadow: lightGithubColors.shadow,
overlay: lightGithubColors.overlay,
underlineNav: lightGithubColors.underlineNav,
contribution: lightGithubColors.contribution,
};
export const colorblindLightPrettylights: prettylightsColor = {
syntax: {
brackethighlighter: { angle: "#59636e", unmatched: "#762c00" },
carriage: { return: { bg: "#bc4c00", text: "#f6f8fa" } },
comment: "#59636e",
constant: "#0550ae",
constantOtherReferenceLink: "#0a3069",
entity: "#6639ba",
entityTag: "#0550ae",
invalid: { illegal: { bg: "#762c00", text: "#f6f8fa" } },
keyword: "#bc4c00",
markup: {
bold: "#1f2328",
changed: { bg: "#ffd8b5", text: "#953800" },
deleted: { bg: "#fff1e5", text: "#762c00" },
heading: "#0550ae",
ignored: { bg: "#0550ae", text: "#d1d9e0" },
inserted: { bg: "#ddf4ff", text: "#0550ae" },
italic: "#1f2328",
list: "#3b2300",
},
metaDiffRange: "#8250df",
storageModifierImport: "#1f2328",
string: "#0a3069",
stringRegexp: "#0550ae",
sublimelinterGutterMark: "#818b98",
variable: "#953800",
},
};
export const colorblindLightColors: ThemeColor = github2ThemeColor(colorblindLightGithubColors);
export const colorblindLightChroma: Chroma = prettylights2Chroma(colorblindLightPrettylights);
export default defineTheme(colorblindLightColors, colorblindLightChroma);

View File

@@ -1,6 +1,7 @@
import { defineGithubTheme } from "src/core/github"; import { defineTheme, type ThemeColor } from "src";
import { github2ThemeColor, type GithubColor } from "src/core/github";
export default defineGithubTheme({ export const darkGithubColors: GithubColor = {
isDarkTheme: true, isDarkTheme: true,
display: { display: {
brown: { fgColor: "#b69a6d" }, brown: { fgColor: "#b69a6d" },
@@ -22,7 +23,7 @@ export default defineGithubTheme({
attention: "#d29922", attention: "#d29922",
danger: "#f85149", danger: "#f85149",
default: "#f0f6fc", default: "#f0f6fc",
disabled: "#656c7699", disabled: "#656c76",
done: "#ab7df8", done: "#ab7df8",
muted: "#9198a1", muted: "#9198a1",
neutral: "#9198a1", neutral: "#9198a1",
@@ -35,20 +36,20 @@ export default defineGithubTheme({
bgColor: { bgColor: {
accent: { emphasis: "#1f6feb", muted: "#388bfd1a" }, accent: { emphasis: "#1f6feb", muted: "#388bfd1a" },
attention: { muted: "#bb800926" }, attention: { muted: "#bb800926" },
success: { emphasis: "#238636", muted: "#2ea04326" },
danger: { muted: "#f851491a" }, danger: { muted: "#f851491a" },
done: { emphasis: "#8957e5" },
default: "#0d1117", default: "#0d1117",
inset: "#010409", done: { emphasis: "#8957e5" },
muted: "#151b23", muted: "#151b23",
neutral: { muted: "#656c7633" }, neutral: { muted: "#656c7633" },
success: { emphasis: "#238636", muted: "#2ea04326" },
inset: "#010409",
}, },
borderColor: { borderColor: {
accent: { emphasis: "#1f6feb" }, accent: { emphasis: "#1f6feb" },
default: "#3d444d",
attention: { emphasis: "#9e6a03" }, attention: { emphasis: "#9e6a03" },
success: { emphasis: "#238636" }, default: "#3d444d",
done: { emphasis: "#8957e5" }, done: { emphasis: "#8957e5" },
success: { emphasis: "#238636" },
muted: "#3d444db3", muted: "#3d444db3",
translucent: "#ffffff26", translucent: "#ffffff26",
}, },
@@ -69,4 +70,8 @@ export default defineGithubTheme({
borderColor: { num0: "#0104090d" }, borderColor: { num0: "#0104090d" },
}, },
}, },
}); };
export const darkColors: ThemeColor = github2ThemeColor(darkGithubColors);
export default defineTheme(darkColors);

View File

@@ -1,6 +1,7 @@
import { defineGithubTheme } from "src/core/github"; import { defineTheme, type ThemeColor } from "src";
import { github2ThemeColor, type GithubColor } from "src/core/github";
export default defineGithubTheme({ export const lightGithubColors: GithubColor = {
isDarkTheme: false, isDarkTheme: false,
display: { display: {
brown: { fgColor: "#755f43" }, brown: { fgColor: "#755f43" },
@@ -35,20 +36,20 @@ export default defineGithubTheme({
bgColor: { bgColor: {
accent: { emphasis: "#0969da", muted: "#ddf4ff" }, accent: { emphasis: "#0969da", muted: "#ddf4ff" },
attention: { muted: "#fff8c5" }, attention: { muted: "#fff8c5" },
success: { emphasis: "#1f883d", muted: "#dafbe1" },
danger: { muted: "#ffebe9" }, danger: { muted: "#ffebe9" },
done: { emphasis: "#8250df" },
default: "#ffffff", default: "#ffffff",
inset: "#f6f8fa", done: { emphasis: "#8250df" },
muted: "#f6f8fa", muted: "#f6f8fa",
neutral: { muted: "#818b981f" }, neutral: { muted: "#818b981f" },
success: { emphasis: "#1f883d", muted: "#dafbe1" },
inset: "#f6f8fa",
}, },
borderColor: { borderColor: {
accent: { emphasis: "#0969da" }, accent: { emphasis: "#0969da" },
default: "#d1d9e0",
attention: { emphasis: "#9a6700" }, attention: { emphasis: "#9a6700" },
success: { emphasis: "#1a7f37" }, default: "#d1d9e0",
done: { emphasis: "#8250df" }, done: { emphasis: "#8250df" },
success: { emphasis: "#1a7f37" },
muted: "#d1d9e0b3", muted: "#d1d9e0b3",
translucent: "#1f232826", translucent: "#1f232826",
}, },
@@ -69,4 +70,8 @@ export default defineGithubTheme({
borderColor: { num0: "#1f23280d" }, borderColor: { num0: "#1f23280d" },
}, },
}, },
}); };
export const lightColors: ThemeColor = github2ThemeColor(lightGithubColors);
export default defineTheme(lightColors);

View File

@@ -1,129 +1,103 @@
import { defineGithubTheme } from "src/core/github"; import { defineTheme, type Chroma, type ThemeColor } from "src";
import { prettylights2Chroma } from "src/core/prettylights"; import { github2ThemeColor, type GithubColor } from "src/core/github";
import { prettylights2Chroma, type prettylightsColor } from "src/core/prettylights";
import { darkGithubColors } from "themes/dark";
export default defineGithubTheme( export const softDarkGithubColors: GithubColor = {
{ isDarkTheme: true,
isDarkTheme: true, display: darkGithubColors.display,
display: { diffBlob: {
brown: { fgColor: "#b69a6d" }, addtionNum: { bgColor: "#57ab5a4d" },
cyan: { fgColor: "#07ace4" }, addtionWord: { bgColor: "#46954a66" },
indigo: { fgColor: "#9899ec" }, deletionNum: { bgColor: "#e5534b4d" },
lemon: { fgColor: "#ba9b12" }, deletionWord: { bgColor: "#e5534b66" },
olive: { fgColor: "#a2a626" }, hunkNum: { bgColor: { rest: "#143d79" } },
teal: { fgColor: "#1cb0ab" }, },
}, fgColor: {
diffBlob: { accent: "#478be6",
addtionNum: { bgColor: "#57ab5a4d" }, attention: "#c69026",
addtionWord: { bgColor: "#46954a66" }, danger: "#e5534b",
deletionNum: { bgColor: "#e5534b4d" }, default: "#d1d7e0",
deletionWord: { bgColor: "#e5534b66" }, disabled: "#656c76",
hunkNum: { bgColor: { rest: "#143d79" } }, done: "#986ee2",
}, muted: "#9198a1",
fgColor: { neutral: "#9198a1",
accent: "#478be6", severe: "#cc6b2c",
attention: "#c69026", sponsors: "#c96198",
danger: "#e5534b", success: "#57ab5a",
default: "#d1d7e0", black: "#010409",
disabled: "#656c76", white: "#cdd9e5",
done: "#986ee2", },
muted: "#9198a1", bgColor: {
neutral: "#9198a1", accent: { emphasis: "#316dca", muted: "#4184e41a" },
severe: "#cc6b2c", attention: { muted: "#ae7c1426" },
sponsors: "#c96198", danger: { muted: "#e5534b1a" },
success: "#57ab5a", default: "#212830",
black: "#010409", done: { emphasis: "#8256d0" },
white: "#cdd9e5", muted: "#262c36",
}, neutral: { muted: "#656c7633" },
bgColor: { success: { emphasis: "#347d39", muted: "#46954a26" },
accent: { emphasis: "#316dca", muted: "#4184e41a" }, inset: "#151b23",
attention: { muted: "#ae7c1426" }, },
success: { emphasis: "#347d39", muted: "#46954a26" }, borderColor: {
danger: { muted: "#e5534b1a" }, accent: { emphasis: "#316dca" },
done: { emphasis: "#8256d0" }, attention: { emphasis: "#966600" },
default: "#212830", default: "#3d444d",
inset: "#151b23", done: { emphasis: "#8256d0" },
muted: "#262c36", success: { emphasis: "#347d39" },
neutral: { muted: "#656c7633" }, muted: "#3d444db3",
}, translucent: "#cdd9e526",
borderColor: { },
accent: { emphasis: "#316dca" }, button: {
default: "#3d444d", primary: { fgColor: { rest: "#ffffff" }, bgColor: { hover: "#3b8640" } },
attention: { emphasis: "#966600" }, danger: { fgColor: { rest: "#ea5c53", hover: "#ffffff" }, bgColor: { hover: "#ad2e2c" } },
success: { emphasis: "#347d39" }, },
done: { emphasis: "#8256d0" }, control: {
muted: "#3d444db3", bgColor: { active: "#3d444d", hover: "#2f3742", rest: "#2a313c" },
translucent: "#cdd9e526", transparent: { bgColor: { active: "#656c7633", hover: "#656c7626", selected: "#656c761a" } },
}, },
button: { shadow: { floating: { small: "#01040966" } },
primary: { fgColor: { rest: "#ffffff" }, bgColor: { hover: "#3b8640" } }, overlay: { backdrop: { bgColor: "#262c3666" } },
danger: { fgColor: { rest: "#ea5c53", hover: "#ffffff" }, bgColor: { hover: "#ad2e2c" } }, underlineNav: { borderColor: { active: "#ec775c" } },
}, contribution: {
control: { default: {
bgColor: { active: "#3d444d", hover: "#2f3742", rest: "#2a313c" }, bgColor: { num0: "#2a313c", num1: "#1b4721", num2: "#2b6a30", num3: "#46954a", num4: "#6bc46d" },
transparent: { bgColor: { active: "#656c7633", hover: "#656c7626", selected: "#656c761a" } }, borderColor: { num0: "#0104090d" },
},
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: { export const softDarkPrettylights: prettylightsColor = {
angle: "#9198a1", syntax: {
unmatched: "#e5534b", brackethighlighter: { angle: "#9198a1", unmatched: "#e5534b" },
}, carriage: { return: { bg: "#ad2e2c", text: "#f0f6fc" } },
carriage: { comment: "#9198a1",
return: { constant: "#6cb6ff",
bg: "#ad2e2c", constantOtherReferenceLink: "#96d0ff",
text: "#f0f6fc", entity: "#dcbdfb",
}, entityTag: "#8ddb8c",
}, invalid: { illegal: { bg: "#922323", text: "#f0f6fc" } },
comment: "#9198a1", keyword: "#f47067",
constant: "#6cb6ff", markup: {
constantOtherReferenceLink: "#96d0ff", bold: "#f0f6fc",
entity: "#dcbdfb", changed: { bg: "#682d0f", text: "#ffddb0" },
entityTag: "#8ddb8c", deleted: { bg: "#78191b", text: "#ffd8d3" },
invalid: { heading: "#316dca",
illegal: { ignored: { bg: "#255ab2", text: "#f0f6fc" },
bg: "#922323", inserted: { bg: "#1b4721", text: "#b4f1b4" },
text: "#f0f6fc", italic: "#f0f6fc",
}, list: "#eac55f",
},
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",
}, },
}) metaDiffRange: "#dcbdfb",
); storageModifierImport: "#f0f6fc",
string: "#96d0ff",
stringRegexp: "#8ddb8c",
sublimelinterGutterMark: "#3d444d",
variable: "#f69d50",
},
};
export const softDarkColors: ThemeColor = github2ThemeColor(softDarkGithubColors);
export const softDarkChroma: Chroma = prettylights2Chroma(softDarkPrettylights);
export default defineTheme(softDarkColors, softDarkChroma);

View File

@@ -0,0 +1,45 @@
import { defineTheme, type Chroma, type ThemeColor } from "src";
import { darkPrettylights } from "src/core/chroma";
import { github2ThemeColor, type GithubColor } from "src/core/github";
import { prettylights2Chroma, type prettylightsColor } from "src/core/prettylights";
import { colorblindDarkGithubColors, colorblindDarkPrettylights } from "themes/colorblind-dark";
import { darkGithubColors } from "themes/dark";
export const tritanopiaDarkGithubColors: GithubColor = {
...colorblindDarkGithubColors,
diffBlob: {
...colorblindDarkGithubColors.diffBlob,
deletionNum: darkGithubColors.diffBlob.deletionNum,
deletionWord: darkGithubColors.diffBlob.deletionWord,
},
fgColor: {
...colorblindDarkGithubColors.fgColor,
danger: darkGithubColors.fgColor.danger,
},
bgColor: {
...colorblindDarkGithubColors.bgColor,
danger: darkGithubColors.bgColor.danger,
},
button: {
...colorblindDarkGithubColors.button,
danger: darkGithubColors.button.danger,
},
};
export const tritanopiaDarkPrettylights: prettylightsColor = {
syntax: {
...darkPrettylights.syntax,
markup: {
...darkPrettylights.syntax.markup,
changed: { bg: "#67060c", text: "#ffdcd7" },
inserted: colorblindDarkPrettylights.syntax.markup.inserted,
},
stringRegexp: colorblindDarkPrettylights.syntax.stringRegexp,
variable: "#ffa198",
},
};
export const tritanopiaDarkColors: ThemeColor = github2ThemeColor(tritanopiaDarkGithubColors);
export const tritanopiaDarkChroma: Chroma = prettylights2Chroma(tritanopiaDarkPrettylights);
export default defineTheme(tritanopiaDarkColors, tritanopiaDarkChroma);

View File

@@ -0,0 +1,45 @@
import { defineTheme, type Chroma, type ThemeColor } from "src";
import { lightPrettylights } from "src/core/chroma";
import { github2ThemeColor, type GithubColor } from "src/core/github";
import { prettylights2Chroma, type prettylightsColor } from "src/core/prettylights";
import { colorblindLightGithubColors, colorblindLightPrettylights } from "themes/colorblind-light";
import { lightGithubColors } from "themes/light";
export const tritanopiaLightGithubColors: GithubColor = {
...colorblindLightGithubColors,
diffBlob: {
...colorblindLightGithubColors.diffBlob,
deletionNum: lightGithubColors.diffBlob.deletionNum,
deletionWord: lightGithubColors.diffBlob.deletionWord,
},
fgColor: {
...colorblindLightGithubColors.fgColor,
danger: lightGithubColors.fgColor.danger,
},
bgColor: {
...colorblindLightGithubColors.bgColor,
danger: lightGithubColors.bgColor.danger,
},
button: {
...colorblindLightGithubColors.button,
danger: lightGithubColors.button.danger,
},
};
export const tritanopiaLightPrettylights: prettylightsColor = {
syntax: {
...lightPrettylights.syntax,
markup: {
...lightPrettylights.syntax.markup,
changed: { bg: "#ffcecb", text: "#a40e26" },
inserted: colorblindLightPrettylights.syntax.markup.inserted,
},
stringRegexp: colorblindLightPrettylights.syntax.stringRegexp,
variable: "#a40e26",
},
};
export const tritanopiaLightColors: ThemeColor = github2ThemeColor(tritanopiaLightGithubColors);
export const tritanopiaLightChroma: Chroma = prettylights2Chroma(tritanopiaLightPrettylights);
export default defineTheme(tritanopiaLightColors, tritanopiaLightChroma);