Skip to content

Commit

Permalink
feat(demo): improve demo part 3
Browse files Browse the repository at this point in the history
ISSUES CLOSED: NationalBankBelgium#6
  • Loading branch information
christophercr committed Jan 17, 2019
1 parent 16661fc commit 7e8e7c0
Show file tree
Hide file tree
Showing 21 changed files with 544 additions and 209 deletions.
16 changes: 4 additions & 12 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,12 +31,8 @@ Let's just have a look at the following example:
<input type="text" formControlName="foo" />

<!-- You need to add an element for each and every error to display a different message -->
<div *ngIf="form.get('foo').hasError('required') && form.get('foo').touched">
Field is required
</div>
<div *ngIf="form.get('foo').hasError('minlength') && form.get('foo').dirty">
Min length is 5
</div>
<div *ngIf="form.get('foo').hasError('required') && form.get('foo').touched"> Field is required </div>
<div *ngIf="form.get('foo').hasError('minlength') && form.get('foo').dirty"> Min length is 5 </div>
<div *ngIf="form.get('foo').hasError('pattern') && form.get('foo').dirty">
Field must contain at least one uppercase, one lowercase, and one number
</div>
Expand All @@ -61,14 +57,10 @@ You decide how to display the messages by defining your own Error component:
<!-- Error component's template -->

<!-- you can simply display the message 'as is' -->
<div *ngFor="let error of errors" class="awesome-error-message">
{{ error.message }}
</div>
<div *ngFor="let error of errors" class="awesome-error-message"> {{ error.message }} </div>

