This repository has been archived on 2025-06-18. You can view files and clone it, but you cannot make any changes to its state, such as pushing and creating new issues, pull requests or comments.
casino/frontend/src/app/feature/auth/register/register.component.ts
csimonis 64a1155eed
All checks were successful
CI / Get Changed Files (pull_request) Successful in 32s
CI / Checkstyle Main (pull_request) Has been skipped
CI / Docker backend validation (pull_request) Has been skipped
CI / oxlint (pull_request) Successful in 30s
CI / eslint (pull_request) Successful in 32s
CI / prettier (pull_request) Successful in 37s
CI / Docker frontend validation (pull_request) Successful in 59s
CI / test-build (pull_request) Successful in 59s
chore: prettier
2025-05-15 14:30:13 +02:00

87 lines
2.6 KiB
TypeScript

import { Component, EventEmitter, Output, signal } from '@angular/core';
import { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';
import { RegisterRequest } from '../../../model/auth/RegisterRequest';
import { AuthService } from '@service/auth.service';
import { CommonModule } from '@angular/common';
import { HttpErrorResponse } from '@angular/common/http';
@Component({
selector: 'app-register',
standalone: true,
imports: [CommonModule, ReactiveFormsModule],
templateUrl: './register.component.html',
})
export class RegisterComponent {
registerForm: FormGroup;
errorMessage = signal<string>('');
isLoading = signal<boolean>(false);
fieldErrors = signal<Record<string, string>>({});
@Output() switchForm = new EventEmitter<void>();
@Output() closeDialog = new EventEmitter<void>();
constructor(
private fb: FormBuilder,
private authService: AuthService
) {
this.registerForm = this.fb.group({
email: ['', [Validators.required, Validators.email]],
username: ['', [Validators.required, Validators.minLength(3)]],
password: ['', [Validators.required, Validators.minLength(6)]],
});
}
get form() {
return this.registerForm.controls;
}
switchToLogin(): void {
this.switchForm.emit();
}
onSubmit(): void {
if (this.registerForm.invalid) {
return;
}
this.isLoading.set(true);
this.errorMessage.set('');
this.fieldErrors.set({});
const registerRequest: RegisterRequest = {
email: this.form['email'].value,
username: this.form['username'].value,
password: this.form['password'].value,
};
this.authService.register(registerRequest).subscribe({
next: () => {
this.isLoading.set(false);
this.closeDialog.emit();
this.switchToLogin();
},
error: (err: HttpErrorResponse) => {
this.isLoading.set(false);
if (err.status === 409) {
const message = err.error?.message;
switch (message) {
case 'Email is already in use':
this.fieldErrors.update((errors) => ({
...errors,
email: 'Diese E-Mail-Adresse wird bereits verwendet.',
}));
break;
case 'Username is already taken':
this.fieldErrors.update((errors) => ({
...errors,
username: 'Dieser Benutzername ist bereits vergeben.',
}));
break;
}
} else {
this.errorMessage.set(err.error?.message || 'Failed to register. Please try again.');
}
},
});
}
}