UNPKG

@asi-ngtools/lib

Version:

This project is a little components library, simple to use, which will help you to simplify your project.

148 lines (147 loc) 13.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { FormControl, FormGroupDirective, FormGroupName } from '@angular/forms'; import { Injector } from '@angular/core'; import { AsiMessage } from './asi-message.directive'; import { Component, Input, ElementRef, ContentChildren, QueryList, Inject, forwardRef, } from '@angular/core'; export class AsiErrorMessages { /** * @param {?} element * @param {?} formGroupDirective * @param {?} injector */ constructor(element, formGroupDirective, injector) { this.element = element; this.formGroupDirective = formGroupDirective; this.injector = injector; /** * Display error one by one */ this.showOne = false; this.errorMessages = []; this.submitted = false; } /** * @return {?} */ ngOnInit() { /** @type {?} */ const formGroupName = this.injector.get(FormGroupName, null); if (this.forName) { if (!formGroupName) { this.for = /** @type {?} */ (this.formGroupDirective.control.controls[this.forName]); } else { /** @type {?} */ const groupFormName = /** @type {?} */ (this.formGroupDirective.control.controls[formGroupName.name]); this.for = /** @type {?} */ (groupFormName.controls[this.forName]); } } this.formGroupDirective.ngSubmit.subscribe(() => { this.submitted = true; this.onStatusChange(); }); this.for.statusChanges.subscribe(() => { this.submitted = false; this.onStatusChange(); }); } /** * @return {?} */ ngAfterContentInit() { if (this.isFieldRequired()) { this.element.nativeElement.parentElement.classList.add('asi-required'); } } /** * @return {?} */ isFieldRequired() { /** @type {?} */ let required = false; this.messages.forEach(element => { if (element.error === 'required') { required = true; } }); return required; } /** * Methode appellée à chaque changement de l'entré du composant "for" * @return {?} */ onStatusChange() { /** @type {?} */ let messagesError = []; if (this.for.touched || this.submitted) { if (this.for.errors != null && this.messages != null) { this.messages.forEach(message => { if (this.for.errors[message.error] && (!message.onSubmit || this.submitted) && !(this.showOne && messagesError.length > 0)) { messagesError.push(message); } }); } } this.errorMessages = messagesError; if (this.errorMessages.length > 0) { this.element.nativeElement.parentElement.classList.add('asi-has-error'); this.element.nativeElement.classList.add('active'); } else { this.element.nativeElement.parentElement.classList.remove('asi-has-error'); this.element.nativeElement.classList.remove('active'); } } } AsiErrorMessages.decorators = [ { type: Component, args: [{ selector: 'error-messages , asi-error-messages', host: { 'class': 'asi-component asi-error-messages' }, template: "<div class=\"errorPanel\">\r\n <ng-content select=\"message\"></ng-content>\r\n <div *ngFor=\"let message of errorMessages\" class=\"asi-error-message\">{{message.value | translate}}</div>\r\n</div>\r\n" }] } ]; /** @nocollapse */ AsiErrorMessages.ctorParameters = () => [ { type: ElementRef }, { type: FormGroupDirective, decorators: [{ type: Inject, args: [forwardRef(() => FormGroupDirective),] }] }, { type: Injector } ]; AsiErrorMessages.propDecorators = { for: [{ type: Input }], forName: [{ type: Input }], showOne: [{ type: Input }], messages: [{ type: ContentChildren, args: [AsiMessage,] }] }; if (false) { /** * link the error messages to a formControl * @type {?} */ AsiErrorMessages.prototype.for; /** * link the error messages to a formControl by is name * @type {?} */ AsiErrorMessages.prototype.forName; /** * Display error one by one * @type {?} */ AsiErrorMessages.prototype.showOne; /** @type {?} */ AsiErrorMessages.prototype.messages; /** @type {?} */ AsiErrorMessages.prototype.errorMessages; /** @type {?} */ AsiErrorMessages.prototype.submitted; /** @type {?} */ AsiErrorMessages.prototype.element; /** @type {?} */ AsiErrorMessages.prototype.formGroupDirective; /** @type {?} */ AsiErrorMessages.prototype.injector; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-error-messages.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-error-messages/asi-error-messages.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormControl, FormGroupDirective, FormGroupName, FormGroup } from '@angular/forms';\nimport { Injector } from '@angular/core';\nimport { AsiMessage } from './asi-message.directive';\nimport {\n  Component, Input, ElementRef, OnInit, ContentChildren,\n  AfterContentInit, QueryList, Inject, forwardRef,\n} from '@angular/core';\n\n@Component({\n  selector: 'error-messages , asi-error-messages',\n  host: { 'class': 'asi-component asi-error-messages' },\n  templateUrl: 'asi-error-messages.component.html'\n})\nexport class AsiErrorMessages implements OnInit, AfterContentInit {\n\n  /** link the error messages to a formControl */\n  @Input() for: FormControl;\n  /** link the error messages to a formControl by is name */\n  @Input() forName: string;\n  /** Display error one by one */\n  @Input() showOne = false;\n\n  @ContentChildren(AsiMessage) messages: QueryList<AsiMessage>;\n\n  errorMessages: Array<AsiMessage> = [];\n  submitted = false;\n\n  constructor(private element: ElementRef,\n    @Inject(forwardRef(() => FormGroupDirective)) private formGroupDirective: FormGroupDirective,\n    private injector: Injector) {\n  }\n\n  ngOnInit() {\n    const formGroupName = this.injector.get(FormGroupName, null);\n    if (this.forName) {\n      if (!formGroupName) {\n        this.for = <FormControl>this.formGroupDirective.control.controls[this.forName];\n      } else {\n        const groupFormName: FormGroup = <FormGroup>this.formGroupDirective.control.controls[formGroupName.name];\n        this.for = <FormControl>groupFormName.controls[this.forName];\n      }\n    }\n\n    this.formGroupDirective.ngSubmit.subscribe(() => {\n      this.submitted = true;\n      this.onStatusChange();\n    });\n    this.for.statusChanges.subscribe(() => {\n      this.submitted = false;\n      this.onStatusChange();\n    });\n  }\n\n  ngAfterContentInit() {\n    if (this.isFieldRequired()) {\n      this.element.nativeElement.parentElement.classList.add('asi-required');\n    }\n  }\n\n  isFieldRequired() {\n    let required = false;\n    this.messages.forEach(element => {\n      if (element.error === 'required') {\n        required = true;\n      }\n    });\n    return required;\n  }\n\n  /**\n   * Methode appellée à chaque changement de l'entré du composant \"for\"\n   */\n  onStatusChange() {\n    let messagesError: Array<AsiMessage> = [];\n    if (this.for.touched || this.submitted) {\n      if (this.for.errors != null && this.messages != null) {\n        this.messages.forEach(message => {\n          if (this.for.errors[message.error] && (!message.onSubmit || this.submitted) && !(this.showOne && messagesError.length > 0)) {\n            messagesError.push(message);\n          }\n        });\n      }\n    }\n    this.errorMessages = messagesError;\n    if (this.errorMessages.length > 0) {\n      this.element.nativeElement.parentElement.classList.add('asi-has-error');\n      this.element.nativeElement.classList.add('active');\n    } else {\n      this.element.nativeElement.parentElement.classList.remove('asi-has-error');\n      this.element.nativeElement.classList.remove('active');\n    }\n  }\n}\n"]}