1
0
mirror of https://github.com/dkmstr/openuds-gui.git synced 2025-01-04 09:17:36 +03:00

upgraded user interface (Angular 18)

This commit is contained in:
Adolfo Gómez García 2024-06-20 04:24:03 +02:00
parent 2c0ec1fd22
commit 81856fa5dd
No known key found for this signature in database
GPG Key ID: DD1ABF20724CDA23
8 changed files with 74 additions and 78 deletions

View File

@ -12,11 +12,12 @@
"projectType": "application", "projectType": "application",
"architect": { "architect": {
"build": { "build": {
"builder": "@angular-devkit/build-angular:browser", "builder": "@angular-devkit/build-angular:application",
"options": { "options": {
"outputPath": "dist", "outputPath": {
"base": "dist"
},
"index": "src/index.html", "index": "src/index.html",
"main": "src/main.ts",
"tsConfig": "src/tsconfig.app.json", "tsConfig": "src/tsconfig.app.json",
"polyfills": ["zone.js"], "polyfills": ["zone.js"],
"assets": [ "assets": [
@ -30,12 +31,11 @@
"scripts": [ "scripts": [
"node_modules/cookieconsent/build/cookieconsent.min.js" "node_modules/cookieconsent/build/cookieconsent.min.js"
], ],
"vendorChunk": true,
"extractLicenses": false, "extractLicenses": false,
"buildOptimizer": false,
"sourceMap": true, "sourceMap": true,
"optimization": false, "optimization": false,
"namedChunks": true "namedChunks": true,
"browser": "src/main.ts"
}, },
"configurations": { "configurations": {
"production": { "production": {
@ -50,8 +50,6 @@
"sourceMap": false, "sourceMap": false,
"namedChunks": false, "namedChunks": false,
"extractLicenses": true, "extractLicenses": true,
"vendorChunk": false,
"buildOptimizer": true,
"fileReplacements": [ "fileReplacements": [
{ {
"replace": "src/environments/environment.ts", "replace": "src/environments/environment.ts",

View File

@ -5,7 +5,7 @@
"scripts": { "scripts": {
"ng": "ng", "ng": "ng",
"start": "ng serve --host 0.0.0.0 --port 9000 --proxy-config proxy.conf.json", "start": "ng serve --host 0.0.0.0 --port 9000 --proxy-config proxy.conf.json",
"build": "ng build --configuration production --output-hashing=none --aot --delete-output-path --build-optimizer --deploy-url /uds/res/modern/ --base-href /uds/page", "build": "ng build --configuration production --output-hashing=none --aot --delete-output-path --deploy-url /uds/res/modern/ --base-href /uds/page",
"postbuild": "python3 toUDS.py", "postbuild": "python3 toUDS.py",
"test": "ng test", "test": "ng test",
"lint": "ng lint", "lint": "ng lint",
@ -17,16 +17,16 @@
}, },
"private": true, "private": true,
"dependencies": { "dependencies": {
"@angular/animations": "^17.2.2", "@angular/animations": "^18.0.3",
"@angular/cdk": "^17.2.1", "@angular/cdk": "^18.0.3",
"@angular/common": "^17.2.2", "@angular/common": "^18.0.3",
"@angular/compiler": "^17.2.2", "@angular/compiler": "^18.0.3",
"@angular/core": "^17.2.2", "@angular/core": "^18.0.3",
"@angular/forms": "^17.2.2", "@angular/forms": "^18.0.3",
"@angular/material": "^17.2.1", "@angular/material": "^18.0.3",
"@angular/platform-browser": "^17.2.2", "@angular/platform-browser": "^18.0.3",
"@angular/platform-browser-dynamic": "^17.2.2", "@angular/platform-browser-dynamic": "^18.0.3",
"@angular/router": "^17.2.2", "@angular/router": "^18.0.3",
"cookieconsent": "^3.1.1", "cookieconsent": "^3.1.1",
"core-js": "^3.21.1", "core-js": "^3.21.1",
"rxjs": "^7.5.4", "rxjs": "^7.5.4",
@ -34,26 +34,26 @@
"zone.js": "^0.14.3" "zone.js": "^0.14.3"
}, },
"devDependencies": { "devDependencies": {
"@angular-devkit/build-angular": "^17.2.1", "@angular-devkit/build-angular": "^18.0.4",
"@angular-devkit/core": "^18.0.4", "@angular-devkit/core": "^18.0.4",
"@angular-devkit/schematics": "^18.0.4", "@angular-devkit/schematics": "^18.0.4",
"@angular-eslint/builder": "^17.2.1", "@angular-eslint/builder": "^18.0.1",
"@angular-eslint/eslint-plugin": "^17.2.1", "@angular-eslint/eslint-plugin": "^18.0.1",
"@angular-eslint/eslint-plugin-template": "^17.2.1", "@angular-eslint/eslint-plugin-template": "^18.0.1",
"@angular-eslint/schematics": "17.2.1", "@angular-eslint/schematics": "18.0.1",
"@angular-eslint/template-parser": "^17.2.1", "@angular-eslint/template-parser": "^18.0.1",
"@angular/cli": "^17.2.1", "@angular/cli": "^18.0.4",
"@angular/compiler-cli": "^17.2.2", "@angular/compiler-cli": "^18.0.3",
"@angular/language-service": "^17.2.2", "@angular/language-service": "^18.0.3",
"@types/jasmine": "~3.6.0", "@types/jasmine": "~3.6.0",
"@types/jasminewd2": "~2.0.6", "@types/jasminewd2": "~2.0.6",
"@types/node": "^12.11.1", "@types/node": "^12.11.1",
"@typescript-eslint/eslint-plugin": "^7.13.1", "@typescript-eslint/eslint-plugin": "^7.2.0",
"@typescript-eslint/parser": "^6.10.0", "@typescript-eslint/parser": "^7.2.0",
"@typescript-eslint/utils": "^7.13.1", "@typescript-eslint/utils": "^7.2.0",
"browser-sync": "^3.0.2", "browser-sync": "^3.0.2",
"codelyzer": "^6.0.2", "codelyzer": "^6.0.2",
"eslint": "^9.5.0", "eslint": "^8.57.0",
"eslint-config-prettier": "^8.5.0", "eslint-config-prettier": "^8.5.0",
"eslint-plugin-import": "^2.25.4", "eslint-plugin-import": "^2.25.4",
"eslint-plugin-prefer-arrow": "^1.2.3", "eslint-plugin-prefer-arrow": "^1.2.3",
@ -69,6 +69,6 @@
"prettier-eslint": "^13.0.0", "prettier-eslint": "^13.0.0",
"protractor": "^7.0.0", "protractor": "^7.0.0",
"ts-node": "~8.4.1", "ts-node": "~8.4.1",
"typescript": "~5.2.2" "typescript": "~5.4.5"
} }
} }

View File

@ -2,7 +2,7 @@ import { BrowserModule } from '@angular/platform-browser';
import { LayoutModule } from '@angular/cdk/layout'; import { LayoutModule } from '@angular/cdk/layout';
import { NgModule } from '@angular/core'; import { NgModule } from '@angular/core';
import { HttpClientModule } from '@angular/common/http'; import { provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';
import { AppRoutingModule } from './modules/app-routing.module'; import { AppRoutingModule } from './modules/app-routing.module';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
@ -42,8 +42,7 @@ import { FilterComponent } from './gui/components/filter/filter.component';
import { CredentialsModalComponent } from './gui/credentials-modal/credentials-modal.component'; import { CredentialsModalComponent } from './gui/credentials-modal/credentials-modal.component';
@NgModule({ @NgModule({ declarations: [
declarations: [
AppComponent, AppComponent,
NavbarComponent, NavbarComponent,
TranslateDirective, TranslateDirective,
@ -64,18 +63,13 @@ import { CredentialsModalComponent } from './gui/credentials-modal/credentials-m
FilterComponent, FilterComponent,
MfaComponent, MfaComponent,
], ],
imports: [ bootstrap: [AppComponent], imports: [BrowserModule,
BrowserModule,
LayoutModule, LayoutModule,
HttpClientModule,
AppRoutingModule, AppRoutingModule,
BrowserAnimationsModule, BrowserAnimationsModule,
AppMaterialModule, AppMaterialModule], providers: [
],
providers: [
UDSApiService, UDSApiService,
UDSGuiService, UDSGuiService,
], provideHttpClient(withInterceptorsFromDi()),
bootstrap: [AppComponent] ] })
})
export class AppModule { } export class AppModule { }

View File

@ -1,4 +1,4 @@
@import "globals.scss"; @import "../../../globals.scss";
.uds-nav { .uds-nav {
position: fixed; position: fixed;

View File

@ -1,32 +1,32 @@
@use '@angular/material' as mat; @use '@angular/material' as mat;
@include mat.core(); @include mat.core();
$angular-primary: mat.define-palette(mat.$indigo-palette, 500, 100, 900); $angular-primary: mat.m2-define-palette(mat.$m2-indigo-palette, 500, 100, 900);
$angular-accent: mat.define-palette(mat.$pink-palette, A200, A100, A400); $angular-accent: mat.m2-define-palette(mat.$m2-pink-palette, A200, A100, A400);
// The "warn" palette is optional and defaults to red if not specified. // The "warn" palette is optional and defaults to red if not specified.
$angular-warn: mat.define-palette(mat.$red-palette); $angular-warn: mat.m2-define-palette(mat.$m2-red-palette);
$angular-default-theme: mat.define-light-theme( $angular-default-theme: mat.m2-define-light-theme(
( (
color: ( color: (
primary: $angular-primary, primary: $angular-primary,
accent: $angular-accent, accent: $angular-accent,
warn: $angular-warn, warn: $angular-warn,
), ),
typography: mat.define-typography-config(), typography: mat.m2-define-typography-config(),
density: 0, density: 0,
) )
); );
$angular-dark-theme: mat.define-dark-theme( $angular-dark-theme: mat.m2-define-dark-theme(
( (
color: ( color: (
primary: $angular-primary, primary: $angular-primary,
accent: $angular-accent, accent: $angular-accent,
warn: $angular-warn, warn: $angular-warn,
), ),
typography: mat.define-typography-config(), typography: mat.m2-define-typography-config(),
density: 0, density: 0,
) )
); );

View File

@ -6,7 +6,7 @@
@include mat.all-component-themes($angular-default-theme); @include mat.all-component-themes($angular-default-theme);
/* Cookie consent */ /* Cookie consent */
@import '~cookieconsent/build/cookieconsent.min.css'; @import 'cookieconsent/build/cookieconsent.min.css';
// variables // variables
$font-family: 'Roboto', 'Helvetica', 'Arial', sans-serif; $font-family: 'Roboto', 'Helvetica', 'Arial', sans-serif;

View File

@ -33,14 +33,15 @@ import glob
import re import re
import typing import typing
DIST = 'dist' DIST = 'dist/browser'
THIRD_PARTY_LICENSES = 'dist/3rdpartylicenses.txt'
SRC = 'src' SRC = 'src'
UDS = os.path.join(DIST, 'uds') UDS = os.path.join(DIST, 'uds')
STATIC = 'static/modern' STATIC = 'static/modern'
TEMPLATE = 'templates/uds/modern' TEMPLATE = 'templates/uds/modern'
def mkPath(path) -> None: def make_path(path) -> None:
folder = '' folder = ''
for p in path.split(os.path.sep): for p in path.split(os.path.sep):
folder = os.path.join(folder, p) folder = os.path.join(folder, p)
@ -50,29 +51,29 @@ def mkPath(path) -> None:
pass # Already exits, ignore pass # Already exits, ignore
def locateFiles(files: typing.List[str], folder: str, extension: str) -> None: def locate_files(files: typing.List[str], folder: str, extension: str) -> None:
for f in glob.glob(folder+"/*"): for f in glob.glob(folder+"/*"):
if os.path.isdir(f): if os.path.isdir(f):
# Recurse # Recurse
locateFiles(files, os.path.join(f), extension) locate_files(files, os.path.join(f), extension)
else: else:
if os.path.splitext(f)[1][1:].lower() == extension: if os.path.splitext(f)[1][1:].lower() == extension:
files.append(f) files.append(f)
def locateHtmlFiles() -> typing.List[str]: def locate_html_files() -> typing.List[str]:
files: typing.List[str] = [] files: typing.List[str] = []
locateFiles(files, SRC, 'html') locate_files(files, SRC, 'html')
return files return files
def locateTypeScriptFiles() -> typing.List[str]: def locate_typescript_files() -> typing.List[str]:
files: typing.List[str] = [] files: typing.List[str] = []
locateFiles(files, SRC, 'ts') locate_files(files, SRC, 'ts')
return files return files
def fixIndex() -> None: def fix_index_html() -> None:
print('Fixing index.html...') print('Fixing index.html...')
translations = '<script type="text/javascript" src="{% url \'utility.jsCatalog\' LANGUAGE_CODE %}"></script>' translations = '<script type="text/javascript" src="{% url \'utility.jsCatalog\' LANGUAGE_CODE %}"></script>'
jsdata = '<script type="text/javascript" src="{% url \'utility.js\' %}"></script>' jsdata = '<script type="text/javascript" src="{% url \'utility.js\' %}"></script>'
@ -98,7 +99,7 @@ def fixIndex() -> None:
f.write(translatePattern.sub(translations + jsdata, html)) f.write(translatePattern.sub(translations + jsdata, html))
def extractTranslations(): def extract_translations():
print('Extracting translations from HTML') print('Extracting translations from HTML')
# Generate "fake" translations file (just to use django translator) # Generate "fake" translations file (just to use django translator)
@ -121,21 +122,24 @@ def extractTranslations():
# First, extract translations from typescript # First, extract translations from typescript
typeScriptTranslationPattern = re.compile(r'django\.gettext\(\s*([\'"])(?P<data>.*?)\1\)') typeScriptTranslationPattern = re.compile(r'django\.gettext\(\s*([\'"])(?P<data>.*?)\1\)')
print('// Typescript', file=output) print('// Typescript', file=output)
getTranslations(locateTypeScriptFiles, typeScriptTranslationPattern, output, strip=False) getTranslations(locate_typescript_files, typeScriptTranslationPattern, output, strip=False)
# Now extract translations from html # Now extract translations from html
htmlTranslationPattern = re.compile(r'<uds-translate[^>]*>(?P<data>.*?)</uds-translate>', re.MULTILINE | re.IGNORECASE | re.DOTALL) htmlTranslationPattern = re.compile(r'<uds-translate[^>]*>(?P<data>.*?)</uds-translate>', re.MULTILINE | re.IGNORECASE | re.DOTALL)
print('// HTML', file=output) print('// HTML', file=output)
getTranslations(locateHtmlFiles, htmlTranslationPattern, output) getTranslations(locate_html_files, htmlTranslationPattern, output)
def copyImages(): def copy_images():
print('Copying images') print('Copying images')
outputPath = os.path.join(UDS, STATIC, 'img') outputPath = os.path.join(UDS, STATIC, 'img')
mkPath(outputPath) make_path(outputPath)
for f in glob.glob(DIST + '/static/modern/img/*'): for f in glob.glob(DIST + '/static/modern/img/*'):
shutil.copy(f, outputPath) shutil.copy(f, outputPath)
def copy_third_party_licenses() -> None:
print('Copying third party licenses')
shutil.copy(THIRD_PARTY_LICENSES, os.path.join(UDS, STATIC))
def organize(): def organize():
print('Organizing content') print('Organizing content')
@ -147,13 +151,13 @@ def organize():
shutil.copy(f, os.path.join(UDS, STATIC)) shutil.copy(f, os.path.join(UDS, STATIC))
def cleanUp(): def clean_up():
print('Cleaning unneeded content') print('Cleaning unneeded content')
folder = os.path.join(UDS, STATIC) folder = os.path.join(UDS, STATIC)
os.unlink(os.path.join(folder, 'favicon.ico')) os.unlink(os.path.join(folder, 'favicon.ico'))
def createDirs(): def create_output_folders():
try: try:
print('Creating output uds dir...') print('Creating output uds dir...')
os.mkdir(UDS) os.mkdir(UDS)
@ -163,8 +167,8 @@ def createDirs():
os.mkdir(UDS) os.mkdir(UDS)
# Static folders # Static folders
mkPath(os.path.join(UDS, STATIC)) make_path(os.path.join(UDS, STATIC))
mkPath(os.path.join(UDS, TEMPLATE)) make_path(os.path.join(UDS, TEMPLATE))
# #
# def buildSource(): # def buildSource():
@ -174,12 +178,12 @@ def createDirs():
def main(): def main():
print('Use "yarn build" to correctly build for UDS') print('Use "yarn build" to correctly build for UDS')
# buildSource() # buildSource()
createDirs() create_output_folders()
extractTranslations() extract_translations()
fixIndex() fix_index_html()
copyImages() copy_images()
organize() organize()
cleanUp() clean_up()
# Updades index.html # Updades index.html

View File

@ -5,6 +5,7 @@
"baseUrl": "./", "baseUrl": "./",
"outDir": "./dist/out-tsc", "outDir": "./dist/out-tsc",
"forceConsistentCasingInFileNames": true, "forceConsistentCasingInFileNames": true,
"esModuleInterop": true,
"strict": true, "strict": true,
"noImplicitOverride": true, "noImplicitOverride": true,
"noPropertyAccessFromIndexSignature": true, "noPropertyAccessFromIndexSignature": true,
@ -12,7 +13,6 @@
"noFallthroughCasesInSwitch": true, "noFallthroughCasesInSwitch": true,
"sourceMap": true, "sourceMap": true,
"declaration": false, "declaration": false,
"downlevelIteration": true,
"experimentalDecorators": true, "experimentalDecorators": true,
"moduleResolution": "node", "moduleResolution": "node",
"importHelpers": true, "importHelpers": true,