UNPKG

@formql/core

Version:

FormQL - A framework for building dynamic forms

167 lines 23.8 kB
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"]}