@limble/limble-tree 0.13.0 → 1.0.0-alpha.2

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 (163) hide show
  1. package/README.md +418 -96
  2. package/esm2020/lib/components/branch/branch.component.mjs +79 -0
  3. package/esm2020/lib/components/dropzone/dropzone.component.mjs +35 -0
  4. package/esm2020/lib/components/host-component.interface.mjs +2 -0
  5. package/esm2020/lib/components/node-component.interface.mjs +2 -0
  6. package/esm2020/lib/components/root/root.component.mjs +36 -0
  7. package/esm2020/lib/core/branch-options.interface.mjs +2 -0
  8. package/esm2020/lib/core/configuration/configuration.mjs +17 -0
  9. package/esm2020/lib/core/configuration/tree-options.interface.mjs +2 -0
  10. package/esm2020/lib/core/index.mjs +6 -0
  11. package/esm2020/lib/core/relationship.interface.mjs +2 -0
  12. package/esm2020/lib/core/tree-branch/branch-controller.mjs +99 -0
  13. package/esm2020/lib/core/tree-branch/tree-branch.mjs +224 -0
  14. package/esm2020/lib/core/tree-node-base.mjs +69 -0
  15. package/esm2020/lib/core/tree-root/root-controller.mjs +42 -0
  16. package/esm2020/lib/core/tree-root/tree-root.mjs +85 -0
  17. package/esm2020/lib/core/tree-service/tree.service.mjs +19 -0
  18. package/esm2020/lib/errors/index.mjs +2 -0
  19. package/esm2020/lib/errors/tree-error.mjs +3 -0
  20. package/esm2020/lib/events/drag/drag-end-event.mjs +28 -0
  21. package/esm2020/lib/events/drag/drag-start-event.mjs +12 -0
  22. package/esm2020/lib/events/drag/drop-event.mjs +20 -0
  23. package/esm2020/lib/events/drag/index.mjs +4 -0
  24. package/esm2020/lib/events/general/destruction-event.mjs +12 -0
  25. package/esm2020/lib/events/general/index.mjs +2 -0
  26. package/esm2020/lib/events/index.mjs +4 -0
  27. package/esm2020/lib/events/relational/graft-event.mjs +24 -0
  28. package/esm2020/lib/events/relational/index.mjs +4 -0
  29. package/esm2020/lib/events/relational/prune-event.mjs +24 -0
  30. package/esm2020/lib/events/relational/relational-tree-event.interface.mjs +2 -0
  31. package/esm2020/lib/extras/collapse/collapse.mjs +33 -0
  32. package/esm2020/lib/extras/collapse/collapse.module.mjs +15 -0
  33. package/esm2020/lib/extras/collapse/collapse.service.mjs +20 -0
  34. package/esm2020/lib/extras/collapse/index.mjs +3 -0
  35. package/esm2020/lib/extras/drag-and-drop/drag-and-drop.mjs +85 -0
  36. package/esm2020/lib/extras/drag-and-drop/drag-and-drop.module.mjs +19 -0
  37. package/esm2020/lib/extras/drag-and-drop/drag-and-drop.service.mjs +28 -0
  38. package/esm2020/lib/extras/drag-and-drop/drag-state.mjs +47 -0
  39. package/esm2020/lib/extras/drag-and-drop/draggable.directive.mjs +30 -0
  40. package/esm2020/lib/extras/drag-and-drop/dragover-no-change-detect.mjs +40 -0
  41. package/esm2020/lib/extras/drag-and-drop/dropzone-renderer.mjs +178 -0
  42. package/esm2020/lib/extras/drag-and-drop/index.mjs +5 -0
  43. package/esm2020/lib/legacy/index.mjs +7 -0
  44. package/esm2020/lib/legacy/legacy-component-obj.interface.mjs +2 -0
  45. package/esm2020/lib/legacy/legacy-tree-data.interface.mjs +2 -0
  46. package/esm2020/lib/legacy/legacy-tree-options.interface.mjs +2 -0
  47. package/esm2020/lib/legacy/legacy-tree.mjs +73 -0
  48. package/esm2020/lib/legacy/limble-tree-legacy.module.mjs +20 -0
  49. package/esm2020/lib/legacy/limble-tree-root/limble-tree-root.component.mjs +78 -0
  50. package/esm2020/lib/limble-tree.module.mjs +21 -47
  51. package/esm2020/lib/structure/branchable.interface.mjs +2 -0
  52. package/esm2020/lib/structure/component-container.interface.mjs +2 -0
  53. package/esm2020/lib/structure/event-conduit.interface.mjs +2 -0
  54. package/esm2020/lib/structure/graftable.interface.mjs +2 -0
  55. package/esm2020/lib/structure/index.mjs +10 -0
  56. package/esm2020/lib/structure/tree-branch-node.interface.mjs +2 -0
  57. package/esm2020/lib/structure/tree-event.interface.mjs +2 -0
  58. package/esm2020/lib/structure/tree-node.interface.mjs +2 -0
  59. package/esm2020/lib/structure/tree-plot.mjs +2 -0
  60. package/esm2020/lib/structure/tree-relationship.interface.mjs +2 -0
  61. package/esm2020/limble-limble-tree.mjs +4 -4
  62. package/esm2020/public-api.mjs +12 -6
  63. package/esm2020/shared/assert.mjs +7 -0
  64. package/fesm2015/limble-limble-tree.mjs +1404 -2226
  65. package/fesm2015/limble-limble-tree.mjs.map +1 -1
  66. package/fesm2020/limble-limble-tree.mjs +1396 -2132
  67. package/fesm2020/limble-limble-tree.mjs.map +1 -1
  68. package/index.d.ts +5 -5
  69. package/lib/components/branch/branch.component.d.ts +26 -0
  70. package/lib/components/dropzone/dropzone.component.d.ts +13 -0
  71. package/lib/components/host-component.interface.d.ts +6 -0
  72. package/lib/components/node-component.interface.d.ts +5 -0
  73. package/lib/components/root/root.component.d.ts +14 -0
  74. package/lib/core/branch-options.interface.d.ts +14 -0
  75. package/lib/core/configuration/configuration.d.ts +11 -0
  76. package/lib/core/configuration/tree-options.interface.d.ts +32 -0
  77. package/lib/core/index.d.ts +5 -0
  78. package/lib/core/relationship.interface.d.ts +5 -0
  79. package/lib/core/tree-branch/branch-controller.d.ts +25 -0
  80. package/lib/core/tree-branch/tree-branch.d.ts +44 -0
  81. package/lib/core/tree-node-base.d.ts +25 -0
  82. package/lib/core/tree-root/root-controller.d.ts +19 -0
  83. package/lib/core/tree-root/tree-root.d.ts +30 -0
  84. package/lib/core/tree-service/tree.service.d.ts +9 -0
  85. package/lib/errors/index.d.ts +1 -0
  86. package/lib/errors/tree-error.d.ts +2 -0
  87. package/lib/events/drag/drag-end-event.d.ts +24 -0
  88. package/lib/events/drag/drag-start-event.d.ts +8 -0
  89. package/lib/events/drag/drop-event.d.ts +13 -0
  90. package/lib/events/drag/index.d.ts +3 -0
  91. package/lib/events/general/destruction-event.d.ts +8 -0
  92. package/lib/events/general/index.d.ts +1 -0
  93. package/lib/events/index.d.ts +3 -0
  94. package/lib/events/relational/graft-event.d.ts +15 -0
  95. package/lib/events/relational/index.d.ts +3 -0
  96. package/lib/events/relational/prune-event.d.ts +15 -0
  97. package/lib/events/relational/relational-tree-event.interface.d.ts +6 -0
  98. package/lib/extras/collapse/collapse.d.ts +11 -0
  99. package/lib/extras/collapse/collapse.module.d.ts +6 -0
  100. package/lib/extras/collapse/collapse.service.d.ts +9 -0
  101. package/lib/extras/collapse/index.d.ts +2 -0
  102. package/lib/extras/drag-and-drop/drag-and-drop.d.ts +16 -0
  103. package/lib/extras/drag-and-drop/drag-and-drop.module.d.ts +8 -0
  104. package/lib/extras/drag-and-drop/drag-and-drop.service.d.ts +16 -0
  105. package/lib/extras/drag-and-drop/drag-state.d.ts +23 -0
  106. package/lib/extras/drag-and-drop/draggable.directive.d.ts +12 -0
  107. package/lib/{custom-event-bindings/dragover-no-change-detect.directive.d.ts → extras/drag-and-drop/dragover-no-change-detect.d.ts} +14 -14
  108. package/lib/extras/drag-and-drop/dropzone-renderer.d.ts +28 -0
  109. package/lib/extras/drag-and-drop/index.d.ts +4 -0
  110. package/lib/legacy/index.d.ts +6 -0
  111. package/lib/legacy/legacy-component-obj.interface.d.ts +13 -0
  112. package/lib/legacy/legacy-tree-data.interface.d.ts +18 -0
  113. package/lib/legacy/legacy-tree-options.interface.d.ts +34 -0
  114. package/lib/legacy/legacy-tree.d.ts +14 -0
  115. package/lib/legacy/limble-tree-legacy.module.d.ts +8 -0
  116. package/lib/legacy/limble-tree-root/limble-tree-root.component.d.ts +28 -0
  117. package/lib/limble-tree.module.d.ts +9 -14
  118. package/lib/structure/branchable.interface.d.ts +4 -0
  119. package/lib/structure/component-container.interface.d.ts +8 -0
  120. package/lib/structure/event-conduit.interface.d.ts +6 -0
  121. package/lib/structure/graftable.interface.d.ts +6 -0
  122. package/lib/structure/index.d.ts +9 -0
  123. package/lib/structure/tree-branch-node.interface.d.ts +5 -0
  124. package/lib/structure/tree-event.interface.d.ts +5 -0
  125. package/lib/structure/tree-node.interface.d.ts +11 -0
  126. package/lib/structure/tree-plot.d.ts +1 -0
  127. package/lib/structure/tree-relationship.interface.d.ts +7 -0
  128. package/package.json +6 -14
  129. package/public-api.d.ts +8 -3
  130. package/shared/assert.d.ts +1 -0
  131. package/esm2020/lib/classes/Branch.mjs +0 -153
  132. package/esm2020/lib/classes/DropZone.mjs +0 -71
  133. package/esm2020/lib/classes/DropZoneLocation.mjs +0 -16
  134. package/esm2020/lib/custom-event-bindings/dragleave-no-change-detect.directive.mjs +0 -33
  135. package/esm2020/lib/custom-event-bindings/dragover-no-change-detect.directive.mjs +0 -39
  136. package/esm2020/lib/drop-zone/drop-zone.component.mjs +0 -75
  137. package/esm2020/lib/limble-tree-branch/limble-tree-branch.component.mjs +0 -110
  138. package/esm2020/lib/limble-tree-node/limble-tree-node.component.mjs +0 -467
  139. package/esm2020/lib/limble-tree-placeholder/limble-tree-placeholder.component.mjs +0 -70
  140. package/esm2020/lib/limble-tree-root/drop-zone.service.mjs +0 -376
  141. package/esm2020/lib/limble-tree-root/limble-tree-root.component.mjs +0 -172
  142. package/esm2020/lib/limble-tree-root/tree-construction-status.service.mjs +0 -33
  143. package/esm2020/lib/limble-tree-root/tree.service.mjs +0 -297
  144. package/esm2020/lib/singletons/component-creator.service.mjs +0 -19
  145. package/esm2020/lib/singletons/drag-state.service.mjs +0 -63
  146. package/esm2020/lib/singletons/global-events.service.mjs +0 -136
  147. package/esm2020/lib/util.mjs +0 -74
  148. package/lib/classes/Branch.d.ts +0 -26
  149. package/lib/classes/DropZone.d.ts +0 -27
  150. package/lib/classes/DropZoneLocation.d.ts +0 -9
  151. package/lib/custom-event-bindings/dragleave-no-change-detect.directive.d.ts +0 -13
  152. package/lib/drop-zone/drop-zone.component.d.ts +0 -18
  153. package/lib/limble-tree-branch/limble-tree-branch.component.d.ts +0 -28
  154. package/lib/limble-tree-node/limble-tree-node.component.d.ts +0 -53
  155. package/lib/limble-tree-placeholder/limble-tree-placeholder.component.d.ts +0 -21
  156. package/lib/limble-tree-root/drop-zone.service.d.ts +0 -62
  157. package/lib/limble-tree-root/limble-tree-root.component.d.ts +0 -37
  158. package/lib/limble-tree-root/tree-construction-status.service.d.ts +0 -15
  159. package/lib/limble-tree-root/tree.service.d.ts +0 -132
  160. package/lib/singletons/component-creator.service.d.ts +0 -9
  161. package/lib/singletons/drag-state.service.d.ts +0 -35
  162. package/lib/singletons/global-events.service.d.ts +0 -13
  163. package/lib/util.d.ts +0 -13
