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