@formql/core
Version:
FormQL - A framework for building dynamic forms
76 lines • 13.5 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, Input } from '@angular/core';
import { FormGroup } from '@angular/forms';
import { DndService } from '../services/dnd.service';
import { FormQLMode, ContainerType } from '../models/type.model';
import { GridPositionType } from '../models/style.model';
import { StoreService } from '../services/store.service';
import { InternalEventType } from '../models/internal-event.model';
var PageWrapperComponent = /** @class */ (function () {
function PageWrapperComponent(dndService, storeService) {
this.dndService = dndService;
this.storeService = storeService;
this.FormQLMode = FormQLMode;
this.ContainerType = ContainerType;
this.ComponentPositionType = GridPositionType;
}
PageWrapperComponent.prototype.ngOnInit = function () {
this.sections = this.createSections(this.page);
};
PageWrapperComponent.prototype.synchroniseModel = function ($event, positionId) {
var dndEvent = {
sourceObjectId: $event.sourceObjectId,
sourceWrapperId: $event.sourceWrapperId,
targetPositionId: positionId,
targetWrapperId: this.page.pageId,
targetIndexId: $event.targetIndexId
};
this.page = this.dndService.synchronisePageModel(this.page, dndEvent);
this.sections = this.createSections(this.page);
this.storeService.reSetForm(InternalEventType.DndFormChanged, this.page);
};
PageWrapperComponent.prototype.createSections = function (page) {
var sections = {};
if (page && page.sections)
page.sections.forEach(function (section) {
if (sections && sections[section.position.id])
sections[section.position.id].push(section);
else
sections[section.position.id] = [section];
});
return sections;
};
PageWrapperComponent.prototype.trackByFn = function (index, item) {
return item.id;
};
PageWrapperComponent.prototype.resetSections = function () {
if (this.sections)
this.sections = this.createSections(this.page);
};
__decorate([
Input(),
__metadata("design:type", Object)
], PageWrapperComponent.prototype, "page", void 0);
__decorate([
Input(),
__metadata("design:type", FormGroup)
], PageWrapperComponent.prototype, "reactivePage", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], PageWrapperComponent.prototype, "mode", void 0);
PageWrapperComponent = __decorate([
Component({
// tslint:disable-next-line: component-selector
selector: '[formql-page-wrapper]',
template: "\n <div class=\"fql-page-body\">\n <ng-template formqlGdConfig\n [formqlGdConfigOf]=\"page.template.body\" let-bodyitem let-i=\"index\"\n (resetItems)=\"resetSections()\">\n <div\n [ngClass]=\"{'fql-page-container': mode === FormQLMode.Edit}\"\n [ngStyle]=\"bodyitem.style\">\n <div formqlDndDrop\n [type]=\"ContainerType.Section\"\n [mode]=\"mode\"\n [ngClass]=\"{'fql-page-container': (mode === FormQLMode.Edit)}\"\n (synchronise)=\"synchroniseModel($event, bodyitem.id)\">\n <ng-container *ngFor=\"let section of sections[bodyitem.id]; trackBy: trackByFn\">\n <ng-container *ngTemplateOutlet=\"templateRef; context: {section: section}\">\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-template>\n </div>\n <ng-template #templateRef let-section=\"section\">\n <div [formGroup]=\"reactivePage\">\n <div formql-section-wrapper\n [page]=\"page\"\n [section]=\"section\"\n [formGroupName]=\"section.sectionId\"\n [reactiveSection]=\"reactivePage.controls[section.sectionId]\"\n [mode]=\"mode\">\n </div>\n </div>\n </ng-template>",
providers: [DndService],
styles: [".fql-bundle-field-input{width:100%;box-sizing:border-box;-webkit-box-sizing:border-box;-moz-box-sizing:border-box}.fql-bundle-checkbox-input{cursor:pointer;box-sizing:border-box;-webkit-box-sizing:border-box;-moz-box-sizing:border-box}.fql-bundle-label-required:after{content:\" *\";color:red}.fql-bundle-field-radio{cursor:pointer}.fql-error-message{text-align:center;padding:20px}.fql-dnd-container-separator{box-shadow:0 -2px 0 #00f}.fql-dnd-container-drop-area{outline:dashed 3px}.fql-page-body{display:-ms-grid;display:grid;width:100%;min-height:30px}.fql-page-container{display:table;height:100%;width:100%;min-height:15px}.fql-page-container:hover{outline:solid 2px}"]
}),
__metadata("design:paramtypes", [DndService,
StoreService])
], PageWrapperComponent);
return PageWrapperComponent;
}());
export { PageWrapperComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-wrapper.component.js","sourceRoot":"ng://@formql/core/","sources":["components/page-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ChangeDetectionStrategy } from '@angular/core';\r\nimport { FormPage } from '../models/form-page.model';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { DndService } from '../services/dnd.service';\r\nimport { FormQLMode, ContainerType } from '../models/type.model';\r\nimport { GridPositionType } from '../models/style.model';\r\nimport { DndTransfer, DndEvent } from '../models/dnd.model';\r\nimport { StoreService } from '../services/store.service';\r\nimport { InternalEventType } from '../models/internal-event.model';\r\nimport { FormSection, SectionGroup } from '../models/form-section.model';\r\n\r\n@Component({\r\n  // tslint:disable-next-line: component-selector\r\n  selector: '[formql-page-wrapper]',\r\n  template: `\r\n      <div class=\"fql-page-body\">\r\n        <ng-template formqlGdConfig\r\n          [formqlGdConfigOf]=\"page.template.body\" let-bodyitem let-i=\"index\"\r\n          (resetItems)=\"resetSections()\">\r\n          <div\r\n            [ngClass]=\"{'fql-page-container': mode === FormQLMode.Edit}\"\r\n            [ngStyle]=\"bodyitem.style\">\r\n            <div formqlDndDrop\r\n              [type]=\"ContainerType.Section\"\r\n              [mode]=\"mode\"\r\n              [ngClass]=\"{'fql-page-container': (mode === FormQLMode.Edit)}\"\r\n              (synchronise)=\"synchroniseModel($event, bodyitem.id)\">\r\n              <ng-container *ngFor=\"let section of sections[bodyitem.id]; trackBy: trackByFn\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef; context: {section: section}\">\r\n                </ng-container>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </ng-template>\r\n      </div>\r\n      <ng-template #templateRef let-section=\"section\">\r\n        <div [formGroup]=\"reactivePage\">\r\n          <div formql-section-wrapper\r\n            [page]=\"page\"\r\n            [section]=\"section\"\r\n            [formGroupName]=\"section.sectionId\"\r\n            [reactiveSection]=\"reactivePage.controls[section.sectionId]\"\r\n            [mode]=\"mode\">\r\n          </div>\r\n        </div>\r\n      </ng-template>`,\r\n  styleUrls: ['./page-wrapper.component.scss'],\r\n  providers: [DndService]\r\n})\r\nexport class PageWrapperComponent implements OnInit {\r\n\r\n  @Input() public page: FormPage;\r\n  @Input() public reactivePage: FormGroup;\r\n  @Input() public mode: FormQLMode;\r\n\r\n  public FormQLMode = FormQLMode;\r\n  public ContainerType = ContainerType;\r\n  public ComponentPositionType = GridPositionType;\r\n\r\n  error: string;\r\n  row: any;\r\n  sections: SectionGroup;\r\n\r\n  constructor(\r\n    private dndService: DndService,\r\n    private storeService: StoreService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.sections = this.createSections(this.page);\r\n  }\r\n\r\n  synchroniseModel($event: DndTransfer, positionId: string) {\r\n    const dndEvent = <DndEvent>{\r\n      sourceObjectId: $event.sourceObjectId,\r\n      sourceWrapperId: $event.sourceWrapperId,\r\n      targetPositionId: positionId,\r\n      targetWrapperId: this.page.pageId,\r\n      targetIndexId: $event.targetIndexId\r\n    };\r\n    this.page = this.dndService.synchronisePageModel(this.page, dndEvent);\r\n    this.sections = this.createSections(this.page);\r\n    this.storeService.reSetForm(InternalEventType.DndFormChanged, this.page);\r\n  }\r\n\r\n  private createSections(page: FormPage): SectionGroup {\r\n    const sections = <SectionGroup>{};\r\n    if (page && page.sections)\r\n      page.sections.forEach(section => {\r\n        if (sections && sections[section.position.id])\r\n          sections[section.position.id].push(section);\r\n        else\r\n          sections[section.position.id] = [section];\r\n      });\r\n\r\n    return sections;\r\n  }\r\n\r\n  trackByFn(index, item) {\r\n    return item.id;\r\n  }\r\n\r\n  resetSections() {\r\n    if (this.sections)\r\n      this.sections = this.createSections(this.page);\r\n  }\r\n}\r\n"]}