mirror of
				https://github.com/lutinglt/gitea-github-theme.git
				synced 2025-10-26 13:00:31 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			631 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			631 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { css, otherThemeVars, themeVars } from "src/types/vars";
 | |
| 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;
 | |
|       margin-top: 16px;
 | |
|       .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;
 | |
|         > .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: 16px;
 | |
|     .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`
 | |
|   .issue-content-left .field.footer {
 | |
|     // 关闭工单按钮
 | |
|     .ui.red.basic.button#status-button {
 | |
|       color: ${themeVars.github.fgColor.done};
 | |
|       background-color: ${themeVars.color.button};
 | |
|       border-color: ${themeVars.color.light.border};
 | |
|       &:hover {
 | |
|         background-color: ${themeVars.color.hover.self};
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     // 重新开启按钮
 | |
|     .ui.basic.primary.button#status-button {
 | |
|       color: ${themeVars.github.fgColor.success};
 | |
|     }
 | |
|   }
 | |
|   // 工单&PR标题右侧按钮
 | |
|   .repository.view.issue .issue-title-buttons > .ui.button {
 | |
|     padding: 0 12px;
 | |
|     height: 32px;
 | |
|   }
 | |
| `;
 | |
| 
 | |
| export const babel = css`
 | |
|   .issue-content-left {
 | |
|     .badge {
 | |
|       // 时间线打开状态标签
 | |
|       &.tw-bg-green {
 | |
|         background-color: ${themeVars.github.bgColor.success.emphasis} !important;
 | |
|       }
 | |
|       // 时间线关闭状态标签
 | |
|       &.tw-bg-red {
 | |
|         background-color: ${themeVars.github.bgColor.done.emphasis} !important;
 | |
|       }
 | |
|       // 时间线合并状态标签
 | |
|       &.tw-bg-purple {
 | |
|         background-color: ${themeVars.github.bgColor.done.emphasis} !important;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
|   // 工单&PR状态标签
 | |
|   .ui.label.issue-state-label {
 | |
|     border-radius: 25px !important;
 | |
| 
 | |
|     &.green {
 | |
|       color: ${themeVars.color.white} !important;
 | |
|       background-color: ${themeVars.github.bgColor.success.emphasis} !important;
 | |
|       border-color: ${themeVars.github.bgColor.success.emphasis} !important;
 | |
|     }
 | |
| 
 | |
|     &.red {
 | |
|       color: ${themeVars.color.white} !important;
 | |
|       background-color: ${themeVars.github.bgColor.done.emphasis} !important;
 | |
|       border-color: ${themeVars.github.bgColor.done.emphasis} !important;
 | |
|     }
 | |
| 
 | |
|     &.purple {
 | |
|       color: ${themeVars.color.white} !important;
 | |
|       background-color: ${themeVars.github.bgColor.done.emphasis} !important;
 | |
|       border-color: ${themeVars.github.bgColor.done.emphasis} !important;
 | |
|     }
 | |
|   }
 | |
| `;
 | |
| 
 | |
| // PR 分支标签
 | |
| export const prBranch = css`
 | |
|   .repository.view.issue .pull-desc code,
 | |
|   #issue-list .flex-item-body .branches .branch {
 | |
|     color: ${themeVars.github.fgColor.accent};
 | |
|     background-color: ${themeVars.github.bgColor.accent.muted};
 | |
|     border-radius: ${otherThemeVars.border.radius};
 | |
|     font-family: var(--fontStack-monospace, ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, monospace);
 | |
|     font-size: 12px;
 | |
|     padding: 0 5px;
 | |
|     line-height: 20px;
 | |
|   }
 | |
| 
 | |
|   .repository.view.issue .pull-desc code {
 | |
|     padding-top: 3px;
 | |
|     padding-bottom: 3px;
 | |
|     a:hover {
 | |
|       text-decoration-line: none;
 | |
|     }
 | |
|   }
 | |
| `;
 | |
| 
 | |
| // 评论
 | |
