Улучшен фронт

1. Добавлен функционал в интерфейс по управлению сертификатами и службой редактирования сертификатов.

2. Добавлена кнопка для добавления прокси и экран редактирования прокси.
This commit is contained in:
2026-01-17 11:57:57 +07:00
parent 9a788800b5
commit 05ddb1e796
22 changed files with 1641 additions and 77 deletions

View File

@@ -20,21 +20,18 @@
background: linear-gradient(135deg, rgba(16, 185, 129, 0.25), rgba(16, 185, 129, 0.15));
color: var(--accent-green);
border: 1px solid rgba(16, 185, 129, 0.4);
box-shadow: 0 0 12px rgba(16, 185, 129, 0.3);
}
.badge-offline {
background: linear-gradient(135deg, rgba(239, 68, 68, 0.25), rgba(239, 68, 68, 0.15));
color: var(--accent-red);
border: 1px solid rgba(239, 68, 68, 0.4);
box-shadow: 0 0 12px rgba(239, 68, 68, 0.3);
}
.badge-pending {
background: linear-gradient(135deg, rgba(245, 158, 11, 0.25), rgba(245, 158, 11, 0.15));
color: var(--accent-yellow);
border: 1px solid rgba(245, 158, 11, 0.4);
box-shadow: 0 0 12px rgba(245, 158, 11, 0.3);
}
/* Yes/No Badges */
@@ -55,7 +52,6 @@
width: 7px;
height: 7px;
border-radius: var(--radius-full);
box-shadow: 0 0 8px currentColor;
}
.status-online {
@@ -85,3 +81,27 @@
}
}
/* Certificate Icons */
.cert-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 22px;
height: 22px;
margin-right: 8px;
border-radius: var(--radius-sm);
font-size: 12px;
}
.cert-valid {
background: rgba(16, 185, 129, 0.2);
color: var(--accent-green);
border: 1px solid rgba(16, 185, 129, 0.4);
}
.cert-expired {
background: rgba(239, 68, 68, 0.2);
color: var(--accent-red);
border: 1px solid rgba(239, 68, 68, 0.4);
}

View File

