UNPKG

@formql/core

Version:

FormQL - A framework for building dynamic forms

114 lines 14.5 kB
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"]}