<!-- or you can use the error's data/properties to do something fancy -->
<div *ngFor="let error of errors" [class]="getErrorClass(error)">
{{ constructDisplayedErrorMMessage(error) }}
</div>
<div *ngFor="let error of errors" [ngClass]="getErrorClass(error)"> {{ constructDisplayedErrorMMessage(error) }} </div>
```

And the messages are centralized in a service:
Expand Down
60 changes: 30 additions & 30 deletions demo-app/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 4 additions & 3 deletions demo-app/src/app/app-routing.module.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
/*tslint:disable:completed-docs */
import { NgModule } from "@angular/core";
import { Routes, RouterModule } from "@angular/router";
//import {AppComponent} from "./app.component";
import { ReactiveFormsExampleComponent } from "./pages/reactive-forms-example/reactive-forms-example.component";
import { NgxFormsExampleComponent } from "./pages/ngx-forms-example/ngx-forms-example.component";
import { TemplateDrivenFormsExampleComponent } from "./pages/template-driven-forms-example/template-driven-forms-example.component";

const routes: Routes = [
//{ path: "", component: AppComponent},
{ path: "", redirectTo: "/reactive-forms", pathMatch: "full" },
{ path: "", redirectTo: "/template-driven-forms", pathMatch: "full" },
{ path: "reactive-forms", component: ReactiveFormsExampleComponent },
{ path: "template-driven-forms", component: TemplateDrivenFormsExampleComponent },
{ path: "ngx-form-errors", component: NgxFormsExampleComponent }
];

Expand Down
5 changes: 4 additions & 1 deletion demo-app/src/app/app.component.html
Original file line number Diff line number Diff line change
@@ -1,10 +1,13 @@
<!--<img width="300" alt="Angular Logo" src="">-->
<h1 class="mat-h1">Ngx-Form-Errors</h1> <h2 class="mat-h2">Validation messages in Reactive Forms made easy</h2>

<!--<button mat-button (click)="sidenav.toggle()">Toggle Sidenav</button>-->

<mat-sidenav-container class="example-container">
<mat-sidenav mode="side" opened>
<mat-sidenav #sidenav mode="side" opened>
<app-language-selector></app-language-selector>
<mat-list>
<mat-list-item><a routerLink="/template-driven-forms" routerLinkActive="active">Template Driven Forms</a></mat-list-item>
<mat-list-item><a routerLink="/reactive-forms" routerLinkActive="active">Reactive Forms</a></mat-list-item>
<mat-list-item><a routerLink="/ngx-form-errors" routerLinkActive="active">Ngx Form Errors</a></mat-list-item>
</mat-list>
Expand Down
2 changes: 2 additions & 0 deletions demo-app/src/app/app.component.scss
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
/*
.form-group {
display: flex;
align-items: start;
Expand Down Expand Up @@ -49,3 +50,4 @@
border: 1px #000 solid;
border-radius: 6px;
}
*/
8 changes: 6 additions & 2 deletions demo-app/src/app/app.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,11 @@ import { Component, OnInit } from "@angular/core";
styleUrls: ["./app.component.scss"]
})
export class AppComponent implements OnInit {
public constructor() {}
public constructor() {
/*empty*/
}

public ngOnInit(): void {}
public ngOnInit(): void {
/*empty*/
}
}
4 changes: 3 additions & 1 deletion demo-app/src/app/app.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import { LanguageSelectorComponent, SimpleFormErrorComponent, TranslatedFormErro
import { AppRoutingModule } from "./app-routing.module";
import { ReactiveFormsExampleComponent } from "./pages/reactive-forms-example/reactive-forms-example.component";
import { NgxFormsExampleComponent } from "./pages/ngx-forms-example/ngx-forms-example.component";
import { TemplateDrivenFormsExampleComponent } from "./pages/template-driven-forms-example/template-driven-forms-example.component";

/* tslint:disable:no-hardcoded-credentials */
@NgModule({
Expand All @@ -26,7 +27,8 @@ import { NgxFormsExampleComponent } from "./pages/ngx-forms-example/ngx-forms-ex
SimpleFormErrorComponent,
TranslatedFormErrorComponent,
ReactiveFormsExampleComponent,
NgxFormsExampleComponent
NgxFormsExampleComponent,
TemplateDrivenFormsExampleComponent
],
imports: [
BrowserModule,
Expand Down
Original file line number Diff line number Diff line change
@@ -1 +1 @@
<div *ngFor="let error of errors" [class]="getErrorClass()"> {{ error.message | translate: error.params }} </div>
<div *ngFor="let error of errors" [ngClass]="getErrorClass()"> {{ error.message | translate: error.params }} </div>
Original file line number Diff line number Diff line change
Expand Up @@ -25,19 +25,18 @@ export class TranslatedFormErrorComponent implements NgxFormErrorComponent, OnIn

public checkForErrors(): void {
this.errors$.subscribe((errors: NgxFormFieldError[]) => {
// the formField can be retrieved from the "fieldName" param of any of the errors
this.errors = errors;

if (errors.length) {
// the formField can be retrieved from the "fieldName" param of any of the errors
this.fieldName = errors[0].params.fieldName;
this.translateFieldName();
}

this.errors = errors;
this.translateFieldName();
});
}

public translateFieldName(): void {
for (const error of this.errors) {
console.log("-------- translating error.params.fieldName", this.fieldName);
error.params = { ...error.params, fieldName: this.translateService.instant(this.fieldName) };
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,43 +31,63 @@
<div class="form-buttons">
<button color="primary" mat-raised-button type="submit" [disabled]="!formNgxError.valid">Submit</button>
<button color="primary" mat-raised-button type="button" (click)="getFormStatus()">Get Form status</button>
<button color="primary" mat-stroked-button type="button" (click)="toggleValidationDetails()">
{{ showValidationDetails ? "Hide validation details" : "Show validation details" }}
</button>
<button color="primary" mat-stroked-button type="button" (click)="toggleValidationSummary()">
{{ showValidationSummary ? "Hide validation summary" : "Show validation summary" }}
</button>
</div>

<div class="form-validation-info">
<div class="form-validation-info" *ngIf="showValidationDetails">
<mat-card class="form-field-info">
<div>Has errors: {{ usernameField.hasErrors }}</div> <div>Has 'required' error: {{ usernameField.hasError("required") }}</div>
<div>Is valid?: {{ usernameField.isValid() }}</div>
<div>'required' error: {{ usernameField.getError("required") | json }}</div>
<div>Is touched? {{ usernameField.hasState("touched") }}</div>
<div *ngIf="usernameField.hasErrors">Errors: {{ usernameField.errors | json }}</div>
<div>Is valid?: {{ usernameField.isValid() }}</div> <div>Is touched? {{ usernameField.hasState("touched") }}</div>
<div>
'required' error: <pre>{{ usernameField.getError("required") | json }}</pre>
</div>
<div *ngIf="usernameField.hasErrors">
Errors: <pre>{{ usernameField.errors | json }}</pre>
</div>
</mat-card>
<mat-card class="form-field-info">
<div>Has errors: {{ passwordField.hasErrors }}</div> <div>Has 'pattern' error: {{ passwordField.hasError("pattern") }}</div>
<div>Is valid?: {{ passwordField.isValid() }}</div> <div>Is touched? {{ passwordField.hasState("touched") }}</div>
<div>'pattern' error: {{ passwordField.getError("pattern") | json }}</div>
<div *ngIf="passwordField.hasErrors">Errors: {{ passwordField.errors | json }}</div>
<div>Is pattern valid?: {{ passwordField.isValid("pattern") }}</div>
<div>Is touched? {{ passwordField.hasState("touched") }}</div>
<div>
'pattern' error: <pre>{{ passwordField.getError("pattern") | json }}</pre>
</div>
<div *ngIf="passwordField.hasErrors">
Errors: <pre>{{ passwordField.errors | json }}</pre>
</div>
</mat-card>
<mat-card class="form-field-info">
<div>Has errors: {{ confirmPasswordField.hasErrors }}</div>
<div>Has 'pattern' error: {{ confirmPasswordField.hasError("pattern") }}</div>
<div>Is valid?: {{ confirmPasswordField.isValid() }}</div>
<div>Has 'required' error: {{ confirmPasswordField.hasError("required") }}</div>
<div>Is required valid?: {{ confirmPasswordField.isValid("required") }}</div>
<div>Is touched? {{ confirmPasswordField.hasState("touched") }}</div>
<div>'pattern' error: {{ confirmPasswordField.getError("pattern") | json }}</div>
<div *ngIf="confirmPasswordField.hasErrors">Errors: {{ confirmPasswordField.errors | json }}</div>
<div>
'required' error: <pre>{{ confirmPasswordField.getError("required") | json }}</pre>
</div>
<div *ngIf="confirmPasswordField.hasErrors">
Errors: <pre>{{ confirmPasswordField.errors | json }}</pre>
</div>
</mat-card>
</div>

<!-- <div class="form-validation-messages" *ngIf="usernameField.hasErrors || passwordField.hasErrors || confirmPasswordField.hasErrors">
<ul>
<li *ngIf="usernameField.hasErrors">
<ng-template ngxFormErrors="username" ngxFormErrorsFieldName="blabla"></ng-template>
</li>
<li *ngIf="passwordField.hasErrors">
<ng-template ngxFormErrors="matchingPasswords.password"></ng-template>
</li>
<li *ngIf="confirmPasswordField.hasErrors">
<ng-template *ngxFormErrors="'matchingPasswords.confirmPassword'"></ng-template>
</li>
</ul>
</div> -->
<mat-card
class="form-validation-messages"
[ngClass]="{ 'no-errors': !usernameField.hasErrors && !passwordField.hasErrors && !confirmPasswordField.hasErrors }"
*ngIf="showValidationSummary"
>
<span *ngIf="!usernameField.hasErrors && !passwordField.hasErrors && !confirmPasswordField.hasErrors">No validation errors</span>
<!-- TODO: IMPORTANT: the ngIf cannot be used here because it causes some issues with the ErrorComponent created by the ngxFormErrors -->
<div [hidden]="!usernameField.hasErrors && !passwordField.hasErrors && !confirmPasswordField.hasErrors">
<span [hidden]="!usernameField.hasErrors"><ng-template ngxFormErrors="username"></ng-template></span>
<span [hidden]="!passwordField.hasErrors"><ng-template ngxFormErrors="matchingPasswords.password"></ng-template></span>
<span [hidden]="!confirmPasswordField.hasErrors"
><ng-template ngxFormErrors="matchingPasswords.confirmPassword"></ng-template
></span>
</div>
</mat-card>
</form>
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
.form-group {
display: flex;
align-items: start;
align-items: flex-start;
flex-direction: column;
flex-wrap: wrap;

Expand All @@ -18,12 +18,13 @@
.form-buttons {
margin-top: 25px;

button:first-child {
margin-right: 20px;
}
button {
margin-left: 20px;
min-width: 150px;
}
button:first-child {
margin-left: 0;
}
}
}

Expand All @@ -33,19 +34,19 @@
flex-wrap: wrap;
justify-content: flex-start;

/*& .form-field-info {
background-color: aliceblue;
border: 1px #000 solid;
border-radius: 6px;
width: 350px;
margin: 20px;
margin-right: 20px;
}*/
& .form-field-info {
background-color: #94c6ff;
width: 350px;
margin: 20px;
margin-right: 20px;
}
}

.form-validation-messages {
margin: 20px;
background-color: cornsilk;
border: 1px #000 solid;
border-radius: 6px;
background-color: #ffb006;

&.no-errors {
background-color: #3fbf35;
}
}
Loading

0 comments on commit 7e8e7c0

Please sign in to comment.