Picsur/frontend/src/app/models/forms/login.control.ts

42 lines
1.2 KiB
TypeScript

import { FormControl } from '@angular/forms';
import { Fail, Failable, FT } from 'picsur-shared/dist/types/failable';
import { UserPassModel } from '../forms-dto/userpass.dto';
import {
CreatePasswordError,
CreateUsernameError,
PasswordValidators,
UsernameValidators,
} from '../validators/user.validator';
export class LoginControl {
public username = new FormControl('', UsernameValidators);
public password = new FormControl('', PasswordValidators);
public get usernameError() {
return CreateUsernameError(this.username.errors);
}
public get passwordError() {
return CreatePasswordError(this.password.errors);
}
// This getter firstly verifies the form, RawData does not
public getData(): Failable<UserPassModel> {
if (this.username.errors || this.password.errors)
return Fail(FT.Authentication, 'Invalid username or password');
else return this.getRawData();
}
public getRawData(): UserPassModel {
return {
username: this.username.value ?? '',
password: this.password.value ?? '',
};
}
public putData(data: UserPassModel) {
this.username.setValue(data.username);
this.password.setValue(data.password);
}
}