Added theming
This commit is contained in:
parent
581462d22a
commit
865e6465cf
@ -1 +1 @@
|
|||||||
1.1.0
|
1.2.0
|
@ -1,4 +1,4 @@
|
|||||||
<main *ngIf="isLoggedIn && !hideUI; else home">
|
<main *ngIf="isLoggedIn && !hideUI; else home" [class]="theme">
|
||||||
<app-header></app-header>
|
<app-header></app-header>
|
||||||
|
|
||||||
<div class="app">
|
<div class="app">
|
||||||
|
@ -1,16 +1,17 @@
|
|||||||
import { Component, OnDestroy } from "@angular/core";
|
import { Component, OnDestroy } from '@angular/core';
|
||||||
import { SidebarService } from "src/app/service/sidebar.service";
|
import { SidebarService } from 'src/app/service/sidebar.service';
|
||||||
import { Subject } from "rxjs";
|
import { Subject } from 'rxjs';
|
||||||
import { takeUntil } from "rxjs/operators";
|
import { takeUntil } from 'rxjs/operators';
|
||||||
import { AuthService } from "src/app/service/auth.service";
|
import { AuthService } from 'src/app/service/auth.service';
|
||||||
import { GuiService } from "src/app/service/gui.service";
|
import { GuiService } from 'src/app/service/gui.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: "app-root",
|
selector: 'app-root',
|
||||||
templateUrl: "./app.component.html",
|
templateUrl: './app.component.html',
|
||||||
styleUrl: "./app.component.scss",
|
styleUrl: './app.component.scss',
|
||||||
})
|
})
|
||||||
export class AppComponent implements OnDestroy {
|
export class AppComponent implements OnDestroy {
|
||||||
|
theme = 'open-redirect';
|
||||||
showSidebar = false;
|
showSidebar = false;
|
||||||
hideUI = false;
|
hideUI = false;
|
||||||
isLoggedIn = false;
|
isLoggedIn = false;
|
||||||
@ -19,23 +20,27 @@ export class AppComponent implements OnDestroy {
|
|||||||
constructor(
|
constructor(
|
||||||
private sidebar: SidebarService,
|
private sidebar: SidebarService,
|
||||||
private auth: AuthService,
|
private auth: AuthService,
|
||||||
private gui: GuiService,
|
private gui: GuiService
|
||||||
) {
|
) {
|
||||||
this.auth.loadUser();
|
this.auth.loadUser();
|
||||||
|
|
||||||
this.auth.user$.pipe(takeUntil(this.unsubscribe$)).subscribe((user) => {
|
this.auth.user$.pipe(takeUntil(this.unsubscribe$)).subscribe(user => {
|
||||||
this.isLoggedIn = user !== null && user !== undefined;
|
this.isLoggedIn = user !== null && user !== undefined;
|
||||||
});
|
});
|
||||||
|
|
||||||
this.sidebar.visible$
|
this.sidebar.visible$
|
||||||
.pipe(takeUntil(this.unsubscribe$))
|
.pipe(takeUntil(this.unsubscribe$))
|
||||||
.subscribe((visible) => {
|
.subscribe(visible => {
|
||||||
this.showSidebar = visible;
|
this.showSidebar = visible;
|
||||||
});
|
});
|
||||||
|
|
||||||
this.gui.hideGui$.pipe(takeUntil(this.unsubscribe$)).subscribe((hide) => {
|
this.gui.hideGui$.pipe(takeUntil(this.unsubscribe$)).subscribe(hide => {
|
||||||
this.hideUI = hide;
|
this.hideUI = hide;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.gui.theme$.pipe(takeUntil(this.unsubscribe$)).subscribe(theme => {
|
||||||
|
this.theme = theme;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
ngOnDestroy() {
|
ngOnDestroy() {
|
||||||
|
@ -17,6 +17,18 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-center justify-center">
|
<div class="flex items-center justify-center">
|
||||||
|
<div class="flex items-center justify-center">
|
||||||
|
<p-button
|
||||||
|
type="button"
|
||||||
|
icon="pi pi-palette"
|
||||||
|
class="btn icon-btn p-button-text"
|
||||||
|
(onClick)="themeMenu.toggle($event)"></p-button>
|
||||||
|
<p-menu
|
||||||
|
#themeMenu
|
||||||
|
[popup]="true"
|
||||||
|
[model]="themeList"
|
||||||
|
class="lang-menu"></p-menu>
|
||||||
|
</div>
|
||||||
<div class="flex items-center justify-center">
|
<div class="flex items-center justify-center">
|
||||||
<p-button
|
<p-button
|
||||||
type="button"
|
type="button"
|
||||||
|
@ -1,21 +1,24 @@
|
|||||||
import { Component, OnDestroy, OnInit } from "@angular/core";
|
import { Component, OnDestroy, OnInit } from '@angular/core';
|
||||||
import { MenuItem, PrimeNGConfig } from "primeng/api";
|
import { MenuItem, PrimeNGConfig } from 'primeng/api';
|
||||||
import { Subject } from "rxjs";
|
import { Subject } from 'rxjs';
|
||||||
import { takeUntil } from "rxjs/operators";
|
import { takeUntil } from 'rxjs/operators';
|
||||||
import { TranslateService } from "@ngx-translate/core";
|
import { TranslateService } from '@ngx-translate/core';
|
||||||
import { GuiService } from "src/app/service/gui.service";
|
import { GuiService } from 'src/app/service/gui.service';
|
||||||
import { User } from "src/app/model/auth/user";
|
import { User } from 'src/app/model/auth/user';
|
||||||
import { AuthService } from "src/app/service/auth.service";
|
import { AuthService } from 'src/app/service/auth.service';
|
||||||
import { MenuElement } from "src/app/model/view/menu-element";
|
import { MenuElement } from 'src/app/model/view/menu-element';
|
||||||
import { SidebarService } from "src/app/service/sidebar.service";
|
import { SidebarService } from 'src/app/service/sidebar.service';
|
||||||
|
import { SettingsService } from 'src/app/service/settings.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: "app-header",
|
selector: 'app-header',
|
||||||
templateUrl: "./header.component.html",
|
templateUrl: './header.component.html',
|
||||||
styleUrls: ["./header.component.scss"],
|
styleUrls: ['./header.component.scss'],
|
||||||
})
|
})
|
||||||
export class HeaderComponent implements OnInit, OnDestroy {
|
export class HeaderComponent implements OnInit, OnDestroy {
|
||||||
langList: MenuItem[] = [];
|
langList: MenuItem[] = [];
|
||||||
|
themeList: MenuItem[] = [];
|
||||||
|
|
||||||
userMenuList!: MenuItem[];
|
userMenuList!: MenuItem[];
|
||||||
user: User | null = null;
|
user: User | null = null;
|
||||||
private unsubscribe$ = new Subject<void>();
|
private unsubscribe$ = new Subject<void>();
|
||||||
@ -29,22 +32,30 @@ export class HeaderComponent implements OnInit, OnDestroy {
|
|||||||
private guiService: GuiService,
|
private guiService: GuiService,
|
||||||
private auth: AuthService,
|
private auth: AuthService,
|
||||||
private sidebarService: SidebarService,
|
private sidebarService: SidebarService,
|
||||||
|
private settings: SettingsService
|
||||||
) {
|
) {
|
||||||
this.guiService.isMobile$
|
this.guiService.isMobile$
|
||||||
.pipe(takeUntil(this.unsubscribe$))
|
.pipe(takeUntil(this.unsubscribe$))
|
||||||
.subscribe((isMobile) => {
|
.subscribe(isMobile => {
|
||||||
this.isMobile = isMobile;
|
this.isMobile = isMobile;
|
||||||
if (isMobile) {
|
if (isMobile) {
|
||||||
this.sidebarService.hide();
|
this.sidebarService.hide();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
this.auth.user$
|
this.auth.user$.pipe(takeUntil(this.unsubscribe$)).subscribe(async user => {
|
||||||
.pipe(takeUntil(this.unsubscribe$))
|
|
||||||
.subscribe(async (user) => {
|
|
||||||
this.user = user;
|
this.user = user;
|
||||||
await this.initMenuLists();
|
await this.initMenuLists();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.themeList = this.settings.settings.themes.map(theme => {
|
||||||
|
return {
|
||||||
|
label: theme.label,
|
||||||
|
command: () => {
|
||||||
|
this.guiService.theme$.next(theme.name);
|
||||||
|
},
|
||||||
|
};
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async ngOnInit() {
|
async ngOnInit() {
|
||||||
@ -69,17 +80,17 @@ export class HeaderComponent implements OnInit, OnDestroy {
|
|||||||
async initLangMenuList() {
|
async initLangMenuList() {
|
||||||
this.langList = [
|
this.langList = [
|
||||||
{
|
{
|
||||||
label: "English",
|
label: 'English',
|
||||||
command: () => {
|
command: () => {
|
||||||
this.translate("en");
|
this.translate('en');
|
||||||
this.setLang("en");
|
this.setLang('en');
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: "Deutsch",
|
label: 'Deutsch',
|
||||||
command: () => {
|
command: () => {
|
||||||
this.translate("de");
|
this.translate('de');
|
||||||
this.setLang("de");
|
this.setLang('de');
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
@ -96,13 +107,13 @@ export class HeaderComponent implements OnInit, OnDestroy {
|
|||||||
separator: true,
|
separator: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: this.translateService.instant("header.logout"),
|
label: this.translateService.instant('header.logout'),
|
||||||
command: () => {
|
command: () => {
|
||||||
this.auth.logout().then(() => {
|
this.auth.logout().then(() => {
|
||||||
console.log("logout");
|
console.log('logout');
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
icon: "pi pi-sign-out",
|
icon: 'pi pi-sign-out',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
@ -110,19 +121,19 @@ export class HeaderComponent implements OnInit, OnDestroy {
|
|||||||
translate(lang: string) {
|
translate(lang: string) {
|
||||||
this.translateService.use(lang);
|
this.translateService.use(lang);
|
||||||
this.translateService
|
this.translateService
|
||||||
.get("primeng")
|
.get('primeng')
|
||||||
.subscribe((res) => this.config.setTranslation(res));
|
.subscribe(res => this.config.setTranslation(res));
|
||||||
}
|
}
|
||||||
|
|
||||||
async loadLang() {
|
async loadLang() {
|
||||||
const lang = "en";
|
const lang = 'en';
|
||||||
this.setLang(lang);
|
this.setLang(lang);
|
||||||
this.translate(lang);
|
this.translate(lang);
|
||||||
}
|
}
|
||||||
|
|
||||||
setLang(lang: string) {
|
setLang(lang: string) {
|
||||||
// this.settings.setSetting(`lang`, lang);
|
// this.settings.setSetting(`lang`, lang);
|
||||||
console.log("setLang", lang);
|
console.log('setLang', lang);
|
||||||
}
|
}
|
||||||
|
|
||||||
toggleSidebar() {
|
toggleSidebar() {
|
||||||
|
@ -3,6 +3,7 @@ import { BehaviorSubject, filter } from 'rxjs';
|
|||||||
import { Logger } from 'src/app/service/logger.service';
|
import { Logger } from 'src/app/service/logger.service';
|
||||||
import { NavigationEnd, Router } from '@angular/router';
|
import { NavigationEnd, Router } from '@angular/router';
|
||||||
import { SidebarService } from 'src/app/service/sidebar.service';
|
import { SidebarService } from 'src/app/service/sidebar.service';
|
||||||
|
import { SettingsService } from 'src/app/service/settings.service';
|
||||||
|
|
||||||
const logger = new Logger('GuiService');
|
const logger = new Logger('GuiService');
|
||||||
|
|
||||||
@ -14,10 +15,14 @@ export class GuiService {
|
|||||||
isTablet$ = new BehaviorSubject<boolean>(this.isTabletByWindowWith());
|
isTablet$ = new BehaviorSubject<boolean>(this.isTabletByWindowWith());
|
||||||
|
|
||||||
hideGui$ = new BehaviorSubject<boolean>(false);
|
hideGui$ = new BehaviorSubject<boolean>(false);
|
||||||
|
theme$ = new BehaviorSubject<string>(
|
||||||
|
this.settingsService.settings.themes[0].name
|
||||||
|
);
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
private router: Router,
|
private router: Router,
|
||||||
private sidebarService: SidebarService
|
private sidebarService: SidebarService,
|
||||||
|
private settingsService: SettingsService
|
||||||
) {
|
) {
|
||||||
this.router.events
|
this.router.events
|
||||||
.pipe(filter(event => event instanceof NavigationEnd))
|
.pipe(filter(event => event instanceof NavigationEnd))
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
import { HttpClient } from "@angular/common/http";
|
import { HttpClient } from '@angular/common/http';
|
||||||
import { Injectable } from "@angular/core";
|
import { Injectable } from '@angular/core';
|
||||||
import { throwError } from "rxjs";
|
import { throwError } from 'rxjs';
|
||||||
import { catchError } from "rxjs/operators";
|
import { catchError } from 'rxjs/operators';
|
||||||
import { AppSettings } from "src/app/model/config/app-settings";
|
import { AppSettings } from 'src/app/model/config/app-settings';
|
||||||
import { environment } from "src/environments/environment";
|
import { environment } from 'src/environments/environment';
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
providedIn: "root",
|
providedIn: 'root',
|
||||||
})
|
})
|
||||||
export class SettingsService {
|
export class SettingsService {
|
||||||
settings!: AppSettings;
|
settings!: AppSettings;
|
||||||
@ -18,13 +18,19 @@ export class SettingsService {
|
|||||||
this.http
|
this.http
|
||||||
.get<AppSettings>(`/assets/config/${environment.config}`)
|
.get<AppSettings>(`/assets/config/${environment.config}`)
|
||||||
.pipe(
|
.pipe(
|
||||||
catchError((error) => {
|
catchError(error => {
|
||||||
reject(error);
|
reject(error);
|
||||||
return throwError(() => error);
|
return throwError(() => error);
|
||||||
}),
|
})
|
||||||
)
|
)
|
||||||
.subscribe((settings) => {
|
.subscribe(settings => {
|
||||||
this.settings = settings;
|
this.settings = settings;
|
||||||
|
if (this.settings.themes.length === 0) {
|
||||||
|
this.settings.themes.push({
|
||||||
|
label: 'Open-redirect',
|
||||||
|
name: 'open-redirect',
|
||||||
|
});
|
||||||
|
}
|
||||||
resolve();
|
resolve();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -5,7 +5,11 @@
|
|||||||
"themes": [
|
"themes": [
|
||||||
{
|
{
|
||||||
"label": "Open-redirect",
|
"label": "Open-redirect",
|
||||||
"name": "Open-redirect"
|
"name": "open-redirect"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"label": "Maxlan",
|
||||||
|
"name": "maxlan"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"api": {
|
"api": {
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
@import 'tailwindcss/utilities';
|
@import 'tailwindcss/utilities';
|
||||||
|
|
||||||
@import 'styles/theme';
|
@import 'styles/theme';
|
||||||
|
@import 'styles/theme_maxlan';
|
||||||
@import 'styles/tablet';
|
@import 'styles/tablet';
|
||||||
@import 'styles/mobile';
|
@import 'styles/mobile';
|
||||||
|
|
||||||
@ -58,7 +59,6 @@ body {
|
|||||||
input,
|
input,
|
||||||
.p-checkbox-box,
|
.p-checkbox-box,
|
||||||
.p-dropdown {
|
.p-dropdown {
|
||||||
border: 1px solid $accentColor;
|
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -70,16 +70,6 @@ body {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@layer utilities {
|
|
||||||
.divider {
|
|
||||||
border-bottom: 1px solid $accentColor;
|
|
||||||
}
|
|
||||||
|
|
||||||
.v-divider {
|
|
||||||
border-left: 1px solid $accentColor;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
header {
|
header {
|
||||||
height: $headerHeight;
|
height: $headerHeight;
|
||||||
display: flex;
|
display: flex;
|
||||||
@ -129,7 +119,6 @@ main {
|
|||||||
.component {
|
.component {
|
||||||
margin: 0 10px;
|
margin: 0 10px;
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
background-color: $backgroundColor;
|
|
||||||
flex: 1;
|
flex: 1;
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
}
|
}
|
||||||
@ -141,7 +130,6 @@ footer {
|
|||||||
display: flex;
|
display: flex;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
color: $textColor;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn {
|
.btn {
|
||||||
|
@ -1,25 +1,25 @@
|
|||||||
$headerColor: #a2271f;
|
.open-redirect {
|
||||||
|
$headerColor: #ef9d0d;
|
||||||
|
|
||||||
// generated with https://colorffy.com/dark-theme-generator?colors=314390-121212
|
// generated with https://colorffy.com/dark-theme-generator?colors=314390-121212
|
||||||
$textColor: #fff;
|
$textColor: #fff;
|
||||||
$textColorHighlight: #314390;
|
$textColorHighlight: #ef9d0d;
|
||||||
$textColorHighlight2: #a2271f;
|
$textColorHighlight2: #b76f00;
|
||||||
|
|
||||||
// https://tailwindcss.com/docs/customizing-colors
|
// https://tailwindcss.com/docs/customizing-colors
|
||||||
$backgroundColor: #1e293b; // slate-800
|
$backgroundColor: #1e293b; // slate-800
|
||||||
$backgroundColor2: #0f172a; // slate-900
|
$backgroundColor2: #0f172a; // slate-900
|
||||||
$backgroundColor3: #334155; // slate-700
|
$backgroundColor3: #334155; // slate-700
|
||||||
|
|
||||||
$accentColor: #475569; // slate-600
|
$accentColor: #475569; // slate-600
|
||||||
$infoColor: #1ea97c;
|
$infoColor: #1ea97c;
|
||||||
$warningColor: #ffc107;
|
$warningColor: #ffc107;
|
||||||
$errorColor: #ff5252;
|
$errorColor: #ff5252;
|
||||||
|
|
||||||
body {
|
|
||||||
background-color: $backgroundColor2;
|
background-color: $backgroundColor2;
|
||||||
}
|
|
||||||
|
|
||||||
@layer utilities {
|
|
||||||
|
@layer utilities {
|
||||||
.highlight {
|
.highlight {
|
||||||
color: $textColorHighlight;
|
color: $textColorHighlight;
|
||||||
}
|
}
|
||||||
@ -59,21 +59,21 @@ body {
|
|||||||
.deleted {
|
.deleted {
|
||||||
color: $accentColor !important;
|
color: $accentColor !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
h1,
|
h1,
|
||||||
h2,
|
h2,
|
||||||
h3 {
|
h3 {
|
||||||
color: $headerColor;
|
color: $headerColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
.app {
|
.app {
|
||||||
.component {
|
.component {
|
||||||
background-color: $backgroundColor;
|
background-color: $backgroundColor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn-base {
|
.btn-base {
|
||||||
color: $textColor;
|
color: $textColor;
|
||||||
background: $textColorHighlight !important;
|
background: $textColorHighlight !important;
|
||||||
border: 1px solid $textColorHighlight;
|
border: 1px solid $textColorHighlight;
|
||||||
@ -85,15 +85,15 @@ h3 {
|
|||||||
&:hover {
|
&:hover {
|
||||||
background: transparent !important;
|
background: transparent !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn {
|
.btn {
|
||||||
.p-button {
|
.p-button {
|
||||||
@extend .btn-base;
|
@extend .btn-base;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.icon-btn {
|
.icon-btn {
|
||||||
background-color: transparent !important;
|
background-color: transparent !important;
|
||||||
border: none;
|
border: none;
|
||||||
|
|
||||||
@ -106,9 +106,9 @@ h3 {
|
|||||||
color: $textColorHighlight;
|
color: $textColorHighlight;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.text-btn {
|
.text-btn {
|
||||||
background-color: transparent !important;
|
background-color: transparent !important;
|
||||||
|
|
||||||
.p-button {
|
.p-button {
|
||||||
@ -121,22 +121,22 @@ h3 {
|
|||||||
background-color: transparent !important;
|
background-color: transparent !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.icon-btn-without-hover {
|
.icon-btn-without-hover {
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: transparent !important;
|
background-color: transparent !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.icon-btn {
|
.icon-btn {
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: transparent !important;
|
background-color: transparent !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.danger-btn,
|
.danger-btn,
|
||||||
.danger-icon-btn {
|
.danger-icon-btn {
|
||||||
background-color: transparent !important;
|
background-color: transparent !important;
|
||||||
|
|
||||||
.p-button {
|
.p-button {
|
||||||
@ -147,64 +147,64 @@ h3 {
|
|||||||
color: $errorColor;
|
color: $errorColor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.hidden-columns-select {
|
.hidden-columns-select {
|
||||||
.active-while-panel-open {
|
.active-while-panel-open {
|
||||||
.p-button {
|
.p-button {
|
||||||
color: $textColorHighlight;
|
color: $textColorHighlight;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.custom-spinner {
|
.custom-spinner {
|
||||||
.p-progress-spinner-circle {
|
.p-progress-spinner-circle {
|
||||||
stroke: $textColorHighlight !important;
|
stroke: $textColorHighlight !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-paginator {
|
p-paginator {
|
||||||
.p-paginator-element {
|
.p-paginator-element {
|
||||||
&:hover {
|
&:hover {
|
||||||
color: $textColorHighlight;
|
color: $textColorHighlight;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.p-highlight {
|
.p-highlight {
|
||||||
color: $textColorHighlight2;
|
color: $textColorHighlight2;
|
||||||
box-shadow: none !important;
|
box-shadow: none !important;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
color: $textColorHighlight2 !important;
|
color: $textColorHighlight2 !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.p-multiselect,
|
.p-multiselect,
|
||||||
.p-paginator,
|
.p-paginator,
|
||||||
.p-dropdown,
|
.p-dropdown,
|
||||||
input {
|
input {
|
||||||
background-color: $backgroundColor;
|
background-color: $backgroundColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
.p-inputtext:enabled:focus,
|
.p-inputtext:enabled:focus,
|
||||||
.p-inputtext:enabled:hover,
|
.p-inputtext:enabled:hover,
|
||||||
.p-multiselect:not(.p-disabled):hover,
|
.p-multiselect:not(.p-disabled):hover,
|
||||||
.p-multiselect:not(.p-disabled).p-focus,
|
.p-multiselect:not(.p-disabled).p-focus,
|
||||||
.p-dropdown:not(.p-disabled):hover,
|
.p-dropdown:not(.p-disabled):hover,
|
||||||
.p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box:hover,
|
.p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box:hover,
|
||||||
.p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box.p-focus {
|
.p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box.p-focus {
|
||||||
border-color: $textColorHighlight;
|
border-color: $textColorHighlight;
|
||||||
box-shadow: none !important;
|
box-shadow: none !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.p-checkbox .p-checkbox-box.p-highlight {
|
.p-checkbox .p-checkbox-box.p-highlight {
|
||||||
border-color: $textColorHighlight;
|
border-color: $textColorHighlight;
|
||||||
background: $textColorHighlight;
|
background: $textColorHighlight;
|
||||||
box-shadow: none !important;
|
box-shadow: none !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
p-checkbox {
|
p-checkbox {
|
||||||
.p-checkbox {
|
.p-checkbox {
|
||||||
.p-checkbox-box {
|
.p-checkbox-box {
|
||||||
background-color: $backgroundColor;
|
background-color: $backgroundColor;
|
||||||
@ -215,9 +215,9 @@ p-checkbox {
|
|||||||
background-color: $textColorHighlight;
|
background-color: $textColorHighlight;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-inputSwitch {
|
p-inputSwitch {
|
||||||
.p-inputswitch {
|
.p-inputswitch {
|
||||||
&.p-focus .p-inputswitch-slider {
|
&.p-focus .p-inputswitch-slider {
|
||||||
box-shadow: none !important;
|
box-shadow: none !important;
|
||||||
@ -243,9 +243,9 @@ p-inputSwitch {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-panel-menu {
|
p-panel-menu {
|
||||||
.p-panelmenu {
|
.p-panelmenu {
|
||||||
.p-panelmenu-content
|
.p-panelmenu-content
|
||||||
.p-menuitem:not(.p-highlight):not(.p-disabled)
|
.p-menuitem:not(.p-highlight):not(.p-disabled)
|
||||||
@ -274,9 +274,9 @@ p-panel-menu {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-menubar {
|
p-menubar {
|
||||||
.p-menubar {
|
.p-menubar {
|
||||||
background-color: $backgroundColor2;
|
background-color: $backgroundColor2;
|
||||||
}
|
}
|
||||||
@ -303,9 +303,9 @@ p-menubar {
|
|||||||
background-color: $backgroundColor2;
|
background-color: $backgroundColor2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-dropdown {
|
p-dropdown {
|
||||||
.p-dropdown:not(.p-disabled).p-focus {
|
.p-dropdown:not(.p-disabled).p-focus {
|
||||||
box-shadow: none !important;
|
box-shadow: none !important;
|
||||||
border-color: $headerColor !important;
|
border-color: $headerColor !important;
|
||||||
@ -314,16 +314,16 @@ p-dropdown {
|
|||||||
.p-dropdown-panel {
|
.p-dropdown-panel {
|
||||||
background-color: $backgroundColor2;
|
background-color: $backgroundColor2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-multiselect {
|
p-multiselect {
|
||||||
.p-multiselect-panel,
|
.p-multiselect-panel,
|
||||||
.p-multiselect-panel .p-multiselect-header {
|
.p-multiselect-panel .p-multiselect-header {
|
||||||
background-color: $backgroundColor2;
|
background-color: $backgroundColor2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-table {
|
p-table {
|
||||||
.p-datatable {
|
.p-datatable {
|
||||||
.p-datatable-header,
|
.p-datatable-header,
|
||||||
.p-datatable-footer,
|
.p-datatable-footer,
|
||||||
@ -343,20 +343,20 @@ p-table {
|
|||||||
color: $textColorHighlight;
|
color: $textColorHighlight;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-sidebar {
|
p-sidebar {
|
||||||
.p-sidebar {
|
.p-sidebar {
|
||||||
background-color: $backgroundColor;
|
background-color: $backgroundColor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.p-steps .p-steps-item.p-highlight .p-steps-number {
|
.p-steps .p-steps-item.p-highlight .p-steps-number {
|
||||||
background-color: $headerColor;
|
background-color: $headerColor;
|
||||||
color: $textColor;
|
color: $textColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
.p-dialog {
|
.p-dialog {
|
||||||
.p-dialog-header {
|
.p-dialog-header {
|
||||||
background-color: $backgroundColor;
|
background-color: $backgroundColor;
|
||||||
}
|
}
|
||||||
@ -369,23 +369,23 @@ p-sidebar {
|
|||||||
.p-dialog-footer {
|
.p-dialog-footer {
|
||||||
background-color: $backgroundColor;
|
background-color: $backgroundColor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.p-badge {
|
.p-badge {
|
||||||
background: $headerColor;
|
background: $headerColor;
|
||||||
color: $textColor;
|
color: $textColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
p-password {
|
p-password {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
border: none;
|
border: none;
|
||||||
|
|
||||||
.p-password-panel {
|
.p-password-panel {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p-slider {
|
p-slider {
|
||||||
.p-slider {
|
.p-slider {
|
||||||
.p-slider-range {
|
.p-slider-range {
|
||||||
background: $headerColor;
|
background: $headerColor;
|
||||||
@ -403,4 +403,5 @@ p-slider {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
407
web/src/styles/theme_maxlan.scss
Normal file
407
web/src/styles/theme_maxlan.scss
Normal file
@ -0,0 +1,407 @@
|
|||||||
|
.maxlan {
|
||||||
|
$headerColor: #a2271f;
|
||||||
|
|
||||||
|
// generated with https://colorffy.com/dark-theme-generator?colors=314390-121212
|
||||||
|
$textColor: #fff;
|
||||||
|
$textColorHighlight: #314390;
|
||||||
|
$textColorHighlight2: #a2271f;
|
||||||
|
|
||||||
|
// https://tailwindcss.com/docs/customizing-colors
|
||||||
|
$backgroundColor: #1e293b; // slate-800
|
||||||
|
$backgroundColor2: #0f172a; // slate-900
|
||||||
|
$backgroundColor3: #334155; // slate-700
|
||||||
|
|
||||||
|
$accentColor: #475569; // slate-600
|
||||||
|
$infoColor: #1ea97c;
|
||||||
|
$warningColor: #ffc107;
|
||||||
|
$errorColor: #ff5252;
|
||||||
|
|
||||||
|
background-color: $backgroundColor2;
|
||||||
|
|
||||||
|
|
||||||
|
@layer utilities {
|
||||||
|
.highlight {
|
||||||
|
color: $textColorHighlight;
|
||||||
|
}
|
||||||
|
|
||||||
|
.highlight2 {
|
||||||
|
color: $textColorHighlight2 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bg {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bg2 {
|
||||||
|
background-color: $backgroundColor2;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bg3 {
|
||||||
|
background-color: $backgroundColor3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.accent {
|
||||||
|
color: $accentColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.info {
|
||||||
|
color: $infoColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.warning {
|
||||||
|
color: $warningColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.error {
|
||||||
|
color: $errorColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.deleted {
|
||||||
|
color: $accentColor !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
h1,
|
||||||
|
h2,
|
||||||
|
h3 {
|
||||||
|
color: $headerColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.app {
|
||||||
|
.component {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.btn-base {
|
||||||
|
color: $textColor;
|
||||||
|
background: $textColorHighlight !important;
|
||||||
|
border: 1px solid $textColorHighlight;
|
||||||
|
|
||||||
|
&:focus {
|
||||||
|
box-shadow: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background: transparent !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.btn {
|
||||||
|
.p-button {
|
||||||
|
@extend .btn-base;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon-btn {
|
||||||
|
background-color: transparent !important;
|
||||||
|
border: none;
|
||||||
|
|
||||||
|
.p-button {
|
||||||
|
color: $textColor;
|
||||||
|
background: transparent !important;
|
||||||
|
padding: 0;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
color: $textColorHighlight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-btn {
|
||||||
|
background-color: transparent !important;
|
||||||
|
|
||||||
|
.p-button {
|
||||||
|
color: $textColor;
|
||||||
|
background: transparent !important;
|
||||||
|
border: none !important;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
color: $textColorHighlight;
|
||||||
|
background-color: transparent !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon-btn-without-hover {
|
||||||
|
&:hover {
|
||||||
|
background-color: transparent !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon-btn {
|
||||||
|
&:hover {
|
||||||
|
background-color: transparent !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.danger-btn,
|
||||||
|
.danger-icon-btn {
|
||||||
|
background-color: transparent !important;
|
||||||
|
|
||||||
|
.p-button {
|
||||||
|
color: $textColor;
|
||||||
|
background: transparent !important;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
color: $errorColor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.hidden-columns-select {
|
||||||
|
.active-while-panel-open {
|
||||||
|
.p-button {
|
||||||
|
color: $textColorHighlight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.custom-spinner {
|
||||||
|
.p-progress-spinner-circle {
|
||||||
|
stroke: $textColorHighlight !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-paginator {
|
||||||
|
.p-paginator-element {
|
||||||
|
&:hover {
|
||||||
|
color: $textColorHighlight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-highlight {
|
||||||
|
color: $textColorHighlight2;
|
||||||
|
box-shadow: none !important;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
color: $textColorHighlight2 !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-multiselect,
|
||||||
|
.p-paginator,
|
||||||
|
.p-dropdown,
|
||||||
|
input {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-inputtext:enabled:focus,
|
||||||
|
.p-inputtext:enabled:hover,
|
||||||
|
.p-multiselect:not(.p-disabled):hover,
|
||||||
|
.p-multiselect:not(.p-disabled).p-focus,
|
||||||
|
.p-dropdown:not(.p-disabled):hover,
|
||||||
|
.p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box:hover,
|
||||||
|
.p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box.p-focus {
|
||||||
|
border-color: $textColorHighlight;
|
||||||
|
box-shadow: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-checkbox .p-checkbox-box.p-highlight {
|
||||||
|
border-color: $textColorHighlight;
|
||||||
|
background: $textColorHighlight;
|
||||||
|
box-shadow: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
p-checkbox {
|
||||||
|
.p-checkbox {
|
||||||
|
.p-checkbox-box {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-checkbox-box.p-highlight {
|
||||||
|
border-color: $textColorHighlight;
|
||||||
|
background-color: $textColorHighlight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-inputSwitch {
|
||||||
|
.p-inputswitch {
|
||||||
|
&.p-focus .p-inputswitch-slider {
|
||||||
|
box-shadow: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-inputswitch-slider {
|
||||||
|
background-color: $headerColor;
|
||||||
|
|
||||||
|
&.p-highlight {
|
||||||
|
border-color: $textColorHighlight;
|
||||||
|
background: $textColorHighlight;
|
||||||
|
box-shadow: none !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.p-inputswitch-checked {
|
||||||
|
.p-inputswitch-slider {
|
||||||
|
background-color: $headerColor;
|
||||||
|
|
||||||
|
&:before {
|
||||||
|
background-color: $textColor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-panel-menu {
|
||||||
|
.p-panelmenu {
|
||||||
|
.p-panelmenu-content
|
||||||
|
.p-menuitem:not(.p-highlight):not(.p-disabled)
|
||||||
|
> .p-menuitem-content:hover
|
||||||
|
.p-menuitem-link
|
||||||
|
.p-menuitem-text,
|
||||||
|
.p-panelmenu-content
|
||||||
|
.p-menuitem:not(.p-highlight):not(.p-disabled)
|
||||||
|
> .p-menuitem-content:hover
|
||||||
|
.p-menuitem-link
|
||||||
|
.p-menuitem-icon,
|
||||||
|
.p-panelmenu
|
||||||
|
.p-panelmenu-content
|
||||||
|
.p-menuitem:not(.p-highlight):not(.p-disabled)
|
||||||
|
> .p-menuitem-content:hover
|
||||||
|
.p-menuitem-link
|
||||||
|
.p-submenu-icon {
|
||||||
|
color: $textColorHighlight;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-panelmenu-header-content {
|
||||||
|
&:hover {
|
||||||
|
.p-panelmenu-header-action {
|
||||||
|
color: $textColorHighlight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-menubar {
|
||||||
|
.p-menubar {
|
||||||
|
background-color: $backgroundColor2;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-menubar-root-list {
|
||||||
|
display: flex;
|
||||||
|
gap: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-menuitem {
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
.p-menuitem-content .p-menuitem-link .p-menuitem-text {
|
||||||
|
color: $textColorHighlight2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-focus {
|
||||||
|
background-color: $backgroundColor2;
|
||||||
|
|
||||||
|
.p-menuitem-content {
|
||||||
|
background-color: $backgroundColor2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-dropdown {
|
||||||
|
.p-dropdown:not(.p-disabled).p-focus {
|
||||||
|
box-shadow: none !important;
|
||||||
|
border-color: $headerColor !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dropdown-panel {
|
||||||
|
background-color: $backgroundColor2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-multiselect {
|
||||||
|
.p-multiselect-panel,
|
||||||
|
.p-multiselect-panel .p-multiselect-header {
|
||||||
|
background-color: $backgroundColor2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-table {
|
||||||
|
.p-datatable {
|
||||||
|
.p-datatable-header,
|
||||||
|
.p-datatable-footer,
|
||||||
|
.p-datatable-thead > tr > th,
|
||||||
|
.p-datatable-tbody > tr {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
border-bottom: 1px solid $accentColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-sortable-column.p-highlight,
|
||||||
|
.p-sortable-column:not(.p-highlight):hover {
|
||||||
|
background-color: transparent !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-sortable-column:not(.p-highlight):hover,
|
||||||
|
.p-sortable-column:not(.p-highlight):hover .p-sortable-column-icon {
|
||||||
|
color: $textColorHighlight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-sidebar {
|
||||||
|
.p-sidebar {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-steps .p-steps-item.p-highlight .p-steps-number {
|
||||||
|
background-color: $headerColor;
|
||||||
|
color: $textColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog {
|
||||||
|
.p-dialog-header {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog-content {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
padding-top: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-dialog-footer {
|
||||||
|
background-color: $backgroundColor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-badge {
|
||||||
|
background: $headerColor;
|
||||||
|
color: $textColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
p-password {
|
||||||
|
background-color: transparent;
|
||||||
|
border: none;
|
||||||
|
|
||||||
|
.p-password-panel {
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p-slider {
|
||||||
|
.p-slider {
|
||||||
|
.p-slider-range {
|
||||||
|
background: $headerColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.p-slider-handle {
|
||||||
|
border-color: $headerColor;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background: $headerColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:focus {
|
||||||
|
box-shadow: none !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user