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