@decaf-ts/injectable-decorators 1.6.1 → 1.6.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.
- package/LICENSE.md +21 -157
- package/README.md +272 -5
- package/dist/injectable-decorators.cjs +291 -136
- package/dist/injectable-decorators.esm.cjs +291 -136
- package/lib/Injectables.cjs +76 -18
- package/lib/Injectables.d.ts +75 -17
- package/lib/constants.cjs +8 -7
- package/lib/constants.d.ts +7 -6
- package/lib/decorators.cjs +158 -98
- package/lib/decorators.d.ts +80 -19
- package/lib/esm/Injectables.d.ts +75 -17
- package/lib/esm/Injectables.js +77 -19
- package/lib/esm/constants.d.ts +7 -6
- package/lib/esm/constants.js +8 -7
- package/lib/esm/decorators.d.ts +80 -19
- package/lib/esm/decorators.js +159 -98
- package/lib/esm/index.d.ts +6 -8
- package/lib/esm/index.js +12 -14
- package/lib/esm/registry.d.ts +68 -21
- package/lib/esm/registry.js +39 -2
- package/lib/esm/utils.d.ts +9 -9
- package/lib/esm/utils.js +10 -10
- package/lib/index.cjs +7 -9
- package/lib/index.d.ts +6 -8
- package/lib/registry.cjs +39 -2
- package/lib/registry.d.ts +68 -21
- package/lib/utils.cjs +10 -10
- package/lib/utils.d.ts +9 -9
- package/package.json +3 -3
package/lib/esm/utils.d.ts
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import "reflect-metadata";
|
|
2
2
|
/**
|
|
3
|
-
* @
|
|
3
|
+
* @description Reflection metadata key for accessing TypeScript type information.
|
|
4
|
+
* @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.
|
|
4
5
|
* @const TypeKey
|
|
5
|
-
* @memberOf
|
|
6
|
+
* @memberOf module:injectable-decorators
|
|
6
7
|
*/
|
|
7
8
|
export declare const TypeKey = "design:type";
|
|
8
9
|
/**
|
|
9
|
-
* @
|
|
10
|
-
* @
|
|
11
|
-
* @param {
|
|
12
|
-
* @
|
|
13
|
-
*
|
|
14
|
-
* @function
|
|
15
|
-
*
|
|
10
|
+
* @description Extracts the type name from a decorated property using reflection.
|
|
11
|
+
* @summary Retrieves the type from a property decorator by accessing TypeScript's reflection metadata.
|
|
12
|
+
* @param {any} model The target object containing the decorated property
|
|
13
|
+
* @param {string | symbol} propKey The property key (name or symbol) of the decorated property
|
|
14
|
+
* @return {string | undefined} The name of the property type, or undefined if it's a Function type
|
|
15
|
+
* @function getTypeFromDecorator
|
|
16
16
|
* @memberOf module:injectable-decorators
|
|
17
17
|
*/
|
|
18
18
|
export declare function getTypeFromDecorator(model: any, propKey: string | symbol): string | undefined;
|
package/lib/esm/utils.js
CHANGED
|
@@ -1,22 +1,22 @@
|
|
|
1
1
|
import "reflect-metadata";
|
|
2
2
|
/**
|
|
3
|
-
* @
|
|
3
|
+
* @description Reflection metadata key for accessing TypeScript type information.
|
|
4
|
+
* @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.
|
|
4
5
|
* @const TypeKey
|
|
5
|
-
* @memberOf
|
|
6
|
+
* @memberOf module:injectable-decorators
|
|
6
7
|
*/
|
|
7
8
|
export const TypeKey = "design:type";
|
|
8
9
|
/**
|
|
9
|
-
* @
|
|
10
|
-
* @
|
|
11
|
-
* @param {
|
|
12
|
-
* @
|
|
13
|
-
*
|
|
14
|
-
* @function
|
|
15
|
-
*
|
|
10
|
+
* @description Extracts the type name from a decorated property using reflection.
|
|
11
|
+
* @summary Retrieves the type from a property decorator by accessing TypeScript's reflection metadata.
|
|
12
|
+
* @param {any} model The target object containing the decorated property
|
|
13
|
+
* @param {string | symbol} propKey The property key (name or symbol) of the decorated property
|
|
14
|
+
* @return {string | undefined} The name of the property type, or undefined if it's a Function type
|
|
15
|
+
* @function getTypeFromDecorator
|
|
16
16
|
* @memberOf module:injectable-decorators
|
|
17
17
|
*/
|
|
18
18
|
export function getTypeFromDecorator(model, propKey) {
|
|
19
19
|
const typeDef = Reflect.getMetadata(TypeKey, model, propKey);
|
|
20
20
|
return typeDef.name !== "Function" ? typeDef.name : undefined;
|
|
21
21
|
}
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxrQkFBa0IsQ0FBQztBQUUxQjs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUM7QUFFckM7Ozs7Ozs7O0dBUUc7QUFDSCxNQUFNLFVBQVUsb0JBQW9CLENBQ2xDLEtBQVUsRUFDVixPQUF3QjtJQUV4QixNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDN0QsT0FBTyxPQUFPLENBQUMsSUFBSSxLQUFLLFVBQVUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO0FBQ2hFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXCJyZWZsZWN0LW1ldGFkYXRhXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIFJlZmxlY3Rpb24gbWV0YWRhdGEga2V5IGZvciBhY2Nlc3NpbmcgVHlwZVNjcmlwdCB0eXBlIGluZm9ybWF0aW9uLlxuICogQHN1bW1hcnkgSG9sZHMgdGhlIGtleSBmb3IgcmV0cmlldmluZyB0aGUgZGVzaWduIHR5cGUgZnJvbSBUeXBlU2NyaXB0J3MgcmVmbGVjdGlvbiBtZXRhZGF0YS5cbiAqIEBjb25zdCBUeXBlS2V5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmluamVjdGFibGUtZGVjb3JhdG9yc1xuICovXG5leHBvcnQgY29uc3QgVHlwZUtleSA9IFwiZGVzaWduOnR5cGVcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRXh0cmFjdHMgdGhlIHR5cGUgbmFtZSBmcm9tIGEgZGVjb3JhdGVkIHByb3BlcnR5IHVzaW5nIHJlZmxlY3Rpb24uXG4gKiBAc3VtbWFyeSBSZXRyaWV2ZXMgdGhlIHR5cGUgZnJvbSBhIHByb3BlcnR5IGRlY29yYXRvciBieSBhY2Nlc3NpbmcgVHlwZVNjcmlwdCdzIHJlZmxlY3Rpb24gbWV0YWRhdGEuXG4gKiBAcGFyYW0ge2FueX0gbW9kZWwgVGhlIHRhcmdldCBvYmplY3QgY29udGFpbmluZyB0aGUgZGVjb3JhdGVkIHByb3BlcnR5XG4gKiBAcGFyYW0ge3N0cmluZyB8IHN5bWJvbH0gcHJvcEtleSBUaGUgcHJvcGVydHkga2V5IChuYW1lIG9yIHN5bWJvbCkgb2YgdGhlIGRlY29yYXRlZCBwcm9wZXJ0eVxuICogQHJldHVybiB7c3RyaW5nIHwgdW5kZWZpbmVkfSBUaGUgbmFtZSBvZiB0aGUgcHJvcGVydHkgdHlwZSwgb3IgdW5kZWZpbmVkIGlmIGl0J3MgYSBGdW5jdGlvbiB0eXBlXG4gKiBAZnVuY3Rpb24gZ2V0VHlwZUZyb21EZWNvcmF0b3JcbiAqIEBtZW1iZXJPZiBtb2R1bGU6aW5qZWN0YWJsZS1kZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRUeXBlRnJvbURlY29yYXRvcihcbiAgbW9kZWw6IGFueSxcbiAgcHJvcEtleTogc3RyaW5nIHwgc3ltYm9sLFxuKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgY29uc3QgdHlwZURlZiA9IFJlZmxlY3QuZ2V0TWV0YWRhdGEoVHlwZUtleSwgbW9kZWwsIHByb3BLZXkpO1xuICByZXR1cm4gdHlwZURlZi5uYW1lICE9PSBcIkZ1bmN0aW9uXCIgPyB0eXBlRGVmLm5hbWUgOiB1bmRlZmluZWQ7XG59XG4iXX0=
|
package/lib/index.cjs
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
/**
|
|
3
|
+
* @description A lightweight dependency injection library for TypeScript applications.
|
|
3
4
|
* @summary Adds a simple Injectables implementation to create singleton instances of an object
|
|
4
|
-
* and easily inject it into other objects
|
|
5
|
+
* and easily inject it into other objects. Provides decorators for marking classes as injectable
|
|
6
|
+
* and for injecting dependencies into class properties.
|
|
5
7
|
*
|
|
6
8
|
* @module injectable-decorators
|
|
7
9
|
*/
|
|
@@ -21,20 +23,16 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
21
23
|
};
|
|
22
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
23
25
|
exports.VERSION = void 0;
|
|
24
|
-
/**
|
|
25
|
-
* @summary functions that decorate classes or class properties
|
|
26
|
-
* @namespace Decorators
|
|
27
|
-
* @memberOf module:injectable-decorators
|
|
28
|
-
*/
|
|
29
26
|
__exportStar(require("./constants.cjs"), exports);
|
|
30
27
|
__exportStar(require("./decorators.cjs"), exports);
|
|
31
28
|
__exportStar(require("./Injectables.cjs"), exports);
|
|
32
29
|
__exportStar(require("./registry.cjs"), exports);
|
|
33
30
|
__exportStar(require("./utils.cjs"), exports);
|
|
34
31
|
/**
|
|
35
|
-
* @
|
|
32
|
+
* @description Current version of the injectable-decorators library.
|
|
33
|
+
* @summary Defined on library build. Holds the library's current version string.
|
|
36
34
|
* @const VERSION
|
|
37
35
|
* @memberOf module:injectable-decorators
|
|
38
36
|
*/
|
|
39
|
-
exports.VERSION = "1.6.
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
exports.VERSION = "1.6.2";
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7O0dBT0c7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsa0RBQTRCO0FBQzVCLG1EQUE2QjtBQUM3QixvREFBOEI7QUFDOUIsaURBQTJCO0FBQzNCLDhDQUF3QjtBQUV4Qjs7Ozs7R0FLRztBQUNVLFFBQUEsT0FBTyxHQUFHLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGRlc2NyaXB0aW9uIEEgbGlnaHR3ZWlnaHQgZGVwZW5kZW5jeSBpbmplY3Rpb24gbGlicmFyeSBmb3IgVHlwZVNjcmlwdCBhcHBsaWNhdGlvbnMuXG4gKiBAc3VtbWFyeSBBZGRzIGEgc2ltcGxlIEluamVjdGFibGVzIGltcGxlbWVudGF0aW9uIHRvIGNyZWF0ZSBzaW5nbGV0b24gaW5zdGFuY2VzIG9mIGFuIG9iamVjdFxuICogYW5kIGVhc2lseSBpbmplY3QgaXQgaW50byBvdGhlciBvYmplY3RzLiBQcm92aWRlcyBkZWNvcmF0b3JzIGZvciBtYXJraW5nIGNsYXNzZXMgYXMgaW5qZWN0YWJsZVxuICogYW5kIGZvciBpbmplY3RpbmcgZGVwZW5kZW5jaWVzIGludG8gY2xhc3MgcHJvcGVydGllcy5cbiAqXG4gKiBAbW9kdWxlIGluamVjdGFibGUtZGVjb3JhdG9yc1xuICovXG5cbmV4cG9ydCAqIGZyb20gXCIuL2NvbnN0YW50c1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZGVjb3JhdG9yc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vSW5qZWN0YWJsZXNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3JlZ2lzdHJ5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBDdXJyZW50IHZlcnNpb24gb2YgdGhlIGluamVjdGFibGUtZGVjb3JhdG9ycyBsaWJyYXJ5LlxuICogQHN1bW1hcnkgRGVmaW5lZCBvbiBsaWJyYXJ5IGJ1aWxkLiBIb2xkcyB0aGUgbGlicmFyeSdzIGN1cnJlbnQgdmVyc2lvbiBzdHJpbmcuXG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTppbmplY3RhYmxlLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
|
package/lib/index.d.ts
CHANGED
|
@@ -1,22 +1,20 @@
|
|
|
1
1
|
/**
|
|
2
|
+
* @description A lightweight dependency injection library for TypeScript applications.
|
|
2
3
|
* @summary Adds a simple Injectables implementation to create singleton instances of an object
|
|
3
|
-
* and easily inject it into other objects
|
|
4
|
+
* and easily inject it into other objects. Provides decorators for marking classes as injectable
|
|
5
|
+
* and for injecting dependencies into class properties.
|
|
4
6
|
*
|
|
5
7
|
* @module injectable-decorators
|
|
6
8
|
*/
|
|
7
|
-
/**
|
|
8
|
-
* @summary functions that decorate classes or class properties
|
|
9
|
-
* @namespace Decorators
|
|
10
|
-
* @memberOf module:injectable-decorators
|
|
11
|
-
*/
|
|
12
9
|
export * from "./constants";
|
|
13
10
|
export * from "./decorators";
|
|
14
11
|
export * from "./Injectables";
|
|
15
12
|
export * from "./registry";
|
|
16
13
|
export * from "./utils";
|
|
17
14
|
/**
|
|
18
|
-
* @
|
|
15
|
+
* @description Current version of the injectable-decorators library.
|
|
16
|
+
* @summary Defined on library build. Holds the library's current version string.
|
|
19
17
|
* @const VERSION
|
|
20
18
|
* @memberOf module:injectable-decorators
|
|
21
19
|
*/
|
|
22
|
-
export declare const VERSION = "1.6.
|
|
20
|
+
export declare const VERSION = "1.6.2";
|
package/lib/registry.cjs
CHANGED
|
@@ -2,9 +2,46 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.InjectableRegistryImp = void 0;
|
|
4
4
|
/**
|
|
5
|
-
* @
|
|
5
|
+
* @description Default implementation of the InjectablesRegistry interface.
|
|
6
|
+
* @summary Holds the various {@link Injectable}s in a cache and provides methods to register, retrieve, and build them.
|
|
7
|
+
* @template T Type parameter used in the class methods
|
|
8
|
+
*
|
|
6
9
|
* @class InjectableRegistryImp
|
|
7
10
|
* @implements InjectablesRegistry
|
|
11
|
+
*
|
|
12
|
+
* @memberOf module:injectable-decorators
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* // Create a new registry
|
|
16
|
+
* const registry = new InjectableRegistryImp();
|
|
17
|
+
*
|
|
18
|
+
* // Register a class
|
|
19
|
+
* class MyService {
|
|
20
|
+
* doSomething() {
|
|
21
|
+
* return 'Hello World';
|
|
22
|
+
* }
|
|
23
|
+
* }
|
|
24
|
+
* registry.register(MyService, 'MyService', true);
|
|
25
|
+
*
|
|
26
|
+
* // Get the instance
|
|
27
|
+
* const service = registry.get('MyService');
|
|
28
|
+
* service.doSomething(); // 'Hello World'
|
|
29
|
+
*
|
|
30
|
+
* @mermaid
|
|
31
|
+
* sequenceDiagram
|
|
32
|
+
* participant Client
|
|
33
|
+
* participant Registry
|
|
34
|
+
*
|
|
35
|
+
* Client->>Registry: register(MyService)
|
|
36
|
+
* Registry->>Registry: Store in cache
|
|
37
|
+
*
|
|
38
|
+
* Client->>Registry: get("MyService")
|
|
39
|
+
* alt Instance exists and is singleton
|
|
40
|
+
* Registry-->>Client: Return cached instance
|
|
41
|
+
* else No instance or not singleton
|
|
42
|
+
* Registry->>Registry: build(name)
|
|
43
|
+
* Registry-->>Client: Return new instance
|
|
44
|
+
* end
|
|
8
45
|
*/
|
|
9
46
|
class InjectableRegistryImp {
|
|
10
47
|
constructor() {
|
|
@@ -60,4 +97,4 @@ class InjectableRegistryImp {
|
|
|
60
97
|
}
|
|
61
98
|
}
|
|
62
99
|
exports.InjectableRegistryImp = InjectableRegistryImp;
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcmVnaXN0cnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBeUNBOzs7O0dBSUc7QUFDSCxNQUFhLHFCQUFxQjtJQUFsQztRQUNVLFVBQUssR0FBK0IsRUFBRSxDQUFDO0lBNERqRCxDQUFDO0lBMURDOztPQUVHO0lBQ0gsR0FBRyxDQUFJLElBQVksRUFBRSxHQUFHLElBQVc7UUFDakMsSUFBSSxDQUFDO1lBQ0gsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNwQyxNQUFNLFFBQVEsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQztZQUNoQyxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRO2dCQUMvQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUksUUFBUSxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUM7WUFDMUMsT0FBTyxVQUFVLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUksUUFBUSxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUM7WUFDL0QsNkRBQTZEO1FBQy9ELENBQUM7UUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ1gsT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQztJQUNILENBQUM7SUFDRDs7T0FFRztJQUNILFFBQVEsQ0FDTixHQUFrQixFQUNsQixXQUErQixTQUFTLEVBQ3hDLGNBQXVCLElBQUksRUFDM0IsUUFBaUIsS0FBSztRQUV0QixNQUFNLE9BQU8sR0FBd0IsR0FBMEIsQ0FBQztRQUVoRSxNQUFNLFdBQVcsR0FBRyxDQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUksT0FBTyxDQUFDLFdBQVcsQ0FBQztRQUN6RCxJQUFJLE9BQU8sT0FBTyxLQUFLLFVBQVUsSUFBSSxDQUFDLFdBQVc7WUFDL0MsTUFBTSxJQUFJLEtBQUssQ0FDYixrRUFBa0UsQ0FDbkUsQ0FBQztRQUVKLE1BQU0sSUFBSSxHQUNSLFFBQVE7WUFDUixDQUFDLFdBQVcsSUFBSSxXQUFXLENBQUMsSUFBSSxJQUFJLFdBQVcsQ0FBQyxJQUFJLEtBQUssVUFBVTtnQkFDakUsQ0FBQyxDQUFFLFdBQTBDLENBQUMsSUFBSTtnQkFDbEQsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUVwQixJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLO1lBQzVCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUc7Z0JBQ2pCLFFBQVEsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsU0FBUztnQkFDdkMsV0FBVyxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVM7Z0JBQzNDLFNBQVMsRUFBRSxXQUFXO2FBQ3ZCLENBQUM7SUFDTixDQUFDO0lBQ0Q7O09BRUc7SUFDSCxLQUFLLENBQUksSUFBc0IsRUFBRSxHQUFHLElBQVc7UUFDN0MsTUFBTSxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6RCxNQUFNLFFBQVEsR0FBRyxJQUFJLFdBQVcsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHO1lBQ3RCLFFBQVEsRUFBRSxRQUFRO1lBQ2xCLFdBQVcsRUFBRSxXQUFXO1lBQ3hCLFNBQVMsRUFBRSxTQUFTO1NBQ3JCLENBQUM7UUFDRixPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDO0NBQ0Y7QUE3REQsc0RBNkRDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAc3VtbWFyeSBkZWZpbmVzIGFuIEluamVjdGFibGUgdHlwZVxuICogQG1lbWJlck9mIG1vZHVsZTppbmplY3RhYmxlLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IHR5cGUgSW5qZWN0YWJsZTxUPiA9IHsgbmV3ICguLi5hcmdzOiBhbnlbXSk6IFQgfSB8IFQ7XG5cbi8qKlxuICogQHN1bW1hcnkgSW50ZXJmYWNlIGZvciBhbiBpbmplY3RhYmxlIHJlZ2lzdHJ5XG4gKiBAaW50ZXJmYWNlIEluamVjdGFibGVSZWdpc3RyeVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEluamVjdGFibGVzUmVnaXN0cnkge1xuICAvKipcbiAgICogQHN1bW1hcnkgcmV0cmlldmVzIGFuIHtAbGluayBJbmplY3RhYmxlfVxuICAgKiBAcGFyYW0ge3N0cmluZ30gbmFtZVxuICAgKiBAcGFyYW0ge2FueVtdfSBhcmdzXG4gICAqIEByZXR1cm4ge0luamVjdGFibGUgfCB1bmRlZmluZWR9XG4gICAqXG4gICAqIEBtZXRob2RcbiAgICovXG4gIGdldDxUPihuYW1lOiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKTogSW5qZWN0YWJsZTxUPiB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogQHN1bW1hcnkgcmVnaXN0ZXJzIGFuIGluamVjdGFibGUgY29uc3RydWN0b3JcbiAgICogQHBhcmFtIHtJbmplY3RhYmxlfSBjb25zdHJ1Y3RvclxuICAgKiBAcGFyYW0ge2FueVtdfSBhcmdzXG4gICAqXG4gICAqIEBtZXRob2RcbiAgICovXG4gIHJlZ2lzdGVyPFQ+KGNvbnN0cnVjdG9yOiBJbmplY3RhYmxlPFQ+LCAuLi5hcmdzOiBhbnlbXSk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIEBzdW1tYXJ5IEluc3RhbnRpYXRlcyBhbiBJbmplY3RhYmxlXG4gICAqIEBwYXJhbSB7UmVjb3JkPHN0cmluZywgYW55Pn0gb2JqXG4gICAqIEBwYXJhbSB7YW55W119IGFyZ3NcbiAgICogQHJldHVybiBUXG4gICAqXG4gICAqIEBtZXRob2RcbiAgICovXG4gIGJ1aWxkPFQ+KG9iajogUmVjb3JkPHN0cmluZywgYW55PiwgLi4uYXJnczogYW55W10pOiBUO1xufVxuXG4vKipcbiAqIEBzdW1tYXJ5IEhvbGRzIHRoZSB2YWlyb3VzIHtAbGluayBJbmplY3RhYmxlfXNcbiAqIEBjbGFzcyBJbmplY3RhYmxlUmVnaXN0cnlJbXBcbiAqIEBpbXBsZW1lbnRzIEluamVjdGFibGVzUmVnaXN0cnlcbiAqL1xuZXhwb3J0IGNsYXNzIEluamVjdGFibGVSZWdpc3RyeUltcCBpbXBsZW1lbnRzIEluamVjdGFibGVzUmVnaXN0cnkge1xuICBwcml2YXRlIGNhY2hlOiB7IFtpbmRleGVyOiBzdHJpbmddOiBhbnkgfSA9IHt9O1xuXG4gIC8qKlxuICAgKiBAaW5oZXJpdERvY1xuICAgKi9cbiAgZ2V0PFQ+KG5hbWU6IHN0cmluZywgLi4uYXJnczogYW55W10pOiBUIHwgdW5kZWZpbmVkIHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgaW5uZXJDYWNoZSA9IHRoaXMuY2FjaGVbbmFtZV07XG4gICAgICBjb25zdCBidWlsZERlZiA9IHsgbmFtZTogbmFtZSB9O1xuICAgICAgaWYgKCFpbm5lckNhY2hlLnNpbmdsZXRvbiAmJiAhaW5uZXJDYWNoZS5pbnN0YW5jZSlcbiAgICAgICAgcmV0dXJuIHRoaXMuYnVpbGQ8VD4oYnVpbGREZWYsIC4uLmFyZ3MpO1xuICAgICAgcmV0dXJuIGlubmVyQ2FjaGUuaW5zdGFuY2UgfHwgdGhpcy5idWlsZDxUPihidWlsZERlZiwgLi4uYXJncyk7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICByZWdpc3RlcjxUPihcbiAgICBvYmo6IEluamVjdGFibGU8VD4sXG4gICAgY2F0ZWdvcnk6IHN0cmluZyB8IHVuZGVmaW5lZCA9IHVuZGVmaW5lZCxcbiAgICBpc1NpbmdsZXRvbjogYm9vbGVhbiA9IHRydWUsXG4gICAgZm9yY2U6IGJvb2xlYW4gPSBmYWxzZVxuICApOiB2b2lkIHtcbiAgICBjb25zdCBjYXN0T2JqOiBSZWNvcmQ8c3RyaW5nLCBhbnk+ID0gb2JqIGFzIFJlY29yZDxzdHJpbmcsIGFueT47XG5cbiAgICBjb25zdCBjb25zdHJ1Y3RvciA9ICFjYXN0T2JqLm5hbWUgJiYgY2FzdE9iai5jb25zdHJ1Y3RvcjtcbiAgICBpZiAodHlwZW9mIGNhc3RPYmogIT09IFwiZnVuY3Rpb25cIiAmJiAhY29uc3RydWN0b3IpXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGBJbmplY3RhYmxlIHJlZ2lzdGVyaW5nIGZhaWxlZC4gTWlzc2luZyBDbGFzcyBuYW1lIG9yIGNvbnN0cnVjdG9yYFxuICAgICAgKTtcblxuICAgIGNvbnN0IG5hbWUgPVxuICAgICAgY2F0ZWdvcnkgfHxcbiAgICAgIChjb25zdHJ1Y3RvciAmJiBjb25zdHJ1Y3Rvci5uYW1lICYmIGNvbnN0cnVjdG9yLm5hbWUgIT09IFwiRnVuY3Rpb25cIlxuICAgICAgICA/IChjb25zdHJ1Y3RvciBhcyB7IFtpbmRleGVyOiBzdHJpbmddOiBhbnkgfSkubmFtZVxuICAgICAgICA6IGNhc3RPYmoubmFtZSk7XG5cbiAgICBpZiAoIXRoaXMuY2FjaGVbbmFtZV0gfHwgZm9yY2UpXG4gICAgICB0aGlzLmNhY2hlW25hbWVdID0ge1xuICAgICAgICBpbnN0YW5jZTogY29uc3RydWN0b3IgPyBvYmogOiB1bmRlZmluZWQsXG4gICAgICAgIGNvbnN0cnVjdG9yOiAhY29uc3RydWN0b3IgPyBvYmogOiB1bmRlZmluZWQsXG4gICAgICAgIHNpbmdsZXRvbjogaXNTaW5nbGV0b24sXG4gICAgICB9O1xuICB9XG4gIC8qKlxuICAgKiBAaW5oZXJpdERvY1xuICAgKi9cbiAgYnVpbGQ8VD4oZGVmczogeyBuYW1lOiBzdHJpbmcgfSwgLi4uYXJnczogYW55W10pOiBUIHtcbiAgICBjb25zdCB7IGNvbnN0cnVjdG9yLCBzaW5nbGV0b24gfSA9IHRoaXMuY2FjaGVbZGVmcy5uYW1lXTtcbiAgICBjb25zdCBpbnN0YW5jZSA9IG5ldyBjb25zdHJ1Y3RvciguLi5hcmdzKTtcbiAgICB0aGlzLmNhY2hlW2RlZnMubmFtZV0gPSB7XG4gICAgICBpbnN0YW5jZTogaW5zdGFuY2UsXG4gICAgICBjb25zdHJ1Y3RvcjogY29uc3RydWN0b3IsXG4gICAgICBzaW5nbGV0b246IHNpbmdsZXRvbixcbiAgICB9O1xuICAgIHJldHVybiBpbnN0YW5jZTtcbiAgfVxufVxuIl19
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"registry.js","sourceRoot":"","sources":["../src/registry.ts"],"names":[],"mappings":";;;AAmDA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AACH,MAAa,qBAAqB;IAAlC;QACU,UAAK,GAA+B,EAAE,CAAC;IA4DjD,CAAC;IA1DC;;OAEG;IACH,GAAG,CAAI,IAAY,EAAE,GAAG,IAAW;QACjC,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACpC,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;YAChC,IAAI,CAAC,UAAU,CAAC,SAAS,IAAI,CAAC,UAAU,CAAC,QAAQ;gBAC/C,OAAO,IAAI,CAAC,KAAK,CAAI,QAAQ,EAAE,GAAG,IAAI,CAAC,CAAC;YAC1C,OAAO,UAAU,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAI,QAAQ,EAAE,GAAG,IAAI,CAAC,CAAC;YAC/D,6DAA6D;QAC/D,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IACD;;OAEG;IACH,QAAQ,CACN,GAAkB,EAClB,WAA+B,SAAS,EACxC,cAAuB,IAAI,EAC3B,QAAiB,KAAK;QAEtB,MAAM,OAAO,GAAwB,GAA0B,CAAC;QAEhE,MAAM,WAAW,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,WAAW,CAAC;QACzD,IAAI,OAAO,OAAO,KAAK,UAAU,IAAI,CAAC,WAAW;YAC/C,MAAM,IAAI,KAAK,CACb,kEAAkE,CACnE,CAAC;QAEJ,MAAM,IAAI,GACR,QAAQ;YACR,CAAC,WAAW,IAAI,WAAW,CAAC,IAAI,IAAI,WAAW,CAAC,IAAI,KAAK,UAAU;gBACjE,CAAC,CAAE,WAA0C,CAAC,IAAI;gBAClD,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEpB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK;YAC5B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG;gBACjB,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS;gBACvC,WAAW,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS;gBAC3C,SAAS,EAAE,WAAW;aACvB,CAAC;IACN,CAAC;IACD;;OAEG;IACH,KAAK,CAAI,IAAsB,EAAE,GAAG,IAAW;QAC7C,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzD,MAAM,QAAQ,GAAG,IAAI,WAAW,CAAC,GAAG,IAAI,CAAC,CAAC;QAC1C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG;YACtB,QAAQ,EAAE,QAAQ;YAClB,WAAW,EAAE,WAAW;YACxB,SAAS,EAAE,SAAS;SACrB,CAAC;QACF,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AA7DD,sDA6DC","sourcesContent":["/**\n * @description Type representing either a class constructor or an instance.\n * @summary Defines an Injectable type that can be either a class constructor or an instance of a class.\n * @template T The type of the injectable object\n * @typedef {function(any): T | T} Injectable\n * @memberOf module:injectable-decorators\n */\nexport type Injectable<T> = { new (...args: any[]): T } | T;\n\n/**\n * @description Contract for a registry that manages injectable objects.\n * @summary Interface for an injectable registry that provides methods for retrieving, registering, and building injectable objects.\n * @template T Type parameter used in the interface methods\n * @interface InjectablesRegistry\n * @memberOf module:injectable-decorators\n */\nexport interface InjectablesRegistry {\n  /**\n   * @description Fetches an injectable instance by its registered name.\n   * @summary Retrieves an {@link Injectable} from the registry by name, optionally passing constructor arguments.\n   * @template T Type of the injectable object to retrieve\n   * @param {string} name The registered name of the injectable to retrieve\n   * @param {any[]} args Constructor arguments to pass when instantiating the injectable\n   * @return {Injectable<T> | undefined} The injectable instance or undefined if not found\n   * @memberOf module:injectable-decorators\n   */\n  get<T>(name: string, ...args: any[]): Injectable<T> | undefined;\n\n  /**\n   * @description Adds a class or object to the injectable registry.\n   * @summary Registers an injectable constructor or instance with the registry, making it available for injection.\n   * @template T Type of the injectable object to register\n   * @param {Injectable<T>} constructor The class constructor or object instance to register\n   * @param {any[]} args Additional arguments for registration (category, singleton flag, etc.)\n   * @return {void}\n   * @memberOf module:injectable-decorators\n   */\n  register<T>(constructor: Injectable<T>, ...args: any[]): void;\n\n  /**\n   * @description Creates a new instance of an injectable class.\n   * @summary Instantiates an injectable class using its constructor and the provided arguments.\n   * @template T Type of the object to build\n   * @param {Record<string, any>} obj Object containing the name of the injectable to build\n   * @param {any[]} args Constructor arguments to pass when instantiating the injectable\n   * @return {T} The newly created instance\n   * @memberOf module:injectable-decorators\n   */\n  build<T>(obj: Record<string, any>, ...args: any[]): T;\n}\n\n/**\n * @description Default implementation of the InjectablesRegistry interface.\n * @summary Holds the various {@link Injectable}s in a cache and provides methods to register, retrieve, and build them.\n * @template T Type parameter used in the class methods\n *\n * @class InjectableRegistryImp\n * @implements InjectablesRegistry\n *\n * @memberOf module:injectable-decorators\n *\n * @example\n * // Create a new registry\n * const registry = new InjectableRegistryImp();\n *\n * // Register a class\n * class MyService {\n *   doSomething() {\n *     return 'Hello World';\n *   }\n * }\n * registry.register(MyService, 'MyService', true);\n *\n * // Get the instance\n * const service = registry.get('MyService');\n * service.doSomething(); // 'Hello World'\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Registry\n *\n *   Client->>Registry: register(MyService)\n *   Registry->>Registry: Store in cache\n *\n *   Client->>Registry: get(\"MyService\")\n *   alt Instance exists and is singleton\n *     Registry-->>Client: Return cached instance\n *   else No instance or not singleton\n *     Registry->>Registry: build(name)\n *     Registry-->>Client: Return new instance\n *   end\n */\nexport class InjectableRegistryImp implements InjectablesRegistry {\n  private cache: { [indexer: string]: any } = {};\n\n  /**\n   * @inheritDoc\n   */\n  get<T>(name: string, ...args: any[]): T | undefined {\n    try {\n      const innerCache = this.cache[name];\n      const buildDef = { name: name };\n      if (!innerCache.singleton && !innerCache.instance)\n        return this.build<T>(buildDef, ...args);\n      return innerCache.instance || this.build<T>(buildDef, ...args);\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e) {\n      return undefined;\n    }\n  }\n  /**\n   * @inheritDoc\n   */\n  register<T>(\n    obj: Injectable<T>,\n    category: string | undefined = undefined,\n    isSingleton: boolean = true,\n    force: boolean = false\n  ): void {\n    const castObj: Record<string, any> = obj as Record<string, any>;\n\n    const constructor = !castObj.name && castObj.constructor;\n    if (typeof castObj !== \"function\" && !constructor)\n      throw new Error(\n        `Injectable registering failed. Missing Class name or constructor`\n      );\n\n    const name =\n      category ||\n      (constructor && constructor.name && constructor.name !== \"Function\"\n        ? (constructor as { [indexer: string]: any }).name\n        : castObj.name);\n\n    if (!this.cache[name] || force)\n      this.cache[name] = {\n        instance: constructor ? obj : undefined,\n        constructor: !constructor ? obj : undefined,\n        singleton: isSingleton,\n      };\n  }\n  /**\n   * @inheritDoc\n   */\n  build<T>(defs: { name: string }, ...args: any[]): T {\n    const { constructor, singleton } = this.cache[defs.name];\n    const instance = new constructor(...args);\n    this.cache[defs.name] = {\n      instance: instance,\n      constructor: constructor,\n      singleton: singleton,\n    };\n    return instance;\n  }\n}\n"]}
|
package/lib/registry.d.ts
CHANGED
|
@@ -1,46 +1,93 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @
|
|
2
|
+
* @description Type representing either a class constructor or an instance.
|
|
3
|
+
* @summary Defines an Injectable type that can be either a class constructor or an instance of a class.
|
|
4
|
+
* @template T The type of the injectable object
|
|
5
|
+
* @typedef {function(any): T | T} Injectable
|
|
3
6
|
* @memberOf module:injectable-decorators
|
|
4
7
|
*/
|
|
5
8
|
export type Injectable<T> = {
|
|
6
9
|
new (...args: any[]): T;
|
|
7
10
|
} | T;
|
|
8
11
|
/**
|
|
9
|
-
* @
|
|
10
|
-
* @
|
|
12
|
+
* @description Contract for a registry that manages injectable objects.
|
|
13
|
+
* @summary Interface for an injectable registry that provides methods for retrieving, registering, and building injectable objects.
|
|
14
|
+
* @template T Type parameter used in the interface methods
|
|
15
|
+
* @interface InjectablesRegistry
|
|
16
|
+
* @memberOf module:injectable-decorators
|
|
11
17
|
*/
|
|
12
18
|
export interface InjectablesRegistry {
|
|
13
19
|
/**
|
|
14
|
-
* @
|
|
15
|
-
* @
|
|
16
|
-
* @
|
|
17
|
-
* @
|
|
18
|
-
*
|
|
19
|
-
* @
|
|
20
|
+
* @description Fetches an injectable instance by its registered name.
|
|
21
|
+
* @summary Retrieves an {@link Injectable} from the registry by name, optionally passing constructor arguments.
|
|
22
|
+
* @template T Type of the injectable object to retrieve
|
|
23
|
+
* @param {string} name The registered name of the injectable to retrieve
|
|
24
|
+
* @param {any[]} args Constructor arguments to pass when instantiating the injectable
|
|
25
|
+
* @return {Injectable<T> | undefined} The injectable instance or undefined if not found
|
|
26
|
+
* @memberOf module:injectable-decorators
|
|
20
27
|
*/
|
|
21
28
|
get<T>(name: string, ...args: any[]): Injectable<T> | undefined;
|
|
22
29
|
/**
|
|
23
|
-
* @
|
|
24
|
-
* @
|
|
25
|
-
* @
|
|
26
|
-
*
|
|
27
|
-
* @
|
|
30
|
+
* @description Adds a class or object to the injectable registry.
|
|
31
|
+
* @summary Registers an injectable constructor or instance with the registry, making it available for injection.
|
|
32
|
+
* @template T Type of the injectable object to register
|
|
33
|
+
* @param {Injectable<T>} constructor The class constructor or object instance to register
|
|
34
|
+
* @param {any[]} args Additional arguments for registration (category, singleton flag, etc.)
|
|
35
|
+
* @return {void}
|
|
36
|
+
* @memberOf module:injectable-decorators
|
|
28
37
|
*/
|
|
29
38
|
register<T>(constructor: Injectable<T>, ...args: any[]): void;
|
|
30
39
|
/**
|
|
31
|
-
* @
|
|
32
|
-
* @
|
|
33
|
-
* @
|
|
34
|
-
* @
|
|
35
|
-
*
|
|
36
|
-
* @
|
|
40
|
+
* @description Creates a new instance of an injectable class.
|
|
41
|
+
* @summary Instantiates an injectable class using its constructor and the provided arguments.
|
|
42
|
+
* @template T Type of the object to build
|
|
43
|
+
* @param {Record<string, any>} obj Object containing the name of the injectable to build
|
|
44
|
+
* @param {any[]} args Constructor arguments to pass when instantiating the injectable
|
|
45
|
+
* @return {T} The newly created instance
|
|
46
|
+
* @memberOf module:injectable-decorators
|
|
37
47
|
*/
|
|
38
48
|
build<T>(obj: Record<string, any>, ...args: any[]): T;
|
|
39
49
|
}
|
|
40
50
|
/**
|
|
41
|
-
* @
|
|
51
|
+
* @description Default implementation of the InjectablesRegistry interface.
|
|
52
|
+
* @summary Holds the various {@link Injectable}s in a cache and provides methods to register, retrieve, and build them.
|
|
53
|
+
* @template T Type parameter used in the class methods
|
|
54
|
+
*
|
|
42
55
|
* @class InjectableRegistryImp
|
|
43
56
|
* @implements InjectablesRegistry
|
|
57
|
+
*
|
|
58
|
+
* @memberOf module:injectable-decorators
|
|
59
|
+
*
|
|
60
|
+
* @example
|
|
61
|
+
* // Create a new registry
|
|
62
|
+
* const registry = new InjectableRegistryImp();
|
|
63
|
+
*
|
|
64
|
+
* // Register a class
|
|
65
|
+
* class MyService {
|
|
66
|
+
* doSomething() {
|
|
67
|
+
* return 'Hello World';
|
|
68
|
+
* }
|
|
69
|
+
* }
|
|
70
|
+
* registry.register(MyService, 'MyService', true);
|
|
71
|
+
*
|
|
72
|
+
* // Get the instance
|
|
73
|
+
* const service = registry.get('MyService');
|
|
74
|
+
* service.doSomething(); // 'Hello World'
|
|
75
|
+
*
|
|
76
|
+
* @mermaid
|
|
77
|
+
* sequenceDiagram
|
|
78
|
+
* participant Client
|
|
79
|
+
* participant Registry
|
|
80
|
+
*
|
|
81
|
+
* Client->>Registry: register(MyService)
|
|
82
|
+
* Registry->>Registry: Store in cache
|
|
83
|
+
*
|
|
84
|
+
* Client->>Registry: get("MyService")
|
|
85
|
+
* alt Instance exists and is singleton
|
|
86
|
+
* Registry-->>Client: Return cached instance
|
|
87
|
+
* else No instance or not singleton
|
|
88
|
+
* Registry->>Registry: build(name)
|
|
89
|
+
* Registry-->>Client: Return new instance
|
|
90
|
+
* end
|
|
44
91
|
*/
|
|
45
92
|
export declare class InjectableRegistryImp implements InjectablesRegistry {
|
|
46
93
|
private cache;
|
package/lib/utils.cjs
CHANGED
|
@@ -4,23 +4,23 @@ exports.TypeKey = void 0;
|
|
|
4
4
|
exports.getTypeFromDecorator = getTypeFromDecorator;
|
|
5
5
|
require("reflect-metadata");
|
|
6
6
|
/**
|
|
7
|
-
* @
|
|
7
|
+
* @description Reflection metadata key for accessing TypeScript type information.
|
|
8
|
+
* @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.
|
|
8
9
|
* @const TypeKey
|
|
9
|
-
* @memberOf
|
|
10
|
+
* @memberOf module:injectable-decorators
|
|
10
11
|
*/
|
|
11
12
|
exports.TypeKey = "design:type";
|
|
12
13
|
/**
|
|
13
|
-
* @
|
|
14
|
-
* @
|
|
15
|
-
* @param {
|
|
16
|
-
* @
|
|
17
|
-
*
|
|
18
|
-
* @function
|
|
19
|
-
*
|
|
14
|
+
* @description Extracts the type name from a decorated property using reflection.
|
|
15
|
+
* @summary Retrieves the type from a property decorator by accessing TypeScript's reflection metadata.
|
|
16
|
+
* @param {any} model The target object containing the decorated property
|
|
17
|
+
* @param {string | symbol} propKey The property key (name or symbol) of the decorated property
|
|
18
|
+
* @return {string | undefined} The name of the property type, or undefined if it's a Function type
|
|
19
|
+
* @function getTypeFromDecorator
|
|
20
20
|
* @memberOf module:injectable-decorators
|
|
21
21
|
*/
|
|
22
22
|
function getTypeFromDecorator(model, propKey) {
|
|
23
23
|
const typeDef = Reflect.getMetadata(exports.TypeKey, model, propKey);
|
|
24
24
|
return typeDef.name !== "Function" ? typeDef.name : undefined;
|
|
25
25
|
}
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBbUJBLG9EQU1DO0FBekJELDRCQUEwQjtBQUUxQjs7Ozs7R0FLRztBQUNVLFFBQUEsT0FBTyxHQUFHLGFBQWEsQ0FBQztBQUVyQzs7Ozs7Ozs7R0FRRztBQUNILFNBQWdCLG9CQUFvQixDQUNsQyxLQUFVLEVBQ1YsT0FBd0I7SUFFeEIsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FBQyxlQUFPLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzdELE9BQU8sT0FBTyxDQUFDLElBQUksS0FBSyxVQUFVLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztBQUNoRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFwicmVmbGVjdC1tZXRhZGF0YVwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBSZWZsZWN0aW9uIG1ldGFkYXRhIGtleSBmb3IgYWNjZXNzaW5nIFR5cGVTY3JpcHQgdHlwZSBpbmZvcm1hdGlvbi5cbiAqIEBzdW1tYXJ5IEhvbGRzIHRoZSBrZXkgZm9yIHJldHJpZXZpbmcgdGhlIGRlc2lnbiB0eXBlIGZyb20gVHlwZVNjcmlwdCdzIHJlZmxlY3Rpb24gbWV0YWRhdGEuXG4gKiBAY29uc3QgVHlwZUtleVxuICogQG1lbWJlck9mIG1vZHVsZTppbmplY3RhYmxlLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IFR5cGVLZXkgPSBcImRlc2lnbjp0eXBlXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEV4dHJhY3RzIHRoZSB0eXBlIG5hbWUgZnJvbSBhIGRlY29yYXRlZCBwcm9wZXJ0eSB1c2luZyByZWZsZWN0aW9uLlxuICogQHN1bW1hcnkgUmV0cmlldmVzIHRoZSB0eXBlIGZyb20gYSBwcm9wZXJ0eSBkZWNvcmF0b3IgYnkgYWNjZXNzaW5nIFR5cGVTY3JpcHQncyByZWZsZWN0aW9uIG1ldGFkYXRhLlxuICogQHBhcmFtIHthbnl9IG1vZGVsIFRoZSB0YXJnZXQgb2JqZWN0IGNvbnRhaW5pbmcgdGhlIGRlY29yYXRlZCBwcm9wZXJ0eVxuICogQHBhcmFtIHtzdHJpbmcgfCBzeW1ib2x9IHByb3BLZXkgVGhlIHByb3BlcnR5IGtleSAobmFtZSBvciBzeW1ib2wpIG9mIHRoZSBkZWNvcmF0ZWQgcHJvcGVydHlcbiAqIEByZXR1cm4ge3N0cmluZyB8IHVuZGVmaW5lZH0gVGhlIG5hbWUgb2YgdGhlIHByb3BlcnR5IHR5cGUsIG9yIHVuZGVmaW5lZCBpZiBpdCdzIGEgRnVuY3Rpb24gdHlwZVxuICogQGZ1bmN0aW9uIGdldFR5cGVGcm9tRGVjb3JhdG9yXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmluamVjdGFibGUtZGVjb3JhdG9yc1xuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0VHlwZUZyb21EZWNvcmF0b3IoXG4gIG1vZGVsOiBhbnksXG4gIHByb3BLZXk6IHN0cmluZyB8IHN5bWJvbCxcbik6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gIGNvbnN0IHR5cGVEZWYgPSBSZWZsZWN0LmdldE1ldGFkYXRhKFR5cGVLZXksIG1vZGVsLCBwcm9wS2V5KTtcbiAgcmV0dXJuIHR5cGVEZWYubmFtZSAhPT0gXCJGdW5jdGlvblwiID8gdHlwZURlZi5uYW1lIDogdW5kZWZpbmVkO1xufVxuIl19
|
package/lib/utils.d.ts
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import "reflect-metadata";
|
|
2
2
|
/**
|
|
3
|
-
* @
|
|
3
|
+
* @description Reflection metadata key for accessing TypeScript type information.
|
|
4
|
+
* @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.
|
|
4
5
|
* @const TypeKey
|
|
5
|
-
* @memberOf
|
|
6
|
+
* @memberOf module:injectable-decorators
|
|
6
7
|
*/
|
|
7
8
|
export declare const TypeKey = "design:type";
|
|
8
9
|
/**
|
|
9
|
-
* @
|
|
10
|
-
* @
|
|
11
|
-
* @param {
|
|
12
|
-
* @
|
|
13
|
-
*
|
|
14
|
-
* @function
|
|
15
|
-
*
|
|
10
|
+
* @description Extracts the type name from a decorated property using reflection.
|
|
11
|
+
* @summary Retrieves the type from a property decorator by accessing TypeScript's reflection metadata.
|
|
12
|
+
* @param {any} model The target object containing the decorated property
|
|
13
|
+
* @param {string | symbol} propKey The property key (name or symbol) of the decorated property
|
|
14
|
+
* @return {string | undefined} The name of the property type, or undefined if it's a Function type
|
|
15
|
+
* @function getTypeFromDecorator
|
|
16
16
|
* @memberOf module:injectable-decorators
|
|
17
17
|
*/
|
|
18
18
|
export declare function getTypeFromDecorator(model: any, propKey: string | symbol): string | undefined;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@decaf-ts/injectable-decorators",
|
|
3
|
-
"version": "1.6.
|
|
3
|
+
"version": "1.6.2",
|
|
4
4
|
"description": "injectable decorators extension for decorator validation",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
@@ -59,8 +59,8 @@
|
|
|
59
59
|
"id",
|
|
60
60
|
"timestamp"
|
|
61
61
|
],
|
|
62
|
-
"author": "
|
|
63
|
-
"license": "
|
|
62
|
+
"author": "Tiago Venceslau",
|
|
63
|
+
"license": "MIT",
|
|
64
64
|
"bugs": {
|
|
65
65
|
"url": "https://github.com/decaf-ts/injectable-decorators/issues"
|
|
66
66
|
},
|