@limble/limble-tree 0.12.2 → 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} +105 -147
  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 +24 -10
  35. package/bundles/limble-limble-tree.umd.js +0 -2905
  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 -372
  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
@@ -1,116 +0,0 @@
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
- var _a;
22
- this.treeService = treeService;
23
- this.changeDetectorRef = changeDetectorRef;
24
- this.dropZoneService = dropZoneService;
25
- this.treeConstructionStatus = treeConstructionStatus;
26
- this.ngZone = ngZone;
27
- this.treeConstructionStatus.constructing();
28
- this.indent = (_a = this.treeService.treeOptions) === null || _a === void 0 ? void 0 : _a.indent;
29
- this.renderDropZoneInside = false;
30
- }
31
- ngOnInit() {
32
- this.addDropZoneInside();
33
- this.ngZone.runOutsideAngular(() => {
34
- if (this.dropZoneInside === undefined) {
35
- throw new Error("drop zone inside is not defined");
36
- }
37
- this.dropZoneInside
38
- .getCommChannel()
39
- .pipe(filter((message) => message === "checkRendered"))
40
- .subscribe(() => {
41
- if (this.dropZoneInside === undefined ||
42
- this.branch === undefined) {
43
- throw new Error("Zones not registered");
44
- }
45
- if (isNestingAllowed(this.treeService.treeOptions, this.branch.data)) {
46
- this.renderDropZoneInside = this.dropZoneInside.isRendered();
47
- }
48
- });
49
- });
50
- }
51
- ngAfterViewInit() {
52
- this.reRender();
53
- this.setDropZoneHost();
54
- this.treeConstructionStatus.doneConstructing();
55
- this.changeDetectorRef.detectChanges();
56
- }
57
- ngOnDestroy() {
58
- if (this.dropZoneInside !== undefined) {
59
- this.dropZoneService.removeDropZone(this.dropZoneInside);
60
- }
61
- this.treeService.cleanupSignal$.next(true);
62
- }
63
- addDropZoneInside() {
64
- if (this.branch === undefined) {
65
- throw new Error("failed to register drop zone inside");
66
- }
67
- this.dropZoneInside = new DropZone([...this.branch.getCoordinates()], 0);
68
- this.dropZoneService.addDropZone(this.dropZoneInside);
69
- }
70
- reRender() {
71
- if (this.children === undefined || this.branch === undefined) {
72
- throw new Error("Failed to render limble tree branch");
73
- }
74
- this.treeService.renderBranch(this.children, this.branch);
75
- }
76
- setDropZoneHost() {
77
- if (this.children === undefined || this.dropZoneInside === undefined) {
78
- throw new Error("Failed to add drop zone host");
79
- }
80
- this.dropZoneInside.setHost(this.children);
81
- }
82
- }
83
- 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)); };
84
- LimbleTreeBranchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: LimbleTreeBranchComponent, selectors: [["limble-tree-branch"]], viewQuery: function LimbleTreeBranchComponent_Query(rf, ctx) { if (rf & 1) {
85
- i0.ɵɵviewQuery(_c0, 5, ViewContainerRef);
86
- } if (rf & 2) {
87
- let _t;
88
- i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.children = _t.first);
89
- } }, 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) {
90
- i0.ɵɵelementStart(0, "div");
91
- i0.ɵɵtemplate(1, LimbleTreeBranchComponent_drop_zone_1_Template, 1, 1, "drop-zone", 0);
92
- i0.ɵɵelementStart(2, "span", 1);
93
- i0.ɵɵtemplate(3, LimbleTreeBranchComponent_ng_template_3_Template, 0, 0, "ng-template", null, 2, i0.ɵɵtemplateRefExtractor);
94
- i0.ɵɵelementEnd();
95
- i0.ɵɵelementEnd();
96
- } if (rf & 2) {
97
- i0.ɵɵstyleProp("margin-left", ctx.indent, "px");
98
- i0.ɵɵadvance(1);
99
- i0.ɵɵproperty("ngIf", ctx.renderDropZoneInside);
100
- i0.ɵɵadvance(1);
101
- i0.ɵɵproperty("hidden", ctx.branch && ctx.branch.data.collapsed);
102
- } }, directives: [i4.NgIf, i5.DropZoneComponent], styles: [""] });
103
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LimbleTreeBranchComponent, [{
104
- type: Component,
105
- args: [{
106
- selector: "limble-tree-branch",
107
- templateUrl: "./limble-tree-branch.component.html",
108
- styleUrls: ["./limble-tree-branch.component.scss"]
109
- }]
110
- }], function () { return [{ type: i1.TreeService }, { type: i0.ChangeDetectorRef }, { type: i2.DropZoneService }, { type: i3.TreeConstructionStatus }, { type: i0.NgZone }]; }, { branch: [{
111
- type: Input
112
- }], children: [{
113
- type: ViewChild,
114
- args: ["children", { read: ViewContainerRef }]
115
- }] }); })();
116
- //# 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 {\r\n   AfterViewInit,\r\n   ChangeDetectorRef,\r\n   Component,\r\n   Input,\r\n   NgZone,\r\n   OnDestroy,\r\n   OnInit,\r\n   ViewChild,\r\n   ViewContainerRef\r\n} from \"@angular/core\";\r\nimport { TreeService } from \"../limble-tree-root/tree.service\";\r\nimport type { Branch } from \"../classes/Branch\";\r\nimport { DropZone } from \"../classes/DropZone\";\r\nimport { filter } from \"rxjs/operators\";\r\nimport { isNestingAllowed } from \"../util\";\r\nimport { DropZoneService } from \"../limble-tree-root/drop-zone.service\";\r\nimport { TreeConstructionStatus } from \"../limble-tree-root/tree-construction-status.service\";\r\n\r\n@Component({\r\n   selector: \"limble-tree-branch\",\r\n   templateUrl: \"./limble-tree-branch.component.html\",\r\n   styleUrls: [\"./limble-tree-branch.component.scss\"]\r\n})\r\nexport class LimbleTreeBranchComponent\r\n   implements AfterViewInit, OnInit, OnDestroy {\r\n   @Input() branch: Branch<any> | undefined;\r\n\r\n   @ViewChild(\"children\", { read: ViewContainerRef }) children:\r\n      | ViewContainerRef\r\n      | undefined;\r\n\r\n   public dropZoneInside: DropZone | undefined;\r\n   public renderDropZoneInside: boolean;\r\n\r\n   public readonly indent;\r\n\r\n   constructor(\r\n      private treeService: TreeService,\r\n      private readonly changeDetectorRef: ChangeDetectorRef,\r\n      private readonly dropZoneService: DropZoneService,\r\n      private readonly treeConstructionStatus: TreeConstructionStatus,\r\n      private readonly ngZone: NgZone\r\n   ) {\r\n      this.treeConstructionStatus.constructing();\r\n      this.indent = this.treeService.treeOptions?.indent;\r\n      this.renderDropZoneInside = false;\r\n   }\r\n\r\n   public ngOnInit() {\r\n      this.addDropZoneInside();\r\n      this.ngZone.runOutsideAngular(() => {\r\n         if (this.dropZoneInside === undefined) {\r\n            throw new Error(\"drop zone inside is not defined\");\r\n         }\r\n         this.dropZoneInside\r\n            .getCommChannel()\r\n            .pipe(filter((message) => message === \"checkRendered\"))\r\n            .subscribe(() => {\r\n               if (\r\n                  this.dropZoneInside === undefined ||\r\n                  this.branch === undefined\r\n               ) {\r\n                  throw new Error(\"Zones not registered\");\r\n               }\r\n               if (\r\n                  isNestingAllowed(\r\n                     this.treeService.treeOptions,\r\n                     this.branch.data\r\n                  )\r\n               ) {\r\n                  this.renderDropZoneInside = this.dropZoneInside.isRendered();\r\n               }\r\n            });\r\n      });\r\n   }\r\n\r\n   public ngAfterViewInit() {\r\n      this.reRender();\r\n      this.setDropZoneHost();\r\n      this.treeConstructionStatus.doneConstructing();\r\n      this.changeDetectorRef.detectChanges();\r\n   }\r\n\r\n   public ngOnDestroy() {\r\n      if (this.dropZoneInside !== undefined) {\r\n         this.dropZoneService.removeDropZone(this.dropZoneInside);\r\n      }\r\n      this.treeService.cleanupSignal$.next(true);\r\n   }\r\n\r\n   private addDropZoneInside() {\r\n      if (this.branch === undefined) {\r\n         throw new Error(\"failed to register drop zone inside\");\r\n      }\r\n      this.dropZoneInside = new DropZone([...this.branch.getCoordinates()], 0);\r\n      this.dropZoneService.addDropZone(this.dropZoneInside);\r\n   }\r\n\r\n   public reRender() {\r\n      if (this.children === undefined || this.branch === undefined) {\r\n         throw new Error(\"Failed to render limble tree branch\");\r\n      }\r\n      this.treeService.renderBranch(this.children, this.branch);\r\n   }\r\n\r\n   private setDropZoneHost() {\r\n      if (this.children === undefined || this.dropZoneInside === undefined) {\r\n         throw new Error(\"Failed to add drop zone host\");\r\n      }\r\n      this.dropZoneInside.setHost(this.children);\r\n   }\r\n}\r\n","<div [style.marginLeft.px]=\"indent\">\r\n   <drop-zone\r\n      *ngIf=\"renderDropZoneInside\"\r\n      [dropZone]=\"dropZoneInside\"\r\n   ></drop-zone>\r\n   <span [hidden]=\"branch && branch.data.collapsed\" class=\"limble-child-nodes\">\r\n      <ng-template #children></ng-template>\r\n   </span>\r\n</div>\r\n"]}