ngx-form-control
Version:
Form controls for angular 6
174 lines (170 loc) • 15.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { Component, ElementRef, ViewChild } from '@angular/core';
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
import { BaseListControlComponent } from '../../utils/base-list-control.component';
export class FormCheckboxComponent extends BaseListControlComponent {
constructor() {
super(...arguments);
this._isTouched = false;
}
/**
* @return {?}
*/
get isEmpty() {
return !this._selectedIndexes || !this._selectedIndexes.length;
}
/**
* @return {?}
*/
get value() {
return this.isEmpty ? null : this._selectedIndexes.map(index => this._selectOptions[index].value);
}
/**
* @return {?}
*/
get invalid() {
if (this.hasCustomError) {
return true;
}
if (!this._isTouched) {
return false;
}
return this.hasRequiredError;
}
/**
* @return {?}
*/
get valid() {
if (this.hasCustomError) {
return false;
}
if (!this._isTouched) {
return false;
}
return !this.hasRequiredError;
}
/**
* @return {?}
*/
get errorMessages() {
if (this.hasCustomError) {
return this.innerCustomErrorMessages;
}
if (this.hasRequiredError) {
return [this.requiredErrorMessage];
}
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
/** @type {?} */
const listElement = this.listRadioElement.nativeElement.querySelectorAll('.custom-control-input');
for (const element of listElement) {
element.checked = false;
}
if (!value) {
return;
}
this._selectedIndexes = this.findIndexes(value);
if (!this.listRadioElement || !this.listRadioElement.nativeElement) {
return;
}
if (this.value) {
setTimeout(() => {
this._selectedIndexes.map(index => {
listElement[index].checked = true;
});
});
}
}
/**
* @return {?}
*/
validate() {
/** @type {?} */
const result = {};
if (this.hasRequiredError) {
result['required'] = true;
}
return result;
}
/**
* @param {?} index
* @param {?} event
* @return {?}
*/
toggle(index, event) {
this._isTouched = true;
/** @type {?} */
const checked = event.target.checked;
index = +index;
if (checked) {
this._selectedIndexes.push(index);
}
else {
/** @type {?} */
const indexOfIndex = this._selectedIndexes.indexOf(index);
if (indexOfIndex > -1) {
this._selectedIndexes.splice(indexOfIndex, 1);
}
}
this.triggerChange();
}
/**
* @return {?}
*/
reset() {
this._isTouched = false;
}
}
FormCheckboxComponent.decorators = [
{ type: Component, args: [{
selector: 'ngx-form-checkbox',
template: `<label *ngIf="label" [for]="id">{{label}}</label>
<div #listRadioElement>
<div class="custom-control custom-checkbox" *ngFor="let option of selectOptions; let index = index;">
<input class="custom-control-input"
[ngClass]="{'is-invalid': invalid, 'is-valid': valid}"
type="checkbox"
[id]="id + '-' + index"
[name]="id"
(click)="toggle(index, $event)"
title="">
<label class="custom-control-label" [for]="id + '-' + index">{{option.text}}</label>
</div>
</div>
<ng-container *ngIf="valid && validMessage">
<div class="custom-control-input is-valid"></div>
<div class="valid-feedback">{{validMessage}}</div>
</ng-container>
<ng-container *ngIf="invalid">
<div class="custom-control-input is-invalid"></div>
<div class="invalid-feedback">
<span *ngFor="let message of errorMessages; let last = last;">
{{message}}<br *ngIf="!last">
</span>
</div>
</ng-container>
`,
styles: [`:host .form-check.is-valid~.invalid-feedback,:host .form-check.is-valid~.invalid-tooltip,:host .form-check.is-valid~.valid-feedback,:host .form-check.is-valid~.valid-tooltip,:host .was-validated~.invalid-feedback,:host .was-validated~.invalid-tooltip,:host .was-validated~.valid-feedback,:host .was-validated~.valid-tooltip{display:block}`],
providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: FormCheckboxComponent, multi: true },
{ provide: NG_VALIDATORS, useExisting: FormCheckboxComponent, multi: true }
]
},] },
];
FormCheckboxComponent.propDecorators = {
listRadioElement: [{ type: ViewChild, args: ['listRadioElement',] }]
};
if (false) {
/** @type {?} */
FormCheckboxComponent.prototype.listRadioElement;
/** @type {?} */
FormCheckboxComponent.prototype._isTouched;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-checkbox.component.js","sourceRoot":"ng://ngx-form-control/","sources":["lib/form-checkbox/form-checkbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild } from '@angular/core';\r\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from '@angular/forms';\r\nimport { BaseListControlComponent } from '../../utils/base-list-control.component';\r\n\r\n@Component({\r\n  selector: 'ngx-form-checkbox',\r\n  template: `<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\r\n\r\n<div #listRadioElement>\r\n  <div class=\"custom-control custom-checkbox\" *ngFor=\"let option of selectOptions; let index = index;\">\r\n    <input class=\"custom-control-input\"\r\n           [ngClass]=\"{'is-invalid': invalid, 'is-valid': valid}\"\r\n           type=\"checkbox\"\r\n           [id]=\"id + '-' + index\"\r\n           [name]=\"id\"\r\n           (click)=\"toggle(index, $event)\"\r\n           title=\"\">\r\n    <label class=\"custom-control-label\" [for]=\"id + '-' + index\">{{option.text}}</label>\r\n  </div>\r\n</div>\r\n\r\n<ng-container *ngIf=\"valid && validMessage\">\r\n  <div class=\"custom-control-input is-valid\"></div>\r\n  <div class=\"valid-feedback\">{{validMessage}}</div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"invalid\">\r\n  <div class=\"custom-control-input is-invalid\"></div>\r\n  <div class=\"invalid-feedback\">\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</ng-container>\r\n`,\r\n  styles: [`:host .form-check.is-valid~.invalid-feedback,:host .form-check.is-valid~.invalid-tooltip,:host .form-check.is-valid~.valid-feedback,:host .form-check.is-valid~.valid-tooltip,:host .was-validated~.invalid-feedback,:host .was-validated~.invalid-tooltip,:host .was-validated~.valid-feedback,:host .was-validated~.valid-tooltip{display:block}`],\r\n  providers: [\r\n    {provide: NG_VALUE_ACCESSOR, useExisting: FormCheckboxComponent, multi: true},\r\n    {provide: NG_VALIDATORS, useExisting: FormCheckboxComponent, multi: true}\r\n  ]\r\n})\r\nexport class FormCheckboxComponent extends BaseListControlComponent {\r\n\r\n  @ViewChild('listRadioElement') listRadioElement: ElementRef;\r\n\r\n  private _isTouched = false;\r\n\r\n  get isEmpty(): boolean {\r\n    return !this._selectedIndexes || !this._selectedIndexes.length;\r\n  }\r\n\r\n  get value(): any {\r\n    return this.isEmpty ? null : this._selectedIndexes.map(index => this._selectOptions[index].value);\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._isTouched) {\r\n      return false;\r\n    }\r\n\r\n    return 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._isTouched) {\r\n      return false;\r\n    }\r\n\r\n    return !this.hasRequiredError;\r\n  }\r\n\r\n  get errorMessages(): Array<string> {\r\n    if (this.hasCustomError) {\r\n      return this.innerCustomErrorMessages;\r\n    }\r\n\r\n    if (this.hasRequiredError) {\r\n      return [this.requiredErrorMessage];\r\n    }\r\n  }\r\n\r\n  writeValue(value: Array<any>): void {\r\n    const listElement = this.listRadioElement.nativeElement.querySelectorAll('.custom-control-input');\r\n\r\n    for (const element of listElement) {\r\n      element.checked = false;\r\n    }\r\n\r\n    if (!value) {\r\n      return;\r\n    }\r\n\r\n    this._selectedIndexes = this.findIndexes(value);\r\n\r\n    if (!this.listRadioElement || !this.listRadioElement.nativeElement) {\r\n      return;\r\n    }\r\n\r\n    if (this.value) {\r\n      setTimeout(() => {\r\n        this._selectedIndexes.map(index => {\r\n          listElement[index].checked = true;\r\n        });\r\n      });\r\n    }\r\n  }\r\n\r\n  validate(): ValidationErrors {\r\n    const result = {};\r\n\r\n    if (this.hasRequiredError) {\r\n      result['required'] = true;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  // noinspection JSMethodCanBeStatic\r\n  toggle(index, event) {\r\n    this._isTouched = true;\r\n    const checked = event.target.checked;\r\n\r\n    index = +index;\r\n\r\n    if (checked) {\r\n      this._selectedIndexes.push(index);\r\n    } else {\r\n      const indexOfIndex = this._selectedIndexes.indexOf(index);\r\n\r\n      if (indexOfIndex > -1) {\r\n        this._selectedIndexes.splice(indexOfIndex, 1);\r\n      }\r\n    }\r\n\r\n    this.triggerChange();\r\n  }\r\n\r\n  reset() {\r\n    this._isTouched = false;\r\n  }\r\n\r\n}\r\n"]}