import { css, themeVars } from "src/types/vars"; export const primaryStyle = { color: themeVars.github.button.primary.fgColor.rest, backgroundColor: themeVars.github.button.primary.bgColor.rest, borderColor: themeVars.github.button.primary.borderColor.rest, boxShadow: themeVars.github.shadow.resting.small, }; export const primaryHoverStyle = { color: themeVars.github.button.primary.fgColor.rest, backgroundColor: themeVars.github.button.primary.bgColor.hover, borderColor: themeVars.github.button.primary.borderColor.hover, }; // 普通按钮和主色调按钮 export const baseButton = css` .ui.button { min-height: 30px; font-weight: 500; padding: 9px 16px; &.ui { gap: 8px; } } .ui.button:not(.primary):not(.red) svg { color: ${themeVars.color.text.light.num1}; } // 主色调按钮保持白色 .ui.primary.buttons .button svg { color: ${themeVars.color.text.self}; } .ui.primary { &.button, // 按钮组, PR 里的压缩合并按钮 &.buttons .button { ${primaryStyle} &:hover { ${primaryHoverStyle} } } } // 主色调基本按钮和普通按钮一样 // 作者的关注按钮 .ui.basic.primary.button { background-color: ${themeVars.color.button}; color: ${themeVars.color.text.self}; border-color: ${themeVars.color.light.border}; box-shadow: none; &:hover { background-color: ${themeVars.color.hover.self}; color: ${themeVars.color.text.self}; border-color: ${themeVars.color.light.border}; } } /* 普通按钮边框色不变 */ .ui.basic.button, /* 仓库点星等数字标签按钮边框色不变 */ .ui.labeled.button > .label { &:hover { border-color: ${themeVars.color.light.border}; } } /* 普通按钮激活时背景色 */ .ui.basic.buttons .button:active, .ui.basic.button:active, .ui.basic.buttons .active.button, .ui.basic.active.button, .ui.basic.buttons .active.button:hover, .ui.basic.active.button:hover { background-color: ${themeVars.github.button.default.bgColor.active}; } `; // 红色按钮 export const redButton = css` .ui.red.button, .ui.basic.red.buttons .button, .ui.basic.red.button { color: ${themeVars.github.button.danger.fgColor.rest}; background-color: ${themeVars.github.button.danger.bgColor.rest}; /* 一些按钮边框色为红色, 比如危险操作区, 统一为暗色边框和 github 一致 */ border-color: ${themeVars.color.light.border}; &:hover { color: ${themeVars.github.button.danger.fgColor.hover}; background-color: ${themeVars.github.button.danger.bgColor.hover}; border-color: ${themeVars.github.button.danger.borderColor.hover}; box-shadow: ${themeVars.github.shadow.resting.small}; } } `; // 修复按钮高度 export const fixButtonHeight = css` // 修复一些主色调或者其他小按钮的高度避免过高 .ui.small.buttons .button, .ui.ui.ui.ui.small.button { min-height: 26px; height: 32px; } // 修复仓库页仓库操作按钮高度对齐和修正 .repo-button-row .ui.button { min-height: 32px; } // 修复因上面小按钮高度导致仓库星标克隆等按钮高度过高 .repo-header { .ui.ui.ui.ui.small.compact.button, .ui.labeled.button > .label { height: 28px; min-height: 28px; } } .ui.ui.ui.ui.small.button.compact .ui.tiny.buttons .button, .ui.ui.ui.ui.tiny.button { min-height: 20px; } `; export const fixButton = css` // 修复关注&派生 hover 意外点亮右侧 label 左边框 .ui.ui.ui.ui.small.button { z-index: 0; } // 代码复制按钮 .ui.button.code-copy { padding: 4px 6px; min-height: 28px; } `;