mirror of
https://github.com/lutinglt/gitea-github-theme.git
synced 2025-10-26 21:20:31 +00:00
Compare commits
5 Commits
v1.22.6-20
...
v1.22.6-20
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
73052da7f2 | ||
|
|
5a203804be | ||
|
|
3489fc94c2 | ||
|
|
e9d2b62b0e | ||
|
|
f357ee4181 |
4
.github/release.md
vendored
4
.github/release.md
vendored
@@ -1,3 +1 @@
|
|||||||
提交查看页面增加了提交之间的间隔
|
集成字体
|
||||||
隐藏仓库文件列表头部最后一次提交的 SHA
|
|
||||||
其他一些细节优化
|
|
||||||
2
.github/workflows/release.yml
vendored
2
.github/workflows/release.yml
vendored
@@ -30,6 +30,6 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
export TZ=Asia/Shanghai
|
export TZ=Asia/Shanghai
|
||||||
TAG="v${{ inputs.gitea_version }}-$(date +%Y%m%d-%H%M)"
|
TAG="v${{ inputs.gitea_version }}-$(date +%Y%m%d-%H%M)"
|
||||||
gh release create "$TAG" dist/theme-github.css --notes-file .github/release.md -t $TAG
|
gh release create "$TAG" dist/theme-github.css --notes-file .github/release.md --draft -t $TAG
|
||||||
env:
|
env:
|
||||||
GH_TOKEN: ${{ github.token }}
|
GH_TOKEN: ${{ github.token }}
|
||||||
|
|||||||
27
README.md
27
README.md
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
字体说明:
|
字体说明:
|
||||||
|
|
||||||
- UI 默认字体 [Maple Hand](https://github.com/subframe7536/maple-font/tree/other-resources/cn-resource/maple-hand) & [VictorMono Nerd Font](https://github.com/ryanoasis/nerd-fonts/releases/download/v3.3.0/VictorMono.zip) & [汉仪正圆](https://www.hanyi.com.cn/productdetail.php?id=2913) (优先匹配左侧, 需要系统包含相应字体)
|
- UI 默认字体 [Maple Hand](https://github.com/subframe7536/maple-font/tree/other-resources/cn-resource/maple-hand) & [VictorMono Nerd Font](https://github.com/ryanoasis/nerd-fonts/releases/download/v3.3.0/VictorMono.zip)
|
||||||
- Actions 日志默认字体 VictorMono 优先
|
- Actions 日志默认字体 VictorMono 优先
|
||||||
|
|
||||||
> Victor Mono 相比其他等宽字体更为紧凑, 可以减少换行
|
> Victor Mono 相比其他等宽字体更为紧凑, 可以减少换行
|
||||||
@@ -24,6 +24,31 @@ THEMES = gitea-dark, github
|
|||||||
|
|
||||||
详细请查看 Gitea 文档 [Gitea docs](https://docs.gitea.com/next/administration/customizing-gitea#customizing-the-look-of-gitea)
|
详细请查看 Gitea 文档 [Gitea docs](https://docs.gitea.com/next/administration/customizing-gitea#customizing-the-look-of-gitea)
|
||||||
|
|
||||||
|
### 集成字体
|
||||||
|
|
||||||
|
如果不想手动在系统安装字体, 可以将字体放入 Gitea 中, 在访问时拉取字体文件
|
||||||
|
|
||||||
|
>[!CAUTION]
|
||||||
|
>
|
||||||
|
> 不推荐此行为, 字体文件较大, 且一些字体粗细样式可能会有缺失
|
||||||
|
>
|
||||||
|
> 页面会在加载完字体后切换字体
|
||||||
|
|
||||||
|
下载字体文件, 放入 `gitea/public/assets/fonts` 目录下, 包含以下6个文件:
|
||||||
|
|
||||||
|
- `MapleHand-Regular.ttf`
|
||||||
|
- `MapleHand-Bold.ttf`
|
||||||
|
- `VictorMonoNerdFont-Regular.ttf`
|
||||||
|
- `VictorMonoNerdFont-Bold.ttf`
|
||||||
|
- `VictorMonoNerdFont-Italic.ttf`
|
||||||
|
- `VictorMonoNerdFont-BoldItalic.ttf`
|
||||||
|
|
||||||
|
清除浏览器缓存, 强制刷新浏览器查看效果
|
||||||
|
|
||||||
|
文件位置如下:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
## 截图
|
## 截图
|
||||||
|
|
||||||

|

|
||||||
|
|||||||
BIN
screenshots/themetree.png
Normal file
BIN
screenshots/themetree.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 52 KiB |
@@ -109,7 +109,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 关闭工单按钮 */
|
// 关闭工单按钮
|
||||||
.ui.red.basic.button#status-button {
|
.ui.red.basic.button#status-button {
|
||||||
color: #ab7df8;
|
color: #ab7df8;
|
||||||
border-color: var(--color-light-border);
|
border-color: var(--color-light-border);
|
||||||
@@ -121,7 +121,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 重新开启按钮 */
|
// 重新开启按钮
|
||||||
.ui.basic.primary.button#status-button {
|
.ui.basic.primary.button#status-button {
|
||||||
color: #39d353;
|
color: #39d353;
|
||||||
background-color: var(--color-button);
|
background-color: var(--color-button);
|
||||||
|
|||||||
@@ -1,4 +1,25 @@
|
|||||||
// Made by Luting ^-^
|
// Made by Luting ^-^
|
||||||
|
// 下拉菜单动画
|
||||||
|
@keyframes overlay-appear {
|
||||||
|
0% {
|
||||||
|
opacity: 0;
|
||||||
|
transform: translateY(-5%);
|
||||||
|
}
|
||||||
|
|
||||||
|
100% {
|
||||||
|
opacity: 1;
|
||||||
|
transform: translateY(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.ui.dropdown .menu {
|
||||||
|
margin-top: 3.75px !important;
|
||||||
|
border-radius: 12px !important;
|
||||||
|
overflow: hidden auto;
|
||||||
|
box-shadow: #30363d 0px 0px 0px 0.5px;
|
||||||
|
animation: 200ms cubic-bezier(0.33, 1, 0.68, 1) 0s 1 normal none running overlay-appear;
|
||||||
|
}
|
||||||
|
|
||||||
.ui.dropdown .menu,
|
.ui.dropdown .menu,
|
||||||
.branch-tag-item.active,
|
.branch-tag-item.active,
|
||||||
.ui.pointing.dropdown > .menu:not(.hidden):after {
|
.ui.pointing.dropdown > .menu:not(.hidden):after {
|
||||||
@@ -29,3 +50,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 按钮菜单选项(主要为仓库)
|
||||||
|
.ui.button.dropdown .menu .item {
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
margin: 0 6px;
|
||||||
|
|
||||||
|
&:first-of-type {
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
margin-top: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:last-of-type {
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
margin-bottom: 6px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
48
src/fontface.scss
Normal file
48
src/fontface.scss
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
@font-face {
|
||||||
|
font-family: 'Maple Hand';
|
||||||
|
src: local('Maple Hand'),
|
||||||
|
url('/assets/fonts/MapleHand-Regular.ttf') format('truetype');
|
||||||
|
font-display: swap;
|
||||||
|
font-weight: normal;
|
||||||
|
font-style: normal;
|
||||||
|
}
|
||||||
|
@font-face {
|
||||||
|
font-family: 'Maple Hand';
|
||||||
|
src: local('Maple Hand'),
|
||||||
|
url('/assets/fonts/MapleHand-Bold.ttf') format('truetype');
|
||||||
|
font-display: swap;
|
||||||
|
font-weight: bold;
|
||||||
|
font-style: normal;
|
||||||
|
}
|
||||||
|
@font-face {
|
||||||
|
font-family: 'VictorMono NF';
|
||||||
|
src: local('VictorMono NF'),
|
||||||
|
url('/assets/fonts/VictorMonoNerdFont-Regular.ttf') format('truetype');
|
||||||
|
font-display: swap;
|
||||||
|
font-weight: normal;
|
||||||
|
font-style: normal;
|
||||||
|
}
|
||||||
|
@font-face {
|
||||||
|
font-family: 'VictorMono NF';
|
||||||
|
src: local('VictorMono NF'),
|
||||||
|
url('/assets/fonts/VictorMonoNerdFont-Italic.ttf') format('truetype');
|
||||||
|
font-display: swap;
|
||||||
|
font-weight: normal;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
@font-face {
|
||||||
|
font-family: 'VictorMono NF';
|
||||||
|
src: local('VictorMono NF'),
|
||||||
|
url('/assets/fonts/VictorMonoNerdFont-Bold.ttf') format('truetype');
|
||||||
|
font-display: swap;
|
||||||
|
font-weight: bold;
|
||||||
|
font-style: normal;
|
||||||
|
}
|
||||||
|
@font-face {
|
||||||
|
font-family: 'VictorMono NF';
|
||||||
|
src: local('VictorMono NF'),
|
||||||
|
url('/assets/fonts/VictorMonoNerdFont-BoldItalic.ttf') format('truetype');
|
||||||
|
font-display: swap;
|
||||||
|
font-weight: bold;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
@@ -17,10 +17,9 @@ textarea,
|
|||||||
.ui.form input[type='time'],
|
.ui.form input[type='time'],
|
||||||
.ui.form input[type='url'],
|
.ui.form input[type='url'],
|
||||||
.ui.selection.dropdown {
|
.ui.selection.dropdown {
|
||||||
&:focus {
|
&:focus,
|
||||||
border-color: #1f6feb;
|
|
||||||
}
|
|
||||||
&:focus-visible {
|
&:focus-visible {
|
||||||
|
border-radius: var(--border-radius);
|
||||||
border-color: #1f6feb;
|
border-color: #1f6feb;
|
||||||
outline: none;
|
outline: none;
|
||||||
box-shadow: inset 0 0 0 1px #1f6feb;
|
box-shadow: inset 0 0 0 1px #1f6feb;
|
||||||
|
|||||||
@@ -111,6 +111,32 @@ a.ui.ui.ui {
|
|||||||
border-radius: 25px;
|
border-radius: 25px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.task-status-success {
|
||||||
|
color: var(--color-success-text);
|
||||||
|
border: 1px solid var(--color-success-border);
|
||||||
|
background: var(--color-success-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.task-status-failure {
|
||||||
|
color: var(--color-error-text);
|
||||||
|
border: 1px solid var(--color-error-border);
|
||||||
|
background: var(--color-error-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.task-status-running,
|
||||||
|
&.task-status-skipped {
|
||||||
|
color: var(--color-info-text);
|
||||||
|
border: 1px solid var(--color-info-border);
|
||||||
|
background: var(--color-info-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.task-status-cancelled,
|
||||||
|
&.task-status-blocked {
|
||||||
|
color: var(--color-warning-text);
|
||||||
|
border: 1px solid var(--color-warning-border);
|
||||||
|
background: var(--color-warning-bg);
|
||||||
|
}
|
||||||
|
|
||||||
> a {
|
> a {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
}
|
}
|
||||||
@@ -138,11 +164,21 @@ a.ui.label:not(.basic, .sha):hover {
|
|||||||
#rev-list,
|
#rev-list,
|
||||||
.timeline-item.commits-list .singular-commit {
|
.timeline-item.commits-list .singular-commit {
|
||||||
.sha.label {
|
.sha.label {
|
||||||
.detail.icon,
|
.detail.icon {
|
||||||
&.isSigned.isVerified .detail.icon {
|
border: 0;
|
||||||
|
background: unset;
|
||||||
|
}
|
||||||
|
&.isSigned {
|
||||||
|
&.isWarning,
|
||||||
|
&.isVerified,
|
||||||
|
&.isVerifiedUntrusted,
|
||||||
|
&.isVerifiedUnmatched {
|
||||||
|
.detail.icon {
|
||||||
border: 0;
|
border: 0;
|
||||||
background: unset;
|
background: unset;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
// Made by Luting ^-^
|
// Made by Luting ^-^
|
||||||
|
|
||||||
/* 用户仓库列表字体颜色
|
/* 用户仓库列表字体颜色 */
|
||||||
/* .repo-list-link {
|
/* .repo-list-link {
|
||||||
color: var(--color-blue) !important;
|
color: var(--color-blue) !important;
|
||||||
} */
|
} */
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
// Made by Luting ^-^
|
// Made by Luting ^-^
|
||||||
:root :lang(zh-CN) {
|
:root :lang(zh-CN) {
|
||||||
--fonts-override: 'Maple Hand', 'VictorMono Nerd Font', 'HYZhengYuan';
|
--fonts-override: "Maple Hand", "VictorMono NF", "VictorMono Nerd Font"
|
||||||
}
|
}
|
||||||
|
|
||||||
.job-step-logs {
|
.job-step-logs {
|
||||||
font-family: 'VictorMono Nerd Font', 'Maple Hand', 'HYZhengYuan' !important;
|
font-family: "VictorMono NF", "VictorMono Nerd Font", "Maple Hand" !important;
|
||||||
font-weight: 500;
|
font-weight: 500
|
||||||
}
|
}
|
||||||
|
|
||||||
:root {
|
:root {
|
||||||
|
|||||||
@@ -1,5 +1,17 @@
|
|||||||
// Made by Luting ^-^
|
// Made by Luting ^-^
|
||||||
// 设置左边栏(包含 Actions 的工作流栏)
|
// 设置左边栏(包含 Actions 的工作流栏)
|
||||||
|
|
||||||
|
%active-item-after-style {
|
||||||
|
background: #1f6feb;
|
||||||
|
border-radius: 0.375rem;
|
||||||
|
content: '';
|
||||||
|
height: 1.8rem;
|
||||||
|
left: calc(0.5rem * -1);
|
||||||
|
position: absolute;
|
||||||
|
top: calc(50% - 13px);
|
||||||
|
width: 0.25rem;
|
||||||
|
}
|
||||||
|
|
||||||
.ui.vertical.menu {
|
.ui.vertical.menu {
|
||||||
background: var(--color-body);
|
background: var(--color-body);
|
||||||
border: 0;
|
border: 0;
|
||||||
@@ -30,14 +42,37 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.active.item:after {
|
.active.item:after {
|
||||||
background: #1f6feb;
|
@extend %active-item-after-style;
|
||||||
border-radius: 0.375rem;
|
}
|
||||||
content: '';
|
|
||||||
height: 1.8rem;
|
details {
|
||||||
left: calc(0.5rem * -1);
|
&:has(.active.item) {
|
||||||
position: absolute;
|
> summary {
|
||||||
top: calc(50% - 13px);
|
background: #161a21;
|
||||||
width: 0.25rem;
|
|
||||||
|
&:hover {
|
||||||
|
background: var(--color-hover);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&[open] {
|
||||||
|
> summary {
|
||||||
|
background: unset;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background: var(--color-hover);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&:after {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&:after {
|
||||||
|
@extend %active-item-after-style;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
/* Made by Luting ^-^ */
|
/* Made by Luting ^-^ */
|
||||||
|
@use 'fontface';
|
||||||
@use 'chroma';
|
@use 'chroma';
|
||||||
@use 'codemirror';
|
@use 'codemirror';
|
||||||
@use 'root';
|
@use 'root';
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ textarea,
|
|||||||
tr,
|
tr,
|
||||||
td,
|
td,
|
||||||
button,
|
button,
|
||||||
|
details summary,
|
||||||
#navbar .item,
|
#navbar .item,
|
||||||
.header-wrapper .ui.tabular.menu .item,
|
.header-wrapper .ui.tabular.menu .item,
|
||||||
.job-step-summary,
|
.job-step-summary,
|
||||||
|
|||||||
Reference in New Issue
Block a user