| export const comment = css`
 | |
|   .comment .comment-container {
 | |
|     // 去除评论标题左侧指向头像的小箭头
 | |
|     .comment-header,
 | |
|     &:target .comment-header {
 | |
|       &:before,
 | |
|       &:after {
 | |
|         display: none;
 | |
|       }
 | |
|     }
 | |
|     // 评论焦点样式
 | |
|     &:target {
 | |
|       .comment-container {
 | |
|         border-color: ${themeVars.github.borderColor.accent.emphasis} !important;
 | |
|         box-shadow: 0 0 0 1px ${themeVars.color.primary.self} !important;
 | |
|       }
 | |
|     }
 | |
|     .comment-header {
 | |
|       padding: 4px 4px 4px 16px;
 | |
|       min-height: 38px;
 | |
|     }
 | |
|     .comment-header-right {
 | |
|       > .item,
 | |
|       > .label {
 | |
|         color: ${themeVars.color.text.light.num1};
 | |
|       }
 | |
|       > .ui.label {
 | |
|         background-color: initial;
 | |
|         font-size: 12px;
 | |
|         height: 20px;
 | |
|         padding: 0 6px;
 | |
|       }
 | |
|       // 隐藏顶部菜单的表情按钮
 | |
|       // 无法使用此样式, 评论无表情时底部的表情按钮元素不会渲染, 这是一个先有鸡还是先有蛋的问题
 | |
|       // 很蛋疼, 希望 Gitea 早日使用 Github 的样式, 因为 Github 的更合理, 无论是操作的方便程度还是按钮的冗余度
 | |
|       // .ui.dropdown.action.select-reaction {
 | |
|       //   display: none;
 | |
|       // }
 | |
|       .context-dropdown {
 | |
|         a.context-menu {
 | |
|           display: flex;
 | |
|           align-items: center;
 | |
|         }
 | |
|         // 评论菜单的删除按钮
 | |
|         .menu .item.delete-comment {
 | |
|           color: ${themeVars.color.red.self};
 | |
|           &:hover {
 | |
|             background-color: ${themeVars.color.red.badge.bg} !important;
 | |
|             color: ${themeVars.color.red.light};
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|     // 表情菜单按钮头部+底部
 | |
|     .ui.dropdown.action.select-reaction > a {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       background: ${themeVars.color.button};
 | |
|       border-radius: 25px;
 | |
|       border: 1px solid ${themeVars.color.light.border};
 | |
|       color: ${themeVars.color.text.light.num1};
 | |
|       padding: 0px 8px !important;
 | |
|       height: 28px;
 | |
|       width: 28px;
 | |
|     }
 | |
|     // 底部表情栏
 | |
|     .bottom-reactions {
 | |
|       .ui.ui.ui.label {
 | |
|         background-color: unset !important;
 | |
|         border-radius: 25px;
 | |
|         border-color: ${themeVars.color.light.border};
 | |
|         &:hover {
 | |
|           background-color: ${themeVars.color.reaction.hoverBg} !important;
 | |
|           border-color: ${themeVars.color.light.border};
 | |
|         }
 | |
|         .reaction {
 | |
|           font-size: 12px;
 | |
|         }
 | |
|         .reaction-count {
 | |
|           color: ${themeVars.color.text.light.self};
 | |
|           font-weight: 500;
 | |
|           margin-left: 0;
 | |
|         }
 | |
|       }
 | |
|       // 显示表情菜单按钮
 | |
|       .select-reaction {
 | |
|         padding: 0;
 | |
|         // 两个表情按钮看着怪怪的, 很难受
 | |
|         // visibility: visible;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| `;
 | |
| 
 | |
| export const dropdown = css`
 | |
|   .repository {
 | |
|     // Issue/PR 列表下的所有筛选菜单
 | |
|     &.issue-list .ui.dropdown .menu, .ui.menu .ui.dropdown .menu,
 | |
|     // Issue/PR 详情下的右侧的上半部分选项菜单
 | |
|     &.issue.view .issue-content-right .ui.dropdown .scrolling.menu {
 | |
|       .item:hover:after {
 | |
|         content: "";
 | |
|         ${activeItemAfterStyle}
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| `;
 | |
| 
 | |
| // PR 界面的 PR 操作评论
 | |
