@decaf-ts/injectable-decorators 1.6.6 → 1.6.8

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.
@@ -1,60 +1,105 @@
1
1
  import { InstanceCallback } from "./types";
2
2
  /**
3
- * @description Generates a fully qualified reflection metadata key.
4
- * @summary Returns the reflection key for injectables by prefixing the provided key with the base reflection key.
5
- * @param {string} key The key to be prefixed
6
- * @return {string} The fully qualified reflection key
7
- * @function getInjectKey
3
+ * @description Configuration options for the @injectable decorator.
4
+ * @summary Controls lifecycle (singleton vs on-demand) and an optional instance transformation callback executed post-construction.
5
+ * @template T The instance type affected by the callback when provided.
6
+ * @property {boolean} singleton When true, a single instance is shared (singleton). When false, instances are created on demand.
7
+ * @property {InstanceCallback<T>} [callback] Optional hook to transform the instance after it is constructed.
8
+ * @typedef InjectableConfig
8
9
  * @memberOf module:injectable-decorators
9
10
  */
10
- export declare const getInjectKey: (key: string) => string;
11
+ export type InjectableConfig = {
12
+ singleton: boolean;
13
+ callback?: InstanceCallback<any>;
14
+ };
15
+ /**
16
+ * @description Generic constructor type for class-like values.
17
+ * @summary Represents any class that can be instantiated with arbitrary arguments, producing an instance of type T.
18
+ * @template T The instance type created by the constructor.
19
+ * @typedef Constructor
20
+ * @example
21
+ * // Using Constructor to type a factory
22
+ * function make<T>(Ctor: Constructor<T>, ...args: any[]): T {
23
+ * return new Ctor(...args);
24
+ * }
25
+ * @memberOf module:injectable-decorators
26
+ */
27
+ export type Constructor<T = any> = {
28
+ new (...args: any[]): T;
29
+ };
11
30
  /**
12
31
  * @description Decorator that marks a class as available for dependency injection.
13
- * @summary Defines a class as an injectable singleton that can be retrieved from the registry.
14
- * When applied to a class, replaces its constructor with one that returns a singleton instance.
32
+ * @summary Defines a class as an injectable that can be retrieved from the registry.
33
+ * When applied to a class, replaces its constructor with one that returns an instance.
34
+ *
35
+ * @return {function(any): any} A decorator function that transforms the class into an injectable.
15
36
  *
16
- * @param {string} [category] Defaults to the class name. Useful when minification occurs and names are changed,
37
+ * @function injectable
38
+ * @category Decorators
39
+ */
40
+ export declare function injectable(): (original: any) => any;
41
+ /**
42
+ * @description Decorator that marks a class as available for dependency injection.
43
+ * @summary Defines a class as an injectable that can be retrieved from the registry.
44
+ * When applied to a class, replaces its constructor with one that returns an instance.
45
+ *
46
+ * @param {string | Constructor} category Defaults to the class category. Useful when minification occurs and names are changed,
17
47
  * or when you want to upcast the object to a different type.
18
- * @param {boolean} [force] Defines if the injectable should override an already existing instance (if any).
19
- * Only meant for extending decorators.
20
- * @param {Function} [instanceCallback] Optional callback function that will be called with the instance after creation.
21
- * @return {Function} A decorator function that transforms the class into an injectable.
48
+ *
49
+ * @return {function(any): any} A decorator function that transforms the class into an injectable.
22
50
  *
23
51
  * @function injectable
24
- * @category Class Decorators
52
+ * @category Decorators
53
+ */
54
+ export declare function injectable(category: string | Constructor): (original: any) => any;
55
+ /**
56
+ * @description Decorator that marks a class as available for dependency injection.
57
+ * @summary Defines a class as an injectable that can be retrieved from the registry.
58
+ * When applied to a class, replaces its constructor with one that returns an instance.
25
59
  *
26
- * @mermaid
27
- * sequenceDiagram
28
- * participant Client
29
- * participant Decorator
30
- * participant Injectables
31
- *
32
- * Client->>Decorator: @injectable()
33
- * Decorator->>Decorator: Create new constructor
34
- *
35
- * Note over Decorator: When new instance requested
36
- * Decorator->>Injectables: get(name)
37
- * alt Instance exists
38
- * Injectables-->>Decorator: Return existing instance
39
- * else No instance
40
- * Decorator->>Injectables: register(original, name)
41
- * Decorator->>Injectables: get(name)
42
- * Injectables-->>Decorator: Return new instance
43
- * opt Has callback
44
- * Decorator->>Decorator: Call instanceCallback
45
- * end
46
- * end
47
- * Decorator->>Decorator: Define metadata
48
- * Decorator-->>Client: Return instance
60
+ * @param {Partial<InjectableConfig>} cfg=DefaultInjectableConfig Allows overriding the default singleton behavior and adding a callback function.
61
+ *
62
+ * @return {function(any): any} A decorator function that transforms the class into an injectable.
63
+ *
64
+ * @function injectable
65
+ * @category Decorators
49
66
  */
