@formql/core
Version:
FormQL - A framework for building dynamic forms
140 lines • 20.4 kB
JavaScript
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
*/
var DndDropDirective = /** @class */ (function () {
function DndDropDirective(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';
}
DndDropDirective.prototype.onDrop = function ($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();
var sourceIds = $event.dataTransfer.getData('Text');
var arr = sourceIds.split('#');
var targetIndexId = null;
var element = this.getPositionElement($event.srcElement);
if (element)
targetIndexId = this.getPositionAttribute(element);
this.synchronise.emit({
sourceObjectId: arr[0],
sourceWrapperId: arr[1],
targetIndexId: targetIndexId
});
}
};
DndDropDirective.prototype.onDragOver = function ($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';
var nativeElement = this.view.element.nativeElement;
var currentDropAreaBorderClasses = nativeElement.getAttribute('class') ? nativeElement.getAttribute('class').trim() : '';
if (currentDropAreaBorderClasses.indexOf(this.dropAreaClass) === -1) {
var newDropAreaClasses = currentDropAreaBorderClasses + " " + this.dropAreaClass;
this.renderer.setAttribute(nativeElement, 'class', newDropAreaClasses);
}
var element = this.getPositionElement($event.srcElement);
if (element) {
var currentDropSeparatorBoderStyle = element.getAttribute('class') ? element.getAttribute('class').trim() : '';
if (currentDropSeparatorBoderStyle.indexOf(this.dropSeparatorBorderClass) === -1) {
var newDropSeparatorBorderStyling = currentDropSeparatorBoderStyle + " " + this.dropSeparatorBorderClass;
this.renderer.setAttribute(element, 'class', newDropSeparatorBorderStyling);
}
}
}
};
DndDropDirective.prototype.onDragLeave = function ($event) {
if (this.mode !== FormQLMode.View && $event) {
var nativeElement = this.view.element.nativeElement;
var currentDropAreaClasses = nativeElement.getAttribute('class') ? nativeElement.getAttribute('class') : '';
if (currentDropAreaClasses.indexOf(this.dropAreaClass) !== -1)
this.renderer.setAttribute(nativeElement, 'class', currentDropAreaClasses.replace(this.dropAreaClass, ''));
var element = this.getPositionElement($event.srcElement);
if (element) {
var currentDropSeparatorBoderStyle = element.getAttribute('class') ? element.getAttribute('class') : '';
if (currentDropSeparatorBoderStyle.indexOf(this.dropSeparatorBorderClass) !== -1)
this.renderer.setAttribute(element, 'class', currentDropSeparatorBoderStyle.replace(this.dropSeparatorBorderClass, ''));
}
}
};
DndDropDirective.prototype.getPositionElement = function (sourceELement) {
var className = 'fql-component-container-wrapper';
if (this.type === ContainerType.Section)
className = 'fql-section-wrapper-edit';
var element = sourceELement;
var 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;
};
DndDropDirective.prototype.getPositionAttribute = function (element) {
var 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);
return 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"]}