ngx-form-control
Version:
Form controls for angular 6
275 lines (274 loc) • 21.3 kB
JavaScript
/**
* @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"]}