50
- export declare function injectable(): (original: any) => any;
51
- export declare function injectable(category: string | {
52
- new (...args: any[]): any;
53
- }): (original: any) => any;
54
- export declare function injectable(instanceCallback: InstanceCallback<any>): (original: any) => any;
55
- export declare function injectable(category: string | {
56
- new (...args: any[]): any;
57
- }, instanceCallback: InstanceCallback<any>): (original: any) => any;
67
+ export declare function injectable(cfg: Partial<InjectableConfig>): (original: any) => any;
68
+ /**
69
+ * @description Decorator that marks a class as available for dependency injection.
70
+ * @summary Defines a class as an injectable that can be retrieved from the registry.
71
+ * When applied to a class, replaces its constructor with one that returns an instance.
72
+ *
73
+ * @param category Defaults to the class category. Useful when minification occurs and names are changed,
74
+ * or when you want to upcast the object to a different type.
75
+ * @param {Partial<InjectableConfig>} cfg=DefaultInjectableConfig Allows overriding the default singleton behavior and adding a callback function.
76
+ *
77
+ * @return {function(any): any} A decorator function that transforms the class into an injectable.
78
+ *
79
+ * @function injectable
80
+ * @category Decorators
81
+ */
82
+ export declare function injectable(category: string | Constructor, cfg: Partial<InjectableConfig>): (original: any) => any;
83
+ /**
84
+ * @description Convenience decorator to register an injectable as a singleton.
85
+ * @summary Wraps {@link injectable} forcing the singleton lifecycle so only one instance is created and reused.
86
+ * @param {string|Constructor} [category] Optional explicit category/symbol source; defaults to the class.
87
+ * @param {Omit<InjectableConfig, "singleton">} [cfg] Additional injectable configuration excluding the singleton flag.
88
+ * @return function(any): any} A class decorator that registers the target as a singleton injectable.
89
+ * @function singleton
90
+ * @category Class Decorators
91
+ */
92
+ export declare function singleton(category?: string | Constructor, cfg?: Omit<InjectableConfig, "singleton">): (original: any) => any;
93
+ /**
94
+ * @description Convenience decorator to register an injectable as on-demand (non-singleton).
95
+ * @summary Wraps {@link injectable} forcing new instances to be created on every injection or retrieval.
96
+ * @param {string|Constructor} [category] Optional explicit category/symbol source; defaults to the class.
97
+ * @param {Omit<InjectableConfig, "singleton">} [cfg] Additional injectable configuration excluding the singleton flag.
98
+ * @return {function(any): any} A class decorator that registers the target as a non-singleton injectable.
99
+ * @function onDemand
100
+ * @category Class Decorators
101
+ */
102
+ export declare function onDemand(category?: string | Constructor, cfg?: Omit<InjectableConfig, "singleton">): (original: any) => any;
58
103
  /**
59
104
  * @description Function type for transforming injectable instances before they're injected.
60
105
  * @summary Function which transforms a cached {@link injectable} instance before it's injected into a target object.
@@ -64,68 +109,69 @@ export declare function injectable(category: string | {
64
109
  * @return {any} The transformed injectable instance
65
110
  *
66
111
  * @typedef {Function} InstanceTransformer
112
+ * @category Decorators
67
113
  * @memberOf module:injectable-decorators
68
114
  */
69
115
  export type InstanceTransformer = (injectable: any, obj: any) => any;
