@stemy/backend 2.7.4 → 2.8.3
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/bundles/stemy-backend.umd.js +400 -222
- package/bundles/stemy-backend.umd.js.map +1 -1
- package/bundles/stemy-backend.umd.min.js +1 -1
- package/bundles/stemy-backend.umd.min.js.map +1 -1
- package/common-types.d.ts +17 -8
- package/esm2015/common-types.js +1 -1
- package/esm2015/services/assets.js +21 -4
- package/esm2015/services/configuration.js +4 -2
- package/esm2015/services/entities/asset.js +16 -21
- package/esm2015/services/entities/base-entity.js +37 -0
- package/esm2015/services/entities/lazy-asset.js +42 -45
- package/esm2015/services/entities/progress.js +72 -54
- package/esm2015/services/lazy-assets.js +9 -5
- package/esm2015/services/progresses.js +10 -6
- package/esm2015/utilities/di-container.js +4 -4
- package/esm2015/utilities/lazy-asset-generator.js +7 -2
- package/esm2015/utilities/tree.js +11 -7
- package/fesm2015/stemy-backend.js +231 -151
- package/fesm2015/stemy-backend.js.map +1 -1
- package/package.json +1 -1
- package/services/assets.d.ts +1 -0
- package/services/entities/asset.d.ts +6 -9
- package/services/entities/base-entity.d.ts +13 -0
- package/services/entities/lazy-asset.d.ts +6 -12
- package/services/entities/progress.d.ts +18 -20
- package/stemy-backend.metadata.json +1 -1
- package/utilities/di-container.d.ts +1 -1
- package/utilities/tree.d.ts +2 -1
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { isString } from "../utils";
|
|
2
2
|
export class Tree {
|
|
3
|
-
constructor(container, path) {
|
|
3
|
+
constructor(container, exists, path) {
|
|
4
4
|
this.container = container;
|
|
5
|
+
this.exists = exists;
|
|
5
6
|
this.path = path;
|
|
6
7
|
this.map = new Map();
|
|
7
8
|
}
|
|
@@ -9,7 +10,7 @@ export class Tree {
|
|
|
9
10
|
return this.container.parent.tree;
|
|
10
11
|
}
|
|
11
12
|
resolveService() {
|
|
12
|
-
return this.container.resolve(this.path);
|
|
13
|
+
return !this.exists ? null : this.container.resolve(this.path);
|
|
13
14
|
}
|
|
14
15
|
resolveLeaves() {
|
|
15
16
|
let map;
|
|
@@ -50,7 +51,7 @@ export class Tree {
|
|
|
50
51
|
parentTree = parentTree.resolveAncestor(path);
|
|
51
52
|
}
|
|
52
53
|
catch (e) {
|
|
53
|
-
parentTree = new Tree(this.container, "");
|
|
54
|
+
parentTree = new Tree(this.container, false, "");
|
|
54
55
|
}
|
|
55
56
|
const pathParts = path.split(".");
|
|
56
57
|
let tree = this;
|
|
@@ -73,7 +74,7 @@ export class Tree {
|
|
|
73
74
|
}
|
|
74
75
|
resolvePath(path, throwError = true) {
|
|
75
76
|
const absolutePath = !this.path ? path : `${this.path}.${path}`;
|
|
76
|
-
let tree = new Tree(this.container, absolutePath);
|
|
77
|
+
let tree = new Tree(this.container, false, absolutePath);
|
|
77
78
|
try {
|
|
78
79
|
tree = this.resolveAncestor(path);
|
|
79
80
|
}
|
|
@@ -96,16 +97,19 @@ export class Tree {
|
|
|
96
97
|
return this;
|
|
97
98
|
}
|
|
98
99
|
const pathParts = path.split(".");
|
|
100
|
+
const maxIx = pathParts.length - 1;
|
|
99
101
|
let tree = this;
|
|
100
102
|
path = this.path;
|
|
101
|
-
for (let
|
|
103
|
+
for (let ix = 0; ix <= maxIx; ix++) {
|
|
104
|
+
const part = pathParts[ix];
|
|
102
105
|
if (!tree.map.has(part)) {
|
|
103
|
-
tree.map.set(part, new Tree(this.container, !path ? part : `${path}.${part}`));
|
|
106
|
+
tree.map.set(part, new Tree(this.container, false, !path ? part : `${path}.${part}`));
|
|
104
107
|
}
|
|
105
108
|
tree = tree.map.get(part);
|
|
109
|
+
tree.exists = tree.exists || ix == maxIx;
|
|
106
110
|
path = tree.path;
|
|
107
111
|
}
|
|
108
112
|
return this;
|
|
109
113
|
}
|
|
110
114
|
}
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.js","sourceRoot":"","sources":["../../../src/utilities/tree.ts"],"names":[],"mappings":"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","sourcesContent":["import {IDependencyContainer, ITree} from \"../common-types\";\r\nimport {isString} from \"../utils\";\r\n\r\nexport class Tree implements ITree {\r\n\r\n    protected map: Map<string, Tree>;\r\n\r\n    protected get parentTree(): ITree {\r\n        return this.container.parent.tree;\r\n    }\r\n\r\n    constructor(protected container: IDependencyContainer, readonly path: string) {\r\n        this.map = new Map<string, Tree>();\r\n    }\r\n\r\n    resolveService(): any {\r\n        return this.container.resolve(this.path);\r\n    }\r\n\r\n    resolveLeaves(): Map<string, ITree> {\r\n        let map: Map<string, ITree>;\r\n        try {\r\n            const parentTree = this.parentTree.resolvePath(this.path);\r\n            map = parentTree.resolveLeaves();\r\n        } catch (e) {\r\n            map = new Map<string, ITree>();\r\n        }\r\n        const visitor = (treeMap: Map<string, Tree>, path: string) => {\r\n            treeMap.forEach((tree, key) => {\r\n                const subKey = !path ? key : `${path}.${key}`;\r\n                if (tree.map.size == 0) {\r\n                    map.set(subKey, tree);\r\n                    return;\r\n                }\r\n                visitor(tree.map, subKey);\r\n            });\r\n        };\r\n        visitor(this.map, \"\");\r\n        return map;\r\n    }\r\n\r\n    resolveServices(): Map<string, any> {\r\n        const map = new Map<string, any>();\r\n        this.resolveLeaves().forEach((leaf, key) => {\r\n            map.set(key, leaf.resolveService());\r\n        });\r\n        return map;\r\n    }\r\n\r\n    resolveAncestor(path: string): ITree {\r\n        if (!isString(path) || path.length == 0) {\r\n            return this;\r\n        }\r\n        let parentTree: ITree;\r\n        try {\r\n            parentTree = this.parentTree.resolvePath(this.path);\r\n            parentTree = parentTree.resolveAncestor(path);\r\n        } catch (e) {\r\n            parentTree = new Tree(this.container, \"\");\r\n        }\r\n        const pathParts = path.split(\".\");\r\n        let tree: Tree = this;\r\n        let previousTree: Tree = this;\r\n        for (let part of pathParts) {\r\n            tree = tree.map.get(part);\r\n            if (!tree) {\r\n                if (previousTree == this) {\r\n                    if (parentTree.path.length > 0) {\r\n                        return parentTree;\r\n                    }\r\n                    throw new Error(`Ancestor '${path}' not found in current tree: '${this.path}'`);\r\n                }\r\n                return previousTree;\r\n            }\r\n            previousTree = tree;\r\n        }\r\n        return parentTree.path.length > previousTree.path.length\r\n            ? parentTree : previousTree;\r\n    }\r\n\r\n    resolvePath(path: string, throwError: boolean = true): ITree {\r\n        const absolutePath = !this.path ? path : `${this.path}.${path}`;\r\n        let tree: ITree = new Tree(this.container, absolutePath);\r\n        try {\r\n            tree = this.resolveAncestor(path);\r\n        } catch (e) {\r\n            if (throwError) {\r\n                throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);\r\n            }\r\n            return tree;\r\n        }\r\n        if (tree.path !== absolutePath) {\r\n            if (throwError) {\r\n                throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);\r\n            }\r\n            return tree;\r\n        }\r\n        return tree;\r\n    }\r\n\r\n    addPath(path: string): this {\r\n        if (!isString(path) || path.length == 0) {\r\n            return this;\r\n        }\r\n        const pathParts = path.split(\".\");\r\n        let tree: Tree = this;\r\n        path = this.path;\r\n        for (let part of pathParts) {\r\n            if (!tree.map.has(part)) {\r\n                tree.map.set(part, new Tree(this.container, !path ? part : `${path}.${part}`))\r\n            }\r\n            tree = tree.map.get(part);\r\n            path = tree.path;\r\n        }\r\n        return this;\r\n    }\r\n}\r\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.js","sourceRoot":"","sources":["../../../src/utilities/tree.ts"],"names":[],"mappings":"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","sourcesContent":["import {IDependencyContainer, ITree} from \"../common-types\";\r\nimport {isString} from \"../utils\";\r\n\r\nexport class Tree implements ITree {\r\n\r\n    protected map: Map<string, Tree>;\r\n\r\n    protected get parentTree(): ITree {\r\n        return this.container.parent.tree;\r\n    }\r\n\r\n    constructor(protected container: IDependencyContainer, protected exists: boolean, readonly path: string) {\r\n        this.map = new Map<string, Tree>();\r\n    }\r\n\r\n    resolveService(): any {\r\n        return !this.exists ? null : this.container.resolve(this.path);\r\n    }\r\n\r\n    resolveLeaves(): Map<string, ITree> {\r\n        let map: Map<string, ITree>;\r\n        try {\r\n            const parentTree = this.parentTree.resolvePath(this.path);\r\n            map = parentTree.resolveLeaves();\r\n        } catch (e) {\r\n            map = new Map<string, ITree>();\r\n        }\r\n        const visitor = (treeMap: Map<string, Tree>, path: string) => {\r\n            treeMap.forEach((tree, key) => {\r\n                const subKey = !path ? key : `${path}.${key}`;\r\n                if (tree.map.size == 0) {\r\n                    map.set(subKey, tree);\r\n                    return;\r\n                }\r\n                visitor(tree.map, subKey);\r\n            });\r\n        };\r\n        visitor(this.map, \"\");\r\n        return map;\r\n    }\r\n\r\n    resolveServices(): Map<string, any> {\r\n        const map = new Map<string, any>();\r\n        this.resolveLeaves().forEach((leaf, key) => {\r\n            map.set(key, leaf.resolveService());\r\n        });\r\n        return map;\r\n    }\r\n\r\n    resolveAncestor(path: string): ITree {\r\n        if (!isString(path) || path.length == 0) {\r\n            return this;\r\n        }\r\n        let parentTree: ITree;\r\n        try {\r\n            parentTree = this.parentTree.resolvePath(this.path);\r\n            parentTree = parentTree.resolveAncestor(path);\r\n        } catch (e) {\r\n            parentTree = new Tree(this.container, false, \"\");\r\n        }\r\n        const pathParts = path.split(\".\");\r\n        let tree: Tree = this;\r\n        let previousTree: Tree = this;\r\n        for (let part of pathParts) {\r\n            tree = tree.map.get(part);\r\n            if (!tree) {\r\n                if (previousTree == this) {\r\n                    if (parentTree.path.length > 0) {\r\n                        return parentTree;\r\n                    }\r\n                    throw new Error(`Ancestor '${path}' not found in current tree: '${this.path}'`);\r\n                }\r\n                return previousTree;\r\n            }\r\n            previousTree = tree;\r\n        }\r\n        return parentTree.path.length > previousTree.path.length\r\n            ? parentTree : previousTree;\r\n    }\r\n\r\n    resolvePath(path: string, throwError: boolean = true): ITree {\r\n        const absolutePath = !this.path ? path : `${this.path}.${path}`;\r\n        let tree: ITree = new Tree(this.container, false, absolutePath);\r\n        try {\r\n            tree = this.resolveAncestor(path);\r\n        } catch (e) {\r\n            if (throwError) {\r\n                throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);\r\n            }\r\n            return tree;\r\n        }\r\n        if (tree.path !== absolutePath) {\r\n            if (throwError) {\r\n                throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);\r\n            }\r\n            return tree;\r\n        }\r\n        return tree;\r\n    }\r\n\r\n    addPath(path: string): this {\r\n        if (!isString(path) || path.length == 0) {\r\n            return this;\r\n        }\r\n        const pathParts = path.split(\".\");\r\n        const maxIx = pathParts.length - 1;\r\n        let tree: Tree = this;\r\n        path = this.path;\r\n        for (let ix = 0; ix <= maxIx; ix++) {\r\n            const part = pathParts[ix];\r\n            if (!tree.map.has(part)) {\r\n                tree.map.set(part, new Tree(this.container, false, !path ? part : `${path}.${part}`))\r\n            }\r\n            tree = tree.map.get(part);\r\n            tree.exists = tree.exists || ix == maxIx;\r\n            path = tree.path;\r\n        }\r\n        return this;\r\n    }\r\n}\r\n"]}
|