UNPKG

ngx-form-control

Version:
275 lines (274 loc) 21.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core'; import { NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel } from '@angular/forms'; import { BaseControlComponent } from '../../utils/base-control.component'; var FormInputComponent = /** @class */ (function (_super) { tslib_1.__extends(FormInputComponent, _super); function FormInputComponent() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.type = 'text'; _this.pattern = ''; _this.readonly = false; _this.autocomplete = true; _this.trimResult = true; _this.minLengthErrorMessage = 'Value is too short.'; _this.patternErrorMessage = 'Value is not valid.'; _this.matchErrorMessage = 'Value does not match.'; _this.focus = new EventEmitter(); _this.blur = new EventEmitter(); return _this; } Object.defineProperty(FormInputComponent.prototype, "match", { set: /** * @param {?} value * @return {?} */ function (value) { this._match = value || ''; this.triggerChange(); }, enumerable: true, configurable: true }); Object.defineProperty(FormInputComponent.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(FormInputComponent.prototype, "hasMatchError", { get: /** * @return {?} */ function () { return !!this._match && this._match !== this.value; }, enumerable: true, configurable: true }); Object.defineProperty(FormInputComponent.prototype, "hasPatternError", { get: /** * @return {?} */ function () { return this.customInput.errors && this.customInput.errors['pattern']; }, enumerable: true, configurable: true }); Object.defineProperty(FormInputComponent.prototype, "hasMinLengthError", { get: /** * @return {?} */ function () { return this.customInput.errors && this.customInput.errors['minlength']; }, enumerable: true, configurable: true }); Object.defineProperty(FormInputComponent.prototype, "invalid", { get: /** * @return {?} */ function () { if (this.hasCustomError) { return true; } if (!this.customInput.touched) { return false; } return this.customInput.invalid || this.hasMatchError || this.hasRequiredError; }, enumerable: true, configurable: true }); Object.defineProperty(FormInputComponent.prototype, "valid", { get: /** * @return {?} */ function () { if (this.hasCustomError) { return false; } if (!this.customInput.touched) { return false; } return !this.customInput.invalid && !this.hasMatchError && !this.hasRequiredError; }, enumerable: true, configurable: true }); Object.defineProperty(FormInputComponent.prototype, "errorMessages", { get: /** * @return {?} */ function () { if (this.hasRequiredError) { return [this.requiredErrorMessage]; } if (this.hasMatchError) { return [this.matchErrorMessage]; } if (this.hasPatternError) { return [this.patternErrorMessage]; } if (this.hasMinLengthError) { return [this.minLengthErrorMessage]; } if (this.hasCustomError) { return this.innerCustomErrorMessages; } }, enumerable: true, configurable: true }); /** * @param {?} value * @return {?} */ FormInputComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this._innerValue = value; }; /** * @return {?} */ FormInputComponent.prototype.validate = /** * @return {?} */ function () { /** @type {?} */ var result = this.customInput.errors || {}; if (this.hasRequiredError) { result['required'] = true; } else { delete result['required']; } if (this.hasMatchError) { result['match'] = true; } return result; }; // noinspection JSUnusedGlobalSymbols /** * @return {?} */ FormInputComponent.prototype.reset = /** * @return {?} */ function () { this.customInput.reset(); }; /** * @param {?} event * @return {?} */ FormInputComponent.prototype.onFocus = /** * @param {?} event * @return {?} */ function (event) { this.focus.emit(event); }; /** * @param {?} event * @return {?} */ FormInputComponent.prototype.onBlur = /** * @param {?} event * @return {?} */ function (event) { this.blur.emit(event); }; FormInputComponent.decorators = [ { type: Component, args: [{ selector: 'ngx-form-input', template: "<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\n\n<!--suppress HtmlFormInputWithoutLabel -->\n<input class=\"form-control\"\n [ngClass]=\"{'is-invalid': invalid, 'is-valid': valid}\"\n [type]=\"type\"\n [id]=\"id\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [minlength]=\"minlength\"\n [maxlength]=\"maxlength\"\n [placeholder]=\"placeholder\"\n [title]=\"title\"\n [pattern]=\"pattern\"\n [(ngModel)]=\"value\"\n (input)=\"triggerChange()\"\n [autocomplete]=\"autocomplete ? 'on' : 'off'\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n #customInput=\"ngModel\">\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: FormInputComponent, multi: true }, { provide: NG_VALIDATORS, useExisting: FormInputComponent, multi: true } ] },] }, ]; FormInputComponent.propDecorators = { type: [{ type: Input }], pattern: [{ type: Input }], readonly: [{ type: Input }], autocomplete: [{ type: Input }], minlength: [{ type: Input }], maxlength: [{ type: Input }], trimResult: [{ type: Input }], minLengthErrorMessage: [{ type: Input }], patternErrorMessage: [{ type: Input }], matchErrorMessage: [{ type: Input }], customInput: [{ type: ViewChild, args: ['customInput',] }], match: [{ type: Input }], focus: [{ type: Output }], blur: [{ type: Output }] }; return FormInputComponent; }(BaseControlComponent)); export { FormInputComponent }; if (false) { /** @type {?} */ FormInputComponent.prototype.type; /** @type {?} */ FormInputComponent.prototype.pattern; /** @type {?} */ FormInputComponent.prototype.readonly; /** @type {?} */ FormInputComponent.prototype.autocomplete; /** @type {?} */ FormInputComponent.prototype.minlength; /** @type {?} */ FormInputComponent.prototype.maxlength; /** @type {?} */ FormInputComponent.prototype.trimResult; /** @type {?} */ FormInputComponent.prototype.minLengthErrorMessage; /** @type {?} */ FormInputComponent.prototype.patternErrorMessage; /** @type {?} */ FormInputComponent.prototype.matchErrorMessage; /** @type {?} */ FormInputComponent.prototype.customInput; /** @type {?} */ FormInputComponent.prototype.focus; /** @type {?} */ FormInputComponent.prototype.blur; /** @type {?} */ FormInputComponent.prototype._innerValue; /** @type {?} */ FormInputComponent.prototype._match; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"ng://ngx-form-control/","sources":["lib/form-input/form-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, Output, 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-input',\r\n  template: `<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\r\n\r\n<!--suppress HtmlFormInputWithoutLabel -->\r\n<input class=\"form-control\"\r\n       [ngClass]=\"{'is-invalid': invalid, 'is-valid': valid}\"\r\n       [type]=\"type\"\r\n       [id]=\"id\"\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       [title]=\"title\"\r\n       [pattern]=\"pattern\"\r\n       [(ngModel)]=\"value\"\r\n       (input)=\"triggerChange()\"\r\n       [autocomplete]=\"autocomplete ? 'on' : 'off'\"\r\n       (focus)=\"onFocus($event)\"\r\n       (blur)=\"onBlur($event)\"\r\n       #customInput=\"ngModel\">\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: FormInputComponent, multi: true},\r\n    {provide: NG_VALIDATORS, useExisting: FormInputComponent, multi: true}\r\n  ]\r\n})\r\nexport class FormInputComponent extends BaseControlComponent {\r\n\r\n  @Input() type = 'text';\r\n  @Input() pattern = '';\r\n  @Input() readonly = false;\r\n  @Input() autocomplete = true;\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  @Input() patternErrorMessage = 'Value is not valid.';\r\n  @Input() matchErrorMessage = 'Value does not match.';\r\n  @ViewChild('customInput') customInput: NgModel;\r\n\r\n  @Input() set match(value: string) {\r\n    this._match = value || '';\r\n    this.triggerChange();\r\n  }\r\n\r\n  @Output() focus = new EventEmitter<any>();\r\n  @Output() blur = new EventEmitter<any>();\r\n\r\n  private _innerValue: string;\r\n  private _match;\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 hasMatchError(): boolean {\r\n    return !!this._match && this._match !== this.value;\r\n  }\r\n\r\n  get hasPatternError(): boolean {\r\n    return this.customInput.errors && this.customInput.errors['pattern'];\r\n  }\r\n\r\n  get hasMinLengthError(): boolean {\r\n    return this.customInput.errors && this.customInput.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.customInput.touched) {\r\n      return false;\r\n    }\r\n\r\n    return this.customInput.invalid || this.hasMatchError || 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.customInput.touched) {\r\n      return false;\r\n    }\r\n\r\n    return !this.customInput.invalid && !this.hasMatchError && !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.hasMatchError) {\r\n      return [this.matchErrorMessage];\r\n    }\r\n\r\n    if (this.hasPatternError) {\r\n      return [this.patternErrorMessage];\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.customInput.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    if (this.hasMatchError) {\r\n      result['match'] = true;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  // noinspection JSUnusedGlobalSymbols\r\n  reset() {\r\n    this.customInput.reset();\r\n  }\r\n\r\n  onFocus(event) {\r\n    this.focus.emit(event);\r\n  }\r\n\r\n  onBlur(event) {\r\n    this.blur.emit(event);\r\n  }\r\n\r\n}\r\n"]}