Compare commits
5 commits
Author | SHA1 | Date | |
---|---|---|---|
77c48982fa |
|||
|
64b2e28566 | ||
|
5f9d60d332 | ||
b37e48da2e |
|||
2995065dfd |
3 changed files with 33 additions and 27 deletions
|
@ -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
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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.'
|
||||||
|
);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
Reference in a new issue