@limble/limble-tree 1.0.0-alpha.1 → 1.0.0-beta.1
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.
- package/README.md +450 -17
- package/esm2020/lib/components/branch/branch.component.mjs +7 -15
- package/esm2020/lib/components/dropzone/dropzone.component.mjs +2 -2
- package/esm2020/lib/components/root/root.component.mjs +3 -4
- package/esm2020/lib/core/branch-options.interface.mjs +1 -1
- package/esm2020/lib/core/configuration/configuration.mjs +1 -1
- package/esm2020/lib/core/configuration/tree-options.interface.mjs +1 -1
- package/esm2020/lib/core/index.mjs +1 -2
- package/esm2020/lib/core/relationship.interface.mjs +1 -1
- package/esm2020/lib/core/tree-branch/branch-controller.mjs +99 -0
- package/esm2020/lib/core/tree-branch/tree-branch.mjs +260 -106
- package/esm2020/lib/core/tree-node-base.mjs +10 -9
- package/esm2020/lib/core/tree-root/root-controller.mjs +42 -0
- package/esm2020/lib/core/tree-root/tree-root.mjs +138 -27
- package/esm2020/lib/core/tree-service/tree.service.mjs +7 -1
- package/esm2020/lib/events/drag/drag-end-event.mjs +9 -7
- package/esm2020/lib/events/drag/drag-start-event.mjs +2 -4
- package/esm2020/lib/events/drag/drop-event.mjs +2 -4
- package/esm2020/lib/events/general/destruction-event.mjs +10 -0
- package/esm2020/lib/events/general/index.mjs +2 -0
- package/esm2020/lib/events/index.mjs +2 -1
- package/esm2020/lib/events/relational/graft-event.mjs +2 -4
- package/esm2020/lib/events/relational/prune-event.mjs +2 -4
- package/esm2020/lib/events/relational/relational-tree-event.interface.mjs +1 -1
- package/esm2020/lib/extras/collapse/collapse.mjs +2 -2
- package/esm2020/lib/extras/collapse/collapse.module.mjs +2 -1
- package/esm2020/lib/extras/collapse/collapse.service.mjs +26 -1
- package/esm2020/lib/extras/drag-and-drop/drag-and-drop.mjs +6 -10
- package/esm2020/lib/extras/drag-and-drop/drag-and-drop.module.mjs +5 -1
- package/esm2020/lib/extras/drag-and-drop/drag-and-drop.service.mjs +21 -5
- package/esm2020/lib/extras/drag-and-drop/draggable.directive.mjs +7 -7
- package/esm2020/lib/extras/drag-and-drop/dragover-no-change-detect.mjs +10 -11
- package/esm2020/lib/extras/drag-and-drop/dropzone-renderer.mjs +9 -7
- package/esm2020/lib/legacy/legacy-component-obj.interface.mjs +1 -1
- package/esm2020/lib/legacy/legacy-tree-data.interface.mjs +1 -1
- package/esm2020/lib/legacy/legacy-tree-options.interface.mjs +1 -1
- package/esm2020/lib/legacy/legacy-tree.mjs +30 -30
- package/esm2020/lib/legacy/limble-tree-root/limble-tree-root.component.mjs +1 -1
- package/esm2020/lib/limble-tree.module.mjs +6 -2
- package/esm2020/lib/structure/branchable.interface.mjs +1 -1
- package/esm2020/lib/structure/component-container.interface.mjs +2 -0
- package/esm2020/lib/structure/index.mjs +2 -5
- package/esm2020/lib/structure/tree-branch-node.interface.mjs +1 -1
- package/esm2020/lib/structure/tree-event.interface.mjs +1 -1
- package/esm2020/lib/structure/tree-node.interface.mjs +1 -1
- package/esm2020/lib/structure/tree-relationship.interface.mjs +1 -1
- package/fesm2015/limble-limble-tree.mjs +821 -376
- package/fesm2015/limble-limble-tree.mjs.map +1 -1
- package/fesm2020/limble-limble-tree.mjs +819 -372
- package/fesm2020/limble-limble-tree.mjs.map +1 -1
- package/lib/core/branch-options.interface.d.ts +1 -1
- package/lib/core/configuration/configuration.d.ts +2 -2
- package/lib/core/configuration/tree-options.interface.d.ts +48 -29
- package/lib/core/index.d.ts +0 -1
- package/lib/core/relationship.interface.d.ts +2 -3
- package/lib/core/tree-branch/branch-controller.d.ts +25 -0
- package/lib/core/tree-branch/tree-branch.d.ts +199 -24
- package/lib/core/tree-node-base.d.ts +4 -5
- package/lib/core/tree-root/root-controller.d.ts +19 -0
- package/lib/core/tree-root/tree-root.d.ts +109 -14
- package/lib/core/tree-service/tree.service.d.ts +8 -2
- package/lib/events/drag/drag-end-event.d.ts +15 -13
- package/lib/events/drag/drag-start-event.d.ts +6 -5
- package/lib/events/drag/drop-event.d.ts +7 -10
- package/lib/events/general/destruction-event.d.ts +8 -0
- package/lib/events/general/index.d.ts +1 -0
- package/lib/events/index.d.ts +1 -0
- package/lib/events/relational/graft-event.d.ts +5 -6
- package/lib/events/relational/prune-event.d.ts +5 -6
- package/lib/events/relational/relational-tree-event.interface.d.ts +5 -1
- package/lib/extras/collapse/collapse.module.d.ts +1 -0
- package/lib/extras/collapse/collapse.service.d.ts +25 -0
- package/lib/extras/drag-and-drop/drag-and-drop.d.ts +2 -3
- package/lib/extras/drag-and-drop/drag-and-drop.module.d.ts +4 -0
- package/lib/extras/drag-and-drop/drag-and-drop.service.d.ts +22 -3
- package/lib/extras/drag-and-drop/draggable.directive.d.ts +4 -5
- package/lib/extras/drag-and-drop/dragover-no-change-detect.d.ts +7 -3
- package/lib/legacy/legacy-component-obj.interface.d.ts +1 -1
- package/lib/legacy/legacy-tree-data.interface.d.ts +1 -1
- package/lib/legacy/legacy-tree-options.interface.d.ts +2 -2
- package/lib/legacy/legacy-tree.d.ts +4 -4
- package/lib/legacy/limble-tree-root/limble-tree-root.component.d.ts +4 -4
- package/lib/limble-tree.module.d.ts +4 -0
- package/lib/structure/branchable.interface.d.ts +0 -1
- package/lib/structure/component-container.interface.d.ts +8 -0
- package/lib/structure/index.d.ts +1 -4
- package/lib/structure/tree-branch-node.interface.d.ts +3 -3
- package/lib/structure/tree-event.interface.d.ts +3 -3
- package/lib/structure/tree-node.interface.d.ts +11 -6
- package/lib/structure/tree-relationship.interface.d.ts +2 -2
- package/package.json +1 -1
- package/esm2020/lib/structure/container-tree-node.interface.mjs +0 -2
- package/esm2020/lib/structure/content-container.interface.mjs +0 -2
- package/esm2020/lib/structure/event-conduit.interface.mjs +0 -2
- package/esm2020/lib/structure/tree-root.node.interface.mjs +0 -2
- package/lib/structure/container-tree-node.interface.d.ts +0 -3
- package/lib/structure/content-container.interface.d.ts +0 -3
- package/lib/structure/event-conduit.interface.d.ts +0 -6
- package/lib/structure/tree-root.node.interface.d.ts +0 -2
|
@@ -14,4 +14,4 @@ class Configuration {
|
|
|
14
14
|
}
|
|
15
15
|
}
|
|
16
16
|
export const config = new Configuration();
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy9saWIvY29yZS9jb25maWd1cmF0aW9uL2NvbmZpZ3VyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxhQUFhO0lBR2hCO1FBRmlCLGtCQUFhLEdBQUcsSUFBSSxHQUFHLEVBQThCLENBQUM7UUFHcEUsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBQ2xDLENBQUM7SUFFTSxTQUFTLENBQUksSUFBaUIsRUFBRSxPQUFvQjtRQUN4RCxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDekMsQ0FBQztJQUVNLFNBQVMsQ0FBQyxJQUFTO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVNLE1BQU0sQ0FBQyxJQUFTO1FBQ3BCLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ25DLENBQUM7Q0FDSDtBQUVELE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxJQUFJLGFBQWEsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUcmVlUm9vdCB9IGZyb20gXCIuLi90cmVlLXJvb3QvdHJlZS1yb290XCI7XG5pbXBvcnQgdHlwZSB7IFRyZWVPcHRpb25zIH0gZnJvbSBcIi4vdHJlZS1vcHRpb25zLmludGVyZmFjZVwiO1xuXG5jbGFzcyBDb25maWd1cmF0aW9uIHtcbiAgIHByaXZhdGUgcmVhZG9ubHkgY29uZmlnU3RvcmFnZSA9IG5ldyBNYXA8VHJlZVJvb3Q8YW55PiwgVHJlZU9wdGlvbnM+KCk7XG5cbiAgIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICAgIHRoaXMuY29uZmlnU3RvcmFnZSA9IG5ldyBNYXAoKTtcbiAgIH1cblxuICAgcHVibGljIHNldENvbmZpZzxUPihyb290OiBUcmVlUm9vdDxUPiwgb3B0aW9uczogVHJlZU9wdGlvbnMpOiB2b2lkIHtcbiAgICAgIHRoaXMuY29uZmlnU3RvcmFnZS5zZXQocm9vdCwgb3B0aW9ucyk7XG4gICB9XG5cbiAgIHB1YmxpYyBnZXRDb25maWcocm9vdDogYW55KTogVHJlZU9wdGlvbnMgfCB1bmRlZmluZWQge1xuICAgICAgcmV0dXJuIHRoaXMuY29uZmlnU3RvcmFnZS5nZXQocm9vdCk7XG4gICB9XG5cbiAgIHB1YmxpYyBkZWxldGUocm9vdDogYW55KTogdm9pZCB7XG4gICAgICB0aGlzLmNvbmZpZ1N0b3JhZ2UuZGVsZXRlKHJvb3QpO1xuICAgfVxufVxuXG5leHBvcnQgY29uc3QgY29uZmlnID0gbmV3IENvbmZpZ3VyYXRpb24oKTtcbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1vcHRpb25zLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpbWJsZS10cmVlL3NyYy9saWIvY29yZS9jb25maWd1cmF0aW9uL3RyZWUtb3B0aW9ucy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVHJlZUJyYW5jaCB9IGZyb20gXCIuLi90cmVlLWJyYW5jaC90cmVlLWJyYW5jaFwiO1xuaW1wb3J0IHR5cGUgeyBUcmVlUm9vdCB9IGZyb20gXCIuLi90cmVlLXJvb3QvdHJlZS1yb290XCI7XG5cbi8qKiBUaGUgY29uZmlndXJhdGlvbiBvcHRpb25zIGZvciBhIHRyZWUsIGFzIGlkZW50aWZpZWQgYnkgYSBUcmVlUm9vdCAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmVlT3B0aW9ucyB7XG4gICBkcmFnQW5kRHJvcD86IHtcbiAgICAgIC8qKlxuICAgICAgICogQSBmdW5jdGlvbiB0aGF0IGRldGVybWluZXMgd2hldGhlciB0byBhbGxvdyBhIG5vZGUgdG8gYmUgZHJhZ2dlZC5cbiAgICAgICAqXG4gICAgICAgKiBAcmVtYXJrc1xuICAgICAgICogUnVucyB3aGVuIGEgZHJhZyBiZWdpbnMsIGJ1dCBiZWZvcmUgdGhlIGJyYW5jaCBpcyBwcnVuZWQgZnJvbSB0aGUgdHJlZS5cbiAgICAgICAqXG4gICAgICAgKiBAcGFyYW0gdHJlZUJyYW5jaCAtIFRoZSBub2RlIG9mIHRoZSB0cmVlIHRoYXQgaXMgYWJvdXQgdG8gYmUgZHJhZ2dlZC5cbiAgICAgICAqXG4gICAgICAgKiBAZGVmYXVsdFZhbHVlIEEgZnVuY3Rpb24gdGhhdCBhbHdheXMgcmV0dXJucyB0cnVlLlxuICAgICAgICpcbiAgICAgICAqIEByZXR1cm5zIGB0cnVlYCBpZiB0aGUgbm9kZSBjYW4gYmUgZHJhZ2dlZDsgYGZhbHNlYCBpZiBpdCBjYW5ub3QuXG4gICAgICAgKi9cbiAgICAgIGFsbG93RHJhZ2dpbmc/OiA8VD4odHJlZUJyYW5jaDogVHJlZUJyYW5jaDxUPikgPT4gYm9vbGVhbjtcblxuICAgICAgLyoqXG4gICAgICAgKiBBIGZ1bmN0aW9uIHRvIGRldGVybWluZSB3aGV0aGVyIGEgc291cmNlTm9kZSBjYW4gYmUgZHJvcHBlZCBhdCBhXG4gICAgICAgKiBwYXJ0aWN1bGFyIGxvY2F0aW9uLlxuICAgICAgICpcbiAgICAgICAqIEByZW1hcmtzXG4gICAgICAgKiBUaGlzIGZ1bmN0aW9uIHJ1bnMganVzdCBiZWZvcmUgZGlzcGxheWluZyBhIGZhbWlseSBvZiBkcm9wem9uZXMuXG4gICAgICAgKlxuICAgICAgICogQHBhcmFtIHNvdXJjZUJyYW5jaCAtIFRoZSBicmFuY2ggdGhhdCBpcyBiZWluZyBkcmFnZ2VkLlxuICAgICAgICogQHBhcmFtIHByb3Bvc2VkUGFyZW50IC0gVGhlIHByb3Bvc2VkIG5ldyBwYXJlbnQgb2YgdGhlIHNvdXJjZUJyYW5jaC5cbiAgICAgICAqIEBwYXJhbSBwcm9wb3NlZEluZGV4IC0gVGhlIHByb3Bvc2VkIG5ldyBpbmRleCBvZiB0aGUgc291cmNlQnJhbmNoLlxuICAgICAgICpcbiAgICAgICAqIEBkZWZhdWx0VmFsdWUgQSBmdW5jdGlvbiB0aGF0IGFsd2F5cyByZXR1cm5zIHRydWUuXG4gICAgICAgKi9cbiAgICAgIGFsbG93RHJvcD86IDxUPihcbiAgICAgICAgIHNvdXJjZUJyYW5jaDogVHJlZUJyYW5jaDxUPixcbiAgICAgICAgIHByb3Bvc2VkUGFyZW50OiBUcmVlQnJhbmNoPFQ+IHwgVHJlZVJvb3Q8VD4sXG4gICAgICAgICBwcm9wb3NlZEluZGV4OiBudW1iZXJcbiAgICAgICkgPT4gYm9vbGVhbjtcblxuICAgICAgLyoqXG4gICAgICAgKiBBIGZ1bmN0aW9uIHRvIGluZGljYXRlIHdoZXRoZXIgdG8gYWxsb3cgXCJuZXN0aW5nXCIgKHBsYWNpbmcgYSBicmFuY2ggYXNcbiAgICAgICAqIGEgY2hpbGQpIG9mIGEgcGFydGljdWxhciBicmFuY2guXG4gICAgICAgKlxuICAgICAgICogQHJlbWFya3NcbiAgICAgICAqIFRoaXMgZnVuY3Rpb24gcnVucyBqdXN0IGJlZm9yZSBkaXNwbGF5aW5nIGEgZmFtaWx5IG9mIGRyb3B6b25lcy5cbiAgICAgICAqXG4gICAgICAgKiBAcGFyYW0gdHJlZUJyYW5jaCAtIFRoZSBub2RlIG9mIHRoZSB0cmVlIHdob3NlIG5lc3RpbmcgY2FwYWJpbGl0eSBpcyBiZWluZ1xuICAgICAgICogY2hlY2tlZC5cbiAgICAgICAqXG4gICAgICAgKiBAZGVmYXVsdFZhbHVlIEEgZnVuY3Rpb24gdGhhdCBhbHdheXMgcmV0dXJucyB0cnVlLlxuICAgICAgICovXG4gICAgICBhbGxvd05lc3Rpbmc/OiA8VD4odHJlZUJyYW5jaDogVHJlZUJyYW5jaDxUPikgPT4gYm9vbGVhbjtcbiAgIH07XG5cbiAgIC8qKlxuICAgICogVGhlIG51bWJlciBvZiBwaXhlbHMgZWFjaCBsZXZlbCBvZiB0aGUgdHJlZSB3aWxsIGJlIGluZGVudGVkIHJlbGF0aXZlIHRvXG4gICAgKiBpdHMgcGFyZW50LlxuICAgICpcbiAgICAqIEBkZWZhdWx0VmFsdWUgMTZcbiAgICAqL1xuICAgaW5kZW50YXRpb24/OiBudW1iZXI7XG59XG4iXX0=
|
|
@@ -2,5 +2,4 @@ export * from "./tree-service/tree.service";
|
|
|
2
2
|
export * from "./tree-root/tree-root";
|
|
3
3
|
export * from "./tree-branch/tree-branch";
|
|
4
4
|
export * from "./configuration/tree-options.interface";
|
|
5
|
-
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saW1ibGUtdHJlZS9zcmMvbGliL2NvcmUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vdHJlZS1zZXJ2aWNlL3RyZWUuc2VydmljZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHJlZS1yb290L3RyZWUtcm9vdFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHJlZS1icmFuY2gvdHJlZS1icmFuY2hcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbmZpZ3VyYXRpb24vdHJlZS1vcHRpb25zLmludGVyZmFjZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29uZmlndXJhdGlvbi9jb25maWd1cmF0aW9uXCI7XG4iXX0=
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saW1ibGUtdHJlZS9zcmMvbGliL2NvcmUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx3Q0FBd0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL3RyZWUtc2VydmljZS90cmVlLnNlcnZpY2VcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3RyZWUtcm9vdC90cmVlLXJvb3RcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3RyZWUtYnJhbmNoL3RyZWUtYnJhbmNoXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb25maWd1cmF0aW9uL3RyZWUtb3B0aW9ucy5pbnRlcmZhY2VcIjtcbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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"]}
|