You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

62 lines
1.8 KiB
TypeScript

import { Component, OnInit } from '@angular/core';
import { Validators, FormBuilder, FormGroup, FormControl } from '@angular/forms';
import { AuthService } from '../services/auth.service';
import { User } from '../models/user.model';
import { ModalController } from '@ionic/angular';
@Component({
selector: 'app-auth-register',
templateUrl: './auth-register.component.html',
styleUrls: ['./auth-register.component.scss'],
})
export class AuthRegisterComponent implements OnInit {
registerForm: FormGroup;
error: string;
constructor(
private formBuilder: FormBuilder,
private auth: AuthService,
private modal: ModalController
) { }
ngOnInit() {
this.registerForm = this.formBuilder.group({
password_confirm: new FormControl('', Validators.required),
password: new FormControl('', Validators.required),
email: new FormControl('', Validators.compose([
Validators.required,
Validators.pattern('^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+.[a-zA-Z0-9-.]+$')
])),
name: new FormControl('', Validators.compose([
Validators.required,
Validators.pattern('^[a-zA-Z0-9_.+-]+$')
]))
}, { validators: this.passwordsMatch });
}
onSubmit($event) {
$event.preventDefault();
if (!this.registerForm.valid) { return; }
const newuser: User = {
email: this.registerForm.controls.email.value,
name: this.registerForm.controls.name.value
};
this.auth.register(newuser, this.registerForm.controls.password.value)
.then((user) => {
this.modal.dismiss();
})
.catch((e) => {
this.error = e.statusText;
throw e;
});
}
passwordsMatch(group: FormGroup) {
return group.controls.password.value === group.controls.password_confirm.value ? null : { passwordsMisMatch: true };
}
}