Backend (Go): - Добавлен полный функционал создания сайтов - Добавлен функционал удаления сайтов - Новые API методы в admin.go: - Добавлен шаблон стартовой страницы - Добавлена функция DecodeBase64 Исправления критических ошибок: - Исправлена работа wildcard алиасов (*.domain.com) в handler.go - Исправлены ошибки "файл не найден" при создании файлов Frontend (JavaScript + HTML + CSS): - Добавлена страница создания сайта - Добавлена кнопка "Удалить сайт" в редактировании - Мелкие доработки стилей Build: - Обновлён build_admin.ps1 - добавлен шаг генерации биндингов (wails generate module) Fixes: - #fix Wildcard алиасы (*.domain.com) теперь работают корректно - #fix Удалён порт из host при проверке алиасов - #fix Приоритет точных доменов над wildcard - #fix Ошибки "файл не найден" при создании сайтов/vAccess - #fix Секция добавления сайта теперь скрывается при навигации
67 lines
1.4 KiB
CSS
67 lines
1.4 KiB
CSS
/* ============================================
|
|
Container Layout
|
|
Основной контейнер контента
|
|
============================================ */
|
|
|
|
.container {
|
|
height: calc(100vh - var(--header-height));
|
|
margin-top: var(--header-height);
|
|
margin-left: var(--sidebar-width);
|
|
padding: 40px var(--space-3xl);
|
|
position: relative;
|
|
z-index: var(--z-base);
|
|
overflow-y: auto;
|
|
overflow-x: hidden;
|
|
}
|
|
|
|
/* Main Content */
|
|
.main-content {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--space-2xl);
|
|
}
|
|
|
|
/* Section */
|
|
.section {
|
|
position: relative;
|
|
}
|
|
|
|
.section-title {
|
|
font-size: var(--text-md);
|
|
font-weight: var(--font-bold);
|
|
color: var(--text-primary);
|
|
margin-bottom: var(--space-lg);
|
|
text-transform: uppercase;
|
|
letter-spacing: 1.5px;
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--space-lg);
|
|
|
|
&::before {
|
|
content: '';
|
|
width: 4px;
|
|
height: 16px;
|
|
background: linear-gradient(180deg, var(--accent-purple), var(--accent-purple-light));
|
|
border-radius: 2px;
|
|
}
|
|
}
|
|
|
|
/* Footer */
|
|
.footer {
|
|
margin-top: var(--space-lg);
|
|
padding: 20px;
|
|
text-align: center;
|
|
color: var(--text-muted);
|
|
font-size: var(--text-sm);
|
|
opacity: 0.6;
|
|
}
|
|
|
|
/* Responsive */
|
|
@media (max-width: 600px) {
|
|
.header {
|
|
flex-direction: column;
|
|
gap: 10px;
|
|
}
|
|
}
|
|
|