UNPKG

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
/** * @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"]}