UNPKG

@formql/core

Version:

FormQL - A framework for building dynamic forms

122 lines 15.3 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'; var LayoutLoaderComponent = /** @class */ (function () { function LayoutLoaderComponent(vcRef, componentResolverService, storeService, internalEventHandlerService, actionHandlerService) { var _this = this; 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(function (response) { return _this.actionHandler(response); }); } Object.defineProperty(LayoutLoaderComponent.prototype, "formState", { set: function (formState) { var _this = this; if (!this.formLoaded && formState && formState.form) { if (this.target) this.target.clear(); var componentRef = this.vcRef.createComponent(this.componentResolverService.resolveComponent(formState.form.layoutComponentName)); var 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(function (response) { return _this.internalEventHandler(response); }); this.target.insert(component.hostView); this.formLoaded = true; } }, enumerable: true, configurable: true }); LayoutLoaderComponent.prototype.onSubmitTriggered = function () { this.submit.emit(null); }; LayoutLoaderComponent.prototype.saveData = function () { var _this = this; this.formSaveStart.emit(true); this.storeService.saveData().subscribe(function (response) { _this.formSaveEnd.emit(true); }, function (error) { _this.formError.emit(error); }); }; LayoutLoaderComponent.prototype.actionHandler = function (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; } }; LayoutLoaderComponent.prototype.internalEventHandler = function (response) { if (response) this.storeService.reSetForm(response.eventType, response.event); }; LayoutLoaderComponent.prototype.ngOnDestroy = function () { 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); return 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":";AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,SAAS,EACT,gBAAgB,EACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAc,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAEpE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAC1E,OAAO,EAAE,wBAAwB,EAAE,MAAM,wCAAwC,CAAC;AAClF,OAAO,EAAE,2BAA2B,EAAE,MAAM,4CAA4C,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAOzD;IAiCE,+BACU,KAAuB,EACvB,wBAAkD,EAClD,YAA0B,EAC1B,2BAAwD,EACxD,oBAA0C;QALpD,iBAQC;QAPS,UAAK,GAAL,KAAK,CAAkB;QACvB,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,iBAAY,GAAZ,YAAY,CAAc;QAC1B,gCAA2B,GAA3B,2BAA2B,CAA6B;QACxD,yBAAoB,GAApB,oBAAoB,CAAsB;QAnCpD,eAAU,GAAG,KAAK,CAAC;QACX,uBAAkB,GAAG,IAAI,OAAO,EAAE,CAAC;QAwBjC,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QAC5B,kBAAa,GAA0B,IAAI,YAAY,EAAE,CAAC;QAC1D,gBAAW,GAA0B,IAAI,YAAY,EAAE,CAAC;QACxD,cAAS,GAA0B,IAAI,YAAY,EAAE,CAAC;QAS9D,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,SAAS,CAAC,UAAC,QAAQ,IAAK,OAAA,KAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAA5B,CAA4B,CAAC,CAAC;IACzF,CAAC;IAlCD,sBAAI,4CAAS;aAAb,UAAc,SAAS;YADvB,iBAoBC;YAlBC,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,SAAS,IAAI,SAAS,CAAC,IAAI,EAAE;gBACnD,IAAI,IAAI,CAAC,MAAM;oBAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;gBAErC,IAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAC7C,IAAI,CAAC,wBAAwB,CAAC,gBAAgB,CAAC,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CACnF,CAAC;gBACF,IAAM,SAAS,GAAQ,YAAY,CAAC;gBACpC,SAAS,CAAC,QAAQ,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;gBACzC,SAAS,CAAC,QAAQ,CAAC,YAAY,GAAG,SAAS,CAAC,YAAY,CAAC;gBACzD,SAAS,CAAC,QAAQ,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;gBAEzC,IAAI,SAAS,CAAC,IAAI,KAAK,UAAU,CAAC,IAAI;oBACpC,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,SAAS,CAAC,UAAC,QAAQ,IAAK,OAAA,KAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,EAAnC,CAAmC,CAAC,CAAC;gBAEtG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;gBAEvC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;aACxB;QACH,CAAC;;;OAAA;IAiBD,iDAAiB,GAAjB;QACE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAED,wCAAQ,GAAR;QAAA,iBAUC;QATC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC,SAAS,CACpC,UAAC,QAAQ;YACP,KAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC,EACD,UAAC,KAAK;YACJ,KAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC,CACF,CAAC;IACJ,CAAC;IAED,6CAAa,GAAb,UAAc,aAAyB;QACrC,IAAI,aAAa;YACf,QAAQ,aAAa,CAAC,GAAG,EAAE;gBACzB,KAAK,cAAc,CAAC,IAAI;oBACtB,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAChB,MAAM;gBAER,KAAK,cAAc,CAAC,QAAQ;oBAC1B,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;oBACjC,MAAM;gBAER,KAAK,cAAc,CAAC,eAAe;oBACjC,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;oBACjC,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE;wBAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;oBACrD,MAAM;aACT;IACL,CAAC;IAED,oDAAoB,GAApB,UAAqB,QAA8B;QACjD,IAAI,QAAQ;YAAE,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAS,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;IAChF,CAAC;IAED,2CAAW,GAAX;QACE,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;QAC/B,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,CAAC;IACrC,CAAC;IAnF8D;QAA9D,SAAS,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;kCAAS,gBAAgB;yDAAC;IAMxF;QADC,KAAK,EAAE;;;0DAoBP;IAES;QAAT,MAAM,EAAE;;yDAA6B;IAC5B;QAAT,MAAM,EAAE;kCAAgB,YAAY;gEAA+B;IAC1D;QAAT,MAAM,EAAE;kCAAc,YAAY;8DAA+B;IACxD;QAAT,MAAM,EAAE;kCAAY,YAAY;4DAA+B;IA/BrD,qBAAqB;QALjC,SAAS,CAAC;YACT,QAAQ,EAAE,sBAAsB;YAChC,QAAQ,EAAE,uCAAuC;YACjD,eAAe,EAAE,uBAAuB,CAAC,MAAM;SAChD,CAAC;yCAmCiB,gBAAgB;YACG,wBAAwB;YACpC,YAAY;YACG,2BAA2B;YAClC,oBAAoB;OAtCzC,qBAAqB,CAqFjC;IAAD,4BAAC;CAAA,AArFD,IAqFC;SArFY,qBAAqB","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"]}