UNPKG

@formql/core

Version:

FormQL - A framework for building dynamic forms

139 lines 20 kB
import { __decorate, __metadata } from "tslib"; import { Directive, EventEmitter, HostListener, Input, Output, Renderer2, ViewContainerRef } from '@angular/core'; import { GridPositionType } from '../models/style.model'; import { ContainerType, FormQLMode } from '../models/type.model'; /* Directive to handle the drop and receive the information from the dnd directive */ let DndDropDirective = class DndDropDirective { constructor(view, renderer) { this.view = view; this.renderer = renderer; this.synchronise = new EventEmitter(); this.dropAreaClass = 'fql-dnd-container-drop-area'; this.dropSeparatorBorderClass = 'fql-dnd-container-separator'; } onDrop($event) { if (this.mode !== FormQLMode.View && $event && ($event.dataTransfer.types[1] === this.type.toString() || ($event.dataTransfer.types.item && $event.dataTransfer.types.item[1] && $event.dataTransfer.types.item[1] === this.type.toString()))) { $event.stopPropagation(); $event.preventDefault(); const sourceIds = $event.dataTransfer.getData('Text'); const arr = sourceIds.split('#'); let targetIndexId = null; const element = this.getPositionElement($event.srcElement); if (element) targetIndexId = this.getPositionAttribute(element); this.synchronise.emit({ sourceObjectId: arr[0], sourceWrapperId: arr[1], targetIndexId: targetIndexId }); } } onDragOver($event) { if (this.mode !== FormQLMode.View && $event) if ($event.dataTransfer.types[1] === this.type.toString() || ($event.dataTransfer.types.item && $event.dataTransfer.types.item[1] && $event.dataTransfer.types.item[1] === this.type.toString())) { $event.stopPropagation(); $event.preventDefault(); $event.dataTransfer.dropEffect = 'move'; const nativeElement = this.view.element.nativeElement; const currentDropAreaBorderClasses = nativeElement.getAttribute('class') ? nativeElement.getAttribute('class').trim() : ''; if (currentDropAreaBorderClasses.indexOf(this.dropAreaClass) === -1) { const newDropAreaClasses = `${currentDropAreaBorderClasses} ${this.dropAreaClass}`; this.renderer.setAttribute(nativeElement, 'class', newDropAreaClasses); } const element = this.getPositionElement($event.srcElement); if (element) { const currentDropSeparatorBoderStyle = element.getAttribute('class') ? element.getAttribute('class').trim() : ''; if (currentDropSeparatorBoderStyle.indexOf(this.dropSeparatorBorderClass) === -1) { const newDropSeparatorBorderStyling = `${currentDropSeparatorBoderStyle} ${this.dropSeparatorBorderClass}`; this.renderer.setAttribute(element, 'class', newDropSeparatorBorderStyling); } } } } onDragLeave($event) { if (this.mode !== FormQLMode.View && $event) { const nativeElement = this.view.element.nativeElement; const currentDropAreaClasses = nativeElement.getAttribute('class') ? nativeElement.getAttribute('class') : ''; if (currentDropAreaClasses.indexOf(this.dropAreaClass) !== -1) this.renderer.setAttribute(nativeElement, 'class', currentDropAreaClasses.replace(this.dropAreaClass, '')); const element = this.getPositionElement($event.srcElement); if (element) { const currentDropSeparatorBoderStyle = element.getAttribute('class') ? element.getAttribute('class') : ''; if (currentDropSeparatorBoderStyle.indexOf(this.dropSeparatorBorderClass) !== -1) this.renderer.setAttribute(element, 'class', currentDropSeparatorBoderStyle.replace(this.dropSeparatorBorderClass, '')); } } } getPositionElement(sourceELement) { let className = 'fql-component-container-wrapper'; if (this.type === ContainerType.Section) className = 'fql-section-wrapper-edit'; let element = sourceELement; let i = 0; while (element.className && element.className.indexOf(className) === -1 && i < 10) { element = element.parentElement; i++; } if (element.className && element.className.indexOf(className) !== -1) return element; return null; } getPositionAttribute(element) { let attributeName = 'componentId'; if (this.type === ContainerType.Section) attributeName = 'sectionId'; return element.getAttribute(attributeName); } }; __decorate([ Input(), __metadata("design:type", Number) ], DndDropDirective.prototype, "type", void 0); __decorate([ Input(), __metadata("design:type", Number) ], DndDropDirective.prototype, "positionType", void 0); __decorate([ Input(), __metadata("design:type", Number) ], DndDropDirective.prototype, "mode", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], DndDropDirective.prototype, "synchronise", void 0); __decorate([ HostListener('drop', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], DndDropDirective.prototype, "onDrop", null); __decorate([ HostListener('dragover', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], DndDropDirective.prototype, "onDragOver", null); __decorate([ HostListener('dragleave', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], DndDropDirective.prototype, "onDragLeave", null); DndDropDirective = __decorate([ Directive({ selector: '[formqlDndDrop]' }), __metadata("design:paramtypes", [ViewContainerRef, Renderer2]) ], DndDropDirective); export { DndDropDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dnd-drop.directive.js","sourceRoot":"ng://@formql/core/","sources":["directives/dnd-drop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, HostListener, Input, Output, Renderer2, ViewContainerRef } from '@angular/core';\r\nimport { DndTransfer } from '../models/dnd.model';\r\nimport { GridPositionType } from '../models/style.model';\r\nimport { ContainerType, FormQLMode } from '../models/type.model';\r\n/*\r\n    Directive to handle the drop and receive the information from the dnd directive\r\n*/\r\n@Directive({\r\n  selector: '[formqlDndDrop]'\r\n})\r\nexport class DndDropDirective {\r\n  constructor(private view: ViewContainerRef, private renderer: Renderer2) {}\r\n\r\n  @Input() public type: ContainerType;\r\n  @Input() public positionType: GridPositionType;\r\n  @Input() public mode: FormQLMode;\r\n\r\n  @Output() synchronise: EventEmitter<any> = new EventEmitter();\r\n\r\n  dropAreaClass = 'fql-dnd-container-drop-area';\r\n  dropSeparatorBorderClass = 'fql-dnd-container-separator';\r\n\r\n  @HostListener('drop', ['$event']) public onDrop($event) {\r\n    if (\r\n      this.mode !== FormQLMode.View &&\r\n      $event &&\r\n      ($event.dataTransfer.types[1] === this.type.toString() ||\r\n        ($event.dataTransfer.types.item &&\r\n          $event.dataTransfer.types.item[1] &&\r\n          $event.dataTransfer.types.item[1] === this.type.toString()))\r\n    ) {\r\n      $event.stopPropagation();\r\n      $event.preventDefault();\r\n      const sourceIds = $event.dataTransfer.getData('Text');\r\n      const arr = sourceIds.split('#');\r\n\r\n      let targetIndexId = null;\r\n      const element = this.getPositionElement($event.srcElement);\r\n      if (element) targetIndexId = this.getPositionAttribute(element);\r\n\r\n      this.synchronise.emit(<DndTransfer>{\r\n        sourceObjectId: arr[0],\r\n        sourceWrapperId: arr[1],\r\n        targetIndexId: targetIndexId\r\n      });\r\n    }\r\n  }\r\n\r\n  @HostListener('dragover', ['$event']) public onDragOver($event) {\r\n    if (this.mode !== FormQLMode.View && $event)\r\n      if (\r\n        $event.dataTransfer.types[1] === this.type.toString() ||\r\n        ($event.dataTransfer.types.item &&\r\n          $event.dataTransfer.types.item[1] &&\r\n          $event.dataTransfer.types.item[1] === this.type.toString())\r\n      ) {\r\n        $event.stopPropagation();\r\n        $event.preventDefault();\r\n        $event.dataTransfer.dropEffect = 'move';\r\n\r\n        const nativeElement = this.view.element.nativeElement;\r\n        const currentDropAreaBorderClasses = nativeElement.getAttribute('class') ? nativeElement.getAttribute('class').trim() : '';\r\n\r\n        if (currentDropAreaBorderClasses.indexOf(this.dropAreaClass) === -1) {\r\n          const newDropAreaClasses = `${currentDropAreaBorderClasses} ${this.dropAreaClass}`;\r\n          this.renderer.setAttribute(nativeElement, 'class', newDropAreaClasses);\r\n        }\r\n\r\n        const element = this.getPositionElement($event.srcElement);\r\n        if (element) {\r\n          const currentDropSeparatorBoderStyle = element.getAttribute('class') ? element.getAttribute('class').trim() : '';\r\n          if (currentDropSeparatorBoderStyle.indexOf(this.dropSeparatorBorderClass) === -1) {\r\n            const newDropSeparatorBorderStyling = `${currentDropSeparatorBoderStyle} ${this.dropSeparatorBorderClass}`;\r\n            this.renderer.setAttribute(element, 'class', newDropSeparatorBorderStyling);\r\n          }\r\n        }\r\n      }\r\n  }\r\n\r\n  @HostListener('dragleave', ['$event']) public onDragLeave($event) {\r\n    if (this.mode !== FormQLMode.View && $event) {\r\n      const nativeElement = this.view.element.nativeElement;\r\n\r\n      const currentDropAreaClasses = nativeElement.getAttribute('class') ? nativeElement.getAttribute('class') : '';\r\n      if (currentDropAreaClasses.indexOf(this.dropAreaClass) !== -1)\r\n        this.renderer.setAttribute(nativeElement, 'class', currentDropAreaClasses.replace(this.dropAreaClass, ''));\r\n\r\n      const element = this.getPositionElement($event.srcElement);\r\n      if (element) {\r\n        const currentDropSeparatorBoderStyle = element.getAttribute('class') ? element.getAttribute('class') : '';\r\n        if (currentDropSeparatorBoderStyle.indexOf(this.dropSeparatorBorderClass) !== -1)\r\n          this.renderer.setAttribute(element, 'class', currentDropSeparatorBoderStyle.replace(this.dropSeparatorBorderClass, ''));\r\n      }\r\n    }\r\n  }\r\n\r\n  getPositionElement(sourceELement): HTMLElement {\r\n    let className = 'fql-component-container-wrapper';\r\n\r\n    if (this.type === ContainerType.Section) className = 'fql-section-wrapper-edit';\r\n\r\n    let element = sourceELement;\r\n    let i = 0;\r\n    while (element.className && element.className.indexOf(className) === -1 && i < 10) {\r\n      element = element.parentElement;\r\n      i++;\r\n    }\r\n\r\n    if (element.className && element.className.indexOf(className) !== -1) return element as HTMLElement;\r\n\r\n    return null;\r\n  }\r\n\r\n  getPositionAttribute(element): number {\r\n    let attributeName = 'componentId';\r\n\r\n    if (this.type === ContainerType.Section) attributeName = 'sectionId';\r\n\r\n    return element.getAttribute(attributeName);\r\n  }\r\n}\r\n"]}