@limble/limble-tree 0.12.4 → 0.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/README.md +149 -149
  2. package/{esm2015/lib/classes/Branch.js → esm2020/lib/classes/Branch.mjs} +1 -1
  3. package/{esm2015/lib/classes/DropZone.js → esm2020/lib/classes/DropZone.mjs} +1 -1
  4. package/{esm2015/lib/classes/DropZoneLocation.js → esm2020/lib/classes/DropZoneLocation.mjs} +1 -1
  5. package/{esm2015/lib/custom-event-bindings/dragleave-no-change-detect.directive.js → esm2020/lib/custom-event-bindings/dragleave-no-change-detect.directive.mjs} +0 -0
  6. package/{esm2015/lib/custom-event-bindings/dragover-no-change-detect.directive.js → esm2020/lib/custom-event-bindings/dragover-no-change-detect.directive.mjs} +1 -1
  7. package/esm2020/lib/drop-zone/drop-zone.component.mjs +75 -0
  8. package/esm2020/lib/limble-tree-branch/limble-tree-branch.component.mjs +110 -0
  9. package/esm2020/lib/limble-tree-node/limble-tree-node.component.mjs +467 -0
  10. package/{esm2015/lib/limble-tree-placeholder/limble-tree-placeholder.component.js → esm2020/lib/limble-tree-placeholder/limble-tree-placeholder.component.mjs} +3 -8
  11. package/esm2020/lib/limble-tree-root/drop-zone.service.mjs +376 -0
  12. package/esm2020/lib/limble-tree-root/limble-tree-root.component.mjs +172 -0
  13. package/{esm2015/lib/limble-tree-root/tree-construction-status.service.js → esm2020/lib/limble-tree-root/tree-construction-status.service.mjs} +1 -1
  14. package/esm2020/lib/limble-tree-root/tree.service.mjs +297 -0
  15. package/{esm2015/lib/limble-tree.module.js → esm2020/lib/limble-tree.module.mjs} +5 -5
  16. package/{esm2015/lib/singletons/component-creator.service.js → esm2020/lib/singletons/component-creator.service.mjs} +1 -1
  17. package/esm2020/lib/singletons/drag-state.service.mjs +63 -0
  18. package/esm2020/lib/singletons/global-events.service.mjs +136 -0
  19. package/{esm2015/lib/util.js → esm2020/lib/util.mjs} +1 -1
  20. package/{esm2015/limble-limble-tree.js → esm2020/limble-limble-tree.mjs} +0 -0
  21. package/{esm2015/public-api.js → esm2020/public-api.mjs} +1 -1
  22. package/fesm2015/limble-limble-tree.mjs +2256 -0
  23. package/fesm2015/limble-limble-tree.mjs.map +1 -0
  24. package/{fesm2015/limble-limble-tree.js → fesm2020/limble-limble-tree.mjs} +89 -136
  25. package/fesm2020/limble-limble-tree.mjs.map +1 -0
  26. package/{limble-limble-tree.d.ts → index.d.ts} +0 -0
  27. package/lib/custom-event-bindings/dragleave-no-change-detect.directive.d.ts +1 -1
  28. package/lib/custom-event-bindings/dragover-no-change-detect.directive.d.ts +1 -1
  29. package/lib/drop-zone/drop-zone.component.d.ts +1 -1
  30. package/lib/limble-tree-branch/limble-tree-branch.component.d.ts +1 -1
  31. package/lib/limble-tree-node/limble-tree-node.component.d.ts +1 -1
  32. package/lib/limble-tree-placeholder/limble-tree-placeholder.component.d.ts +1 -1
  33. package/lib/limble-tree-root/limble-tree-root.component.d.ts +1 -1
  34. package/package.json +22 -9
  35. package/bundles/limble-limble-tree.umd.js +0 -2910
  36. package/bundles/limble-limble-tree.umd.js.map +0 -1
  37. package/esm2015/lib/drop-zone/drop-zone.component.js +0 -81
  38. package/esm2015/lib/limble-tree-branch/limble-tree-branch.component.js +0 -116
  39. package/esm2015/lib/limble-tree-node/limble-tree-node.component.js +0 -484
  40. package/esm2015/lib/limble-tree-root/drop-zone.service.js +0 -377
  41. package/esm2015/lib/limble-tree-root/limble-tree-root.component.js +0 -178
  42. package/esm2015/lib/limble-tree-root/tree.service.js +0 -301
  43. package/esm2015/lib/singletons/drag-state.service.js +0 -64
  44. package/esm2015/lib/singletons/global-events.service.js +0 -137
  45. package/fesm2015/limble-limble-tree.js.map +0 -1
