feat(ui): add web UI with Jinja2 templates and Gitea themes

- Add Jinja2 templates with data-testid attributes for testing
- Create light/dark themes based on Gitea color scheme
- Add theme switching with localStorage persistence
- Create base CSS, components, and layout styles
- Add mock web routes for UI demonstration
- Register web router and static files in main.py
- Add data-testid requirements to AGENTS.md
- Install jinja2 dependency
This commit is contained in:
2026-05-02 14:45:51 +03:00
parent ca4e8877a5
commit e2802d83f2
18 changed files with 2212 additions and 1 deletions

150
static/css/base.css Normal file
View File

@@ -0,0 +1,150 @@
/* Base styles for blog application
*
* This file provides reset, typography, and base styles
* using CSS variables from theme files.
*/
/* Reset */
*,
*::before,
*::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html {
font-size: 16px;
line-height: 1.5;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
body {
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
background-color: var(--color-body);
color: var(--color-text);
min-height: 100vh;
display: flex;
flex-direction: column;
}
/* Typography */
h1, h2, h3, h4, h5, h6 {
color: var(--color-text-dark);
font-weight: 600;
line-height: 1.25;
margin-bottom: 1rem;
}
h1 { font-size: 2rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; }
p {
margin-bottom: 1rem;
color: var(--color-text);
}
a {
color: var(--color-primary);
text-decoration: none;
transition: color 0.2s ease;
}
a:hover {
color: var(--color-primary-hover);
text-decoration: underline;
}
/* Lists */
ul, ol {
margin-bottom: 1rem;
padding-left: 1.5rem;
}
li {
margin-bottom: 0.25rem;
}
/* Code */
code {
font-family: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, monospace;
font-size: 0.875em;
background-color: var(--color-code-bg);
color: var(--color-text);
padding: 0.125rem 0.375rem;
border-radius: 3px;
}
pre {
background-color: var(--color-code-bg);
padding: 1rem;
border-radius: 6px;
overflow-x: auto;
margin-bottom: 1rem;
}
pre code {
background: none;
padding: 0;
}
/* Selection */
::selection {
background-color: var(--color-primary-alpha-30);
color: var(--color-text-dark);
}
/* Focus styles */
:focus-visible {
outline: 2px solid var(--color-primary);
outline-offset: 2px;
}
/* Scrollbar */
::-webkit-scrollbar {
width: 10px;
height: 10px;
}
::-webkit-scrollbar-track {
background: var(--color-secondary-light-4);
}
::-webkit-scrollbar-thumb {
background: var(--color-secondary-dark-4);
border-radius: 5px;
}
::-webkit-scrollbar-thumb:hover {
background: var(--color-secondary-dark-5);
}
/* Utility classes */
.text-light {
color: var(--color-text-light);
}
.text-muted {
color: var(--color-text-light-3);
}
.text-center {
text-align: center;
}
.sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}

347
static/css/components.css Normal file
View File

