mirror of
				https://github.com/lutinglt/gitea-github-theme.git
				synced 2025-10-26 21:20:31 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			234 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			234 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { animationDown, animationUp } from "src/core/theme";
 | |
| import { fallbackVar } from "src/functions";
 | |
| import { css, customThemeVars, otherThemeVars, themeVars } from "src/types/vars";
 | |
| import { activeItemAfterStyle } from "styles/public/menu";
 | |
| 
 | |
| export const dropdown = css`
 | |
|   .ui.dropdown,
 | |
|   .ui.menu .ui.dropdown {
 | |
|     .menu {
 | |
|       animation: ${animationDown};
 | |
|       // 统一所有下拉菜单的样式
 | |
|       background-color: ${themeVars.color.menu} !important;
 | |
|       border: unset !important;
 | |
|       border-radius: 12px !important;
 | |
|       box-shadow: ${themeVars.github.shadow.floating.small} !important;
 | |
|       // 忽略隐藏
 | |
|       > .item:not(.tw-hidden) {
 | |
|         display: flex !important;
 | |
|         align-items: center;
 | |
|         padding: 6px 8px !important;
 | |
|         border-radius: ${otherThemeVars.border.radius} !important;
 | |
|         &:not(.emoji) {
 | |
|           margin: 0 8px;
 | |
|         }
 | |
|         &:not(.emoji):first-of-type {
 | |
|           margin-top: 8px;
 | |
|         }
 | |
|         // 不知道为什么提交差异对比页面操作中的 cherrypick 按钮无法被选中
 | |
|         &.cherry-pick-button,
 | |
|         &:not(.emoji):last-of-type {
 | |
|           margin-bottom: 8px;
 | |
|         }
 | |
|         &:hover {
 | |
|           background-color: ${themeVars.github.control.transparent.bgColor.hover} !important;
 | |
|         }
 | |
|         &.selected {
 | |
|           background-color: ${themeVars.color.active} !important;
 | |
|           &:hover {
 | |
|             background-color: ${themeVars.github.control.transparent.bgColor.hover} !important;
 | |
|           }
 | |
|         }
 | |
|         &.active,
 | |
|         &.selected {
 | |
|           &:after {
 | |
|             content: "";
 | |
|             ${activeItemAfterStyle};
 | |
|           }
 | |
|         }
 | |
|         svg {
 | |
|           margin-top: 2px;
 | |
|           margin-right: 8px;
 | |
|         }
 | |
|         // 复选框对齐
 | |
|         .ui.checkbox input[type="checkbox"] {
 | |
|           height: 100%;
 | |
|         }
 | |
|       }
 | |
|       > .divider {
 | |
|         margin: 8px 0;
 | |
|       }
 | |
|       &:after {
 | |
|         display: none !important;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
|   // 向下弹出的下拉菜单向下偏移
 | |
|   .ui.dropdown:not(.upward),
 | |
|   .ui.menu .ui.dropdown:not(.upward) {
 | |
|     > .menu {
 | |
|       margin-top: 4px !important;
 | |
|     }
 | |
|   }
 | |
|   // 向上弹出的下拉菜单向上偏移
 | |
|   .ui.dropdown.upward,
 | |
|   .ui.menu .ui.dropdown.upward {
 | |
|     > .menu {
 | |
|       animation: ${animationUp};
 | |
|       margin-bottom: 4px !important;
 | |
|     }
 | |
|   }
 | |
|   // 修复 wiki 的页面下拉菜单圆角
 | |
|   .ui.floating.dropdown > .menu {
 | |
|     border-radius: 12px !important;
 | |
|   }
 | |
|   // 修复嵌套菜单的圆角问题, wiki 页面和组织页面的用户下拉菜单
 | |
|   .ui.dropdown .menu .scrolling.menu {
 | |
|     border-radius: 0 0 12px 12px !important;
 | |
|   }
 | |
|   // 修复下拉菜单元素溢出问题
 | |
|   // 用户菜单
 | |
|   .user-menu>.item,
 | |
|   // Issue/PR 菜单
 | |
|   .ui.menu .ui.dropdown.item .menu .item {
 | |
|     width: auto;
 | |
|   }
 | |
|   // 去掉下拉菜单的边框线
 | |
|   // 设置里的下拉菜单
 | |
|   .ui.selection.dropdown .menu > .item {
 | |
|     border: unset;
 | |
|   }
 | |
|   // 修复一些菜单下的菜单元素溢出问题
 | |
|   // 目前主要为分支菜单
 | |
|   .ui.dropdown .menu .menu {
 | |
|     border-radius: 12px !important;
 | |
|   }
 | |
|   // 修复按钮阴影被覆盖缺少边框线的问题
 | |
|   // 仓库动态页面的右侧按钮, 比如时间周期
 | |
|   .ui.floating.dropdown .menu,
 | |
|   // 仪表板切换控制用户按钮
 | |
|   .ui.dropdown .menu.context-user-switch .scrolling.menu {
 | |
|     box-shadow: ${themeVars.github.shadow.floating.small} !important;
 | |
|   }
 | |
| `;
 | |
| 
 | |
| // 选择框的下拉菜单看起来像普通按钮
 | |
