Socket
Socket
Sign inDemoInstall

@limble/limble-tree

Package Overview
Dependencies
Maintainers
2
Versions
51
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@limble/limble-tree - npm Package Compare versions

Comparing version 0.3.1 to 0.4.0

esm2015/lib/limble-tree-placeholder/limble-tree-placeholder.component.js

4

bundles/limble-limble-tree.umd.min.js

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs"),require("@angular/common")):"function"==typeof define&&define.amd?define("@limble/limble-tree",["exports","@angular/core","rxjs","@angular/common"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self).limble=e.limble||{},e.limble["limble-tree"]={}),e.ng.core,e.rxjs,e.ng.common)}(this,(function(e,t,r,n){"use strict";
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs"),require("rxjs/operators"),require("@angular/common")):"function"==typeof define&&define.amd?define("@limble/limble-tree",["exports","@angular/core","rxjs","rxjs/operators","@angular/common"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self).limble=e.limble||{},e.limble["limble-tree"]={}),e.ng.core,e.rxjs,e.rxjs.operators,e.ng.common)}(this,(function(e,t,r,o,n){"use strict";
/*! *****************************************************************************

@@ -15,3 +15,3 @@ Copyright (c) Microsoft Corporation.

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */Object.create;function o(e){var t="function"==typeof Symbol&&Symbol.iterator,r=t&&e[t],n=0;if(r)return r.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function i(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,o,i=r.call(e),a=[];try{for(;(void 0===t||t-- >0)&&!(n=i.next()).done;)a.push(n.value)}catch(e){o={error:e}}finally{try{n&&!n.done&&(r=i.return)&&r.call(i)}finally{if(o)throw o.error}}return a}function a(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(i(arguments[t]));return e}Object.create;var s=function(){function e(e){this.factoryResolver=e,this.factoryResolver=e}return e.prototype.appendComponent=function(e,t,r){void 0===r&&(r=null);var n=this.factoryResolver.resolveComponentFactory(e),o=t.createComponent(n);if(null!==r){var i=t.indexOf(o.hostView);t.detach(i),t.insert(o.hostView,r)}return o},e}();s.decorators=[{type:t.Injectable}],s.ctorParameters=function(){return[{type:t.ComponentFactoryResolver}]};var d=function(){function e(e){this.dropZoneService=e,this.active=!1}return e.prototype.dragenterHandler=function(){!0!==this.active&&void 0!==this.dropZoneInfo&&this.dropZoneService.swapActiveDropZone(this.dropZoneInfo)},e}();function c(e,t){var r,n;if(e.length!==t.length)return!1;try{for(var a=o(e.entries()),s=a.next();!s.done;s=a.next()){var d=i(s.value,2),l=d[0],p=d[1],h=t[l];if(p instanceof Array&&h instanceof Array){if(!c(p,h))return!1}else if(p!==h)return!1}}catch(e){r={error:e}}finally{try{s&&!s.done&&(n=a.return)&&n.call(a)}finally{if(r)throw r.error}}return!0}function l(e,t){return void 0!==e&&(!0===e.allowNesting||"function"==typeof e.allowNesting&&void 0!==t&&!0===e.allowNesting(t))}d.decorators=[{type:t.Component,args:[{selector:"drop-zone",template:'<div class="dropZoneContainer" (dragenter)="dragenterHandler()">\r\n <div [ngClass]="{ active: active, related: !active }"></div>\r\n</div>\r\n',styles:[".active{background:#f0f9ff;border:2px dashed #bed2db;border-radius:5px;height:100px}.active,.related{box-sizing:border-box;margin:10px 0;width:calc(100% - 20px)}.related{background:#fff6f0;border:1px dashed #dbccbe;border-radius:5px;height:20px;opacity:.8}.dropZoneContainer{position:relative}"]}]}],d.ctorParameters=function(){return[{type:h}]},d.propDecorators={active:[{type:t.Input}],dropZoneInfo:[{type:t.Input}]};var p=function(){function e(){}return e.prototype.set=function(e){this._tempData=e},e.prototype.get=function(){return this._tempData},e.prototype.delete=function(){this._tempData=void 0},e}();p.decorators=[{type:t.Injectable}];var h=function(){function e(e,t){this.componentCreatorService=e,this.tempService=t,this.activeDropZoneInfo=null,this.secondaryDropZones=[],this.dropZones=[]}return e.prototype.init=function(e,t){this.treeData=e,this.treeOptions=t},e.prototype.showSingleDropZone=function(e,t){void 0===t&&(t=!0),!0===t&&this.removeActiveAndSecondaryZones();var r=this.componentCreatorService.appendComponent(d,e.container);r.instance.active=t,r.instance.dropZoneInfo=e,!0===t?this.activeDropZoneInfo=e:this.secondaryDropZones.push(e)},e.prototype.removeActiveAndSecondaryZones=function(){var e,t,r;null===(r=this.activeDropZoneInfo)||void 0===r||r.container.clear(),this.activeDropZoneInfo=null;try{for(var n=o(this.secondaryDropZones),i=n.next();!i.done;i=n.next()){i.value.container.clear()}}catch(t){e={error:t}}finally{try{i&&!i.done&&(t=n.return)&&t.call(n)}finally{if(e)throw e.error}}this.secondaryDropZones=[]},e.prototype.getActiveDropZoneInfo=function(){return this.activeDropZoneInfo},e.prototype.getDropZones=function(){return this.dropZones},e.prototype.getSecondaryDropZones=function(){return this.secondaryDropZones},e.prototype.addDropZone=function(e){void 0===this.dropZones.find((function(t){return t.coordinates===e.coordinates}))&&this.dropZones.push(e)},e.prototype.clearDropZones=function(){this.removeActiveAndSecondaryZones(),this.dropZones=[]},e.prototype.isLastDropZoneInBranch=function(e){return this.getCoordinatesGroup(e).length-1<e[e.length-1]},e.prototype.isOnRoot=function(e){return 1===e.length},e.prototype.showDropZoneFamily=function(e,t,r){var n,o;if(void 0===t&&(t=!0),void 0===r&&(r=!1),this.showSingleDropZone(e,t),!this.isOnRoot(e.coordinates)&&this.isLastDropZoneInBranch(e.coordinates)&&"below"!==r){var i=a(e.coordinates);i.pop();var s=this.getNextSibling(i);if(null===s)throw new Error("Could not get secondary drop zone coordinates");void 0!==(f=this.getDropZones().find((function(e){return c(e.coordinates,s)})))&&this.showDropZoneFamily(f,!1,"above")}if("above"!==r){if(0===e.coordinates[e.coordinates.length-1])return;var d=a(e.coordinates);if(d[d.length-1]--,this.coordinatesHasChildren(d)){var p=a(d);p.push(0);for(var h=p,v=this.getNextSibling(h);null!==v;)h=v,v=this.getNextSibling(h);void 0!==(f=this.getDropZones().find((function(e){return c(e.coordinates,h)})))&&this.showDropZoneFamily(f,!1,"below")}else if(!c(null!==(o=null===(n=this.tempService.get())||void 0===n?void 0:n.getCoordinates())&&void 0!==o?o:[],d)){var u=this.getCoordinatesGroup(d)[d[d.length-1]];if(l(this.treeOptions,u)){var f,g=a(d);g.push(0),void 0!==(f=this.getDropZones().find((function(e){return c(e.coordinates,g)})))&&this.showDropZoneFamily(f,!1,"below")}}}},e.prototype.coordinatesHasChildren=function(e){var t=this.getCoordinatesChildren(e);return void 0!==t&&t.length>0},e.prototype.swapActiveDropZone=function(e){if(null===this.getActiveDropZoneInfo())throw new Error("could not get active drop zone");if(-1===this.getSecondaryDropZones().findIndex((function(t){return t.coordinates===e.coordinates})))throw new Error("failed to swap active drop zone");this.showDropZoneFamily(e)},e.prototype.getNextSibling=function(e){var t=a(e),r=this.getCoordinatesGroup(t),n=t[t.length-1]++;return r.length<=n?null:t},e.prototype.getCoordinatesGroup=function(e){var t,r;if(void 0===this.treeData)throw new Error("treeData is not defined");var n=this.treeData,a=!0;try{for(var s=o(e.entries()),d=s.next();!d.done;d=s.next()){var c=i(d.value,2),l=c[0],p=c[1];if(l===e.length-1)break;var h=n[p].nodes;if(void 0===h){if(!0!==a)throw new Error("bad coordinates");n[p].nodes=[],h=n[p].nodes,a=!1}n=h}}catch(e){t={error:e}}finally{try{d&&!d.done&&(r=s.return)&&r.call(s)}finally{if(t)throw t.error}}return n},e.prototype.getCoordinatesChildren=function(e){var t,r;if(void 0===this.treeData)throw new Error("treeData is not defined");var n=this.treeData;try{for(var i=o(e),a=i.next();!a.done;a=i.next()){var s=n[a.value].nodes;if(void 0===s)return;n=s}}catch(e){t={error:e}}finally{try{a&&!a.done&&(r=i.return)&&r.call(i)}finally{if(t)throw t.error}}return n},e}();h.decorators=[{type:t.Injectable}],h.ctorParameters=function(){return[{type:s},{type:p}]};var v=function(){function e(e){this.data=e,this.children=[],this.parent=null}return e.prototype.isRoot=function(){return null===this.parent},e.prototype.getParent=function(){return this.parent},e.prototype.setParent=function(e){this.parent=e},e.prototype.getCoordinates=function(){for(var e=[],t=this;null!==t.parent;){var r=t.getIndex();if(void 0===r)throw new Error("Unreachable error");e.unshift(r),t=t.parent}return e},e.prototype.getChild=function(e){return this.children[e]},e.prototype.getChildren=function(){return this.children},e.prototype.getIndex=function(){var e,t,r=this;return null!==(t=null===(e=this.parent)||void 0===e?void 0:e.children.findIndex((function(e){return e===r})))&&void 0!==t?t:void 0},e.prototype.getDescendant=function(e){var t,r,n=this;try{for(var i=o(e),a=i.next();!a.done;a=i.next()){var s=a.value;if(void 0===(n=n.children[s]))return}}catch(e){t={error:e}}finally{try{a&&!a.done&&(r=i.return)&&r.call(i)}finally{if(t)throw t.error}}return n},e.prototype.findDescendant=function(e){var t,r;if(!0===e(this.data))return this;if(this.children.length>0)try{for(var n=o(this.children),i=n.next();!i.done;i=n.next()){var a=i.value.findDescendant(e);if(void 0!==a)return a}}catch(e){t={error:e}}finally{try{i&&!i.done&&(r=n.return)&&r.call(n)}finally{if(t)throw t.error}}},e.prototype.appendChild=function(e){return null!==e.getParent()&&e.remove(),e.setParent(this),this.children.push(e),e},e.prototype.insertChild=function(e,t){var r=this.children.indexOf(e);return-1===r?(null!==e.getParent()&&e.remove(),e.setParent(this),this.children.splice(t,0,e)):t>r?(this.children.splice(t,0,e),this.removeChild(r),e.setParent(this)):(e.remove(),this.children.splice(t,0,e),e.setParent(this)),e},e.prototype.removeChild=function(e){var t=this.children.splice(e,1)[0];return t.setParent(null),t},e.prototype.remove=function(){var e=this.getIndex();if(null===this.parent||void 0===e)throw new Error("can't remove root");return this.parent.removeChild(e)},e}(),u=function(){function e(e,t){var n;this.treeService=e,this.changeDetectorRef=t,this.dropZoneInside$=new r.BehaviorSubject(this.dropZoneInside),this.indent=null===(n=this.treeService.treeOptions)||void 0===n?void 0:n.indent}return e.prototype.ngAfterViewInit=function(){this.dropZoneInside$.next(this.dropZoneInside),this.dropZoneInside$.complete(),this.reRender(),this.changeDetectorRef.detectChanges()},e.prototype.reRender=function(){if(void 0===this.host||void 0===this.branch)throw new Error("Failed to render limble tree branch");this.treeService.renderBranch(this.host,this.branch)},e}();u.decorators=[{type:t.Component,args:[{selector:"limble-tree-branch",template:'<div [style.marginLeft.px]="indent">\r\n <ng-template #dropZoneInside></ng-template>\r\n <span [hidden]="branch?.data.collapsed" class="limble-child-nodes">\r\n <ng-template #host></ng-template>\r\n </span>\r\n</div>\r\n',styles:["./limble-tree-branch.component.scss"]}]}],u.ctorParameters=function(){return[{type:g},{type:t.ChangeDetectorRef}]},u.propDecorators={branch:[{type:t.Input}],host:[{type:t.ViewChild,args:["host",{read:t.ViewContainerRef}]}],dropZoneInside:[{type:t.ViewChild,args:["dropZoneInside",{read:t.ViewContainerRef}]}],dropZoneInside$:[{type:t.Output}]};var f=function(){function e(e,t,r,n,o){this.componentCreatorService=e,this.changeDetectorRef=t,this.tempService=r,this.dropZoneService=n,this.treeService=o}return e.prototype.ngAfterViewInit=function(){this.registerDropZones(),this.renderSelf(),this.renderChildren(),this.checkForHandle(),this.changeDetectorRef.detectChanges()},e.prototype.dragstartHandler=function(e){var t;if(e.stopPropagation(),null!==e.dataTransfer&&void 0!==this.branch){var r=e.target;"LIMBLE-TREE-NODE"===(null===(t=r.parentElement)||void 0===t?void 0:t.tagName)&&(e.dataTransfer.effectAllowed="move",r.classList.add("dragging"),this.tempService.set(this.branch))}},e.prototype.dragendHandler=function(e){e.stopPropagation();var t=e.target,r=this.tempService.get();if(void 0!==r){this.tempService.delete(),t.classList.remove("dragging");var n=this.dropZoneService.getActiveDropZoneInfo();if(null!==n){if(this.dropZoneService.removeActiveAndSecondaryZones(),void 0===n.coordinates)throw new Error("could not determine drop zone location");this.treeService.move(r,n.coordinates)}}},e.prototype.dragoverHandler=function(e){var t,r,n;if(void 0!==this.tempService.get()&&void 0!==this.branch){var o=this.tempService.get();if(void 0!==o)if(o!==this.branch){var i=e.currentTarget.offsetHeight/3,s=2*i;if(e.offsetY<i&&void 0!==this.dropZoneAbove&&(null===(t=this.dropZoneService.getActiveDropZoneInfo())||void 0===t?void 0:t.container)!==this.dropZoneAbove){var d=a(this.branch.getCoordinates());this.dropZoneService.showDropZoneFamily({container:this.dropZoneAbove,coordinates:d})}else if(e.offsetY<s&&void 0!==this.dropZoneInside&&(null===(r=this.dropZoneService.getActiveDropZoneInfo())||void 0===r?void 0:r.container)!==this.dropZoneInside){(d=a(this.branch.getCoordinates())).push(0),this.dropZoneService.showDropZoneFamily({container:this.dropZoneInside,coordinates:d})}else if(e.offsetY>=s&&void 0!==this.dropZoneBelow&&(null===(n=this.dropZoneService.getActiveDropZoneInfo())||void 0===n?void 0:n.container)!==this.dropZoneBelow&&0===this.branch.getChildren().length){(d=a(this.branch.getCoordinates()))[d.length-1]++,this.dropZoneService.showDropZoneFamily({container:this.dropZoneBelow,coordinates:d})}}else null!==this.dropZoneService.getActiveDropZoneInfo()&&this.dropZoneService.removeActiveAndSecondaryZones()}},e.prototype.renderSelf=function(){var e;if(void 0===this.nodeHost||void 0===this.branch)throw new Error("Failed to render tree node");var t=this.branch.data.component;if(void 0===t&&(t=null===(e=this.treeService.treeOptions)||void 0===e?void 0:e.defaultComponent),void 0===t)throw new Error("limbleTree requires a component to render");var r=this.componentCreatorService.appendComponent(t.class,this.nodeHost);for(var n in r.instance.nodeData=this.branch.data,t.bindings)r.instance[n]=t.bindings[n]},e.prototype.renderChildren=function(){var e=this;if(void 0!==this.children){if(void 0===this.branch)throw new Error("branch is undefined");var t=this.componentCreatorService.appendComponent(u,this.children);t.instance.branch=this.branch,l(this.treeService.treeOptions,this.branch.data)&&t.instance.dropZoneInside$.subscribe((function(t){var r;if(void 0!==t&&!1!==(null===(r=e.treeService.treeOptions)||void 0===r?void 0:r.allowDragging)){if(e.dropZoneInside=t,void 0===e.branch)throw new Error("failed to register inner drop zone");var n=e.branch.getCoordinates();n.push(0),e.dropZoneService.addDropZone({container:e.dropZoneInside,coordinates:n})}}))}},e.prototype.registerDropZones=function(){var e;if(!1!==(null===(e=this.treeService.treeOptions)||void 0===e?void 0:e.allowDragging)){if(void 0===this.dropZoneAbove||void 0===this.dropZoneBelow||void 0===this.branch)throw new Error("failed to register drop zones");var t=this.branch.getCoordinates(),r=a(t);this.dropZoneService.addDropZone({container:this.dropZoneAbove,coordinates:r});var n=a(t);n[n.length-1]++,this.dropZoneService.addDropZone({container:this.dropZoneBelow,coordinates:n})}},e.prototype.checkForHandle=function(){var e;if(void 0!==this.draggableDiv){var t,r,n=this.draggableDiv.nativeElement,o=n.querySelector(".limble-tree-handle");t=this.treeService.treeOptions,r=null===(e=this.branch)||void 0===e?void 0:e.data,void 0===t||!0!==t.allowDragging&&("function"!=typeof t.allowDragging||void 0===r||!0!==t.allowDragging(r))?n.setAttribute("draggable","false"):null===o?n.setAttribute("draggable","true"):(o.addEventListener("mousedown",(function(){n.setAttribute("draggable","true")})),o.addEventListener("mouseup",(function(){n.setAttribute("draggable","false")})))}},e}();f.decorators=[{type:t.Component,args:[{selector:"limble-tree-node",template:'<ng-template #dropZoneAbove></ng-template>\r\n<div\r\n (dragstart)="dragstartHandler($event)"\r\n (dragend)="dragendHandler($event)"\r\n #draggableDiv\r\n>\r\n <div (dragover)="dragoverHandler($event)">\r\n <ng-template #nodeHost></ng-template>\r\n </div>\r\n <ng-template #children></ng-template>\r\n</div>\r\n<ng-template #dropZoneBelow></ng-template>\r\n',styles:[".dragging{opacity:.33}"]}]}],f.ctorParameters=function(){return[{type:s},{type:t.ChangeDetectorRef},{type:p},{type:h},{type:g}]},f.propDecorators={branch:[{type:t.Input}],nodeHost:[{type:t.ViewChild,args:["nodeHost",{read:t.ViewContainerRef}]}],dropZoneAbove:[{type:t.ViewChild,args:["dropZoneAbove",{read:t.ViewContainerRef}]}],dropZoneBelow:[{type:t.ViewChild,args:["dropZoneBelow",{read:t.ViewContainerRef}]}],children:[{type:t.ViewChild,args:["children",{read:t.ViewContainerRef}]}],draggableDiv:[{type:t.ViewChild,args:["draggableDiv",{read:t.ElementRef}]}]};var g=function(){function e(e,t){this.componentCreatorService=e,this.dropZoneService=t,this.changes$=new r.ReplaySubject(1),this.drops$=new r.ReplaySubject(1),this.treeModel=new v(null)}return e.prototype.init=function(e,t,r){this.host=e,this.treeData=t,this.treeOptions=this.processOptions(r),this.render()},e.prototype.render=function(){var e,t,r,n;if(void 0===this.host||void 0===this.treeData||void 0===this.treeOptions)throw new Error("TreeModel not initialized");this.host.clear(),this.treeModel=new v(null),this.dropZoneService.clearDropZones(),this.dropZoneService.init(this.treeData,this.treeOptions);try{for(var i=o(this.treeData),a=i.next();!a.done;a=i.next()){var s=a.value,d=new v(s);this.treeModel.appendChild(d)}}catch(t){e={error:t}}finally{try{a&&!a.done&&(t=i.return)&&t.call(i)}finally{if(e)throw e.error}}try{for(var c=o(this.treeModel.getChildren()),l=c.next();!l.done;l=c.next()){d=l.value;this.componentCreatorService.appendComponent(f,this.host).instance.branch=d}}catch(e){r={error:e}}finally{try{l&&!l.done&&(n=c.return)&&n.call(c)}finally{if(r)throw r.error}}this.changes$.next(null)},e.prototype.renderBranch=function(e,t){var r,n,i;if(void 0===this.treeModel)throw new Error("TreeModel not initialized");e.clear();try{for(var a=o(null!==(i=t.data.nodes)&&void 0!==i?i:[]),s=a.next();!s.done;s=a.next()){var d=s.value,c=new v(d);t.appendChild(c),this.componentCreatorService.appendComponent(f,e).instance.branch=c}}catch(e){r={error:e}}finally{try{s&&!s.done&&(n=a.return)&&n.call(a)}finally{if(r)throw r.error}}},e.prototype.processOptions=function(e){var t,r,n;return void 0===e&&(e={}),{defaultComponent:e.defaultComponent,indent:null!==(t=e.indent)&&void 0!==t?t:45,allowNesting:null===(r=e.allowNesting)||void 0===r||r,allowDragging:null===(n=e.allowDragging)||void 0===n||n}},e.prototype.move=function(e,t){var r=e.getParent(),n=e.getIndex();if(void 0===n)throw new Error("Cannot move the hidden root node");var o=a(t),i=o.pop();if(void 0===i)throw new Error("target coordinates are empty");var s=this.treeModel.getDescendant(o);if(void 0===s)throw new Error("could not get to target");s.insertChild(e,i),this.rebuildTreeData(),console.log(r),this.drops$.next({target:e.data,oldParent:null==r?void 0:r.data,oldIndex:n,newParent:s.data,newIndex:i}),this.render()},e.prototype.rebuildTreeData=function(){var e,t;if(null==this.treeData)throw new Error("Tree data not initialized");this.treeData.length=0;try{for(var r=o(this.treeModel.getChildren()),n=r.next();!n.done;n=r.next()){var i=n.value;this.treeData.push(this.rebuildBranch(i))}}catch(t){e={error:t}}finally{try{n&&!n.done&&(t=r.return)&&t.call(r)}finally{if(e)throw e.error}}},e.prototype.rebuildBranch=function(e){var t,r,n=e.data;n.nodes=[];try{for(var i=o(e.getChildren()),a=i.next();!a.done;a=i.next()){var s=a.value;n.nodes.push(this.rebuildBranch(s))}}catch(e){t={error:e}}finally{try{a&&!a.done&&(r=i.return)&&r.call(i)}finally{if(t)throw t.error}}return n},e}();g.decorators=[{type:t.Injectable}],g.ctorParameters=function(){return[{type:s},{type:h}]};var y=function(){function e(e,n,o){var i=this;this.treeService=e,this.changeDetectorRef=n,this.dropZoneService=o,this.treeChange=new t.EventEmitter,this.treeDrop=new t.EventEmitter,this.dropZoneInside$=new r.BehaviorSubject(this.dropZoneInside),this.changesSubscription=this.treeService.changes$.subscribe((function(){i.treeChange.emit()})),this.dropSubscription=this.treeService.drops$.subscribe((function(e){i.treeDrop.emit(e)}))}return e.prototype.ngAfterViewInit=function(){this.dropZoneInside$.next(this.dropZoneInside),this.dropZoneInside$.complete(),this.update(),this.changeDetectorRef.detectChanges()},e.prototype.ngOnChanges=function(){void 0!==this.host&&void 0!==this.data&&this.update()},e.prototype.update=function(){if(void 0===this.host)throw new Error("Failed to render limble tree. Failure occurred at root.");if(void 0===this.data)throw new Error("limbleTree requires a data object");this.treeService.init(this.host,this.data,this.options)},e.prototype.dragoverHandler=function(e){null!==e.dataTransfer&&(e.stopPropagation(),e.preventDefault(),e.dataTransfer.dropEffect="move")},e.prototype.dragleaveHandler=function(e){var t=e.currentTarget,r=e.relatedTarget;t instanceof Node&&r instanceof Node&&!1===function(e,t){if(e===t)return!0;for(var r=t.parentNode;r!==document;){if(null===r)return;if(r===e)return!0;r=r.parentNode}return!1}(t,r)&&this.dropZoneService.removeActiveAndSecondaryZones()},e.prototype.ngOnDestroy=function(){this.changesSubscription.unsubscribe()},e}();y.decorators=[{type:t.Component,args:[{selector:"limble-tree-root",template:'<div\r\n (dragover)="dragoverHandler($event)"\r\n (dragleave)="dragleaveHandler($event)"\r\n>\r\n <ng-template #dropZoneInside></ng-template>\r\n <ng-template #host></ng-template>\r\n</div>\r\n',providers:[g],styles:[""]}]}],y.ctorParameters=function(){return[{type:g},{type:t.ChangeDetectorRef},{type:h}]},y.propDecorators={data:[{type:t.Input}],options:[{type:t.Input}],host:[{type:t.ViewChild,args:["host",{read:t.ViewContainerRef}]}],dropZoneInside:[{type:t.ViewChild,args:["dropZoneInside",{read:t.ViewContainerRef}]}],dropZoneInside$:[{type:t.Output}],treeChange:[{type:t.Output}],treeDrop:[{type:t.Output}]};var m=function(){};m.decorators=[{type:t.NgModule,args:[{declarations:[u,d,f,y],imports:[n.CommonModule],exports:[y],providers:[s,p,h]}]}],e.LimbleTreeModule=m,e.LimbleTreeRootComponent=y,e.ɵa=g,e.ɵb=s,e.ɵc=h,e.ɵd=p,e.ɵe=u,e.ɵf=d,e.ɵg=f,Object.defineProperty(e,"__esModule",{value:!0})}));
***************************************************************************** */Object.create;function i(e){var t="function"==typeof Symbol&&Symbol.iterator,r=t&&e[t],o=0;if(r)return r.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&o>=e.length&&(e=void 0),{value:e&&e[o++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function a(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var o,n,i=r.call(e),a=[];try{for(;(void 0===t||t-- >0)&&!(o=i.next()).done;)a.push(o.value)}catch(e){n={error:e}}finally{try{o&&!o.done&&(r=i.return)&&r.call(i)}finally{if(n)throw n.error}}return a}function s(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(a(arguments[t]));return e}Object.create;var d=function(){function e(e){this.factoryResolver=e,this.factoryResolver=e}return e.prototype.appendComponent=function(e,t,r){void 0===r&&(r=null);var o=this.factoryResolver.resolveComponentFactory(e),n=t.createComponent(o);if(null!==r){var i=t.indexOf(n.hostView);t.detach(i),t.insert(n.hostView,r)}return n},e}();d.decorators=[{type:t.Injectable}],d.ctorParameters=function(){return[{type:t.ComponentFactoryResolver}]};var p=function(){function e(e){this.dropZoneService=e,this.active=!1}return e.prototype.dragenterHandler=function(){!0!==this.active&&void 0!==this.dropZoneInfo&&this.dropZoneService.swapActiveDropZone(this.dropZoneInfo)},e}();function h(e,t){var r,o;if(e.length!==t.length)return!1;try{for(var n=i(e.entries()),s=n.next();!s.done;s=n.next()){var d=a(s.value,2),p=d[0],c=d[1],l=t[p];if(c instanceof Array&&l instanceof Array){if(!h(c,l))return!1}else if(c!==l)return!1}}catch(e){r={error:e}}finally{try{s&&!s.done&&(o=n.return)&&o.call(n)}finally{if(r)throw r.error}}return!0}function c(e,t){return void 0!==e&&(!0===e.allowNesting||"function"==typeof e.allowNesting&&void 0!==t&&!0===e.allowNesting(t))}p.decorators=[{type:t.Component,args:[{selector:"drop-zone",template:'<div class="dropZoneContainer" (dragenter)="dragenterHandler()">\r\n <div [ngClass]="{ active: active, related: !active }"></div>\r\n</div>\r\n',styles:[".active{background:#f0f9ff;border:2px dashed #bed2db;border-radius:5px;height:100px}.active,.related{box-sizing:border-box;margin:10px 0;width:calc(100% - 20px)}.related{background:#fff6f0;border:1px dashed #dbccbe;border-radius:5px;height:20px;opacity:.8}.dropZoneContainer{position:relative}"]}]}],p.ctorParameters=function(){return[{type:v}]},p.propDecorators={active:[{type:t.Input}],dropZoneInfo:[{type:t.Input}]};var l=function(){function e(){this.state="idle",this.state$=new r.BehaviorSubject(this.state)}return e.prototype.dragging=function(e){this._tempData=e,this.state="dragging",this.state$.next(this.state)},e.prototype.droppable=function(){if("dragging"!==this.state)throw new Error("Can only move to `droppable` state from `dragging` state");this.state="droppable",this.state$.next(this.state)},e.prototype.notDroppable=function(){if("droppable"!==this.state)throw new Error("Can only call `notDroppable` when state is `droppable`");this.state="dragging",this.state$.next(this.state)},e.prototype.capture=function(){if("droppable"!==this.state)throw new Error("Can only move to `captured` state from `droppable` state");return this.state="captured",this.state$.next(this.state),this._tempData},e.prototype.release=function(){this._tempData=void 0,this.state="idle",this.state$.next(this.state)},e.prototype.getData=function(){return this._tempData},e.prototype.getState=function(){return this.state},e}();l.decorators=[{type:t.Injectable}],l.ctorParameters=function(){return[]};var v=function(){function e(e,t){this.componentCreatorService=e,this.dragStateService=t,this.activeDropZoneInfo=null,this.setActiveDropZoneInfo(null),this.secondaryDropZones=[],this.dropZones=[]}return e.prototype.init=function(e,t){this.treeData=e,this.treeOptions=t},e.prototype.showSingleDropZone=function(e,t){void 0===t&&(t=!0),!0===t&&this.removeActiveAndSecondaryZones();var r=this.componentCreatorService.appendComponent(p,e.container);r.instance.active=t,r.instance.dropZoneInfo=e,!0===t?this.setActiveDropZoneInfo(e):this.secondaryDropZones.push(e)},e.prototype.removeActiveAndSecondaryZones=function(){var e,t,r;null===(r=this.activeDropZoneInfo)||void 0===r||r.container.clear(),this.setActiveDropZoneInfo(null);try{for(var o=i(this.secondaryDropZones),n=o.next();!n.done;n=o.next()){n.value.container.clear()}}catch(t){e={error:t}}finally{try{n&&!n.done&&(t=o.return)&&t.call(o)}finally{if(e)throw e.error}}this.secondaryDropZones=[]},e.prototype.getActiveDropZoneInfo=function(){return this.activeDropZoneInfo},e.prototype.setActiveDropZoneInfo=function(e){this.activeDropZoneInfo=e,null!==this.activeDropZoneInfo?this.dragStateService.droppable():"droppable"===this.dragStateService.getState()&&this.dragStateService.notDroppable()},e.prototype.getDropZones=function(){return this.dropZones},e.prototype.getSecondaryDropZones=function(){return this.secondaryDropZones},e.prototype.addDropZone=function(e){void 0===this.dropZones.find((function(t){return t.coordinates===e.coordinates}))&&this.dropZones.push(e)},e.prototype.clearDropZones=function(){this.removeActiveAndSecondaryZones(),this.dropZones=[]},e.prototype.isLastDropZoneInBranch=function(e){return this.getCoordinatesGroup(e).length-1<e[e.length-1]},e.prototype.isOnRoot=function(e){return 1===e.length},e.prototype.showDropZoneFamily=function(e,t,r){var o,n;if(void 0===t&&(t=!0),void 0===r&&(r=!1),this.showSingleDropZone(e,t),!this.isOnRoot(e.coordinates)&&this.isLastDropZoneInBranch(e.coordinates)&&"below"!==r){var i=s(e.coordinates);i.pop();var a=this.getNextSibling(i);if(null===a)throw new Error("Could not get secondary drop zone coordinates");void 0!==(f=this.getDropZones().find((function(e){return h(e.coordinates,a)})))&&this.showDropZoneFamily(f,!1,"above")}if("above"!==r){if(0===e.coordinates[e.coordinates.length-1])return;var d=s(e.coordinates);if(d[d.length-1]--,h(null!==(n=null===(o=this.dragStateService.getData())||void 0===o?void 0:o.getCoordinates())&&void 0!==n?n:[],d))return;if(this.coordinatesHasChildren(d)){var p=s(d);p.push(0);for(var l=p,v=this.getNextSibling(l);null!==v;)l=v,v=this.getNextSibling(l);void 0!==(f=this.getDropZones().find((function(e){return h(e.coordinates,l)})))&&this.showDropZoneFamily(f,!1,"below")}else{var u=this.getCoordinatesGroup(d)[d[d.length-1]];if(c(this.treeOptions,u)){var f,g=s(d);g.push(0),void 0!==(f=this.getDropZones().find((function(e){return h(e.coordinates,g)})))&&this.showDropZoneFamily(f,!1,"below")}}}},e.prototype.coordinatesHasChildren=function(e){var t=this.getCoordinatesChildren(e);return void 0!==t&&t.length>0},e.prototype.swapActiveDropZone=function(e){if(null===this.getActiveDropZoneInfo())throw new Error("could not get active drop zone");if(-1===this.getSecondaryDropZones().findIndex((function(t){return t.coordinates===e.coordinates})))throw new Error("failed to swap active drop zone");this.showDropZoneFamily(e)},e.prototype.getNextSibling=function(e){var t=s(e),r=this.getCoordinatesGroup(t),o=t[t.length-1]++;return r.length<=o?null:t},e.prototype.getCoordinatesGroup=function(e){var t,r;if(void 0===this.treeData)throw new Error("treeData is not defined");var o=this.treeData,n=!0;try{for(var s=i(e.entries()),d=s.next();!d.done;d=s.next()){var p=a(d.value,2),h=p[0],c=p[1];if(h===e.length-1)break;var l=o[c].nodes;if(void 0===l){if(!0!==n)throw new Error("bad coordinates");o[c].nodes=[],l=o[c].nodes,n=!1}o=l}}catch(e){t={error:e}}finally{try{d&&!d.done&&(r=s.return)&&r.call(s)}finally{if(t)throw t.error}}return o},e.prototype.getCoordinatesChildren=function(e){var t,r;if(void 0===this.treeData)throw new Error("treeData is not defined");var o=this.treeData;try{for(var n=i(e),a=n.next();!a.done;a=n.next()){var s=o[a.value].nodes;if(void 0===s)return;o=s}}catch(e){t={error:e}}finally{try{a&&!a.done&&(r=n.return)&&r.call(n)}finally{if(t)throw t.error}}return o},e}();v.decorators=[{type:t.Injectable}],v.ctorParameters=function(){return[{type:d},{type:l}]};var u=function(){function e(e){this.data=e,this.children=[],this.parent=null}return e.prototype.isRoot=function(){return null===this.parent},e.prototype.getParent=function(){return this.parent},e.prototype.setParent=function(e){this.parent=e},e.prototype.getCoordinates=function(){for(var e=[],t=this;null!==t.parent;){var r=t.getIndex();if(void 0===r)throw new Error("Unreachable error");e.unshift(r),t=t.parent}return e},e.prototype.getChild=function(e){return this.children[e]},e.prototype.getChildren=function(){return this.children},e.prototype.getIndex=function(){var e,t,r=this;return null!==(t=null===(e=this.parent)||void 0===e?void 0:e.children.findIndex((function(e){return e===r})))&&void 0!==t?t:void 0},e.prototype.getDescendant=function(e){var t,r,o=this;try{for(var n=i(e),a=n.next();!a.done;a=n.next()){var s=a.value;if(void 0===(o=o.children[s]))return}}catch(e){t={error:e}}finally{try{a&&!a.done&&(r=n.return)&&r.call(n)}finally{if(t)throw t.error}}return o},e.prototype.findDescendant=function(e){var t,r;if(!0===e(this.data))return this;if(this.children.length>0)try{for(var o=i(this.children),n=o.next();!n.done;n=o.next()){var a=n.value.findDescendant(e);if(void 0!==a)return a}}catch(e){t={error:e}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(t)throw t.error}}},e.prototype.getAncestors=function(){for(var e=[],t=this;null!==t.parent;)e.push(t.parent),t=t.parent;return e},e.prototype.appendChild=function(e){return null!==e.getParent()&&e.remove(),e.setParent(this),this.children.push(e),e},e.prototype.insertChild=function(e,t){var r=this.children.indexOf(e);return-1===r?(null!==e.getParent()&&e.remove(),e.setParent(this),this.children.splice(t,0,e)):t>r?(this.children.splice(t,0,e),this.removeChild(r),e.setParent(this)):(e.remove(),this.children.splice(t,0,e),e.setParent(this)),e},e.prototype.removeChild=function(e){var t=this.children.splice(e,1)[0];return t.setParent(null),t},e.prototype.remove=function(){var e=this.getIndex();if(null===this.parent||void 0===e)throw new Error("can't remove root");return this.parent.removeChild(e)},e}(),f=function(){function e(e,t){var o;this.treeService=e,this.changeDetectorRef=t,this.dropZoneInside$=new r.BehaviorSubject(this.dropZoneInside),this.indent=null===(o=this.treeService.treeOptions)||void 0===o?void 0:o.indent}return e.prototype.ngAfterViewInit=function(){this.dropZoneInside$.next(this.dropZoneInside),this.dropZoneInside$.complete(),this.reRender(),this.changeDetectorRef.detectChanges()},e.prototype.reRender=function(){if(void 0===this.host||void 0===this.branch)throw new Error("Failed to render limble tree branch");this.treeService.renderBranch(this.host,this.branch)},e}();f.decorators=[{type:t.Component,args:[{selector:"limble-tree-branch",template:'<div [style.marginLeft.px]="indent">\r\n <ng-template #dropZoneInside></ng-template>\r\n <span [hidden]="branch?.data.collapsed" class="limble-child-nodes">\r\n <ng-template #host></ng-template>\r\n </span>\r\n</div>\r\n',styles:["./limble-tree-branch.component.scss"]}]}],f.ctorParameters=function(){return[{type:b},{type:t.ChangeDetectorRef}]},f.propDecorators={branch:[{type:t.Input}],host:[{type:t.ViewChild,args:["host",{read:t.ViewContainerRef}]}],dropZoneInside:[{type:t.ViewChild,args:["dropZoneInside",{read:t.ViewContainerRef}]}],dropZoneInside$:[{type:t.Output}]};var g=function(){function e(e,t,r,o,n){this.componentCreatorService=e,this.changeDetectorRef=t,this.dragStateService=r,this.dropZoneService=o,this.treeService=n}return e.prototype.ngAfterViewInit=function(){this.registerDropZones(),this.renderSelf(),this.renderChildren(),this.checkForHandle(),this.changeDetectorRef.detectChanges()},e.prototype.dragstartHandler=function(e){var t;if(e.stopPropagation(),null===e.dataTransfer||void 0===this.branch)throw new Error("failed to run dragstartHandler");var r=e.target;"LIMBLE-TREE-NODE"===(null===(t=r.parentElement)||void 0===t?void 0:t.tagName)&&(e.dataTransfer.effectAllowed="move",r.classList.add("dragging"),this.dragStateService.dragging(this.branch))},e.prototype.dragendHandler=function(e){var t=this;if(e.stopPropagation(),e.target.classList.remove("dragging"),void 0===this.branch)throw new Error("failed to get current branch in dragendHandler");"captured"===this.dragStateService.getState()&&this.dragStateService.state$.pipe(o.take(2)).subscribe((function(e){"captured"===e&&void 0!==t.branch&&(t.treeService.remove(t.branch),t.dragStateService.release())}))},e.prototype.dragoverHandler=function(e){var t,r,o;if(void 0===this.branch)throw new Error("Can't get current branch during dragover event");var n=this.dragStateService.getData();if(void 0===n)throw new Error("Can't get source branch during dragover event");if(n===this.branch||this.branch.getAncestors().includes(n))null!==this.dropZoneService.getActiveDropZoneInfo()&&this.dropZoneService.removeActiveAndSecondaryZones();else if(!0!==this.treeService.getPlaceholder()||void 0===this.dropZoneAbove){var i,a=e.currentTarget.offsetHeight/3,d=2*a,p=this.branch.getParent();if(null!==p&&(i=p.data),e.offsetY<a&&void 0!==this.dropZoneAbove&&(null===(t=this.dropZoneService.getActiveDropZoneInfo())||void 0===t?void 0:t.container)!==this.dropZoneAbove&&c(this.treeService.treeOptions,i)){h=s(this.branch.getCoordinates());this.dropZoneService.showDropZoneFamily({container:this.dropZoneAbove,coordinates:h})}else if(e.offsetY<d&&void 0!==this.dropZoneInside&&(null===(r=this.dropZoneService.getActiveDropZoneInfo())||void 0===r?void 0:r.container)!==this.dropZoneInside){(h=s(this.branch.getCoordinates())).push(0),this.dropZoneService.showDropZoneFamily({container:this.dropZoneInside,coordinates:h})}else if(e.offsetY>=d&&void 0!==this.dropZoneBelow&&(null===(o=this.dropZoneService.getActiveDropZoneInfo())||void 0===o?void 0:o.container)!==this.dropZoneBelow&&0===this.branch.getChildren().length&&c(this.treeService.treeOptions,i)){(h=s(this.branch.getCoordinates()))[h.length-1]++,this.dropZoneService.showDropZoneFamily({container:this.dropZoneBelow,coordinates:h})}}else{var h=s(this.branch.getCoordinates());this.dropZoneService.showDropZoneFamily({container:this.dropZoneAbove,coordinates:h})}},e.prototype.renderSelf=function(){var e;if(void 0===this.nodeHost||void 0===this.branch)throw new Error("Failed to render tree node");var t=this.branch.data.component;if(void 0===t&&(t=null===(e=this.treeService.treeOptions)||void 0===e?void 0:e.defaultComponent),void 0===t)throw new Error("limbleTree requires a component to render");var r=this.componentCreatorService.appendComponent(t.class,this.nodeHost);for(var o in r.instance.nodeData=this.branch.data,t.bindings)r.instance[o]=t.bindings[o]},e.prototype.renderChildren=function(){var e=this;if(void 0!==this.children){if(void 0===this.branch)throw new Error("branch is undefined");var t=this.componentCreatorService.appendComponent(f,this.children);t.instance.branch=this.branch,c(this.treeService.treeOptions,this.branch.data)&&!0==!this.treeService.getPlaceholder()&&t.instance.dropZoneInside$.subscribe((function(t){var r;if(void 0!==t&&!1!==(null===(r=e.treeService.treeOptions)||void 0===r?void 0:r.allowDragging)){if(e.dropZoneInside=t,void 0===e.branch)throw new Error("failed to register inner drop zone");var o=e.branch.getCoordinates();o.push(0),e.dropZoneService.addDropZone({container:e.dropZoneInside,coordinates:o})}}))}},e.prototype.registerDropZones=function(){var e;if(!1!==(null===(e=this.treeService.treeOptions)||void 0===e?void 0:e.allowDragging)){if(void 0===this.dropZoneAbove||void 0===this.dropZoneBelow||void 0===this.branch)throw new Error("failed to register drop zones");var t,r=this.branch.getParent();if(null!==r&&(t=r.data),c(this.treeService.treeOptions,t)){var o=this.branch.getCoordinates(),n=s(o);if(this.dropZoneService.addDropZone({container:this.dropZoneAbove,coordinates:n}),!0!==this.treeService.getPlaceholder()){var i=s(o);i[i.length-1]++,this.dropZoneService.addDropZone({container:this.dropZoneBelow,coordinates:i})}}}},e.prototype.checkForHandle=function(){var e;if(void 0!==this.draggableDiv){var t,r,o=this.draggableDiv.nativeElement,n=o.querySelector(".limble-tree-handle");t=this.treeService.treeOptions,r=null===(e=this.branch)||void 0===e?void 0:e.data,void 0===t||!0!==t.allowDragging&&("function"!=typeof t.allowDragging||void 0===r||!0!==t.allowDragging(r))?o.setAttribute("draggable","false"):null===n?o.setAttribute("draggable","true"):(n.addEventListener("mousedown",(function(){o.setAttribute("draggable","true")})),n.addEventListener("mouseup",(function(){o.setAttribute("draggable","false")})))}},e}();g.decorators=[{type:t.Component,args:[{selector:"limble-tree-node",template:'<ng-template #dropZoneAbove></ng-template>\r\n<div\r\n (dragstart)="dragstartHandler($event)"\r\n (dragend)="dragendHandler($event)"\r\n #draggableDiv\r\n>\r\n <div (dragover)="dragoverHandler($event)">\r\n <ng-template #nodeHost></ng-template>\r\n </div>\r\n <ng-template #children></ng-template>\r\n</div>\r\n<ng-template #dropZoneBelow></ng-template>\r\n',styles:[".dragging{opacity:.33}"]}]}],g.ctorParameters=function(){return[{type:d},{type:t.ChangeDetectorRef},{type:l},{type:v},{type:b}]},g.propDecorators={branch:[{type:t.Input}],nodeHost:[{type:t.ViewChild,args:["nodeHost",{read:t.ViewContainerRef}]}],dropZoneAbove:[{type:t.ViewChild,args:["dropZoneAbove",{read:t.ViewContainerRef}]}],dropZoneBelow:[{type:t.ViewChild,args:["dropZoneBelow",{read:t.ViewContainerRef}]}],children:[{type:t.ViewChild,args:["children",{read:t.ViewContainerRef}]}],draggableDiv:[{type:t.ViewChild,args:["draggableDiv",{read:t.ElementRef}]}]};var y=function(){};y.decorators=[{type:t.Component,args:[{selector:"limble-tree-placeholder",template:'<div class="placeholder"></div>\n',styles:[".placeholder{height:20px;width:100%}"]}]}];var b=function(){function e(e,t){this.componentCreatorService=e,this.dropZoneService=t,this.changes$=new r.ReplaySubject(1),this.drops$=new r.ReplaySubject(1),this.treeModel=new u(null),this.placeholder=!1}return e.prototype.init=function(e,t,r){this.host=e,this.treeData=t,this.treeOptions=this.processOptions(r),this.render()},e.prototype.render=function(){var e,t,r,o;if(void 0===this.host||void 0===this.treeData||void 0===this.treeOptions)throw new Error("TreeModel not initialized");if(this.host.clear(),this.treeModel=new u(null),this.dropZoneService.clearDropZones(),this.dropZoneService.init(this.treeData,this.treeOptions),0===this.treeData.length){this.placeholder=!0;var n=new u({component:{class:y}});this.treeModel.appendChild(n),this.componentCreatorService.appendComponent(g,this.host).instance.branch=n}else{try{for(var a=i(this.treeData),s=a.next();!s.done;s=a.next()){var d=s.value;n=new u(d);this.treeModel.appendChild(n)}}catch(t){e={error:t}}finally{try{s&&!s.done&&(t=a.return)&&t.call(a)}finally{if(e)throw e.error}}try{for(var p=i(this.treeModel.getChildren()),h=p.next();!h.done;h=p.next()){n=h.value;this.componentCreatorService.appendComponent(g,this.host).instance.branch=n}}catch(e){r={error:e}}finally{try{h&&!h.done&&(o=p.return)&&o.call(p)}finally{if(r)throw r.error}}}this.changes$.next(null)},e.prototype.renderBranch=function(e,t){var r,o,n;if(void 0===this.treeModel)throw new Error("TreeModel not initialized");e.clear();try{for(var a=i(null!==(n=t.data.nodes)&&void 0!==n?n:[]),s=a.next();!s.done;s=a.next()){var d=s.value,p=new u(d);t.appendChild(p),this.componentCreatorService.appendComponent(g,e).instance.branch=p}}catch(e){r={error:e}}finally{try{s&&!s.done&&(o=a.return)&&o.call(a)}finally{if(r)throw r.error}}},e.prototype.processOptions=function(e){var t,r,o;return void 0===e&&(e={}),{defaultComponent:e.defaultComponent,indent:null!==(t=e.indent)&&void 0!==t?t:45,allowNesting:null===(r=e.allowNesting)||void 0===r||r,allowDragging:null===(o=e.allowDragging)||void 0===o||o}},e.prototype.drop=function(e,t){var r,o,n=e.getParent(),i=e.getIndex();if(void 0===i)throw new Error("Cannot move the hidden root node");if(!0===this.placeholder?(r=[],o=0,this.treeModel.removeChild(0),this.placeholder=!1):o=(r=s(t)).pop(),void 0===o)throw new Error("target coordinates are empty");var a=this.treeModel.getDescendant(r);if(void 0===a)throw new Error("could not get to target");a.insertChild(e,o),this.rebuildTreeData(),this.drops$.next({target:e.data,oldParent:null==n?void 0:n.data,oldIndex:i,newParent:a.data,newIndex:o}),this.render()},e.prototype.remove=function(e){e.remove(),this.rebuildTreeData(),this.render()},e.prototype.rebuildTreeData=function(){var e,t;if(null==this.treeData)throw new Error("Tree data not initialized");this.treeData.length=0;try{for(var r=i(this.treeModel.getChildren()),o=r.next();!o.done;o=r.next()){var n=o.value;this.treeData.push(this.rebuildBranch(n))}}catch(t){e={error:t}}finally{try{o&&!o.done&&(t=r.return)&&t.call(r)}finally{if(e)throw e.error}}},e.prototype.rebuildBranch=function(e){var t,r,o=e.data;o.nodes=[];try{for(var n=i(e.getChildren()),a=n.next();!a.done;a=n.next()){var s=a.value;o.nodes.push(this.rebuildBranch(s))}}catch(e){t={error:e}}finally{try{a&&!a.done&&(r=n.return)&&r.call(n)}finally{if(t)throw t.error}}return o},e.prototype.getPlaceholder=function(){return this.placeholder},e}();b.decorators=[{type:t.Injectable}],b.ctorParameters=function(){return[{type:d},{type:v}]};var w=function(){function e(e,o,n,i){var a=this;this.treeService=e,this.changeDetectorRef=o,this.dropZoneService=n,this.dragStateService=i,this.treeChange=new t.EventEmitter,this.treeDrop=new t.EventEmitter,this.dropZoneInside$=new r.BehaviorSubject(this.dropZoneInside),this.changesSubscription=this.treeService.changes$.subscribe((function(){a.treeChange.emit()})),this.dropSubscription=this.treeService.drops$.subscribe((function(e){a.treeDrop.emit(e)}))}return e.prototype.ngAfterViewInit=function(){this.dropZoneInside$.next(this.dropZoneInside),this.dropZoneInside$.complete(),this.update(),this.changeDetectorRef.detectChanges()},e.prototype.ngOnChanges=function(){void 0!==this.host&&void 0!==this.data&&this.update()},e.prototype.update=function(){if(void 0===this.host)throw new Error("Failed to render limble tree. Failure occurred at root.");if(void 0===this.data)throw new Error("limbleTree requires a data object");this.treeService.init(this.host,this.data,this.options)},e.prototype.dragoverHandler=function(e){null!==e.dataTransfer&&(e.stopPropagation(),e.preventDefault(),e.dataTransfer.dropEffect="move")},e.prototype.dragleaveHandler=function(e){var t=e.currentTarget,r=e.relatedTarget;t instanceof Node&&r instanceof Node&&!1===function(e,t){if(e===t)return!0;for(var r=t.parentNode;r!==document;){if(null===r)return;if(r===e)return!0;r=r.parentNode}return!1}(t,r)&&this.dropZoneService.removeActiveAndSecondaryZones()},e.prototype.dropHandler=function(e){e.stopPropagation();var t=this.dropZoneService.getActiveDropZoneInfo();if("droppable"===this.dragStateService.getState()){if(null===t)throw new Error("failed to get active drop zone at drop handler");var r=this.dragStateService.capture();if(void 0===r)throw new Error("failed to get current branch in dragendHandler");this.dropZoneService.removeActiveAndSecondaryZones(),this.treeService.drop(r,t.coordinates)}},e.prototype.ngOnDestroy=function(){this.changesSubscription.unsubscribe(),this.dropSubscription.unsubscribe()},e}();w.decorators=[{type:t.Component,args:[{selector:"limble-tree-root",template:'<div\r\n (dragover)="dragoverHandler($event)"\r\n (dragleave)="dragleaveHandler($event)"\r\n (drop)="dropHandler($event)"\r\n>\r\n <ng-template #dropZoneInside></ng-template>\r\n <ng-template #host></ng-template>\r\n</div>\r\n',providers:[b,v],styles:[""]}]}],w.ctorParameters=function(){return[{type:b},{type:t.ChangeDetectorRef},{type:v},{type:l}]},w.propDecorators={data:[{type:t.Input}],options:[{type:t.Input}],host:[{type:t.ViewChild,args:["host",{read:t.ViewContainerRef}]}],dropZoneInside:[{type:t.ViewChild,args:["dropZoneInside",{read:t.ViewContainerRef}]}],dropZoneInside$:[{type:t.Output}],treeChange:[{type:t.Output}],treeDrop:[{type:t.Output}]};var m=function(){};m.decorators=[{type:t.NgModule,args:[{declarations:[f,p,g,w,y],imports:[n.CommonModule],exports:[w],providers:[d,l]}]}],e.LimbleTreeModule=m,e.LimbleTreeRootComponent=w,e.ɵa=b,e.ɵb=d,e.ɵc=v,e.ɵd=l,e.ɵe=f,e.ɵf=p,e.ɵg=g,e.ɵh=y,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=limble-limble-tree.umd.min.js.map

@@ -63,2 +63,11 @@ export class Branch {

}
getAncestors() {
const result = [];
let cursor = this;
while (cursor.parent !== null) {
result.push(cursor.parent);
cursor = cursor.parent;
}
return result;
}
appendChild(child) {

@@ -110,2 +119,2 @@ if (child.getParent() !== null) {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"branch.js","sourceRoot":"../../../projects/limble-tree/src/","sources":["lib/branch.ts"],"names":[],"mappings":"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","sourcesContent":["/** An object indicating a location within a tree */\r\nexport type BranchCoordinates = Array<number>;\r\n\r\nexport class Branch<T> {\r\n   public data: T;\r\n   private children: Array<Branch<T>>;\r\n   private parent: Branch<unknown> | null;\r\n\r\n   public constructor(data: T) {\r\n      this.data = data;\r\n      this.children = [];\r\n      this.parent = null;\r\n   }\r\n\r\n   public isRoot() {\r\n      return this.parent === null;\r\n   }\r\n\r\n   public getParent() {\r\n      return this.parent;\r\n   }\r\n\r\n   public setParent<U>(parent: Branch<U> | null) {\r\n      this.parent = parent;\r\n   }\r\n\r\n   public getCoordinates() {\r\n      const coordinates: BranchCoordinates = [];\r\n      let cursor: Branch<unknown> = this;\r\n      while (cursor.parent !== null) {\r\n         const cursorIndex = cursor.getIndex();\r\n         if (cursorIndex === undefined) {\r\n            throw new Error(\"Unreachable error\"); //This should be impossible to hit\r\n         }\r\n         coordinates.unshift(cursorIndex);\r\n         cursor = cursor.parent;\r\n      }\r\n      return coordinates;\r\n   }\r\n\r\n   public getChild(index: number): Branch<T> | undefined {\r\n      return this.children[index];\r\n   }\r\n\r\n   public getChildren() {\r\n      return this.children;\r\n   }\r\n\r\n   public getIndex(): number | undefined {\r\n      return (\r\n         this.parent?.children.findIndex((branch) => branch === this) ??\r\n         undefined\r\n      );\r\n   }\r\n\r\n   public getDescendant(\r\n      relativeCoordinates: BranchCoordinates\r\n   ): Branch<T> | undefined {\r\n      let cursor: Branch<T> = this;\r\n      for (const index of relativeCoordinates) {\r\n         cursor = cursor.children[index];\r\n         if (cursor === undefined) {\r\n            return undefined;\r\n         }\r\n      }\r\n      return cursor;\r\n   }\r\n\r\n   public findDescendant(\r\n      predicate: (data: T) => boolean\r\n   ): Branch<T> | undefined {\r\n      if (predicate(this.data) === true) {\r\n         return this;\r\n      }\r\n      if (this.children.length > 0) {\r\n         for (const child of this.children) {\r\n            const foundDeeper = child.findDescendant(predicate);\r\n            if (foundDeeper !== undefined) {\r\n               return foundDeeper;\r\n            }\r\n         }\r\n      }\r\n      return undefined;\r\n   }\r\n\r\n   public appendChild(child: Branch<T>): Branch<T> {\r\n      if (child.getParent() !== null) {\r\n         child.remove();\r\n      }\r\n      child.setParent(this);\r\n      this.children.push(child);\r\n      return child;\r\n   }\r\n\r\n   public insertChild(child: Branch<T>, index: number): Branch<T> {\r\n      const isOwnChild = this.children.indexOf(child);\r\n      if (isOwnChild === -1) {\r\n         if (child.getParent() !== null) {\r\n            child.remove();\r\n         }\r\n         child.setParent(this);\r\n         this.children.splice(index, 0, child);\r\n      } else {\r\n         if (index > isOwnChild) {\r\n            //Insert first, then remove\r\n            this.children.splice(index, 0, child);\r\n            this.removeChild(isOwnChild);\r\n            child.setParent(this);\r\n         } else {\r\n            //remove first, then insert\r\n            child.remove();\r\n            this.children.splice(index, 0, child);\r\n            child.setParent(this);\r\n         }\r\n      }\r\n      return child;\r\n   }\r\n\r\n   public removeChild(index: number): Branch<T> {\r\n      const target = this.children.splice(index, 1)[0];\r\n      target.setParent(null);\r\n      return target;\r\n   }\r\n\r\n   public remove(): Branch<T> {\r\n      const index = this.getIndex();\r\n      if (this.parent === null || index === undefined) {\r\n         throw new Error(\"can't remove root\");\r\n      }\r\n      return this.parent.removeChild(index) as Branch<T>;\r\n   }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"branch.js","sourceRoot":"../../../projects/limble-tree/src/","sources":["lib/branch.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,MAAM;IAKhB,YAAmB,IAAO;QACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACtB,CAAC;IAEM,MAAM;QACV,OAAO,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC;IAC/B,CAAC;IAEM,SAAS;QACb,OAAO,IAAI,CAAC,MAAM,CAAC;IACtB,CAAC;IAEM,SAAS,CAAI,MAAwB;QACzC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACxB,CAAC;IAEM,cAAc;QAClB,MAAM,WAAW,GAAsB,EAAE,CAAC;QAC1C,IAAI,MAAM,GAAoB,IAAI,CAAC;QACnC,OAAO,MAAM,CAAC,MAAM,KAAK,IAAI,EAAE;YAC5B,MAAM,WAAW,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;YACtC,IAAI,WAAW,KAAK,SAAS,EAAE;gBAC5B,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC,kCAAkC;aAC1E;YACD,WAAW,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACjC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;SACzB;QACD,OAAO,WAAW,CAAC;IACtB,CAAC;IAEM,QAAQ,CAAC,KAAa;QAC1B,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAEM,WAAW;QACf,OAAO,IAAI,CAAC,QAAQ,CAAC;IACxB,CAAC;IAEM,QAAQ;;QACZ,OAAO,aACJ,IAAI,CAAC,MAAM,0CAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,KAAK,IAAI,oCAC3D,SAAS,CACX,CAAC;IACL,CAAC;IAEM,aAAa,CACjB,mBAAsC;QAEtC,IAAI,MAAM,GAAc,IAAI,CAAC;QAC7B,KAAK,MAAM,KAAK,IAAI,mBAAmB,EAAE;YACtC,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAChC,IAAI,MAAM,KAAK,SAAS,EAAE;gBACvB,OAAO,SAAS,CAAC;aACnB;SACH;QACD,OAAO,MAAM,CAAC;IACjB,CAAC;IAEM,cAAc,CAClB,SAA+B;QAE/B,IAAI,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YAChC,OAAO,IAAI,CAAC;SACd;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE;gBAChC,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;gBACpD,IAAI,WAAW,KAAK,SAAS,EAAE;oBAC5B,OAAO,WAAW,CAAC;iBACrB;aACH;SACH;QACD,OAAO,SAAS,CAAC;IACpB,CAAC;IAEM,YAAY;QAChB,MAAM,MAAM,GAA2B,EAAE,CAAC;QAC1C,IAAI,MAAM,GAAoB,IAAI,CAAC;QACnC,OAAO,MAAM,CAAC,MAAM,KAAK,IAAI,EAAE;YAC5B,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAC3B,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;SACzB;QACD,OAAO,MAAM,CAAC;IACjB,CAAC;IAEM,WAAW,CAAC,KAAgB;QAChC,IAAI,KAAK,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;YAC7B,KAAK,CAAC,MAAM,EAAE,CAAC;SACjB;QACD,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,OAAO,KAAK,CAAC;IAChB,CAAC;IAEM,WAAW,CAAC,KAAgB,EAAE,KAAa;QAC/C,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,UAAU,KAAK,CAAC,CAAC,EAAE;YACpB,IAAI,KAAK,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;gBAC7B,KAAK,CAAC,MAAM,EAAE,CAAC;aACjB;YACD,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YACtB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;SACxC;aAAM;YACJ,IAAI,KAAK,GAAG,UAAU,EAAE;gBACrB,2BAA2B;gBAC3B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;gBACtC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;gBAC7B,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;aACxB;iBAAM;gBACJ,2BAA2B;gBAC3B,KAAK,CAAC,MAAM,EAAE,CAAC;gBACf,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;gBACtC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;aACxB;SACH;QACD,OAAO,KAAK,CAAC;IAChB,CAAC;IAEM,WAAW,CAAC,KAAa;QAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACvB,OAAO,MAAM,CAAC;IACjB,CAAC;IAEM,MAAM;QACV,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;YAC9C,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;SACvC;QACD,OAAO,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAc,CAAC;IACtD,CAAC;CACH","sourcesContent":["/** An object indicating a location within a tree */\r\nexport type BranchCoordinates = Array<number>;\r\n\r\nexport class Branch<T> {\r\n   public data: T;\r\n   private children: Array<Branch<T>>;\r\n   private parent: Branch<unknown> | null;\r\n\r\n   public constructor(data: T) {\r\n      this.data = data;\r\n      this.children = [];\r\n      this.parent = null;\r\n   }\r\n\r\n   public isRoot() {\r\n      return this.parent === null;\r\n   }\r\n\r\n   public getParent() {\r\n      return this.parent;\r\n   }\r\n\r\n   public setParent<U>(parent: Branch<U> | null) {\r\n      this.parent = parent;\r\n   }\r\n\r\n   public getCoordinates() {\r\n      const coordinates: BranchCoordinates = [];\r\n      let cursor: Branch<unknown> = this;\r\n      while (cursor.parent !== null) {\r\n         const cursorIndex = cursor.getIndex();\r\n         if (cursorIndex === undefined) {\r\n            throw new Error(\"Unreachable error\"); //This should be impossible to hit\r\n         }\r\n         coordinates.unshift(cursorIndex);\r\n         cursor = cursor.parent;\r\n      }\r\n      return coordinates;\r\n   }\r\n\r\n   public getChild(index: number): Branch<T> | undefined {\r\n      return this.children[index];\r\n   }\r\n\r\n   public getChildren() {\r\n      return this.children;\r\n   }\r\n\r\n   public getIndex(): number | undefined {\r\n      return (\r\n         this.parent?.children.findIndex((branch) => branch === this) ??\r\n         undefined\r\n      );\r\n   }\r\n\r\n   public getDescendant(\r\n      relativeCoordinates: BranchCoordinates\r\n   ): Branch<T> | undefined {\r\n      let cursor: Branch<T> = this;\r\n      for (const index of relativeCoordinates) {\r\n         cursor = cursor.children[index];\r\n         if (cursor === undefined) {\r\n            return undefined;\r\n         }\r\n      }\r\n      return cursor;\r\n   }\r\n\r\n   public findDescendant(\r\n      predicate: (data: T) => boolean\r\n   ): Branch<T> | undefined {\r\n      if (predicate(this.data) === true) {\r\n         return this;\r\n      }\r\n      if (this.children.length > 0) {\r\n         for (const child of this.children) {\r\n            const foundDeeper = child.findDescendant(predicate);\r\n            if (foundDeeper !== undefined) {\r\n               return foundDeeper;\r\n            }\r\n         }\r\n      }\r\n      return undefined;\r\n   }\r\n\r\n   public getAncestors(): Array<Branch<unknown>> {\r\n      const result: Array<Branch<unknown>> = [];\r\n      let cursor: Branch<unknown> = this;\r\n      while (cursor.parent !== null) {\r\n         result.push(cursor.parent);\r\n         cursor = cursor.parent;\r\n      }\r\n      return result;\r\n   }\r\n\r\n   public appendChild(child: Branch<T>): Branch<T> {\r\n      if (child.getParent() !== null) {\r\n         child.remove();\r\n      }\r\n      child.setParent(this);\r\n      this.children.push(child);\r\n      return child;\r\n   }\r\n\r\n   public insertChild(child: Branch<T>, index: number): Branch<T> {\r\n      const isOwnChild = this.children.indexOf(child);\r\n      if (isOwnChild === -1) {\r\n         if (child.getParent() !== null) {\r\n            child.remove();\r\n         }\r\n         child.setParent(this);\r\n         this.children.splice(index, 0, child);\r\n      } else {\r\n         if (index > isOwnChild) {\r\n            //Insert first, then remove\r\n            this.children.splice(index, 0, child);\r\n            this.removeChild(isOwnChild);\r\n            child.setParent(this);\r\n         } else {\r\n            //remove first, then insert\r\n            child.remove();\r\n            this.children.splice(index, 0, child);\r\n            child.setParent(this);\r\n         }\r\n      }\r\n      return child;\r\n   }\r\n\r\n   public removeChild(index: number): Branch<T> {\r\n      const target = this.children.splice(index, 1)[0];\r\n      target.setParent(null);\r\n      return target;\r\n   }\r\n\r\n   public remove(): Branch<T> {\r\n      const index = this.getIndex();\r\n      if (this.parent === null || index === undefined) {\r\n         throw new Error(\"can't remove root\");\r\n      }\r\n      return this.parent.removeChild(index) as Branch<T>;\r\n   }\r\n}\r\n"]}
import { Component, Input } from "@angular/core";
import { DropZoneService } from "../singletons/drop-zone.service";
import { DropZoneService } from "../limble-tree-root/drop-zone.service";
export class DropZoneComponent {

@@ -29,2 +29,2 @@ constructor(dropZoneService) {

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcC16b25lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLi9wcm9qZWN0cy9saW1ibGUtdHJlZS9zcmMvIiwic291cmNlcyI6WyJsaWIvZHJvcC16b25lL2Ryb3Atem9uZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBT2xFLE1BQU0sT0FBTyxpQkFBaUI7SUFJM0IsWUFBNkIsZUFBZ0M7UUFBaEMsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBSHBELFdBQU0sR0FBWSxLQUFLLENBQUM7SUFHK0IsQ0FBQztJQUUxRCxnQkFBZ0I7UUFDcEIsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLElBQUksSUFBSSxJQUFJLENBQUMsWUFBWSxLQUFLLFNBQVMsRUFBRTtZQUMxRCxPQUFPO1NBQ1Q7UUFDRCxJQUFJLENBQUMsZUFBZSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM5RCxDQUFDOzs7WUFoQkgsU0FBUyxTQUFDO2dCQUNSLFFBQVEsRUFBRSxXQUFXO2dCQUNyQixtS0FBeUM7O2FBRTNDOzs7WUFOUSxlQUFlOzs7cUJBUXBCLEtBQUs7MkJBQ0wsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgdHlwZSB7IERyb3Bab25lSW5mbyB9IGZyb20gXCIuLi9zaW5nbGV0b25zL2Ryb3Atem9uZS5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IERyb3Bab25lU2VydmljZSB9IGZyb20gXCIuLi9zaW5nbGV0b25zL2Ryb3Atem9uZS5zZXJ2aWNlXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgc2VsZWN0b3I6IFwiZHJvcC16b25lXCIsXHJcbiAgIHRlbXBsYXRlVXJsOiBcIi4vZHJvcC16b25lLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgIHN0eWxlVXJsczogW1wiLi9kcm9wLXpvbmUuY29tcG9uZW50LnNjc3NcIl1cclxufSlcclxuZXhwb3J0IGNsYXNzIERyb3Bab25lQ29tcG9uZW50IHtcclxuICAgQElucHV0KCkgYWN0aXZlOiBib29sZWFuID0gZmFsc2U7XHJcbiAgIEBJbnB1dCgpIGRyb3Bab25lSW5mbzogRHJvcFpvbmVJbmZvIHwgdW5kZWZpbmVkO1xyXG5cclxuICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBkcm9wWm9uZVNlcnZpY2U6IERyb3Bab25lU2VydmljZSkge31cclxuXHJcbiAgIHB1YmxpYyBkcmFnZW50ZXJIYW5kbGVyKCkge1xyXG4gICAgICBpZiAodGhpcy5hY3RpdmUgPT09IHRydWUgfHwgdGhpcy5kcm9wWm9uZUluZm8gPT09IHVuZGVmaW5lZCkge1xyXG4gICAgICAgICByZXR1cm47XHJcbiAgICAgIH1cclxuICAgICAgdGhpcy5kcm9wWm9uZVNlcnZpY2Uuc3dhcEFjdGl2ZURyb3Bab25lKHRoaXMuZHJvcFpvbmVJbmZvKTtcclxuICAgfVxyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcC16b25lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLi9wcm9qZWN0cy9saW1ibGUtdHJlZS9zcmMvIiwic291cmNlcyI6WyJsaWIvZHJvcC16b25lL2Ryb3Atem9uZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBT3hFLE1BQU0sT0FBTyxpQkFBaUI7SUFJM0IsWUFBNkIsZUFBZ0M7UUFBaEMsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBSHBELFdBQU0sR0FBWSxLQUFLLENBQUM7SUFHK0IsQ0FBQztJQUUxRCxnQkFBZ0I7UUFDcEIsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLElBQUksSUFBSSxJQUFJLENBQUMsWUFBWSxLQUFLLFNBQVMsRUFBRTtZQUMxRCxPQUFPO1NBQ1Q7UUFDRCxJQUFJLENBQUMsZUFBZSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM5RCxDQUFDOzs7WUFoQkgsU0FBUyxTQUFDO2dCQUNSLFFBQVEsRUFBRSxXQUFXO2dCQUNyQixtS0FBeUM7O2FBRTNDOzs7WUFOUSxlQUFlOzs7cUJBUXBCLEtBQUs7MkJBQ0wsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgdHlwZSB7IERyb3Bab25lSW5mbyB9IGZyb20gXCIuLi9saW1ibGUtdHJlZS1yb290L2Ryb3Atem9uZS5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IERyb3Bab25lU2VydmljZSB9IGZyb20gXCIuLi9saW1ibGUtdHJlZS1yb290L2Ryb3Atem9uZS5zZXJ2aWNlXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgc2VsZWN0b3I6IFwiZHJvcC16b25lXCIsXHJcbiAgIHRlbXBsYXRlVXJsOiBcIi4vZHJvcC16b25lLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgIHN0eWxlVXJsczogW1wiLi9kcm9wLXpvbmUuY29tcG9uZW50LnNjc3NcIl1cclxufSlcclxuZXhwb3J0IGNsYXNzIERyb3Bab25lQ29tcG9uZW50IHtcclxuICAgQElucHV0KCkgYWN0aXZlOiBib29sZWFuID0gZmFsc2U7XHJcbiAgIEBJbnB1dCgpIGRyb3Bab25lSW5mbzogRHJvcFpvbmVJbmZvIHwgdW5kZWZpbmVkO1xyXG5cclxuICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBkcm9wWm9uZVNlcnZpY2U6IERyb3Bab25lU2VydmljZSkge31cclxuXHJcbiAgIHB1YmxpYyBkcmFnZW50ZXJIYW5kbGVyKCkge1xyXG4gICAgICBpZiAodGhpcy5hY3RpdmUgPT09IHRydWUgfHwgdGhpcy5kcm9wWm9uZUluZm8gPT09IHVuZGVmaW5lZCkge1xyXG4gICAgICAgICByZXR1cm47XHJcbiAgICAgIH1cclxuICAgICAgdGhpcy5kcm9wWm9uZVNlcnZpY2Uuc3dhcEFjdGl2ZURyb3Bab25lKHRoaXMuZHJvcFpvbmVJbmZvKTtcclxuICAgfVxyXG59XHJcbiJdfQ==
import { ChangeDetectorRef, Component, ElementRef, Input, ViewChild, ViewContainerRef } from "@angular/core";
import { ComponentCreatorService } from "../singletons/component-creator.service";
import { DropZoneService } from "../singletons/drop-zone.service";
import { DropZoneService } from "../limble-tree-root/drop-zone.service";
import { LimbleTreeBranchComponent } from "../limble-tree-branch/limble-tree-branch.component";
import { TempService } from "../singletons/temp.service";
import { DragStateService } from "../singletons/drag-state.service";
import { TreeService } from "../limble-tree-root/tree.service";
import { isDraggingAllowed, isNestingAllowed } from "../util";
import { take } from "rxjs/operators";
export class LimbleTreeNodeComponent {
constructor(componentCreatorService, changeDetectorRef, tempService, dropZoneService, treeService) {
constructor(componentCreatorService, changeDetectorRef, dragStateService, dropZoneService, treeService) {
this.componentCreatorService = componentCreatorService;
this.changeDetectorRef = changeDetectorRef;
this.tempService = tempService;
this.dragStateService = dragStateService;
this.dropZoneService = dropZoneService;

@@ -27,6 +28,7 @@ this.treeService = treeService;

if (event.dataTransfer === null || this.branch === undefined) {
return;
throw new Error("failed to run dragstartHandler");
}
const draggedElement = event.target;
if (((_a = draggedElement.parentElement) === null || _a === void 0 ? void 0 : _a.tagName) !== "LIMBLE-TREE-NODE") {
//Don't drag stuff that isn't part of the tree
return;

@@ -36,3 +38,3 @@ }

draggedElement.classList.add("dragging");
this.tempService.set(this.branch);
this.dragStateService.dragging(this.branch);
}

@@ -42,29 +44,28 @@ dragendHandler(event) {

const draggedElement = event.target;
const sourceBranch = this.tempService.get();
if (sourceBranch === undefined) {
return;
draggedElement.classList.remove("dragging");
if (this.branch === undefined) {
throw new Error("failed to get current branch in dragendHandler");
}
this.tempService.delete();
draggedElement.classList.remove("dragging");
const dropZoneInfo = this.dropZoneService.getActiveDropZoneInfo();
if (dropZoneInfo === null) {
if (this.dragStateService.getState() !== "captured") {
return;
}
this.dropZoneService.removeActiveAndSecondaryZones();
if (dropZoneInfo.coordinates === undefined) {
throw new Error("could not determine drop zone location");
}
this.treeService.move(sourceBranch, dropZoneInfo.coordinates);
this.dragStateService.state$.pipe(take(2)).subscribe((state) => {
if (state === "captured" && this.branch !== undefined) {
this.treeService.remove(this.branch);
this.dragStateService.release();
}
});
}
dragoverHandler(event) {
var _a, _b, _c;
if (this.tempService.get() === undefined || this.branch === undefined) {
return;
if (this.branch === undefined) {
throw new Error("Can't get current branch during dragover event");
}
const sourceBranch = this.tempService.get();
const sourceBranch = this.dragStateService.getData();
if (sourceBranch === undefined) {
return;
throw new Error("Can't get source branch during dragover event");
}
//If trying to drop on self, remove any remaining drop zones and return.
if (sourceBranch === this.branch) {
//If trying to drop on self, remove any existing drop zones and return.
if (sourceBranch === this.branch ||
this.branch.getAncestors().includes(sourceBranch)) {
if (this.dropZoneService.getActiveDropZoneInfo() !== null) {

@@ -75,9 +76,26 @@ this.dropZoneService.removeActiveAndSecondaryZones();

}
if (this.treeService.getPlaceholder() === true &&
this.dropZoneAbove !== undefined) {
//If placeholder system is active, then activate the only existing drop zone
//and skip the rest of the logic in this function
const dropCoordinates = [...this.branch.getCoordinates()];
this.dropZoneService.showDropZoneFamily({
container: this.dropZoneAbove,
coordinates: dropCoordinates
});
return;
}
const target = event.currentTarget;
const topLine = target.offsetHeight / 3; //an imaginary line 1/3 of the way down from the top of the element;
const bottomLine = topLine * 2; //an imaginary line 1/3 of the way up from the bottom of the element;
const parent = this.branch.getParent();
let parentData;
if (parent !== null) {
parentData = parent.data;
}
if (event.offsetY < topLine &&
this.dropZoneAbove !== undefined &&
((_a = this.dropZoneService.getActiveDropZoneInfo()) === null || _a === void 0 ? void 0 : _a.container) !==
this.dropZoneAbove) {
this.dropZoneAbove &&
isNestingAllowed(this.treeService.treeOptions, parentData)) {
const dropCoordinates = [...this.branch.getCoordinates()];

@@ -104,3 +122,4 @@ this.dropZoneService.showDropZoneFamily({

this.dropZoneBelow &&
this.branch.getChildren().length === 0) {
this.branch.getChildren().length === 0 &&
isNestingAllowed(this.treeService.treeOptions, parentData)) {
const dropCoordinates = [...this.branch.getCoordinates()];

@@ -139,3 +158,4 @@ dropCoordinates[dropCoordinates.length - 1]++;

newBranchComponent.instance.branch = this.branch;
if (isNestingAllowed(this.treeService.treeOptions, this.branch.data)) {
if (isNestingAllowed(this.treeService.treeOptions, this.branch.data) &&
!this.treeService.getPlaceholder() === true) {
newBranchComponent.instance.dropZoneInside$.subscribe((dropZone) => {

@@ -170,2 +190,10 @@ var _a;

}
const parent = this.branch.getParent();
let parentData;
if (parent !== null) {
parentData = parent.data;
}
if (!isNestingAllowed(this.treeService.treeOptions, parentData)) {
return;
}
const currentCoordinates = this.branch.getCoordinates();

@@ -177,2 +205,6 @@ const dropCoordinatesAbove = [...currentCoordinates];

});
if (this.treeService.getPlaceholder() === true) {
//Only register one drop zone if the placeholder system is active
return;
}
const dropCoordinatesBelow = [...currentCoordinates];

@@ -218,3 +250,3 @@ dropCoordinatesBelow[dropCoordinatesBelow.length - 1]++;

{ type: ChangeDetectorRef },
{ type: TempService },
{ type: DragStateService },
{ type: DropZoneService },

@@ -231,2 +263,2 @@ { type: TreeService }

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"limble-tree-node.component.js","sourceRoot":"../../../projects/limble-tree/src/","sources":["lib/limble-tree-node/limble-tree-node.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEJ,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,KAAK,EACL,SAAS,EACT,gBAAgB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,yCAAyC,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,yBAAyB,EAAE,MAAM,oDAAoD,CAAC;AAC/F,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAE/D,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAO9D,MAAM,OAAO,uBAAuB;IAiBjC,YACoB,uBAAgD,EAChD,iBAAoC,EACpC,WAAwB,EACxB,eAAgC,EAChC,WAAwB;QAJxB,4BAAuB,GAAvB,uBAAuB,CAAyB;QAChD,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,gBAAW,GAAX,WAAW,CAAa;QACxB,oBAAe,GAAf,eAAe,CAAiB;QAChC,gBAAW,GAAX,WAAW,CAAa;IACzC,CAAC;IAEJ,eAAe;QACZ,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IAC1C,CAAC;IAEM,gBAAgB,CAAC,KAAgB;;QACrC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,KAAK,CAAC,YAAY,KAAK,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;YAC3D,OAAO;SACT;QACD,MAAM,cAAc,GAAG,KAAK,CAAC,MAAqB,CAAC;QACnD,IAAI,OAAA,cAAc,CAAC,aAAa,0CAAE,OAAO,MAAK,kBAAkB,EAAE;YAC/D,OAAO;SACT;QACD,KAAK,CAAC,YAAY,CAAC,aAAa,GAAG,MAAM,CAAC;QAC1C,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACzC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACrC,CAAC;IAEM,cAAc,CAAC,KAAgB;QACnC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,cAAc,GAAG,KAAK,CAAC,MAAqB,CAAC;QACnD,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC;QAC5C,IAAI,YAAY,KAAK,SAAS,EAAE;YAC7B,OAAO;SACT;QACD,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QAC1B,cAAc,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC5C,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE,CAAC;QAClE,IAAI,YAAY,KAAK,IAAI,EAAE;YACxB,OAAO;SACT;QACD,IAAI,CAAC,eAAe,CAAC,6BAA6B,EAAE,CAAC;QACrD,IAAI,YAAY,CAAC,WAAW,KAAK,SAAS,EAAE;YACzC,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;SAC5D;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,WAAW,CAAC,CAAC;IACjE,CAAC;IAEM,eAAe,CAAC,KAAgB;;QACpC,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,KAAK,SAAS,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;YACpE,OAAO;SACT;QACD,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC;QAC5C,IAAI,YAAY,KAAK,SAAS,EAAE;YAC7B,OAAO;SACT;QACD,wEAAwE;QACxE,IAAI,YAAY,KAAK,IAAI,CAAC,MAAM,EAAE;YAC/B,IAAI,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE,KAAK,IAAI,EAAE;gBACxD,IAAI,CAAC,eAAe,CAAC,6BAA6B,EAAE,CAAC;aACvD;YACD,OAAO;SACT;QACD,MAAM,MAAM,GAAG,KAAK,CAAC,aAA4B,CAAC;QAClD,MAAM,OAAO,GAAG,MAAM,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,oEAAoE;QAC7G,MAAM,UAAU,GAAG,OAAO,GAAG,CAAC,CAAC,CAAC,qEAAqE;QACrG,IACG,KAAK,CAAC,OAAO,GAAG,OAAO;YACvB,IAAI,CAAC,aAAa,KAAK,SAAS;YAChC,OAAA,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE,0CAAE,SAAS;gBACpD,IAAI,CAAC,aAAa,EACtB;YACC,MAAM,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC;YAC1D,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC;gBACrC,SAAS,EAAE,IAAI,CAAC,aAAa;gBAC7B,WAAW,EAAE,eAAe;aAC9B,CAAC,CAAC;SACL;aAAM,IACJ,KAAK,CAAC,OAAO,GAAG,UAAU;YAC1B,IAAI,CAAC,cAAc,KAAK,SAAS;YACjC,OAAA,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE,0CAAE,SAAS;gBACpD,IAAI,CAAC,cAAc,EACvB;YACC,MAAM,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC;YAC1D,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACxB,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC;gBACrC,SAAS,EAAE,IAAI,CAAC,cAAc;gBAC9B,WAAW,EAAE,eAAe;aAC9B,CAAC,CAAC;SACL;aAAM,IACJ,KAAK,CAAC,OAAO,IAAI,UAAU;YAC3B,IAAI,CAAC,aAAa,KAAK,SAAS;YAChC,OAAA,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE,0CAAE,SAAS;gBACpD,IAAI,CAAC,aAAa;YACrB,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,MAAM,KAAK,CAAC,EACvC;YACC,MAAM,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC;YAC1D,eAAe,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC;YAC9C,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC;gBACrC,SAAS,EAAE,IAAI,CAAC,aAAa;gBAC7B,WAAW,EAAE,eAAe;aAC9B,CAAC,CAAC;SACL;IACJ,CAAC;IAEO,UAAU;;QACf,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;YAC3D,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;SAChD;QACD,IAAI,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;QAC3C,IAAI,SAAS,KAAK,SAAS,EAAE;YAC1B,SAAS,SAAG,IAAI,CAAC,WAAW,CAAC,WAAW,0CAAE,gBAAgB,CAAC;SAC7D;QACD,IAAI,SAAS,KAAK,SAAS,EAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAC/D;QACD,MAAM,YAAY,GAAG,IAAI,CAAC,uBAAuB,CAAC,eAAe,CAC9D,SAAS,CAAC,KAAK,EACf,IAAI,CAAC,QAAQ,CACf,CAAC;QACF,YAAY,CAAC,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;QAClD,KAAK,MAAM,OAAO,IAAI,SAAS,CAAC,QAAQ,EAAE;YACvC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;SAC/D;IACJ,CAAC;IAEO,cAAc;QACnB,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC9B,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;gBAC5B,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;aACzC;YACD,MAAM,kBAAkB,GAAG,IAAI,CAAC,uBAAuB,CAAC,eAAe,CACpE,yBAAyB,EACzB,IAAI,CAAC,QAAQ,CACf,CAAC;YACF,kBAAkB,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACjD,IAAI,gBAAgB,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gBACnE,kBAAkB,CAAC,QAAQ,CAAC,eAAe,CAAC,SAAS,CAClD,CAAC,QAAQ,EAAE,EAAE;;oBACV,IACG,QAAQ,KAAK,SAAS;wBACtB,OAAA,IAAI,CAAC,WAAW,CAAC,WAAW,0CAAE,aAAa,MAAK,KAAK,EACtD;wBACC,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC;wBAC/B,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;4BAC5B,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;yBACxD;wBACD,MAAM,qBAAqB,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;wBAC3D,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;wBAC9B,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC;4BAC9B,SAAS,EAAE,IAAI,CAAC,cAAc;4BAC9B,WAAW,EAAE,qBAAqB;yBACpC,CAAC,CAAC;qBACL;gBACJ,CAAC,CACH,CAAC;aACJ;SACH;IACJ,CAAC;IAEO,iBAAiB;;QACtB,IAAI,OAAA,IAAI,CAAC,WAAW,CAAC,WAAW,0CAAE,aAAa,MAAK,KAAK,EAAE;YACxD,OAAO;SACT;QACD,IACG,IAAI,CAAC,aAAa,KAAK,SAAS;YAChC,IAAI,CAAC,aAAa,KAAK,SAAS;YAChC,IAAI,CAAC,MAAM,KAAK,SAAS,EAC1B;YACC,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;SACnD;QACD,MAAM,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;QACxD,MAAM,oBAAoB,GAAG,CAAC,GAAG,kBAAkB,CAAC,CAAC;QACrD,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC;YAC9B,SAAS,EAAE,IAAI,CAAC,aAAa;YAC7B,WAAW,EAAE,oBAAoB;SACnC,CAAC,CAAC;QACH,MAAM,oBAAoB,GAAG,CAAC,GAAG,kBAAkB,CAAC,CAAC;QACrD,oBAAoB,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC;QACxD,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC;YAC9B,SAAS,EAAE,IAAI,CAAC,aAAa;YAC7B,WAAW,EAAE,oBAAoB;SACnC,CAAC,CAAC;IACN,CAAC;IAEO,cAAc;;QACnB,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;YAClC,OAAO;SACT;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;QAChD,MAAM,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;QAC5D,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,QAAE,IAAI,CAAC,MAAM,0CAAE,IAAI,CAAC,EAAE;YACtE,OAAO,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;SAC7C;aAAM,IAAI,MAAM,KAAK,IAAI,EAAE;YACzB,OAAO,CAAC,YAAY,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;SAC5C;aAAM;YACJ,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,EAAE;gBACvC,OAAO,CAAC,YAAY,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;YAC7C,CAAC,CAAC,CAAC;YACH,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,GAAG,EAAE;gBACrC,OAAO,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAC9C,CAAC,CAAC,CAAC;SACL;IACJ,CAAC;;;YAnOH,SAAS,SAAC;gBACR,QAAQ,EAAE,kBAAkB;gBAC5B,wYAAgD;;aAElD;;;YAZQ,uBAAuB;YAP7B,iBAAiB;YAUX,WAAW;YAFX,eAAe;YAGf,WAAW;;;qBAUhB,KAAK;uBACL,SAAS,SAAC,UAAU,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;4BAGhD,SAAS,SAAC,eAAe,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;4BAErD,SAAS,SAAC,eAAe,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;uBAGrD,SAAS,SAAC,UAAU,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;2BAGhD,SAAS,SAAC,cAAc,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE","sourcesContent":["import {\r\n   AfterViewInit,\r\n   ChangeDetectorRef,\r\n   Component,\r\n   ElementRef,\r\n   Input,\r\n   ViewChild,\r\n   ViewContainerRef\r\n} from \"@angular/core\";\r\nimport { ComponentCreatorService } from \"../singletons/component-creator.service\";\r\nimport { DropZoneService } from \"../singletons/drop-zone.service\";\r\nimport { LimbleTreeBranchComponent } from \"../limble-tree-branch/limble-tree-branch.component\";\r\nimport { TempService } from \"../singletons/temp.service\";\r\nimport { TreeService } from \"../limble-tree-root/tree.service\";\r\nimport type { Branch } from \"../branch\";\r\nimport { isDraggingAllowed, isNestingAllowed } from \"../util\";\r\n\r\n@Component({\r\n   selector: \"limble-tree-node\",\r\n   templateUrl: \"./limble-tree-node.component.html\",\r\n   styleUrls: [\"./limble-tree-node.component.scss\"]\r\n})\r\nexport class LimbleTreeNodeComponent implements AfterViewInit {\r\n   @Input() branch: Branch<any> | undefined;\r\n   @ViewChild(\"nodeHost\", { read: ViewContainerRef }) private nodeHost:\r\n      | ViewContainerRef\r\n      | undefined;\r\n   @ViewChild(\"dropZoneAbove\", { read: ViewContainerRef })\r\n   private dropZoneAbove: ViewContainerRef | undefined;\r\n   @ViewChild(\"dropZoneBelow\", { read: ViewContainerRef })\r\n   private dropZoneBelow: ViewContainerRef | undefined;\r\n   private dropZoneInside: ViewContainerRef | undefined;\r\n   @ViewChild(\"children\", { read: ViewContainerRef }) private children:\r\n      | ViewContainerRef\r\n      | undefined;\r\n   @ViewChild(\"draggableDiv\", { read: ElementRef }) private draggableDiv:\r\n      | ElementRef<HTMLElement>\r\n      | undefined;\r\n\r\n   constructor(\r\n      private readonly componentCreatorService: ComponentCreatorService,\r\n      private readonly changeDetectorRef: ChangeDetectorRef,\r\n      private readonly tempService: TempService,\r\n      private readonly dropZoneService: DropZoneService,\r\n      private readonly treeService: TreeService\r\n   ) {}\r\n\r\n   ngAfterViewInit() {\r\n      this.registerDropZones();\r\n      this.renderSelf();\r\n      this.renderChildren();\r\n      this.checkForHandle();\r\n      this.changeDetectorRef.detectChanges();\r\n   }\r\n\r\n   public dragstartHandler(event: DragEvent): void {\r\n      event.stopPropagation();\r\n      if (event.dataTransfer === null || this.branch === undefined) {\r\n         return;\r\n      }\r\n      const draggedElement = event.target as HTMLElement;\r\n      if (draggedElement.parentElement?.tagName !== \"LIMBLE-TREE-NODE\") {\r\n         return;\r\n      }\r\n      event.dataTransfer.effectAllowed = \"move\";\r\n      draggedElement.classList.add(\"dragging\");\r\n      this.tempService.set(this.branch);\r\n   }\r\n\r\n   public dragendHandler(event: DragEvent): void {\r\n      event.stopPropagation();\r\n      const draggedElement = event.target as HTMLElement;\r\n      const sourceBranch = this.tempService.get();\r\n      if (sourceBranch === undefined) {\r\n         return;\r\n      }\r\n      this.tempService.delete();\r\n      draggedElement.classList.remove(\"dragging\");\r\n      const dropZoneInfo = this.dropZoneService.getActiveDropZoneInfo();\r\n      if (dropZoneInfo === null) {\r\n         return;\r\n      }\r\n      this.dropZoneService.removeActiveAndSecondaryZones();\r\n      if (dropZoneInfo.coordinates === undefined) {\r\n         throw new Error(\"could not determine drop zone location\");\r\n      }\r\n      this.treeService.move(sourceBranch, dropZoneInfo.coordinates);\r\n   }\r\n\r\n   public dragoverHandler(event: DragEvent) {\r\n      if (this.tempService.get() === undefined || this.branch === undefined) {\r\n         return;\r\n      }\r\n      const sourceBranch = this.tempService.get();\r\n      if (sourceBranch === undefined) {\r\n         return;\r\n      }\r\n      //If trying to drop on self, remove any remaining drop zones and return.\r\n      if (sourceBranch === this.branch) {\r\n         if (this.dropZoneService.getActiveDropZoneInfo() !== null) {\r\n            this.dropZoneService.removeActiveAndSecondaryZones();\r\n         }\r\n         return;\r\n      }\r\n      const target = event.currentTarget as HTMLElement;\r\n      const topLine = target.offsetHeight / 3; //an imaginary line 1/3 of the way down from the top of the element;\r\n      const bottomLine = topLine * 2; //an imaginary line 1/3 of the way up from the bottom of the element;\r\n      if (\r\n         event.offsetY < topLine &&\r\n         this.dropZoneAbove !== undefined &&\r\n         this.dropZoneService.getActiveDropZoneInfo()?.container !==\r\n            this.dropZoneAbove\r\n      ) {\r\n         const dropCoordinates = [...this.branch.getCoordinates()];\r\n         this.dropZoneService.showDropZoneFamily({\r\n            container: this.dropZoneAbove,\r\n            coordinates: dropCoordinates\r\n         });\r\n      } else if (\r\n         event.offsetY < bottomLine &&\r\n         this.dropZoneInside !== undefined &&\r\n         this.dropZoneService.getActiveDropZoneInfo()?.container !==\r\n            this.dropZoneInside\r\n      ) {\r\n         const dropCoordinates = [...this.branch.getCoordinates()];\r\n         dropCoordinates.push(0);\r\n         this.dropZoneService.showDropZoneFamily({\r\n            container: this.dropZoneInside,\r\n            coordinates: dropCoordinates\r\n         });\r\n      } else if (\r\n         event.offsetY >= bottomLine &&\r\n         this.dropZoneBelow !== undefined &&\r\n         this.dropZoneService.getActiveDropZoneInfo()?.container !==\r\n            this.dropZoneBelow &&\r\n         this.branch.getChildren().length === 0\r\n      ) {\r\n         const dropCoordinates = [...this.branch.getCoordinates()];\r\n         dropCoordinates[dropCoordinates.length - 1]++;\r\n         this.dropZoneService.showDropZoneFamily({\r\n            container: this.dropZoneBelow,\r\n            coordinates: dropCoordinates\r\n         });\r\n      }\r\n   }\r\n\r\n   private renderSelf() {\r\n      if (this.nodeHost === undefined || this.branch === undefined) {\r\n         throw new Error(\"Failed to render tree node\");\r\n      }\r\n      let component = this.branch.data.component;\r\n      if (component === undefined) {\r\n         component = this.treeService.treeOptions?.defaultComponent;\r\n      }\r\n      if (component === undefined) {\r\n         throw new Error(\"limbleTree requires a component to render\");\r\n      }\r\n      const componentRef = this.componentCreatorService.appendComponent<any>(\r\n         component.class,\r\n         this.nodeHost\r\n      );\r\n      componentRef.instance.nodeData = this.branch.data;\r\n      for (const binding in component.bindings) {\r\n         componentRef.instance[binding] = component.bindings[binding];\r\n      }\r\n   }\r\n\r\n   private renderChildren() {\r\n      if (this.children !== undefined) {\r\n         if (this.branch === undefined) {\r\n            throw new Error(\"branch is undefined\");\r\n         }\r\n         const newBranchComponent = this.componentCreatorService.appendComponent<LimbleTreeBranchComponent>(\r\n            LimbleTreeBranchComponent,\r\n            this.children\r\n         );\r\n         newBranchComponent.instance.branch = this.branch;\r\n         if (isNestingAllowed(this.treeService.treeOptions, this.branch.data)) {\r\n            newBranchComponent.instance.dropZoneInside$.subscribe(\r\n               (dropZone) => {\r\n                  if (\r\n                     dropZone !== undefined &&\r\n                     this.treeService.treeOptions?.allowDragging !== false\r\n                  ) {\r\n                     this.dropZoneInside = dropZone;\r\n                     if (this.branch === undefined) {\r\n                        throw new Error(\"failed to register inner drop zone\");\r\n                     }\r\n                     const dropCoordinatesInside = this.branch.getCoordinates();\r\n                     dropCoordinatesInside.push(0);\r\n                     this.dropZoneService.addDropZone({\r\n                        container: this.dropZoneInside,\r\n                        coordinates: dropCoordinatesInside\r\n                     });\r\n                  }\r\n               }\r\n            );\r\n         }\r\n      }\r\n   }\r\n\r\n   private registerDropZones() {\r\n      if (this.treeService.treeOptions?.allowDragging === false) {\r\n         return;\r\n      }\r\n      if (\r\n         this.dropZoneAbove === undefined ||\r\n         this.dropZoneBelow === undefined ||\r\n         this.branch === undefined\r\n      ) {\r\n         throw new Error(\"failed to register drop zones\");\r\n      }\r\n      const currentCoordinates = this.branch.getCoordinates();\r\n      const dropCoordinatesAbove = [...currentCoordinates];\r\n      this.dropZoneService.addDropZone({\r\n         container: this.dropZoneAbove,\r\n         coordinates: dropCoordinatesAbove\r\n      });\r\n      const dropCoordinatesBelow = [...currentCoordinates];\r\n      dropCoordinatesBelow[dropCoordinatesBelow.length - 1]++;\r\n      this.dropZoneService.addDropZone({\r\n         container: this.dropZoneBelow,\r\n         coordinates: dropCoordinatesBelow\r\n      });\r\n   }\r\n\r\n   private checkForHandle(): void {\r\n      if (this.draggableDiv === undefined) {\r\n         return;\r\n      }\r\n      const element = this.draggableDiv.nativeElement;\r\n      const handle = element.querySelector(\".limble-tree-handle\");\r\n      if (!isDraggingAllowed(this.treeService.treeOptions, this.branch?.data)) {\r\n         element.setAttribute(\"draggable\", \"false\");\r\n      } else if (handle === null) {\r\n         element.setAttribute(\"draggable\", \"true\");\r\n      } else {\r\n         handle.addEventListener(\"mousedown\", () => {\r\n            element.setAttribute(\"draggable\", \"true\");\r\n         });\r\n         handle.addEventListener(\"mouseup\", () => {\r\n            element.setAttribute(\"draggable\", \"false\");\r\n         });\r\n      }\r\n   }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"limble-tree-node.component.js","sourceRoot":"../../../projects/limble-tree/src/","sources":["lib/limble-tree-node/limble-tree-node.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n   AfterViewInit,\r\n   ChangeDetectorRef,\r\n   Component,\r\n   ElementRef,\r\n   Input,\r\n   ViewChild,\r\n   ViewContainerRef\r\n} from \"@angular/core\";\r\nimport { ComponentCreatorService } from \"../singletons/component-creator.service\";\r\nimport { DropZoneService } from \"../limble-tree-root/drop-zone.service\";\r\nimport { LimbleTreeBranchComponent } from \"../limble-tree-branch/limble-tree-branch.component\";\r\nimport { DragStateService } from \"../singletons/drag-state.service\";\r\nimport { LimbleTreeNode, TreeService } from \"../limble-tree-root/tree.service\";\r\nimport { Branch } from \"../branch\";\r\nimport { isDraggingAllowed, isNestingAllowed } from \"../util\";\r\nimport { take } from \"rxjs/operators\";\r\n\r\n@Component({\r\n   selector: \"limble-tree-node\",\r\n   templateUrl: \"./limble-tree-node.component.html\",\r\n   styleUrls: [\"./limble-tree-node.component.scss\"]\r\n})\r\nexport class LimbleTreeNodeComponent implements AfterViewInit {\r\n   @Input() branch: Branch<any> | undefined;\r\n   @ViewChild(\"nodeHost\", { read: ViewContainerRef }) private nodeHost:\r\n      | ViewContainerRef\r\n      | undefined;\r\n   @ViewChild(\"dropZoneAbove\", { read: ViewContainerRef })\r\n   private dropZoneAbove: ViewContainerRef | undefined;\r\n   @ViewChild(\"dropZoneBelow\", { read: ViewContainerRef })\r\n   private dropZoneBelow: ViewContainerRef | undefined;\r\n   private dropZoneInside: ViewContainerRef | undefined;\r\n   @ViewChild(\"children\", { read: ViewContainerRef }) private children:\r\n      | ViewContainerRef\r\n      | undefined;\r\n   @ViewChild(\"draggableDiv\", { read: ElementRef }) private draggableDiv:\r\n      | ElementRef<HTMLElement>\r\n      | undefined;\r\n\r\n   constructor(\r\n      private readonly componentCreatorService: ComponentCreatorService,\r\n      private readonly changeDetectorRef: ChangeDetectorRef,\r\n      private readonly dragStateService: DragStateService,\r\n      private readonly dropZoneService: DropZoneService,\r\n      private readonly treeService: TreeService\r\n   ) {}\r\n\r\n   ngAfterViewInit() {\r\n      this.registerDropZones();\r\n      this.renderSelf();\r\n      this.renderChildren();\r\n      this.checkForHandle();\r\n      this.changeDetectorRef.detectChanges();\r\n   }\r\n\r\n   public dragstartHandler(event: DragEvent): void {\r\n      event.stopPropagation();\r\n      if (event.dataTransfer === null || this.branch === undefined) {\r\n         throw new Error(\"failed to run dragstartHandler\");\r\n      }\r\n      const draggedElement = event.target as HTMLElement;\r\n      if (draggedElement.parentElement?.tagName !== \"LIMBLE-TREE-NODE\") {\r\n         //Don't drag stuff that isn't part of the tree\r\n         return;\r\n      }\r\n      event.dataTransfer.effectAllowed = \"move\";\r\n      draggedElement.classList.add(\"dragging\");\r\n      this.dragStateService.dragging(this.branch);\r\n   }\r\n\r\n   public dragendHandler(event: DragEvent): void {\r\n      event.stopPropagation();\r\n      const draggedElement = event.target as HTMLElement;\r\n      draggedElement.classList.remove(\"dragging\");\r\n      if (this.branch === undefined) {\r\n         throw new Error(\"failed to get current branch in dragendHandler\");\r\n      }\r\n      if (this.dragStateService.getState() !== \"captured\") {\r\n         return;\r\n      }\r\n      this.dragStateService.state$.pipe(take(2)).subscribe((state) => {\r\n         if (state === \"captured\" && this.branch !== undefined) {\r\n            this.treeService.remove(this.branch);\r\n            this.dragStateService.release();\r\n         }\r\n      });\r\n   }\r\n\r\n   public dragoverHandler(event: DragEvent) {\r\n      if (this.branch === undefined) {\r\n         throw new Error(\"Can't get current branch during dragover event\");\r\n      }\r\n      const sourceBranch = this.dragStateService.getData();\r\n      if (sourceBranch === undefined) {\r\n         throw new Error(\"Can't get source branch during dragover event\");\r\n      }\r\n      //If trying to drop on self, remove any existing drop zones and return.\r\n      if (\r\n         sourceBranch === this.branch ||\r\n         this.branch.getAncestors().includes(sourceBranch)\r\n      ) {\r\n         if (this.dropZoneService.getActiveDropZoneInfo() !== null) {\r\n            this.dropZoneService.removeActiveAndSecondaryZones();\r\n         }\r\n         return;\r\n      }\r\n      if (\r\n         this.treeService.getPlaceholder() === true &&\r\n         this.dropZoneAbove !== undefined\r\n      ) {\r\n         //If placeholder system is active, then activate the only existing drop zone\r\n         //and skip the rest of the logic in this function\r\n         const dropCoordinates = [...this.branch.getCoordinates()];\r\n         this.dropZoneService.showDropZoneFamily({\r\n            container: this.dropZoneAbove,\r\n            coordinates: dropCoordinates\r\n         });\r\n         return;\r\n      }\r\n      const target = event.currentTarget as HTMLElement;\r\n      const topLine = target.offsetHeight / 3; //an imaginary line 1/3 of the way down from the top of the element;\r\n      const bottomLine = topLine * 2; //an imaginary line 1/3 of the way up from the bottom of the element;\r\n      const parent = this.branch.getParent();\r\n      let parentData;\r\n      if (parent !== null) {\r\n         parentData = parent.data as LimbleTreeNode;\r\n      }\r\n      if (\r\n         event.offsetY < topLine &&\r\n         this.dropZoneAbove !== undefined &&\r\n         this.dropZoneService.getActiveDropZoneInfo()?.container !==\r\n            this.dropZoneAbove &&\r\n         isNestingAllowed(this.treeService.treeOptions, parentData)\r\n      ) {\r\n         const dropCoordinates = [...this.branch.getCoordinates()];\r\n         this.dropZoneService.showDropZoneFamily({\r\n            container: this.dropZoneAbove,\r\n            coordinates: dropCoordinates\r\n         });\r\n      } else if (\r\n         event.offsetY < bottomLine &&\r\n         this.dropZoneInside !== undefined &&\r\n         this.dropZoneService.getActiveDropZoneInfo()?.container !==\r\n            this.dropZoneInside\r\n      ) {\r\n         const dropCoordinates = [...this.branch.getCoordinates()];\r\n         dropCoordinates.push(0);\r\n         this.dropZoneService.showDropZoneFamily({\r\n            container: this.dropZoneInside,\r\n            coordinates: dropCoordinates\r\n         });\r\n      } else if (\r\n         event.offsetY >= bottomLine &&\r\n         this.dropZoneBelow !== undefined &&\r\n         this.dropZoneService.getActiveDropZoneInfo()?.container !==\r\n            this.dropZoneBelow &&\r\n         this.branch.getChildren().length === 0 &&\r\n         isNestingAllowed(this.treeService.treeOptions, parentData)\r\n      ) {\r\n         const dropCoordinates = [...this.branch.getCoordinates()];\r\n         dropCoordinates[dropCoordinates.length - 1]++;\r\n         this.dropZoneService.showDropZoneFamily({\r\n            container: this.dropZoneBelow,\r\n            coordinates: dropCoordinates\r\n         });\r\n      }\r\n   }\r\n\r\n   private renderSelf() {\r\n      if (this.nodeHost === undefined || this.branch === undefined) {\r\n         throw new Error(\"Failed to render tree node\");\r\n      }\r\n      let component = this.branch.data.component;\r\n      if (component === undefined) {\r\n         component = this.treeService.treeOptions?.defaultComponent;\r\n      }\r\n      if (component === undefined) {\r\n         throw new Error(\"limbleTree requires a component to render\");\r\n      }\r\n      const componentRef = this.componentCreatorService.appendComponent<any>(\r\n         component.class,\r\n         this.nodeHost\r\n      );\r\n      componentRef.instance.nodeData = this.branch.data;\r\n      for (const binding in component.bindings) {\r\n         componentRef.instance[binding] = component.bindings[binding];\r\n      }\r\n   }\r\n\r\n   private renderChildren() {\r\n      if (this.children !== undefined) {\r\n         if (this.branch === undefined) {\r\n            throw new Error(\"branch is undefined\");\r\n         }\r\n         const newBranchComponent = this.componentCreatorService.appendComponent<LimbleTreeBranchComponent>(\r\n            LimbleTreeBranchComponent,\r\n            this.children\r\n         );\r\n         newBranchComponent.instance.branch = this.branch;\r\n         if (\r\n            isNestingAllowed(this.treeService.treeOptions, this.branch.data) &&\r\n            !this.treeService.getPlaceholder() === true\r\n         ) {\r\n            newBranchComponent.instance.dropZoneInside$.subscribe(\r\n               (dropZone) => {\r\n                  if (\r\n                     dropZone !== undefined &&\r\n                     this.treeService.treeOptions?.allowDragging !== false\r\n                  ) {\r\n                     this.dropZoneInside = dropZone;\r\n                     if (this.branch === undefined) {\r\n                        throw new Error(\"failed to register inner drop zone\");\r\n                     }\r\n                     const dropCoordinatesInside = this.branch.getCoordinates();\r\n                     dropCoordinatesInside.push(0);\r\n                     this.dropZoneService.addDropZone({\r\n                        container: this.dropZoneInside,\r\n                        coordinates: dropCoordinatesInside\r\n                     });\r\n                  }\r\n               }\r\n            );\r\n         }\r\n      }\r\n   }\r\n\r\n   private registerDropZones() {\r\n      if (this.treeService.treeOptions?.allowDragging === false) {\r\n         return;\r\n      }\r\n      if (\r\n         this.dropZoneAbove === undefined ||\r\n         this.dropZoneBelow === undefined ||\r\n         this.branch === undefined\r\n      ) {\r\n         throw new Error(\"failed to register drop zones\");\r\n      }\r\n      const parent = this.branch.getParent();\r\n      let parentData;\r\n      if (parent !== null) {\r\n         parentData = parent.data as LimbleTreeNode;\r\n      }\r\n      if (!isNestingAllowed(this.treeService.treeOptions, parentData)) {\r\n         return;\r\n      }\r\n      const currentCoordinates = this.branch.getCoordinates();\r\n      const dropCoordinatesAbove = [...currentCoordinates];\r\n      this.dropZoneService.addDropZone({\r\n         container: this.dropZoneAbove,\r\n         coordinates: dropCoordinatesAbove\r\n      });\r\n      if (this.treeService.getPlaceholder() === true) {\r\n         //Only register one drop zone if the placeholder system is active\r\n         return;\r\n      }\r\n      const dropCoordinatesBelow = [...currentCoordinates];\r\n      dropCoordinatesBelow[dropCoordinatesBelow.length - 1]++;\r\n      this.dropZoneService.addDropZone({\r\n         container: this.dropZoneBelow,\r\n         coordinates: dropCoordinatesBelow\r\n      });\r\n   }\r\n\r\n   private checkForHandle(): void {\r\n      if (this.draggableDiv === undefined) {\r\n         return;\r\n      }\r\n      const element = this.draggableDiv.nativeElement;\r\n      const handle = element.querySelector(\".limble-tree-handle\");\r\n      if (!isDraggingAllowed(this.treeService.treeOptions, this.branch?.data)) {\r\n         element.setAttribute(\"draggable\", \"false\");\r\n      } else if (handle === null) {\r\n         element.setAttribute(\"draggable\", \"true\");\r\n      } else {\r\n         handle.addEventListener(\"mousedown\", () => {\r\n            element.setAttribute(\"draggable\", \"true\");\r\n         });\r\n         handle.addEventListener(\"mouseup\", () => {\r\n            element.setAttribute(\"draggable\", \"false\");\r\n         });\r\n      }\r\n   }\r\n}\r\n"]}
import { ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewContainerRef } from "@angular/core";
import { BehaviorSubject } from "rxjs";
import { DropZoneService } from "../singletons/drop-zone.service";
import { DropZoneService } from "./drop-zone.service";
import { TreeService } from "./tree.service";
import { isElementDescendant } from "../util";
import { DragStateService } from "../singletons/drag-state.service";
export class LimbleTreeRootComponent {
constructor(treeService, changeDetectorRef, dropZoneService) {
constructor(treeService, changeDetectorRef, dropZoneService, dragStateService) {
this.treeService = treeService;
this.changeDetectorRef = changeDetectorRef;
this.dropZoneService = dropZoneService;
this.dragStateService = dragStateService;
this.treeChange = new EventEmitter();

@@ -59,4 +61,21 @@ this.treeDrop = new EventEmitter();

}
dropHandler(event) {
event.stopPropagation();
const dropZoneInfo = this.dropZoneService.getActiveDropZoneInfo();
if (this.dragStateService.getState() !== "droppable") {
return;
}
if (dropZoneInfo === null) {
throw new Error("failed to get active drop zone at drop handler");
}
const sourceBranch = this.dragStateService.capture();
if (sourceBranch === undefined) {
throw new Error("failed to get current branch in dragendHandler");
}
this.dropZoneService.removeActiveAndSecondaryZones();
this.treeService.drop(sourceBranch, dropZoneInfo.coordinates);
}
ngOnDestroy() {
this.changesSubscription.unsubscribe();
this.dropSubscription.unsubscribe();
}

@@ -67,4 +86,4 @@ }

selector: "limble-tree-root",
template: "<div\r\n (dragover)=\"dragoverHandler($event)\"\r\n (dragleave)=\"dragleaveHandler($event)\"\r\n>\r\n <ng-template #dropZoneInside></ng-template>\r\n <ng-template #host></ng-template>\r\n</div>\r\n",
providers: [TreeService],
template: "<div\r\n (dragover)=\"dragoverHandler($event)\"\r\n (dragleave)=\"dragleaveHandler($event)\"\r\n (drop)=\"dropHandler($event)\"\r\n>\r\n <ng-template #dropZoneInside></ng-template>\r\n <ng-template #host></ng-template>\r\n</div>\r\n",
providers: [TreeService, DropZoneService],
styles: [""]

@@ -76,3 +95,4 @@ },] }

{ type: ChangeDetectorRef },
{ type: DropZoneService }
{ type: DropZoneService },
{ type: DragStateService }
];

@@ -88,2 +108,2 @@ LimbleTreeRootComponent.propDecorators = {

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"limble-tree-root.component.js","sourceRoot":"../../../projects/limble-tree/src/","sources":["lib/limble-tree-root/limble-tree-root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n   AfterViewInit,\r\n   ChangeDetectorRef,\r\n   Component,\r\n   EventEmitter,\r\n   Input,\r\n   OnChanges,\r\n   OnDestroy,\r\n   Output,\r\n   ViewChild,\r\n   ViewContainerRef\r\n} from \"@angular/core\";\r\nimport { BehaviorSubject, Subscription } from \"rxjs\";\r\nimport { DropZoneService } from \"../singletons/drop-zone.service\";\r\nimport {\r\n   LimbleTreeData,\r\n   LimbleTreeOptions,\r\n   TreeDrop\r\n} from \"../limble-tree-root/tree.service\";\r\nimport { TreeService } from \"./tree.service\";\r\nimport { isElementDescendant } from \"../util\";\r\n\r\n@Component({\r\n   selector: \"limble-tree-root\",\r\n   templateUrl: \"./limble-tree-root.component.html\",\r\n   styleUrls: [\"./limble-tree-root.component.scss\"],\r\n   providers: [TreeService]\r\n})\r\nexport class LimbleTreeRootComponent\r\n   implements AfterViewInit, OnChanges, OnDestroy {\r\n   @Input() data: LimbleTreeData | undefined;\r\n   @Input() options: LimbleTreeOptions | undefined;\r\n\r\n   @ViewChild(\"host\", { read: ViewContainerRef }) private host:\r\n      | ViewContainerRef\r\n      | undefined;\r\n\r\n   @ViewChild(\"dropZoneInside\", { read: ViewContainerRef })\r\n   dropZoneInside: ViewContainerRef | undefined;\r\n\r\n   @Output()\r\n   readonly dropZoneInside$: BehaviorSubject<ViewContainerRef | undefined>;\r\n\r\n   @Output() readonly treeChange = new EventEmitter<null>();\r\n\r\n   @Output() readonly treeDrop = new EventEmitter<TreeDrop>();\r\n\r\n   private readonly changesSubscription: Subscription;\r\n   private readonly dropSubscription: Subscription;\r\n\r\n   constructor(\r\n      private readonly treeService: TreeService,\r\n      private readonly changeDetectorRef: ChangeDetectorRef,\r\n      private readonly dropZoneService: DropZoneService\r\n   ) {\r\n      this.dropZoneInside$ = new BehaviorSubject(this.dropZoneInside);\r\n      this.changesSubscription = this.treeService.changes$.subscribe(() => {\r\n         this.treeChange.emit();\r\n      });\r\n      this.dropSubscription = this.treeService.drops$.subscribe((drop) => {\r\n         this.treeDrop.emit(drop);\r\n      });\r\n   }\r\n\r\n   ngAfterViewInit() {\r\n      this.dropZoneInside$.next(this.dropZoneInside);\r\n      this.dropZoneInside$.complete();\r\n      this.update();\r\n      this.changeDetectorRef.detectChanges();\r\n   }\r\n\r\n   ngOnChanges() {\r\n      if (this.host !== undefined && this.data !== undefined) {\r\n         this.update();\r\n      }\r\n   }\r\n\r\n   public update() {\r\n      if (this.host === undefined) {\r\n         throw new Error(\r\n            \"Failed to render limble tree. Failure occurred at root.\"\r\n         );\r\n      }\r\n      if (this.data === undefined) {\r\n         throw new Error(`limbleTree requires a data object`);\r\n      }\r\n      this.treeService.init(this.host, this.data, this.options);\r\n   }\r\n\r\n   public dragoverHandler(event: DragEvent) {\r\n      if (event.dataTransfer === null) {\r\n         return;\r\n      }\r\n      event.stopPropagation();\r\n      event.preventDefault();\r\n      event.dataTransfer.dropEffect = \"move\";\r\n   }\r\n\r\n   public dragleaveHandler(event: DragEvent) {\r\n      const currentTarget = event.currentTarget;\r\n      const relatedTarget = event.relatedTarget;\r\n      if (\r\n         !(currentTarget instanceof Node) ||\r\n         !(relatedTarget instanceof Node) ||\r\n         isElementDescendant(currentTarget, relatedTarget) !== false\r\n      ) {\r\n         return;\r\n      }\r\n      this.dropZoneService.removeActiveAndSecondaryZones();\r\n   }\r\n\r\n   ngOnDestroy() {\r\n      this.changesSubscription.unsubscribe();\r\n   }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"limble-tree-root.component.js","sourceRoot":"../../../projects/limble-tree/src/","sources":["lib/limble-tree-root/limble-tree-root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n   AfterViewInit,\r\n   ChangeDetectorRef,\r\n   Component,\r\n   EventEmitter,\r\n   Input,\r\n   OnChanges,\r\n   OnDestroy,\r\n   Output,\r\n   ViewChild,\r\n   ViewContainerRef\r\n} from \"@angular/core\";\r\nimport { BehaviorSubject, Subscription } from \"rxjs\";\r\nimport { DropZoneService } from \"./drop-zone.service\";\r\nimport {\r\n   LimbleTreeData,\r\n   LimbleTreeOptions,\r\n   TreeDrop\r\n} from \"../limble-tree-root/tree.service\";\r\nimport { TreeService } from \"./tree.service\";\r\nimport { isElementDescendant } from \"../util\";\r\nimport { DragStateService } from \"../singletons/drag-state.service\";\r\n\r\n@Component({\r\n   selector: \"limble-tree-root\",\r\n   templateUrl: \"./limble-tree-root.component.html\",\r\n   styleUrls: [\"./limble-tree-root.component.scss\"],\r\n   providers: [TreeService, DropZoneService]\r\n})\r\nexport class LimbleTreeRootComponent\r\n   implements AfterViewInit, OnChanges, OnDestroy {\r\n   @Input() data: LimbleTreeData | undefined;\r\n   @Input() options: LimbleTreeOptions | undefined;\r\n\r\n   @ViewChild(\"host\", { read: ViewContainerRef }) private host:\r\n      | ViewContainerRef\r\n      | undefined;\r\n\r\n   @ViewChild(\"dropZoneInside\", { read: ViewContainerRef })\r\n   dropZoneInside: ViewContainerRef | undefined;\r\n\r\n   @Output()\r\n   readonly dropZoneInside$: BehaviorSubject<ViewContainerRef | undefined>;\r\n\r\n   @Output() readonly treeChange = new EventEmitter<null>();\r\n\r\n   @Output() readonly treeDrop = new EventEmitter<TreeDrop>();\r\n\r\n   private readonly changesSubscription: Subscription;\r\n   private readonly dropSubscription: Subscription;\r\n\r\n   constructor(\r\n      private readonly treeService: TreeService,\r\n      private readonly changeDetectorRef: ChangeDetectorRef,\r\n      private readonly dropZoneService: DropZoneService,\r\n      private readonly dragStateService: DragStateService\r\n   ) {\r\n      this.dropZoneInside$ = new BehaviorSubject(this.dropZoneInside);\r\n      this.changesSubscription = this.treeService.changes$.subscribe(() => {\r\n         this.treeChange.emit();\r\n      });\r\n      this.dropSubscription = this.treeService.drops$.subscribe((drop) => {\r\n         this.treeDrop.emit(drop);\r\n      });\r\n   }\r\n\r\n   ngAfterViewInit() {\r\n      this.dropZoneInside$.next(this.dropZoneInside);\r\n      this.dropZoneInside$.complete();\r\n      this.update();\r\n      this.changeDetectorRef.detectChanges();\r\n   }\r\n\r\n   ngOnChanges() {\r\n      if (this.host !== undefined && this.data !== undefined) {\r\n         this.update();\r\n      }\r\n   }\r\n\r\n   public update() {\r\n      if (this.host === undefined) {\r\n         throw new Error(\r\n            \"Failed to render limble tree. Failure occurred at root.\"\r\n         );\r\n      }\r\n      if (this.data === undefined) {\r\n         throw new Error(`limbleTree requires a data object`);\r\n      }\r\n      this.treeService.init(this.host, this.data, this.options);\r\n   }\r\n\r\n   public dragoverHandler(event: DragEvent) {\r\n      if (event.dataTransfer === null) {\r\n         return;\r\n      }\r\n      event.stopPropagation();\r\n      event.preventDefault();\r\n      event.dataTransfer.dropEffect = \"move\";\r\n   }\r\n\r\n   public dragleaveHandler(event: DragEvent) {\r\n      const currentTarget = event.currentTarget;\r\n      const relatedTarget = event.relatedTarget;\r\n      if (\r\n         !(currentTarget instanceof Node) ||\r\n         !(relatedTarget instanceof Node) ||\r\n         isElementDescendant(currentTarget, relatedTarget) !== false\r\n      ) {\r\n         return;\r\n      }\r\n      this.dropZoneService.removeActiveAndSecondaryZones();\r\n   }\r\n\r\n   public dropHandler(event: DragEvent) {\r\n      event.stopPropagation();\r\n      const dropZoneInfo = this.dropZoneService.getActiveDropZoneInfo();\r\n      if (this.dragStateService.getState() !== \"droppable\") {\r\n         return;\r\n      }\r\n      if (dropZoneInfo === null) {\r\n         throw new Error(\"failed to get active drop zone at drop handler\");\r\n      }\r\n      const sourceBranch = this.dragStateService.capture();\r\n      if (sourceBranch === undefined) {\r\n         throw new Error(\"failed to get current branch in dragendHandler\");\r\n      }\r\n      this.dropZoneService.removeActiveAndSecondaryZones();\r\n      this.treeService.drop(sourceBranch, dropZoneInfo.coordinates);\r\n   }\r\n\r\n   ngOnDestroy() {\r\n      this.changesSubscription.unsubscribe();\r\n      this.dropSubscription.unsubscribe();\r\n   }\r\n}\r\n"]}
import { Injectable } from "@angular/core";
import { ReplaySubject } from "rxjs";
import { ComponentCreatorService } from "../singletons/component-creator.service";
import { DropZoneService } from "../singletons/drop-zone.service";
import { DropZoneService } from "./drop-zone.service";
import { Branch } from "../branch";
import { LimbleTreeNodeComponent } from "../limble-tree-node/limble-tree-node.component";
import { LimbleTreePlaceholderComponent } from "../limble-tree-placeholder/limble-tree-placeholder.component";
/** The default value for the `indent` option */

@@ -16,2 +17,3 @@ export const INDENT = 45;

this.treeModel = new Branch(null);
this.placeholder = false;
}

@@ -41,12 +43,25 @@ /** Initializes the service and renders the tree.

this.dropZoneService.init(this.treeData, this.treeOptions);
for (const node of this.treeData) {
const branch = new Branch(node);
if (this.treeData.length === 0) {
//Tree is empty, but we have to to have something there so other trees' items can be dropped into it
this.placeholder = true;
const placeholderNode = {
component: { class: LimbleTreePlaceholderComponent }
};
const branch = new Branch(placeholderNode);
this.treeModel.appendChild(branch);
}
for (const branch of this.treeModel.getChildren()) {
const componentRef = this.componentCreatorService.appendComponent(LimbleTreeNodeComponent, this.host);
componentRef.instance.branch = branch;
//The LimbleTreeNodeComponent will (indirectly) call the `renderBranch` method of this service to render
//its own children
}
else {
for (const node of this.treeData) {
const branch = new Branch(node);
this.treeModel.appendChild(branch);
}
for (const branch of this.treeModel.getChildren()) {
const componentRef = this.componentCreatorService.appendComponent(LimbleTreeNodeComponent, this.host);
componentRef.instance.branch = branch;
//The LimbleTreeNodeComponent will (indirectly) call the `renderBranch` method of this service to render
//its own children
}
}
this.changes$.next(null);

@@ -79,3 +94,3 @@ }

}
move(source, targetCoordinates) {
drop(source, targetCoordinates) {
const sourceParent = source.getParent();

@@ -86,4 +101,14 @@ const sourceIndex = source.getIndex();

}
const targetParentCoordinates = [...targetCoordinates];
const index = targetParentCoordinates.pop();
let targetParentCoordinates;
let index;
if (this.placeholder === true) {
targetParentCoordinates = [];
index = 0;
this.treeModel.removeChild(0); //remove the placeholder
this.placeholder = false;
}
else {
targetParentCoordinates = [...targetCoordinates];
index = targetParentCoordinates.pop();
}
if (index === undefined) {

@@ -98,3 +123,2 @@ throw new Error("target coordinates are empty");

this.rebuildTreeData();
console.log(sourceParent);
this.drops$.next({

@@ -109,2 +133,7 @@ target: source.data,

}
remove(target) {
target.remove();
this.rebuildTreeData();
this.render();
}
rebuildTreeData() {

@@ -127,2 +156,5 @@ if (this.treeData == undefined) {

}
getPlaceholder() {
return this.placeholder;
}
}

@@ -136,2 +168,2 @@ TreeService.decorators = [

];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.service.js","sourceRoot":"../../../projects/limble-tree/src/","sources":["lib/limble-tree-root/tree.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Type, ViewContainerRef } from \"@angular/core\";\r\nimport { ReplaySubject } from \"rxjs\";\r\nimport { ComponentCreatorService } from \"../singletons/component-creator.service\";\r\nimport { DropZoneService } from \"../singletons/drop-zone.service\";\r\nimport { Branch, BranchCoordinates } from \"../branch\";\r\nimport { LimbleTreeNodeComponent } from \"../limble-tree-node/limble-tree-node.component\";\r\n\r\n/** An object describing a node of the tree */\r\nexport interface LimbleTreeNode {\r\n   /** A list of nodes to be rendered \"under\" this one, one level deeper in the tree. */\r\n   nodes?: LimbleTreeData;\r\n   // /** A custom data object that will be passed into the component as an `Input()` binding called `nodeData` */\r\n   // data: unknown;\r\n   /** An object that describes the component which will represent this node in the visual tree */\r\n   component?: ComponentObj;\r\n   collapsed?: boolean;\r\n   [index: string]: unknown;\r\n}\r\n\r\n/** An object that the limble-tree-root component uses to build the tree */\r\nexport type LimbleTreeData = Array<LimbleTreeNode>;\r\n\r\n/** A group of settings for changing the functionality of the tree */\r\nexport interface LimbleTreeOptions {\r\n   /** The component object to use if one is not specified for a particular node */\r\n   defaultComponent?: ComponentObj;\r\n   /** The number of pixels to indent each level of the tree. Defaults to 45 */\r\n   indent?: number;\r\n   /** Whether to allow \"nesting\" (placing a node one level deeper than currently exists on the branch)\r\n    * when dragging a node. Defaults to true.\r\n    */\r\n   allowNesting?: boolean | ((nodeData: LimbleTreeNode) => boolean);\r\n   /** Whether to allow drag-and-drop functionality. Defaults to true.*/\r\n   allowDragging?: boolean | ((nodeData: LimbleTreeNode) => boolean);\r\n}\r\n\r\n/** An object that references the component to be rendered and its bindings */\r\nexport interface ComponentObj {\r\n   /** The component class */\r\n   class: Type<unknown>;\r\n   /** The bindings (inputs and outputs) of the class */\r\n   bindings?: {\r\n      [index: string]: unknown;\r\n   };\r\n}\r\n\r\n/** The default value for the `indent` option */\r\nexport const INDENT = 45;\r\n\r\n/** An options object with default values loaded where applicable */\r\nexport interface ProcessedOptions extends LimbleTreeOptions {\r\n   defaultComponent?: ComponentObj;\r\n   indent: number;\r\n   allowNesting: boolean | ((nodeData: LimbleTreeNode) => boolean);\r\n   allowDragging: boolean | ((nodeData: LimbleTreeNode) => boolean);\r\n}\r\n\r\n/** the value emitted from the root component after a node is dropped */\r\nexport interface TreeDrop {\r\n   /** The node that was dropped */\r\n   target: LimbleTreeNode;\r\n   /** the target's parent before the drag and drop, or null if it was a top-level node */\r\n   oldParent: LimbleTreeNode | null;\r\n   /** the index of the node before the drag and drop relative to its old siblings */\r\n   oldIndex: number;\r\n   /** the target's parent after the drag and drop, or null if it is now a top-level node */\r\n   newParent: LimbleTreeNode | null;\r\n   /** the index of the node after the drag and drop relative to its new siblings */\r\n   newIndex: number;\r\n}\r\n\r\n@Injectable()\r\nexport class TreeService {\r\n   public changes$: ReplaySubject<null>;\r\n   public drops$: ReplaySubject<TreeDrop>;\r\n   private host: ViewContainerRef | undefined;\r\n   public treeData: LimbleTreeData | undefined;\r\n   public treeOptions: ProcessedOptions | undefined;\r\n   public treeModel: Branch<any>;\r\n\r\n   constructor(\r\n      private readonly componentCreatorService: ComponentCreatorService,\r\n      private readonly dropZoneService: DropZoneService\r\n   ) {\r\n      this.changes$ = new ReplaySubject(1);\r\n      this.drops$ = new ReplaySubject(1);\r\n      this.treeModel = new Branch(null);\r\n   }\r\n\r\n   /** Initializes the service and renders the tree.\r\n    * @param host - The ViewContainerRef into which the tree will be rendered.\r\n    * @param data - The data array that was passed in to LimbleTreeRoot, which is\r\n    * the users' representation of the tree\r\n    * @param options - The options object that was passed in to LimbleTreeRoot\r\n    */\r\n   public init(\r\n      host: ViewContainerRef,\r\n      data: LimbleTreeData,\r\n      options?: LimbleTreeOptions\r\n   ): void {\r\n      this.host = host;\r\n      this.treeData = data;\r\n      this.treeOptions = this.processOptions(options);\r\n      this.render();\r\n   }\r\n\r\n   /** Renders the entire tree from root to leaves */\r\n   private render() {\r\n      if (\r\n         this.host === undefined ||\r\n         this.treeData === undefined ||\r\n         this.treeOptions === undefined\r\n      ) {\r\n         throw new Error(\"TreeModel not initialized\");\r\n      }\r\n      this.host.clear();\r\n      this.treeModel = new Branch(null);\r\n      this.dropZoneService.clearDropZones();\r\n      this.dropZoneService.init(this.treeData, this.treeOptions);\r\n      for (const node of this.treeData) {\r\n         const branch = new Branch(node);\r\n         this.treeModel.appendChild(branch);\r\n      }\r\n      for (const branch of this.treeModel.getChildren()) {\r\n         const componentRef = this.componentCreatorService.appendComponent<LimbleTreeNodeComponent>(\r\n            LimbleTreeNodeComponent,\r\n            this.host\r\n         );\r\n         componentRef.instance.branch = branch;\r\n         //The LimbleTreeNodeComponent will (indirectly) call the `renderBranch` method of this service to render\r\n         //its own children\r\n      }\r\n      this.changes$.next(null);\r\n   }\r\n\r\n   /** Renders a branch of the tree and all of its descendants */\r\n   public renderBranch(host: ViewContainerRef, branch: Branch<any>) {\r\n      if (this.treeModel === undefined) {\r\n         throw new Error(\"TreeModel not initialized\");\r\n      }\r\n      host.clear();\r\n      for (const node of branch.data.nodes ?? []) {\r\n         const newBranch = new Branch(node);\r\n         branch.appendChild(newBranch);\r\n         const componentRef = this.componentCreatorService.appendComponent<LimbleTreeNodeComponent>(\r\n            LimbleTreeNodeComponent,\r\n            host\r\n         );\r\n         componentRef.instance.branch = newBranch;\r\n         //The LimbleTreeNodeComponent will (indirectly) call the `renderBranch` method of this service to render\r\n         //its own children\r\n      }\r\n   }\r\n\r\n   private processOptions(options: LimbleTreeOptions = {}): ProcessedOptions {\r\n      return {\r\n         defaultComponent: options.defaultComponent,\r\n         indent: options.indent ?? INDENT,\r\n         allowNesting: options.allowNesting ?? true,\r\n         allowDragging: options.allowDragging ?? true\r\n      };\r\n   }\r\n\r\n   public move(source: Branch<any>, targetCoordinates: BranchCoordinates) {\r\n      const sourceParent = source.getParent();\r\n      const sourceIndex = source.getIndex();\r\n      if (sourceIndex === undefined) {\r\n         throw new Error(\"Cannot move the hidden root node\");\r\n      }\r\n      const targetParentCoordinates = [...targetCoordinates];\r\n      const index = targetParentCoordinates.pop();\r\n      if (index === undefined) {\r\n         throw new Error(\"target coordinates are empty\");\r\n      }\r\n      const targetParent = this.treeModel.getDescendant(\r\n         targetParentCoordinates\r\n      );\r\n      if (targetParent === undefined) {\r\n         throw new Error(\"could not get to target\");\r\n      }\r\n      targetParent.insertChild(source, index);\r\n      this.rebuildTreeData();\r\n      console.log(sourceParent);\r\n      this.drops$.next({\r\n         target: source.data,\r\n         oldParent: sourceParent?.data as LimbleTreeNode,\r\n         oldIndex: sourceIndex,\r\n         newParent: targetParent.data,\r\n         newIndex: index\r\n      });\r\n      this.render();\r\n   }\r\n\r\n   private rebuildTreeData(): void {\r\n      if (this.treeData == undefined) {\r\n         throw new Error(\"Tree data not initialized\");\r\n      }\r\n      this.treeData.length = 0;\r\n      for (const branch of this.treeModel.getChildren()) {\r\n         this.treeData.push(this.rebuildBranch(branch));\r\n      }\r\n   }\r\n\r\n   private rebuildBranch(branch: Branch<any>): LimbleTreeNode {\r\n      const temp: LimbleTreeNode = branch.data;\r\n      temp.nodes = [];\r\n      for (const child of branch.getChildren()) {\r\n         temp.nodes.push(this.rebuildBranch(child));\r\n      }\r\n      return temp;\r\n   }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.service.js","sourceRoot":"../../../projects/limble-tree/src/","sources":["lib/limble-tree-root/tree.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Type, ViewContainerRef } from \"@angular/core\";\r\nimport { ReplaySubject } from \"rxjs\";\r\nimport { ComponentCreatorService } from \"../singletons/component-creator.service\";\r\nimport { DropZoneService } from \"./drop-zone.service\";\r\nimport { Branch, BranchCoordinates } from \"../branch\";\r\nimport { LimbleTreeNodeComponent } from \"../limble-tree-node/limble-tree-node.component\";\r\nimport { LimbleTreePlaceholderComponent } from \"../limble-tree-placeholder/limble-tree-placeholder.component\";\r\n\r\n/** An object describing a node of the tree */\r\nexport interface LimbleTreeNode {\r\n   /** A list of nodes to be rendered \"under\" this one, one level deeper in the tree. */\r\n   nodes?: LimbleTreeData;\r\n   // /** A custom data object that will be passed into the component as an `Input()` binding called `nodeData` */\r\n   // data: unknown;\r\n   /** An object that describes the component which will represent this node in the visual tree */\r\n   component?: ComponentObj;\r\n   collapsed?: boolean;\r\n   [index: string]: unknown;\r\n}\r\n\r\n/** An object that the limble-tree-root component uses to build the tree */\r\nexport type LimbleTreeData = Array<LimbleTreeNode>;\r\n\r\n/** A group of settings for changing the functionality of the tree */\r\nexport interface LimbleTreeOptions {\r\n   /** The component object to use if one is not specified for a particular node */\r\n   defaultComponent?: ComponentObj;\r\n   /** The number of pixels to indent each level of the tree. Defaults to 45 */\r\n   indent?: number;\r\n   /**\r\n    * Whether to allow \"nesting\" (placing a node one level deeper than currently exists on the branch)\r\n    * when dragging a node. Defaults to true.\r\n    */\r\n   allowNesting?: boolean | ((nodeData: LimbleTreeNode) => boolean);\r\n   /** Whether to allow drag-and-drop functionality. Defaults to true. */\r\n   allowDragging?: boolean | ((nodeData: LimbleTreeNode) => boolean);\r\n}\r\n\r\n/** An object that references the component to be rendered and its bindings */\r\nexport interface ComponentObj {\r\n   /** The component class */\r\n   class: Type<unknown>;\r\n   /** The bindings (inputs and outputs) of the class */\r\n   bindings?: {\r\n      [index: string]: unknown;\r\n   };\r\n}\r\n\r\n/** The default value for the `indent` option */\r\nexport const INDENT = 45;\r\n\r\n/** An options object with default values loaded where applicable */\r\nexport interface ProcessedOptions extends LimbleTreeOptions {\r\n   defaultComponent?: ComponentObj;\r\n   indent: number;\r\n   allowNesting: boolean | ((nodeData: LimbleTreeNode) => boolean);\r\n   allowDragging: boolean | ((nodeData: LimbleTreeNode) => boolean);\r\n}\r\n\r\n/** the value emitted from the root component after a node is dropped */\r\nexport interface TreeDrop {\r\n   /** The node that was dropped */\r\n   target: LimbleTreeNode;\r\n   /** the target's parent before the drag and drop, or null if it was a top-level node */\r\n   oldParent: LimbleTreeNode | null;\r\n   /** the index of the node before the drag and drop relative to its old siblings */\r\n   oldIndex: number;\r\n   /** the target's parent after the drag and drop, or null if it is now a top-level node */\r\n   newParent: LimbleTreeNode | null;\r\n   /** the index of the node after the drag and drop relative to its new siblings */\r\n   newIndex: number;\r\n}\r\n\r\n@Injectable()\r\nexport class TreeService {\r\n   public changes$: ReplaySubject<null>;\r\n   public drops$: ReplaySubject<TreeDrop>;\r\n   private host: ViewContainerRef | undefined;\r\n   public treeData: LimbleTreeData | undefined;\r\n   public treeOptions: ProcessedOptions | undefined;\r\n   public treeModel: Branch<any>;\r\n   private placeholder: boolean;\r\n\r\n   constructor(\r\n      private readonly componentCreatorService: ComponentCreatorService,\r\n      private readonly dropZoneService: DropZoneService\r\n   ) {\r\n      this.changes$ = new ReplaySubject(1);\r\n      this.drops$ = new ReplaySubject(1);\r\n      this.treeModel = new Branch(null);\r\n      this.placeholder = false;\r\n   }\r\n\r\n   /** Initializes the service and renders the tree.\r\n    * @param host - The ViewContainerRef into which the tree will be rendered.\r\n    * @param data - The data array that was passed in to LimbleTreeRoot, which is\r\n    * the users' representation of the tree\r\n    * @param options - The options object that was passed in to LimbleTreeRoot\r\n    */\r\n   public init(\r\n      host: ViewContainerRef,\r\n      data: LimbleTreeData,\r\n      options?: LimbleTreeOptions\r\n   ): void {\r\n      this.host = host;\r\n      this.treeData = data;\r\n      this.treeOptions = this.processOptions(options);\r\n      this.render();\r\n   }\r\n\r\n   /** Renders the entire tree from root to leaves */\r\n   private render() {\r\n      if (\r\n         this.host === undefined ||\r\n         this.treeData === undefined ||\r\n         this.treeOptions === undefined\r\n      ) {\r\n         throw new Error(\"TreeModel not initialized\");\r\n      }\r\n      this.host.clear();\r\n      this.treeModel = new Branch(null);\r\n      this.dropZoneService.clearDropZones();\r\n      this.dropZoneService.init(this.treeData, this.treeOptions);\r\n      if (this.treeData.length === 0) {\r\n         //Tree is empty, but we have to to have something there so other trees' items can be dropped into it\r\n         this.placeholder = true;\r\n         const placeholderNode: LimbleTreeNode = {\r\n            component: { class: LimbleTreePlaceholderComponent }\r\n         };\r\n         const branch = new Branch(placeholderNode);\r\n         this.treeModel.appendChild(branch);\r\n         const componentRef = this.componentCreatorService.appendComponent<LimbleTreeNodeComponent>(\r\n            LimbleTreeNodeComponent,\r\n            this.host\r\n         );\r\n         componentRef.instance.branch = branch;\r\n      } else {\r\n         for (const node of this.treeData) {\r\n            const branch = new Branch(node);\r\n            this.treeModel.appendChild(branch);\r\n         }\r\n         for (const branch of this.treeModel.getChildren()) {\r\n            const componentRef = this.componentCreatorService.appendComponent<LimbleTreeNodeComponent>(\r\n               LimbleTreeNodeComponent,\r\n               this.host\r\n            );\r\n            componentRef.instance.branch = branch;\r\n            //The LimbleTreeNodeComponent will (indirectly) call the `renderBranch` method of this service to render\r\n            //its own children\r\n         }\r\n      }\r\n      this.changes$.next(null);\r\n   }\r\n\r\n   /** Renders a branch of the tree and all of its descendants */\r\n   public renderBranch(host: ViewContainerRef, branch: Branch<any>) {\r\n      if (this.treeModel === undefined) {\r\n         throw new Error(\"TreeModel not initialized\");\r\n      }\r\n      host.clear();\r\n      for (const node of branch.data.nodes ?? []) {\r\n         const newBranch = new Branch(node);\r\n         branch.appendChild(newBranch);\r\n         const componentRef = this.componentCreatorService.appendComponent<LimbleTreeNodeComponent>(\r\n            LimbleTreeNodeComponent,\r\n            host\r\n         );\r\n         componentRef.instance.branch = newBranch;\r\n         //The LimbleTreeNodeComponent will (indirectly) call the `renderBranch` method of this service to render\r\n         //its own children\r\n      }\r\n   }\r\n\r\n   private processOptions(options: LimbleTreeOptions = {}): ProcessedOptions {\r\n      return {\r\n         defaultComponent: options.defaultComponent,\r\n         indent: options.indent ?? INDENT,\r\n         allowNesting: options.allowNesting ?? true,\r\n         allowDragging: options.allowDragging ?? true\r\n      };\r\n   }\r\n\r\n   public drop(source: Branch<any>, targetCoordinates: BranchCoordinates) {\r\n      const sourceParent = source.getParent();\r\n      const sourceIndex = source.getIndex();\r\n      if (sourceIndex === undefined) {\r\n         throw new Error(\"Cannot move the hidden root node\");\r\n      }\r\n      let targetParentCoordinates: BranchCoordinates;\r\n      let index: number | undefined;\r\n      if (this.placeholder === true) {\r\n         targetParentCoordinates = [];\r\n         index = 0;\r\n         this.treeModel.removeChild(0); //remove the placeholder\r\n         this.placeholder = false;\r\n      } else {\r\n         targetParentCoordinates = [...targetCoordinates];\r\n         index = targetParentCoordinates.pop();\r\n      }\r\n      if (index === undefined) {\r\n         throw new Error(\"target coordinates are empty\");\r\n      }\r\n      const targetParent = this.treeModel.getDescendant(\r\n         targetParentCoordinates\r\n      );\r\n      if (targetParent === undefined) {\r\n         throw new Error(\"could not get to target\");\r\n      }\r\n      targetParent.insertChild(source, index);\r\n      this.rebuildTreeData();\r\n      this.drops$.next({\r\n         target: source.data,\r\n         oldParent: sourceParent?.data as LimbleTreeNode,\r\n         oldIndex: sourceIndex,\r\n         newParent: targetParent.data,\r\n         newIndex: index\r\n      });\r\n      this.render();\r\n   }\r\n\r\n   public remove(target: Branch<any>) {\r\n      target.remove();\r\n      this.rebuildTreeData();\r\n      this.render();\r\n   }\r\n\r\n   private rebuildTreeData(): void {\r\n      if (this.treeData == undefined) {\r\n         throw new Error(\"Tree data not initialized\");\r\n      }\r\n      this.treeData.length = 0;\r\n      for (const branch of this.treeModel.getChildren()) {\r\n         this.treeData.push(this.rebuildBranch(branch));\r\n      }\r\n   }\r\n\r\n   private rebuildBranch(branch: Branch<any>): LimbleTreeNode {\r\n      const temp: LimbleTreeNode = branch.data;\r\n      temp.nodes = [];\r\n      for (const child of branch.getChildren()) {\r\n         temp.nodes.push(this.rebuildBranch(child));\r\n      }\r\n      return temp;\r\n   }\r\n\r\n   public getPlaceholder() {\r\n      return this.placeholder;\r\n   }\r\n}\r\n"]}

@@ -7,5 +7,5 @@ import { NgModule } from "@angular/core";

import { LimbleTreeNodeComponent } from "./limble-tree-node/limble-tree-node.component";
import { TempService } from "./singletons/temp.service";
import { DropZoneService } from "./singletons/drop-zone.service";
import { DragStateService } from "./singletons/drag-state.service";
import { LimbleTreeRootComponent } from "./limble-tree-root/limble-tree-root.component";
import { LimbleTreePlaceholderComponent } from './limble-tree-placeholder/limble-tree-placeholder.component';
export class LimbleTreeModule {

@@ -19,9 +19,10 @@ }

LimbleTreeNodeComponent,
LimbleTreeRootComponent
LimbleTreeRootComponent,
LimbleTreePlaceholderComponent
],
imports: [CommonModule],
exports: [LimbleTreeRootComponent],
providers: [ComponentCreatorService, TempService, DropZoneService]
providers: [ComponentCreatorService, DragStateService]
},] }
];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGltYmxlLXRyZWUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9saW1ibGUtdHJlZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUNqRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUM5RixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDeEYsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQWF4RixNQUFNLE9BQU8sZ0JBQWdCOzs7WUFYNUIsUUFBUSxTQUFDO2dCQUNQLFlBQVksRUFBRTtvQkFDWCx5QkFBeUI7b0JBQ3pCLGlCQUFpQjtvQkFDakIsdUJBQXVCO29CQUN2Qix1QkFBdUI7aUJBQ3pCO2dCQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztnQkFDdkIsT0FBTyxFQUFFLENBQUMsdUJBQXVCLENBQUM7Z0JBQ2xDLFNBQVMsRUFBRSxDQUFDLHVCQUF1QixFQUFFLFdBQVcsRUFBRSxlQUFlLENBQUM7YUFDcEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IENvbXBvbmVudENyZWF0b3JTZXJ2aWNlIH0gZnJvbSBcIi4vc2luZ2xldG9ucy9jb21wb25lbnQtY3JlYXRvci5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IERyb3Bab25lQ29tcG9uZW50IH0gZnJvbSBcIi4vZHJvcC16b25lL2Ryb3Atem9uZS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgTGltYmxlVHJlZUJyYW5jaENvbXBvbmVudCB9IGZyb20gXCIuL2xpbWJsZS10cmVlLWJyYW5jaC9saW1ibGUtdHJlZS1icmFuY2guY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgTGltYmxlVHJlZU5vZGVDb21wb25lbnQgfSBmcm9tIFwiLi9saW1ibGUtdHJlZS1ub2RlL2xpbWJsZS10cmVlLW5vZGUuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IFRlbXBTZXJ2aWNlIH0gZnJvbSBcIi4vc2luZ2xldG9ucy90ZW1wLnNlcnZpY2VcIjtcclxuaW1wb3J0IHsgRHJvcFpvbmVTZXJ2aWNlIH0gZnJvbSBcIi4vc2luZ2xldG9ucy9kcm9wLXpvbmUuc2VydmljZVwiO1xyXG5pbXBvcnQgeyBMaW1ibGVUcmVlUm9vdENvbXBvbmVudCB9IGZyb20gXCIuL2xpbWJsZS10cmVlLXJvb3QvbGltYmxlLXRyZWUtcm9vdC5jb21wb25lbnRcIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICBMaW1ibGVUcmVlQnJhbmNoQ29tcG9uZW50LFxyXG4gICAgICBEcm9wWm9uZUNvbXBvbmVudCxcclxuICAgICAgTGltYmxlVHJlZU5vZGVDb21wb25lbnQsXHJcbiAgICAgIExpbWJsZVRyZWVSb290Q29tcG9uZW50XHJcbiAgIF0sXHJcbiAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gICBleHBvcnRzOiBbTGltYmxlVHJlZVJvb3RDb21wb25lbnRdLFxyXG4gICBwcm92aWRlcnM6IFtDb21wb25lbnRDcmVhdG9yU2VydmljZSwgVGVtcFNlcnZpY2UsIERyb3Bab25lU2VydmljZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIExpbWJsZVRyZWVNb2R1bGUge31cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGltYmxlLXRyZWUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9saW1ibGUtdHJlZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUNqRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUM5RixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDeEYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbkUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDeEYsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFjN0csTUFBTSxPQUFPLGdCQUFnQjs7O1lBWjVCLFFBQVEsU0FBQztnQkFDUCxZQUFZLEVBQUU7b0JBQ1gseUJBQXlCO29CQUN6QixpQkFBaUI7b0JBQ2pCLHVCQUF1QjtvQkFDdkIsdUJBQXVCO29CQUN2Qiw4QkFBOEI7aUJBQ2hDO2dCQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztnQkFDdkIsT0FBTyxFQUFFLENBQUMsdUJBQXVCLENBQUM7Z0JBQ2xDLFNBQVMsRUFBRSxDQUFDLHVCQUF1QixFQUFFLGdCQUFnQixDQUFDO2FBQ3hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBDb21wb25lbnRDcmVhdG9yU2VydmljZSB9IGZyb20gXCIuL3NpbmdsZXRvbnMvY29tcG9uZW50LWNyZWF0b3Iuc2VydmljZVwiO1xyXG5pbXBvcnQgeyBEcm9wWm9uZUNvbXBvbmVudCB9IGZyb20gXCIuL2Ryb3Atem9uZS9kcm9wLXpvbmUuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IExpbWJsZVRyZWVCcmFuY2hDb21wb25lbnQgfSBmcm9tIFwiLi9saW1ibGUtdHJlZS1icmFuY2gvbGltYmxlLXRyZWUtYnJhbmNoLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7IExpbWJsZVRyZWVOb2RlQ29tcG9uZW50IH0gZnJvbSBcIi4vbGltYmxlLXRyZWUtbm9kZS9saW1ibGUtdHJlZS1ub2RlLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBEcmFnU3RhdGVTZXJ2aWNlIH0gZnJvbSBcIi4vc2luZ2xldG9ucy9kcmFnLXN0YXRlLnNlcnZpY2VcIjtcclxuaW1wb3J0IHsgTGltYmxlVHJlZVJvb3RDb21wb25lbnQgfSBmcm9tIFwiLi9saW1ibGUtdHJlZS1yb290L2xpbWJsZS10cmVlLXJvb3QuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBMaW1ibGVUcmVlUGxhY2Vob2xkZXJDb21wb25lbnQgfSBmcm9tICcuL2xpbWJsZS10cmVlLXBsYWNlaG9sZGVyL2xpbWJsZS10cmVlLXBsYWNlaG9sZGVyLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICBkZWNsYXJhdGlvbnM6IFtcclxuICAgICAgTGltYmxlVHJlZUJyYW5jaENvbXBvbmVudCxcclxuICAgICAgRHJvcFpvbmVDb21wb25lbnQsXHJcbiAgICAgIExpbWJsZVRyZWVOb2RlQ29tcG9uZW50LFxyXG4gICAgICBMaW1ibGVUcmVlUm9vdENvbXBvbmVudCxcclxuICAgICAgTGltYmxlVHJlZVBsYWNlaG9sZGVyQ29tcG9uZW50XHJcbiAgIF0sXHJcbiAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gICBleHBvcnRzOiBbTGltYmxlVHJlZVJvb3RDb21wb25lbnRdLFxyXG4gICBwcm92aWRlcnM6IFtDb21wb25lbnRDcmVhdG9yU2VydmljZSwgRHJhZ1N0YXRlU2VydmljZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIExpbWJsZVRyZWVNb2R1bGUge31cclxuIl19

@@ -8,6 +8,7 @@ /**

export { LimbleTreeNodeComponent as ɵg } from './lib/limble-tree-node/limble-tree-node.component';
export { LimbleTreePlaceholderComponent as ɵh } from './lib/limble-tree-placeholder/limble-tree-placeholder.component';
export { DropZoneService as ɵc } from './lib/limble-tree-root/drop-zone.service';
export { TreeService as ɵa } from './lib/limble-tree-root/tree.service';
export { ComponentCreatorService as ɵb } from './lib/singletons/component-creator.service';
export { DropZoneService as ɵc } from './lib/singletons/drop-zone.service';
export { TempService as ɵd } from './lib/singletons/temp.service';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGltYmxlLWxpbWJsZS10cmVlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy8iLCJzb3VyY2VzIjpbImxpbWJsZS1saW1ibGUtdHJlZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM1RSxPQUFPLEVBQUMseUJBQXlCLElBQUksRUFBRSxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDdEcsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQ2hHLE9BQU8sRUFBQyxXQUFXLElBQUksRUFBRSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQ3pGLE9BQU8sRUFBQyxlQUFlLElBQUksRUFBRSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFDLFdBQVcsSUFBSSxFQUFFLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtEcm9wWm9uZUNvbXBvbmVudCBhcyDJtWZ9IGZyb20gJy4vbGliL2Ryb3Atem9uZS9kcm9wLXpvbmUuY29tcG9uZW50JztcbmV4cG9ydCB7TGltYmxlVHJlZUJyYW5jaENvbXBvbmVudCBhcyDJtWV9IGZyb20gJy4vbGliL2xpbWJsZS10cmVlLWJyYW5jaC9saW1ibGUtdHJlZS1icmFuY2guY29tcG9uZW50JztcbmV4cG9ydCB7TGltYmxlVHJlZU5vZGVDb21wb25lbnQgYXMgybVnfSBmcm9tICcuL2xpYi9saW1ibGUtdHJlZS1ub2RlL2xpbWJsZS10cmVlLW5vZGUuY29tcG9uZW50JztcbmV4cG9ydCB7VHJlZVNlcnZpY2UgYXMgybVhfSBmcm9tICcuL2xpYi9saW1ibGUtdHJlZS1yb290L3RyZWUuc2VydmljZSc7XG5leHBvcnQge0NvbXBvbmVudENyZWF0b3JTZXJ2aWNlIGFzIMm1Yn0gZnJvbSAnLi9saWIvc2luZ2xldG9ucy9jb21wb25lbnQtY3JlYXRvci5zZXJ2aWNlJztcbmV4cG9ydCB7RHJvcFpvbmVTZXJ2aWNlIGFzIMm1Y30gZnJvbSAnLi9saWIvc2luZ2xldG9ucy9kcm9wLXpvbmUuc2VydmljZSc7XG5leHBvcnQge1RlbXBTZXJ2aWNlIGFzIMm1ZH0gZnJvbSAnLi9saWIvc2luZ2xldG9ucy90ZW1wLnNlcnZpY2UnOyJdfQ==
export { DragStateService as ɵd } from './lib/singletons/drag-state.service';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGltYmxlLWxpbWJsZS10cmVlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy8iLCJzb3VyY2VzIjpbImxpbWJsZS1saW1ibGUtdHJlZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM1RSxPQUFPLEVBQUMseUJBQXlCLElBQUksRUFBRSxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDdEcsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQ2hHLE9BQU8sRUFBQyw4QkFBOEIsSUFBSSxFQUFFLEVBQUMsTUFBTSxpRUFBaUUsQ0FBQztBQUNySCxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQy9FLE9BQU8sRUFBQyxXQUFXLElBQUksRUFBRSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQ3pGLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtEcm9wWm9uZUNvbXBvbmVudCBhcyDJtWZ9IGZyb20gJy4vbGliL2Ryb3Atem9uZS9kcm9wLXpvbmUuY29tcG9uZW50JztcbmV4cG9ydCB7TGltYmxlVHJlZUJyYW5jaENvbXBvbmVudCBhcyDJtWV9IGZyb20gJy4vbGliL2xpbWJsZS10cmVlLWJyYW5jaC9saW1ibGUtdHJlZS1icmFuY2guY29tcG9uZW50JztcbmV4cG9ydCB7TGltYmxlVHJlZU5vZGVDb21wb25lbnQgYXMgybVnfSBmcm9tICcuL2xpYi9saW1ibGUtdHJlZS1ub2RlL2xpbWJsZS10cmVlLW5vZGUuY29tcG9uZW50JztcbmV4cG9ydCB7TGltYmxlVHJlZVBsYWNlaG9sZGVyQ29tcG9uZW50IGFzIMm1aH0gZnJvbSAnLi9saWIvbGltYmxlLXRyZWUtcGxhY2Vob2xkZXIvbGltYmxlLXRyZWUtcGxhY2Vob2xkZXIuY29tcG9uZW50JztcbmV4cG9ydCB7RHJvcFpvbmVTZXJ2aWNlIGFzIMm1Y30gZnJvbSAnLi9saWIvbGltYmxlLXRyZWUtcm9vdC9kcm9wLXpvbmUuc2VydmljZSc7XG5leHBvcnQge1RyZWVTZXJ2aWNlIGFzIMm1YX0gZnJvbSAnLi9saWIvbGltYmxlLXRyZWUtcm9vdC90cmVlLnNlcnZpY2UnO1xuZXhwb3J0IHtDb21wb25lbnRDcmVhdG9yU2VydmljZSBhcyDJtWJ9IGZyb20gJy4vbGliL3NpbmdsZXRvbnMvY29tcG9uZW50LWNyZWF0b3Iuc2VydmljZSc7XG5leHBvcnQge0RyYWdTdGF0ZVNlcnZpY2UgYXMgybVkfSBmcm9tICcuL2xpYi9zaW5nbGV0b25zL2RyYWctc3RhdGUuc2VydmljZSc7Il19
import { Injectable, ComponentFactoryResolver, Component, Input, ChangeDetectorRef, ViewChild, ViewContainerRef, Output, ElementRef, EventEmitter, NgModule } from '@angular/core';
import { BehaviorSubject, ReplaySubject } from 'rxjs';
import { take } from 'rxjs/operators';
import { CommonModule } from '@angular/common';

@@ -104,22 +105,64 @@

class TempService {
set(value) {
class DragStateService {
constructor() {
this.state = "idle";
this.state$ = new BehaviorSubject(this.state);
}
/** Called to indicate that something is being dragged. Stores that something for later. */
dragging(value) {
this._tempData = value;
this.state = "dragging";
this.state$.next(this.state);
}
get() {
/** Called to indicate that there is a valid active drop zone. Drop is now possible. */
droppable() {
if (this.state !== "dragging") {
throw new Error("Can only move to `droppable` state from `dragging` state");
}
this.state = "droppable";
this.state$.next(this.state);
}
/** Called to indicate that there is no longer a valid active drop zone. Drop is no longer possible. */
notDroppable() {
if (this.state !== "droppable") {
throw new Error("Can only call `notDroppable` when state is `droppable`");
}
this.state = "dragging";
this.state$.next(this.state);
}
/** Called to indicate that a drop into a valid drop zone has occurred. Returns the item that was dropped. */
capture() {
if (this.state !== "droppable") {
throw new Error("Can only move to `captured` state from `droppable` state");
}
this.state = "captured";
this.state$.next(this.state);
return this._tempData;
}
delete() {
/** Called to reset the service for future drags */
release() {
this._tempData = undefined;
this.state = "idle";
this.state$.next(this.state);
}
/** gets the current thing being dragged, if any. */
getData() {
return this._tempData;
}
/** gets the current state */
getState() {
return this.state;
}
}
TempService.decorators = [
DragStateService.decorators = [
{ type: Injectable }
];
DragStateService.ctorParameters = () => [];
class DropZoneService {
constructor(componentCreatorService, tempService) {
constructor(componentCreatorService, dragStateService) {
this.componentCreatorService = componentCreatorService;
this.tempService = tempService;
this.dragStateService = dragStateService;
this.activeDropZoneInfo = null;
this.setActiveDropZoneInfo(null);
this.secondaryDropZones = [];

@@ -140,3 +183,3 @@ this.dropZones = [];

if (active === true) {
this.activeDropZoneInfo = dropZone;
this.setActiveDropZoneInfo(dropZone);
}

@@ -150,3 +193,3 @@ else {

(_a = this.activeDropZoneInfo) === null || _a === void 0 ? void 0 : _a.container.clear();
this.activeDropZoneInfo = null;
this.setActiveDropZoneInfo(null);
for (const secondaryZone of this.secondaryDropZones) {

@@ -160,2 +203,11 @@ secondaryZone.container.clear();

}
setActiveDropZoneInfo(dropZoneInfo) {
this.activeDropZoneInfo = dropZoneInfo;
if (this.activeDropZoneInfo !== null) {
this.dragStateService.droppable();
}
else if (this.dragStateService.getState() === "droppable") {
this.dragStateService.notDroppable();
}
}
getDropZones() {

@@ -214,2 +266,6 @@ return this.dropZones;

previousSibling[previousSibling.length - 1]--;
const currentNode = (_b = (_a = this.dragStateService.getData()) === null || _a === void 0 ? void 0 : _a.getCoordinates()) !== null && _b !== void 0 ? _b : [];
if (arraysAreEqual(currentNode, previousSibling)) {
return;
}
const hasChildren = this.coordinatesHasChildren(previousSibling);

@@ -232,3 +288,3 @@ if (hasChildren) {

}
else if (!arraysAreEqual((_b = (_a = this.tempService.get()) === null || _a === void 0 ? void 0 : _a.getCoordinates()) !== null && _b !== void 0 ? _b : [], previousSibling)) {
else {
const previousSiblingNode = this.getCoordinatesGroup(previousSibling)[previousSibling[previousSibling.length - 1]];

@@ -320,3 +376,3 @@ if (isNestingAllowed(this.treeOptions, previousSiblingNode)) {

{ type: ComponentCreatorService },
{ type: TempService }
{ type: DragStateService }
];

@@ -386,2 +442,11 @@

}
getAncestors() {
const result = [];
let cursor = this;
while (cursor.parent !== null) {
result.push(cursor.parent);
cursor = cursor.parent;
}
return result;
}
appendChild(child) {

@@ -474,6 +539,6 @@ if (child.getParent() !== null) {

class LimbleTreeNodeComponent {
constructor(componentCreatorService, changeDetectorRef, tempService, dropZoneService, treeService) {
constructor(componentCreatorService, changeDetectorRef, dragStateService, dropZoneService, treeService) {
this.componentCreatorService = componentCreatorService;
this.changeDetectorRef = changeDetectorRef;
this.tempService = tempService;
this.dragStateService = dragStateService;
this.dropZoneService = dropZoneService;

@@ -493,6 +558,7 @@ this.treeService = treeService;

if (event.dataTransfer === null || this.branch === undefined) {
return;
throw new Error("failed to run dragstartHandler");
}
const draggedElement = event.target;
if (((_a = draggedElement.parentElement) === null || _a === void 0 ? void 0 : _a.tagName) !== "LIMBLE-TREE-NODE") {
//Don't drag stuff that isn't part of the tree
return;

@@ -502,3 +568,3 @@ }

draggedElement.classList.add("dragging");
this.tempService.set(this.branch);
this.dragStateService.dragging(this.branch);
}

@@ -508,29 +574,28 @@ dragendHandler(event) {

const draggedElement = event.target;
const sourceBranch = this.tempService.get();
if (sourceBranch === undefined) {
return;
draggedElement.classList.remove("dragging");
if (this.branch === undefined) {
throw new Error("failed to get current branch in dragendHandler");
}
this.tempService.delete();
draggedElement.classList.remove("dragging");
const dropZoneInfo = this.dropZoneService.getActiveDropZoneInfo();
if (dropZoneInfo === null) {
if (this.dragStateService.getState() !== "captured") {
return;
}
this.dropZoneService.removeActiveAndSecondaryZones();
if (dropZoneInfo.coordinates === undefined) {
throw new Error("could not determine drop zone location");
}
this.treeService.move(sourceBranch, dropZoneInfo.coordinates);
this.dragStateService.state$.pipe(take(2)).subscribe((state) => {
if (state === "captured" && this.branch !== undefined) {
this.treeService.remove(this.branch);
this.dragStateService.release();
}
});
}
dragoverHandler(event) {
var _a, _b, _c;
if (this.tempService.get() === undefined || this.branch === undefined) {
return;
if (this.branch === undefined) {
throw new Error("Can't get current branch during dragover event");
}
const sourceBranch = this.tempService.get();
const sourceBranch = this.dragStateService.getData();
if (sourceBranch === undefined) {
return;
throw new Error("Can't get source branch during dragover event");
}
//If trying to drop on self, remove any remaining drop zones and return.
if (sourceBranch === this.branch) {
//If trying to drop on self, remove any existing drop zones and return.
if (sourceBranch === this.branch ||
this.branch.getAncestors().includes(sourceBranch)) {
if (this.dropZoneService.getActiveDropZoneInfo() !== null) {

@@ -541,9 +606,26 @@ this.dropZoneService.removeActiveAndSecondaryZones();

}
if (this.treeService.getPlaceholder() === true &&
this.dropZoneAbove !== undefined) {
//If placeholder system is active, then activate the only existing drop zone
//and skip the rest of the logic in this function
const dropCoordinates = [...this.branch.getCoordinates()];
this.dropZoneService.showDropZoneFamily({
container: this.dropZoneAbove,
coordinates: dropCoordinates
});
return;
}
const target = event.currentTarget;
const topLine = target.offsetHeight / 3; //an imaginary line 1/3 of the way down from the top of the element;
const bottomLine = topLine * 2; //an imaginary line 1/3 of the way up from the bottom of the element;
const parent = this.branch.getParent();
let parentData;
if (parent !== null) {
parentData = parent.data;
}
if (event.offsetY < topLine &&
this.dropZoneAbove !== undefined &&
((_a = this.dropZoneService.getActiveDropZoneInfo()) === null || _a === void 0 ? void 0 : _a.container) !==
this.dropZoneAbove) {
this.dropZoneAbove &&
isNestingAllowed(this.treeService.treeOptions, parentData)) {
const dropCoordinates = [...this.branch.getCoordinates()];

@@ -570,3 +652,4 @@ this.dropZoneService.showDropZoneFamily({

this.dropZoneBelow &&
this.branch.getChildren().length === 0) {
this.branch.getChildren().length === 0 &&
isNestingAllowed(this.treeService.treeOptions, parentData)) {
const dropCoordinates = [...this.branch.getCoordinates()];

@@ -605,3 +688,4 @@ dropCoordinates[dropCoordinates.length - 1]++;

newBranchComponent.instance.branch = this.branch;
if (isNestingAllowed(this.treeService.treeOptions, this.branch.data)) {
if (isNestingAllowed(this.treeService.treeOptions, this.branch.data) &&
!this.treeService.getPlaceholder() === true) {
newBranchComponent.instance.dropZoneInside$.subscribe((dropZone) => {

@@ -636,2 +720,10 @@ var _a;

}
const parent = this.branch.getParent();
let parentData;
if (parent !== null) {
parentData = parent.data;
}
if (!isNestingAllowed(this.treeService.treeOptions, parentData)) {
return;
}
const currentCoordinates = this.branch.getCoordinates();

@@ -643,2 +735,6 @@ const dropCoordinatesAbove = [...currentCoordinates];

});
if (this.treeService.getPlaceholder() === true) {
//Only register one drop zone if the placeholder system is active
return;
}
const dropCoordinatesBelow = [...currentCoordinates];

@@ -684,3 +780,3 @@ dropCoordinatesBelow[dropCoordinatesBelow.length - 1]++;

{ type: ChangeDetectorRef },
{ type: TempService },
{ type: DragStateService },
{ type: DropZoneService },

@@ -698,2 +794,12 @@ { type: TreeService }

class LimbleTreePlaceholderComponent {
}
LimbleTreePlaceholderComponent.decorators = [
{ type: Component, args: [{
selector: "limble-tree-placeholder",
template: "<div class=\"placeholder\"></div>\n",
styles: [".placeholder{height:20px;width:100%}"]
},] }
];
/** The default value for the `indent` option */

@@ -708,2 +814,3 @@ const INDENT = 45;

this.treeModel = new Branch(null);
this.placeholder = false;
}

@@ -733,12 +840,25 @@ /** Initializes the service and renders the tree.

this.dropZoneService.init(this.treeData, this.treeOptions);
for (const node of this.treeData) {
const branch = new Branch(node);
if (this.treeData.length === 0) {
//Tree is empty, but we have to to have something there so other trees' items can be dropped into it
this.placeholder = true;
const placeholderNode = {
component: { class: LimbleTreePlaceholderComponent }
};
const branch = new Branch(placeholderNode);
this.treeModel.appendChild(branch);
}
for (const branch of this.treeModel.getChildren()) {
const componentRef = this.componentCreatorService.appendComponent(LimbleTreeNodeComponent, this.host);
componentRef.instance.branch = branch;
//The LimbleTreeNodeComponent will (indirectly) call the `renderBranch` method of this service to render
//its own children
}
else {
for (const node of this.treeData) {
const branch = new Branch(node);
this.treeModel.appendChild(branch);
}
for (const branch of this.treeModel.getChildren()) {
const componentRef = this.componentCreatorService.appendComponent(LimbleTreeNodeComponent, this.host);
componentRef.instance.branch = branch;
//The LimbleTreeNodeComponent will (indirectly) call the `renderBranch` method of this service to render
//its own children
}
}
this.changes$.next(null);

@@ -771,3 +891,3 @@ }

}
move(source, targetCoordinates) {
drop(source, targetCoordinates) {
const sourceParent = source.getParent();

@@ -778,4 +898,14 @@ const sourceIndex = source.getIndex();

}
const targetParentCoordinates = [...targetCoordinates];
const index = targetParentCoordinates.pop();
let targetParentCoordinates;
let index;
if (this.placeholder === true) {
targetParentCoordinates = [];
index = 0;
this.treeModel.removeChild(0); //remove the placeholder
this.placeholder = false;
}
else {
targetParentCoordinates = [...targetCoordinates];
index = targetParentCoordinates.pop();
}
if (index === undefined) {

@@ -790,3 +920,2 @@ throw new Error("target coordinates are empty");

this.rebuildTreeData();
console.log(sourceParent);
this.drops$.next({

@@ -801,2 +930,7 @@ target: source.data,

}
remove(target) {
target.remove();
this.rebuildTreeData();
this.render();
}
rebuildTreeData() {

@@ -819,2 +953,5 @@ if (this.treeData == undefined) {

}
getPlaceholder() {
return this.placeholder;
}
}

@@ -830,6 +967,7 @@ TreeService.decorators = [

class LimbleTreeRootComponent {
constructor(treeService, changeDetectorRef, dropZoneService) {
constructor(treeService, changeDetectorRef, dropZoneService, dragStateService) {
this.treeService = treeService;
this.changeDetectorRef = changeDetectorRef;
this.dropZoneService = dropZoneService;
this.dragStateService = dragStateService;
this.treeChange = new EventEmitter();

@@ -883,4 +1021,21 @@ this.treeDrop = new EventEmitter();

}
dropHandler(event) {
event.stopPropagation();
const dropZoneInfo = this.dropZoneService.getActiveDropZoneInfo();
if (this.dragStateService.getState() !== "droppable") {
return;
}
if (dropZoneInfo === null) {
throw new Error("failed to get active drop zone at drop handler");
}
const sourceBranch = this.dragStateService.capture();
if (sourceBranch === undefined) {
throw new Error("failed to get current branch in dragendHandler");
}
this.dropZoneService.removeActiveAndSecondaryZones();
this.treeService.drop(sourceBranch, dropZoneInfo.coordinates);
}
ngOnDestroy() {
this.changesSubscription.unsubscribe();
this.dropSubscription.unsubscribe();
}

@@ -891,4 +1046,4 @@ }

selector: "limble-tree-root",
template: "<div\r\n (dragover)=\"dragoverHandler($event)\"\r\n (dragleave)=\"dragleaveHandler($event)\"\r\n>\r\n <ng-template #dropZoneInside></ng-template>\r\n <ng-template #host></ng-template>\r\n</div>\r\n",
providers: [TreeService],
template: "<div\r\n (dragover)=\"dragoverHandler($event)\"\r\n (dragleave)=\"dragleaveHandler($event)\"\r\n (drop)=\"dropHandler($event)\"\r\n>\r\n <ng-template #dropZoneInside></ng-template>\r\n <ng-template #host></ng-template>\r\n</div>\r\n",
providers: [TreeService, DropZoneService],
styles: [""]

@@ -900,3 +1055,4 @@ },] }

{ type: ChangeDetectorRef },
{ type: DropZoneService }
{ type: DropZoneService },
{ type: DragStateService }
];

@@ -921,7 +1077,8 @@ LimbleTreeRootComponent.propDecorators = {

LimbleTreeNodeComponent,
LimbleTreeRootComponent
LimbleTreeRootComponent,
LimbleTreePlaceholderComponent
],
imports: [CommonModule],
exports: [LimbleTreeRootComponent],
providers: [ComponentCreatorService, TempService, DropZoneService]
providers: [ComponentCreatorService, DragStateService]
},] }

@@ -938,3 +1095,3 @@ ];

export { LimbleTreeModule, LimbleTreeRootComponent, TreeService as ɵa, ComponentCreatorService as ɵb, DropZoneService as ɵc, TempService as ɵd, LimbleTreeBranchComponent as ɵe, DropZoneComponent as ɵf, LimbleTreeNodeComponent as ɵg };
export { LimbleTreeModule, LimbleTreeRootComponent, TreeService as ɵa, ComponentCreatorService as ɵb, DropZoneService as ɵc, DragStateService as ɵd, LimbleTreeBranchComponent as ɵe, DropZoneComponent as ɵf, LimbleTreeNodeComponent as ɵg, LimbleTreePlaceholderComponent as ɵh };
//# sourceMappingURL=limble-limble-tree.js.map

@@ -17,2 +17,3 @@ /** An object indicating a location within a tree */

findDescendant(predicate: (data: T) => boolean): Branch<T> | undefined;
getAncestors(): Array<Branch<unknown>>;
appendChild(child: Branch<T>): Branch<T>;

@@ -19,0 +20,0 @@ insertChild(child: Branch<T>, index: number): Branch<T>;

@@ -1,3 +0,3 @@

import type { DropZoneInfo } from "../singletons/drop-zone.service";
import { DropZoneService } from "../singletons/drop-zone.service";
import type { DropZoneInfo } from "../limble-tree-root/drop-zone.service";
import { DropZoneService } from "../limble-tree-root/drop-zone.service";
export declare class DropZoneComponent {

@@ -4,0 +4,0 @@ private readonly dropZoneService;

import { AfterViewInit, ChangeDetectorRef } from "@angular/core";
import { ComponentCreatorService } from "../singletons/component-creator.service";
import { DropZoneService } from "../singletons/drop-zone.service";
import { TempService } from "../singletons/temp.service";
import { DropZoneService } from "../limble-tree-root/drop-zone.service";
import { DragStateService } from "../singletons/drag-state.service";
import { TreeService } from "../limble-tree-root/tree.service";
import type { Branch } from "../branch";
import { Branch } from "../branch";
export declare class LimbleTreeNodeComponent implements AfterViewInit {
private readonly componentCreatorService;
private readonly changeDetectorRef;
private readonly tempService;
private readonly dragStateService;
private readonly dropZoneService;

@@ -20,3 +20,3 @@ private readonly treeService;

private draggableDiv;
constructor(componentCreatorService: ComponentCreatorService, changeDetectorRef: ChangeDetectorRef, tempService: TempService, dropZoneService: DropZoneService, treeService: TreeService);
constructor(componentCreatorService: ComponentCreatorService, changeDetectorRef: ChangeDetectorRef, dragStateService: DragStateService, dropZoneService: DropZoneService, treeService: TreeService);
ngAfterViewInit(): void;

@@ -23,0 +23,0 @@ dragstartHandler(event: DragEvent): void;

import { AfterViewInit, ChangeDetectorRef, EventEmitter, OnChanges, OnDestroy, ViewContainerRef } from "@angular/core";
import { BehaviorSubject } from "rxjs";
import { DropZoneService } from "../singletons/drop-zone.service";
import { DropZoneService } from "./drop-zone.service";
import { LimbleTreeData, LimbleTreeOptions, TreeDrop } from "../limble-tree-root/tree.service";
import { TreeService } from "./tree.service";
import { DragStateService } from "../singletons/drag-state.service";
export declare class LimbleTreeRootComponent implements AfterViewInit, OnChanges, OnDestroy {

@@ -10,2 +11,3 @@ private readonly treeService;

private readonly dropZoneService;
private readonly dragStateService;
data: LimbleTreeData | undefined;

@@ -20,3 +22,3 @@ options: LimbleTreeOptions | undefined;

private readonly dropSubscription;
constructor(treeService: TreeService, changeDetectorRef: ChangeDetectorRef, dropZoneService: DropZoneService);
constructor(treeService: TreeService, changeDetectorRef: ChangeDetectorRef, dropZoneService: DropZoneService, dragStateService: DragStateService);
ngAfterViewInit(): void;

@@ -27,3 +29,4 @@ ngOnChanges(): void;

dragleaveHandler(event: DragEvent): void;
dropHandler(event: DragEvent): void;
ngOnDestroy(): void;
}
import { Type, ViewContainerRef } from "@angular/core";
import { ReplaySubject } from "rxjs";
import { ComponentCreatorService } from "../singletons/component-creator.service";
import { DropZoneService } from "../singletons/drop-zone.service";
import { DropZoneService } from "./drop-zone.service";
import { Branch, BranchCoordinates } from "../branch";

@@ -23,7 +23,8 @@ /** An object describing a node of the tree */

indent?: number;
/** Whether to allow "nesting" (placing a node one level deeper than currently exists on the branch)
/**
* Whether to allow "nesting" (placing a node one level deeper than currently exists on the branch)
* when dragging a node. Defaults to true.
*/
allowNesting?: boolean | ((nodeData: LimbleTreeNode) => boolean);
/** Whether to allow drag-and-drop functionality. Defaults to true.*/
/** Whether to allow drag-and-drop functionality. Defaults to true. */
allowDragging?: boolean | ((nodeData: LimbleTreeNode) => boolean);

@@ -71,2 +72,3 @@ }

treeModel: Branch<any>;
private placeholder;
constructor(componentCreatorService: ComponentCreatorService, dropZoneService: DropZoneService);

@@ -85,5 +87,7 @@ /** Initializes the service and renders the tree.

private processOptions;
move(source: Branch<any>, targetCoordinates: BranchCoordinates): void;
drop(source: Branch<any>, targetCoordinates: BranchCoordinates): void;
remove(target: Branch<any>): void;
private rebuildTreeData;
private rebuildBranch;
getPlaceholder(): boolean;
}

@@ -8,5 +8,6 @@ /**

export { LimbleTreeNodeComponent as ɵg } from './lib/limble-tree-node/limble-tree-node.component';
export { LimbleTreePlaceholderComponent as ɵh } from './lib/limble-tree-placeholder/limble-tree-placeholder.component';
export { DropZoneService as ɵc } from './lib/limble-tree-root/drop-zone.service';
export { TreeService as ɵa } from './lib/limble-tree-root/tree.service';
export { ComponentCreatorService as ɵb } from './lib/singletons/component-creator.service';
export { DropZoneService as ɵc } from './lib/singletons/drop-zone.service';
export { TempService as ɵd } from './lib/singletons/temp.service';
export { DragStateService as ɵd } from './lib/singletons/drag-state.service';

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":71,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"}]}],"init":[{"__symbolic":"method"}],"render":[{"__symbolic":"method"}],"renderBranch":[{"__symbolic":"method"}],"processOptions":[{"__symbolic":"method"}],"move":[{"__symbolic":"method"}],"rebuildTreeData":[{"__symbolic":"method"}],"rebuildBranch":[{"__symbolic":"method"}]}},"LimbleTreeNode":{"__symbolic":"interface"},"LimbleTreeData":{"__symbolic":"interface"},"LimbleTreeOptions":{"__symbolic":"interface"},"ComponentObj":{"__symbolic":"interface"},"TreeDrop":{"__symbolic":"interface"},"LimbleTreeRootComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":22,"character":1},"arguments":[{"selector":"limble-tree-root","providers":[{"__symbolic":"reference","name":"ɵa"}],"template":"<div\r\n (dragover)=\"dragoverHandler($event)\"\r\n (dragleave)=\"dragleaveHandler($event)\"\r\n>\r\n <ng-template #dropZoneInside></ng-template>\r\n <ng-template #host></ng-template>\r\n</div>\r\n","styles":[""]}]}],"members":{"data":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":4}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":31,"character":4}}]}],"host":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":33,"character":4},"arguments":["host",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":33,"character":30}}]}]}],"dropZoneInside":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":37,"character":4},"arguments":["dropZoneInside",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":37,"character":40}}]}]}],"dropZoneInside$":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":40,"character":4}}]}],"treeChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":43,"character":4}}]}],"treeDrop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":45,"character":4}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":52,"character":42},{"__symbolic":"reference","name":"ɵc"}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"update":[{"__symbolic":"method"}],"dragoverHandler":[{"__symbolic":"method"}],"dragleaveHandler":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}]}},"LimbleTreeModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":10,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"},{"__symbolic":"reference","name":"LimbleTreeRootComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":17,"character":13}],"exports":[{"__symbolic":"reference","name":"LimbleTreeRootComponent"}],"providers":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵc"}]}]}],"members":{}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":7,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":9,"character":49}]}],"appendComponent":[{"__symbolic":"method"}]}},"ɵc":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":17,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵd"}]}],"init":[{"__symbolic":"method"}],"showSingleDropZone":[{"__symbolic":"method"}],"removeActiveAndSecondaryZones":[{"__symbolic":"method"}],"getActiveDropZoneInfo":[{"__symbolic":"method"}],"getDropZones":[{"__symbolic":"method"}],"getSecondaryDropZones":[{"__symbolic":"method"}],"addDropZone":[{"__symbolic":"method"}],"clearDropZones":[{"__symbolic":"method"}],"isLastDropZoneInBranch":[{"__symbolic":"method"}],"isOnRoot":[{"__symbolic":"method"}],"showDropZoneFamily":[{"__symbolic":"method"}],"coordinatesHasChildren":[{"__symbolic":"method"}],"swapActiveDropZone":[{"__symbolic":"method"}],"getNextSibling":[{"__symbolic":"method"}],"getCoordinatesGroup":[{"__symbolic":"method"}],"getCoordinatesChildren":[{"__symbolic":"method"}]}},"ɵd":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1}}],"members":{"set":[{"__symbolic":"method"}],"get":[{"__symbolic":"method"}],"delete":[{"__symbolic":"method"}]}},"ɵe":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":13,"character":1},"arguments":[{"selector":"limble-tree-branch","styles":["./limble-tree-branch.component.scss"],"template":"<div [style.marginLeft.px]=\"indent\">\r\n <ng-template #dropZoneInside></ng-template>\r\n <span [hidden]=\"branch?.data.collapsed\" class=\"limble-child-nodes\">\r\n <ng-template #host></ng-template>\r\n </span>\r\n</div>\r\n"}]}],"members":{"branch":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":4}}]}],"host":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":21,"character":4},"arguments":["host",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":21,"character":30}}]}]}],"dropZoneInside":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":25,"character":4},"arguments":["dropZoneInside",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":25,"character":40}}]}]}],"dropZoneInside$":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":28,"character":4}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":35,"character":42}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"reRender":[{"__symbolic":"method"}]}},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"drop-zone","template":"<div class=\"dropZoneContainer\" (dragenter)=\"dragenterHandler()\">\r\n <div [ngClass]=\"{ active: active, related: !active }\"></div>\r\n</div>\r\n","styles":[".active{background:#f0f9ff;border:2px dashed #bed2db;border-radius:5px;height:100px}.active,.related{box-sizing:border-box;margin:10px 0;width:calc(100% - 20px)}.related{background:#fff6f0;border:1px dashed #dbccbe;border-radius:5px;height:20px;opacity:.8}.dropZoneContainer{position:relative}"]}]}],"members":{"active":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":4}}]}],"dropZoneInfo":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":4}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵc"}]}],"dragenterHandler":[{"__symbolic":"method"}]}},"ɵg":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":17,"character":1},"arguments":[{"selector":"limble-tree-node","template":"<ng-template #dropZoneAbove></ng-template>\r\n<div\r\n (dragstart)=\"dragstartHandler($event)\"\r\n (dragend)=\"dragendHandler($event)\"\r\n #draggableDiv\r\n>\r\n <div (dragover)=\"dragoverHandler($event)\">\r\n <ng-template #nodeHost></ng-template>\r\n </div>\r\n <ng-template #children></ng-template>\r\n</div>\r\n<ng-template #dropZoneBelow></ng-template>\r\n","styles":[".dragging{opacity:.33}"]}]}],"members":{"branch":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":4}}]}],"nodeHost":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":24,"character":4},"arguments":["nodeHost",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":24,"character":34}}]}]}],"dropZoneAbove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":27,"character":4},"arguments":["dropZoneAbove",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":27,"character":39}}]}]}],"dropZoneBelow":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":29,"character":4},"arguments":["dropZoneBelow",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":29,"character":39}}]}]}],"children":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":32,"character":4},"arguments":["children",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":32,"character":34}}]}]}],"draggableDiv":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":35,"character":4},"arguments":["draggableDiv",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":35,"character":38}}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":41,"character":42},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵa"}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"dragstartHandler":[{"__symbolic":"method"}],"dragendHandler":[{"__symbolic":"method"}],"dragoverHandler":[{"__symbolic":"method"}],"renderSelf":[{"__symbolic":"method"}],"renderChildren":[{"__symbolic":"method"}],"registerDropZones":[{"__symbolic":"method"}],"checkForHandle":[{"__symbolic":"method"}]}}},"origins":{"ɵa":"./lib/limble-tree-root/tree.service","LimbleTreeNode":"./lib/limble-tree-root/tree.service","LimbleTreeData":"./lib/limble-tree-root/tree.service","LimbleTreeOptions":"./lib/limble-tree-root/tree.service","ComponentObj":"./lib/limble-tree-root/tree.service","TreeDrop":"./lib/limble-tree-root/tree.service","LimbleTreeRootComponent":"./lib/limble-tree-root/limble-tree-root.component","LimbleTreeModule":"./lib/limble-tree.module","ɵb":"./lib/singletons/component-creator.service","ɵc":"./lib/singletons/drop-zone.service","ɵd":"./lib/singletons/temp.service","ɵe":"./lib/limble-tree-branch/limble-tree-branch.component","ɵf":"./lib/drop-zone/drop-zone.component","ɵg":"./lib/limble-tree-node/limble-tree-node.component"},"importAs":"@limble/limble-tree"}
{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":73,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"}]}],"init":[{"__symbolic":"method"}],"render":[{"__symbolic":"method"}],"renderBranch":[{"__symbolic":"method"}],"processOptions":[{"__symbolic":"method"}],"drop":[{"__symbolic":"method"}],"remove":[{"__symbolic":"method"}],"rebuildTreeData":[{"__symbolic":"method"}],"rebuildBranch":[{"__symbolic":"method"}],"getPlaceholder":[{"__symbolic":"method"}]}},"LimbleTreeNode":{"__symbolic":"interface"},"LimbleTreeData":{"__symbolic":"interface"},"LimbleTreeOptions":{"__symbolic":"interface"},"ComponentObj":{"__symbolic":"interface"},"TreeDrop":{"__symbolic":"interface"},"LimbleTreeRootComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":23,"character":1},"arguments":[{"selector":"limble-tree-root","providers":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵc"}],"template":"<div\r\n (dragover)=\"dragoverHandler($event)\"\r\n (dragleave)=\"dragleaveHandler($event)\"\r\n (drop)=\"dropHandler($event)\"\r\n>\r\n <ng-template #dropZoneInside></ng-template>\r\n <ng-template #host></ng-template>\r\n</div>\r\n","styles":[""]}]}],"members":{"data":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":31,"character":4}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":4}}]}],"host":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":34,"character":4},"arguments":["host",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":34,"character":30}}]}]}],"dropZoneInside":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":38,"character":4},"arguments":["dropZoneInside",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":38,"character":40}}]}]}],"dropZoneInside$":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":41,"character":4}}]}],"treeChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":44,"character":4}}]}],"treeDrop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":46,"character":4}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":53,"character":42},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"update":[{"__symbolic":"method"}],"dragoverHandler":[{"__symbolic":"method"}],"dragleaveHandler":[{"__symbolic":"method"}],"dropHandler":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}]}},"LimbleTreeModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":10,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"},{"__symbolic":"reference","name":"LimbleTreeRootComponent"},{"__symbolic":"reference","name":"ɵh"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":18,"character":13}],"exports":[{"__symbolic":"reference","name":"LimbleTreeRootComponent"}],"providers":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵd"}]}]}],"members":{}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":7,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":9,"character":49}]}],"appendComponent":[{"__symbolic":"method"}]}},"ɵc":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":17,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵd"}]}],"init":[{"__symbolic":"method"}],"showSingleDropZone":[{"__symbolic":"method"}],"removeActiveAndSecondaryZones":[{"__symbolic":"method"}],"getActiveDropZoneInfo":[{"__symbolic":"method"}],"setActiveDropZoneInfo":[{"__symbolic":"method"}],"getDropZones":[{"__symbolic":"method"}],"getSecondaryDropZones":[{"__symbolic":"method"}],"addDropZone":[{"__symbolic":"method"}],"clearDropZones":[{"__symbolic":"method"}],"isLastDropZoneInBranch":[{"__symbolic":"method"}],"isOnRoot":[{"__symbolic":"method"}],"showDropZoneFamily":[{"__symbolic":"method"}],"coordinatesHasChildren":[{"__symbolic":"method"}],"swapActiveDropZone":[{"__symbolic":"method"}],"getNextSibling":[{"__symbolic":"method"}],"getCoordinatesGroup":[{"__symbolic":"method"}],"getCoordinatesChildren":[{"__symbolic":"method"}]}},"ɵd":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":6,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"dragging":[{"__symbolic":"method"}],"droppable":[{"__symbolic":"method"}],"notDroppable":[{"__symbolic":"method"}],"capture":[{"__symbolic":"method"}],"release":[{"__symbolic":"method"}],"getData":[{"__symbolic":"method"}],"getState":[{"__symbolic":"method"}]}},"ɵe":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":13,"character":1},"arguments":[{"selector":"limble-tree-branch","styles":["./limble-tree-branch.component.scss"],"template":"<div [style.marginLeft.px]=\"indent\">\r\n <ng-template #dropZoneInside></ng-template>\r\n <span [hidden]=\"branch?.data.collapsed\" class=\"limble-child-nodes\">\r\n <ng-template #host></ng-template>\r\n </span>\r\n</div>\r\n"}]}],"members":{"branch":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":4}}]}],"host":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":21,"character":4},"arguments":["host",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":21,"character":30}}]}]}],"dropZoneInside":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":25,"character":4},"arguments":["dropZoneInside",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":25,"character":40}}]}]}],"dropZoneInside$":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":28,"character":4}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":35,"character":42}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"reRender":[{"__symbolic":"method"}]}},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"drop-zone","template":"<div class=\"dropZoneContainer\" (dragenter)=\"dragenterHandler()\">\r\n <div [ngClass]=\"{ active: active, related: !active }\"></div>\r\n</div>\r\n","styles":[".active{background:#f0f9ff;border:2px dashed #bed2db;border-radius:5px;height:100px}.active,.related{box-sizing:border-box;margin:10px 0;width:calc(100% - 20px)}.related{background:#fff6f0;border:1px dashed #dbccbe;border-radius:5px;height:20px;opacity:.8}.dropZoneContainer{position:relative}"]}]}],"members":{"active":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":4}}]}],"dropZoneInfo":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":4}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵc"}]}],"dragenterHandler":[{"__symbolic":"method"}]}},"ɵg":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":18,"character":1},"arguments":[{"selector":"limble-tree-node","template":"<ng-template #dropZoneAbove></ng-template>\r\n<div\r\n (dragstart)=\"dragstartHandler($event)\"\r\n (dragend)=\"dragendHandler($event)\"\r\n #draggableDiv\r\n>\r\n <div (dragover)=\"dragoverHandler($event)\">\r\n <ng-template #nodeHost></ng-template>\r\n </div>\r\n <ng-template #children></ng-template>\r\n</div>\r\n<ng-template #dropZoneBelow></ng-template>\r\n","styles":[".dragging{opacity:.33}"]}]}],"members":{"branch":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":4}}]}],"nodeHost":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":25,"character":4},"arguments":["nodeHost",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":25,"character":34}}]}]}],"dropZoneAbove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":28,"character":4},"arguments":["dropZoneAbove",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":28,"character":39}}]}]}],"dropZoneBelow":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":30,"character":4},"arguments":["dropZoneBelow",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":30,"character":39}}]}]}],"children":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":33,"character":4},"arguments":["children",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":33,"character":34}}]}]}],"draggableDiv":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":36,"character":4},"arguments":["draggableDiv",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":36,"character":38}}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":42,"character":42},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵa"}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"dragstartHandler":[{"__symbolic":"method"}],"dragendHandler":[{"__symbolic":"method"}],"dragoverHandler":[{"__symbolic":"method"}],"renderSelf":[{"__symbolic":"method"}],"renderChildren":[{"__symbolic":"method"}],"registerDropZones":[{"__symbolic":"method"}],"checkForHandle":[{"__symbolic":"method"}]}},"ɵh":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"limble-tree-placeholder","template":"<div class=\"placeholder\"></div>\n","styles":[".placeholder{height:20px;width:100%}"]}]}],"members":{}}},"origins":{"ɵa":"./lib/limble-tree-root/tree.service","LimbleTreeNode":"./lib/limble-tree-root/tree.service","LimbleTreeData":"./lib/limble-tree-root/tree.service","LimbleTreeOptions":"./lib/limble-tree-root/tree.service","ComponentObj":"./lib/limble-tree-root/tree.service","TreeDrop":"./lib/limble-tree-root/tree.service","LimbleTreeRootComponent":"./lib/limble-tree-root/limble-tree-root.component","LimbleTreeModule":"./lib/limble-tree.module","ɵb":"./lib/singletons/component-creator.service","ɵc":"./lib/limble-tree-root/drop-zone.service","ɵd":"./lib/singletons/drag-state.service","ɵe":"./lib/limble-tree-branch/limble-tree-branch.component","ɵf":"./lib/drop-zone/drop-zone.component","ɵg":"./lib/limble-tree-node/limble-tree-node.component","ɵh":"./lib/limble-tree-placeholder/limble-tree-placeholder.component"},"importAs":"@limble/limble-tree"}
{
"name": "@limble/limble-tree",
"version": "0.3.1",
"version": "0.4.0",
"peerDependencies": {

@@ -5,0 +5,0 @@ "@angular/common": "^11.0.9",

@@ -15,2 +15,14 @@ # Limble Tree

### Features
- Unlimited tree depth
- Can have a different component rendered for each node in the tree
- Can drag nodes from one location in the tree to other locations
- Dragging can be turned off for all or some of the nodes
- Easy nesting of nodes
- Nesting can be turned off for all or some of the nodes
- Nodes can be dropped into other limble trees
- Supports drag handles
- Catchable events are fired when the tree renders and when a drop occurs
### Versioning

@@ -86,4 +98,4 @@

- `indent`: The number of pixels to indent for each level of the tree. Defaults to 45.
- `allowNesting`: Whether to allow "nesting" (placing a node one level deeper than currently exists on the branch) when dragging a node. May be a boolean or a callback function that returns a boolean. If it is a callback, the callback will be called for each node and the node will be passed in to the callback. Defaults to true.
- `allowDragging`: Whether to allow drag-and-drop functionality. May be a boolean or a callback function that returns a boolean. If it is a callback, the callback will be called for each node and the node will be passed in to the callback. Defaults to true.
- `allowNesting`: Whether to allow "nesting" (placing a node one level deeper than currently exists on the branch) under a node. May be a boolean or a callback function that returns a boolean. If it is a callback, the callback will be called for each node when another node is attempting to nest under it. The parent node (the one which is potentially being nested under) will be passed in to the callback. Defaults to true.
- `allowDragging`: Whether to allow drag-and-drop functionality. May be a boolean or a callback function that returns a boolean. If it is a callback, the callback will be called for each node when a drag is attempted on it, and that node will be passed in to the callback. Defaults to true.

@@ -114,2 +126,6 @@ ### The LimbleTreeRoot Component

### Drag Handles
Adding the `limble-tree-handle` css class to an element in a node component will designate that element as the drag handle, making it so the node can only be dragged by clicking on that element.
### Demo App

@@ -116,0 +132,0 @@

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc