mirror of
https://github.com/catppuccin/gitea.git
synced 2025-01-07 04:04:45 -05:00
329 lines
12 KiB
SCSS
329 lines
12 KiB
SCSS
@use "sass:color";
|
|
|
|
// context-aware lighten: darkens if dark, lightens if light
|
|
@function ctx_lighten($color, $amount) {
|
|
$multiplier: if($isDark, -1, 1);
|
|
@return color.adjust($color, $lightness: $amount * $multiplier);
|
|
}
|
|
|
|
$lvl1: if($isDark, $crust, $base);
|
|
$lvl2: $mantle;
|
|
$lvl3: if($isDark, $base, $crust);
|
|
|
|
:root {
|
|
@if $isDark {
|
|
color-scheme: dark;
|
|
--is-dark-theme: true;
|
|
} @else {
|
|
color-scheme: light;
|
|
--is-dark-theme: false;
|
|
}
|
|
|
|
accent-color: #{$accent};
|
|
|
|
--color-primary: #{$accent};
|
|
--color-primary-contrast: #{$lvl1};
|
|
--color-primary-hover: #{ctx_lighten($accent, 5%)};
|
|
|
|
--color-primary-dark-1: #{ctx_lighten($accent, 3%)};
|
|
--color-primary-dark-2: #{ctx_lighten($accent, 6%)};
|
|
--color-primary-dark-3: #{ctx_lighten($accent, 9%)};
|
|
--color-primary-dark-4: #{ctx_lighten($accent, 12%)};
|
|
--color-primary-dark-5: #{ctx_lighten($accent, 15%)};
|
|
--color-primary-dark-6: #{ctx_lighten($accent, 18%)};
|
|
--color-primary-dark-7: #{ctx_lighten($accent, 21%)};
|
|
|
|
--color-primary-light-1: #{ctx_lighten($accent, -3%)};
|
|
--color-primary-light-2: #{ctx_lighten($accent, -6%)};
|
|
--color-primary-light-3: #{ctx_lighten($accent, -9%)};
|
|
--color-primary-light-4: #{ctx_lighten($accent, -12%)};
|
|
--color-primary-light-5: #{ctx_lighten($accent, -15%)};
|
|
--color-primary-light-6: #{ctx_lighten($accent, -18%)};
|
|
--color-primary-light-7: #{ctx_lighten($accent, -21%)};
|
|
|
|
--color-primary-alpha-10: #{color.change($accent, $alpha: 0.1)};
|
|
--color-primary-alpha-20: #{color.change($accent, $alpha: 0.2)};
|
|
--color-primary-alpha-30: #{color.change($accent, $alpha: 0.3)};
|
|
--color-primary-alpha-40: #{color.change($accent, $alpha: 0.4)};
|
|
--color-primary-alpha-50: #{color.change($accent, $alpha: 0.5)};
|
|
--color-primary-alpha-60: #{color.change($accent, $alpha: 0.6)};
|
|
--color-primary-alpha-70: #{color.change($accent, $alpha: 0.7)};
|
|
--color-primary-alpha-80: #{color.change($accent, $alpha: 0.8)};
|
|
--color-primary-alpha-90: #{color.change($accent, $alpha: 0.9)};
|
|
|
|
--color-secondary: #{$surface1};
|
|
|
|
--color-secondary-dark-1: #{ctx_lighten($surface0, -3%)};
|
|
--color-secondary-dark-2: #{ctx_lighten($surface0, -6%)};
|
|
--color-secondary-dark-3: #{ctx_lighten($surface0, -9%)};
|
|
--color-secondary-dark-4: #{ctx_lighten($surface0, -12%)};
|
|
--color-secondary-dark-5: #{ctx_lighten($surface0, -15%)};
|
|
--color-secondary-dark-6: #{ctx_lighten($surface0, -18%)};
|
|
--color-secondary-dark-7: #{ctx_lighten($surface0, -21%)};
|
|
--color-secondary-dark-8: #{ctx_lighten($surface0, -24%)};
|
|
--color-secondary-dark-9: #{ctx_lighten($surface0, -27%)};
|
|
--color-secondary-dark-10: #{ctx_lighten($surface0, -30%)};
|
|
--color-secondary-dark-11: #{ctx_lighten($surface0, -33%)};
|
|
--color-secondary-dark-12: #{ctx_lighten($surface0, -36%)};
|
|
--color-secondary-dark-13: #{ctx_lighten($surface0, -39%)};
|
|
|
|
--color-secondary-light-1: #{ctx_lighten($surface0, 3%)};
|
|
--color-secondary-light-2: #{ctx_lighten($surface0, 6%)};
|
|
--color-secondary-light-3: #{ctx_lighten($surface0, 9%)};
|
|
--color-secondary-light-4: #{ctx_lighten($surface0, 12%)};
|
|
|
|
--color-secondary-alpha-10: #{color.change($surface0, $alpha: 0.1)};
|
|
--color-secondary-alpha-20: #{color.change($surface0, $alpha: 0.2)};
|
|
--color-secondary-alpha-30: #{color.change($surface0, $alpha: 0.3)};
|
|
--color-secondary-alpha-40: #{color.change($surface0, $alpha: 0.4)};
|
|
--color-secondary-alpha-50: #{color.change($surface0, $alpha: 0.5)};
|
|
--color-secondary-alpha-60: #{color.change($surface0, $alpha: 0.6)};
|
|
--color-secondary-alpha-70: #{color.change($surface0, $alpha: 0.7)};
|
|
--color-secondary-alpha-80: #{color.change($surface0, $alpha: 0.8)};
|
|
--color-secondary-alpha-90: #{color.change($surface0, $alpha: 0.9)};
|
|
|
|
/* colors */
|
|
--color-red: #{$red};
|
|
--color-orange: #{$peach};
|
|
--color-yellow: #{$yellow};
|
|
--color-olive: #{$green};
|
|
--color-green: #{$green};
|
|
--color-teal: #{$teal};
|
|
--color-blue: #{$blue};
|
|
--color-violet: #{$lavender};
|
|
--color-purple: #{$mauve};
|
|
--color-pink: #{$pink};
|
|
--color-brown: #{$flamingo};
|
|
--color-grey: #{$overlay2};
|
|
--color-black: #{if(isDark, $mantle, $text)};
|
|
|
|
/* light variants - produced via Sass scale-color(color, $lightness: -10%) */
|
|
--color-red-light: #{ctx_lighten($red, 10%)};
|
|
--color-orange-light: #{ctx_lighten($peach, 10%)};
|
|
--color-yellow-light: #{ctx_lighten($yellow, 10%)};
|
|
--color-olive-light: #{ctx_lighten($green, 10%)};
|
|
--color-green-light: #{ctx_lighten($green, 10%)};
|
|
--color-teal-light: #{ctx_lighten($teal, 10%)};
|
|
--color-blue-light: #{ctx_lighten($blue, 10%)};
|
|
--color-violet-light: #{ctx_lighten($lavender, 10%)};
|
|
--color-purple-light: #{ctx_lighten($mauve, 10%)};
|
|
--color-pink-light: #{ctx_lighten($pink, 10%)};
|
|
--color-brown-light: #{ctx_lighten($flamingo, 10%)};
|
|
--color-grey-light: #{ctx_lighten($overlay2, 10%)};
|
|
--color-black-light: #{if(
|
|
isDark,
|
|
ctx_lighten($mantle, 10%),
|
|
ctx_lighten($text, 10%)
|
|
)};
|
|
|
|
/* dark 1 variants - produced via Sass scale-color(color, $lightness: -10%) */
|
|
--color-red-dark-1: #{ctx_lighten($red, 10%)};
|
|
--color-orange-dark-1: #{ctx_lighten($peach, 10%)};
|
|
--color-yellow-dark-1: #{ctx_lighten($yellow, 10%)};
|
|
--color-olive-dark-1: #{ctx_lighten($green, 10%)};
|
|
--color-green-dark-1: #{ctx_lighten($green, 10%)};
|
|
--color-teal-dark-1: #{ctx_lighten($teal, 10%)};
|
|
--color-blue-dark-1: #{ctx_lighten($blue, 10%)};
|
|
--color-violet-dark-1: #{ctx_lighten($lavender, 10%)};
|
|
--color-purple-dark-1: #{ctx_lighten($mauve, 10%)};
|
|
--color-pink-dark-1: #{ctx_lighten($pink, 10%)};
|
|
--color-brown-dark-1: #{ctx_lighten($flamingo, 10%)};
|
|
--color-black-dark-1: #{ctx_lighten($mantle, 10%)};
|
|
/* dark 2 variants - produced via Sass scale-color(color, $lightness: -20%) */
|
|
--color-red-dark-2: #{ctx_lighten($red, 20%)};
|
|
--color-orange-dark-2: #{ctx_lighten($peach, 20%)};
|
|
--color-yellow-dark-2: #{ctx_lighten($yellow, 20%)};
|
|
--color-olive-dark-2: #{ctx_lighten($green, 20%)};
|
|
--color-green-dark-2: #{ctx_lighten($green, 20%)};
|
|
--color-teal-dark-2: #{ctx_lighten($teal, 20%)};
|
|
--color-blue-dark-2: #{ctx_lighten($blue, 20%)};
|
|
--color-violet-dark-2: #{ctx_lighten($lavender, 20%)};
|
|
--color-purple-dark-2: #{ctx_lighten($mauve, 20%)};
|
|
--color-pink-dark-2: #{ctx_lighten($pink, 20%)};
|
|
--color-brown-dark-2: #{ctx_lighten($flamingo, 20%)};
|
|
--color-black-dark-2: #{ctx_lighten($mantle, 20%)};
|
|
|
|
/* other colors */
|
|
--color-gold: #{$rosewater};
|
|
--color-white: #{$text};
|
|
--color-diff-removed-word-bg: #{color.change($red, $alpha: 0.15)};
|
|
--color-diff-added-word-bg: #{color.change($green, $alpha: 0.15)};
|
|
--color-diff-removed-row-bg: #{color.change($red, $alpha: 0.07)};
|
|
--color-diff-moved-row-bg: #{color.change($yellow, $alpha: 0.07)};
|
|
--color-diff-added-row-bg: #{color.change($green, $alpha: 0.07)};
|
|
--color-diff-removed-row-border: #{color.change($red, $alpha: 0.07)};
|
|
--color-diff-moved-row-border: #{color.change($yellow, $alpha: 0.07)};
|
|
--color-diff-added-row-border: #{color.change($green, $alpha: 0.07)};
|
|
--color-diff-inactive: #{$overlay2};
|
|
--color-error-border: #{$red};
|
|
--color-error-bg: #{$red};
|
|
--color-error-bg-active: #{ctx_lighten($red, 5%)};
|
|
--color-error-bg-hover: #{ctx_lighten($red, 10%)};
|
|
--color-error-text: #{$lvl1};
|
|
--color-success-border: #{ctx_lighten($green, 10%)};
|
|
--color-success-bg: #{$green};
|
|
--color-success-text: #{$lvl1};
|
|
--color-warning-border: #{ctx_lighten($yellow, 10%)};
|
|
--color-warning-bg: #{$yellow};
|
|
--color-warning-text: #{$lvl1};
|
|
--color-info-border: #{ctx_lighten($blue, 10%)};
|
|
--color-info-bg: #{$lvl1};
|
|
--color-info-text: #{$text};
|
|
--color-red-badge: #{ctx_lighten($red, 10%)};
|
|
--color-red-badge-bg: #{$lvl1};
|
|
--color-red-badge-hover-bg: #{ctx_lighten($red, 5%)};
|
|
--color-green-badge: #{$green};
|
|
--color-green-badge-bg: #{$green};
|
|
--color-green-badge-hover-bg: #{ctx_lighten($green, 5%)};
|
|
--color-yellow-badge: #{$yellow};
|
|
--color-yellow-badge-bg: #{$lvl1};
|
|
--color-yellow-badge-hover-bg: #{ctx_lighten($yellow, 5%)};
|
|
--color-orange-badge: #{$peach};
|
|
--color-orange-badge-bg: #{$lvl1};
|
|
--color-orange-badge-hover-bg: #{ctx_lighten($peach, 5%)};
|
|
--color-git: #{$peach};
|
|
--color-highlight-bg: #{color.change($yellow, $alpha: 0.15)};
|
|
|
|
/* target-based colors */
|
|
--color-body: #{$lvl1};
|
|
--color-box-header: #{$lvl2};
|
|
--color-box-body: #{$lvl2};
|
|
--color-box-body-highlight: #{$surface0};
|
|
--color-text-dark: #{$subtext0};
|
|
--color-text: #{$text};
|
|
--color-text-light: #{$subtext1};
|
|
--color-text-light-1: #{$subtext1};
|
|
--color-text-light-2: #{$subtext1};
|
|
--color-text-light-3: #{$subtext1};
|
|
--color-footer: #{$lvl2};
|
|
--color-timeline: #{$surface0};
|
|
--color-input-text: #{$text};
|
|
--color-input-background: #{$surface0};
|
|
--color-input-toggle-background: #{$surface0};
|
|
--color-input-border: #{$surface1};
|
|
--color-input-border-hover: #{$surface2};
|
|
--color-nav-bg: #{$lvl2};
|
|
--color-nav-hover-bg: #{$surface0};
|
|
--color-navbar: #{$lvl2};
|
|
--color-navbar-transparent: #{color.change($lvl1, $alpha: 0)};
|
|
--color-light: #{color.change($surface2, $alpha: 0.3)};
|
|
--color-light-mimic-enabled: rgba(
|
|
0,
|
|
0,
|
|
0,
|
|
calc(40 / 255 * 222 / 255 / var(--opacity-disabled))
|
|
);
|
|
--color-light-border: #{$surface2};
|
|
--color-hover: #{color.change($overlay0, $alpha: 0.1)};
|
|
--color-active: #{color.change($text, $alpha: 0.1)};
|
|
--color-menu: #{$surface0};
|
|
--color-card: #{$surface0};
|
|
--color-markup-table-row: #{color.change($text, $alpha: 0.02)};
|
|
--color-markup-code-block: #{color.change($text, $alpha: 0.05)};
|
|
--color-button: #{$surface0};
|
|
--color-code-bg: #{$base};
|
|
--color-code-sidebar-bg: #{$surface0};
|
|
--color-shadow: #{color.change($lvl1, $alpha: 0.1)};
|
|
--color-secondary-bg: #{$surface0};
|
|
--color-text-focus: #{$text};
|
|
--color-expand-button: #{$surface2};
|
|
--color-placeholder-text: #{$subtext0};
|
|
--color-editor-line-highlight: var(--color-primary-light-5);
|
|
--color-project-board-bg: var(--color-secondary-light-2);
|
|
/* gitea source code: */
|
|
/* should ideally be --color-text-dark, see go-gitea/gitea#15651 */
|
|
--color-caret: var(--color-text);
|
|
--color-reaction-bg: #{color.change($text, $alpha: 0.07)};
|
|
--color-reaction-active-bg: var(--color-primary-alpha-40);
|
|
--color-header-wrapper: #{$lvl2};
|
|
--color-header-wrapper-transparent: #{color.change($lvl2, $alpha: 0)};
|
|
--color-label-text: #{$crust};
|
|
--color-label-bg: #{$accent};
|
|
--color-label-hover-bg: #{ctx_lighten($accent, 6%)};
|
|
--color-label-active-bg: #{ctx_lighten($accent, 3%)};
|
|
--color-accent: var(--color-primary-light-1);
|
|
--color-small-accent: var(--color-primary-light-5);
|
|
--color-active-line: #{$surface1};
|
|
}
|
|
|
|
@if $isDark {
|
|
/* invert emojis that are hard to read otherwise */
|
|
.emoji[aria-label="check mark"],
|
|
.emoji[aria-label="currency exchange"],
|
|
.emoji[aria-label="TOP arrow"],
|
|
.emoji[aria-label="END arrow"],
|
|
.emoji[aria-label="ON! arrow"],
|
|
.emoji[aria-label="SOON arrow"],
|
|
.emoji[aria-label="heavy dollar sign"],
|
|
.emoji[aria-label="copyright"],
|
|
.emoji[aria-label="registered"],
|
|
.emoji[aria-label="trade mark"],
|
|
.emoji[aria-label="multiply"],
|
|
.emoji[aria-label="plus"],
|
|
.emoji[aria-label="minus"],
|
|
.emoji[aria-label="divide"],
|
|
.emoji[aria-label="curly loop"],
|
|
.emoji[aria-label="double curly loop"],
|
|
.emoji[aria-label="wavy dash"],
|
|
.emoji[aria-label="paw prints"],
|
|
.emoji[aria-label="musical note"],
|
|
.emoji[aria-label="musical notes"] {
|
|
filter: invert(100%) hue-rotate(180deg);
|
|
}
|
|
}
|
|
|
|
.ui.ui.ui.button:not(.inverted, .basic),
|
|
.ui.ui.ui.label:not(.inverted, .basic) {
|
|
&.primary,
|
|
&.green,
|
|
&.red,
|
|
&.teal {
|
|
color: $lvl1;
|
|
&:hover {
|
|
color: $lvl3;
|
|
}
|
|
}
|
|
}
|
|
|
|
.ui.basic.modal {
|
|
background-color: $lvl3;
|
|
}
|
|
|
|
// link color for signed commits
|
|
.ui.commit-header-row .svg.gitea-lock ~ a {
|
|
color: $lvl1;
|
|
}
|
|
|
|
// error message headers weirdly don't seem to be using --color-error-text
|
|
.ui.negative.message .header {
|
|
color: var(--color-error-text)
|
|
}
|
|
|
|
// most recent commit hover when signed
|
|
.ui.sha.isSigned.isVerified {
|
|
.shortsha {
|
|
color: $lvl1;
|
|
}
|
|
svg.gitea-lock {
|
|
fill: $lvl1;
|
|
}
|
|
}
|
|
|
|
// modal text color for the "Remove GPG Key" modal
|
|
.ui.basic.modal,
|
|
.ui.basic.modal > .header,
|
|
.ui.inverted.button {
|
|
color: $text !important;
|
|
}
|
|
|
|
.inline-code-block {
|
|
color: #{$crust};
|
|
}
|
|
|
|
::selection {
|
|
background: color.change($accent, $alpha: 0.3) !important;
|
|
}
|
|
|
|
@import "chroma";
|
|
@import "codemirror";
|
|
@import "monaco";
|