@formql/core
Version:
FormQL - A framework for building dynamic forms
167 lines • 23.8 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, Input, ViewChild, ViewContainerRef } from '@angular/core';
import { FormGroup } from '@angular/forms';
import { InternalEventHandlerService } from '../services/internal-event-handler.service';
import { InternalEventType } from '../models/internal-event.model';
import { ComponentResolverService } from '../services/component-resolver.service';
import { FormQLMode, ContainerType } from '../models/type.model';
import { GridPositionType } from '../models/style.model';
import { DndService } from '../services/dnd.service';
import { StoreService } from '../services/store.service';
let SectionWrapperComponent = class SectionWrapperComponent {
constructor(internalEventHandlerService, componentResolverService, viewContainerRef, dndService, storeService) {
this.internalEventHandlerService = internalEventHandlerService;
this.componentResolverService = componentResolverService;
this.viewContainerRef = viewContainerRef;
this.dndService = dndService;
this.storeService = storeService;
this.FormQLMode = FormQLMode;
this.ContainerType = ContainerType;
this.ComponentPositionType = GridPositionType;
}
ngOnInit() {
this.components = this.createComponents(this.section);
if (this.mode === FormQLMode.Edit) {
const tooltip = this.viewContainerRef.createComponent(this.componentResolverService.resolveComponent('TooltipComponent'));
tooltip.instance.wrapper = this.wrapper;
tooltip.instance.type = ContainerType.Section;
tooltip.instance.object = this.section;
this.tooltip.insert(tooltip.hostView);
}
}
editField() {
if (this.mode === FormQLMode.Edit)
this.internalEventHandlerService.send(InternalEventType.EditingSection, this.section);
}
synchroniseModel($event, positionId, positionType) {
const dndEvent = {
sourceObjectId: $event.sourceObjectId,
sourceWrapperId: $event.sourceWrapperId,
targetPositionId: positionId,
targetWrapperId: this.section.sectionId,
targetIndexId: $event.targetIndexId,
positionType: positionType
};
this.page = this.dndService.synchroniseSectionModel(this.page, dndEvent);
this.storeService.reSetForm(InternalEventType.DndFormChanged, this.page);
}
trackByFn(index, item) {
return item.id;
}
createComponents(section) {
const components = {};
if (section && section.components)
section.components.sort((left, right) => {
return left.position.index - right.position.index;
});
section.components.forEach(component => {
if (components && components[component.position.type + '_' + component.position.id])
components[component.position.type + '_' + component.position.id].push(component);
else
components[component.position.type + '_' + component.position.id] = [component];
});
return components;
}
};
__decorate([
ViewChild('wrapper', { read: ViewContainerRef, static: true }),
__metadata("design:type", ViewContainerRef)
], SectionWrapperComponent.prototype, "wrapper", void 0);
__decorate([
ViewChild('tooltip', { read: ViewContainerRef, static: true }),
__metadata("design:type", ViewContainerRef)
], SectionWrapperComponent.prototype, "tooltip", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], SectionWrapperComponent.prototype, "section", void 0);
__decorate([
Input(),
__metadata("design:type", FormGroup)
], SectionWrapperComponent.prototype, "reactiveSection", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], SectionWrapperComponent.prototype, "page", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], SectionWrapperComponent.prototype, "mode", void 0);
SectionWrapperComponent = __decorate([
Component({
// tslint:disable-next-line: component-selector
selector: '[formql-section-wrapper]',
template: `
<div #wrapper formqlDnd
[sourceObjectId]="section.sectionId"
[attr.sectionId]="section.sectionId"
[sourceWrapperId]="page.pageId"
[type]="ContainerType.Section"
[mode]="mode"
[ngClass]="[(mode === FormQLMode.Edit) ? 'fql-section-wrapper-edit' : 'fql-section-wrapper']">
<div class="fql-section-tooltip">
<ng-container #tooltip></ng-container>
</div>
<div *ngIf="section.template && !section.template.header.hidden" class="fql-section-header">
<ng-template formqlGdConfig
[formqlGdConfigOf]="section.template.header" let-headeritem let-i="index">
<ng-container *ngTemplateOutlet="templateRef;
context: {
templateitem: headeritem,
positionType: ComponentPositionType.Header
}">
</ng-container>
</ng-template>
</div>
<div *ngIf="section.template && !section.template.body.hidden" class="fql-section-body">
<ng-template formqlGdConfig
[formqlGdConfigOf]="section.template.body" let-bodyitem let-i="index">
<ng-container *ngTemplateOutlet="templateRef;
context: {
templateitem: bodyitem,
positionType: ComponentPositionType.Body
}">
</ng-container>
</ng-template>
</div>
</div>
<ng-template #templateRef let-templateitem="templateitem" let-positionType="positionType">
<div [ngStyle]="templateitem.style">
<div formqlDndDrop
*ngIf="(mode === FormQLMode.Edit)"
[type]="ContainerType.Component"
class="fql-section-container"
(synchronise)="synchroniseModel($event, templateitem.id, positionType)">
<ng-container *ngFor="let component of components[positionType + '_' + templateitem.id]; trackBy: trackByFn">
<div formql-component-container
[ngClass]="{'fql-component-container-hidden': component.rules?.hidden?.value}"
[component]="component"
[sectionId]="section.sectionId"
[value]="component.value"
[reactiveSection]="reactiveSection"
[mode]="mode"></div>
</ng-container>
</div>
<div *ngIf="mode !== FormQLMode.Edit">
<ng-container *ngFor="let component of components[positionType + '_' + templateitem.id]; trackBy: trackByFn">
<div formql-component-container *ngIf="!component.rules?.hidden?.value"
[component]="component"
[sectionId]="section.sectionId"
[value]="component.value"
[reactiveSection]="reactiveSection"
[mode]="mode"></div>
</ng-container>
</div>
</div>
</ng-template>
`,
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-section-wrapper,.fql-section-wrapper-edit{display:-ms-grid;display:grid;padding:1px;-ms-grid-columns:100%;grid-template-columns:100%;-ms-grid-rows:auto auto;grid-template-rows:auto auto;position:relative}.fql-section-wrapper-edit:hover .fql-section-tooltip{opacity:1}.fql-section-tooltip{opacity:0;display:block;position:absolute;right:0;z-index:1;transition:opacity .3s}.fql-section-header{display:-ms-grid;display:grid;min-height:30px;-ms-grid-row:1;-ms-grid-column:1}.fql-section-body{display:-ms-grid;display:grid;min-height:30px;-ms-grid-row:2;-ms-grid-column:1}.fql-section-container{display:table;height:100%;width:100%;min-height:15px}.fql-section-container:hover{outline:solid 1px}.fql-component-container-hidden{background-color:#ffecf2}"]
}),
__metadata("design:paramtypes", [InternalEventHandlerService,
ComponentResolverService,
ViewContainerRef,
DndService,
StoreService])
], SectionWrapperComponent);
export { SectionWrapperComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"section-wrapper.component.js","sourceRoot":"ng://@formql/core/","sources":["components/section-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, ViewContainerRef, OnInit } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { FormSection } from '../models/form-section.model';\r\nimport { InternalEventHandlerService } from '../services/internal-event-handler.service';\r\nimport { InternalEventType } from '../models/internal-event.model';\r\nimport { FormPage } from '../models/form-page.model';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { ComponentResolverService } from '../services/component-resolver.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 { DndService } from '../services/dnd.service';\r\nimport { StoreService } from '../services/store.service';\r\nimport { ComponentGroup, FormComponent } from '../models/form-component.model';\r\n\r\n@Component({\r\n  // tslint:disable-next-line: component-selector\r\n  selector: '[formql-section-wrapper]',\r\n  template: `\r\n        <div #wrapper formqlDnd\r\n            [sourceObjectId]=\"section.sectionId\"\r\n            [attr.sectionId]=\"section.sectionId\"\r\n            [sourceWrapperId]=\"page.pageId\"\r\n            [type]=\"ContainerType.Section\"\r\n            [mode]=\"mode\"\r\n            [ngClass]=\"[(mode === FormQLMode.Edit) ? 'fql-section-wrapper-edit' : 'fql-section-wrapper']\">\r\n            <div class=\"fql-section-tooltip\">\r\n                <ng-container #tooltip></ng-container>\r\n            </div>\r\n            <div *ngIf=\"section.template && !section.template.header.hidden\" class=\"fql-section-header\">\r\n                <ng-template formqlGdConfig\r\n                    [formqlGdConfigOf]=\"section.template.header\" let-headeritem let-i=\"index\">\r\n                    <ng-container *ngTemplateOutlet=\"templateRef;\r\n                      context: {\r\n                        templateitem: headeritem,\r\n                        positionType: ComponentPositionType.Header\r\n                      }\">\r\n                    </ng-container>\r\n                </ng-template>\r\n            </div>\r\n            <div *ngIf=\"section.template && !section.template.body.hidden\" class=\"fql-section-body\">\r\n                <ng-template formqlGdConfig\r\n                    [formqlGdConfigOf]=\"section.template.body\" let-bodyitem let-i=\"index\">\r\n                    <ng-container *ngTemplateOutlet=\"templateRef;\r\n                      context: {\r\n                        templateitem: bodyitem,\r\n                        positionType: ComponentPositionType.Body\r\n                      }\">\r\n                    </ng-container>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n        <ng-template #templateRef let-templateitem=\"templateitem\" let-positionType=\"positionType\">\r\n          <div [ngStyle]=\"templateitem.style\">\r\n            <div formqlDndDrop\r\n              *ngIf=\"(mode === FormQLMode.Edit)\"\r\n              [type]=\"ContainerType.Component\"\r\n              class=\"fql-section-container\"\r\n              (synchronise)=\"synchroniseModel($event, templateitem.id, positionType)\">\r\n              <ng-container *ngFor=\"let component of components[positionType + '_' + templateitem.id]; trackBy: trackByFn\">\r\n                  <div formql-component-container\r\n                      [ngClass]=\"{'fql-component-container-hidden': component.rules?.hidden?.value}\"\r\n                      [component]=\"component\"\r\n                      [sectionId]=\"section.sectionId\"\r\n                      [value]=\"component.value\"\r\n                      [reactiveSection]=\"reactiveSection\"\r\n                      [mode]=\"mode\"></div>\r\n              </ng-container>\r\n            </div>\r\n            <div *ngIf=\"mode !== FormQLMode.Edit\">\r\n              <ng-container *ngFor=\"let component of components[positionType + '_' + templateitem.id]; trackBy: trackByFn\">\r\n                <div formql-component-container *ngIf=\"!component.rules?.hidden?.value\"\r\n                    [component]=\"component\"\r\n                    [sectionId]=\"section.sectionId\"\r\n                    [value]=\"component.value\"\r\n                    [reactiveSection]=\"reactiveSection\"\r\n                    [mode]=\"mode\"></div>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </ng-template>\r\n        `,\r\n  styleUrls: ['./section-wrapper.component.scss']\r\n})\r\nexport class SectionWrapperComponent implements OnInit {\r\n\r\n  @ViewChild('wrapper', { read: ViewContainerRef, static: true }) wrapper: ViewContainerRef;\r\n  @ViewChild('tooltip', { read: ViewContainerRef, static: true }) tooltip: ViewContainerRef;\r\n\r\n  @Input() section: FormSection;\r\n  @Input() reactiveSection: FormGroup;\r\n  @Input() page: FormPage;\r\n  @Input() mode: FormQLMode;\r\n\r\n  error: string;\r\n  components: ComponentGroup;\r\n\r\n  public FormQLMode = FormQLMode;\r\n  public ContainerType = ContainerType;\r\n  public ComponentPositionType = GridPositionType;\r\n\r\n  constructor(\r\n      private internalEventHandlerService: InternalEventHandlerService,\r\n      private componentResolverService: ComponentResolverService,\r\n      private viewContainerRef: ViewContainerRef,\r\n      private dndService: DndService,\r\n      private storeService: StoreService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n\r\n    this.components = this.createComponents(this.section);\r\n\r\n    if (this.mode === FormQLMode.Edit) {\r\n      const tooltip = this.viewContainerRef.createComponent(this.componentResolverService.resolveComponent('TooltipComponent'));\r\n      (<any>tooltip).instance.wrapper = this.wrapper;\r\n      (<any>tooltip).instance.type = ContainerType.Section;\r\n      (<any>tooltip).instance.object = this.section;\r\n      this.tooltip.insert(tooltip.hostView);\r\n    }\r\n  }\r\n\r\n  editField() {\r\n    if (this.mode === FormQLMode.Edit)\r\n      this.internalEventHandlerService.send(InternalEventType.EditingSection, this.section);\r\n  }\r\n\r\n  synchroniseModel($event: DndTransfer, positionId: string, positionType: GridPositionType) {\r\n    const dndEvent = <DndEvent>{\r\n      sourceObjectId: $event.sourceObjectId,\r\n      sourceWrapperId: $event.sourceWrapperId,\r\n      targetPositionId: positionId,\r\n      targetWrapperId: this.section.sectionId,\r\n      targetIndexId: $event.targetIndexId,\r\n      positionType: positionType\r\n    };\r\n    this.page = this.dndService.synchroniseSectionModel(this.page, dndEvent);\r\n    this.storeService.reSetForm(InternalEventType.DndFormChanged, this.page);\r\n  }\r\n\r\n  trackByFn(index, item) {\r\n    return item.id;\r\n  }\r\n\r\n  private createComponents(section: FormSection): ComponentGroup {\r\n    const components = <ComponentGroup>{};\r\n    if (section && section.components)\r\n      section.components.sort((left: FormComponent<any>, right: FormComponent<any>) => {\r\n          return left.position.index - right.position.index;\r\n      });\r\n\r\n      section.components.forEach(component => {\r\n        if (components && components[component.position.type + '_' + component.position.id])\r\n          components[component.position.type + '_' + component.position.id].push(component);\r\n        else\r\n          components[component.position.type + '_' + component.position.id] = [component];\r\n      });\r\n\r\n    return components;\r\n  }\r\n\r\n}\r\n"]}