@formql/core
Version:
FormQL - A framework for building dynamic forms
114 lines • 14.5 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild, ViewContainerRef } from '@angular/core';
import { Subject } from 'rxjs';
import { FormActionType } from '../models/action.model';
import { FormQLMode } from '../models/type.model';
import { ActionHandlerService } from '../services/action-handler.service';
import { ComponentResolverService } from '../services/component-resolver.service';
import { InternalEventHandlerService } from '../services/internal-event-handler.service';
import { StoreService } from '../services/store.service';
let LayoutLoaderComponent = class LayoutLoaderComponent {
constructor(vcRef, componentResolverService, storeService, internalEventHandlerService, actionHandlerService) {
this.vcRef = vcRef;
this.componentResolverService = componentResolverService;
this.storeService = storeService;
this.internalEventHandlerService = internalEventHandlerService;
this.actionHandlerService = actionHandlerService;
this.formLoaded = false;
this.componentDestroyed = new Subject();
this.submit = new EventEmitter();
this.formSaveStart = new EventEmitter();
this.formSaveEnd = new EventEmitter();
this.formError = new EventEmitter();
this.actionHandlerService.action.subscribe((response) => this.actionHandler(response));
}
set formState(formState) {
if (!this.formLoaded && formState && formState.form) {
if (this.target)
this.target.clear();
const componentRef = this.vcRef.createComponent(this.componentResolverService.resolveComponent(formState.form.layoutComponentName));
const component = componentRef;
component.instance.form = formState.form;
component.instance.reactiveForm = formState.reactiveForm;
component.instance.mode = formState.mode;
if (formState.mode === FormQLMode.Edit)
this.internalEventHandlerService.event.subscribe((response) => this.internalEventHandler(response));
this.target.insert(component.hostView);
this.formLoaded = true;
}
}
onSubmitTriggered() {
this.submit.emit(null);
}
saveData() {
this.formSaveStart.emit(true);
this.storeService.saveData().subscribe((response) => {
this.formSaveEnd.emit(true);
}, (error) => {
this.formError.emit(error);
});
}
actionHandler(actionHandler) {
if (actionHandler)
switch (actionHandler.key) {
case FormActionType.Save:
this.saveData();
break;
case FormActionType.Validate:
this.storeService.validateForm();
break;
case FormActionType.ValidateAndSave:
this.storeService.validateForm();
if (this.storeService.isFormValid())
this.saveData();
break;
}
}
internalEventHandler(response) {
if (response)
this.storeService.reSetForm(response.eventType, response.event);
}
ngOnDestroy() {
this.componentDestroyed.next();
this.componentDestroyed.complete();
}
};
__decorate([
ViewChild('target', { read: ViewContainerRef, static: true }),
__metadata("design:type", ViewContainerRef)
], LayoutLoaderComponent.prototype, "target", void 0);
__decorate([
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], LayoutLoaderComponent.prototype, "formState", null);
__decorate([
Output(),
__metadata("design:type", Object)
], LayoutLoaderComponent.prototype, "submit", void 0);
__decorate([
Output(),
__metadata("design:type", EventEmitter)
], LayoutLoaderComponent.prototype, "formSaveStart", void 0);
__decorate([
Output(),
__metadata("design:type", EventEmitter)
], LayoutLoaderComponent.prototype, "formSaveEnd", void 0);
__decorate([
Output(),
__metadata("design:type", EventEmitter)
], LayoutLoaderComponent.prototype, "formError", void 0);
LayoutLoaderComponent = __decorate([
Component({
selector: 'formql-layout-loader',
template: `<ng-container #target></ng-container>`,
changeDetection: ChangeDetectionStrategy.OnPush
}),
__metadata("design:paramtypes", [ViewContainerRef,
ComponentResolverService,
StoreService,
InternalEventHandlerService,
ActionHandlerService])
], LayoutLoaderComponent);
export { LayoutLoaderComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout-loader.component.js","sourceRoot":"ng://@formql/core/","sources":["components/layout-loader.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  ViewChild,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { FormAction, FormActionType } from '../models/action.model';\r\nimport { InternalEventHandler } from '../models/internal-event.model';\r\nimport { FormQLMode } from '../models/type.model';\r\nimport { ActionHandlerService } from '../services/action-handler.service';\r\nimport { ComponentResolverService } from '../services/component-resolver.service';\r\nimport { InternalEventHandlerService } from '../services/internal-event-handler.service';\r\nimport { StoreService } from '../services/store.service';\r\n\r\n@Component({\r\n  selector: 'formql-layout-loader',\r\n  template: `<ng-container #target></ng-container>`,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class LayoutLoaderComponent implements OnDestroy {\r\n  @ViewChild('target', { read: ViewContainerRef, static: true }) target: ViewContainerRef;\r\n\r\n  formLoaded = false;\r\n  private componentDestroyed = new Subject();\r\n\r\n  @Input()\r\n  set formState(formState) {\r\n    if (!this.formLoaded && formState && formState.form) {\r\n      if (this.target) this.target.clear();\r\n\r\n      const componentRef = this.vcRef.createComponent(\r\n        this.componentResolverService.resolveComponent(formState.form.layoutComponentName)\r\n      );\r\n      const component = <any>componentRef;\r\n      component.instance.form = formState.form;\r\n      component.instance.reactiveForm = formState.reactiveForm;\r\n      component.instance.mode = formState.mode;\r\n\r\n      if (formState.mode === FormQLMode.Edit)\r\n        this.internalEventHandlerService.event.subscribe((response) => this.internalEventHandler(response));\r\n\r\n      this.target.insert(component.hostView);\r\n\r\n      this.formLoaded = true;\r\n    }\r\n  }\r\n\r\n  @Output() submit = new EventEmitter();\r\n  @Output() formSaveStart: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() formSaveEnd: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() formError: EventEmitter<boolean> = new EventEmitter();\r\n\r\n  constructor(\r\n    private vcRef: ViewContainerRef,\r\n    private componentResolverService: ComponentResolverService,\r\n    private storeService: StoreService,\r\n    private internalEventHandlerService: InternalEventHandlerService,\r\n    private actionHandlerService: ActionHandlerService\r\n  ) {\r\n    this.actionHandlerService.action.subscribe((response) => this.actionHandler(response));\r\n  }\r\n\r\n  onSubmitTriggered() {\r\n    this.submit.emit(null);\r\n  }\r\n\r\n  saveData() {\r\n    this.formSaveStart.emit(true);\r\n    this.storeService.saveData().subscribe(\r\n      (response) => {\r\n        this.formSaveEnd.emit(true);\r\n      },\r\n      (error) => {\r\n        this.formError.emit(error);\r\n      }\r\n    );\r\n  }\r\n\r\n  actionHandler(actionHandler: FormAction) {\r\n    if (actionHandler)\r\n      switch (actionHandler.key) {\r\n        case FormActionType.Save:\r\n          this.saveData();\r\n          break;\r\n\r\n        case FormActionType.Validate:\r\n          this.storeService.validateForm();\r\n          break;\r\n\r\n        case FormActionType.ValidateAndSave:\r\n          this.storeService.validateForm();\r\n          if (this.storeService.isFormValid()) this.saveData();\r\n          break;\r\n      }\r\n  }\r\n\r\n  internalEventHandler(response: InternalEventHandler) {\r\n    if (response) this.storeService.reSetForm(response.eventType, response.event);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.componentDestroyed.next();\r\n    this.componentDestroyed.complete();\r\n  }\r\n}\r\n"]}