@decaf-ts/injectable-decorators 1.6.0 → 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.
@@ -5,14 +5,15 @@
5
5
  })(this, (function (exports) { 'use strict';
6
6
 
7
7
  /**
8
- * @summary Injectables Reflection keys
9
- * @const InjectablesKeys
8
+ * @description Constants used for reflection metadata keys in the dependency injection system.
9
+ * @summary Injectables Reflection keys used to store and retrieve metadata about injectable classes and properties.
10
10
  *
11
- * @property {string} REFLECT Reflection injectables base key
12
- * @property {string} INJECTABLE Reflection injectable key
13
- * @property {string} INJECT Reflection inject key
11
+ * @property {string} REFLECT Reflection injectables base key prefix for all metadata keys
12
+ * @property {string} INJECTABLE Reflection key suffix for marking a class as injectable
13
+ * @property {string} INJECT Reflection key suffix for marking a property for injection
14
14
  *
15
- * @memberOf injectable-decorators
15
+ * @const InjectablesKeys
16
+ * @memberOf module:injectable-decorators
16
17
  */
17
18
  const InjectablesKeys = {
18
19
  REFLECT: "inject.db.",
@@ -21,9 +22,46 @@
21
22
  };
22
23
 
23
24
  /**
24
- * @summary Holds the vairous {@link Injectable}s
25
+ * @description Default implementation of the InjectablesRegistry interface.
26
+ * @summary Holds the various {@link Injectable}s in a cache and provides methods to register, retrieve, and build them.
27
+ * @template T Type parameter used in the class methods
28
+ *
25
29
  * @class InjectableRegistryImp
26
30
  * @implements InjectablesRegistry
31
+ *
32
+ * @memberOf module:injectable-decorators
33
+ *
34
+ * @example
35
+ * // Create a new registry
36
+ * const registry = new InjectableRegistryImp();
37
+ *
38
+ * // Register a class
39
+ * class MyService {
40
+ * doSomething() {
41
+ * return 'Hello World';
42
+ * }
43
+ * }
44
+ * registry.register(MyService, 'MyService', true);
45
+ *
46
+ * // Get the instance
47
+ * const service = registry.get('MyService');
48
+ * service.doSomething(); // 'Hello World'
49
+ *
50
+ * @mermaid
51
+ * sequenceDiagram
52
+ * participant Client
53
+ * participant Registry
54
+ *
55
+ * Client->>Registry: register(MyService)
56
+ * Registry->>Registry: Store in cache
57
+ *
58
+ * Client->>Registry: get("MyService")
59
+ * alt Instance exists and is singleton
60
+ * Registry-->>Client: Return cached instance
61
+ * else No instance or not singleton
62
+ * Registry->>Registry: build(name)
63
+ * Registry-->>Client: Return new instance
64
+ * end
27
65
  */
28
66
  class InjectableRegistryImp {
29
67
  constructor() {
@@ -80,59 +118,117 @@
80
118
  }
81
119
 
82
120
  /**
83
- * @summary Static class Holding the access to the injectables functions
121
+ * @description Central registry for managing injectable dependencies.
122
+ * @summary Static class holding the access to the injectables functions. Provides methods for registering,
123
+ * retrieving, and building injectable objects.
124
+ * @template T Type of the injectable object
84
125
  *
85
126
  * @class Injectables
86
- * @static
127
+ *
128
+ * @example
129
+ * // Define an injectable class
130
+ * @injectable()
131
+ * class MyService {
132
+ * doSomething() {
133
+ * return 'Hello World';
134
+ * }
135
+ * }
136
+ *
137
+ * // Inject the service into another class
138
+ * class MyComponent {
139
+ * @inject()
140
+ * private service!: MyService;
141
+ *
142
+ * useService() {
143
+ * return this.service.doSomething();
144
+ * }
145
+ * }
146
+ *
147
+ * @mermaid
148
+ * sequenceDiagram
149
+ * participant Client
150
+ * participant Injectables
151
+ * participant Registry
152
+ *
153
+ * Client->>Injectables: register(MyService)
154
+ * Injectables->>Registry: register(MyService)
155
+ * Registry-->>Injectables: void
156
+ *
157
+ * Client->>Injectables: get("MyService")
158
+ * Injectables->>Registry: get("MyService")
159
+ * Registry-->>Injectables: MyService instance
160
+ * Injectables-->>Client: MyService instance
87
161
  */
88
162
  class Injectables {
89
163
  static { this.actingInjectablesRegistry = undefined; }
90
164
  constructor() { }
91
165
  /**
92
- * @summary Retrieves the named {@link Injectable} from the registry
93
- * @param {string} name
94
- * @param {any[]} args
166
+ * @description Fetches an injectable instance by its registered name.
167
+ * @summary Retrieves the named {@link Injectable} from the registry. If the injectable is a singleton,
168
+ * returns the existing instance. Otherwise, creates a new instance.
169
+ * @template T Type of the injectable object to retrieve
170
+ * @param {string} name The registered name of the injectable to retrieve
171
+ * @param {any[]} args Constructor arguments to pass when instantiating the injectable
172
+ * @return {Injectable<T> | undefined} The injectable instance or undefined if not found
95
173
  */
96
174
  static get(name, ...args) {
97
175
  return Injectables.getRegistry().get(name, ...args);
98
176
  }
99
177
  /**
100
- * @summary registers an injectable constructor
101
- * @param {Injectable} constructor
102
- * @param {any[]} args
103
- *
178
+ * @description Adds a class or object to the injectable registry.
179
+ * @summary Registers an injectable constructor or instance with the registry, making it available for injection.
180
+ * @template T Type of the injectable object to register
181
+ * @param {Injectable<T>} constructor The class constructor or object instance to register
182
+ * @param {any[]} args Additional arguments for registration (category, singleton flag, etc.)
183
+ * @return {void}
104
184
  */
105
185
  static register(constructor, ...args) {
106
186
  return Injectables.getRegistry().register(constructor, ...args);
107
187
  }
108
188
  /**
109
- * @summary Instantiates an Injectable
110
- * @param {Record<string, any>} obj
111
- * @param {any[]} args
112
- * @return T
113
- *
189
+ * @description Creates a new instance of an injectable class.
190
+ * @summary Instantiates an injectable class using its constructor and the provided arguments.
191
+ * @template T Type of the object to build
192
+ * @param {Record<string, any>} obj Object containing the name of the injectable to build
193
+ * @param {any[]} args Constructor arguments to pass when instantiating the injectable
194
+ * @return {T} The newly created instance
114
195
  */
115
196
  static build(obj, ...args) {
116
197
  return Injectables.getRegistry().build(obj, ...args);
117
198
  }
118
199
  /**
119
- * @summary Sets a new {@link InjectablesRegistry}
120
- * @param {InjectablesRegistry} operationsRegistry the new implementation of Registry
200
+ * @description Replaces the current registry implementation.
201
+ * @summary Sets a new {@link InjectablesRegistry} implementation, allowing for custom registry behavior.
202
+ * @param {InjectablesRegistry} operationsRegistry The new implementation of Registry to use
203
+ * @return {void}
121
204
  */
122
205
  static setRegistry(operationsRegistry) {
123
206
  Injectables.actingInjectablesRegistry = operationsRegistry;
124
207
  }
125
208
  /**
126
- * @summary Returns the current {@link InjectablesRegistry}
209
+ * @description Provides access to the current registry instance.
210
+ * @summary Returns the current {@link InjectablesRegistry} or creates a default one if none exists.
211
+ * @return {InjectablesRegistry} The current registry instance
127
212
  */
128
213
  static getRegistry() {
129
214
  if (!Injectables.actingInjectablesRegistry)
130
215
  Injectables.actingInjectablesRegistry = new InjectableRegistryImp();
131
216
  return Injectables.actingInjectablesRegistry;
132
217
  }
218
+ /**
219
+ * @description Clears all registered injectables.
220
+ * @summary Resets the registry to a clean state by creating a new empty registry instance.
221
+ * @return {void}
222
+ */
133
223
  static reset() {
134
224
  Injectables.setRegistry(new InjectableRegistryImp());
135
225
  }
226
+ /**
227
+ * @description Removes specific injectables from the registry based on a pattern.
228
+ * @summary Selectively resets the registry by removing only the injectables whose names match the provided pattern.
229
+ * @param {string | RegExp} match A string or regular expression pattern to match against injectable names
230
+ * @return {void}
231
+ */
136
232
  static selectiveReset(match) {
137
233
  const regexp = typeof match === "string" ? new RegExp(match) : match;
138
234
  Injectables.actingInjectablesRegistry["cache"] = Object.entries(Injectables.actingInjectablesRegistry["cache"]).reduce((accum, [key, val]) => {
@@ -144,19 +240,19 @@
144
240
  }
145
241
 
146
242
  /**
147
- * @summary holds the key for the design type
243
+ * @description Reflection metadata key for accessing TypeScript type information.
244
+ * @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.
148
245
  * @const TypeKey
149
- * @memberOf module:injectable-decorators
246
+ * @memberOf module:injectable-decorators
150
247
  */
151
248
  const TypeKey = "design:type";
152
249
  /**
153
- * @summary Retrieves the type from the decorators
154
- * @param {any} model
155
- * @param {string | symbol} propKey
156
- * @return {string | undefined}
157
- *
158
- * @function geTypeFromDecorators
159
- *
250
+ * @description Extracts the type name from a decorated property using reflection.
251
+ * @summary Retrieves the type from a property decorator by accessing TypeScript's reflection metadata.
252
+ * @param {any} model The target object containing the decorated property
253
+ * @param {string | symbol} propKey The property key (name or symbol) of the decorated property
254
+ * @return {string | undefined} The name of the property type, or undefined if it's a Function type
255
+ * @function getTypeFromDecorator
160
256
  * @memberOf module:injectable-decorators
161
257
  */
162
258
  function getTypeFromDecorator(model, propKey) {
@@ -165,69 +261,97 @@
165
261
  }
166
262
 
167
263
  /**
168
- * @summary Return the reflection key for injectables
169
- *
170
- * @param {string} key
264
+ * @description Generates a fully qualified reflection metadata key.
265
+ * @summary Returns the reflection key for injectables by prefixing the provided key with the base reflection key.
266
+ * @param {string} key The key to be prefixed
267
+ * @return {string} The fully qualified reflection key
171
268
  * @function getInjectKey
172
- *
173
269
  * @memberOf module:injectable-decorators
174
270
  */
175
271
  const getInjectKey = (key) => InjectablesKeys.REFLECT + key;
176
272
  /**
177
- * @summary Defines a class as an injectable
273
+ * @description Decorator that marks a class as available for dependency injection.
274
+ * @summary Defines a class as an injectable singleton that can be retrieved from the registry.
275
+ * When applied to a class, replaces its constructor with one that returns a singleton instance.
178
276
  *
179
- * @param {string} [category] defaults to the class Name. (Useful when minification occours and names are changed so we can no longer rely on the class name, or when we want to upcast the Object)
180
- * @param {boolean} [force] defines if the injectable should override the already existing instance (if any). (only meant for extending decorators
181
- * @param instanceCallback
277
+ * @param {string} [category] Defaults to the class name. Useful when minification occurs and names are changed,
278
+ * or when you want to upcast the object to a different type.
279
+ * @param {boolean} [force] Defines if the injectable should override an already existing instance (if any).
280
+ * Only meant for extending decorators.
281
+ * @param {Function} [instanceCallback] Optional callback function that will be called with the instance after creation.
282
+ * @return {Function} A decorator function that transforms the class into an injectable.
182
283
  *
183
284
  * @function injectable
285
+ * @category Class Decorators
184
286
  *
185
- * @memberOf module:injectable-decorators.Decorators
287
+ * @mermaid
288
+ * sequenceDiagram
289
+ * participant Client
290
+ * participant Decorator
291
+ * participant Injectables
292
+ *
293
+ * Client->>Decorator: @injectable()
294
+ * Decorator->>Decorator: Create new constructor
295
+ *
296
+ * Note over Decorator: When new instance requested
297
+ * Decorator->>Injectables: get(name)
298
+ * alt Instance exists
299
+ * Injectables-->>Decorator: Return existing instance
300
+ * else No instance
301
+ * Decorator->>Injectables: register(original, name)
302
+ * Decorator->>Injectables: get(name)
303
+ * Injectables-->>Decorator: Return new instance
304
+ * opt Has callback
305
+ * Decorator->>Decorator: Call instanceCallback
306
+ * end
307
+ * end
308
+ * Decorator->>Decorator: Define metadata
309
+ * Decorator-->>Client: Return instance
186
310
  */
187
- const injectable = (category = undefined, force = false, instanceCallback) =>
188
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
189
- (original, propertyKey) => {
190
- const name = category || original.name;
191
- // the new constructor behaviour
192
- const newConstructor = function (...args) {
193
- let inj = Injectables.get(name, ...args);
194
- if (!inj) {
195
- Injectables.register(original, name, true, force);
196
- inj = Injectables.get(name, ...args);
197
- if (!inj)
198
- return undefined;
199
- if (instanceCallback)
200
- try {
201
- instanceCallback(inj);
202
- }
203
- catch (e) {
204
- console.error(`Failed to call injectable callback for ${name}: ${e}`);
205
- }
206
- }
207
- const metadata = Object.assign({}, {
208
- class: name,
311
+ function injectable(category = undefined, force = false, instanceCallback) {
312
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
313
+ return (original, propertyKey) => {
314
+ const name = category || original.name;
315
+ // the new constructor behaviour
316
+ const newConstructor = function (...args) {
317
+ let inj = Injectables.get(name, ...args);
318
+ if (!inj) {
319
+ Injectables.register(original, name, true, force);
320
+ inj = Injectables.get(name, ...args);
321
+ if (!inj)
322
+ return undefined;
323
+ if (instanceCallback)
324
+ try {
325
+ instanceCallback(inj);
326
+ }
327
+ catch (e) {
328
+ console.error(`Failed to call injectable callback for ${name}: ${e}`);
329
+ }
330
+ }
331
+ const metadata = Object.assign({}, {
332
+ class: name,
333
+ });
334
+ Reflect.defineMetadata(getInjectKey(InjectablesKeys.INJECTABLE), metadata, inj.constructor);
335
+ return inj;
336
+ };
337
+ // copy prototype so instanceof operator still works
338
+ newConstructor.prototype = original.prototype;
339
+ // newConstructor.__proto__ = original.__proto__;
340
+ // Sets the proper constructor name for type verification
341
+ Object.defineProperty(newConstructor, "name", {
342
+ writable: false,
343
+ enumerable: true,
344
+ configurable: false,
345
+ value: original.prototype.constructor.name,
209
346
  });
210
- Reflect.defineMetadata(getInjectKey(InjectablesKeys.INJECTABLE), metadata, inj.constructor);
211
- return inj;
347
+ // return new constructor (will override original)
348
+ return newConstructor;
212
349
  };
213
- // copy prototype so instanceof operator still works
214
- newConstructor.prototype = original.prototype;
215
- // newConstructor.__proto__ = original.__proto__;
216
- // Sets the proper constructor name for type verification
217
- Object.defineProperty(newConstructor, "name", {
218
- writable: false,
219
- enumerable: true,
220
- configurable: false,
221
- value: original.prototype.constructor.name,
222
- });
223
- // return new constructor (will override original)
224
- return newConstructor;
225
- };
350
+ }
226
351
  /**
227
- * @summary Allows for the injection of an {@link injectable} decorated dependency
228
- * @description the property must be typed for the requested dependency.
229
- *
230
- * Only concrete classes. No generics are supported
352
+ * @description Property decorator that injects a dependency into a class property.
353
+ * @summary Allows for the injection of an {@link injectable} decorated dependency into a class property.
354
+ * The property must be typed for the requested dependency. Only concrete classes are supported; generics are not.
231
355
  *
232
356
  * Injected properties should be described like so:
233
357
  * <pre>
@@ -242,73 +366,104 @@
242
366
  * </pre>
243
367
  *
244
368
  * where InjectableClass is the class you want to inject.
245
- * Notice the use of '!:' to ensure the transpiler the property will be set outside the constructor but will always be defined
246
- * For project where minification occours, you should use the category param to ensure the name is the same throughout
369
+ * Notice the use of '!:' to ensure the transpiler the property will be set outside the constructor but will always be defined.
370
+ * For projects where minification occurs, you should use the category param to ensure the name is the same throughout.
247
371
  *
248
- * @param {string} [category] defaults to the class Name. (Useful when minification occours and names are changed so we can no longer rely on the class name, or when we want to upcast the Object)
249
- * @param {InstanceTransformer} [transformer]
372
+ * @param {string} [category] Defaults to the class name derived from the property type. Useful when minification occurs
373
+ * and names are changed, or when you want to upcast the object to a different type.
374
+ * @param {InstanceTransformer} [transformer] Optional function to transform the injectable instance before it's injected.
375
+ * @return {Function} A property decorator function that sets up the dependency injection.
250
376
  *
251
377
  * @function inject
378
+ * @category Property Decorators
379
+ *
380
+ * @mermaid
381
+ * sequenceDiagram
382
+ * participant Client
383
+ * participant Decorator
384
+ * participant Injectables
385
+ *
386
+ * Client->>Decorator: @inject()
387
+ * Decorator->>Decorator: Get type from property
388
+ * Decorator->>Decorator: Define metadata
389
+ * Decorator->>Decorator: Define property getter
252
390
  *
253
- * @memberOf module:injectable-decorators.Decorators
391
+ * Note over Decorator: When property accessed
392
+ * Client->>Decorator: access property
393
+ * Decorator->>Decorator: Check if instance exists
394
+ * alt Instance exists in WeakMap
395
+ * Decorator-->>Client: Return cached instance
396
+ * else No instance
397
+ * Decorator->>Injectables: get(name)
398
+ * alt Injectable found
399
+ * Injectables-->>Decorator: Return injectable instance
400
+ * opt Has transformer
401
+ * Decorator->>Decorator: Call transformer
402
+ * end
403
+ * Decorator->>Decorator: Store in WeakMap
404
+ * Decorator-->>Client: Return instance
405
+ * else No injectable
406
+ * Decorator-->>Client: Throw error
407
+ * end
408
+ * end
254
409
  */
255
- const inject = (category, transformer) => (target, propertyKey) => {
256
- const values = new WeakMap();
257
- const name = category || getTypeFromDecorator(target, propertyKey);
258
- if (!name)
259
- throw new Error(`Could not get Type from decorator`);
260
- Reflect.defineMetadata(getInjectKey(InjectablesKeys.INJECT), {
261
- injectable: name,
262
- }, target, propertyKey);
263
- Object.defineProperty(target, propertyKey, {
264
- configurable: true,
265
- get() {
266
- const descriptor = Object.getOwnPropertyDescriptor(target, propertyKey);
267
- if (descriptor.configurable) {
268
- Object.defineProperty(this, propertyKey, {
269
- enumerable: true,
270
- configurable: false,
271
- get() {
272
- let obj = values.get(this);
273
- if (!obj) {
274
- obj = Injectables.get(name);
275
- if (!obj)
276
- throw new Error(`Could not get Injectable ${name} to inject in ${target.constructor ? target.constructor.name : target.name}'s ${propertyKey}`);
277
- if (transformer)
278
- try {
279
- obj = transformer(obj, target);
280
- }
281
- catch (e) {
282
- console.error(e);
283
- }
284
- values.set(this, obj);
285
- }
286
- return obj;
287
- },
288
- });
289
- return this[propertyKey];
290
- }
291
- },
292
- });
293
- };
410
+ function inject(category, transformer) {
411
+ return (target, propertyKey) => {
412
+ const values = new WeakMap();
413
+ const name = category || getTypeFromDecorator(target, propertyKey);
414
+ if (!name)
415
+ throw new Error(`Could not get Type from decorator`);
416
+ Reflect.defineMetadata(getInjectKey(InjectablesKeys.INJECT), {
417
+ injectable: name,
418
+ }, target, propertyKey);
419
+ Object.defineProperty(target, propertyKey, {
420
+ configurable: true,
421
+ get() {
422
+ const descriptor = Object.getOwnPropertyDescriptor(target, propertyKey);
423
+ if (descriptor.configurable) {
424
+ Object.defineProperty(this, propertyKey, {
425
+ enumerable: true,
426
+ configurable: false,
427
+ get() {
428
+ let obj = values.get(this);
429
+ if (!obj) {
430
+ obj = Injectables.get(name);
431
+ if (!obj)
432
+ throw new Error(`Could not get Injectable ${name} to inject in ${target.constructor ? target.constructor.name : target.name}'s ${propertyKey}`);
433
+ if (transformer)
434
+ try {
435
+ obj = transformer(obj, target);
436
+ }
437
+ catch (e) {
438
+ console.error(e);
439
+ }
440
+ values.set(this, obj);
441
+ }
442
+ return obj;
443
+ },
444
+ });
445
+ return this[propertyKey];
446
+ }
447
+ },
448
+ });
449
+ };
450
+ }
294
451
 
295
452
  /**
453
+ * @description A lightweight dependency injection library for TypeScript applications.
296
454
  * @summary Adds a simple Injectables implementation to create singleton instances of an object
297
- * and easily inject it into other objects
455
+ * and easily inject it into other objects. Provides decorators for marking classes as injectable
456
+ * and for injecting dependencies into class properties.
298
457
  *
299
458
  * @module injectable-decorators
300
459
  */
301
460
  /**
302
- * @summary functions that decorate classes or class properties
303
- * @namespace Decorators
304
- * @memberOf module:injectable-decorators
305
- */
306
- /**
307
- * @summary Defined on library build. holds the library current version
461
+ * @description Current version of the injectable-decorators library.
462
+ * @summary Defined on library build. Holds the library's current version string.
308
463
  * @const VERSION
309
464
  * @memberOf module:injectable-decorators
310
465
  */
311
- const VERSION = "1.6.0";
466
+ const VERSION = "1.6.2";
312
467
 
313
468
  exports.InjectableRegistryImp = InjectableRegistryImp;
314
469
  exports.Injectables = Injectables;
@@ -320,4 +475,4 @@
320
475
  exports.injectable = injectable;
321
476
 
322
477
  }));
323
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"injectable-decorators.cjs","sources":["../src/constants.ts","../src/registry.ts","../src/Injectables.ts","../src/utils.ts","../src/decorators.ts","../src/index.ts"],"sourcesContent":["/**\n * @summary Injectables Reflection keys\n * @const InjectablesKeys\n *\n * @property {string} REFLECT Reflection injectables base key\n * @property {string} INJECTABLE Reflection injectable key\n * @property {string} INJECT Reflection inject key\n *\n * @memberOf injectable-decorators\n */\nexport const InjectablesKeys = {\n  REFLECT: \"inject.db.\",\n  INJECTABLE: \"injectable\",\n  INJECT: \"inject\",\n};\n","/**\n * @summary defines an Injectable type\n * @memberOf module:injectable-decorators\n */\nexport type Injectable<T> = { new (...args: any[]): T } | T;\n\n/**\n * @summary Interface for an injectable registry\n * @interface InjectableRegistry\n */\nexport interface InjectablesRegistry {\n  /**\n   * @summary retrieves an {@link Injectable}\n   * @param {string} name\n   * @param {any[]} args\n   * @return {Injectable | undefined}\n   *\n   * @method\n   */\n  get<T>(name: string, ...args: any[]): Injectable<T> | undefined;\n\n  /**\n   * @summary registers an injectable constructor\n   * @param {Injectable} constructor\n   * @param {any[]} args\n   *\n   * @method\n   */\n  register<T>(constructor: Injectable<T>, ...args: any[]): void;\n\n  /**\n   * @summary Instantiates an Injectable\n   * @param {Record<string, any>} obj\n   * @param {any[]} args\n   * @return T\n   *\n   * @method\n   */\n  build<T>(obj: Record<string, any>, ...args: any[]): T;\n}\n\n/**\n * @summary Holds the vairous {@link Injectable}s\n * @class InjectableRegistryImp\n * @implements InjectablesRegistry\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","import {\n  Injectable,\n  InjectableRegistryImp,\n  InjectablesRegistry,\n} from \"./registry\";\n\n/**\n * @summary Static class Holding the access to the injectables functions\n *\n * @class Injectables\n * @static\n */\nexport class Injectables {\n  private static actingInjectablesRegistry?: InjectablesRegistry = undefined;\n\n  private constructor() {}\n\n  /**\n   * @summary Retrieves the named {@link Injectable} from the registry\n   * @param {string} name\n   * @param {any[]} args\n   */\n  static get<T>(name: string, ...args: any[]): Injectable<T> | undefined {\n    return Injectables.getRegistry().get(name, ...args);\n  }\n\n  /**\n   * @summary registers an injectable constructor\n   * @param {Injectable} constructor\n   * @param {any[]} args\n   *\n   */\n  static register<T>(constructor: Injectable<T>, ...args: any[]): void {\n    return Injectables.getRegistry().register(constructor, ...args);\n  }\n\n  /**\n   * @summary Instantiates an Injectable\n   * @param {Record<string, any>} obj\n   * @param {any[]} args\n   * @return T\n   *\n   */\n  static build<T>(obj: Record<string, any>, ...args: any[]): T {\n    return Injectables.getRegistry().build(obj, ...args);\n  }\n\n  /**\n   * @summary Sets a new {@link InjectablesRegistry}\n   * @param {InjectablesRegistry} operationsRegistry the new implementation of Registry\n   */\n  static setRegistry(operationsRegistry: InjectablesRegistry) {\n    Injectables.actingInjectablesRegistry = operationsRegistry;\n  }\n  /**\n   * @summary Returns the current {@link InjectablesRegistry}\n   */\n  private static getRegistry() {\n    if (!Injectables.actingInjectablesRegistry)\n      Injectables.actingInjectablesRegistry = new InjectableRegistryImp();\n    return Injectables.actingInjectablesRegistry;\n  }\n\n  static reset() {\n    Injectables.setRegistry(new InjectableRegistryImp());\n  }\n\n  static selectiveReset(match: string | RegExp) {\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","import \"reflect-metadata\";\n\n/**\n * @summary holds the key for the design type\n * @const TypeKey\n * @memberOf  module:injectable-decorators\n */\nexport const TypeKey = \"design:type\";\n\n/**\n * @summary Retrieves the type from the decorators\n * @param {any} model\n * @param {string | symbol} propKey\n * @return {string | undefined}\n *\n * @function geTypeFromDecorators\n *\n * @memberOf module:injectable-decorators\n */\nexport function getTypeFromDecorator(\n  model: any,\n  propKey: string | symbol,\n): string | undefined {\n  const typeDef = Reflect.getMetadata(TypeKey, model, propKey);\n  return typeDef.name !== \"Function\" ? typeDef.name : undefined;\n}\n","import { InjectablesKeys } from \"./constants\";\nimport { Injectables } from \"./Injectables\";\nimport { getTypeFromDecorator } from \"./utils\";\n\n/**\n * @summary Return the reflection key for injectables\n *\n * @param {string} key\n * @function getInjectKey\n *\n * @memberOf module:injectable-decorators\n */\nconst getInjectKey = (key: string) => InjectablesKeys.REFLECT + key;\n\n/**\n * @summary Defines a class as an injectable\n *\n * @param {string} [category] defaults to the class Name. (Useful when minification occours and names are changed so we can no longer rely on the class name, or when we want to upcast the Object)\n * @param {boolean} [force] defines if the injectable should override the already existing instance (if any). (only meant for extending decorators\n * @param instanceCallback\n *\n * @function injectable\n *\n * @memberOf module:injectable-decorators.Decorators\n */\nexport const injectable =\n  (\n    category: string | undefined = undefined,\n    force: boolean = false,\n    instanceCallback?: (instance: any, ...args: any[]) => void\n  ) =>\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  (original: any, propertyKey?: any) => {\n    const name = category || original.name;\n    // the new constructor behaviour\n    const newConstructor: any = function (...args: any[]) {\n      let inj: any = Injectables.get<any>(name, ...args);\n      if (!inj) {\n        Injectables.register(original, name, true, force);\n        inj = Injectables.get<any>(name, ...args);\n        if (!inj) return undefined;\n\n        if (instanceCallback)\n          try {\n            instanceCallback(inj);\n          } catch (e: any) {\n            console.error(\n              `Failed to call injectable callback for ${name}: ${e}`\n            );\n          }\n      }\n\n      const metadata = Object.assign(\n        {},\n        {\n          class: name,\n        }\n      );\n\n      Reflect.defineMetadata(\n        getInjectKey(InjectablesKeys.INJECTABLE),\n        metadata,\n        inj.constructor\n      );\n\n      return inj;\n    };\n\n    // copy prototype so instanceof operator still works\n    newConstructor.prototype = original.prototype;\n    // newConstructor.__proto__ = original.__proto__;\n    // Sets the proper constructor name for type verification\n    Object.defineProperty(newConstructor, \"name\", {\n      writable: false,\n      enumerable: true,\n      configurable: false,\n      value: original.prototype.constructor.name,\n    });\n    // return new constructor (will override original)\n    return newConstructor;\n  };\n\n/**\n * @summary function witch transforms a cached {@link injectable}\n *\n * @param {any} injectable\n * @param {any} obj the obj the injectable will be injected on\n *\n * @memberOf module:injectable-decorators\n */\nexport type InstanceTransformer = (injectable: any, obj: any) => any;\n\n/**\n * @summary Allows for the injection of an {@link injectable} decorated dependency\n * @description the property must be typed for the requested dependency.\n *\n * Only concrete classes. No generics are supported\n *\n * Injected properties should be described like so:\n * <pre>\n *     class ClassName {\n *         ...\n *\n *         @inject()\n *         propertyName!: InjectableClass;\n *\n *         ...\n *     }\n * </pre>\n *\n * where InjectableClass is the class you want to inject.\n * Notice the use of '!:' to ensure the transpiler the property will be set outside the constructor but will always be defined\n * For project where minification occours, you should use the category param to ensure the name is the same throughout\n *\n * @param {string} [category] defaults to the class Name. (Useful when minification occours and names are changed so we can no longer rely on the class name, or when we want to upcast the Object)\n * @param {InstanceTransformer} [transformer]\n *\n * @function inject\n *\n * @memberOf module:injectable-decorators.Decorators\n */\nexport const inject =\n  (category?: string, transformer?: InstanceTransformer) =>\n  (target: any, propertyKey?: any) => {\n    const values = new WeakMap();\n\n    const name: string | undefined =\n      category || getTypeFromDecorator(target, propertyKey);\n    if (!name) throw new Error(`Could not get Type from decorator`);\n\n    Reflect.defineMetadata(\n      getInjectKey(InjectablesKeys.INJECT),\n      {\n        injectable: name,\n      },\n      target,\n      propertyKey\n    );\n\n    Object.defineProperty(target, propertyKey, {\n      configurable: true,\n      get(this: any) {\n        const descriptor: PropertyDescriptor = Object.getOwnPropertyDescriptor(\n          target,\n          propertyKey\n        ) as PropertyDescriptor;\n        if (descriptor.configurable) {\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get(this: any) {\n              let obj = values.get(this);\n              if (!obj) {\n                obj = Injectables.get(name);\n                if (!obj)\n                  throw new Error(\n                    `Could not get Injectable ${name} to inject in ${target.constructor ? target.constructor.name : target.name}'s ${propertyKey}`\n                  );\n                if (transformer)\n                  try {\n                    obj = transformer(obj, target);\n                  } catch (e) {\n                    console.error(e);\n                  }\n                values.set(this, obj);\n              }\n              return obj;\n            },\n          });\n          return this[propertyKey];\n        }\n      },\n    });\n  };\n","/**\n * @summary Adds a simple Injectables implementation to create singleton instances of an object\n * and easily inject it into other objects\n *\n * @module injectable-decorators\n */\n\n/**\n * @summary functions that decorate classes or class properties\n * @namespace Decorators\n * @memberOf module:injectable-decorators\n */\n\nexport * from \"./constants\";\nexport * from \"./decorators\";\nexport * from \"./Injectables\";\nexport * from \"./registry\";\nexport * from \"./utils\";\n\n/**\n * @summary Defined on library build. holds the library current version\n * @const VERSION\n * @memberOf module:injectable-decorators\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":[],"mappings":"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"}
478
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"injectable-decorators.cjs","sources":["../src/constants.ts","../src/registry.ts","../src/Injectables.ts","../src/utils.ts","../src/decorators.ts","../src/index.ts"],"sourcesContent":["/**\n * @description Constants used for reflection metadata keys in the dependency injection system.\n * @summary Injectables Reflection keys used to store and retrieve metadata about injectable classes and properties.\n * \n * @property {string} REFLECT Reflection injectables base key prefix for all metadata keys\n * @property {string} INJECTABLE Reflection key suffix for marking a class as injectable\n * @property {string} INJECT Reflection key suffix for marking a property for injection\n * \n * @const InjectablesKeys\n * @memberOf module:injectable-decorators\n */\nexport const InjectablesKeys = {\n  REFLECT: \"inject.db.\",\n  INJECTABLE: \"injectable\",\n  INJECT: \"inject\",\n};\n","/**\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","import {\n  Injectable,\n  InjectableRegistryImp,\n  InjectablesRegistry,\n} from \"./registry\";\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>(name: string, ...args: any[]): Injectable<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(constructor, ...args);\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 {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   */\n  static build<T>(obj: Record<string, any>, ...args: any[]): T {\n    return Injectables.getRegistry().build(obj, ...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) {\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() {\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() {\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) {\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","import \"reflect-metadata\";\n\n/**\n * @description Reflection metadata key for accessing TypeScript type information.\n * @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.\n * @const TypeKey\n * @memberOf module:injectable-decorators\n */\nexport const TypeKey = \"design:type\";\n\n/**\n * @description Extracts the type name from a decorated property using reflection.\n * @summary Retrieves the type from a property decorator by accessing TypeScript's reflection metadata.\n * @param {any} model The target object containing the decorated property\n * @param {string | symbol} propKey The property key (name or symbol) of the decorated property\n * @return {string | undefined} The name of the property type, or undefined if it's a Function type\n * @function getTypeFromDecorator\n * @memberOf module:injectable-decorators\n */\nexport function getTypeFromDecorator(\n  model: any,\n  propKey: string | symbol,\n): string | undefined {\n  const typeDef = Reflect.getMetadata(TypeKey, model, propKey);\n  return typeDef.name !== \"Function\" ? typeDef.name : undefined;\n}\n","import { InjectablesKeys } from \"./constants\";\nimport { Injectables } from \"./Injectables\";\nimport { getTypeFromDecorator } from \"./utils\";\n\n/**\n * @description Generates a fully qualified reflection metadata key.\n * @summary Returns the reflection key for injectables by prefixing the provided key with the base reflection key.\n * @param {string} key The key to be prefixed\n * @return {string} The fully qualified reflection key\n * @function getInjectKey\n * @memberOf module:injectable-decorators\n */\nconst getInjectKey = (key: string) => InjectablesKeys.REFLECT + key;\n\n/**\n * @description Decorator that marks a class as available for dependency injection.\n * @summary Defines a class as an injectable singleton that can be retrieved from the registry.\n * When applied to a class, replaces its constructor with one that returns a singleton instance.\n *\n * @param {string} [category] Defaults to the class name. Useful when minification occurs and names are changed,\n * or when you want to upcast the object to a different type.\n * @param {boolean} [force] Defines if the injectable should override an already existing instance (if any).\n * Only meant for extending decorators.\n * @param {Function} [instanceCallback] Optional callback function that will be called with the instance after creation.\n * @return {Function} A decorator function that transforms the class into an injectable.\n *\n * @function injectable\n * @category Class Decorators\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator\n *   participant Injectables\n *\n *   Client->>Decorator: @injectable()\n *   Decorator->>Decorator: Create new constructor\n *\n *   Note over Decorator: When new instance requested\n *   Decorator->>Injectables: get(name)\n *   alt Instance exists\n *     Injectables-->>Decorator: Return existing instance\n *   else No instance\n *     Decorator->>Injectables: register(original, name)\n *     Decorator->>Injectables: get(name)\n *     Injectables-->>Decorator: Return new instance\n *     opt Has callback\n *       Decorator->>Decorator: Call instanceCallback\n *     end\n *   end\n *   Decorator->>Decorator: Define metadata\n *   Decorator-->>Client: Return instance\n */\nexport function injectable(\n  category: string | undefined = undefined,\n  force: boolean = false,\n  instanceCallback?: (instance: any, ...args: any[]) => void\n) {\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  return (original: any, propertyKey?: any) => {\n    const name = category || original.name;\n    // the new constructor behaviour\n    const newConstructor: any = function (...args: any[]) {\n      let inj: any = Injectables.get<any>(name, ...args);\n      if (!inj) {\n        Injectables.register(original, name, true, force);\n        inj = Injectables.get<any>(name, ...args);\n        if (!inj) return undefined;\n\n        if (instanceCallback)\n          try {\n            instanceCallback(inj);\n          } catch (e: any) {\n            console.error(\n              `Failed to call injectable callback for ${name}: ${e}`\n            );\n          }\n      }\n\n      const metadata = Object.assign(\n        {},\n        {\n          class: name,\n        }\n      );\n\n      Reflect.defineMetadata(\n        getInjectKey(InjectablesKeys.INJECTABLE),\n        metadata,\n        inj.constructor\n      );\n\n      return inj;\n    };\n\n    // copy prototype so instanceof operator still works\n    newConstructor.prototype = original.prototype;\n    // newConstructor.__proto__ = original.__proto__;\n    // Sets the proper constructor name for type verification\n    Object.defineProperty(newConstructor, \"name\", {\n      writable: false,\n      enumerable: true,\n      configurable: false,\n      value: original.prototype.constructor.name,\n    });\n    // return new constructor (will override original)\n    return newConstructor;\n  };\n}\n/**\n * @description Function type for transforming injectable instances before they're injected.\n * @summary Function which transforms a cached {@link injectable} instance before it's injected into a target object.\n *\n * @param {any} injectable The injectable instance to transform\n * @param {any} obj The object the injectable will be injected on\n * @return {any} The transformed injectable instance\n *\n * @typedef {Function} InstanceTransformer\n * @memberOf module:injectable-decorators\n */\nexport type InstanceTransformer = (injectable: any, obj: any) => any;\n\n/**\n * @description Property decorator that injects a dependency into a class property.\n * @summary Allows for the injection of an {@link injectable} decorated dependency into a class property.\n * The property must be typed for the requested dependency. Only concrete classes are supported; generics are not.\n *\n * Injected properties should be described like so:\n * <pre>\n *     class ClassName {\n *         ...\n *\n *         @inject()\n *         propertyName!: InjectableClass;\n *\n *         ...\n *     }\n * </pre>\n *\n * where InjectableClass is the class you want to inject.\n * Notice the use of '!:' to ensure the transpiler the property will be set outside the constructor but will always be defined.\n * For projects where minification occurs, you should use the category param to ensure the name is the same throughout.\n *\n * @param {string} [category] Defaults to the class name derived from the property type. Useful when minification occurs\n * and names are changed, or when you want to upcast the object to a different type.\n * @param {InstanceTransformer} [transformer] Optional function to transform the injectable instance before it's injected.\n * @return {Function} A property decorator function that sets up the dependency injection.\n *\n * @function inject\n * @category Property Decorators\n *\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator\n *   participant Injectables\n *\n *   Client->>Decorator: @inject()\n *   Decorator->>Decorator: Get type from property\n *   Decorator->>Decorator: Define metadata\n *   Decorator->>Decorator: Define property getter\n *\n *   Note over Decorator: When property accessed\n *   Client->>Decorator: access property\n *   Decorator->>Decorator: Check if instance exists\n *   alt Instance exists in WeakMap\n *     Decorator-->>Client: Return cached instance\n *   else No instance\n *     Decorator->>Injectables: get(name)\n *     alt Injectable found\n *       Injectables-->>Decorator: Return injectable instance\n *       opt Has transformer\n *         Decorator->>Decorator: Call transformer\n *       end\n *       Decorator->>Decorator: Store in WeakMap\n *       Decorator-->>Client: Return instance\n *     else No injectable\n *       Decorator-->>Client: Throw error\n *     end\n *   end\n */\nexport function inject(category?: string, transformer?: InstanceTransformer) {\n  return (target: any, propertyKey?: any) => {\n    const values = new WeakMap();\n\n    const name: string | undefined =\n      category || getTypeFromDecorator(target, propertyKey);\n    if (!name) throw new Error(`Could not get Type from decorator`);\n\n    Reflect.defineMetadata(\n      getInjectKey(InjectablesKeys.INJECT),\n      {\n        injectable: name,\n      },\n      target,\n      propertyKey\n    );\n\n    Object.defineProperty(target, propertyKey, {\n      configurable: true,\n      get(this: any) {\n        const descriptor: PropertyDescriptor = Object.getOwnPropertyDescriptor(\n          target,\n          propertyKey\n        ) as PropertyDescriptor;\n        if (descriptor.configurable) {\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get(this: any) {\n              let obj = values.get(this);\n              if (!obj) {\n                obj = Injectables.get(name);\n                if (!obj)\n                  throw new Error(\n                    `Could not get Injectable ${name} to inject in ${target.constructor ? target.constructor.name : target.name}'s ${propertyKey}`\n                  );\n                if (transformer)\n                  try {\n                    obj = transformer(obj, target);\n                  } catch (e) {\n                    console.error(e);\n                  }\n                values.set(this, obj);\n              }\n              return obj;\n            },\n          });\n          return this[propertyKey];\n        }\n      },\n    });\n  };\n}\n","/**\n * @description A lightweight dependency injection library for TypeScript applications.\n * @summary Adds a simple Injectables implementation to create singleton instances of an object\n * and easily inject it into other objects. Provides decorators for marking classes as injectable\n * and for injecting dependencies into class properties.\n *\n * @module injectable-decorators\n */\n\nexport * from \"./constants\";\nexport * from \"./decorators\";\nexport * from \"./Injectables\";\nexport * from \"./registry\";\nexport * from \"./utils\";\n\n/**\n * @description Current version of the injectable-decorators library.\n * @summary Defined on library build. Holds the library's current version string.\n * @const VERSION\n * @memberOf module:injectable-decorators\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":[],"mappings":"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"}