116
+ /**
117
+ * @description Options for the property-level @inject decorator.
118
+ * @summary Allows specifying constructor arguments and an optional transformer to be applied to the resolved instance.
119
+ * @property {any[]} [args] Optional constructor arguments to use when building the injectable instance.
120
+ * @property {InstanceTransformer} [transformer] Optional function to transform the instance before assignment.
121
+ * @typedef InjectOptions
122
+ * @memberOf module:injectable-decorators
123
+ */
124
+ export type InjectOptions = {
125
+ args?: any[];
126
+ transformer?: InstanceTransformer;
127
+ };
128
+ /**
129
+ * @description Property decorator that injects a dependency into a class property.
130
+ * @summary Allows for the injection of an {@link injectable} decorated dependency into a class property.
131
+ * The property must be typed for the requested dependency. Only concrete classes are supported; generics are not.
132
+ *
133
+ * @return {function(any, any): void} A property decorator function that sets up the dependency injection.
134
+ *
135
+ * @function inject
136
+ * @category Decorators
137
+ */
138
+ export declare function inject(): (target: any, propertyKey: any) => void;
70
139
  /**
71
140
  * @description Property decorator that injects a dependency into a class property.
72
141
  * @summary Allows for the injection of an {@link injectable} decorated dependency into a class property.
73
142
  * The property must be typed for the requested dependency. Only concrete classes are supported; generics are not.
74
143
  *
75
- * Injected properties should be described like so:
76
- * <pre>
77
- * class ClassName {
78
- * ...
144
+ * @param {string} category Defaults to the class name derived from the property type. Useful when minification occurs
145
+ * and names are changed, or when you want to upcast the object to a different type.
146
+ * @return {function(any, any): void} A property decorator function that sets up the dependency injection.
79
147
  *
80
- * @inject()
81
- * propertyName!: InjectableClass;
148
+ * @function inject
149
+ * @category Decorators
150
+ */
151
+ export declare function inject(category: string | Constructor): (target: any, propertyKey: any) => void;
152
+ /**
153
+ * @description Property decorator that injects a dependency into a class property.
154
+ * @summary Allows for the injection of an {@link injectable} decorated dependency into a class property.
155
+ * The property must be typed for the requested dependency. Only concrete classes are supported; generics are not.
82
156
  *
83
- * ...
84
- * }
85
- * </pre>
157
+ * @param {Partial<InjectOptions>} [cfg={}] Optional function to transform the injectable instance before it's injected, or arguments to pass the constructor when injecting onDemand
158
+ * @return {function(any, any): void} A property decorator function that sets up the dependency injection.
86
159
  *
87
- * where InjectableClass is the class you want to inject.
88
- * Notice the use of '!:' to ensure the transpiler the property will be set outside the constructor but will always be defined.
89
- * For projects where minification occurs, you should use the category param to ensure the name is the same throughout.
160
+ * @function inject
161
+ * @category Decorators
162
+ */
163
+ export declare function inject(cfg: Partial<InjectOptions>): (target: any, propertyKey: any) => void;
164
+ /**
165
+ * @description Property decorator that injects a dependency into a class property.
166
+ * @summary Allows for the injection of an {@link injectable} decorated dependency into a class property.
167
+ * The property must be typed for the requested dependency. Only concrete classes are supported; generics are not.
90
168
  *
91
- * @param {string} [category] Defaults to the class name derived from the property type. Useful when minification occurs
169
+ * @param {string} category Defaults to the class name derived from the property type. Useful when minification occurs
92
170
  * and names are changed, or when you want to upcast the object to a different type.
93
- * @param {InstanceTransformer} [transformer] Optional function to transform the injectable instance before it's injected.
94
- * @return {Function} A property decorator function that sets up the dependency injection.
171
+ * @param {Partial<InjectOptions>} cfg={} Optional function to transform the injectable instance before it's injected, or arguments to pass the constructor when injecting onDemand
172
+ * @return {function(any, any): void} A property decorator function that sets up the dependency injection.
95
173
  *
96
174
  * @function inject
97
- * @category Property Decorators
98
- *
99
- * @mermaid
100
- * sequenceDiagram
101
- * participant Client
102
- * participant Decorator
103
- * participant Injectables
104
- *
105
- * Client->>Decorator: @inject()
106
- * Decorator->>Decorator: Get type from property
107
- * Decorator->>Decorator: Define metadata
108
- * Decorator->>Decorator: Define property getter
109
- *
110
- * Note over Decorator: When property accessed
111
- * Client->>Decorator: access property
112
- * Decorator->>Decorator: Check if instance exists
113
- * alt Instance exists in WeakMap
114
- * Decorator-->>Client: Return cached instance
115
- * else No instance
116
- * Decorator->>Injectables: get(name)
117
- * alt Injectable found
118
- * Injectables-->>Decorator: Return injectable instance
119
- * opt Has transformer
120
- * Decorator->>Decorator: Call transformer
121
- * end
122
- * Decorator->>Decorator: Store in WeakMap
123
- * Decorator-->>Client: Return instance
124
- * else No injectable
125
- * Decorator-->>Client: Throw error
126
- * end
127
- * end
175
+ * @category Decorators
128
176
  */
129
- export declare function inject(category?: symbol | string | {
130
- new (...args: any[]): any;
131
- }, transformer?: InstanceTransformer): (target: any, propertyKey?: any) => void;
177
+ export declare function inject(category: string | Constructor, cfg: Partial<InjectOptions>): (target: any, propertyKey: any) => void;
@@ -42,6 +42,11 @@ import { Injectable, InjectablesRegistry } from "./registry";
42
42
  * Injectables-->>Client: MyService instance
