UNPKG

angular-tree-component

Version:

A simple yet powerful tree component for Angular2

152 lines 17.8 kB
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import { Directive, ElementRef, EventEmitter, HostListener, Input, NgZone, Output, Renderer2 } from '@angular/core'; import { TreeDraggedElement } from '../models/tree-dragged-element.model'; var DRAG_OVER_CLASS = 'is-dragging-over'; var DRAG_DISABLED_CLASS = 'is-dragging-over-disabled'; var TreeDropDirective = /** @class */ (function () { function TreeDropDirective(el, renderer, treeDraggedElement, ngZone) { this.el = el; this.renderer = renderer; this.treeDraggedElement = treeDraggedElement; this.ngZone = ngZone; this.allowDragoverStyling = true; this.onDropCallback = new EventEmitter(); this.onDragOverCallback = new EventEmitter(); this.onDragLeaveCallback = new EventEmitter(); this.onDragEnterCallback = new EventEmitter(); this._allowDrop = function (element, $event) { return true; }; this.dragOverEventHandler = this.onDragOver.bind(this); this.dragEnterEventHandler = this.onDragEnter.bind(this); this.dragLeaveEventHandler = this.onDragLeave.bind(this); } Object.defineProperty(TreeDropDirective.prototype, "treeAllowDrop", { set: function (allowDrop) { if (allowDrop instanceof Function) { this._allowDrop = allowDrop; } else this._allowDrop = function (element, $event) { return allowDrop; }; }, enumerable: true, configurable: true }); TreeDropDirective.prototype.allowDrop = function ($event) { return this._allowDrop(this.treeDraggedElement.get(), $event); }; TreeDropDirective.prototype.ngAfterViewInit = function () { var _this = this; var el = this.el.nativeElement; this.ngZone.runOutsideAngular(function () { el.addEventListener('dragover', _this.dragOverEventHandler); el.addEventListener('dragenter', _this.dragEnterEventHandler); el.addEventListener('dragleave', _this.dragLeaveEventHandler); }); }; TreeDropDirective.prototype.ngOnDestroy = function () { var el = this.el.nativeElement; el.removeEventListener('dragover', this.dragOverEventHandler); el.removeEventListener('dragenter', this.dragEnterEventHandler); el.removeEventListener('dragleave', this.dragLeaveEventHandler); }; TreeDropDirective.prototype.onDragOver = function ($event) { if (!this.allowDrop($event)) { if (this.allowDragoverStyling) { return this.addDisabledClass(); } return; } this.onDragOverCallback.emit({ event: $event, element: this.treeDraggedElement.get() }); $event.preventDefault(); if (this.allowDragoverStyling) { this.addClass(); } }; TreeDropDirective.prototype.onDragEnter = function ($event) { if (!this.allowDrop($event)) return; $event.preventDefault(); this.onDragEnterCallback.emit({ event: $event, element: this.treeDraggedElement.get() }); }; TreeDropDirective.prototype.onDragLeave = function ($event) { if (!this.allowDrop($event)) { if (this.allowDragoverStyling) { return this.removeDisabledClass(); } return; } this.onDragLeaveCallback.emit({ event: $event, element: this.treeDraggedElement.get() }); if (this.allowDragoverStyling) { this.removeClass(); } }; TreeDropDirective.prototype.onDrop = function ($event) { if (!this.allowDrop($event)) return; $event.preventDefault(); this.onDropCallback.emit({ event: $event, element: this.treeDraggedElement.get() }); if (this.allowDragoverStyling) { this.removeClass(); } this.treeDraggedElement.set(null); }; TreeDropDirective.prototype.addClass = function () { this.renderer.addClass(this.el.nativeElement, DRAG_OVER_CLASS); }; TreeDropDirective.prototype.removeClass = function () { this.renderer.removeClass(this.el.nativeElement, DRAG_OVER_CLASS); }; TreeDropDirective.prototype.addDisabledClass = function () { this.renderer.addClass(this.el.nativeElement, DRAG_DISABLED_CLASS); }; TreeDropDirective.prototype.removeDisabledClass = function () { this.renderer.removeClass(this.el.nativeElement, DRAG_DISABLED_CLASS); }; __decorate([ Input(), __metadata("design:type", Object) ], TreeDropDirective.prototype, "allowDragoverStyling", void 0); __decorate([ Output('treeDrop'), __metadata("design:type", Object) ], TreeDropDirective.prototype, "onDropCallback", void 0); __decorate([ Output('treeDropDragOver'), __metadata("design:type", Object) ], TreeDropDirective.prototype, "onDragOverCallback", void 0); __decorate([ Output('treeDropDragLeave'), __metadata("design:type", Object) ], TreeDropDirective.prototype, "onDragLeaveCallback", void 0); __decorate([ Output('treeDropDragEnter'), __metadata("design:type", Object) ], TreeDropDirective.prototype, "onDragEnterCallback", void 0); __decorate([ Input(), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], TreeDropDirective.prototype, "treeAllowDrop", null); __decorate([ HostListener('drop', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], TreeDropDirective.prototype, "onDrop", null); TreeDropDirective = __decorate([ Directive({ selector: '[treeDrop]' }), __metadata("design:paramtypes", [ElementRef, Renderer2, TreeDraggedElement, NgZone]) ], TreeDropDirective); return TreeDropDirective; }()); export { TreeDropDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-drop.directive.js","sourceRoot":"","sources":["../../lib/directives/tree-drop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  Renderer2\n} from '@angular/core';\nimport { TreeDraggedElement } from '../models/tree-dragged-element.model';\n\nconst DRAG_OVER_CLASS = 'is-dragging-over';\nconst DRAG_DISABLED_CLASS = 'is-dragging-over-disabled';\n\n@Directive({\n  selector: '[treeDrop]'\n})\nexport class TreeDropDirective implements AfterViewInit, OnDestroy {\n  @Input() allowDragoverStyling = true;\n  @Output('treeDrop') onDropCallback = new EventEmitter();\n  @Output('treeDropDragOver') onDragOverCallback = new EventEmitter();\n  @Output('treeDropDragLeave') onDragLeaveCallback = new EventEmitter();\n  @Output('treeDropDragEnter') onDragEnterCallback = new EventEmitter();\n  private readonly dragOverEventHandler: (ev: DragEvent) => void;\n  private readonly dragEnterEventHandler: (ev: DragEvent) => void;\n  private readonly dragLeaveEventHandler: (ev: DragEvent) => void;\n\n  private _allowDrop = (element, $event) => true;\n\n  @Input() set treeAllowDrop(allowDrop) {\n    if (allowDrop instanceof Function) {\n      this._allowDrop = allowDrop;\n    }\n    else this._allowDrop = (element, $event) => allowDrop;\n  }\n\n  allowDrop($event) {\n    return this._allowDrop(this.treeDraggedElement.get(), $event);\n  }\n\n  constructor(private el: ElementRef, private renderer: Renderer2, private treeDraggedElement: TreeDraggedElement, private ngZone: NgZone) {\n    this.dragOverEventHandler = this.onDragOver.bind(this);\n    this.dragEnterEventHandler = this.onDragEnter.bind(this);\n    this.dragLeaveEventHandler = this.onDragLeave.bind(this);\n  }\n\n  ngAfterViewInit() {\n    let el: HTMLElement = this.el.nativeElement;\n    this.ngZone.runOutsideAngular(() => {\n      el.addEventListener('dragover', this.dragOverEventHandler);\n      el.addEventListener('dragenter', this.dragEnterEventHandler);\n      el.addEventListener('dragleave', this.dragLeaveEventHandler);\n    });\n  }\n\n  ngOnDestroy() {\n    let el: HTMLElement = this.el.nativeElement;\n    el.removeEventListener('dragover', this.dragOverEventHandler);\n    el.removeEventListener('dragenter', this.dragEnterEventHandler);\n    el.removeEventListener('dragleave', this.dragLeaveEventHandler);\n  }\n\n  onDragOver($event) {\n    if (!this.allowDrop($event)) {\n      if (this.allowDragoverStyling) {\n        return this.addDisabledClass();\n      }\n      return;\n    }\n\n    this.onDragOverCallback.emit({event: $event, element: this.treeDraggedElement.get()});\n\n    $event.preventDefault();\n    if (this.allowDragoverStyling) {\n      this.addClass();\n    }\n  }\n\n  onDragEnter($event) {\n    if (!this.allowDrop($event)) return;\n\n    $event.preventDefault();\n    this.onDragEnterCallback.emit({event: $event, element: this.treeDraggedElement.get()});\n  }\n\n  onDragLeave($event) {\n    if (!this.allowDrop($event)) {\n      if (this.allowDragoverStyling) {\n        return this.removeDisabledClass();\n      }\n      return;\n    }\n    this.onDragLeaveCallback.emit({event: $event, element: this.treeDraggedElement.get()});\n\n    if (this.allowDragoverStyling) {\n      this.removeClass();\n    }\n  }\n\n  @HostListener('drop', ['$event']) onDrop($event) {\n    if (!this.allowDrop($event)) return;\n\n    $event.preventDefault();\n    this.onDropCallback.emit({event: $event, element: this.treeDraggedElement.get()});\n\n    if (this.allowDragoverStyling) {\n      this.removeClass();\n    }\n    this.treeDraggedElement.set(null);\n  }\n\n  private addClass() {\n    this.renderer.addClass(this.el.nativeElement, DRAG_OVER_CLASS);\n  }\n\n  private removeClass() {\n    this.renderer.removeClass(this.el.nativeElement, DRAG_OVER_CLASS);\n  }\n\n  private addDisabledClass() {\n    this.renderer.addClass(this.el.nativeElement, DRAG_DISABLED_CLASS);\n  }\n\n  private removeDisabledClass() {\n    this.renderer.removeClass(this.el.nativeElement, DRAG_DISABLED_CLASS);\n  }\n}\n"]}