@@ -0,0 +1,347 @@
/* Component styles for blog application
*
* This file provides reusable UI components like buttons,
* cards, forms, inputs, and other interactive elements.
* All components use CSS variables from theme files.
*/
/* Buttons */
.btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
padding: 0.5rem 1rem;
font-size: 0.875rem;
font-weight: 500;
line-height: 1.5;
border: 1px solid var(--color-secondary-dark-1);
border-radius: 4px;
background-color: var(--color-button);
color: var(--color-text);
cursor: pointer;
text-decoration: none;
transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
white-space: nowrap;
}
.btn:hover {
background-color: var(--color-hover);
border-color: var(--color-secondary-dark-2);
text-decoration: none;
}
.btn:active {
background-color: var(--color-active);
}
.btn:focus {
outline: none;
box-shadow: 0 0 0 3px var(--color-primary-alpha-30);
}
.btn:disabled,
.btn.disabled {
opacity: 0.6;
cursor: not-allowed;
}
.btn-primary {
background-color: var(--color-primary);
border-color: var(--color-primary-dark-1);
color: var(--color-primary-contrast);
}
.btn-primary:hover {
background-color: var(--color-primary-hover);
border-color: var(--color-primary-dark-2);
}
.btn-primary:active {
background-color: var(--color-primary-active);
}
.btn-danger {
background-color: var(--color-red);
border-color: var(--color-red-dark-1);
color: #ffffff;
}
.btn-danger:hover {
background-color: var(--color-red-dark-1);
}
.btn-success {
background-color: var(--color-green);
border-color: var(--color-green-dark-1);
color: #ffffff;
}
.btn-success:hover {
background-color: var(--color-green-dark-1);
}
.btn-ghost {
background-color: transparent;
border-color: transparent;
}
.btn-ghost:hover {
background-color: var(--color-hover);
}
.btn-sm {
padding: 0.25rem 0.75rem;
font-size: 0.8125rem;
}
.btn-lg {
padding: 0.75rem 1.5rem;
font-size: 1rem;
}
/* Cards */
.card {
background-color: var(--color-box-body);
border: 1px solid var(--color-border);
border-radius: 6px;
overflow: hidden;
transition: box-shadow 0.2s ease;
}
.card:hover {
box-shadow: 0 2px 8px var(--color-shadow);
}
.card-header {
background-color: var(--color-box-header);
padding: 1rem 1.25rem;
border-bottom: 1px solid var(--color-border);
font-weight: 600;
}
.card-body {
padding: 1.25rem;
}
.card-footer {
background-color: var(--color-box-header);
padding: 0.75rem 1.25rem;
border-top: 1px solid var(--color-border);
}
/* Forms */
.form-group {
margin-bottom: 1.25rem;
}
.form-label {
display: block;
margin-bottom: 0.5rem;
font-weight: 500;
color: var(--color-text);
}
.form-label-required::after {
content: " *";
color: var(--color-red);
}
.form-hint {
display: block;
margin-top: 0.25rem;
font-size: 0.8125rem;
color: var(--color-text-light-3);
}
/* Inputs */
.input,
.textarea,
.select {
display: block;
width: 100%;
padding: 0.5rem 0.75rem;
font-size: 0.875rem;
line-height: 1.5;
color: var(--color-input-text);
background-color: var(--color-input-background);
border: 1px solid var(--color-input-border);
border-radius: 4px;
transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.input:focus,
.textarea:focus,
.select:focus {
outline: none;
border-color: var(--color-primary);
box-shadow: 0 0 0 3px var(--color-primary-alpha-20);
}
.input:disabled,
.textarea:disabled,
.select:disabled {
background-color: var(--color-secondary-light-2);
cursor: not-allowed;
}
.input::placeholder,
.textarea::placeholder {
color: var(--color-placeholder-text);
}
.textarea {
min-height: 100px;
resize: vertical;
}
.select {
appearance: none;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right 0.75rem center;
padding-right: 2.5rem;
}
/* Input sizes */
.input-sm,
.textarea-sm,
.select-sm {
padding: 0.25rem 0.5rem;
font-size: 0.8125rem;
}
.input-lg,
.textarea-lg,
.select-lg {
padding: 0.75rem 1rem;
font-size: 1rem;
}
/* Alerts */
.alert {
padding: 1rem 1.25rem;
margin-bottom: 1rem;
border: 1px solid transparent;
border-radius: 4px;
}
.alert-error {
background-color: var(--color-error-bg);
border-color: var(--color-error-border);
color: var(--color-error-text);
}
.alert-success {
background-color: var(--color-success-bg);
border-color: var(--color-success-border);
color: var(--color-success-text);
}
.alert-warning {
background-color: var(--color-warning-bg);
border-color: var(--color-warning-border);
color: var(--color-warning-text);
}
.alert-info {
background-color: var(--color-info-bg);
border-color: var(--color-info-border);
color: var(--color-info-text);
}
/* Badges */
.badge {
display: inline-flex;
align-items: center;
padding: 0.125rem 0.5rem;
font-size: 0.75rem;
font-weight: 500;
line-height: 1.5;
border-radius: 9999px;
background-color: var(--color-label-bg);
color: var(--color-label-text);
}
.badge-primary {
background-color: var(--color-primary-alpha-20);
color: var(--color-primary);
}
.badge-success {
background-color: var(--color-green-badge-bg);
color: var(--color-green-badge);
}
.badge-danger {
background-color: var(--color-red-badge-bg);
color: var(--color-red-badge);
}
.badge-warning {
background-color: var(--color-yellow-badge-bg);
color: var(--color-yellow-badge);
}
/* Tags */
.tag {
display: inline-flex;
align-items: center;
gap: 0.25rem;
padding: 0.125rem 0.5rem;
font-size: 0.75rem;
background-color: var(--color-secondary-light-3);
border: 1px solid var(--color-border);
border-radius: 4px;
color: var(--color-text-light);
}
.tag:hover {
background-color: var(--color-hover);
}
/* Avatar */
.avatar {
display: inline-flex;
align-items: center;
justify-content: center;
width: 2rem;
height: 2rem;
border-radius: 50%;
background-color: var(--color-primary);
color: var(--color-primary-contrast);
font-weight: 500;
font-size: 0.875rem;
}
.avatar-sm {
width: 1.5rem;
height: 1.5rem;
font-size: 0.75rem;
}
.avatar-lg {
width: 2.5rem;
height: 2.5rem;
font-size: 1rem;
}
/* Dividers */
.divider {
height: 1px;
background-color: var(--color-border);
margin: 1.5rem 0;
}
/* Empty state */
.empty-state {
text-align: center;
padding: 3rem 1rem;
color: var(--color-text-light-3);
}
.empty-state-icon {
font-size: 3rem;
margin-bottom: 1rem;
opacity: 0.5;
}

441
static/css/layout.css Normal file
View File

@@ -0,0 +1,441 @@
/* Layout styles for blog application
*
* This file provides layout-related styles including
* grid system, navigation, containers, and page structure.
*/
/* Container */
.container {
width: 100%;
max-width: 1200px;
margin: 0 auto;
padding: 0 1rem;
}
.container-narrow {
max-width: 800px;
}
.container-wide {
max-width: 1400px;
}
/* Main layout */
.main-wrapper {
flex: 1;
padding: 2rem 0;
}
/* Grid system */
.grid {
display: grid;
gap: 1.5rem;
}
.grid-2 {
grid-template-columns: repeat(2, 1fr);
}
.grid-3 {
grid-template-columns: repeat(3, 1fr);
}
.grid-4 {
grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 1024px) {
.grid-4 {
grid-template-columns: repeat(2, 1fr);
}
}
@media (max-width: 768px) {
.grid-2,
.grid-3,
.grid-4 {
grid-template-columns: 1fr;
}
}
/* Flex utilities */
.flex {
display: flex;
}
.flex-col {
flex-direction: column;
}
.items-center {
align-items: center;
}
.justify-between {
justify-content: space-between;
}
.justify-center {
justify-content: center;
}
.gap-1 { gap: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: 1rem; }
/* Header */
.site-header {
background-color: var(--color-nav-bg);
border-bottom: 1px solid var(--color-border);
position: sticky;
top: 0;
z-index: 100;
}
.site-header .container {
display: flex;
align-items: center;
justify-content: space-between;
height: 4rem;
}
.site-logo {
display: flex;
align-items: center;
gap: 0.5rem;
font-size: 1.25rem;
font-weight: 600;
color: var(--color-text-dark);
text-decoration: none;
}
.site-logo:hover {
color: var(--color-primary);
text-decoration: none;
}
/* Navigation */
.main-nav {
display: flex;
align-items: center;
gap: 1.5rem;
}
.nav-link {
color: var(--color-nav-text);
font-weight: 500;
padding: 0.5rem 0;
border-bottom: 2px solid transparent;
transition: color 0.2s ease, border-color 0.2s ease;
}
.nav-link:hover {
color: var(--color-primary);
text-decoration: none;
border-bottom-color: var(--color-primary-alpha-50);
}
.nav-link.active {
color: var(--color-primary);
border-bottom-color: var(--color-primary);
}
/* Header actions */
.header-actions {
display: flex;
align-items: center;
gap: 0.75rem;
}
/* Theme toggle button */
.theme-toggle {
display: flex;
align-items: center;
justify-content: center;
width: 2rem;
height: 2rem;
padding: 0;
border-radius: 4px;
background: transparent;
border: 1px solid transparent;
color: var(--color-nav-text);
cursor: pointer;
transition: background-color 0.2s ease, color 0.2s ease;
}
.theme-toggle:hover {
background-color: var(--color-nav-hover-bg);
color: var(--color-primary);
}
/* Footer */
.site-footer {
background-color: var(--color-footer);
border-top: 1px solid var(--color-border);
padding: 2rem 0;
margin-top: auto;
}
.site-footer .container {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 1rem;
}
.footer-links {
display: flex;
align-items: center;
gap: 1.5rem;
}
.footer-link {
color: var(--color-text-light);
font-size: 0.875rem;
}
.footer-link:hover {
color: var(--color-primary);
}
/* Page header */
.page-header {
margin-bottom: 2rem;
padding-bottom: 1rem;
border-bottom: 1px solid var(--color-border);
}
.page-header-flex {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
flex-wrap: wrap;
}
.page-title {
margin-bottom: 0;
}
.page-subtitle {
color: var(--color-text-light);
margin-top: 0.25rem;
}
/* Post list */
.post-list {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* Post card specific */
.post-card {
display: flex;
flex-direction: column;
gap: 1rem;
}
.post-card-header {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 1rem;
}
.post-card-title {
margin-bottom: 0;
font-size: 1.25rem;
}
.post-card-title a {
color: var(--color-text-dark);
}
.post-card-title a:hover {
color: var(--color-primary);
}
.post-card-meta {
display: flex;
align-items: center;
gap: 1rem;
font-size: 0.875rem;
color: var(--color-text-light-2);
}
.post-card-meta-item {
display: flex;
align-items: center;
gap: 0.25rem;
}
.post-card-content {
color: var(--color-text-light);
line-height: 1.6;
}
.post-card-footer {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
padding-top: 1rem;
border-top: 1px solid var(--color-border);
}
.post-card-tags {
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
}
/* Post detail */
.post-detail {
max-width: 800px;
margin: 0 auto;
}
.post-detail-header {
margin-bottom: 2rem;
padding-bottom: 1.5rem;
border-bottom: 1px solid var(--color-border);
}
.post-detail-title {
font-size: 2rem;
margin-bottom: 1rem;
}
.post-detail-meta {
display: flex;
align-items: center;
gap: 1.5rem;
flex-wrap: wrap;
color: var(--color-text-light-2);
}
.post-detail-content {
font-size: 1.125rem;
line-height: 1.8;
color: var(--color-text);
}
.post-detail-content p {
margin-bottom: 1.5rem;
}
.post-detail-footer {
margin-top: 3rem;
padding-top: 1.5rem;
border-top: 1px solid var(--color-border);
}
.post-detail-tags {
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
}
/* Sidebar */
.sidebar {
position: sticky;
top: 6rem;
}
.sidebar-section {
background-color: var(--color-box-body);
border: 1px solid var(--color-border);
border-radius: 6px;
padding: 1.25rem;
margin-bottom: 1.5rem;
}
.sidebar-title {
font-size: 0.875rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.025em;
color: var(--color-text-light);
margin-bottom: 1rem;
}
/* Two column layout */
.two-column {
display: grid;
grid-template-columns: 1fr 300px;
gap: 2rem;
}
@media (max-width: 1024px) {
.two-column {
grid-template-columns: 1fr;
}
.sidebar {
position: static;
}
}
/* Pagination */
.pagination {
display: flex;
align-items: center;
justify-content: center;
gap: 0.25rem;
margin-top: 2rem;
}
.pagination-item {
display: flex;
align-items: center;
justify-content: center;
min-width: 2rem;
height: 2rem;
padding: 0 0.5rem;
border-radius: 4px;
font-size: 0.875rem;
color: var(--color-text);
text-decoration: none;
transition: background-color 0.2s ease;
}
.pagination-item:hover {
background-color: var(--color-hover);
text-decoration: none;
}
.pagination-item.active {
background-color: var(--color-primary);
color: var(--color-primary-contrast);
}
.pagination-item.disabled {
opacity: 0.5;
cursor: not-allowed;
}
/* Mobile menu */
@media (max-width: 768px) {
.site-header .container {
height: 3.5rem;
}
.main-nav {
display: none;
}
.mobile-menu-btn {
display: flex;
}
}
@media (min-width: 769px) {
.mobile-menu-btn {
display: none;
}
}

View File

@@ -0,0 +1,199 @@
gitea-theme-meta-info {
--theme-display-name: "Dark";
--theme-color-scheme: "dark";
}
[data-theme="dark"] {
--is-dark-theme: true;
/* Primary colors */
--color-primary: #4183c4;
--color-primary-contrast: #ffffff;
--color-primary-dark-1: #548fca;
--color-primary-dark-2: #679cd0;
--color-primary-dark-3: #7aa8d6;
--color-primary-dark-4: #8db5dc;
--color-primary-dark-5: #b3cde7;
--color-primary-dark-6: #d9e6f3;
--color-primary-dark-7: #f4f8fb;
--color-primary-light-1: #3876b3;
--color-primary-light-2: #31699f;
--color-primary-light-3: #2b5c8b;
--color-primary-light-4: #254f77;
--color-primary-light-5: #193450;
--color-primary-light-6: #0c1a28;
--color-primary-light-7: #04080c;
--color-primary-alpha-10: #4183c419;
--color-primary-alpha-20: #4183c433;
--color-primary-alpha-30: #4183c44b;
--color-primary-alpha-40: #4183c466;
--color-primary-alpha-50: #4183c480;
--color-primary-alpha-60: #4183c499;
--color-primary-alpha-70: #4183c4b3;
--color-primary-alpha-80: #4183c4cc;
--color-primary-alpha-90: #4183c4e1;
--color-primary-hover: var(--color-primary-light-1);
--color-primary-active: var(--color-primary-light-2);
/* Secondary colors */
--color-secondary: #3f4248;
--color-secondary-dark-1: #46494f;
--color-secondary-dark-2: #4f5259;
--color-secondary-dark-3: #5e626a;
--color-secondary-dark-4: #6f747d;
--color-secondary-dark-5: #7d828c;
--color-secondary-dark-6: #8b8f98;
--color-secondary-dark-7: #999da4;
--color-secondary-dark-8: #a8abb1;
--color-secondary-dark-9: #aeb1b8;
--color-secondary-dark-10: #bbbec3;
--color-secondary-dark-11: #c8cacf;
--color-secondary-dark-12: #d2d4d7;
--color-secondary-dark-13: #d5d6d9;
--color-secondary-light-1: #35373c;
--color-secondary-light-2: #2c2e32;
--color-secondary-light-3: #1f2124;
--color-secondary-light-4: #191a1c;
--color-secondary-alpha-10: #3f424819;
--color-secondary-alpha-20: #3f424833;
--color-secondary-alpha-30: #3f42484b;
--color-secondary-alpha-40: #3f424866;
--color-secondary-alpha-50: #3f424880;
--color-secondary-alpha-60: #3f424899;
--color-secondary-alpha-70: #3f4248b3;
--color-secondary-alpha-80: #3f4248cc;
--color-secondary-alpha-90: #3f4248e1;
--color-secondary-button: var(--color-secondary-dark-4);
--color-secondary-hover: var(--color-secondary-dark-3);
--color-secondary-active: var(--color-secondary-dark-2);
/* Semantic colors */
--color-red: #cc4848;
--color-orange: #cc580c;
--color-yellow: #cc9903;
--color-olive: #91a313;
--color-green: #87ab63;
--color-teal: #00918a;
--color-blue: #3a8ac6;
--color-violet: #906ae1;
--color-purple: #b259d0;
--color-pink: #d22e8b;
--color-brown: #a47252;
--color-black: #202225;
/* Light variants */
--color-red-light: #d15a5a;
--color-orange-light: #f6a066;
--color-yellow-light: #eaaf03;
--color-olive-light: #abc016;
--color-green-light: #93b373;
--color-teal-light: #00b6ad;
--color-blue-light: #4e96cc;
--color-violet-light: #9b79e4;
--color-purple-light: #ba6ad5;
--color-pink-light: #d74397;
--color-brown-light: #b08061;
--color-black-light: #45484e;
/* Dark variants */
--color-red-dark-1: #c23636;
--color-orange-dark-1: #f38236;
--color-yellow-dark-1: #b88a03;
--color-olive-dark-1: #839311;
--color-green-dark-1: #7a9e55;
--color-teal-dark-1: #00837c;
--color-blue-dark-1: #347cb3;
--color-violet-dark-1: #7b4edb;
--color-purple-dark-1: #a742c9;
--color-pink-dark-1: #be297d;
--color-brown-dark-1: #94674a;
--color-black-dark-1: #2e3033;
/* Status colors */
--color-error-border: #763232;
--color-error-bg: #322226;
--color-error-bg-active: #49262a;
--color-error-bg-hover: #3c2427;
--color-error-text: #f85149;
--color-success-border: #225633;
--color-success-bg: #1c3329;
--color-success-text: #3fb950;
--color-warning-border: #5f481a;
--color-warning-bg: #342e1f;
--color-warning-text: #d29922;
--color-info-border: #254a7e;
--color-info-bg: #1b283a;
--color-info-text: #2f81f7;
/* Target-based colors */
--color-body: #1e1f20;
--color-box-header: #1b1c1e;
--color-box-body: #161718;
--color-box-body-highlight: #202124;
--color-text-dark: #f8f8f8;
--color-text: #d2d4d8;
--color-text-light: #c0c2c7;
--color-text-light-1: #aaadb4;
--color-text-light-2: #969aa1;
--color-text-light-3: #80858f;
--color-footer: var(--color-nav-bg);
--color-timeline: #383b40;
--color-input-text: var(--color-text-dark);
--color-input-background: #191a1c;
--color-input-toggle-background: #323438;
--color-input-border: var(--color-secondary-dark-1);
--color-light: #0b0b0c28;
--color-light-border: #f3f3f428;
--color-hover: #f3f3f419;
--color-hover-opaque: #232528;
--color-active: #f3f3f424;
--color-menu: #191a1c;
--color-card: #191a1c;
--color-button: #191a1c;
--color-code-bg: #161718;
--color-shadow: #0b0b0c58;
--color-shadow-opaque: #0b0b0c;
--color-secondary-bg: #2e3033;
--color-expand-button: #333539;
--color-placeholder-text: var(--color-text-light-3);
--color-tooltip-text: #fafafa;
--color-tooltip-bg: #0b0b0cf0;
--color-nav-bg: #18191b;
--color-nav-hover-bg: var(--color-secondary-light-1);
--color-nav-text: var(--color-text);
--color-secondary-nav-bg: #1a1b1e;
--color-label-text: var(--color-text);
--color-label-bg: #7a7f8a4b;
--color-label-hover-bg: #7a7f8aa0;
--color-label-active-bg: #7a7f8aff;
--color-accent: var(--color-primary-light-1);
--color-small-accent: var(--color-primary-light-5);
--color-border: #3f4248;
accent-color: var(--color-accent);
color-scheme: dark;
}
/* 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);
}

View File

@@ -0,0 +1,175 @@
gitea-theme-meta-info {
--theme-display-name: "Light";
--theme-color-scheme: "light";
}
:root {
--is-dark-theme: false;
/* Primary colors */
--color-primary: #4183c4;
--color-primary-contrast: #ffffff;
--color-primary-dark-1: #3876b3;
--color-primary-dark-2: #31699f;
--color-primary-dark-3: #2b5c8b;
--color-primary-dark-4: #254f77;
--color-primary-dark-5: #193450;
--color-primary-dark-6: #0c1a28;
--color-primary-dark-7: #04080c;
--color-primary-light-1: #548fca;
--color-primary-light-2: #679cd0;
--color-primary-light-3: #7aa8d6;
--color-primary-light-4: #8db5dc;
--color-primary-light-5: #b3cde7;
--color-primary-light-6: #d9e6f3;
--color-primary-light-7: #f4f8fb;
--color-primary-alpha-10: #4183c419;
--color-primary-alpha-20: #4183c433;
--color-primary-alpha-30: #4183c44b;
--color-primary-alpha-40: #4183c466;
--color-primary-alpha-50: #4183c480;
--color-primary-alpha-60: #4183c499;
--color-primary-alpha-70: #4183c4b3;
--color-primary-alpha-80: #4183c4cc;
--color-primary-alpha-90: #4183c4e1;
--color-primary-hover: var(--color-primary-dark-1);
--color-primary-active: var(--color-primary-dark-2);
/* Secondary colors */
--color-secondary: #d0d7de;
--color-secondary-dark-1: #c7ced5;
--color-secondary-dark-2: #b9c0c7;
--color-secondary-dark-3: #99a0a7;
--color-secondary-dark-4: #899097;
--color-secondary-dark-5: #7a8188;
--color-secondary-dark-6: #6a7178;
--color-secondary-dark-7: #5b6269;
--color-secondary-dark-8: #4b5259;
--color-secondary-dark-9: #3c434a;
--color-secondary-dark-10: #2c333a;
--color-secondary-dark-11: #1d242b;
--color-secondary-dark-12: #0d141b;
--color-secondary-dark-13: #00040b;
--color-secondary-light-1: #dee5ec;
--color-secondary-light-2: #e4ebf2;
--color-secondary-light-3: #ebf2f9;
--color-secondary-light-4: #f1f8ff;
--color-secondary-alpha-10: #d0d7de19;
--color-secondary-alpha-20: #d0d7de33;
--color-secondary-alpha-30: #d0d7de4b;
--color-secondary-alpha-40: #d0d7de66;
--color-secondary-alpha-50: #d0d7de80;
--color-secondary-alpha-60: #d0d7de99;
--color-secondary-alpha-70: #d0d7deb3;
--color-secondary-alpha-80: #d0d7decc;
--color-secondary-alpha-90: #d0d7dee1;
--color-secondary-button: var(--color-secondary-dark-4);
--color-secondary-hover: var(--color-secondary-dark-5);
--color-secondary-active: var(--color-secondary-dark-6);
/* Semantic colors */
--color-red: #db2828;
--color-orange: #f2711c;
--color-yellow: #fbbd08;
--color-olive: #b5cc18;
--color-green: #21ba45;
--color-teal: #00b5ad;
--color-blue: #2185d0;
--color-violet: #6435c9;
--color-purple: #a333c8;
--color-pink: #e03997;
--color-brown: #a5673f;
--color-black: #1d2328;
/* Light variants */
--color-red-light: #e45e5e;
--color-orange-light: #f59555;
--color-yellow-light: #fcce46;
--color-olive-light: #d3e942;
--color-green-light: #46de6a;
--color-teal-light: #08fff4;
--color-blue-light: #51a5e3;
--color-violet-light: #8b67d7;
--color-purple-light: #bb64d8;
--color-pink-light: #e86bb1;
--color-brown-light: #c58b66;
--color-black-light: #4b5b68;
/* Dark variants */
--color-red-dark-1: #c82121;
--color-orange-dark-1: #e6630d;
--color-yellow-dark-1: #e5ac04;
--color-olive-dark-1: #a3b816;
--color-green-dark-1: #1ea73e;
--color-teal-dark-1: #00a39c;
--color-blue-dark-1: #1e78bb;
--color-violet-dark-1: #5a30b5;
--color-purple-dark-1: #932eb4;
--color-pink-dark-1: #db228a;
--color-brown-dark-1: #955d39;
--color-black-dark-1: #2c3339;
/* Status colors */
--color-error-border: #ff818266;
--color-error-bg: #ffebe9;
--color-error-bg-active: #ffcecb;
--color-error-bg-hover: #ffdcd7;
--color-error-text: #d1242f;
--color-success-border: #4ac26b66;
--color-success-bg: #dafbe1;
--color-success-text: #1a7f37;
--color-warning-border: #d4a72c66;
--color-warning-bg: #fff8c5;
--color-warning-text: #9a6700;
--color-info-border: #54aeff66;
--color-info-bg: #ddf4ff;
--color-info-text: #0969da;
/* Target-based colors */
--color-body: #ffffff;
--color-box-header: #f1f3f5;
--color-box-body: #ffffff;
--color-box-body-highlight: #ecf5fd;
--color-text-dark: #01050a;
--color-text: #181c21;
--color-text-light: #30363b;
--color-text-light-1: #40474d;
--color-text-light-2: #5b6167;
--color-text-light-3: #747c84;
--color-footer: var(--color-nav-bg);
--color-timeline: #d0d7de;
--color-input-text: var(--color-text-dark);
--color-input-background: #fff;
--color-input-toggle-background: #d0d7de;
--color-input-border: var(--color-secondary-dark-1);
--color-light: #00001706;
--color-light-border: #0000171d;
--color-hover: #00001708;
--color-hover-opaque: #f1f3f5;
--color-active: #00001714;
--color-menu: #f8f9fb;
--color-card: #f8f9fb;
--color-button: #f8f9fb;
--color-code-bg: #fafdff;
--color-shadow: #00001726;
--color-shadow-opaque: #c7ced5;
--color-secondary-bg: #f2f5f8;
--color-expand-button: #cfe8fa;
--color-placeholder-text: var(--color-text-light-3);
--color-tooltip-text: #fbfdff;
--color-tooltip-bg: #000017f0;
--color-nav-bg: #f6f7fa;
--color-nav-hover-bg: var(--color-secondary-light-1);
--color-nav-text: var(--color-text);
--color-secondary-nav-bg: #f9fafb;
--color-label-text: var(--color-text);
--color-label-bg: #949da64b;
--color-label-hover-bg: #949da6a0;
--color-label-active-bg: #949da6ff;
--color-accent: var(--color-primary-light-1);
--color-small-accent: var(--color-primary-light-6);
--color-border: #d0d7de;
accent-color: var(--color-accent);
color-scheme: light;
}