@@ -0,0 +1,110 @@
1
+ import { Component, Input, ViewChild, ViewContainerRef } from "@angular/core";
2
+ import { DropZone } from "../classes/DropZone";
3
+ import { filter } from "rxjs/operators";
4
+ import { isNestingAllowed } from "../util";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../limble-tree-root/tree.service";
7
+ import * as i2 from "../limble-tree-root/drop-zone.service";
8
+ import * as i3 from "../limble-tree-root/tree-construction-status.service";
9
+ import * as i4 from "@angular/common";
10
+ import * as i5 from "../drop-zone/drop-zone.component";
11
+ const _c0 = ["children"];
12
+ function LimbleTreeBranchComponent_drop_zone_1_Template(rf, ctx) { if (rf & 1) {
13
+ i0.ɵɵelement(0, "drop-zone", 3);
14
+ } if (rf & 2) {
15
+ const ctx_r0 = i0.ɵɵnextContext();
16
+ i0.ɵɵproperty("dropZone", ctx_r0.dropZoneInside);
17
+ } }
18
+ function LimbleTreeBranchComponent_ng_template_3_Template(rf, ctx) { }
19
+ export class LimbleTreeBranchComponent {
20
+ constructor(treeService, changeDetectorRef, dropZoneService, treeConstructionStatus, ngZone) {
21
+ this.treeService = treeService;
22
+ this.changeDetectorRef = changeDetectorRef;
23
+ this.dropZoneService = dropZoneService;
24
+ this.treeConstructionStatus = treeConstructionStatus;
25
+ this.ngZone = ngZone;
26
+ this.treeConstructionStatus.constructing();
27
+ this.indent = this.treeService.treeOptions?.indent;
28
+ this.renderDropZoneInside = false;
29
+ }
30
+ ngOnInit() {
31
+ this.addDropZoneInside();
32
+ this.ngZone.runOutsideAngular(() => {
33
+ if (this.dropZoneInside === undefined) {
34
+ throw new Error("drop zone inside is not defined");
35
+ }
36
+ this.dropZoneInside
37
+ .getCommChannel()
38
+ .pipe(filter((message) => message === "checkRendered"))
39
+ .subscribe(() => {
40
+ if (this.dropZoneInside === undefined ||
41
+ this.branch === undefined) {
42
+ throw new Error("Zones not registered");
43
+ }
44
+ if (isNestingAllowed(this.treeService.treeOptions, this.branch.data)) {
45
+ this.renderDropZoneInside = this.dropZoneInside.isRendered();
46
+ }
47
+ });
48
+ });
49
+ }
50
+ ngAfterViewInit() {
51
+ this.reRender();
52
+ this.setDropZoneHost();
53
+ this.treeConstructionStatus.doneConstructing();
54
+ this.changeDetectorRef.detectChanges();
55
+ }
56
+ ngOnDestroy() {
57
+ if (this.dropZoneInside !== undefined) {
58
+ this.dropZoneService.removeDropZone(this.dropZoneInside);
59
+ }
60
+ this.treeService.cleanupSignal$.next(true);
61
+ }
62
+ addDropZoneInside() {
63
+ if (this.branch === undefined) {
64
+ throw new Error("failed to register drop zone inside");
65
+ }
66
+ this.dropZoneInside = new DropZone([...this.branch.getCoordinates()], 0);
67
+ this.dropZoneService.addDropZone(this.dropZoneInside);
68
+ }
69
+ reRender() {
70
+ if (this.children === undefined || this.branch === undefined) {
71
+ throw new Error("Failed to render limble tree branch");
72
+ }
73
+ this.treeService.renderBranch(this.children, this.branch);
74
+ }
75
+ setDropZoneHost() {
76
+ if (this.children === undefined || this.dropZoneInside === undefined) {
77
+ throw new Error("Failed to add drop zone host");
78
+ }
79
+ this.dropZoneInside.setHost(this.children);
80
+ }
81
+ }
82
+ LimbleTreeBranchComponent.ɵfac = function LimbleTreeBranchComponent_Factory(t) { return new (t || LimbleTreeBranchComponent)(i0.ɵɵdirectiveInject(i1.TreeService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i2.DropZoneService), i0.ɵɵdirectiveInject(i3.TreeConstructionStatus), i0.ɵɵdirectiveInject(i0.NgZone)); };
83
+ LimbleTreeBranchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: LimbleTreeBranchComponent, selectors: [["limble-tree-branch"]], viewQuery: function LimbleTreeBranchComponent_Query(rf, ctx) { if (rf & 1) {
84
+ i0.ɵɵviewQuery(_c0, 5, ViewContainerRef);
85
+ } if (rf & 2) {
86
+ let _t;
87
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.children = _t.first);
88
+ } }, inputs: { branch: "branch" }, decls: 5, vars: 4, consts: [[3, "dropZone", 4, "ngIf"], [1, "limble-child-nodes", 3, "hidden"], ["children", ""], [3, "dropZone"]], template: function LimbleTreeBranchComponent_Template(rf, ctx) { if (rf & 1) {
89
+ i0.ɵɵelementStart(0, "div");
90
+ i0.ɵɵtemplate(1, LimbleTreeBranchComponent_drop_zone_1_Template, 1, 1, "drop-zone", 0);
91
+ i0.ɵɵelementStart(2, "span", 1);
92
+ i0.ɵɵtemplate(3, LimbleTreeBranchComponent_ng_template_3_Template, 0, 0, "ng-template", null, 2, i0.ɵɵtemplateRefExtractor);
93
+ i0.ɵɵelementEnd()();
94
+ } if (rf & 2) {
95
+ i0.ɵɵstyleProp("margin-left", ctx.indent, "px");
96
+ i0.ɵɵadvance(1);
97
+ i0.ɵɵproperty("ngIf", ctx.renderDropZoneInside);
98
+ i0.ɵɵadvance(1);
99
+ i0.ɵɵproperty("hidden", ctx.branch && ctx.branch.data.collapsed);
100
+ } }, dependencies: [i4.NgIf, i5.DropZoneComponent] });
101
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LimbleTreeBranchComponent, [{
102
+ type: Component,
103
+ args: [{ selector: "limble-tree-branch", template: "<div [style.marginLeft.px]=\"indent\">\n <drop-zone\n *ngIf=\"renderDropZoneInside\"\n [dropZone]=\"dropZoneInside\"\n ></drop-zone>\n <span [hidden]=\"branch && branch.data.collapsed\" class=\"limble-child-nodes\">\n <ng-template #children></ng-template>\n </span>\n</div>\n" }]
104
+ }], function () { return [{ type: i1.TreeService }, { type: i0.ChangeDetectorRef }, { type: i2.DropZoneService }, { type: i3.TreeConstructionStatus }, { type: i0.NgZone }]; }, { branch: [{
105
+ type: Input
106
+ }], children: [{
107
+ type: ViewChild,
108
+ args: ["children", { read: ViewContainerRef }]
109
+ }] }); })();
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"limble-tree-branch.component.js","sourceRoot":"","sources":["../../../../../projects/limble-tree/src/lib/limble-tree-branch/limble-tree-branch.component.ts","../../../../../projects/limble-tree/src/lib/limble-tree-branch/limble-tree-branch.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n   AfterViewInit,\n   ChangeDetectorRef,\n   Component,\n   Input,\n   NgZone,\n   OnDestroy,\n   OnInit,\n   ViewChild,\n   ViewContainerRef\n} from \"@angular/core\";\nimport { TreeService } from \"../limble-tree-root/tree.service\";\nimport type { Branch } from \"../classes/Branch\";\nimport { DropZone } from \"../classes/DropZone\";\nimport { filter } from \"rxjs/operators\";\nimport { isNestingAllowed } from \"../util\";\nimport { DropZoneService } from \"../limble-tree-root/drop-zone.service\";\nimport { TreeConstructionStatus } from \"../limble-tree-root/tree-construction-status.service\";\n\n@Component({\n   selector: \"limble-tree-branch\",\n   templateUrl: \"./limble-tree-branch.component.html\",\n   styleUrls: [\"./limble-tree-branch.component.scss\"]\n})\nexport class LimbleTreeBranchComponent\n   implements AfterViewInit, OnInit, OnDestroy {\n   @Input() branch: Branch<any> | undefined;\n\n   @ViewChild(\"children\", { read: ViewContainerRef }) children:\n      | ViewContainerRef\n      | undefined;\n\n   public dropZoneInside: DropZone | undefined;\n   public renderDropZoneInside: boolean;\n\n   public readonly indent;\n\n   constructor(\n      private treeService: TreeService,\n      private readonly changeDetectorRef: ChangeDetectorRef,\n      private readonly dropZoneService: DropZoneService,\n      private readonly treeConstructionStatus: TreeConstructionStatus,\n      private readonly ngZone: NgZone\n   ) {\n      this.treeConstructionStatus.constructing();\n      this.indent = this.treeService.treeOptions?.indent;\n      this.renderDropZoneInside = false;\n   }\n\n   public ngOnInit() {\n      this.addDropZoneInside();\n      this.ngZone.runOutsideAngular(() => {\n         if (this.dropZoneInside === undefined) {\n            throw new Error(\"drop zone inside is not defined\");\n         }\n         this.dropZoneInside\n            .getCommChannel()\n            .pipe(filter((message) => message === \"checkRendered\"))\n            .subscribe(() => {\n               if (\n                  this.dropZoneInside === undefined ||\n                  this.branch === undefined\n               ) {\n                  throw new Error(\"Zones not registered\");\n               }\n               if (\n                  isNestingAllowed(\n                     this.treeService.treeOptions,\n                     this.branch.data\n                  )\n               ) {\n                  this.renderDropZoneInside = this.dropZoneInside.isRendered();\n               }\n            });\n      });\n   }\n\n   public ngAfterViewInit() {\n      this.reRender();\n      this.setDropZoneHost();\n      this.treeConstructionStatus.doneConstructing();\n      this.changeDetectorRef.detectChanges();\n   }\n\n   public ngOnDestroy() {\n      if (this.dropZoneInside !== undefined) {\n         this.dropZoneService.removeDropZone(this.dropZoneInside);\n      }\n      this.treeService.cleanupSignal$.next(true);\n   }\n\n   private addDropZoneInside() {\n      if (this.branch === undefined) {\n         throw new Error(\"failed to register drop zone inside\");\n      }\n      this.dropZoneInside = new DropZone([...this.branch.getCoordinates()], 0);\n      this.dropZoneService.addDropZone(this.dropZoneInside);\n   }\n\n   public reRender() {\n      if (this.children === undefined || this.branch === undefined) {\n         throw new Error(\"Failed to render limble tree branch\");\n      }\n      this.treeService.renderBranch(this.children, this.branch);\n   }\n\n   private setDropZoneHost() {\n      if (this.children === undefined || this.dropZoneInside === undefined) {\n         throw new Error(\"Failed to add drop zone host\");\n      }\n      this.dropZoneInside.setHost(this.children);\n   }\n}\n","<div [style.marginLeft.px]=\"indent\">\n   <drop-zone\n      *ngIf=\"renderDropZoneInside\"\n      [dropZone]=\"dropZoneInside\"\n   ></drop-zone>\n   <span [hidden]=\"branch && branch.data.collapsed\" class=\"limble-child-nodes\">\n      <ng-template #children></ng-template>\n   </span>\n</div>\n"]}