UNPKG

@formql/core

Version:

FormQL - A framework for building dynamic forms

106 lines 13.1 kB
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'; let PageWrapperComponent = class PageWrapperComponent { constructor(dndService, storeService) { this.dndService = dndService; this.storeService = storeService; this.FormQLMode = FormQLMode; this.ContainerType = ContainerType; this.ComponentPositionType = GridPositionType; } ngOnInit() { this.sections = this.createSections(this.page); } synchroniseModel($event, positionId) { const 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); } createSections(page) { const sections = {}; if (page && page.sections) page.sections.forEach(section => { if (sections && sections[section.position.id]) sections[section.position.id].push(section); else sections[section.position.id] = [section]; }); return sections; } trackByFn(index, item) { return item.id; } resetSections() { 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: ` <div class="fql-page-body"> <ng-template formqlGdConfig [formqlGdConfigOf]="page.template.body" let-bodyitem let-i="index" (resetItems)="resetSections()"> <div [ngClass]="{'fql-page-container': mode === FormQLMode.Edit}" [ngStyle]="bodyitem.style"> <div formqlDndDrop [type]="ContainerType.Section" [mode]="mode" [ngClass]="{'fql-page-container': (mode === FormQLMode.Edit)}" (synchronise)="synchroniseModel($event, bodyitem.id)"> <ng-container *ngFor="let section of sections[bodyitem.id]; trackBy: trackByFn"> <ng-container *ngTemplateOutlet="templateRef; context: {section: section}"> </ng-container> </ng-container> </div> </div> </ng-template> </div> <ng-template #templateRef let-section="section"> <div [formGroup]="reactivePage"> <div formql-section-wrapper [page]="page" [section]="section" [formGroupName]="section.sectionId" [reactiveSection]="reactivePage.controls[section.sectionId]" [mode]="mode"> </div> </div> </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); 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"]}