import { ChangeDetectionStrategy, Component, inject, signal } from '@angular/core'; import { email, form, FormField, maxLength, required, submit } from '@angular/forms/signals'; import { RouterLink } from '@angular/router'; import { injectMutation } from '@tanstack/angular-query-experimental'; import { injectAuthService } from '@/core/services/auth.service'; <% if (hasNotifications) { %>import { PushNotificationService } from '@/core/services/push-notification.service'; <% } %>import { injectUIService } from '@/core/services/ui.service'; import { CheckboxComponent } from '@/shared/forms/checkbox/checkbox.component'; import { signalFormErrors } from '@/shared/forms/form-validations'; import { InputComponent } from '@/shared/forms/input/input.component'; import { MainLayoutComponent } from '@/shared/layout/main-layout/main-layout.component'; import { ButtonDirective } from '@/shared/ui/button.directive'; @Component({ selector: 'app-signup', templateUrl: './signup.component.html', styleUrls: ['./signup.component.scss'], changeDetection: ChangeDetectionStrategy.OnPush, imports: [ RouterLink, FormField, MainLayoutComponent, InputComponent, CheckboxComponent, ButtonDirective, ], standalone: true, }) export default class SignupComponent { private authSrv = injectAuthService(); private uiServ = injectUIService(); <% if (hasNotifications) { %> private pushNotificationService = inject(PushNotificationService); <% } %> signupModel = signal({ name: '', email: '', acceptTerms: false, }); signupForm = form(this.signupModel, (path) => { required(path.name, { message: signalFormErrors.required }); maxLength(path.name, 40, { message: signalFormErrors.maxLength(40) }); required(path.email, { message: signalFormErrors.required }); email(path.email, { message: signalFormErrors.email }); required(path.acceptTerms, { message: signalFormErrors.acceptTerms }); }); signup = injectMutation(() => ({ mutationFn: (_: void) => this.authSrv.signup(this.signupModel()), <% if (hasNotifications) { %> onSuccess: () => this.pushNotificationService.ensurePushSubscription(), <% } %> onError: (error) => this.uiServ.showErrorAlert(error.message), })); onSubmit(event: Event) { event.preventDefault(); submit(this.signupForm, { action: async () => { this.signup.mutate(); }, }); } }