Compare commits

..

5 commits

Author SHA1 Message Date
77c48982fa
Merge pull request 'refactor: immediately display login error' (!185) from refactor-login into main
All checks were successful
Release / Release (push) Successful in 1m3s
Release / Build Backend Image (push) Successful in 29s
Release / Build Frontend Image (push) Successful in 34s
Reviewed-on: #185
Reviewed-by: Constantin Simonis <constantin@simonis.lol>
2025-05-14 07:59:31 +00:00
Phan Huy Tran
64b2e28566 style: run quality tools
All checks were successful
CI / Get Changed Files (pull_request) Successful in 8s
CI / Checkstyle Main (pull_request) Has been skipped
CI / Docker backend validation (pull_request) Has been skipped
CI / oxlint (pull_request) Successful in 27s
CI / eslint (pull_request) Successful in 34s
CI / Docker frontend validation (pull_request) Successful in 46s
CI / prettier (pull_request) Successful in 24s
CI / test-build (pull_request) Successful in 31s
2025-05-14 09:54:24 +02:00
Phan Huy Tran
5f9d60d332 refactor: immediately display login error 2025-05-14 09:54:24 +02:00
b37e48da2e
Merge pull request 'fix: Add needs' (!184) from add-needs-to-docker-pipelines into main
Reviewed-on: #184
Reviewed-by: Constantin Simonis <constantin@simonis.lol>
2025-05-14 07:40:38 +00:00
2995065dfd fix: Add needs
All checks were successful
CI / Get Changed Files (pull_request) Successful in 7s
CI / Docker frontend validation (pull_request) Successful in 12s
CI / Docker backend validation (pull_request) Successful in 12s
CI / oxlint (pull_request) Successful in 24s
CI / eslint (pull_request) Successful in 32s
CI / prettier (pull_request) Successful in 27s
CI / Checkstyle Main (pull_request) Successful in 1m8s
CI / test-build (pull_request) Successful in 36s
2025-05-14 09:38:01 +02:00
3 changed files with 33 additions and 27 deletions

View file

@ -77,6 +77,7 @@ jobs:
validate-docker-frontend: validate-docker-frontend:
runs-on: ubuntu-latest runs-on: ubuntu-latest
name: Docker frontend validation name: Docker frontend validation
needs: changed_files
if: ${{ needs.changed_files.outputs.frontend == 'true' || needs.changed_files.outputs.workflow == 'true' }} if: ${{ needs.changed_files.outputs.frontend == 'true' || needs.changed_files.outputs.workflow == 'true' }}
container: container:
image: catthehacker/ubuntu:act-latest image: catthehacker/ubuntu:act-latest
@ -93,6 +94,7 @@ jobs:
validate-docker-backend: validate-docker-backend:
runs-on: ubuntu-latest runs-on: ubuntu-latest
name: Docker backend validation name: Docker backend validation
needs: changed_files
if: ${{ needs.changed_files.outputs.backend == 'true' || needs.changed_files.outputs.workflow == 'true' }} if: ${{ needs.changed_files.outputs.backend == 'true' || needs.changed_files.outputs.workflow == 'true' }}
container: container:
image: catthehacker/ubuntu:act-latest image: catthehacker/ubuntu:act-latest

View file

@ -2,9 +2,11 @@
<div class="modal-card max-w-md w-full"> <div class="modal-card max-w-md w-full">
<h2 class="modal-heading text-center">Anmelden</h2> <h2 class="modal-heading text-center">Anmelden</h2>
<div *ngIf="errorMessage" class="bg-accent-red text-white p-4 rounded mb-4"> @if (errorMessage()) {
{{ errorMessage }} <div class="bg-accent-red text-white p-4 rounded mb-4">
</div> {{ errorMessage() }}
</div>
}
<form [formGroup]="loginForm" (ngSubmit)="onSubmit()" class="space-y-4"> <form [formGroup]="loginForm" (ngSubmit)="onSubmit()" class="space-y-4">
<div> <div>
@ -19,14 +21,13 @@
placeholder="Gib deinen Benutzernamen oder E-Mail ein" placeholder="Gib deinen Benutzernamen oder E-Mail ein"
/> />
<div @if (form['usernameOrEmail'].touched && form['usernameOrEmail'].errors) {
*ngIf="form['usernameOrEmail'].touched && form['usernameOrEmail'].errors" <div class="text-accent-red mt-1 text-sm">
class="text-accent-red mt-1 text-sm" @if (form['usernameOrEmail'].errors['required']) {
> <span>Benutzername oder E-Mail ist erforderlich</span>
<span *ngIf="form['usernameOrEmail'].errors?.['required']"> }
Benutzername oder E-Mail ist erforderlich </div>
</span> }
</div>
</div> </div>
<div> <div>
@ -41,21 +42,22 @@
placeholder="Gib dein Passwort ein" placeholder="Gib dein Passwort ein"
/> />
<div @if (form['password'].touched && form['password'].errors) {
*ngIf="form['password'].touched && form['password'].errors" <div class="text-accent-red mt-1 text-sm">
class="text-accent-red mt-1 text-sm" @if (form['password'].errors['required']) {
> <span>Passwort ist erforderlich</span>
<span *ngIf="form['password'].errors?.['required']">Passwort ist erforderlich</span> }
</div> </div>
}
</div> </div>
<div class="pt-2"> <div class="pt-2">
<button <button
type="submit" type="submit"
[disabled]="loginForm.invalid || isLoading" [disabled]="loginForm.invalid || isLoading()"
class="button-primary w-full py-2.5 rounded" class="button-primary w-full py-2.5 rounded"
> >
{{ isLoading ? 'Anmeldung läuft...' : 'Anmelden' }} {{ isLoading() ? 'Anmeldung läuft...' : 'Anmelden' }}
</button> </button>
</div> </div>
</form> </form>

View file

@ -1,8 +1,8 @@
import { Component } from '@angular/core'; import { Component, signal } from '@angular/core';
import { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms'; import { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';
import { Router, RouterLink } from '@angular/router'; import { Router, RouterLink } from '@angular/router';
import { LoginRequest } from '../../../model/auth/LoginRequest'; import { LoginRequest } from '../../../model/auth/LoginRequest';
import { AuthService } from '../../../service/auth.service'; import { AuthService } from '@service/auth.service';
import { CommonModule } from '@angular/common'; import { CommonModule } from '@angular/common';
@Component({ @Component({
@ -13,8 +13,8 @@ import { CommonModule } from '@angular/common';
}) })
export class LoginComponent { export class LoginComponent {
loginForm: FormGroup; loginForm: FormGroup;
errorMessage = ''; errorMessage = signal('');
isLoading = false; isLoading = signal(false);
constructor( constructor(
private fb: FormBuilder, private fb: FormBuilder,
@ -36,8 +36,8 @@ export class LoginComponent {
return; return;
} }
this.isLoading = true; this.isLoading.set(true);
this.errorMessage = ''; this.errorMessage.set('');
const loginRequest: LoginRequest = { const loginRequest: LoginRequest = {
usernameOrEmail: this.form['usernameOrEmail'].value, usernameOrEmail: this.form['usernameOrEmail'].value,
@ -49,8 +49,10 @@ export class LoginComponent {
this.router.navigate(['/home']); this.router.navigate(['/home']);
}, },
error: (err) => { error: (err) => {
this.isLoading = false; this.isLoading.set(false);
this.errorMessage = err.error?.message || 'Failed to login. Please check your credentials.'; this.errorMessage.set(
err.error?.message || 'Failed to login. Please check your credentials.'
);
}, },
}); });
} }