@formql/core
Version:
FormQL - A framework for building dynamic forms
122 lines • 15.3 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';
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"]}