@@ -71,7 +71,6 @@
&:hover:not(:disabled) {
background: rgba(239, 68, 68, 0.25);
border-color: rgba(239, 68, 68, 0.5);
box-shadow: 0 4px 12px rgba(239, 68, 68, 0.2);
}
}
@@ -152,7 +151,6 @@
font-weight: var(--font-semibold);
cursor: pointer;
transition: all var(--transition-base);
box-shadow: var(--shadow-red);
&:hover:not(:disabled) {
background: linear-gradient(135deg, rgba(239, 68, 68, 0.3), rgba(239, 68, 68, 0.15));
@@ -173,7 +171,6 @@
background: linear-gradient(135deg, rgba(16, 185, 129, 0.2), rgba(16, 185, 129, 0.1));
border-color: rgba(16, 185, 129, 0.4);
color: var(--accent-green);
box-shadow: var(--shadow-green);
&:hover:not(:disabled) {
background: linear-gradient(135deg, rgba(16, 185, 129, 0.3), rgba(16, 185, 129, 0.15));
@@ -211,7 +208,6 @@
background: rgba(16, 185, 129, 0.2);
border-color: rgba(16, 185, 129, 0.5);
color: var(--accent-green);
box-shadow: 0 0 12px rgba(16, 185, 129, 0.2);
}
&:last-child.active {
@@ -315,7 +311,6 @@
&.active {
background: var(--accent-purple);
color: white;
box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
}
}

View File

@@ -24,6 +24,11 @@
gap: var(--space-md);
}
/* Form Row (3 columns) */
.form-row.form-row-3 {
grid-template-columns: 1fr 1fr 1fr;
}
/* Form Label */
.form-label {
font-size: 12px;

View File

@@ -65,7 +65,6 @@
backdrop-filter: var(--backdrop-blur-light);
border-radius: 20px;
border: 1px solid rgba(16, 185, 129, 0.3);
box-shadow: var(--shadow-green);
}
.status-text {

View File

@@ -262,3 +262,207 @@
}
}
/* ============================================
Cert Manager
============================================ */
.cert-manager-content {
display: flex;
flex-direction: column;
gap: var(--space-md);
}
.cert-card {
background: rgba(139, 92, 246, 0.03);
border: 1px solid var(--glass-border);
border-radius: var(--radius-xl);
padding: var(--space-lg);
transition: all var(--transition-base);
}
.cert-card-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--space-md);
padding-bottom: var(--space-md);
border-bottom: 1px solid var(--glass-border);
}
.cert-card-title {
display: flex;
align-items: center;
gap: var(--space-md);
i {
font-size: 24px;
color: var(--accent-green);
}
h3 {
margin: 0;
font-size: var(--text-xl);
font-weight: var(--font-semibold);
color: var(--text-primary);
}
}
.cert-card-title.expired i {
color: var(--accent-red);
}
.cert-card-actions {
display: flex;
gap: var(--space-sm);
}
.cert-info-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: var(--space-md);
}
.cert-info-item {
padding: var(--space-md);
background: rgba(255, 255, 255, 0.02);
border-radius: var(--radius-md);
.cert-info-label {
font-size: var(--text-sm);
color: var(--text-muted);
margin-bottom: var(--space-xs);
}
.cert-info-value {
font-size: var(--text-md);
color: var(--text-primary);
font-weight: var(--font-medium);
}
.cert-info-value.valid {
color: var(--accent-green);
}
.cert-info-value.expired {
color: var(--accent-red);
}
}
.cert-domains-list {
display: flex;
flex-wrap: wrap;
gap: var(--space-sm);
margin-top: var(--space-md);
}
.cert-domain-tag {
padding: 4px 12px;
background: rgba(139, 92, 246, 0.15);
border-radius: var(--radius-md);
font-size: var(--text-sm);
color: var(--accent-purple-light);
font-family: var(--font-mono);
}
.cert-empty {
text-align: center;
padding: 60px 40px;
color: var(--text-muted);
i {
font-size: 48px;
margin-bottom: var(--space-lg);
opacity: 0.3;
}
h3 {
font-size: var(--text-xl);
font-weight: var(--font-semibold);
color: var(--text-primary);
margin-bottom: var(--space-sm);
}
p {
font-size: var(--text-md);
}
}
/* Wildcard Info Block */
.cert-wildcard-info {
padding: var(--space-md);
background: rgba(139, 92, 246, 0.05);
border-radius: var(--radius-lg);
}
.cert-wildcard-header {
display: flex;
align-items: center;
gap: var(--space-sm);
margin-bottom: var(--space-xs);
font-size: var(--text-md);
font-weight: var(--font-medium);
color: var(--accent-purple-light);
i {
color: var(--accent-purple-light);
}
}
.cert-wildcard-info > p {
margin: 0 0 var(--space-sm) 0;
color: var(--text-muted);
font-size: var(--text-sm);
}
.cert-wildcard-list {
display: flex;
flex-direction: column;
gap: var(--space-xs);
}
.cert-wildcard-item {
display: flex;
align-items: center;
gap: var(--space-md);
padding: var(--space-xs) var(--space-sm);
background: rgba(139, 92, 246, 0.08);
border-radius: var(--radius-sm);
}
.cert-wildcard-item.expired {
opacity: 0.7;
}
.cert-wildcard-domain {
font-family: var(--font-mono);
font-size: var(--text-sm);
color: var(--text-primary);
}
.cert-wildcard-status {
font-size: var(--text-sm);
color: var(--accent-green);
}
.cert-wildcard-item.expired .cert-wildcard-status {
color: var(--accent-red);
}
.cert-wildcard-issuer {
font-size: var(--text-sm);
color: var(--text-muted);
}
/* Card Variants */
.cert-card-wildcard {
/* без особых стилей */
}
.cert-card-local {
opacity: 0.6;
}
.cert-card-empty {
border-style: dashed;
}