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