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

135 lines (134 loc) 13.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Directive, ContentChildren, QueryList, SimpleChange, Input } from '@angular/core'; import { merge } from 'rxjs'; import { filter } from 'rxjs/operators'; import { FormComponent } from '../form/form.component'; import { ActionRegistry } from '../model/actionregistry'; import { ValidatorRegistry } from '../model/validatorregistry'; import { SchemaPropertyType } from '../schema'; import { TemplateSchemaService } from './template-schema.service'; import { FieldComponent } from './field/field.component'; import { ButtonComponent } from './button/button.component'; import { FieldParent } from './field/field-parent'; import { TemplateSchemaElementRegistry } from '../template-schema/template-schema-element-registry'; var TemplateSchemaDirective = /** @class */ (function (_super) { tslib_1.__extends(TemplateSchemaDirective, _super); function TemplateSchemaDirective(formComponent, templateSchemaService, actionRegistry, validatorRegistry, templateRegistry) { var _this = _super.call(this) || this; _this.formComponent = formComponent; _this.templateSchemaService = templateSchemaService; _this.actionRegistry = actionRegistry; _this.validatorRegistry = validatorRegistry; _this.templateRegistry = templateRegistry; return _this; } /** * @param {?} fields * @return {?} */ TemplateSchemaDirective.prototype.setFormDocumentSchema = /** * @param {?} fields * @return {?} */ function (fields) { var _this = this; this.actionRegistry.clear(); this.validatorRegistry.clear(); /** @type {?} */ var schema = this.getFieldsSchema(fields); this.templateRegistry.clear(); // register fields recursively fields.forEach(function (field) { field.register(); }); /** @type {?} */ var _validators = this.getFieldsValidators(fields); _validators.forEach(function (_a) { var path = _a.path, validators = _a.validators; _this.validatorRegistry.register(path, validators); }); /** @type {?} */ var previousSchema = this.formComponent.schema; this.formComponent.schema = { type: SchemaPropertyType.Object, properties: schema.properties }; if (this.fieldsets) { this.formComponent.schema.fieldsets = this.fieldsets; } if (schema.required && schema.required.length > 0) { this.formComponent.schema.required = schema.required; } /** @type {?} */ var buttons = this.getButtons(); if (buttons.length > 0) { this.formComponent.schema.buttons = buttons; } this.formComponent.ngOnChanges({ schema: new SimpleChange(previousSchema, this.formComponent.schema, Boolean(previousSchema)) }); }; /** * @return {?} */ TemplateSchemaDirective.prototype.ngAfterContentInit = /** * @return {?} */ function () { var _this = this; if (this.childFields.length > 0) { this.setFormDocumentSchema(this.childFields.toArray()); } merge(this.childFields.changes, this.childButtons.changes, this.templateSchemaService.changes) .pipe(filter(function (value) { return Boolean(value); })) .subscribe(function () { _this.setFormDocumentSchema(_this.childFields.toArray()); }); }; TemplateSchemaDirective.decorators = [ { type: Directive, args: [{ selector: 'sf-form[templateSchema]', providers: [ TemplateSchemaService ] },] } ]; /** @nocollapse */ TemplateSchemaDirective.ctorParameters = function () { return [ { type: FormComponent }, { type: TemplateSchemaService }, { type: ActionRegistry }, { type: ValidatorRegistry }, { type: TemplateSchemaElementRegistry } ]; }; TemplateSchemaDirective.propDecorators = { childFields: [{ type: ContentChildren, args: [FieldComponent,] }], childButtons: [{ type: ContentChildren, args: [ButtonComponent,] }], fieldsets: [{ type: Input }] }; return TemplateSchemaDirective; }(FieldParent)); export { TemplateSchemaDirective }; if (false) { /** @type {?} */ TemplateSchemaDirective.prototype.childFields; /** @type {?} */ TemplateSchemaDirective.prototype.childButtons; /** @type {?} */ TemplateSchemaDirective.prototype.fieldsets; /** @type {?} */ TemplateSchemaDirective.prototype.formComponent; /** @type {?} */ TemplateSchemaDirective.prototype.templateSchemaService; /** @type {?} */ TemplateSchemaDirective.prototype.actionRegistry; /** @type {?} */ TemplateSchemaDirective.prototype.validatorRegistry; /** @type {?} */ TemplateSchemaDirective.prototype.templateRegistry; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template-schema.directive.js","sourceRoot":"ng://ngx-schema-forms/","sources":["lib/template-schema/template-schema.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ContentChildren,\n  QueryList,\n  AfterContentInit,\n  HostBinding,\n  SimpleChange,\n  SimpleChanges,\n  Input\n} from '@angular/core';\nimport { merge } from 'rxjs';\nimport { filter, debounceTime } from 'rxjs/operators';\n\nimport { FormComponent } from '../form/form.component';\nimport { ActionRegistry } from '../model/actionregistry';\nimport { ValidatorRegistry } from '../model/validatorregistry';\nimport { SchemaPropertyType } from '../schema';\n\nimport { TemplateSchemaService } from './template-schema.service';\nimport { FieldComponent } from './field/field.component';\nimport { Field } from './field/field';\nimport { ButtonComponent } from './button/button.component';\nimport { FieldParent } from './field/field-parent';\nimport {\n  TemplateSchemaElementRegistry\n} from '../template-schema/template-schema-element-registry';\n\n\n@Directive({\n  selector: 'sf-form[templateSchema]',\n  providers: [\n    TemplateSchemaService\n  ]\n})\nexport class TemplateSchemaDirective extends FieldParent\nimplements AfterContentInit {\n\n  @ContentChildren(FieldComponent)\n  childFields: QueryList<FieldComponent>;\n\n  @ContentChildren(ButtonComponent)\n  childButtons: QueryList<ButtonComponent>;\n\n  @Input()\n  fieldsets: { [key: string]: any }[];\n\n  constructor(\n    private formComponent: FormComponent,\n    private templateSchemaService: TemplateSchemaService,\n    protected actionRegistry: ActionRegistry,\n    protected validatorRegistry: ValidatorRegistry,\n    protected templateRegistry: TemplateSchemaElementRegistry,\n  ) {\n    super();\n  }\n\n  setFormDocumentSchema(fields: FieldComponent[]) {\n    this.actionRegistry.clear();\n    this.validatorRegistry.clear();\n\n    const schema = this.getFieldsSchema(fields);\n\n    this.templateRegistry.clear();\n    // register fields recursively\n    fields.forEach((field) => {\n      field.register();\n    });\n\n    const _validators = this.getFieldsValidators(fields);\n    _validators.forEach(({ path, validators }) => {\n      this.validatorRegistry.register(path, validators);\n    });\n\n    const previousSchema = this.formComponent.schema;\n    this.formComponent.schema = {\n      type: SchemaPropertyType.Object,\n      properties: schema.properties\n    };\n\n    if (this.fieldsets) {\n      this.formComponent.schema.fieldsets = this.fieldsets;\n    }\n\n    if (schema.required && schema.required.length > 0) {\n      this.formComponent.schema.required = schema.required;\n    }\n\n    const buttons = this.getButtons();\n    if (buttons.length > 0) {\n      this.formComponent.schema.buttons = buttons;\n    }\n\n    this.formComponent.ngOnChanges({\n      schema: new SimpleChange(\n        previousSchema,\n        this.formComponent.schema,\n        Boolean(previousSchema)\n      )\n    });\n\n  }\n\n\n  ngAfterContentInit() {\n\n    if (this.childFields.length > 0) {\n      this.setFormDocumentSchema(this.childFields.toArray());\n    }\n\n    merge(\n      this.childFields.changes,\n      this.childButtons.changes,\n      this.templateSchemaService.changes\n    )\n    .pipe(\n      filter((value) => Boolean(value)),\n      // building the json schema is a heavy task, avoid unnecessary builds\n      // TODO use this\n      // debounceTime(50)\n    )\n    .subscribe(() => {\n      this.setFormDocumentSchema(this.childFields.toArray());\n    });\n\n  }\n\n}\n"]}