ngx-form-control
Version:
Form controls for angular 6
177 lines (176 loc) • 15.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, Input, ViewChild } from '@angular/core';
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel } from '@angular/forms';
import { BaseListControlComponent } from '../../utils/base-list-control.component';
var FormSelectComponent = /** @class */ (function (_super) {
tslib_1.__extends(FormSelectComponent, _super);
function FormSelectComponent() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(FormSelectComponent.prototype, "multiple", {
get: /**
* @return {?}
*/
function () {
return this._multiple;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._multiple = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelectComponent.prototype, "isEmpty", {
get: /**
* @return {?}
*/
function () {
return !this._selectedIndexes ||
!this._selectedIndexes.length ||
(1 === this._selectedIndexes.length && -1 === this._selectedIndexes[0]);
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelectComponent.prototype, "value", {
get: /**
* @return {?}
*/
function () {
var _this = this;
if (this.isEmpty) {
return null;
}
if (this._multiple) {
return this._selectedIndexes.map(function (index) { return _this._selectOptions[index].value; });
}
else {
/** @type {?} */
var index = this._selectedIndexes[0];
return this.selectOptions[index].value;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelectComponent.prototype, "invalid", {
get: /**
* @return {?}
*/
function () {
if (this.hasCustomError) {
return true;
}
if (!this.customSelect.touched) {
return false;
}
return this.customSelect.invalid || this.hasRequiredError;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelectComponent.prototype, "valid", {
get: /**
* @return {?}
*/
function () {
if (this.hasCustomError) {
return false;
}
if (!this.customSelect.touched) {
return false;
}
return !this.customSelect.invalid && !this.hasRequiredError;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelectComponent.prototype, "errorMessages", {
get: /**
* @return {?}
*/
function () {
if (this.hasRequiredError) {
return [this.requiredErrorMessage];
}
if (this.hasCustomError) {
return this.innerCustomErrorMessages;
}
},
enumerable: true,
configurable: true
});
/**
* @param {?} value
* @return {?}
*/
FormSelectComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (!this.multiple) {
value = [value];
}
this._selectedIndexes = this.findIndexes(value);
};
/**
* @return {?}
*/
FormSelectComponent.prototype.validate = /**
* @return {?}
*/
function () {
/** @type {?} */
var result = this.customSelect.errors || {};
if (this.hasRequiredError) {
result['required'] = true;
}
else {
delete result['required'];
}
return result;
};
/**
* @return {?}
*/
FormSelectComponent.prototype.reset = /**
* @return {?}
*/
function () {
this.customSelect.reset();
};
FormSelectComponent.decorators = [
{ type: Component, args: [{
selector: 'ngx-form-select',
template: "<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\n\n<!--suppress HtmlFormInputWithoutLabel -->\n<select class=\"form-control\"\n [ngClass]=\"{'is-invalid': invalid, 'is-valid': valid}\"\n [id]=\"id\"\n [title]=\"title\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n [(ngModel)]=\"selectedIndexes\"\n #customSelect=\"ngModel\"\n #customSelectElement>\n <option value=\"-1\" *ngIf=\"placeholder\">{{placeholder}}</option>\n <option *ngFor=\"let option of selectOptions; let index = index;\" [value]=\"index\">{{option.text}}</option>\n</select>\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: FormSelectComponent, multi: true },
{ provide: NG_VALIDATORS, useExisting: FormSelectComponent, multi: true }
]
},] },
];
FormSelectComponent.propDecorators = {
customSelect: [{ type: ViewChild, args: ['customSelect',] }],
customSelectElement: [{ type: ViewChild, args: ['customSelectElement',] }],
multiple: [{ type: Input }]
};
return FormSelectComponent;
}(BaseListControlComponent));
export { FormSelectComponent };
if (false) {
/** @type {?} */
FormSelectComponent.prototype.customSelect;
/** @type {?} */
FormSelectComponent.prototype.customSelectElement;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-select.component.js","sourceRoot":"ng://ngx-form-control/","sources":["lib/form-select/form-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Input, ViewChild} from '@angular/core';\r\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel, ValidationErrors} from '@angular/forms';\r\nimport {BaseListControlComponent} from '../../utils/base-list-control.component';\r\n\r\n@Component({\r\n  selector: 'ngx-form-select',\r\n  template: `<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\r\n\r\n<!--suppress HtmlFormInputWithoutLabel -->\r\n<select 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        [multiple]=\"multiple\"\r\n        [(ngModel)]=\"selectedIndexes\"\r\n        #customSelect=\"ngModel\"\r\n        #customSelectElement>\r\n  <option value=\"-1\" *ngIf=\"placeholder\">{{placeholder}}</option>\r\n  <option *ngFor=\"let option of selectOptions; let index = index;\" [value]=\"index\">{{option.text}}</option>\r\n</select>\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: FormSelectComponent, multi: true},\r\n    {provide: NG_VALIDATORS, useExisting: FormSelectComponent, multi: true}\r\n  ]\r\n})\r\nexport class FormSelectComponent extends BaseListControlComponent {\r\n\r\n  @ViewChild('customSelect') customSelect: NgModel;\r\n  @ViewChild('customSelectElement') customSelectElement: ElementRef;\r\n\r\n  get multiple() {\r\n    return this._multiple;\r\n  }\r\n\r\n  @Input() set multiple(value: boolean) {\r\n    this._multiple = value;\r\n  }\r\n\r\n  get isEmpty(): boolean {\r\n    return !this._selectedIndexes ||\r\n      !this._selectedIndexes.length ||\r\n      (1 === this._selectedIndexes.length && -1 === this._selectedIndexes[0]);\r\n  }\r\n\r\n  get value(): any {\r\n    if (this.isEmpty) {\r\n      return null;\r\n    }\r\n\r\n    if (this._multiple) {\r\n      return this._selectedIndexes.map(index => this._selectOptions[index].value);\r\n    } else {\r\n      const index = this._selectedIndexes[0];\r\n      return this.selectOptions[index].value;\r\n    }\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.customSelect.touched) {\r\n      return false;\r\n    }\r\n\r\n    return this.customSelect.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.customSelect.touched) {\r\n      return false;\r\n    }\r\n\r\n    return !this.customSelect.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.hasCustomError) {\r\n      return this.innerCustomErrorMessages;\r\n    }\r\n  }\r\n\r\n  writeValue(value: any | Array<any>): void {\r\n    if (!this.multiple) {\r\n      value = [value];\r\n    }\r\n\r\n    this._selectedIndexes = this.findIndexes(value);\r\n  }\r\n\r\n  validate(): ValidationErrors {\r\n    const result = this.customSelect.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  reset() {\r\n    this.customSelect.reset();\r\n  }\r\n\r\n}\r\n"]}