@asi-ngtools/lib
Version:
This project is a little components library, simple to use, which will help you to simplify your project.
163 lines (162 loc) • 14 kB
JavaScript
/**
* @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';
var AsiErrorMessages = /** @class */ (function () {
function AsiErrorMessages(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 {?}
*/
AsiErrorMessages.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var formGroupName = this.injector.get(FormGroupName, null);
if (this.forName) {
if (!formGroupName) {
this.for = /** @type {?} */ (this.formGroupDirective.control.controls[this.forName]);
}
else {
/** @type {?} */
var groupFormName = /** @type {?} */ (this.formGroupDirective.control.controls[formGroupName.name]);
this.for = /** @type {?} */ (groupFormName.controls[this.forName]);
}
}
this.formGroupDirective.ngSubmit.subscribe(function () {
_this.submitted = true;
_this.onStatusChange();
});
this.for.statusChanges.subscribe(function () {
_this.submitted = false;
_this.onStatusChange();
});
};
/**
* @return {?}
*/
AsiErrorMessages.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
if (this.isFieldRequired()) {
this.element.nativeElement.parentElement.classList.add('asi-required');
}
};
/**
* @return {?}
*/
AsiErrorMessages.prototype.isFieldRequired = /**
* @return {?}
*/
function () {
/** @type {?} */
var required = false;
this.messages.forEach(function (element) {
if (element.error === 'required') {
required = true;
}
});
return required;
};
/**
* Methode appellée à chaque changement de l'entré du composant "for"
*/
/**
* Methode appellée à chaque changement de l'entré du composant "for"
* @return {?}
*/
AsiErrorMessages.prototype.onStatusChange = /**
* Methode appellée à chaque changement de l'entré du composant "for"
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var messagesError = [];
if (this.for.touched || this.submitted) {
if (this.for.errors != null && this.messages != null) {
this.messages.forEach(function (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 = function () { return [
{ type: ElementRef },
{ type: FormGroupDirective, decorators: [{ type: Inject, args: [forwardRef(function () { return FormGroupDirective; }),] }] },
{ type: Injector }
]; };
AsiErrorMessages.propDecorators = {
for: [{ type: Input }],
forName: [{ type: Input }],
showOne: [{ type: Input }],
messages: [{ type: ContentChildren, args: [AsiMessage,] }]
};
return AsiErrorMessages;
}());
export { AsiErrorMessages };
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"]}