UNPKG

ngx-form-control

Version:
268 lines (267 loc) 18.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { BaseControlComponent } from './base-control.component'; import { Input } from '@angular/core'; /** * @abstract */ var BaseListControlComponent = /** @class */ (function (_super) { tslib_1.__extends(BaseListControlComponent, _super); function BaseListControlComponent() { var _this = _super !== null && _super.apply(this, arguments) || this; _this._options = []; _this._selectOptions = []; _this._selectedIndexes = []; return _this; } Object.defineProperty(BaseListControlComponent.prototype, "textKey", { set: /** * @param {?} value * @return {?} */ function (value) { this._textKey = value; this.initOptions(); }, enumerable: true, configurable: true }); Object.defineProperty(BaseListControlComponent.prototype, "valueKey", { set: /** * @param {?} value * @return {?} */ function (value) { this._valueKey = value; this.initOptions(); }, enumerable: true, configurable: true }); Object.defineProperty(BaseListControlComponent.prototype, "comparedKey", { set: /** * @param {?} value * @return {?} */ function (value) { this._comparedKey = value; this.initOptions(); }, enumerable: true, configurable: true }); Object.defineProperty(BaseListControlComponent.prototype, "options", { set: /** * @param {?} options * @return {?} */ function (options) { this._options = options; this.initOptions(); }, enumerable: true, configurable: true }); Object.defineProperty(BaseListControlComponent.prototype, "selectOptions", { get: /** * @return {?} */ function () { return this._selectOptions; }, enumerable: true, configurable: true }); Object.defineProperty(BaseListControlComponent.prototype, "selectedIndexes", { get: /** * @return {?} */ function () { return this._selectedIndexes; }, set: /** * @param {?} indexes * @return {?} */ function (indexes) { /** @type {?} */ var oldSelectedIndexes = JSON.stringify(this._selectedIndexes); this._selectedIndexes = indexes && indexes.length ? indexes.reduce(function (arr, value) { value = +value; if (value > -1) { arr.push(value); } return arr; }, []) : []; /** @type {?} */ var newSelectedIndexes = JSON.stringify(this._selectedIndexes); if (newSelectedIndexes !== oldSelectedIndexes) { this.triggerChange(); } }, enumerable: true, configurable: true }); /** * @param {?} value * @return {?} */ BaseListControlComponent.prototype.findIndex = /** * @param {?} value * @return {?} */ function (value) { /** @type {?} */ var comparedValue = this.getComparedValue(value); return this._selectOptions.findIndex(function (option) { return comparedValue === option.comparedValue; }); }; /** * @param {?} arrValue * @return {?} */ BaseListControlComponent.prototype.findIndexes = /** * @param {?} arrValue * @return {?} */ function (arrValue) { var _this = this; if (!arrValue || !arrValue.length) { return []; } return arrValue.reduce(function (arr, value) { /** @type {?} */ var index = _this.findIndex(value); if (index > -1) { arr.push(index); } return arr; }, []); }; /** * @return {?} */ BaseListControlComponent.prototype.initOptions = /** * @return {?} */ function () { var _this = this; this.beforeInitOptions(); /** @type {?} */ var oldValue = this.value; this._selectOptions = []; if (this._options && this._options.length) { this._options.map(function (option, index) { /** @type {?} */ var text; /** @type {?} */ var value; if ('string' === typeof option || 'number' === typeof option) { text = option; value = option; } else { text = option[_this._textKey || 'text']; value = _this._valueKey ? option[_this._valueKey] : option; } _this._selectOptions.push({ id: index, text: text, value: value, comparedValue: _this.getComparedValue(option), }); }); } this.afterInitOptions(); this.writeValue(oldValue); /** @type {?} */ var newValue = this.value; if (JSON.stringify(oldValue) !== JSON.stringify(newValue)) { this.triggerChange(); } }; /** * @return {?} */ BaseListControlComponent.prototype.beforeInitOptions = /** * @return {?} */ function () { }; /** * @return {?} */ BaseListControlComponent.prototype.afterInitOptions = /** * @return {?} */ function () { }; /** * @param {?} option * @return {?} */ BaseListControlComponent.prototype.getComparedValue = /** * @param {?} option * @return {?} */ function (option) { if (!option) { return ''; } if ('string' === typeof option || 'number' === typeof option) { return option; } /** @type {?} */ var value; if (this._comparedKey) { value = option[this._comparedKey]; } else { value = this._valueKey ? option[this._valueKey] : option; } if ('string' === typeof value || 'number' === typeof value) { return value; } return JSON.stringify(value); }; BaseListControlComponent.propDecorators = { textKey: [{ type: Input }], valueKey: [{ type: Input }], comparedKey: [{ type: Input }], options: [{ type: Input }] }; return BaseListControlComponent; }(BaseControlComponent)); export { BaseListControlComponent }; if (false) { /** @type {?} */ BaseListControlComponent.prototype._multiple; /** @type {?} */ BaseListControlComponent.prototype._textKey; /** @type {?} */ BaseListControlComponent.prototype._valueKey; /** @type {?} */ BaseListControlComponent.prototype._comparedKey; /** @type {?} */ BaseListControlComponent.prototype._options; /** @type {?} */ BaseListControlComponent.prototype._selectOptions; /** @type {?} */ BaseListControlComponent.prototype._selectedIndexes; /** * @abstract * @return {?} */ BaseListControlComponent.prototype.value = function () { }; /** * @abstract * @param {?} value * @return {?} */ BaseListControlComponent.prototype.writeValue = function (value) { }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-list-control.component.js","sourceRoot":"ng://ngx-form-control/","sources":["utils/base-list-control.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseControlComponent } from './base-control.component';\r\nimport { Input } from '@angular/core';\r\n\r\nexport abstract class BaseListControlComponent extends BaseControlComponent {\r\n\r\n  protected _multiple;\r\n  protected _textKey;\r\n\r\n  @Input() set textKey(value: string) {\r\n    this._textKey = value;\r\n    this.initOptions();\r\n  }\r\n\r\n  protected _valueKey;\r\n\r\n  @Input() set valueKey(value: string) {\r\n    this._valueKey = value;\r\n    this.initOptions();\r\n  }\r\n\r\n  protected _comparedKey;\r\n\r\n  @Input() set comparedKey(value: string) {\r\n    this._comparedKey = value;\r\n    this.initOptions();\r\n  }\r\n\r\n  protected _options: Array<any> = [];\r\n\r\n  @Input() set options(options: Array<any>) {\r\n    this._options = options;\r\n    this.initOptions();\r\n  }\r\n\r\n  protected _selectOptions: Array<{ id, text, value, comparedValue }> = [];\r\n\r\n  // noinspection JSUnusedGlobalSymbols\r\n  public get selectOptions() {\r\n    return this._selectOptions;\r\n  }\r\n\r\n  protected _selectedIndexes = [];\r\n\r\n  public get selectedIndexes(): Array<number> {\r\n    return this._selectedIndexes;\r\n  }\r\n\r\n  public set selectedIndexes(indexes: Array<number>) {\r\n    const oldSelectedIndexes = JSON.stringify(this._selectedIndexes);\r\n\r\n    this._selectedIndexes = indexes && indexes.length ? indexes.reduce((arr, value) => {\r\n      value = +value;\r\n\r\n      if (value > -1) {\r\n        arr.push(value);\r\n      }\r\n\r\n      return arr;\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  protected findIndex(value): number {\r\n    const comparedValue = this.getComparedValue(value);\r\n\r\n    return this._selectOptions.findIndex((option: { id, text, value, comparedValue }) => {\r\n      return comparedValue === option.comparedValue;\r\n    });\r\n  }\r\n\r\n  protected findIndexes(arrValue: Array<any>): Array<number> {\r\n    if (!arrValue || !arrValue.length) {\r\n      return [];\r\n    }\r\n\r\n    return arrValue.reduce((arr, value) => {\r\n      const index = this.findIndex(value);\r\n\r\n      if (index > -1) {\r\n        arr.push(index);\r\n      }\r\n\r\n      return arr;\r\n    }, []);\r\n  }\r\n\r\n  protected initOptions() {\r\n    this.beforeInitOptions();\r\n\r\n    const oldValue = this.value;\r\n\r\n    this._selectOptions = [];\r\n    if (this._options && this._options.length) {\r\n      this._options.map((option, index) => {\r\n        let text, value;\r\n\r\n        if ('string' === typeof option || 'number' === typeof option) {\r\n          text = option;\r\n          value = option;\r\n        } else {\r\n          text = option[this._textKey || 'text'];\r\n          value = this._valueKey ? option[this._valueKey] : option;\r\n        }\r\n\r\n        this._selectOptions.push({\r\n          id: index,\r\n          text: text,\r\n          value: value,\r\n          comparedValue: this.getComparedValue(option),\r\n        });\r\n      });\r\n    }\r\n\r\n    this.afterInitOptions();\r\n\r\n    this.writeValue(oldValue);\r\n\r\n    const newValue = this.value;\r\n\r\n    if (JSON.stringify(oldValue) !== JSON.stringify(newValue)) {\r\n      this.triggerChange();\r\n    }\r\n  }\r\n\r\n  protected beforeInitOptions() {\r\n  }\r\n\r\n  protected afterInitOptions() {\r\n  }\r\n\r\n  protected getComparedValue(option) {\r\n    if (!option) {\r\n      return '';\r\n    }\r\n\r\n    if ('string' === typeof option || 'number' === typeof option) {\r\n      return option;\r\n    }\r\n\r\n    let value;\r\n\r\n    if (this._comparedKey) {\r\n      value = option[this._comparedKey];\r\n    } else {\r\n      value = this._valueKey ? option[this._valueKey] : option;\r\n    }\r\n\r\n    if ('string' === typeof value || 'number' === typeof value) {\r\n      return value;\r\n    }\r\n\r\n    return JSON.stringify(value);\r\n  }\r\n\r\n  abstract get value();\r\n\r\n  abstract writeValue(value: any | Array<any>);\r\n\r\n}\r\n"]}