@@ -0,0 +1,79 @@
1
+ import { CommonModule } from "@angular/common";
2
+ import { Component, EventEmitter, Input, NgZone, Output, ViewChild, ViewChildren, ViewContainerRef } from "@angular/core";
3
+ import { map, merge } from "rxjs";
4
+ import { DropzoneComponent } from "../dropzone/dropzone.component";
5
+ import { DragoverNoChangeDetectDirective } from "../../extras/drag-and-drop/dragover-no-change-detect";
6
+ import { assert } from "../../../shared/assert";
7
+ import * as i0 from "@angular/core";
8
+ export class BranchComponent {
9
+ constructor(appRef) {
10
+ this.appRef = appRef;
11
+ this.branchesContainer = undefined;
12
+ this.contentContainer = undefined;
13
+ this.dropzones = undefined;
14
+ this.contentCreated = new EventEmitter();
15
+ this.showDropzones = new EventEmitter();
16
+ this.dropped = new EventEmitter();
17
+ this.showInnerDropzone = false;
18
+ this.showLateralDropzone = false;
19
+ }
20
+ ngAfterViewInit() {
21
+ assert(this.contentContainer !== undefined);
22
+ assert(this.contentToHost !== undefined);
23
+ this.hostedContent = this.contentContainer.createComponent(this.contentToHost);
24
+ this.contentCreated.emit(this.hostedContent.instance);
25
+ assert(this.dropzones !== undefined);
26
+ const inner = this.dropzones.get(0);
27
+ const lateral = this.dropzones.get(1);
28
+ assert(inner !== undefined && lateral !== undefined);
29
+ merge(inner.dropped.pipe(map(() => "inner")), lateral.dropped.pipe(map(() => "lateral"))).subscribe(this.dropped);
30
+ this.hostedContent.changeDetectorRef.detectChanges();
31
+ }
32
+ getHostedContent() {
33
+ return this.hostedContent;
34
+ }
35
+ triggerChangeDetection() {
36
+ if (!NgZone.isInAngularZone()) {
37
+ this.appRef.tick();
38
+ }
39
+ }
40
+ dragoverHandler(event) {
41
+ const elementHeight = event.currentTarget.getBoundingClientRect().height;
42
+ if (event.offsetY < elementHeight / 2) {
43
+ this.showDropzones.emit("upper");
44
+ }
45
+ else {
46
+ this.showDropzones.emit("lower");
47
+ }
48
+ }
49
+ ngOnDestroy() {
50
+ //I'm not 100% sure why, but we have to remove any reference to the
51
+ //componentRef otherwise Angular will never release it for garbage
52
+ //collection.
53
+ this.hostedContent = undefined;
54
+ }
55
+ }
56
+ BranchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BranchComponent, deps: [{ token: i0.ApplicationRef }], target: i0.ɵɵFactoryTarget.Component });
57
+ BranchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BranchComponent, isStandalone: true, selector: "branch", inputs: { contentToHost: "contentToHost" }, outputs: { contentCreated: "contentCreated", showDropzones: "showDropzones", dropped: "dropped" }, viewQueries: [{ propertyName: "branchesContainer", first: true, predicate: ["branchesContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "contentContainer", first: true, predicate: ["contentContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "dropzones", predicate: DropzoneComponent, descendants: true }], ngImport: i0, template: "<div class=\"content\" (dragoverNoChangeDetect)=\"dragoverHandler($event)\">\n <div #contentContainer></div>\n</div>\n<div class=\"branches-container\">\n <dropzone placement=\"inner\" [hidden]=\"!showInnerDropzone\"></dropzone>\n <div #branchesContainer></div>\n</div>\n<dropzone placement=\"lateral\" [hidden]=\"!showLateralDropzone\"></dropzone>\n", styles: [".branches-container{margin-left:16px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: DropzoneComponent, selector: "dropzone", inputs: ["placement"], outputs: ["dropped"] }, { kind: "directive", type: DragoverNoChangeDetectDirective, selector: "[dragoverNoChangeDetect]", inputs: ["dragoverEventThrottle"], outputs: ["dragoverNoChangeDetect"] }] });
58
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BranchComponent, decorators: [{
59
+ type: Component,
60
+ args: [{ standalone: true, selector: "branch", imports: [CommonModule, DropzoneComponent, DragoverNoChangeDetectDirective], template: "<div class=\"content\" (dragoverNoChangeDetect)=\"dragoverHandler($event)\">\n <div #contentContainer></div>\n</div>\n<div class=\"branches-container\">\n <dropzone placement=\"inner\" [hidden]=\"!showInnerDropzone\"></dropzone>\n <div #branchesContainer></div>\n</div>\n<dropzone placement=\"lateral\" [hidden]=\"!showLateralDropzone\"></dropzone>\n", styles: [".branches-container{margin-left:16px}\n"] }]
61
+ }], ctorParameters: function () { return [{ type: i0.ApplicationRef }]; }, propDecorators: { branchesContainer: [{
62
+ type: ViewChild,
63
+ args: ["branchesContainer", { read: ViewContainerRef }]
64
+ }], contentContainer: [{
65
+ type: ViewChild,
66
+ args: ["contentContainer", { read: ViewContainerRef }]
67
+ }], dropzones: [{
68
+ type: ViewChildren,
69
+ args: [DropzoneComponent]
70
+ }], contentToHost: [{
71
+ type: Input
72
+ }], contentCreated: [{
73
+ type: Output
74
+ }], showDropzones: [{
75
+ type: Output
76
+ }], dropped: [{
77
+ type: Output
78
+ }] } });
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"branch.component.js","sourceRoot":"","sources":["../../../../../../projects/limble-tree/src/lib/components/branch/branch.component.ts","../../../../../../projects/limble-tree/src/lib/components/branch/branch.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from \"@angular/common\";\nimport {\n   AfterViewInit,\n   ApplicationRef,\n   Component,\n   ComponentRef,\n   EventEmitter,\n   Input,\n   NgZone,\n   OnDestroy,\n   Output,\n   QueryList,\n   Type,\n   ViewChild,\n   ViewChildren,\n   ViewContainerRef\n} from \"@angular/core\";\nimport { map, merge } from \"rxjs\";\nimport { DropzoneComponent } from \"../dropzone/dropzone.component\";\nimport { HostComponent } from \"../host-component.interface\";\nimport { NodeComponent } from \"../node-component.interface\";\nimport { DragoverNoChangeDetectDirective } from \"../../extras/drag-and-drop/dragover-no-change-detect\";\nimport { assert } from \"../../../shared/assert\";\n\n@Component({\n   standalone: true,\n   selector: \"branch\",\n   templateUrl: \"./branch.component.html\",\n   styleUrls: [\"./branch.component.scss\"],\n   imports: [CommonModule, DropzoneComponent, DragoverNoChangeDetectDirective]\n})\nexport class BranchComponent<T>\n   implements NodeComponent, HostComponent<T>, AfterViewInit, OnDestroy\n{\n   @ViewChild(\"branchesContainer\", { read: ViewContainerRef })\n   branchesContainer: ViewContainerRef | undefined = undefined;\n   @ViewChild(\"contentContainer\", { read: ViewContainerRef })\n   contentContainer: ViewContainerRef | undefined = undefined;\n   @ViewChildren(DropzoneComponent) dropzones:\n      | QueryList<DropzoneComponent>\n      | undefined = undefined;\n\n   @Input() contentToHost?: Type<T>;\n\n   @Output() readonly contentCreated = new EventEmitter<T>();\n   @Output() readonly showDropzones = new EventEmitter<\"upper\" | \"lower\">();\n   @Output() readonly dropped = new EventEmitter<\"inner\" | \"lateral\">();\n\n   public showInnerDropzone: boolean = false;\n   public showLateralDropzone: boolean = false;\n\n   private hostedContent?: ComponentRef<T>;\n\n   public constructor(private readonly appRef: ApplicationRef) {}\n\n   public ngAfterViewInit(): void {\n      assert(this.contentContainer !== undefined);\n      assert(this.contentToHost !== undefined);\n      this.hostedContent = this.contentContainer.createComponent(\n         this.contentToHost\n      );\n      this.contentCreated.emit(this.hostedContent.instance);\n      assert(this.dropzones !== undefined);\n      const inner = this.dropzones.get(0);\n      const lateral = this.dropzones.get(1);\n      assert(inner !== undefined && lateral !== undefined);\n      merge(\n         inner.dropped.pipe(map(() => \"inner\" as const)),\n         lateral.dropped.pipe(map(() => \"lateral\" as const))\n      ).subscribe(this.dropped);\n      this.hostedContent.changeDetectorRef.detectChanges();\n   }\n\n   public getHostedContent(): ComponentRef<T> | undefined {\n      return this.hostedContent;\n   }\n\n   public triggerChangeDetection(): void {\n      if (!NgZone.isInAngularZone()) {\n         this.appRef.tick();\n      }\n   }\n\n   protected dragoverHandler(event: DragEvent): void {\n      const elementHeight = (\n         event.currentTarget as HTMLElement\n      ).getBoundingClientRect().height;\n      if (event.offsetY < elementHeight / 2) {\n         this.showDropzones.emit(\"upper\");\n      } else {\n         this.showDropzones.emit(\"lower\");\n      }\n   }\n\n   public ngOnDestroy(): void {\n      //I'm not 100% sure why, but we have to remove any reference to the\n      //componentRef otherwise Angular will never release it for garbage\n      //collection.\n      this.hostedContent = undefined;\n   }\n}\n","<div class=\"content\" (dragoverNoChangeDetect)=\"dragoverHandler($event)\">\n   <div #contentContainer></div>\n</div>\n<div class=\"branches-container\">\n   <dropzone placement=\"inner\" [hidden]=\"!showInnerDropzone\"></dropzone>\n   <div #branchesContainer></div>\n</div>\n<dropzone placement=\"lateral\" [hidden]=\"!showLateralDropzone\"></dropzone>\n"]}
@@ -0,0 +1,35 @@
1
+ import { CommonModule } from "@angular/common";
2
+ import { Component, EventEmitter, Input, Output } from "@angular/core";
3
+ import { DragoverNoChangeDetectDirective } from "../../extras/drag-and-drop/dragover-no-change-detect";
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ export class DropzoneComponent {
7
+ constructor() {
8
+ this.dropped = new EventEmitter();
9
+ this.active = false;
10
+ }
11
+ dragenterHandler() {
12
+ this.active = true;
13
+ }
14
+ dragleaveHandler() {
15
+ this.active = false;
16
+ }
17
+ dragoverHandler(event) {
18
+ event.preventDefault();
19
+ event.dataTransfer.dropEffect = "move";
20
+ }
21
+ dropHandler(event) {
22
+ this.dropped.emit(event);
23
+ }
24
+ }
25
+ DropzoneComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DropzoneComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
26
+ DropzoneComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DropzoneComponent, isStandalone: true, selector: "dropzone", inputs: { placement: "placement" }, outputs: { dropped: "dropped" }, ngImport: i0, template: "<div\n class=\"dropzone\"\n [ngClass]=\"{ active: active }\"\n (dragenter)=\"dragenterHandler()\"\n (dragleave)=\"dragleaveHandler()\"\n (dragoverNoChangeDetect)=\"dragoverHandler($event)\"\n (drop)=\"dropHandler($event)\"\n></div>\n", styles: [".dropzone{border-radius:8px;border:1px dashed #727374;background-color:#ededed;height:20px;margin:8px 0;transition:height .2s ease-out;animation:animation .2s ease-out}.dropzone.active{border-color:#289e49;border-width:2px;background-color:#d0e8d6;height:48px}@keyframes animation{0%{height:0px;opacity:0}to{height:20px;opacity:1}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: DragoverNoChangeDetectDirective, selector: "[dragoverNoChangeDetect]", inputs: ["dragoverEventThrottle"], outputs: ["dragoverNoChangeDetect"] }] });
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DropzoneComponent, decorators: [{
28
+ type: Component,
29
+ args: [{ standalone: true, selector: "dropzone", imports: [CommonModule, DragoverNoChangeDetectDirective], template: "<div\n class=\"dropzone\"\n [ngClass]=\"{ active: active }\"\n (dragenter)=\"dragenterHandler()\"\n (dragleave)=\"dragleaveHandler()\"\n (dragoverNoChangeDetect)=\"dragoverHandler($event)\"\n (drop)=\"dropHandler($event)\"\n></div>\n", styles: [".dropzone{border-radius:8px;border:1px dashed #727374;background-color:#ededed;height:20px;margin:8px 0;transition:height .2s ease-out;animation:animation .2s ease-out}.dropzone.active{border-color:#289e49;border-width:2px;background-color:#d0e8d6;height:48px}@keyframes animation{0%{height:0px;opacity:0}to{height:20px;opacity:1}}\n"] }]
30
+ }], propDecorators: { placement: [{
31
+ type: Input
32
+ }], dropped: [{
33
+ type: Output
34
+ }] } });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcHpvbmUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGltYmxlLXRyZWUvc3JjL2xpYi9jb21wb25lbnRzL2Ryb3B6b25lL2Ryb3B6b25lLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy9saWIvY29tcG9uZW50cy9kcm9wem9uZS9kcm9wem9uZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RSxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQzs7O0FBU3ZHLE1BQU0sT0FBTyxpQkFBaUI7SUFQOUI7UUFTc0IsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFhLENBQUM7UUFFakQsV0FBTSxHQUFZLEtBQUssQ0FBQztLQWtCcEM7SUFoQlMsZ0JBQWdCO1FBQ3BCLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDO0lBQ3RCLENBQUM7SUFFTSxnQkFBZ0I7UUFDcEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7SUFDdkIsQ0FBQztJQUVNLGVBQWUsQ0FBQyxLQUFnQjtRQUNwQyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDdEIsS0FBSyxDQUFDLFlBQTZCLENBQUMsVUFBVSxHQUFHLE1BQU0sQ0FBQztJQUM1RCxDQUFDO0lBRU0sV0FBVyxDQUFDLEtBQWdCO1FBQ2hDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUM7OytHQXJCUyxpQkFBaUI7bUdBQWpCLGlCQUFpQix5SUNYOUIsdVBBUUEsc1lEQ2EsWUFBWSw2SEFBRSwrQkFBK0I7NEZBRTdDLGlCQUFpQjtrQkFQN0IsU0FBUztpQ0FDSyxJQUFJLFlBQ04sVUFBVSxXQUdYLENBQUMsWUFBWSxFQUFFLCtCQUErQixDQUFDOzhCQUcvQyxTQUFTO3NCQUFqQixLQUFLO2dCQUNhLE9BQU87c0JBQXpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBEcmFnb3Zlck5vQ2hhbmdlRGV0ZWN0RGlyZWN0aXZlIH0gZnJvbSBcIi4uLy4uL2V4dHJhcy9kcmFnLWFuZC1kcm9wL2RyYWdvdmVyLW5vLWNoYW5nZS1kZXRlY3RcIjtcblxuQENvbXBvbmVudCh7XG4gICBzdGFuZGFsb25lOiB0cnVlLFxuICAgc2VsZWN0b3I6IFwiZHJvcHpvbmVcIixcbiAgIHRlbXBsYXRlVXJsOiBcIi4vZHJvcHpvbmUuY29tcG9uZW50Lmh0bWxcIixcbiAgIHN0eWxlVXJsczogW1wiLi9kcm9wem9uZS5jb21wb25lbnQuc2Nzc1wiXSxcbiAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIERyYWdvdmVyTm9DaGFuZ2VEZXRlY3REaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIERyb3B6b25lQ29tcG9uZW50IHtcbiAgIEBJbnB1dCgpIHBsYWNlbWVudD86IFwiaW5uZXJcIiB8IFwibGF0ZXJhbFwiO1xuICAgQE91dHB1dCgpIHJlYWRvbmx5IGRyb3BwZWQgPSBuZXcgRXZlbnRFbWl0dGVyPERyYWdFdmVudD4oKTtcblxuICAgcHJvdGVjdGVkIGFjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICBwdWJsaWMgZHJhZ2VudGVySGFuZGxlcigpOiB2b2lkIHtcbiAgICAgIHRoaXMuYWN0aXZlID0gdHJ1ZTtcbiAgIH1cblxuICAgcHVibGljIGRyYWdsZWF2ZUhhbmRsZXIoKTogdm9pZCB7XG4gICAgICB0aGlzLmFjdGl2ZSA9IGZhbHNlO1xuICAgfVxuXG4gICBwdWJsaWMgZHJhZ292ZXJIYW5kbGVyKGV2ZW50OiBEcmFnRXZlbnQpOiB2b2lkIHtcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAoZXZlbnQuZGF0YVRyYW5zZmVyIGFzIERhdGFUcmFuc2ZlcikuZHJvcEVmZmVjdCA9IFwibW92ZVwiO1xuICAgfVxuXG4gICBwdWJsaWMgZHJvcEhhbmRsZXIoZXZlbnQ6IERyYWdFdmVudCk6IHZvaWQge1xuICAgICAgdGhpcy5kcm9wcGVkLmVtaXQoZXZlbnQpO1xuICAgfVxufVxuIiwiPGRpdlxuICAgY2xhc3M9XCJkcm9wem9uZVwiXG4gICBbbmdDbGFzc109XCJ7IGFjdGl2ZTogYWN0aXZlIH1cIlxuICAgKGRyYWdlbnRlcik9XCJkcmFnZW50ZXJIYW5kbGVyKClcIlxuICAgKGRyYWdsZWF2ZSk9XCJkcmFnbGVhdmVIYW5kbGVyKClcIlxuICAgKGRyYWdvdmVyTm9DaGFuZ2VEZXRlY3QpPVwiZHJhZ292ZXJIYW5kbGVyKCRldmVudClcIlxuICAgKGRyb3ApPVwiZHJvcEhhbmRsZXIoJGV2ZW50KVwiXG4+PC9kaXY+XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9zdC1jb21wb25lbnQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGltYmxlLXRyZWUvc3JjL2xpYi9jb21wb25lbnRzL2hvc3QtY29tcG9uZW50LmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50UmVmLCBFdmVudEVtaXR0ZXIsIFR5cGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEhvc3RDb21wb25lbnQ8VXNlcmxhbmRDb21wb25lbnQ+IHtcbiAgIGNvbnRlbnRDcmVhdGVkOiBFdmVudEVtaXR0ZXI8VXNlcmxhbmRDb21wb25lbnQ+O1xuICAgY29udGVudFRvSG9zdD86IFR5cGU8VXNlcmxhbmRDb21wb25lbnQ+O1xuICAgZ2V0SG9zdGVkQ29udGVudDogKCkgPT4gQ29tcG9uZW50UmVmPFVzZXJsYW5kQ29tcG9uZW50PiB8IHVuZGVmaW5lZDtcbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1jb21wb25lbnQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGltYmxlLXRyZWUvc3JjL2xpYi9jb21wb25lbnRzL25vZGUtY29tcG9uZW50LmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTm9kZUNvbXBvbmVudCB7XG4gICBicmFuY2hlc0NvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZiB8IHVuZGVmaW5lZDtcbiAgIHNob3dJbm5lckRyb3B6b25lOiBib29sZWFuO1xufVxuIl19
@@ -0,0 +1,36 @@
1
+ import { CommonModule } from "@angular/common";
2
+ import { Component, EventEmitter, Output, ViewChild, ViewContainerRef } from "@angular/core";
3
+ import { assert } from "../../../shared/assert";
4
+ import { DropzoneComponent } from "../dropzone/dropzone.component";
5
+ import * as i0 from "@angular/core";
6
+ export class RootComponent {
7
+ constructor() {
8
+ this.branchesContainer = undefined;
9
+ this.dropzone = undefined;
10
+ this.afterViewInit = new EventEmitter();
11
+ this.dropped = new EventEmitter();
12
+ this.showInnerDropzone = false;
13
+ }
14
+ ngAfterViewInit() {
15
+ this.afterViewInit.emit();
16
+ assert(this.dropzone !== undefined);
17
+ this.dropzone.dropped.subscribe(this.dropped);
18
+ }
19
+ }
20
+ RootComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RootComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
21
+ RootComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: RootComponent, isStandalone: true, selector: "root", outputs: { afterViewInit: "afterViewInit", dropped: "dropped" }, viewQueries: [{ propertyName: "branchesContainer", first: true, predicate: ["branchesContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "dropzone", first: true, predicate: DropzoneComponent, descendants: true }], ngImport: i0, template: "<div class=\"branches-container\">\n <dropzone placement=\"inner\" [hidden]=\"!showInnerDropzone\"></dropzone>\n <div #branchesContainer></div>\n</div>\n", styles: [".branches-container{min-width:64px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: DropzoneComponent, selector: "dropzone", inputs: ["placement"], outputs: ["dropped"] }] });
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RootComponent, decorators: [{
23
+ type: Component,
24
+ args: [{ standalone: true, selector: "root", imports: [CommonModule, DropzoneComponent], template: "<div class=\"branches-container\">\n <dropzone placement=\"inner\" [hidden]=\"!showInnerDropzone\"></dropzone>\n <div #branchesContainer></div>\n</div>\n", styles: [".branches-container{min-width:64px}\n"] }]
25
+ }], propDecorators: { branchesContainer: [{
26
+ type: ViewChild,
27
+ args: ["branchesContainer", { read: ViewContainerRef }]
28
+ }], dropzone: [{
29
+ type: ViewChild,
30
+ args: [DropzoneComponent]
31
+ }], afterViewInit: [{
32
+ type: Output
33
+ }], dropped: [{
34
+ type: Output
35
+ }] } });
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9vdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saW1ibGUtdHJlZS9zcmMvbGliL2NvbXBvbmVudHMvcm9vdC9yb290LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy9saWIvY29tcG9uZW50cy9yb290L3Jvb3QuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFFSixTQUFTLEVBQ1QsWUFBWSxFQUNaLE1BQU0sRUFDTixTQUFTLEVBQ1QsZ0JBQWdCLEVBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNoRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFVbkUsTUFBTSxPQUFPLGFBQWE7SUFQMUI7UUFTRyxzQkFBaUIsR0FBaUMsU0FBUyxDQUFDO1FBQzlCLGFBQVEsR0FDbkMsU0FBUyxDQUFDO1FBRU0sa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQ3pDLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRS9DLHNCQUFpQixHQUFZLEtBQUssQ0FBQztLQU81QztJQUxTLGVBQWU7UUFDbkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUMxQixNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsS0FBSyxTQUFTLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pELENBQUM7OzJHQWZTLGFBQWE7K0ZBQWIsYUFBYSxvT0FDaUIsZ0JBQWdCLHdEQUU3QyxpQkFBaUIsZ0RDdkIvQiwrSkFJQSw4RkRjYSxZQUFZLCtCQUFFLGlCQUFpQjs0RkFFL0IsYUFBYTtrQkFQekIsU0FBUztpQ0FDSyxJQUFJLFlBQ04sTUFBTSxXQUdQLENBQUMsWUFBWSxFQUFFLGlCQUFpQixDQUFDOzhCQUkxQyxpQkFBaUI7c0JBRGhCLFNBQVM7dUJBQUMsbUJBQW1CLEVBQUUsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBRTVCLFFBQVE7c0JBQXJDLFNBQVM7dUJBQUMsaUJBQWlCO2dCQUdULGFBQWE7c0JBQS9CLE1BQU07Z0JBQ1ksT0FBTztzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7XG4gICBBZnRlclZpZXdJbml0LFxuICAgQ29tcG9uZW50LFxuICAgRXZlbnRFbWl0dGVyLFxuICAgT3V0cHV0LFxuICAgVmlld0NoaWxkLFxuICAgVmlld0NvbnRhaW5lclJlZlxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgYXNzZXJ0IH0gZnJvbSBcIi4uLy4uLy4uL3NoYXJlZC9hc3NlcnRcIjtcbmltcG9ydCB7IERyb3B6b25lQ29tcG9uZW50IH0gZnJvbSBcIi4uL2Ryb3B6b25lL2Ryb3B6b25lLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgTm9kZUNvbXBvbmVudCB9IGZyb20gXCIuLi9ub2RlLWNvbXBvbmVudC5pbnRlcmZhY2VcIjtcblxuQENvbXBvbmVudCh7XG4gICBzdGFuZGFsb25lOiB0cnVlLFxuICAgc2VsZWN0b3I6IFwicm9vdFwiLFxuICAgdGVtcGxhdGVVcmw6IFwiLi9yb290LmNvbXBvbmVudC5odG1sXCIsXG4gICBzdHlsZVVybHM6IFtcIi4vcm9vdC5jb21wb25lbnQuc2Nzc1wiXSxcbiAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIERyb3B6b25lQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBSb290Q29tcG9uZW50IGltcGxlbWVudHMgTm9kZUNvbXBvbmVudCwgQWZ0ZXJWaWV3SW5pdCB7XG4gICBAVmlld0NoaWxkKFwiYnJhbmNoZXNDb250YWluZXJcIiwgeyByZWFkOiBWaWV3Q29udGFpbmVyUmVmIH0pXG4gICBicmFuY2hlc0NvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZiB8IHVuZGVmaW5lZCA9IHVuZGVmaW5lZDtcbiAgIEBWaWV3Q2hpbGQoRHJvcHpvbmVDb21wb25lbnQpIGRyb3B6b25lOiBEcm9wem9uZUNvbXBvbmVudCB8IHVuZGVmaW5lZCA9XG4gICAgICB1bmRlZmluZWQ7XG5cbiAgIEBPdXRwdXQoKSByZWFkb25seSBhZnRlclZpZXdJbml0ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICAgQE91dHB1dCgpIHJlYWRvbmx5IGRyb3BwZWQgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cbiAgIHB1YmxpYyBzaG93SW5uZXJEcm9wem9uZTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgICAgdGhpcy5hZnRlclZpZXdJbml0LmVtaXQoKTtcbiAgICAgIGFzc2VydCh0aGlzLmRyb3B6b25lICE9PSB1bmRlZmluZWQpO1xuICAgICAgdGhpcy5kcm9wem9uZS5kcm9wcGVkLnN1YnNjcmliZSh0aGlzLmRyb3BwZWQpO1xuICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImJyYW5jaGVzLWNvbnRhaW5lclwiPlxuICAgPGRyb3B6b25lIHBsYWNlbWVudD1cImlubmVyXCIgW2hpZGRlbl09XCIhc2hvd0lubmVyRHJvcHpvbmVcIj48L2Ryb3B6b25lPlxuICAgPGRpdiAjYnJhbmNoZXNDb250YWluZXI+PC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJhbmNoLW9wdGlvbnMuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGltYmxlLXRyZWUvc3JjL2xpYi9jb3JlL2JyYW5jaC1vcHRpb25zLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXZlbnRFbWl0dGVyLCBUeXBlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBCcmFuY2hPcHRpb25zPENvbXBvbmVudD4ge1xuICAgaW5wdXRCaW5kaW5ncz86IHtcbiAgICAgIFtLIGluIGtleW9mIENvbXBvbmVudF0/OiBDb21wb25lbnRbS107XG4gICB9O1xuICAgb3V0cHV0QmluZGluZ3M/OiB7XG4gICAgICBbSyBpbiBrZXlvZiBDb21wb25lbnRdPzogQ29tcG9uZW50W0tdIGV4dGVuZHMgRXZlbnRFbWl0dGVyPGluZmVyIFQ+XG4gICAgICAgICA/ICh2YWx1ZTogVCkgPT4gdm9pZFxuICAgICAgICAgOiBuZXZlcjtcbiAgIH07XG4gICBkZWZhdWx0Q29sbGFwc2VkPzogYm9vbGVhbjtcbiAgIG1ldGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZ1bGxCcmFuY2hPcHRpb25zPENvbXBvbmVudD4gZXh0ZW5kcyBCcmFuY2hPcHRpb25zPENvbXBvbmVudD4ge1xuICAgY29tcG9uZW50OiBUeXBlPENvbXBvbmVudD47XG59XG4iXX0=
@@ -0,0 +1,17 @@
1
+ class Configuration {
2
+ constructor() {
3
+ this.configStorage = new Map();
4
+ this.configStorage = new Map();
5
+ }
6
+ setConfig(root, options) {
7
+ this.configStorage.set(root, options);
8
+ }
9
+ getConfig(root) {
10
+ return this.configStorage.get(root);
11
+ }
12
+ delete(root) {
13
+ this.configStorage.delete(root);
14
+ }
15
+ }
16
+ export const config = new Configuration();
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy9saWIvY29yZS9jb25maWd1cmF0aW9uL2NvbmZpZ3VyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxhQUFhO0lBR2hCO1FBRmlCLGtCQUFhLEdBQUcsSUFBSSxHQUFHLEVBQThCLENBQUM7UUFHcEUsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBQ2xDLENBQUM7SUFFTSxTQUFTLENBQUksSUFBaUIsRUFBRSxPQUFvQjtRQUN4RCxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDekMsQ0FBQztJQUVNLFNBQVMsQ0FBQyxJQUFTO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVNLE1BQU0sQ0FBQyxJQUFTO1FBQ3BCLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ25DLENBQUM7Q0FDSDtBQUVELE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxJQUFJLGFBQWEsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJlZVJvb3QgfSBmcm9tIFwiLi4vdHJlZS1yb290L3RyZWUtcm9vdFwiO1xuaW1wb3J0IHsgVHJlZU9wdGlvbnMgfSBmcm9tIFwiLi90cmVlLW9wdGlvbnMuaW50ZXJmYWNlXCI7XG5cbmNsYXNzIENvbmZpZ3VyYXRpb24ge1xuICAgcHJpdmF0ZSByZWFkb25seSBjb25maWdTdG9yYWdlID0gbmV3IE1hcDxUcmVlUm9vdDxhbnk+LCBUcmVlT3B0aW9ucz4oKTtcblxuICAgcHVibGljIGNvbnN0cnVjdG9yKCkge1xuICAgICAgdGhpcy5jb25maWdTdG9yYWdlID0gbmV3IE1hcCgpO1xuICAgfVxuXG4gICBwdWJsaWMgc2V0Q29uZmlnPFQ+KHJvb3Q6IFRyZWVSb290PFQ+LCBvcHRpb25zOiBUcmVlT3B0aW9ucyk6IHZvaWQge1xuICAgICAgdGhpcy5jb25maWdTdG9yYWdlLnNldChyb290LCBvcHRpb25zKTtcbiAgIH1cblxuICAgcHVibGljIGdldENvbmZpZyhyb290OiBhbnkpOiBUcmVlT3B0aW9ucyB8IHVuZGVmaW5lZCB7XG4gICAgICByZXR1cm4gdGhpcy5jb25maWdTdG9yYWdlLmdldChyb290KTtcbiAgIH1cblxuICAgcHVibGljIGRlbGV0ZShyb290OiBhbnkpOiB2b2lkIHtcbiAgICAgIHRoaXMuY29uZmlnU3RvcmFnZS5kZWxldGUocm9vdCk7XG4gICB9XG59XG5cbmV4cG9ydCBjb25zdCBjb25maWcgPSBuZXcgQ29uZmlndXJhdGlvbigpO1xuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1vcHRpb25zLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy9saWIvY29yZS9jb25maWd1cmF0aW9uL3RyZWUtb3B0aW9ucy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyZWVCcmFuY2ggfSBmcm9tIFwiLi4vdHJlZS1icmFuY2gvdHJlZS1icmFuY2hcIjtcbmltcG9ydCB7IFRyZWVSb290IH0gZnJvbSBcIi4uL3RyZWUtcm9vdC90cmVlLXJvb3RcIjtcblxuZXhwb3J0IGludGVyZmFjZSBUcmVlT3B0aW9ucyB7XG4gICBkcmFnQW5kRHJvcD86IHtcbiAgICAgIC8qKlxuICAgICAgICogQSBmdW5jdGlvbiB0byBpbmRpY2F0ZSB3aGV0aGVyIHRvIGFsbG93IGEgbm9kZSB0byBiZSBkcmFnZ2VkLiBUaGUgbm9kZSBpblxuICAgICAgICogcXVlc3Rpb24gaXMgcGFzc2VkIGluLiBEZWZhdWx0cyB0byBhIGZ1bmN0aW9uIHRoYXQgYWx3YXlzIHJldHVybnMgdHJ1ZS4gVGhpc1xuICAgICAgICogZnVuY3Rpb24gcnVucyB3aGVuIERyYWdBbmREcm9wU2VydmljZS5kcmFnU3RhcnQgcnVucywgYW5kIGJlZm9yZSB0aGUgYnJhbmNoXG4gICAgICAgKiBpcyBwcnVuZWQgZnJvbSB0aGUgdHJlZS5cbiAgICAgICAqL1xuICAgICAgYWxsb3dEcmFnZ2luZz86IDxUPih0cmVlQnJhbmNoOiBUcmVlQnJhbmNoPFQ+KSA9PiBib29sZWFuO1xuXG4gICAgICAvKipcbiAgICAgICAqIEEgZnVuY3Rpb24gdG8gZGV0ZXJtaW5lIHdoZXRoZXIgYSBzb3VyY2VOb2RlIGNhbiBiZSBkcm9wcGVkIGF0IGEgcGFydGljdWxhciBsb2NhdGlvbi5cbiAgICAgICAqIFRoZSBzb3VyY2VOb2RlLCB0aGUgbmV3IHByb3Bvc2VkUGFyZW50IGZvciB0aGUgc291cmNlTm9kZSwgYW5kIHRoZSBuZXcgcHJvcG9zZWRJbmRleFxuICAgICAgICogZm9yIHRoZSBzb3VyY2Ugbm9kZSBhcmUgcGFzc2VkIGluLiBUaGlzIGZ1bmN0aW9uIHJ1bnMganVzdCBiZWZvcmUgZGlzcGxheWluZyBhXG4gICAgICAgKiBmYW1pbHkgb2YgZHJvcHpvbmVzLlxuICAgICAgICovXG4gICAgICBhbGxvd0Ryb3A/OiA8VD4oXG4gICAgICAgICBzb3VyY2VOb2RlOiBUcmVlQnJhbmNoPFQ+LFxuICAgICAgICAgcHJvcG9zZWRQYXJlbnQ6IFRyZWVCcmFuY2g8VD4gfCBUcmVlUm9vdDxUPixcbiAgICAgICAgIHByb3Bvc2VkSW5kZXg6IG51bWJlclxuICAgICAgKSA9PiBib29sZWFuO1xuXG4gICAgICAvKipcbiAgICAgICAqIEEgZnVuY3Rpb24gdG8gaW5kaWNhdGUgd2hldGhlciB0byBhbGxvdyBcIm5lc3RpbmdcIiAocGxhY2luZyBhIGJyYW5jaCBvbmUgbGV2ZWxcbiAgICAgICAqIGRlZXBlciB0aGFuIGl0cyBwYXJlbnQpLiBUaGUgbm9kZSBpbiBxdWVzdGlvbiBpcyBwYXNzZWQgaW4uIERlZmF1bHRzIHRvIGEgZnVuY3Rpb25cbiAgICAgICAqIHRoYXQgYWx3YXlzIHJldHVybnMgdHJ1ZS4gVGhpcyBmdW5jdGlvbiBydW5zIGp1c3QgYmVmb3JlIGRpc3BsYXlpbmcgYSBmYW1pbHkgb2ZcbiAgICAgICAqIGRyb3B6b25lcy5cbiAgICAgICAqL1xuICAgICAgYWxsb3dOZXN0aW5nPzogPFQ+KHRyZWVCcmFuY2g6IFRyZWVCcmFuY2g8VD4pID0+IGJvb2xlYW47XG4gICB9O1xuXG4gICAvKipcbiAgICAqIFRoZSBudW1iZXIgb2YgcGl4ZWxzIGVhY2ggbGV2ZWwgb2YgdGhlIHRyZWUgd2lsbCBiZSBpbmRlbnRlZCByZWxhdGl2ZSB0b1xuICAgICogaXRzIHBhcmVudC4gRGVmYXVsdHMgdG8gMTYuXG4gICAgKi9cbiAgIGluZGVudGF0aW9uPzogbnVtYmVyO1xufVxuIl19
@@ -0,0 +1,6 @@
1
+ export * from "./tree-service/tree.service";
2
+ export * from "./tree-root/tree-root";
3
+ export * from "./tree-branch/tree-branch";
4
+ export * from "./configuration/tree-options.interface";
5
+ export * from "./configuration/configuration";
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saW1ibGUtdHJlZS9zcmMvbGliL2NvcmUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vdHJlZS1zZXJ2aWNlL3RyZWUuc2VydmljZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHJlZS1yb290L3RyZWUtcm9vdFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHJlZS1icmFuY2gvdHJlZS1icmFuY2hcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbmZpZ3VyYXRpb24vdHJlZS1vcHRpb25zLmludGVyZmFjZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29uZmlndXJhdGlvbi9jb25maWd1cmF0aW9uXCI7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb25zaGlwLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy9saWIvY29yZS9yZWxhdGlvbnNoaXAuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOb2RlQ29tcG9uZW50IH0gZnJvbSBcIi4uL2NvbXBvbmVudHMvbm9kZS1jb21wb25lbnQuaW50ZXJmYWNlXCI7XG5pbXBvcnQgeyBUcmVlTm9kZSB9IGZyb20gXCIuLi9zdHJ1Y3R1cmVcIjtcbmltcG9ydCB7IFRyZWVSZWxhdGlvbnNoaXAgfSBmcm9tIFwiLi4vc3RydWN0dXJlL3RyZWUtcmVsYXRpb25zaGlwLmludGVyZmFjZVwiO1xuaW1wb3J0IHsgVHJlZUJyYW5jaCB9IGZyb20gXCIuL3RyZWUtYnJhbmNoL3RyZWUtYnJhbmNoXCI7XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uc2hpcDxVc2VybGFuZENvbXBvbmVudD4gPSBUcmVlUmVsYXRpb25zaGlwPFxuICAgVHJlZU5vZGU8VHJlZUJyYW5jaDxVc2VybGFuZENvbXBvbmVudD4sIE5vZGVDb21wb25lbnQ+LFxuICAgVHJlZUJyYW5jaDxVc2VybGFuZENvbXBvbmVudD5cbj47XG4iXX0=
@@ -0,0 +1,99 @@
1
+ import { createComponent, EnvironmentInjector } from "@angular/core";
2
+ import { assert } from "../../../shared/assert";
3
+ import { filter } from "rxjs";
4
+ import { BranchComponent } from "../../components/branch/branch.component";
5
+ import { dropzoneRenderer } from "../../extras/drag-and-drop/dropzone-renderer";
6
+ /**
7
+ * A wrapper around the BranchComponent that helps instantiate it and handles its events.
8
+ */
9
+ export class BranchController {
10
+ constructor(treeBranch, parentBranchesContainer) {
11
+ this.treeBranch = treeBranch;
12
+ this.outputBindingSubscriptions = [];
13
+ this.branchComponentRef = createComponent(BranchComponent, {
14
+ environmentInjector: parentBranchesContainer.injector.get(EnvironmentInjector)
15
+ });
16
+ this.branchComponentRef.instance.contentToHost =
17
+ this.treeBranch.branchOptions.component;
18
+ this.instanceSubscriptions = this.getInstanceSubscriptions(this.branchComponentRef.instance);
19
+ }
20
+ destroy() {
21
+ this.instanceSubscriptions.forEach((sub) => {
22
+ sub.unsubscribe();
23
+ });
24
+ this.outputBindingSubscriptions.forEach((sub) => {
25
+ sub.unsubscribe();
26
+ });
27
+ }
28
+ detectChanges() {
29
+ this.branchComponentRef.changeDetectorRef.detectChanges();
30
+ }
31
+ getBranchesContainer() {
32
+ return this.branchComponentRef.instance.branchesContainer;
33
+ }
34
+ getComponentInstance() {
35
+ return this.branchComponentRef.instance;
36
+ }
37
+ getHostView() {
38
+ return this.branchComponentRef.hostView;
39
+ }
40
+ getNativeElement() {
41
+ return this.branchComponentRef.location.nativeElement;
42
+ }
43
+ getUserlandComponentRef() {
44
+ return this.branchComponentRef.instance.getHostedContent();
45
+ }
46
+ getContentCreatedSub(instance) {
47
+ return instance.contentCreated.subscribe((userlandComponentInstance) => {
48
+ const component = userlandComponentInstance;
49
+ Object.entries(this.treeBranch.branchOptions.inputBindings ?? {}).forEach(([key, value]) => {
50
+ component[key] = value;
51
+ });
52
+ Object.entries(this.treeBranch.branchOptions.outputBindings ?? {}).forEach(([key, value]) => {
53
+ this.outputBindingSubscriptions.push(component[key].subscribe(value));
54
+ });
55
+ component.treeBranch = this.treeBranch;
56
+ const dropzones = instance.dropzones;
57
+ assert(dropzones !== undefined);
58
+ dropzoneRenderer.registerDropzones(dropzones, this.treeBranch);
59
+ });
60
+ }
61
+ getInstanceSubscriptions(instance) {
62
+ const droppedSub = instance.dropped.subscribe((placement) => {
63
+ dropzoneRenderer.handleDrop(this.treeBranch, placement);
64
+ });
65
+ return [
66
+ this.getContentCreatedSub(instance),
67
+ this.getShowLowerZonesSub(instance),
68
+ this.getShowUpperZonesSub(instance),
69
+ droppedSub
70
+ ];
71
+ }
72
+ getShowLowerZonesSub(instance) {
73
+ return instance.showDropzones
74
+ .pipe(filter((direction) => direction === "lower"))
75
+ .subscribe(() => {
76
+ const currentDropzoneDisplayed = dropzoneRenderer.getCurrentDisplay();
77
+ if (currentDropzoneDisplayed?.treeBranch === this.treeBranch &&
78
+ currentDropzoneDisplayed.direction === "lower") {
79
+ return;
80
+ }
81
+ dropzoneRenderer.showLowerZones(this.treeBranch);
82
+ instance.triggerChangeDetection();
83
+ });
84
+ }
85
+ getShowUpperZonesSub(instance) {
86
+ return instance.showDropzones
87
+ .pipe(filter((direction) => direction === "upper"))
88
+ .subscribe(() => {
89
+ const currentDropzoneDisplayed = dropzoneRenderer.getCurrentDisplay();
90
+ if (currentDropzoneDisplayed?.treeBranch === this.treeBranch &&
91
+ currentDropzoneDisplayed.direction === "upper") {
92
+ return;
93
+ }
94
+ dropzoneRenderer.showUpperZones(this.treeBranch);
95
+ instance.triggerChangeDetection();
96
+ });
97
+ }
98
+ }
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"branch-controller.js","sourceRoot":"","sources":["../../../../../../projects/limble-tree/src/lib/core/tree-branch/branch-controller.ts"],"names":[],"mappings":"AAAA,OAAO,EAEJ,eAAe,EACf,mBAAmB,EAGrB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAgB,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,8CAA8C,CAAC;AAIhF;;GAEG;AACH,MAAM,OAAO,gBAAgB;IAS1B,YACoB,UAAyC,EAC1D,uBAAyC;QADxB,eAAU,GAAV,UAAU,CAA+B;QAG1D,IAAI,CAAC,0BAA0B,GAAG,EAAE,CAAC;QACrC,IAAI,CAAC,kBAAkB,GAAG,eAAe,CAEvC,eAAe,EAAE;YAChB,mBAAmB,EAChB,uBAAuB,CAAC,QAAQ,CAAC,GAAG,CAAC,mBAAmB,CAAC;SAC9D,CAAC,CAAC;QACH,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,aAAa;YAC3C,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC;QAC3C,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,CACvD,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAClC,CAAC;IACL,CAAC;IAEM,OAAO;QACX,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YACxC,GAAG,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,0BAA0B,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YAC7C,GAAG,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;IACN,CAAC;IAEM,aAAa;QACjB,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IAC7D,CAAC;IAEM,oBAAoB;QACxB,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,iBAAiB,CAAC;IAC7D,CAAC;IAEM,oBAAoB;QACxB,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC;IAC3C,CAAC;IAEM,WAAW;QACf,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC;IAC3C,CAAC;IAEM,gBAAgB;QACpB,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,aAAa,CAAC;IACzD,CAAC;IAEM,uBAAuB;QAG3B,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,gBAAgB,EAAE,CAAC;IAC9D,CAAC;IAEO,oBAAoB,CACzB,QAA4C;QAE5C,OAAO,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,yBAAyB,EAAE,EAAE;YACpE,MAAM,SAAS,GAAG,yBAAgC,CAAC;YACnD,MAAM,CAAC,OAAO,CACX,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,IAAI,EAAE,CACnD,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;gBACxB,SAAS,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YAC1B,CAAC,CAAC,CAAC;YACH,MAAM,CAAC,OAAO,CACX,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,cAAc,IAAI,EAAE,CACpD,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;gBACxB,IAAI,CAAC,0BAA0B,CAAC,IAAI,CACjC,SAAS,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CACjC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,SAAS,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;YACvC,MAAM,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC;YACrC,MAAM,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;YAChC,gBAAgB,CAAC,iBAAiB,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,wBAAwB,CAC7B,QAA4C;QAE5C,MAAM,UAAU,GAAG,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;YACzD,gBAAgB,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC;QACH,OAAO;YACJ,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC;YACnC,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC;YACnC,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC;YACnC,UAAU;SACZ,CAAC;IACL,CAAC;IAEO,oBAAoB,CACzB,QAA4C;QAE5C,OAAO,QAAQ,CAAC,aAAa;aACzB,IAAI,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC;aAClD,SAAS,CAAC,GAAG,EAAE;YACb,MAAM,wBAAwB,GAC3B,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;YACxC,IACG,wBAAwB,EAAE,UAAU,KAAK,IAAI,CAAC,UAAU;gBACxD,wBAAwB,CAAC,SAAS,KAAK,OAAO,EAC/C;gBACC,OAAO;aACT;YACD,gBAAgB,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACjD,QAAQ,CAAC,sBAAsB,EAAE,CAAC;QACrC,CAAC,CAAC,CAAC;IACT,CAAC;IAEO,oBAAoB,CACzB,QAA4C;QAE5C,OAAO,QAAQ,CAAC,aAAa;aACzB,IAAI,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC;aAClD,SAAS,CAAC,GAAG,EAAE;YACb,MAAM,wBAAwB,GAC3B,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;YACxC,IACG,wBAAwB,EAAE,UAAU,KAAK,IAAI,CAAC,UAAU;gBACxD,wBAAwB,CAAC,SAAS,KAAK,OAAO,EAC/C;gBACC,OAAO;aACT;YACD,gBAAgB,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACjD,QAAQ,CAAC,sBAAsB,EAAE,CAAC;QACrC,CAAC,CAAC,CAAC;IACT,CAAC;CACH","sourcesContent":["import {\n   ComponentRef,\n   createComponent,\n   EnvironmentInjector,\n   ViewContainerRef,\n   ViewRef\n} from \"@angular/core\";\nimport { assert } from \"../../../shared/assert\";\nimport { filter, Subscription } from \"rxjs\";\nimport { BranchComponent } from \"../../components/branch/branch.component\";\nimport { dropzoneRenderer } from \"../../extras/drag-and-drop/dropzone-renderer\";\nimport { ComponentContainer } from \"../../structure\";\nimport { TreeBranch } from \"./tree-branch\";\n\n/**\n * A wrapper around the BranchComponent that helps instantiate it and handles its events.\n */\nexport class BranchController<UserlandComponent>\n   implements ComponentContainer<BranchComponent<UserlandComponent>>\n{\n   private readonly branchComponentRef: ComponentRef<\n      BranchComponent<UserlandComponent>\n   >;\n   private readonly instanceSubscriptions: Array<Subscription>;\n   private readonly outputBindingSubscriptions: Array<Subscription>;\n\n   public constructor(\n      private readonly treeBranch: TreeBranch<UserlandComponent>,\n      parentBranchesContainer: ViewContainerRef\n   ) {\n      this.outputBindingSubscriptions = [];\n      this.branchComponentRef = createComponent<\n         BranchComponent<UserlandComponent>\n      >(BranchComponent, {\n         environmentInjector:\n            parentBranchesContainer.injector.get(EnvironmentInjector)\n      });\n      this.branchComponentRef.instance.contentToHost =\n         this.treeBranch.branchOptions.component;\n      this.instanceSubscriptions = this.getInstanceSubscriptions(\n         this.branchComponentRef.instance\n      );\n   }\n\n   public destroy(): void {\n      this.instanceSubscriptions.forEach((sub) => {\n         sub.unsubscribe();\n      });\n      this.outputBindingSubscriptions.forEach((sub) => {\n         sub.unsubscribe();\n      });\n   }\n\n   public detectChanges(): void {\n      this.branchComponentRef.changeDetectorRef.detectChanges();\n   }\n\n   public getBranchesContainer(): ViewContainerRef | undefined {\n      return this.branchComponentRef.instance.branchesContainer;\n   }\n\n   public getComponentInstance(): BranchComponent<UserlandComponent> {\n      return this.branchComponentRef.instance;\n   }\n\n   public getHostView(): ViewRef {\n      return this.branchComponentRef.hostView;\n   }\n\n   public getNativeElement(): HTMLElement {\n      return this.branchComponentRef.location.nativeElement;\n   }\n\n   public getUserlandComponentRef():\n      | ComponentRef<UserlandComponent>\n      | undefined {\n      return this.branchComponentRef.instance.getHostedContent();\n   }\n\n   private getContentCreatedSub(\n      instance: BranchComponent<UserlandComponent>\n   ): Subscription {\n      return instance.contentCreated.subscribe((userlandComponentInstance) => {\n         const component = userlandComponentInstance as any;\n         Object.entries(\n            this.treeBranch.branchOptions.inputBindings ?? {}\n         ).forEach(([key, value]) => {\n            component[key] = value;\n         });\n         Object.entries(\n            this.treeBranch.branchOptions.outputBindings ?? {}\n         ).forEach(([key, value]) => {\n            this.outputBindingSubscriptions.push(\n               component[key].subscribe(value)\n            );\n         });\n         component.treeBranch = this.treeBranch;\n         const dropzones = instance.dropzones;\n         assert(dropzones !== undefined);\n         dropzoneRenderer.registerDropzones(dropzones, this.treeBranch);\n      });\n   }\n\n   private getInstanceSubscriptions(\n      instance: BranchComponent<UserlandComponent>\n   ): Array<Subscription> {\n      const droppedSub = instance.dropped.subscribe((placement) => {\n         dropzoneRenderer.handleDrop(this.treeBranch, placement);\n      });\n      return [\n         this.getContentCreatedSub(instance),\n         this.getShowLowerZonesSub(instance),\n         this.getShowUpperZonesSub(instance),\n         droppedSub\n      ];\n   }\n\n   private getShowLowerZonesSub(\n      instance: BranchComponent<UserlandComponent>\n   ): Subscription {\n      return instance.showDropzones\n         .pipe(filter((direction) => direction === \"lower\"))\n         .subscribe(() => {\n            const currentDropzoneDisplayed =\n               dropzoneRenderer.getCurrentDisplay();\n            if (\n               currentDropzoneDisplayed?.treeBranch === this.treeBranch &&\n               currentDropzoneDisplayed.direction === \"lower\"\n            ) {\n               return;\n            }\n            dropzoneRenderer.showLowerZones(this.treeBranch);\n            instance.triggerChangeDetection();\n         });\n   }\n\n   private getShowUpperZonesSub(\n      instance: BranchComponent<UserlandComponent>\n   ): Subscription {\n      return instance.showDropzones\n         .pipe(filter((direction) => direction === \"upper\"))\n         .subscribe(() => {\n            const currentDropzoneDisplayed =\n               dropzoneRenderer.getCurrentDisplay();\n            if (\n               currentDropzoneDisplayed?.treeBranch === this.treeBranch &&\n               currentDropzoneDisplayed.direction === \"upper\"\n            ) {\n               return;\n            }\n            dropzoneRenderer.showUpperZones(this.treeBranch);\n            instance.triggerChangeDetection();\n         });\n   }\n}\n"]}