| export const prMerge = css`
 | |
|   .repository.view.issue .comment-list .timeline-item.pull-merge-box {
 | |
|     // 头像
 | |
|     .timeline-avatar {
 | |
|       color: ${themeVars.color.text.self} !important;
 | |
|       border-radius: ${otherThemeVars.border.radius};
 | |
|       width: 40px;
 | |
|       height: 40px;
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       svg {
 | |
|         width: 24px;
 | |
|         height: 24px;
 | |
|       }
 | |
|       // 可以合并
 | |
|       &.green {
 | |
|         background-color: ${themeVars.github.bgColor.success.emphasis};
 | |
|         // 操作评论边框色
 | |
|         + .content > .ui.attached.segment {
 | |
|           border-left-color: ${themeVars.github.bgColor.success.emphasis};
 | |
|           border-right-color: ${themeVars.github.bgColor.success.emphasis};
 | |
|           &:first-child {
 | |
|             border-top-color: ${themeVars.github.bgColor.success.emphasis};
 | |
|           }
 | |
|           &:last-child {
 | |
|             border-bottom-color: ${themeVars.github.bgColor.success.emphasis};
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|       // 已合并
 | |
|       &.purple {
 | |
|         background-color: ${themeVars.github.bgColor.done.emphasis};
 | |
|         + .content > .ui.attached.segment {
 | |
|           border-left-color: ${themeVars.github.bgColor.done.emphasis};
 | |
|           border-right-color: ${themeVars.github.bgColor.done.emphasis};
 | |
|           &:first-child {
 | |
|             border-top-color: ${themeVars.github.bgColor.done.emphasis};
 | |
|           }
 | |
|           &:last-child {
 | |
|             border-bottom-color: ${themeVars.github.bgColor.done.emphasis};
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|     // 检查状态
 | |
|     .commit-status-panel {
 | |
|       .commit-status-header {
 | |
|         background: ${themeVars.color.body};
 | |
|         padding: 16px;
 | |
|         font-size: 16px;
 | |
|         font-weight: 600;
 | |
|         .ui.right {
 | |
|           color: ${themeVars.color.text.light.num1};
 | |
|           font-size: 14px;
 | |
|           font-weight: 400;
 | |
|         }
 | |
|       }
 | |
|       // 检查状态列表
 | |
|       .commit-status-list {
 | |
|         background: ${themeVars.color.menu};
 | |
|         .commit-status-item {
 | |
|           border-radius: ${otherThemeVars.border.radius};
 | |
|           padding: 2px 8px;
 | |
|           margin: 0px 8px;
 | |
|           height: 37px;
 | |
|           &:first-child {
 | |
|             margin-top: 8px;
 | |
|           }
 | |
|           &:last-child {
 | |
|             margin-bottom: 8px;
 | |
|           }
 | |
|           &:hover {
 | |
|             background-color: ${themeVars.color.hover.opaque};
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|     // 合并信息和操作
 | |
|     .merge-section {
 | |
|       color: ${themeVars.color.text.light.num1};
 | |
|       padding: 16px;
 | |
|       display: grid;
 | |
|       gap: 8px;
 | |
|     }
 | |
|   }
 | |
| `;
 | |
| 
 | |
| // 时间线
 | |
| export const timeline = css`
 | |
|   .repository.view.issue {
 | |
|     .comment-list {
 | |
|       // 时间线本线
 | |
|       .timeline::before {
 | |
|         // 不遮挡归档信息框, 归档信息框背景色有透明度时会漏出线
 | |
|         height: calc(100% - 62px);
 | |
|       }
 | |
|       .timeline-item,
 | |
|       .timeline-item-group {
 | |
|         padding: 16px 0;
 | |
|         // 事件
 | |
|         &.event {
 | |
|           // 修复覆盖后的位置问题
 | |
|           padding-left: 15px;
 | |
|           .avatar {
 | |
|             width: 20px;
 | |
|             height: 20px;
 | |
|           }
 | |
|           .badge {
 | |
|             border: 2px solid ${themeVars.color.body};
 | |
|           }
 | |
|           // 仅匹配只有 badge
 | |
|           .badge:not([class*=" "]) {
 | |
|             background-color: ${themeVars.github.control.bgColor.rest};
 | |
|             svg {
 | |
|               color: ${themeVars.color.text.light.num1};
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|         // 提交
 | |
|         &.commits-list {
 | |
|           // 每个提交之间的间隔
 | |
|           .flex-text-block {
 | |
|             padding-top: 4px;
 | |
|           }
 | |
|           .badge svg {
 | |
|             color: ${themeVars.color.text.light.num1};
 | |
|           }
 | |
|           // 仅覆盖左侧 commit 不覆盖右侧 SHA
 | |
|           a.muted {
 | |
|             font-size: 12px;
 | |
|             color: ${themeVars.color.text.light.num1};
 | |
|             text-decoration-line: underline;
 | |
|             &:hover {
 | |
|               color: ${themeVars.color.primary.self};
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| `;
 | |
| 
 | |
| const sidebarPadding = {
 | |
|   padding: "4px 8px",
 | |
| };
 | |
| 
 | |
| // 侧边栏
 | |
| export const issueSidebar = css`
 | |
|   // 工单&创建工单&PR页面侧边栏
 | |
|   .page-content.repository.issue {
 | |
|     .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};
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| `;
 | 