| export const selectionDropdown = css`
 | |
|   // 排除可以选择的输入搜索框和创建仓库的拥有者
 | |
|   .ui.selection.dropdown:not(.search):not(.ellipsis-text-items),
 | |
|   .ui.selection.dropdown.active:not(.search):not(.ellipsis-text-items) {
 | |
|     background-color: ${themeVars.color.button};
 | |
|     border-color: ${themeVars.color.light.border};
 | |
|     border-radius: ${otherThemeVars.border.radius};
 | |
|     padding: 8px 16px;
 | |
|     min-height: 32px;
 | |
|     &:focus {
 | |
|       background: ${themeVars.color.button};
 | |
|       border-color: ${themeVars.color.light.border};
 | |
|     }
 | |
|     &:hover {
 | |
|       background: ${themeVars.color.hover.self};
 | |
|       border-color: ${themeVars.color.light.border};
 | |
|     }
 | |
|     // 悬停提供伪元素
 | |
|     .item:hover:after {
 | |
|       content: "";
 | |
|       ${activeItemAfterStyle};
 | |
|     }
 | |
|   }
 | |
|   // 修复顶部导航栏工单管理/请求合并页面搜索框旁的选择下拉框按钮内容过窄
 | |
|   .list-header-search .ui.action.input > .dropdown.small {
 | |
|     padding: 8px 40px 8px 16px;
 | |
|   }
 | |
|   // 发布版本页面的分支按钮, 覆盖 Gitea 的样式, 避免按钮元素高度不一致
 | |
|   .repository.new.release .target .selection.dropdown {
 | |
|     padding-top: 8px;
 | |
|     padding-bottom: 8px;
 | |
|   }
 | |
|   // 这个按钮项目前只在创建仓库的拥有者
 | |
|   // 不实现伪元素, 因为 .item 设置溢出的元素会被截断
 | |
|   .ui.selection.dropdown.ellipsis-text-items,
 | |
|   .ui.selection.dropdown.activeellipsis-text-items {
 | |
|     &:focus {
 | |
|       background: ${themeVars.color.button};
 | |
|       border-color: ${themeVars.color.light.border};
 | |
|     }
 | |
|     &:hover {
 | |
|       background: ${themeVars.color.hover.self};
 | |
|       border-color: ${themeVars.color.light.border};
 | |
|     }
 | |
|   }
 | |
|   // 选择输入框效果和输入框 focus 效果一样
 | |
|   .ui.selection.dropdown.active.search {
 | |
|     background: ${themeVars.color.body};
 | |
|     // 向内部添加一个 1px 的边框
 | |
|     box-shadow: inset 0 0 0 1px ${themeVars.github.borderColor.accent.emphasis};
 | |
|     outline: none;
 | |
|   }
 | |
|   // 覆盖选择输入框向上弹出时的 hover 效果, 原阴影会覆盖加厚的边框线
 | |
|   .ui.selection.dropdown.active.search.upward:hover {
 | |
|     box-shadow: inset 0 0 0 1px ${themeVars.github.borderColor.accent.emphasis};
 | |
|   }
 | |
|   // 由于之前的排除导致样式优先级变高, 小按钮去除圆角
 | |
|   .ui.action.input > .dropdown.small:not(:first-child) {
 | |
|     border-radius: 0;
 | |
|   }
 | |
|   // 排除一些小按钮, 例如软件包类型, 通常相邻有元素
 | |
|   .ui.selection.dropdown.active:not(.small) {
 | |
|     border-bottom-left-radius: ${otherThemeVars.border.radius} !important;
 | |
|     border-bottom-right-radius: ${otherThemeVars.border.radius} !important;
 | |
|   }
 | |
|   // 修复因为上面的排除导致的圆角问题
 | |
|   // 具体工单页面下依赖菜单选择框
 | |
|   #new-dependency-drop-list.ui.selection.dropdown.active,
 | |
|   // 提交图分支选择框
 | |
|   #git-graph-container #flow-select-refs-dropdown {
 | |
|     border-bottom-right-radius: 0 !important;
 | |
|   }
 | |
|   // 修复选择框的下拉菜单向上显示时的样式问题
 | |
|   .ui.upward.selection.dropdown.visible:not(.small),
 | |
|   .ui.active.upward.selection.dropdown:not(.small) {
 | |
|     border-top-left-radius: ${otherThemeVars.border.radius} !important;
 | |
|     border-top-right-radius: ${otherThemeVars.border.radius} !important;
 | |
|   }
 | |
| `;
 | |
| 
 | |
| export const fixSelectionDropdown = css`
 | |
|   // 具体工单页面下依赖菜单选择框
 | |
|   #new-dependency-drop-list.ui.selection.dropdown {
 | |
|     // 高度对齐问题, 应该与 input 框高度一致
 | |
|     min-height: 32px;
 | |
|   }
 | |
| `;
 | |
| 
 | |
| // 分支菜单
 | |
| export const branchDropdown = css`
 | |
|   .ui.dropdown.branch-selector-dropdown > .menu {
 | |
|     width: ${fallbackVar(customThemeVars.branchMenuWidth, "320px")};
 | |
|     max-width: 640px;
 | |
|     > .menu > .item {
 | |
|       animation: ${animationDown};
 | |
|     }
 | |
|   }
 | |
| `;
 | |
| 
 | |
| // 包含表情的下拉菜单
 | |
| export const emojiDropdown = css`
 | |
|   .ui.dropdown.action.select-reaction.active .menu:has(.emoji) {
 | |
|     display: flex !important;
 | |
|     flex-direction: row;
 | |
|     gap: 4px;
 | |
|     padding: 4px;
 | |
|     min-width: auto;
 | |
|     > .item.emoji {
 | |
|       font-size: 14px;
 | |
|       min-height: 32px;
 | |
|       height: 32px;
 | |
|       margin: 0px;
 | |
|       &:hover {
 | |
|         background-color: ${themeVars.github.bgColor.accent.emphasis} !important;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| `;
 | 
