Skip to content

Commit

Permalink
feat(auth-form): integrates email and password
Browse files Browse the repository at this point in the history
  • Loading branch information
Felipe Luna committed Feb 18, 2024
1 parent 71f0427 commit 025fdba
Show file tree
Hide file tree
Showing 10 changed files with 137 additions and 9 deletions.
Original file line number Diff line number Diff line change
@@ -1 +1,29 @@
<p>auth-form-email works!</p>
<mat-form-field appearance="outline" class="form-field">
<mat-label>Informe seu email</mat-label>
<input
[formControl]="control"
matInput
placeholder="Ex: [email protected]"
type="email"
/>
@if (control.hasError('email') && !control.hasError('required')) {
<mat-error data-testid="error-email"
>Por favor, insira um email válido</mat-error
>
} @if (control.hasError('required')) {
<mat-error data-testid="error-required"
>O email é <strong>obrigatório</strong></mat-error
>
}
</mat-form-field>

<div class="container">
<button
[disabled]="control.invalid"
[routerLink]="['../', 'password']"
mat-button
color="primary"
>
Próximo
</button>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
.form-field {
width: 100%;
}

.container {
display: flex;
justify-content: end;
}
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
import { RouterTestingModule } from '@angular/router/testing';
import { NoopAnimationsModule } from '@angular/platform-browser/animations';
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { AuthFormEmailComponent } from './auth-form-email.component';
import { AuthFormComponent } from '../auth-form.component';
Expand All @@ -8,7 +10,11 @@ describe('AuthFormEmailComponent', () => {

beforeEach(async () => {
await TestBed.configureTestingModule({
imports: [AuthFormEmailComponent],
imports: [
AuthFormEmailComponent,
NoopAnimationsModule,
RouterTestingModule,
],
providers: [AuthFormComponent],
}).compileComponents();

Expand All @@ -20,4 +26,38 @@ describe('AuthFormEmailComponent', () => {
it('should create', () => {
expect(component).toBeTruthy();
});

it('should enable button when control is valid', () => {
const button: HTMLButtonElement =
fixture.nativeElement.querySelector('button');
expect(button.disabled).toBe(true);

component.control.setValue('[email protected]');

fixture.detectChanges();

expect(button.disabled).toBe(false);
});

it('should display required error message', () => {
component.control.setValue('');
component.control.markAsTouched();
fixture.detectChanges();

const errorMessage = fixture.nativeElement.querySelector(
'[data-testid="error-required"]'
);
expect(errorMessage).toBeTruthy();
});

it('should display email error message', () => {
component.control.setValue('invalidemail');
component.control.markAsTouched();
fixture.detectChanges();

const errorMessage = fixture.nativeElement.querySelector(
'[data-testid="error-email"]'
);
expect(errorMessage).toBeTruthy();
});
});
Original file line number Diff line number Diff line change
@@ -1,19 +1,33 @@
import { AuthFormComponent } from './../auth-form.component';
import { Component, OnInit } from '@angular/core';
import { CommonModule } from '@angular/common';
import { MatButtonModule } from '@angular/material/button';
import { MatInputModule } from '@angular/material/input';
import { FormControl, ReactiveFormsModule } from '@angular/forms';
import { RouterModule } from '@angular/router';

@Component({
selector: 'lib-auth-form-email',
standalone: true,
imports: [CommonModule],
imports: [
CommonModule,
MatButtonModule,
MatInputModule,
ReactiveFormsModule,
RouterModule,
],
templateUrl: './auth-form-email.component.html',
styleUrl: './auth-form-email.component.scss',
})
export class AuthFormEmailComponent implements OnInit {
control!: FormControl<string>;

constructor(private authformComponent: AuthFormComponent) {}

ngOnInit(): void {
// eslint-disable-next-line no-console
console.log(this.authformComponent.form.value);

this.control = this.authformComponent.form.controls.email;
}
}
Original file line number Diff line number Diff line change
@@ -1 +1,13 @@
<p>auth-form-password works!</p>
<mat-form-field appearance="outline" class="form-field">
<mat-label>Informe sua senha</mat-label>
<input
[formControl]="this.control"
matInput
placeholder="Mínimo de 6 caracteres"
type="password"
/>
</mat-form-field>

<div class="container">
<button mat-button color="primary">Entrar</button>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
.form-field {
width: 100%;
}

.container {
display: flex;
justify-content: end;
}
Original file line number Diff line number Diff line change
@@ -1,13 +1,21 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { AuthFormPasswordComponent } from './auth-form-password.component';
import { NoopAnimationsModule } from '@angular/platform-browser/animations';
import { RouterTestingModule } from '@angular/router/testing';
import { AuthFormComponent } from '../auth-form.component';

describe('AuthFormPasswordComponent', () => {
let component: AuthFormPasswordComponent;
let fixture: ComponentFixture<AuthFormPasswordComponent>;

beforeEach(async () => {
await TestBed.configureTestingModule({
imports: [AuthFormPasswordComponent],
imports: [
AuthFormPasswordComponent,
NoopAnimationsModule,
RouterTestingModule,
],
providers: [AuthFormComponent],
}).compileComponents();

fixture = TestBed.createComponent(AuthFormPasswordComponent);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,17 @@
import { Component } from '@angular/core';
import { Component, inject } from '@angular/core';
import { CommonModule } from '@angular/common';
import { MatButtonModule } from '@angular/material/button';
import { MatInputModule } from '@angular/material/input';
import { AuthFormComponent } from '../auth-form.component';
import { ReactiveFormsModule } from '@angular/forms';

@Component({
selector: 'lib-auth-form-password',
standalone: true,
imports: [CommonModule],
imports: [CommonModule, MatButtonModule, MatInputModule, ReactiveFormsModule],
templateUrl: './auth-form-password.component.html',
styleUrl: './auth-form-password.component.scss',
})
export class AuthFormPasswordComponent {}
export class AuthFormPasswordComponent {
control = inject(AuthFormComponent).form.controls.password;
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
<form class="form" [formGroup]="form">
<mat-card class="form__card">
<h1>Login</h1>
<router-outlet></router-outlet>
</mat-card>
</form>
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,10 @@ import { MatCardModule } from '@angular/material/card';
})
export class AuthFormComponent {
form = new FormGroup({
email: new FormControl('', [Validators.required, Validators.email]),
email: new FormControl('', {
nonNullable: true,
validators: [Validators.required, Validators.email],
}),
password: new FormControl('', [
Validators.required,
Validators.minLength(6),
Expand Down

0 comments on commit 025fdba

Please sign in to comment.