ngx-form-control
Version:
Form controls for angular 6
433 lines (432 loc) • 40.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 } from '@angular/forms';
import { BaseListControlComponent } from '../../utils/base-list-control.component';
import { Common } from '../../utils/common';
var FormSelect2Component = /** @class */ (function (_super) {
tslib_1.__extends(FormSelect2Component, _super);
function FormSelect2Component() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this._isTouched = false;
return _this;
}
Object.defineProperty(FormSelect2Component.prototype, "placeholder", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._placeholder = value;
this.updateSelect2Options();
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "required", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._required = value;
this.updateSelect2Options();
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "disabled", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._disabled = value;
this.updateSelect2Options();
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "multiple", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._multiple = value;
this.updateSelect2Options();
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "tag", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._tag = value;
this.updateSelect2Options();
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "tokenSeparators", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._tag = value;
this.updateSelect2Options();
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "value", {
get: /**
* @return {?}
*/
function () {
var _this = this;
if (!this._selectedIndexes || !this._selectedIndexes.length) {
return null;
}
/** @type {?} */
var result = this._selectedIndexes.reduce(function (currentResult, index) {
if (Number.isInteger(index) && _this._selectOptions[index]) {
currentResult.push(_this._selectOptions[index].value);
}
else if (_this._tag) {
/** @type {?} */
var match = index['value'].match(/^number: {([\d]+)}$/);
if (match) {
currentResult.push(match[1]);
}
else {
currentResult.push(index['value']);
}
}
return currentResult;
}, []);
return this._multiple ? result : result[0];
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "invalid", {
get: /**
* @return {?}
*/
function () {
if (this.hasCustomError) {
return true;
}
if (!this._isTouched) {
return false;
}
return this.hasRequiredError;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "valid", {
get: /**
* @return {?}
*/
function () {
if (this.hasCustomError) {
return false;
}
if (!this._isTouched) {
return false;
}
return !this.hasRequiredError;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FormSelect2Component.prototype, "errorMessages", {
get: /**
* @return {?}
*/
function () {
if (this.hasRequiredError) {
return [this.requiredErrorMessage];
}
if (this.hasCustomError) {
return this.innerCustomErrorMessages;
}
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
FormSelect2Component.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.updateSelect2Options();
};
/**
* @param {?} value
* @return {?}
*/
FormSelect2Component.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (this._multiple && value && value.length) {
this.selectValues(value);
}
else if (!this._multiple) {
this.selectValue(value);
}
else {
this.cleanValue();
}
};
/**
* @return {?}
*/
FormSelect2Component.prototype.validate = /**
* @return {?}
*/
function () {
/** @type {?} */
var result = {};
if (this.hasRequiredError) {
result['required'] = true;
}
return result;
};
// noinspection JSUnusedGlobalSymbols
/**
* @return {?}
*/
FormSelect2Component.prototype.reset = /**
* @return {?}
*/
function () {
this._isTouched = false;
};
/**
* @return {?}
*/
FormSelect2Component.prototype.afterInitOptions = /**
* @return {?}
*/
function () {
this._selectOptions = tslib_1.__spread(this._selectOptions);
this.updateSelect2Options();
};
/**
* @param {?} values
* @return {?}
*/
FormSelect2Component.prototype.selectValues = /**
* @param {?} values
* @return {?}
*/
function (values) {
var _this = this;
this._selectedIndexes = [];
/** @type {?} */
var select2Data = [];
if (values && values.length) {
values.map(function (value) {
/** @type {?} */
var index = _this.findIndex(value);
if (index > -1) {
_this._selectedIndexes.push(index);
select2Data.push(index);
}
else if (_this._tag) {
_this._selectedIndexes.push({ value: value });
select2Data.push(value);
}
});
}
if (Common.isClient()) {
this._selectElement.val(select2Data);
this._selectElement.trigger('change');
}
};
/**
* @return {?}
*/
FormSelect2Component.prototype.updateSelectedIndexes = /**
* @return {?}
*/
function () {
var _this = this;
if (Common.isServer()) {
return;
}
/** @type {?} */
var oldSelectedIndexes = JSON.stringify(this._selectedIndexes);
/** @type {?} */
var value = this._selectElement.val();
if ('number' === typeof value || ('string' === typeof value && Number.isInteger(+value))) {
this._selectedIndexes = [+value];
}
else if ('string' === typeof value && this._tag) {
this._selectedIndexes = [{ value: value }];
}
else if (value && value.length) {
this._selectedIndexes = value.map(function (item) {
if (Number.isInteger(+item)) {
return +item;
}
if (_this._tag) {
return { value: item };
}
return null;
});
}
else {
this._selectedIndexes = [];
}
/** @type {?} */
var newSelectedIndexes = JSON.stringify(this._selectedIndexes);
if (newSelectedIndexes !== oldSelectedIndexes) {
this.triggerChange();
}
};
/**
* @param {?} value
* @return {?}
*/
FormSelect2Component.prototype.selectValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (Common.isServer()) {
return;
}
/** @type {?} */
var index = this.findIndex(value);
if (index > -1) {
this._selectedIndexes = [index];
this._selectElement.val(this._selectedIndexes);
this._selectElement.trigger('change');
}
else if (this._tag) {
this._selectedIndexes = [{ value: value }];
this._selectElement.val(value);
this._selectElement.trigger('change');
}
else {
this.cleanValue();
}
};
/**
* @return {?}
*/
FormSelect2Component.prototype.cleanValue = /**
* @return {?}
*/
function () {
if (Common.isServer()) {
return;
}
this._selectedIndexes = [];
this._selectElement.val(null);
this._selectElement.trigger('change');
};
/**
* @return {?}
*/
FormSelect2Component.prototype.updateSelect2Options = /**
* @return {?}
*/
function () {
var _this = this;
if (Common.isServer() || !this.customSelectElement || !this.customSelectElement.nativeElement) {
return;
}
this._selectElement = $(this.customSelectElement.nativeElement);
if (this._selectElement.hasClass('select2-hidden-accessible')) {
this._selectElement.select2().empty();
this._selectElement.select2('destroy');
}
this._selectElement.select2({
tags: this._tag,
tokenSeparators: this._tokenSeparators || [],
placeholder: this._placeholder,
allowClear: !this._required,
multiple: this._multiple,
data: this._selectOptions,
disabled: this._disabled,
createTag: function (params) {
/** @type {?} */
var term = $.trim(params.term);
if (term === '') {
return null;
}
return {
id: Number.isInteger(+term) ? "number: {" + term + "}" : term,
text: term,
newTag: true
};
}
});
this._selectElement.on('select2:select', function () {
_this.updateSelectedIndexes();
});
this._selectElement.on('select2:unselect', function () {
_this.updateSelectedIndexes();
});
this._selectElement.on('select2:close', function () {
_this._isTouched = true;
});
};
FormSelect2Component.decorators = [
{ type: Component, args: [{
selector: 'ngx-form-select2',
template: "<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\n\n<div class=\"form-control is-invalid\" [ngClass]=\"{'is-invalid': invalid, 'is-valid': valid}\">\n <!--suppress HtmlFormInputWithoutLabel -->\n <select [id]=\"id\" #customSelectElement></select>\n</div>\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: [":host .form-control{padding:0}:host .form-control /deep/ .select2-container{width:100%!important}:host .form-control /deep/ .select2-container .select2-selection--single{height:auto}:host .form-control /deep/ .select2-container--default .select2-selection--multiple,:host .form-control /deep/ .select2-container--default .select2-selection--single,:host .form-control /deep/ .select2-container--default.select2-container--focus .select2-selection--multiple{border:none;outline:0!important}:host .form-control /deep/ .select2-container--default .select2-selection--multiple:focus,:host .form-control /deep/ .select2-container--default .select2-selection--single:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}:host .form-control.is-invalid /deep/ .select2-container--default .select2-selection--multiple:focus,:host .form-control.is-invalid /deep/ .select2-container--default .select2-selection--single:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem rgba(220,53,69,.25)}:host .form-control.is-valid /deep/ .select2-container--default .select2-selection--multiple:focus,:host .form-control.is-valid /deep/ .select2-container--default .select2-selection--single:focus{border-color:#28a745;box-shadow:0 0 0 .2rem rgba(40,167,69,.25)}:host .form-control /deep/ .select2-container--default .select2-selection--single .select2-selection__rendered{min-height:40px;line-height:25px;padding:.375rem 25px .375rem .75rem}:host .form-control /deep/ .select2-container .select2-selection--multiple{min-height:40px;padding:.375rem .75rem}:host .form-control /deep/ .select2-container--default .select2-selection--multiple .select2-selection__rendered{padding:0}:host .form-control /deep/ .select2-container--default .select2-selection--single .select2-selection__arrow{height:38px}"],
providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: FormSelect2Component, multi: true },
{ provide: NG_VALIDATORS, useExisting: FormSelect2Component, multi: true }
]
},] },
];
FormSelect2Component.propDecorators = {
customSelectElement: [{ type: ViewChild, args: ['customSelectElement',] }],
placeholder: [{ type: Input }],
required: [{ type: Input }],
disabled: [{ type: Input }],
multiple: [{ type: Input }],
tag: [{ type: Input }],
tokenSeparators: [{ type: Input }]
};
return FormSelect2Component;
}(BaseListControlComponent));
export { FormSelect2Component };
if (false) {
/** @type {?} */
FormSelect2Component.prototype._selectElement;
/** @type {?} */
FormSelect2Component.prototype._isTouched;
/** @type {?} */
FormSelect2Component.prototype._placeholder;
/** @type {?} */
FormSelect2Component.prototype.customSelectElement;
/** @type {?} */
FormSelect2Component.prototype._required;
/** @type {?} */
FormSelect2Component.prototype._disabled;
/** @type {?} */
FormSelect2Component.prototype._tag;
/** @type {?} */
FormSelect2Component.prototype._tokenSeparators;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-select2.component.js","sourceRoot":"ng://ngx-form-control/","sources":["lib/form-select2/form-select2.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Input, OnInit, ViewChild} from '@angular/core';\r\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR} from '@angular/forms';\r\nimport {BaseListControlComponent} from '../../utils/base-list-control.component';\r\nimport {Common} from '../../utils/common';\r\n\r\ndeclare const $;\r\n\r\n@Component({\r\n  selector: 'ngx-form-select2',\r\n  template: `<label *ngIf=\"label\" [for]=\"id\">{{label}}</label>\r\n\r\n<div class=\"form-control is-invalid\" [ngClass]=\"{'is-invalid': invalid, 'is-valid': valid}\">\r\n  <!--suppress HtmlFormInputWithoutLabel -->\r\n  <select [id]=\"id\" #customSelectElement></select>\r\n</div>\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: [`:host .form-control{padding:0}:host .form-control /deep/ .select2-container{width:100%!important}:host .form-control /deep/ .select2-container .select2-selection--single{height:auto}:host .form-control /deep/ .select2-container--default .select2-selection--multiple,:host .form-control /deep/ .select2-container--default .select2-selection--single,:host .form-control /deep/ .select2-container--default.select2-container--focus .select2-selection--multiple{border:none;outline:0!important}:host .form-control /deep/ .select2-container--default .select2-selection--multiple:focus,:host .form-control /deep/ .select2-container--default .select2-selection--single:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}:host .form-control.is-invalid /deep/ .select2-container--default .select2-selection--multiple:focus,:host .form-control.is-invalid /deep/ .select2-container--default .select2-selection--single:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem rgba(220,53,69,.25)}:host .form-control.is-valid /deep/ .select2-container--default .select2-selection--multiple:focus,:host .form-control.is-valid /deep/ .select2-container--default .select2-selection--single:focus{border-color:#28a745;box-shadow:0 0 0 .2rem rgba(40,167,69,.25)}:host .form-control /deep/ .select2-container--default .select2-selection--single .select2-selection__rendered{min-height:40px;line-height:25px;padding:.375rem 25px .375rem .75rem}:host .form-control /deep/ .select2-container .select2-selection--multiple{min-height:40px;padding:.375rem .75rem}:host .form-control /deep/ .select2-container--default .select2-selection--multiple .select2-selection__rendered{padding:0}:host .form-control /deep/ .select2-container--default .select2-selection--single .select2-selection__arrow{height:38px}`],\r\n  providers: [\r\n    {provide: NG_VALUE_ACCESSOR, useExisting: FormSelect2Component, multi: true},\r\n    {provide: NG_VALIDATORS, useExisting: FormSelect2Component, multi: true}\r\n  ]\r\n})\r\nexport class FormSelect2Component extends BaseListControlComponent implements OnInit {\r\n\r\n  private _selectElement;\r\n  private _isTouched = false;\r\n  private _placeholder: string;\r\n\r\n  @ViewChild('customSelectElement') customSelectElement: ElementRef;\r\n\r\n  @Input() set placeholder(value: string) {\r\n    this._placeholder = value;\r\n    this.updateSelect2Options();\r\n  }\r\n\r\n  private _required: boolean;\r\n\r\n  @Input() set required(value: boolean) {\r\n    this._required = value;\r\n    this.updateSelect2Options();\r\n  }\r\n\r\n  private _disabled: boolean;\r\n\r\n  @Input() set disabled(value: boolean) {\r\n    this._disabled = value;\r\n    this.updateSelect2Options();\r\n  }\r\n\r\n  @Input() set multiple(value: boolean) {\r\n    this._multiple = value;\r\n    this.updateSelect2Options();\r\n  }\r\n\r\n  private _tag: boolean;\r\n\r\n  @Input() set tag(value: boolean) {\r\n    this._tag = value;\r\n    this.updateSelect2Options();\r\n  }\r\n\r\n  private _tokenSeparators: boolean;\r\n\r\n  @Input() set tokenSeparators(value: boolean) {\r\n    this._tag = value;\r\n    this.updateSelect2Options();\r\n  }\r\n\r\n  get value(): any {\r\n    if (!this._selectedIndexes || !this._selectedIndexes.length) {\r\n      return null;\r\n    }\r\n\r\n    const result = this._selectedIndexes.reduce((currentResult, index) => {\r\n      if (Number.isInteger(index) && this._selectOptions[index]) {\r\n        currentResult.push(this._selectOptions[index].value);\r\n      } else if (this._tag) {\r\n        const match = index['value'].match(/^number: {([\\d]+)}$/);\r\n\r\n        if (match) {\r\n          currentResult.push(match[1]);\r\n        } else {\r\n          currentResult.push(index['value']);\r\n        }\r\n      }\r\n\r\n      return currentResult;\r\n    }, []);\r\n\r\n    return this._multiple ? result : result[0];\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.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  ngOnInit() {\r\n    this.updateSelect2Options();\r\n  }\r\n\r\n  writeValue(value: any | Array<any>): void {\r\n    if (this._multiple && value && value.length) {\r\n      this.selectValues(value);\r\n    } else if (!this._multiple) {\r\n      this.selectValue(value);\r\n    } else {\r\n      this.cleanValue();\r\n    }\r\n  }\r\n\r\n  validate(): {} {\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 JSUnusedGlobalSymbols\r\n  reset() {\r\n    this._isTouched = false;\r\n  }\r\n\r\n  protected afterInitOptions() {\r\n    this._selectOptions = [...this._selectOptions];\r\n\r\n    this.updateSelect2Options();\r\n  }\r\n\r\n  private selectValues(values) {\r\n    this._selectedIndexes = [];\r\n    const select2Data = [];\r\n\r\n    if (values && values.length) {\r\n      values.map((value) => {\r\n        const index = this.findIndex(value);\r\n\r\n        if (index > -1) {\r\n          this._selectedIndexes.push(index);\r\n          select2Data.push(index);\r\n        } else if (this._tag) {\r\n          this._selectedIndexes.push({value});\r\n          select2Data.push(value);\r\n        }\r\n      });\r\n    }\r\n\r\n    if (Common.isClient()) {\r\n      this._selectElement.val(select2Data);\r\n      this._selectElement.trigger('change');\r\n    }\r\n  }\r\n\r\n  private updateSelectedIndexes() {\r\n    if (Common.isServer()) {\r\n      return;\r\n    }\r\n\r\n    const oldSelectedIndexes = JSON.stringify(this._selectedIndexes);\r\n    const value = this._selectElement.val();\r\n\r\n    if ('number' === typeof value || ('string' === typeof value && Number.isInteger(+value))) {\r\n      this._selectedIndexes = [+value];\r\n    } else if ('string' === typeof value && this._tag) {\r\n      this._selectedIndexes = [{value}];\r\n    } else if (value && value.length) {\r\n      this._selectedIndexes = value.map(item => {\r\n        if (Number.isInteger(+item)) {\r\n          return +item;\r\n        }\r\n\r\n        if (this._tag) {\r\n          return {value: item};\r\n        }\r\n\r\n        return null;\r\n      });\r\n    } else {\r\n      this._selectedIndexes = [];\r\n    }\r\n\r\n    const newSelectedIndexes = JSON.stringify(this._selectedIndexes);\r\n\r\n    if (newSelectedIndexes !== oldSelectedIndexes) {\r\n      this.triggerChange();\r\n    }\r\n  }\r\n\r\n  private selectValue(value) {\r\n    if (Common.isServer()) {\r\n      return;\r\n    }\r\n\r\n    const index = this.findIndex(value);\r\n\r\n    if (index > -1) {\r\n      this._selectedIndexes = [index];\r\n      this._selectElement.val(this._selectedIndexes);\r\n      this._selectElement.trigger('change');\r\n    } else if (this._tag) {\r\n      this._selectedIndexes = [{value}];\r\n      this._selectElement.val(value);\r\n      this._selectElement.trigger('change');\r\n    } else {\r\n      this.cleanValue();\r\n    }\r\n  }\r\n\r\n  private cleanValue() {\r\n    if (Common.isServer()) {\r\n      return;\r\n    }\r\n\r\n    this._selectedIndexes = [];\r\n    this._selectElement.val(null);\r\n    this._selectElement.trigger('change');\r\n  }\r\n\r\n  private updateSelect2Options() {\r\n    if (Common.isServer() || !this.customSelectElement || !this.customSelectElement.nativeElement) {\r\n      return;\r\n    }\r\n\r\n    this._selectElement = $(this.customSelectElement.nativeElement);\r\n    if (this._selectElement.hasClass('select2-hidden-accessible')) {\r\n      this._selectElement.select2().empty();\r\n      this._selectElement.select2('destroy');\r\n    }\r\n\r\n    this._selectElement.select2({\r\n      tags: this._tag,\r\n      tokenSeparators: this._tokenSeparators || [],\r\n      placeholder: this._placeholder,\r\n      allowClear: !this._required,\r\n      multiple: this._multiple,\r\n      data: this._selectOptions,\r\n      disabled: this._disabled,\r\n      createTag: function (params) {\r\n        const term = $.trim(params.term);\r\n\r\n        if (term === '') {\r\n          return null;\r\n        }\r\n\r\n        return {\r\n          id: Number.isInteger(+term) ? `number: {${term}}` : term,\r\n          text: term,\r\n          newTag: true\r\n        };\r\n      }\r\n    });\r\n\r\n    this._selectElement.on('select2:select', () => {\r\n      this.updateSelectedIndexes();\r\n    });\r\n\r\n    this._selectElement.on('select2:unselect', () => {\r\n      this.updateSelectedIndexes();\r\n    });\r\n\r\n    this._selectElement.on('select2:close', () => {\r\n      this._isTouched = true;\r\n    });\r\n  }\r\n\r\n}\r\n"]}