UNPKG

ngx-form-control

Version:
185 lines (184 loc) 15.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, ViewChild } from '@angular/core'; import { NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel, } from '@angular/forms'; import { BaseControlComponent } from '../../utils/base-control.component'; var FormTextareaComponent = /** @class */ (function (_super) { tslib_1.__extends(FormTextareaComponent, _super); function FormTextareaComponent() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.rows = 5; _this.readonly = false; _this.trimResult = true; _this.minLengthErrorMessage = 'Value is too short.'; return _this; } Object.defineProperty(FormTextareaComponent.prototype, "value", { get: /** * @return {?} */ function () { if (!this._innerValue) { return ''; } if ('string' !== typeof this._innerValue) { return this._innerValue; } return this.trimResult ? this._innerValue.trim() : this._innerValue; }, set: /** * @param {?} value * @return {?} */ function (value) { if (value !== this._innerValue) { this._innerValue = value; this.triggerChange(); } }, enumerable: true, configurable: true }); Object.defineProperty(FormTextareaComponent.prototype, "hasMinLengthError", { get: /** * @return {?} */ function () { return this.customTextarea.errors && this.customTextarea.errors['minlength']; }, enumerable: true, configurable: true }); Object.defineProperty(FormTextareaComponent.prototype, "invalid", { get: /** * @return {?} */ function () { if (this.hasCustomError) { return true; } if (!this.customTextarea.touched) { return false; } return this.customTextarea.invalid || this.hasRequiredError; }, enumerable: true, configurable: true }); Object.defineProperty(FormTextareaComponent.prototype, "valid", { get: /** * @return {?} */ function () { if (this.hasCustomError) { return false; } if (!this.customTextarea.touched) { return false; } return !this.customTextarea.invalid && !this.hasRequiredError; }, enumerable: true, configurable: true }); Object.defineProperty(FormTextareaComponent.prototype, "errorMessages", { get: /** * @return {?} */ function () { if (this.hasRequiredError) { return [this.requiredErrorMessage]; } if (this.hasMinLengthError) { return [this.minLengthErrorMessage]; } if (this.hasCustomError) { return this.innerCustomErrorMessages; } }, enumerable: true, configurable: true }); /** * @param {?} value * @return {?} */ FormTextareaComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this._innerValue = value; }; /** * @return {?} */ FormTextareaComponent.prototype.validate = /** * @return {?} */ function () { /** @type {?} */ var result = this.customTextarea.errors || {}; if (this.hasRequiredError) { result['required'] = true; } else { delete result['required']; } return result; }; // noinspection JSUnusedGlobalSymbols /** * @return {?} */ FormTextareaComponent.prototype.reset = /** * @return {?} */ function () { this.customTextarea.reset(); }; FormTextareaComponent.decorators = [ { type: Component, args: [{ selector: 'ngx-form-textarea', template: "<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\n\n<!--suppress HtmlFormInputWithoutLabel -->\n<textarea class=\"form-control\"\n [ngClass]=\"{'is-invalid': invalid, 'is-valid': valid}\"\n [id]=\"id\"\n [title]=\"title\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [minlength]=\"minlength\"\n [maxlength]=\"maxlength\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n [rows]=\"rows\"\n #customTextarea=\"ngModel\"></textarea>\n\n<div class=\"valid-feedback\" *ngIf=\"valid && validMessage\">{{validMessage}}</div>\n\n<div class=\"invalid-feedback\" *ngIf=\"invalid\">\n <span *ngFor=\"let message of errorMessages; let last = last;\">\n {{message}}<br *ngIf=\"!last\">\n </span>\n</div>\n", styles: [""], providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: FormTextareaComponent, multi: true }, { provide: NG_VALIDATORS, useExisting: FormTextareaComponent, multi: true } ] },] }, ]; FormTextareaComponent.propDecorators = { rows: [{ type: Input }], readonly: [{ type: Input }], minlength: [{ type: Input }], maxlength: [{ type: Input }], trimResult: [{ type: Input }], minLengthErrorMessage: [{ type: Input }], customTextarea: [{ type: ViewChild, args: ['customTextarea',] }] }; return FormTextareaComponent; }(BaseControlComponent)); export { FormTextareaComponent }; if (false) { /** @type {?} */ FormTextareaComponent.prototype.rows; /** @type {?} */ FormTextareaComponent.prototype.readonly; /** @type {?} */ FormTextareaComponent.prototype.minlength; /** @type {?} */ FormTextareaComponent.prototype.maxlength; /** @type {?} */ FormTextareaComponent.prototype.trimResult; /** @type {?} */ FormTextareaComponent.prototype.minLengthErrorMessage; /** @type {?} */ FormTextareaComponent.prototype.customTextarea; /** @type {?} */ FormTextareaComponent.prototype._innerValue; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-textarea.component.js","sourceRoot":"ng://ngx-form-control/","sources":["lib/form-textarea/form-textarea.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, ViewChild} from '@angular/core';\r\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel, ValidationErrors,} from '@angular/forms';\r\nimport {BaseControlComponent} from '../../utils/base-control.component';\r\n\r\n@Component({\r\n  selector: 'ngx-form-textarea',\r\n  template: `<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\r\n\r\n<!--suppress HtmlFormInputWithoutLabel -->\r\n<textarea class=\"form-control\"\r\n          [ngClass]=\"{'is-invalid': invalid, 'is-valid': valid}\"\r\n          [id]=\"id\"\r\n          [title]=\"title\"\r\n          [required]=\"required\"\r\n          [disabled]=\"disabled\"\r\n          [readonly]=\"readonly\"\r\n          [minlength]=\"minlength\"\r\n          [maxlength]=\"maxlength\"\r\n          [placeholder]=\"placeholder\"\r\n          [(ngModel)]=\"value\"\r\n          [rows]=\"rows\"\r\n          #customTextarea=\"ngModel\"></textarea>\r\n\r\n<div class=\"valid-feedback\" *ngIf=\"valid && validMessage\">{{validMessage}}</div>\r\n\r\n<div class=\"invalid-feedback\" *ngIf=\"invalid\">\r\n  <span *ngFor=\"let message of errorMessages; let last = last;\">\r\n    {{message}}<br *ngIf=\"!last\">\r\n  </span>\r\n</div>\r\n`,\r\n  styles: [``],\r\n  providers: [\r\n    {provide: NG_VALUE_ACCESSOR, useExisting: FormTextareaComponent, multi: true},\r\n    {provide: NG_VALIDATORS, useExisting: FormTextareaComponent, multi: true}\r\n  ]\r\n})\r\nexport class FormTextareaComponent extends BaseControlComponent {\r\n\r\n  @Input() rows = 5;\r\n  @Input() readonly = false;\r\n  @Input() minlength: number;\r\n  @Input() maxlength: number;\r\n  @Input() trimResult = true;\r\n  @Input() minLengthErrorMessage = 'Value is too short.';\r\n  @ViewChild('customTextarea') customTextarea: NgModel;\r\n  private _innerValue: string;\r\n\r\n  get value(): string {\r\n    if (!this._innerValue) {\r\n      return '';\r\n    }\r\n\r\n    if ('string' !== typeof this._innerValue) {\r\n      return this._innerValue;\r\n    }\r\n\r\n    return this.trimResult ? this._innerValue.trim() : this._innerValue;\r\n  }\r\n\r\n  set value(value: string) {\r\n    if (value !== this._innerValue) {\r\n      this._innerValue = value;\r\n      this.triggerChange();\r\n    }\r\n  }\r\n\r\n  get hasMinLengthError(): boolean {\r\n    return this.customTextarea.errors && this.customTextarea.errors['minlength'];\r\n  }\r\n\r\n  get invalid(): boolean {\r\n    if (this.hasCustomError) {\r\n      return true;\r\n    }\r\n\r\n    if (!this.customTextarea.touched) {\r\n      return false;\r\n    }\r\n\r\n    return this.customTextarea.invalid || this.hasRequiredError;\r\n  }\r\n\r\n  get valid(): boolean {\r\n    if (this.hasCustomError) {\r\n      return false;\r\n    }\r\n\r\n    if (!this.customTextarea.touched) {\r\n      return false;\r\n    }\r\n\r\n    return !this.customTextarea.invalid && !this.hasRequiredError;\r\n  }\r\n\r\n  get errorMessages(): Array<string> {\r\n    if (this.hasRequiredError) {\r\n      return [this.requiredErrorMessage];\r\n    }\r\n\r\n    if (this.hasMinLengthError) {\r\n      return [this.minLengthErrorMessage];\r\n    }\r\n\r\n    if (this.hasCustomError) {\r\n      return this.innerCustomErrorMessages;\r\n    }\r\n  }\r\n\r\n  writeValue(value: string): void {\r\n    this._innerValue = value;\r\n  }\r\n\r\n  validate(): ValidationErrors {\r\n    const result = this.customTextarea.errors || {};\r\n\r\n    if (this.hasRequiredError) {\r\n      result['required'] = true;\r\n    } else {\r\n      delete result['required'];\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  // noinspection JSUnusedGlobalSymbols\r\n  reset() {\r\n    this.customTextarea.reset();\r\n  }\r\n\r\n}\r\n"]}