validation error component in cdk.

This commit is contained in:
David Lebee 2021-07-20 16:41:19 -04:00
parent d1b3408142
commit 91580070dc
10 changed files with 72 additions and 6 deletions

View File

@ -6,8 +6,8 @@
</div> </div>
<div class="modal-body"> <div class="modal-body">
<ng-container [ngTemplateOutlet]="template" <ng-container [ngTemplateOutlet]="template"
[ngTemplateOutletContext]="{ $implicit: commandModel, loading: loading }"></ng-container> [ngTemplateOutletContext]="{ $implicit: commandModel, loading: loading, dataSource: dataSource }"></ng-container>
<div *ngIf="hasError" class="alert alert-danger mt-2" style="white-space: pre-wrap">{{validationMessage}}</div> <div *ngIf="hasError && !disableValidationSummary" class="alert alert-danger mt-2" style="white-space: pre-wrap">{{validationMessage}}</div>
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-light" (click)="modalRef.hide()" <button type="button" class="btn btn-light" (click)="modalRef.hide()"

View File

@ -23,6 +23,7 @@ export class CommandModalComponent implements OnInit, OnDestroy {
cancelText: string; cancelText: string;
form:NgForm; form:NgForm;
validationMessage:string ; validationMessage:string ;
disableValidationSummary: boolean;
btnClass:string; btnClass:string;
successEmitter: EventEmitter<any>; successEmitter: EventEmitter<any>;
hasError: boolean; hasError: boolean;

View File

@ -22,6 +22,7 @@ export class CommandModalDirective {
@Input() animated: boolean; @Input() animated: boolean;
@Input() btnClass:string; @Input() btnClass:string;
@Input() modalSize: string; @Input() modalSize: string;
@Input() disableValidationSummary: boolean;
@Output() success: EventEmitter<any> = new EventEmitter<any>(); @Output() success: EventEmitter<any> = new EventEmitter<any>();
@ -37,6 +38,7 @@ export class CommandModalDirective {
commandModel: commandModel, commandModel: commandModel,
template: this.template, template: this.template,
title: this.commandTitle, title: this.commandTitle,
disableValidationSummary: this.disableValidationSummary === undefined ? false : this.disableValidationSummary,
refreshOnSuccess: this.refreshOnSuccess === undefined ? true : this.refreshOnSuccess, refreshOnSuccess: this.refreshOnSuccess === undefined ? true : this.refreshOnSuccess,
commandText: this.commandText || 'OK', commandText: this.commandText || 'OK',
cancelText: this.cancelText || 'Cancel', cancelText: this.cancelText || 'Cancel',

View File

@ -0,0 +1,4 @@
<ng-container *ngFor="let err of latestErrors; let isLast=last">
{{ err }}
<br *ngIf="!isLast">
</ng-container>

View File

@ -0,0 +1,34 @@
import { Component, Input, OnDestroy, OnInit } from '@angular/core';
import { IDataSource } from '@poweredsoft/data';
import { Subscription } from 'rxjs';
@Component({
selector: 'ps-ds-validation-error',
templateUrl: './ds-validation-error.component.html',
styleUrls: ['./ds-validation-error.component.scss']
})
export class DsValidationErrorComponent implements OnInit, OnDestroy {
@Input() dataSource: IDataSource<any>;
@Input() field: string;
validationErrorsSub: Subscription;
latestErrors: string[] = [];
constructor() { }
ngOnDestroy(): void {
this.validationErrorsSub?.unsubscribe();
}
ngOnInit(): void {
this.validationErrorsSub = this.dataSource.validationError$.subscribe(validationErrors => {
this.latestErrors = Object.keys(validationErrors.errors)
.filter(t => t.toLowerCase() == this.field?.toLowerCase())
.reduce<string[]>((prev, current) => {
return prev.concat(validationErrors.errors[current]);
}, []);
});
}
}

View File

@ -0,0 +1,14 @@
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { DsValidationErrorComponent } from './ds-validation-error.component';
@NgModule({
declarations: [DsValidationErrorComponent],
imports: [
CommonModule
],
exports: [DsValidationErrorComponent]
})
export class DsValidationErrorModule { }

View File

@ -23,3 +23,7 @@ export * from './lib/list-view/directives/list-view-seperator.directive';
export * from './lib/ds-search/ds-search.module'; export * from './lib/ds-search/ds-search.module';
export * from './lib/ds-search/ds-search.component'; export * from './lib/ds-search/ds-search.component';
// ds validation
export * from './lib/ds-validation-error/ds-validation-error.module';
export * from './lib/ds-validation-error/ds-validation-error.component';

View File

@ -2,7 +2,7 @@ import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common'; import { CommonModule } from '@angular/common';
import { CommandModalDemoComponent } from './command-modal-demo/command-modal-demo.component'; import { CommandModalDemoComponent } from './command-modal-demo/command-modal-demo.component';
import { CommandModalDemoRoutingModule } from './command-modal-demo-routing.module'; import { CommandModalDemoRoutingModule } from './command-modal-demo-routing.module';
import { DataGridModule } from '@poweredsoft/ngx-cdk-ui'; import { DataGridModule, DsValidationErrorModule } from '@poweredsoft/ngx-cdk-ui';
import {FormsModule} from '@angular/forms'; import {FormsModule} from '@angular/forms';
import { CommandModalModule, PaginationModule, ConfirmModalModule,CommandModule } from '@poweredsoft/ngx-bootstrap'; import { CommandModalModule, PaginationModule, ConfirmModalModule,CommandModule } from '@poweredsoft/ngx-bootstrap';
@ -11,6 +11,7 @@ import { CommandModalModule, PaginationModule, ConfirmModalModule,CommandModule
imports: [ imports: [
CommonModule, CommonModule,
CommandModalDemoRoutingModule, CommandModalDemoRoutingModule,
DsValidationErrorModule,
DataGridModule, DataGridModule,
CommandModalModule, CommandModalModule,
FormsModule, FormsModule,

View File

@ -6,6 +6,7 @@
<ng-container *psDataGridHeader> <ng-container *psDataGridHeader>
<button class="btn-primary btn" psbxCommandModal <button class="btn-primary btn" psbxCommandModal
commandTitle="Adding a new merchant" commandText="Add" commandTitle="Adding a new merchant" commandText="Add"
[dataSource]="merchantDataSource" command="addMerchant" [dataSource]="merchantDataSource" command="addMerchant"
[template]="theModal">Create a new record</button> [template]="theModal">Create a new record</button>
@ -60,14 +61,19 @@
<input type="text" [attr.disabled]="loading" [(ngModel)]="command.name" placeholder="Entermerchant new name" class="form-control"> <input type="text" [attr.disabled]="loading" [(ngModel)]="command.name" placeholder="Entermerchant new name" class="form-control">
New Address New Address
<input type="text" required [attr.disabled]="loading" [(ngModel)]="command.address" placeholder="Entermerchant new Address" class="form-control"> <input type="text" required [attr.disabled]="loading" [(ngModel)]="command.address" placeholder="Entermerchant new Address" class="form-control">
</ng-template> </ng-template>
<ng-template #theModal let-command let-loading="loading"> <ng-template #theModal let-command let-loading="loading" let-ds="dataSource">
<form > <form >
Name Name
<input type="text" required [disabled]="loading" name="name" [(ngModel)]="command.name" placeholder="Enter a merchant name" class="form-control" > <input type="text" required [disabled]="loading" name="name" [(ngModel)]="command.name" placeholder="Enter a merchant name" class="form-control" >
<ps-ds-validation-error class="text-danger d-block" [dataSource]="ds" field="name">
</ps-ds-validation-error>
Address Address
<input type="text" required [disabled]="loading" name="address" [(ngModel)]="command.address" placeholder="Enter the merchant's address" class="form-control" > <input type="text" required [disabled]="loading" name="address" [(ngModel)]="command.address" placeholder="Enter the merchant's address" class="form-control" >
<ps-ds-validation-error class="text-danger d-block" [dataSource]="ds" field="address">
</ps-ds-validation-error>
Date Date
<input type="text" required [disabled]="loading" name="address" [(ngModel)]="command.address" placeholder="Enter the merchant's address" class="form-control" > <input type="text" required [disabled]="loading" name="address" [(ngModel)]="command.address" placeholder="Enter the merchant's address" class="form-control" >
</form> </form>