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

165 lines (164 loc) 15.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Directive, Input, ViewContainerRef } from '@angular/core'; import { ActionRegistry } from '../model/actionregistry'; import { Unsubscriber } from '../unsubscriber'; import { WidgetFactory } from '../widgetfactory'; import { ButtonWidget } from '../widgets/base'; import { WidgetType } from '../widgetregistry'; import { TemplateElementType, TemplateSchemaElementRegistry } from '../template-schema/template-schema-element-registry'; export class FormButtonWidgetChooserDirective { /** * @param {?} viewContainerRef * @param {?} widgetFactory * @param {?} actionRegistry * @param {?} templateRegistry */ constructor(viewContainerRef, widgetFactory, actionRegistry, templateRegistry) { this.viewContainerRef = viewContainerRef; this.widgetFactory = widgetFactory; this.actionRegistry = actionRegistry; this.templateRegistry = templateRegistry; } /** * @return {?} */ getWidget() { /** @type {?} */ const id = 'button'; if (!this.button.widget) { return { id }; } if (!this.button.widget.id) { this.button.widget.id = id; } return this.button.widget; } /** * @param {?} widgetInstance * @return {?} */ getButtonAction(widgetInstance) { return (event, params) => { /** @type {?} */ const options = this.button.options; if (this.formProperty.invalid && options.onInvalidFormProperty.preventClick) { return; } /** @type {?} */ const action = this.actionRegistry.get(this.button.id); if (!action) { return; } action({ event, formProperty: this.formProperty }, params); if (event.hasOwnProperty('preventDefault')) { event.preventDefault(); } }; } /** * @return {?} */ bindTemplateChanges() { /** @type {?} */ const element = this.templateRegistry.getElement(this.button.id, TemplateElementType.Button); if (!element) { return; } // templateSchema button changes this.subs = element.changes.subscribe((button) => { /** @type {?} */ const instance = this.componentRef.instance; // TODO make sure widget id is not changed // TODO widget id change should trigger a form rebuild instance.label = button.label; if (typeof button.widget !== 'string') { Object.assign(instance.widget, button.widget); } Object.assign(instance.options, button.options); // TODO dont rebuild if there is no changes // rebuild action in case onInvalidProperty changed instance.action = this.getButtonAction(instance); this.componentRef.changeDetectorRef.detectChanges(); }); } /** * @return {?} */ ngOnInit() { /** @type {?} */ const widget = this.getWidget(); this.componentRef = this.widgetFactory.createWidget(this.viewContainerRef, widget.id, { type: WidgetType.Button }); /** @type {?} */ const instance = this.componentRef.instance; instance.label = this.button.label; instance.formProperty = this.formProperty; if (instance.widget) { Object.assign(instance.widget, widget); } else { instance.widget = widget; } // update instance options, with schema options Object.assign(instance.options, this.button.options); // after widget has been merged with defaults instance.action = this.getButtonAction(instance); // react to templateSchema button changes this.bindTemplateChanges(); } /** * @return {?} */ ngOnDestroy() { if (this.componentRef) { this.componentRef.destroy(); } if (this.viewContainerRef) { this.viewContainerRef.clear(); } } } FormButtonWidgetChooserDirective.decorators = [ { type: Directive, args: [{ selector: '[sfFormButtonWidgetChooser]' },] } ]; /** @nocollapse */ FormButtonWidgetChooserDirective.ctorParameters = () => [ { type: ViewContainerRef }, { type: WidgetFactory }, { type: ActionRegistry }, { type: TemplateSchemaElementRegistry } ]; FormButtonWidgetChooserDirective.propDecorators = { button: [{ type: Input }], formProperty: [{ type: Input }] }; tslib_1.__decorate([ Unsubscriber(), tslib_1.__metadata("design:type", Object) ], FormButtonWidgetChooserDirective.prototype, "subs", void 0); if (false) { /** @type {?} */ FormButtonWidgetChooserDirective.prototype.button; /** @type {?} */ FormButtonWidgetChooserDirective.prototype.formProperty; /** @type {?} */ FormButtonWidgetChooserDirective.prototype.componentRef; /** @type {?} */ FormButtonWidgetChooserDirective.prototype.subs; /** @type {?} */ FormButtonWidgetChooserDirective.prototype.viewContainerRef; /** @type {?} */ FormButtonWidgetChooserDirective.prototype.widgetFactory; /** @type {?} */ FormButtonWidgetChooserDirective.prototype.actionRegistry; /** @type {?} */ FormButtonWidgetChooserDirective.prototype.templateRegistry; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-button-widget-chooser.directive.js","sourceRoot":"ng://ngx-schema-forms/","sources":["lib/form/form-button-widget-chooser.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ComponentRef,\n  Input,\n  ViewContainerRef,\n  OnInit,\n  OnDestroy\n} from '@angular/core';\nimport { filter, distinctUntilChanged } from 'rxjs/operators';\n\nimport { ActionRegistry } from '../model/actionregistry';\nimport { Action, ActionEvent } from '../model/action';\nimport { FormProperty } from '../model/form-property';\nimport { Unsubscriber } from '../unsubscriber';\nimport { WidgetFactory } from '../widgetfactory';\nimport { ButtonWidget } from '../widgets/base';\nimport { WidgetType } from '../widgetregistry';\nimport { Widget } from '../widgets/base/widget';\nimport {\n  TemplateElementType,\n  TemplateSchemaElementRegistry\n} from '../template-schema/template-schema-element-registry';\nimport {\n  ButtonComponent\n} from '../template-schema/button/button.component';\n\n\n@Directive({\n  selector: '[sfFormButtonWidgetChooser]'\n})\nexport class FormButtonWidgetChooserDirective implements OnInit, OnDestroy {\n\n  @Input()\n  button: ButtonWidget; // from schema\n\n  @Input()\n  formProperty: FormProperty;\n\n  private componentRef: ComponentRef<ButtonWidget>;\n\n  @Unsubscriber()\n  private subs;\n\n  constructor(\n    private viewContainerRef: ViewContainerRef,\n    private widgetFactory: WidgetFactory,\n    private actionRegistry: ActionRegistry,\n    private templateRegistry: TemplateSchemaElementRegistry\n  ) { }\n\n\n  getWidget(): Widget  {\n    const id = 'button';\n    if (!this.button.widget) {\n      return { id };\n    }\n\n    if (!this.button.widget.id) {\n      this.button.widget.id = id;\n    }\n\n    return this.button.widget;\n  }\n\n  getButtonAction(widgetInstance: ButtonWidget): (event, params?) => void {\n\n    return (event, params?): void => {\n\n      const options = this.button.options;\n      if (this.formProperty.invalid && options.onInvalidFormProperty.preventClick) {\n        return;\n      }\n\n      const action = this.actionRegistry.get(this.button.id);\n      if (!action) {\n        return;\n      }\n\n      action({ event, formProperty: this.formProperty }, params);\n\n      if (event.hasOwnProperty('preventDefault')) {\n        event.preventDefault();\n      }\n    };\n\n  }\n\n  bindTemplateChanges() {\n    const element = this.templateRegistry.getElement<ButtonComponent>(\n      this.button.id,\n      TemplateElementType.Button\n    );\n\n    if (!element) {\n      return;\n    }\n\n    // templateSchema button changes\n    this.subs = element.changes.subscribe((button) => {\n\n      const instance = this.componentRef.instance;\n      // TODO make sure widget id is not changed\n      // TODO widget id change should trigger a form rebuild\n      instance.label = button.label;\n      if (typeof button.widget !== 'string') {\n        Object.assign(instance.widget, button.widget);\n      }\n\n      Object.assign(instance.options, button.options);\n      // TODO dont rebuild if there is no changes\n      // rebuild action in case onInvalidProperty changed\n      instance.action = this.getButtonAction(instance);\n\n      this.componentRef.changeDetectorRef.detectChanges();\n    });\n  }\n\n  ngOnInit() {\n    const widget = this.getWidget();\n    this.componentRef = this.widgetFactory.createWidget<ButtonWidget>(\n      this.viewContainerRef,\n      widget.id,\n      {\n        type: WidgetType.Button\n      }\n    );\n\n    const instance = this.componentRef.instance;\n    instance.label = this.button.label;\n    instance.formProperty = this.formProperty;\n\n    if (instance.widget) {\n      Object.assign(instance.widget, widget);\n    } else {\n      instance.widget = widget;\n    }\n\n    // update instance options, with schema options\n    Object.assign(instance.options, this.button.options);\n\n    // after widget has been merged with defaults\n    instance.action = this.getButtonAction(instance);\n\n    // react to templateSchema button changes\n    this.bindTemplateChanges();\n  }\n\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.destroy();\n    }\n    if (this.viewContainerRef) {\n      this.viewContainerRef.clear();\n    }\n  }\n}\n"]}