43
43
  */
44
44
  export declare class Injectables {
45
+ /**
46
+ * @description Holds the active registry implementation used by the Injectables facade.
47
+ * @summary Internal static reference that can be swapped via setRegistry to customize how injectables are stored and retrieved.
48
+ * @type {InjectablesRegistry | undefined}
49
+ */
45
50
  private static actingInjectablesRegistry?;
46
51
  private constructor();
47
52
  /**
@@ -42,6 +42,11 @@ import { InjectableRegistryImp, } from "./registry.js";
42
42
  * Injectables-->>Client: MyService instance
43
43
  */
44
44
  export class Injectables {
45
+ /**
46
+ * @description Holds the active registry implementation used by the Injectables facade.
47
+ * @summary Internal static reference that can be swapped via setRegistry to customize how injectables are stored and retrieved.
48
+ * @type {InjectablesRegistry | undefined}
49
+ */
45
50
  static { this.actingInjectablesRegistry = undefined; }
46
51
  constructor() { }
47
52
  /**
@@ -120,4 +125,4 @@ export class Injectables {
120
125
  }, {});
121
126
  }
122
127
  }
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Injectables.js","sourceRoot":"","sources":["../../src/Injectables.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,qBAAqB,GAEtB,sBAAmB;AAGpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AACH,MAAM,OAAO,WAAW;aACP,8BAAyB,GAAyB,SAAS,CAAC;IAE3E,gBAAuB,CAAC;IAExB;;;;;;;;OAQG;IACH,MAAM,CAAC,GAAG,CACR,IAAmD,EACnD,GAAG,IAAW;QAEd,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;IACtD,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,QAAQ,CAAI,WAA0B,EAAE,GAAG,IAAW;QAC3D,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CACvC,WAAW,EACX,GAAI,IAAuC,CAC5C,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,KAAK,CAAI,IAAY,EAAE,GAAG,IAAW;QAC1C,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;IACxD,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,WAAW,CAAC,kBAAuC;QACxD,WAAW,CAAC,yBAAyB,GAAG,kBAAkB,CAAC;IAC7D,CAAC;IACD;;;;OAIG;IACK,MAAM,CAAC,WAAW;QACxB,IAAI,CAAC,WAAW,CAAC,yBAAyB;YACxC,WAAW,CAAC,yBAAyB,GAAG,IAAI,qBAAqB,EAAE,CAAC;QACtE,OAAO,WAAW,CAAC,yBAAyB,CAAC;IAC/C,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK;QACV,WAAW,CAAC,WAAW,CAAC,IAAI,qBAAqB,EAAE,CAAC,CAAC;IACvD,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,cAAc,CAAC,KAAsB;QAC1C,MAAM,MAAM,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACpE,WAAW,CAAC,yBAAiC,CAAC,OAAO,CAAC,GAAG,MAAM,CAAC,OAAO,CACrE,WAAW,CAAC,yBAAiC,CAAC,OAAO,CAAC,CACxD,CAAC,MAAM,CAAC,CAAC,KAA0B,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;YAClD,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC;gBAAE,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;YACzC,OAAO,KAAK,CAAC;QACf,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC","sourcesContent":["import {\n  Injectable,\n  InjectableRegistryImp,\n  InjectablesRegistry,\n} from \"./registry\";\nimport { InjectableOptions } from \"./types\";\n\n/**\n * @description Central registry for managing injectable dependencies.\n * @summary Static class holding the access to the injectables functions. Provides methods for registering,\n * retrieving, and building injectable objects.\n * @template T Type of the injectable object\n *\n * @class Injectables\n *\n * @example\n * // Define an injectable class\n * @injectable()\n * class MyService {\n *   doSomething() {\n *     return 'Hello World';\n *   }\n * }\n *\n * // Inject the service into another class\n * class MyComponent {\n *   @inject()\n *   private service!: MyService;\n *\n *   useService() {\n *     return this.service.doSomething();\n *   }\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Injectables\n *   participant Registry\n *\n *   Client->>Injectables: register(MyService)\n *   Injectables->>Registry: register(MyService)\n *   Registry-->>Injectables: void\n *\n *   Client->>Injectables: get(\"MyService\")\n *   Injectables->>Registry: get(\"MyService\")\n *   Registry-->>Injectables: MyService instance\n *   Injectables-->>Client: MyService instance\n */\nexport class Injectables {\n  private static actingInjectablesRegistry?: InjectablesRegistry = undefined;\n\n  private constructor() {}\n\n  /**\n   * @description Fetches an injectable instance by its registered name.\n   * @summary Retrieves the named {@link Injectable} from the registry. If the injectable is a singleton,\n   * returns the existing instance. Otherwise, creates a new instance.\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   */\n  static get<T>(\n    name: symbol | string | { new (...args: any[]): T },\n    ...args: any[]\n  ): T | undefined {\n    return Injectables.getRegistry().get(name, ...args);\n  }\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   */\n  static register<T>(constructor: Injectable<T>, ...args: any[]): void {\n    return Injectables.getRegistry().register(\n      constructor,\n      ...(args as [symbol, InjectableOptions<T>])\n    );\n  }\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 {symbol} name symbol referencing the injectable\n   * @param {any[]} args Constructor arguments to pass when instantiating the injectable\n   * @return {T} The newly created instance\n   */\n  static build<T>(name: symbol, ...args: any[]): T {\n    return Injectables.getRegistry().build(name, ...args);\n  }\n\n  /**\n   * @description Replaces the current registry implementation.\n   * @summary Sets a new {@link InjectablesRegistry} implementation, allowing for custom registry behavior.\n   * @param {InjectablesRegistry} operationsRegistry The new implementation of Registry to use\n   * @return {void}\n   */\n  static setRegistry(operationsRegistry: InjectablesRegistry): void {\n    Injectables.actingInjectablesRegistry = operationsRegistry;\n  }\n  /**\n   * @description Provides access to the current registry instance.\n   * @summary Returns the current {@link InjectablesRegistry} or creates a default one if none exists.\n   * @return {InjectablesRegistry} The current registry instance\n   */\n  private static getRegistry(): InjectablesRegistry {\n    if (!Injectables.actingInjectablesRegistry)\n      Injectables.actingInjectablesRegistry = new InjectableRegistryImp();\n    return Injectables.actingInjectablesRegistry;\n  }\n\n  /**\n   * @description Clears all registered injectables.\n   * @summary Resets the registry to a clean state by creating a new empty registry instance.\n   * @return {void}\n   */\n  static reset(): void {\n    Injectables.setRegistry(new InjectableRegistryImp());\n  }\n\n  /**\n   * @description Removes specific injectables from the registry based on a pattern.\n   * @summary Selectively resets the registry by removing only the injectables whose names match the provided pattern.\n   * @param {string | RegExp} match A string or regular expression pattern to match against injectable names\n   * @return {void}\n   */\n  static selectiveReset(match: string | RegExp): void {\n    const regexp = typeof match === \"string\" ? new RegExp(match) : match;\n    (Injectables.actingInjectablesRegistry as any)[\"cache\"] = Object.entries(\n      (Injectables.actingInjectablesRegistry as any)[\"cache\"]\n    ).reduce((accum: Record<string, any>, [key, val]) => {\n      if (!key.match(regexp)) accum[key] = val;\n      return accum;\n    }, {});\n  }\n}\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Injectables.js","sourceRoot":"","sources":["../../src/Injectables.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,qBAAqB,GAEtB,sBAAmB;AAGpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AACH,MAAM,OAAO,WAAW;IACtB;;;;OAIG;aACY,8BAAyB,GAAyB,SAAS,CAAC;IAE3E,gBAAuB,CAAC;IAExB;;;;;;;;OAQG;IACH,MAAM,CAAC,GAAG,CACR,IAAmD,EACnD,GAAG,IAAW;QAEd,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;IACtD,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,QAAQ,CAAI,WAA0B,EAAE,GAAG,IAAW;QAC3D,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CACvC,WAAW,EACX,GAAI,IAAuC,CAC5C,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,KAAK,CAAI,IAAY,EAAE,GAAG,IAAW;QAC1C,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;IACxD,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,WAAW,CAAC,kBAAuC;QACxD,WAAW,CAAC,yBAAyB,GAAG,kBAAkB,CAAC;IAC7D,CAAC;IACD;;;;OAIG;IACK,MAAM,CAAC,WAAW;QACxB,IAAI,CAAC,WAAW,CAAC,yBAAyB;YACxC,WAAW,CAAC,yBAAyB,GAAG,IAAI,qBAAqB,EAAE,CAAC;QACtE,OAAO,WAAW,CAAC,yBAAyB,CAAC;IAC/C,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK;QACV,WAAW,CAAC,WAAW,CAAC,IAAI,qBAAqB,EAAE,CAAC,CAAC;IACvD,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,cAAc,CAAC,KAAsB;QAC1C,MAAM,MAAM,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACpE,WAAW,CAAC,yBAAiC,CAAC,OAAO,CAAC,GAAG,MAAM,CAAC,OAAO,CACrE,WAAW,CAAC,yBAAiC,CAAC,OAAO,CAAC,CACxD,CAAC,MAAM,CAAC,CAAC,KAA0B,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;YAClD,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC;gBAAE,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;YACzC,OAAO,KAAK,CAAC;QACf,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC","sourcesContent":["import {\n  Injectable,\n  InjectableRegistryImp,\n  InjectablesRegistry,\n} from \"./registry\";\nimport { InjectableOptions } from \"./types\";\n\n/**\n * @description Central registry for managing injectable dependencies.\n * @summary Static class holding the access to the injectables functions. Provides methods for registering,\n * retrieving, and building injectable objects.\n * @template T Type of the injectable object\n *\n * @class Injectables\n *\n * @example\n * // Define an injectable class\n * @injectable()\n * class MyService {\n *   doSomething() {\n *     return 'Hello World';\n *   }\n * }\n *\n * // Inject the service into another class\n * class MyComponent {\n *   @inject()\n *   private service!: MyService;\n *\n *   useService() {\n *     return this.service.doSomething();\n *   }\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Injectables\n *   participant Registry\n *\n *   Client->>Injectables: register(MyService)\n *   Injectables->>Registry: register(MyService)\n *   Registry-->>Injectables: void\n *\n *   Client->>Injectables: get(\"MyService\")\n *   Injectables->>Registry: get(\"MyService\")\n *   Registry-->>Injectables: MyService instance\n *   Injectables-->>Client: MyService instance\n */\nexport class Injectables {\n  /**\n   * @description Holds the active registry implementation used by the Injectables facade.\n   * @summary Internal static reference that can be swapped via setRegistry to customize how injectables are stored and retrieved.\n   * @type {InjectablesRegistry | undefined}\n   */\n  private static actingInjectablesRegistry?: InjectablesRegistry = undefined;\n\n  private constructor() {}\n\n  /**\n   * @description Fetches an injectable instance by its registered name.\n   * @summary Retrieves the named {@link Injectable} from the registry. If the injectable is a singleton,\n   * returns the existing instance. Otherwise, creates a new instance.\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   */\n  static get<T>(\n    name: symbol | string | { new (...args: any[]): T },\n    ...args: any[]\n  ): T | undefined {\n    return Injectables.getRegistry().get(name, ...args);\n  }\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   */\n  static register<T>(constructor: Injectable<T>, ...args: any[]): void {\n    return Injectables.getRegistry().register(\n      constructor,\n      ...(args as [symbol, InjectableOptions<T>])\n    );\n  }\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 {symbol} name symbol referencing the injectable\n   * @param {any[]} args Constructor arguments to pass when instantiating the injectable\n   * @return {T} The newly created instance\n   */\n  static build<T>(name: symbol, ...args: any[]): T {\n    return Injectables.getRegistry().build(name, ...args);\n  }\n\n  /**\n   * @description Replaces the current registry implementation.\n   * @summary Sets a new {@link InjectablesRegistry} implementation, allowing for custom registry behavior.\n   * @param {InjectablesRegistry} operationsRegistry The new implementation of Registry to use\n   * @return {void}\n   */\n  static setRegistry(operationsRegistry: InjectablesRegistry): void {\n    Injectables.actingInjectablesRegistry = operationsRegistry;\n  }\n  /**\n   * @description Provides access to the current registry instance.\n   * @summary Returns the current {@link InjectablesRegistry} or creates a default one if none exists.\n   * @return {InjectablesRegistry} The current registry instance\n   */\n  private static getRegistry(): InjectablesRegistry {\n    if (!Injectables.actingInjectablesRegistry)\n      Injectables.actingInjectablesRegistry = new InjectableRegistryImp();\n    return Injectables.actingInjectablesRegistry;\n  }\n\n  /**\n   * @description Clears all registered injectables.\n   * @summary Resets the registry to a clean state by creating a new empty registry instance.\n   * @return {void}\n   */\n  static reset(): void {\n    Injectables.setRegistry(new InjectableRegistryImp());\n  }\n\n  /**\n   * @description Removes specific injectables from the registry based on a pattern.\n   * @summary Selectively resets the registry by removing only the injectables whose names match the provided pattern.\n   * @param {string | RegExp} match A string or regular expression pattern to match against injectable names\n   * @return {void}\n   */\n  static selectiveReset(match: string | RegExp): void {\n    const regexp = typeof match === \"string\" ? new RegExp(match) : match;\n    (Injectables.actingInjectablesRegistry as any)[\"cache\"] = Object.entries(\n      (Injectables.actingInjectablesRegistry as any)[\"cache\"]\n    ).reduce((accum: Record<string, any>, [key, val]) => {\n      if (!key.match(regexp)) accum[key] = val;\n      return accum;\n    }, {});\n  }\n}\n"]}
@@ -1,11 +1,10 @@
1
+ import { InjectableConfig } from "./decorators";
1
2
  /**
2
3
  * @description Constants used for reflection metadata keys in the dependency injection system.
3
4
  * @summary Injectables Reflection keys used to store and retrieve metadata about injectable classes and properties.
4
- *
5
5
  * @property {string} REFLECT Reflection injectables base key prefix for all metadata keys
6
6
  * @property {string} INJECTABLE Reflection key suffix for marking a class as injectable
7
7
  * @property {string} INJECT Reflection key suffix for marking a property for injection
8
- *
9
8
  * @const InjectablesKeys
10
9
  * @memberOf module:injectable-decorators
11
10
  */
@@ -14,3 +13,17 @@ export declare const InjectablesKeys: {
14
13
  INJECTABLE: string;
15
14
  INJECT: string;
16
15
  };
16
+ /**
17
+ * @description Default configuration applied by the @injectable decorator when none is provided.
18
+ * @summary Sets sensible defaults such as singleton lifecycle for newly registered injectables.
19
+ * @const DefaultInjectablesConfig
20
+ * @memberOf module:injectable-decorators
21
+ */
22
+ export declare const DefaultInjectablesConfig: InjectableConfig;
23
+ /**
24
+ * @description Reflection metadata key for accessing TypeScript type information.
25
+ * @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.
26
+ * @const TypeKey
27
+ * @memberOf module:injectable-decorators
28
+ */
29
+ export declare const TypeKey = "design:type";
@@ -1,11 +1,9 @@
1
1
  /**
2
2
  * @description Constants used for reflection metadata keys in the dependency injection system.
3
3
  * @summary Injectables Reflection keys used to store and retrieve metadata about injectable classes and properties.
4
- *
5
4
  * @property {string} REFLECT Reflection injectables base key prefix for all metadata keys
6
5
  * @property {string} INJECTABLE Reflection key suffix for marking a class as injectable
7
6
  * @property {string} INJECT Reflection key suffix for marking a property for injection
8
- *
9
7
  * @const InjectablesKeys
10
8
  * @memberOf module:injectable-decorators
11
9
  */
@@ -14,4 +12,20 @@ export const InjectablesKeys = {
14
12
  INJECTABLE: "injectable",
15
13
  INJECT: "inject",
16
14
  };
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7OztHQVVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHO0lBQzdCLE9BQU8sRUFBRSxZQUFZO0lBQ3JCLFVBQVUsRUFBRSxZQUFZO0lBQ3hCLE1BQU0sRUFBRSxRQUFRO0NBQ2pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBDb25zdGFudHMgdXNlZCBmb3IgcmVmbGVjdGlvbiBtZXRhZGF0YSBrZXlzIGluIHRoZSBkZXBlbmRlbmN5IGluamVjdGlvbiBzeXN0ZW0uXG4gKiBAc3VtbWFyeSBJbmplY3RhYmxlcyBSZWZsZWN0aW9uIGtleXMgdXNlZCB0byBzdG9yZSBhbmQgcmV0cmlldmUgbWV0YWRhdGEgYWJvdXQgaW5qZWN0YWJsZSBjbGFzc2VzIGFuZCBwcm9wZXJ0aWVzLlxuICogXG4gKiBAcHJvcGVydHkge3N0cmluZ30gUkVGTEVDVCBSZWZsZWN0aW9uIGluamVjdGFibGVzIGJhc2Uga2V5IHByZWZpeCBmb3IgYWxsIG1ldGFkYXRhIGtleXNcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBJTkpFQ1RBQkxFIFJlZmxlY3Rpb24ga2V5IHN1ZmZpeCBmb3IgbWFya2luZyBhIGNsYXNzIGFzIGluamVjdGFibGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBJTkpFQ1QgUmVmbGVjdGlvbiBrZXkgc3VmZml4IGZvciBtYXJraW5nIGEgcHJvcGVydHkgZm9yIGluamVjdGlvblxuICogXG4gKiBAY29uc3QgSW5qZWN0YWJsZXNLZXlzXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmluamVjdGFibGUtZGVjb3JhdG9yc1xuICovXG5leHBvcnQgY29uc3QgSW5qZWN0YWJsZXNLZXlzID0ge1xuICBSRUZMRUNUOiBcImluamVjdC5kYi5cIixcbiAgSU5KRUNUQUJMRTogXCJpbmplY3RhYmxlXCIsXG4gIElOSkVDVDogXCJpbmplY3RcIixcbn07XG4iXX0=
15
+ /**
16
+ * @description Default configuration applied by the @injectable decorator when none is provided.
17
+ * @summary Sets sensible defaults such as singleton lifecycle for newly registered injectables.
18
+ * @const DefaultInjectablesConfig
19
+ * @memberOf module:injectable-decorators
20
+ */
21
+ export const DefaultInjectablesConfig = {
22
+ singleton: true,
23
+ };
24
+ /**
25
+ * @description Reflection metadata key for accessing TypeScript type information.
26
+ * @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.
27
+ * @const TypeKey
28
+ * @memberOf module:injectable-decorators
29
+ */
30
+ export const TypeKey = "design:type";
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQTs7Ozs7Ozs7R0FRRztBQUNILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRztJQUM3QixPQUFPLEVBQUUsWUFBWTtJQUNyQixVQUFVLEVBQUUsWUFBWTtJQUN4QixNQUFNLEVBQUUsUUFBUTtDQUNqQixDQUFDO0FBRUY7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBcUI7SUFDeEQsU0FBUyxFQUFFLElBQUk7Q0FDaEIsQ0FBQztBQUVGOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGVDb25maWcgfSBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIENvbnN0YW50cyB1c2VkIGZvciByZWZsZWN0aW9uIG1ldGFkYXRhIGtleXMgaW4gdGhlIGRlcGVuZGVuY3kgaW5qZWN0aW9uIHN5c3RlbS5cbiAqIEBzdW1tYXJ5IEluamVjdGFibGVzIFJlZmxlY3Rpb24ga2V5cyB1c2VkIHRvIHN0b3JlIGFuZCByZXRyaWV2ZSBtZXRhZGF0YSBhYm91dCBpbmplY3RhYmxlIGNsYXNzZXMgYW5kIHByb3BlcnRpZXMuXG4gKiBAcHJvcGVydHkge3N0cmluZ30gUkVGTEVDVCBSZWZsZWN0aW9uIGluamVjdGFibGVzIGJhc2Uga2V5IHByZWZpeCBmb3IgYWxsIG1ldGFkYXRhIGtleXNcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBJTkpFQ1RBQkxFIFJlZmxlY3Rpb24ga2V5IHN1ZmZpeCBmb3IgbWFya2luZyBhIGNsYXNzIGFzIGluamVjdGFibGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBJTkpFQ1QgUmVmbGVjdGlvbiBrZXkgc3VmZml4IGZvciBtYXJraW5nIGEgcHJvcGVydHkgZm9yIGluamVjdGlvblxuICogQGNvbnN0IEluamVjdGFibGVzS2V5c1xuICogQG1lbWJlck9mIG1vZHVsZTppbmplY3RhYmxlLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IEluamVjdGFibGVzS2V5cyA9IHtcbiAgUkVGTEVDVDogXCJpbmplY3QuZGIuXCIsXG4gIElOSkVDVEFCTEU6IFwiaW5qZWN0YWJsZVwiLFxuICBJTkpFQ1Q6IFwiaW5qZWN0XCIsXG59O1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEZWZhdWx0IGNvbmZpZ3VyYXRpb24gYXBwbGllZCBieSB0aGUgQGluamVjdGFibGUgZGVjb3JhdG9yIHdoZW4gbm9uZSBpcyBwcm92aWRlZC5cbiAqIEBzdW1tYXJ5IFNldHMgc2Vuc2libGUgZGVmYXVsdHMgc3VjaCBhcyBzaW5nbGV0b24gbGlmZWN5Y2xlIGZvciBuZXdseSByZWdpc3RlcmVkIGluamVjdGFibGVzLlxuICogQGNvbnN0IERlZmF1bHRJbmplY3RhYmxlc0NvbmZpZ1xuICogQG1lbWJlck9mIG1vZHVsZTppbmplY3RhYmxlLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IERlZmF1bHRJbmplY3RhYmxlc0NvbmZpZzogSW5qZWN0YWJsZUNvbmZpZyA9IHtcbiAgc2luZ2xldG9uOiB0cnVlLFxufTtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gUmVmbGVjdGlvbiBtZXRhZGF0YSBrZXkgZm9yIGFjY2Vzc2luZyBUeXBlU2NyaXB0IHR5cGUgaW5mb3JtYXRpb24uXG4gKiBAc3VtbWFyeSBIb2xkcyB0aGUga2V5IGZvciByZXRyaWV2aW5nIHRoZSBkZXNpZ24gdHlwZSBmcm9tIFR5cGVTY3JpcHQncyByZWZsZWN0aW9uIG1ldGFkYXRhLlxuICogQGNvbnN0IFR5cGVLZXlcbiAqIEBtZW1iZXJPZiBtb2R1bGU6aW5qZWN0YWJsZS1kZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBjb25zdCBUeXBlS2V5ID0gXCJkZXNpZ246dHlwZVwiO1xuIl19