ngx-schema-forms
Version:
New features: - Ajv schema validator. - Angular forms compatible: Property tree is created using FormGroup, FormArray and FormControl classes. - Array now properly loads initial data from model. - WidgetTyep: WidgetRegistry now supports WidgetType, now wo
173 lines (172 loc) • 13.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { FormArray } from '@angular/forms';
import { FormPropertyErrors } from './form-property-errors';
import { ControlProperty } from './control-property';
var ArrayProperty = /** @class */ (function (_super) {
tslib_1.__extends(ArrayProperty, _super);
function ArrayProperty(formPropertyFactory, path, schema) {
var _this = _super.call(this, []) || this;
_this.formPropertyFactory = formPropertyFactory;
_this.path = path;
_this.schema = schema;
return _this;
}
/**
* @return {?}
*/
ArrayProperty.prototype._updateValue = /**
* @return {?}
*/
function () {
var _this = this;
// to avoid ts complaints
_super.prototype['_updateValue'].call(this);
this.nonEmptyValue = this.controls
.filter(function (control) {
/** @type {?} */
var enabled = control.enabled || _this.disabled;
return control.nonEmptyValue !== undefined && enabled;
})
.map(function (control) { return control.value; });
};
/**
* @return {?}
*/
ArrayProperty.prototype.getErrors = /**
* @return {?}
*/
function () {
/** @type {?} */
var aggregatedErrors = this.controls
.reduce(function (errors, property) {
/** @type {?} */
var propertyErrors = property.getErrors();
if (!propertyErrors) {
return errors;
}
return Object.assign(errors, propertyErrors.errors);
}, {});
if (this.errors) {
aggregatedErrors[this.path] = this.errors;
}
if (!Object.keys(aggregatedErrors).length) {
return null;
}
return new FormPropertyErrors(aggregatedErrors);
};
/**
* @param {?} value
* @param {?=} options
* @return {?}
*/
ArrayProperty.prototype.patchValue = /**
* @param {?} value
* @param {?=} options
* @return {?}
*/
function (value, options) {
var _this = this;
if (options === void 0) { options = {}; }
value.forEach(function (newValue, index) {
_this.addPropertyAt(index);
if (_this.at(index)) {
_this.at(index).patchValue(newValue, { onlySelf: true, emitEvent: options.emitEvent });
}
});
this.updateValueAndValidity(options);
};
/**
* @return {?}
*/
ArrayProperty.prototype.addProperty = /**
* @return {?}
*/
function () {
/** @type {?} */
var property = this.getPropertyFromSchemaItems();
_super.prototype.push.call(this, property);
property.bindVisibility();
};
/**
* @param {?} index
* @return {?}
*/
ArrayProperty.prototype.addPropertyAt = /**
* @param {?} index
* @return {?}
*/
function (index) {
/** @type {?} */
var property = this.getPropertyFromSchemaItems();
this.insert(index, property);
property.bindVisibility();
};
/**
* @return {?}
*/
ArrayProperty.prototype.bindVisibility = /**
* @return {?}
*/
function () {
_super.prototype.bindVisibility.call(this);
this.controls.forEach(function (control) {
control.bindVisibility();
});
};
/**
* @param {?} fn
* @param {?=} opts
* @return {?}
*/
ArrayProperty.prototype.forEach = /**
* @param {?} fn
* @param {?=} opts
* @return {?}
*/
function (fn, opts) {
if (opts === void 0) { opts = { includeSelf: true }; }
if (opts.includeSelf) {
fn(this);
}
try {
for (var _a = tslib_1.__values(this.controls), _b = _a.next(); !_b.done; _b = _a.next()) {
var control = _b.value;
/** @type {?} */
var property = /** @type {?} */ (control);
if (property.forEach instanceof Function) {
property.forEach(fn, { includeSelf: true });
continue;
}
fn(property);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
}
finally { if (e_1) throw e_1.error; }
}
var e_1, _c;
};
/**
* @return {?}
*/
ArrayProperty.prototype.getPropertyFromSchemaItems = /**
* @return {?}
*/
function () {
return this.formPropertyFactory.createProperty(this.schema["items"], this);
};
return ArrayProperty;
}(ControlProperty(FormArray)));
export { ArrayProperty };
if (false) {
/** @type {?} */
ArrayProperty.prototype.formPropertyFactory;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-property.js","sourceRoot":"ng://ngx-schema-forms/","sources":["lib/model/array-property.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormArray, ValidationErrors } from '@angular/forms';\n\nimport { Schema } from '../schema';\nimport { FormProperty } from './form-property';\nimport { FormPropertyErrors } from './form-property-errors';\nimport { FormPropertyFactory } from './form-property-factory';\nimport { ControlProperty } from './control-property';\nimport { GroupProperty } from './group-property';\n\n\nexport class ArrayProperty extends ControlProperty(FormArray) implements GroupProperty {\n\n  constructor(\n    private formPropertyFactory: FormPropertyFactory,\n    path: string,\n    schema: Schema\n  ) {\n    super([]);\n    this.path = path;\n    this.schema = schema;\n  }\n\n  _updateValue() {\n    // to avoid ts complaints\n    super['_updateValue']();\n\n    this.nonEmptyValue = this.controls\n      .filter((control: FormProperty) => {\n        const enabled = control.enabled || this.disabled;\n        return control.nonEmptyValue !== undefined && enabled;\n      })\n      .map((control) => control.value);\n  }\n\n  getErrors(): FormPropertyErrors | null {\n\n    const aggregatedErrors = this.controls\n      .reduce((errors, property: FormProperty) => {\n\n        const propertyErrors = property.getErrors();\n        if (!propertyErrors) {\n          return errors;\n        }\n\n        return Object.assign(errors, propertyErrors.errors);\n\n      }, {});\n\n    if (this.errors) {\n      aggregatedErrors[this.path] = this.errors;\n    }\n\n    if (!Object.keys(aggregatedErrors).length) {\n      return null;\n    }\n\n    return new FormPropertyErrors(aggregatedErrors);\n  }\n\n  patchValue(\n    value: any[],\n    options: {onlySelf?: boolean, emitEvent?: boolean} = {}\n  ) {\n    value.forEach((newValue: any, index: number) => {\n\n      this.addPropertyAt(index);\n\n      if (this.at(index)) {\n        this.at(index).patchValue(\n          newValue,\n          { onlySelf: true, emitEvent: options.emitEvent }\n        );\n      }\n    });\n    this.updateValueAndValidity(options);\n  }\n\n  addProperty() {\n    const property = this.getPropertyFromSchemaItems();\n    super.push(property);\n    property.bindVisibility();\n  }\n\n  addPropertyAt(index: number) {\n    const property = this.getPropertyFromSchemaItems();\n    this.insert(index, property);\n    property.bindVisibility();\n  }\n\n  bindVisibility() {\n    super.bindVisibility();\n\n    this.controls.forEach((control: FormProperty) => {\n      control.bindVisibility();\n    });\n  }\n\n  forEach(fn: (property: FormProperty) => void, opts = { includeSelf: true }) {\n\n    if (opts.includeSelf) {\n      fn(this);\n    }\n\n    for (const control of this.controls) {\n      const property = <GroupProperty>control;\n      if (property.forEach instanceof Function) {\n        property.forEach(fn, { includeSelf: true });\n        continue;\n      }\n\n      fn(property);\n    }\n  }\n\n  private getPropertyFromSchemaItems(): FormProperty {\n    return this.formPropertyFactory.createProperty(\n      this.schema.items,\n      this\n    );\n  }\n\n}\n\n\n"]}