@decaf-ts/injectable-decorators 1.6.17 → 1.8.0

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.
Files changed (45) hide show
  1. package/README.md +22 -2
  2. package/dist/injectable-decorators.cjs +2 -541
  3. package/dist/injectable-decorators.cjs.map +1 -0
  4. package/dist/injectable-decorators.js +2 -0
  5. package/dist/injectable-decorators.js.map +1 -0
  6. package/lib/Injectables.cjs +1 -1
  7. package/lib/Injectables.js.map +1 -0
  8. package/lib/Metadata.cjs +1 -1
  9. package/lib/Metadata.js.map +1 -0
  10. package/lib/constants.cjs +1 -1
  11. package/lib/constants.js.map +1 -0
  12. package/lib/decorators.cjs +1 -1
  13. package/lib/decorators.js.map +1 -0
  14. package/lib/esm/Injectables.js +1 -1
  15. package/lib/esm/Injectables.js.map +1 -0
  16. package/lib/esm/Metadata.js +1 -1
  17. package/lib/esm/Metadata.js.map +1 -0
  18. package/lib/esm/constants.js +1 -1
  19. package/lib/esm/constants.js.map +1 -0
  20. package/lib/esm/decorators.js +1 -1
  21. package/lib/esm/decorators.js.map +1 -0
  22. package/lib/esm/index.d.ts +2 -2
  23. package/lib/esm/index.js +3 -3
  24. package/lib/esm/index.js.map +1 -0
  25. package/lib/esm/overrides.js +1 -1
  26. package/lib/esm/overrides.js.map +1 -0
  27. package/lib/esm/registry.js +1 -1
  28. package/lib/esm/registry.js.map +1 -0
  29. package/lib/esm/types.js +1 -1
  30. package/lib/esm/types.js.map +1 -0
  31. package/lib/esm/utils.js +1 -1
  32. package/lib/esm/utils.js.map +1 -0
  33. package/lib/index.cjs +3 -3
  34. package/lib/index.d.ts +2 -2
  35. package/lib/index.js.map +1 -0
  36. package/lib/overrides.cjs +1 -1
  37. package/lib/overrides.js.map +1 -0
  38. package/lib/registry.cjs +1 -1
  39. package/lib/registry.js.map +1 -0
  40. package/lib/types.cjs +1 -1
  41. package/lib/types.js.map +1 -0
  42. package/lib/utils.cjs +1 -1
  43. package/lib/utils.js.map +1 -0
  44. package/package.json +11 -16
  45. package/dist/injectable-decorators.esm.cjs +0 -522
@@ -1,541 +1,2 @@
1
- (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@decaf-ts/decoration')) :
3
- typeof define === 'function' && define.amd ? define(['exports', '@decaf-ts/decoration'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["injectable-decorators"] = {}, global.decoration));
5
- })(this, (function (exports, decoration) { 'use strict';
6
-
7
- /**
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
- * @property {string} REFLECT Reflection injectables base key prefix for all metadata keys
11
- * @property {string} INJECTABLE Reflection key suffix for marking a class as injectable
12
- * @property {string} INJECT Reflection key suffix for marking a property for injection
13
- * @const InjectablesKeys
14
- * @memberOf module:injectable-decorators
15
- */
16
- const InjectablesKeys = {
17
- REFLECT: "inject.db.",
18
- INJECTABLE: "injectable",
19
- INJECT: "inject",
20
- };
21
- /**
22
- * @description Default configuration applied by the @injectable decorator when none is provided.
23
- * @summary Sets sensible defaults such as singleton lifecycle for newly registered injectables.
24
- * @const DefaultInjectablesConfig
25
- * @memberOf module:injectable-decorators
26
- */
27
- const DefaultInjectablesConfig = {
28
- singleton: true,
29
- };
30
- /**
31
- * @description Reflection metadata key for accessing TypeScript type information.
32
- * @summary Holds the key for retrieving the design type from TypeScript's reflection metadata.
33
- * @const TypeKey
34
- * @memberOf module:injectable-decorators
35
- */
36
- const TypeKey = "design:type";
37
-
38
- /**
39
- * @description Generates a fully qualified reflection metadata key.
40
- * @summary Returns the reflection key for injectables by prefixing the provided key with the base reflection key.
41
- * @param {string} key The key to be prefixed
42
- * @return {string} The fully qualified reflection key
43
- * @function getInjectKey
44
- * @memberOf module:injectable-decorators
45
- */
46
- const getInjectKey = (key) => InjectablesKeys.REFLECT + key;
47
-
48
- /**
49
- * @description Default implementation of the InjectablesRegistry interface.
50
- * @summary Holds the various {@link Injectable}s in a cache and provides methods to register, retrieve, and build them.
51
- * @template T Type parameter used in the class methods
52
- *
53
- * @class InjectableRegistryImp
54
- * @implements InjectablesRegistry
55
- *
56
- * @memberOf module:injectable-decorators
57
- *
58
- * @example
59
- * // Create a new registry
60
- * const registry = new InjectableRegistryImp();
61
- *
62
- * // Register a class
63
- * class MyService {
64
- * doSomething() {
65
- * return 'Hello World';
66
- * }
67
- * }
68
- * registry.register(MyService, 'MyService', true);
69
- *
70
- * // Get the instance
71
- * const service = registry.get('MyService');
72
- * service.doSomething(); // 'Hello World'
73
- *
74
- * @mermaid
75
- * sequenceDiagram
76
- * participant Client
77
- * participant Registry
78
- *
79
- * Client->>Registry: register(MyService)
80
- * Registry->>Registry: Store in cache
81
- *
82
- * Client->>Registry: get("MyService")
83
- * alt Instance exists and is singleton
84
- * Registry-->>Client: Return cached instance
85
- * else No instance or not singleton
86
- * Registry->>Registry: build(name)
87
- * Registry-->>Client: Return new instance
88
- * end
89
- */
90
- class InjectableRegistryImp {
91
- constructor() {
92
- this.cache = {};
93
- }
94
- has(name) {
95
- if (typeof name === "symbol")
96
- return name in this.cache;
97
- return Symbol.for(name.toString()) in this.cache;
98
- }
99
- /**
100
- * @inheritDoc
101
- */
102
- get(name, ...args) {
103
- if (typeof name === "string")
104
- name = Symbol.for(name);
105
- if (typeof name !== "symbol") {
106
- const meta = Reflect.getMetadata(getInjectKey(InjectablesKeys.INJECTABLE), name);
107
- name = meta?.symbol || Symbol.for(name.toString());
108
- }
109
- if (!name)
110
- throw new Error(`Injectable ${name} not found`);
111
- if (!(name in this.cache)) {
112
- return undefined;
113
- }
114
- const cache = this.cache[name];
115
- if (!cache.options.singleton && !cache.instance)
116
- return this.build(name, ...args);
117
- return cache.instance || this.build(name, ...args);
118
- }
119
- /**
120
- * @inheritDoc
121
- */
122
- register(obj, category, options, force = false) {
123
- const castObj = obj;
124
- const constructor = !castObj.name && castObj.constructor;
125
- if (typeof castObj !== "function" && !constructor)
126
- throw new Error(`Injectable registering failed. Missing Class name or constructor`);
127
- const name = category || Symbol.for(obj.toString());
128
- if (!this.cache[name] || force)
129
- this.cache[name] = {
130
- instance: options.singleton && constructor ? obj : undefined,
131
- constructor: !constructor ? obj : obj.constructor,
132
- options: options,
133
- };
134
- }
135
- /**
136
- * @inheritDoc
137
- */
138
- build(name, ...args) {
139
- const { constructor, options } = this.cache[name];
140
- let instance;
141
- try {
142
- instance = new constructor(...args);
143
- }
144
- catch (e) {
145
- throw new Error(`failed to build ${name.toString()} with args ${args}: ${e}`);
146
- }
147
- if (options.singleton) {
148
- this.cache[name].instance = instance;
149
- }
150
- if (options.callback)
151
- instance = options.callback(instance, ...args);
152
- return instance;
153
- }
154
- }
155
-
156
- /**
157
- * @description Central registry for managing injectable dependencies.
158
- * @summary Static class holding the access to the injectables functions. Provides methods for registering,
159
- * retrieving, and building injectable objects.
160
- * @template T Type of the injectable object
161
- *
162
- * @class Injectables
163
- *
164
- * @example
165
- * // Define an injectable class
166
- * @injectable()
167
- * class MyService {
168
- * doSomething() {
169
- * return 'Hello World';
170
- * }
171
- * }
172
- *
173
- * // Inject the service into another class
174
- * class MyComponent {
175
- * @inject()
176
- * private service!: MyService;
177
- *
178
- * useService() {
179
- * return this.service.doSomething();
180
- * }
181
- * }
182
- *
183
- * @mermaid
184
- * sequenceDiagram
185
- * participant Client
186
- * participant Injectables
187
- * participant Registry
188
- *
189
- * Client->>Injectables: register(MyService)
190
- * Injectables->>Registry: register(MyService)
191
- * Registry-->>Injectables: void
192
- *
193
- * Client->>Injectables: get("MyService")
194
- * Injectables->>Registry: get("MyService")
195
- * Registry-->>Injectables: MyService instance
196
- * Injectables-->>Client: MyService instance
197
- */
198
- class Injectables {
199
- /**
200
- * @description Holds the active registry implementation used by the Injectables facade.
201
- * @summary Internal static reference that can be swapped via setRegistry to customize how injectables are stored and retrieved.
202
- * @type {InjectablesRegistry | undefined}
203
- */
204
- static { this.actingInjectablesRegistry = undefined; }
205
- constructor() { }
206
- /**
207
- * @description Fetches an injectable instance by its registered name.
208
- * @summary Retrieves the named {@link Injectable} from the registry. If the injectable is a singleton,
209
- * returns the existing instance. Otherwise, creates a new instance.
210
- * @template T Type of the injectable object to retrieve
211
- * @param {string} name The registered name of the injectable to retrieve
212
- * @param {any[]} args Constructor arguments to pass when instantiating the injectable
213
- * @return {Injectable<T> | undefined} The injectable instance or undefined if not found
214
- */
215
- static get(name, ...args) {
216
- return Injectables.getRegistry().get(name, ...args);
217
- }
218
- /**
219
- * @description Adds a class or object to the injectable registry.
220
- * @summary Registers an injectable constructor or instance with the registry, making it available for injection.
221
- * @template T Type of the injectable object to register
222
- * @param {Injectable<T>} constructor The class constructor or object instance to register
223
- * @param {any[]} args Additional arguments for registration (category, singleton flag, etc.)
224
- * @return {void}
225
- */
226
- static register(constructor, ...args) {
227
- return Injectables.getRegistry().register(constructor, ...args);
228
- }
229
- /**
230
- * @description Creates a new instance of an injectable class.
231
- * @summary Instantiates an injectable class using its constructor and the provided arguments.
232
- * @template T Type of the object to build
233
- * @param {symbol} name symbol referencing the injectable
234
- * @param {any[]} args Constructor arguments to pass when instantiating the injectable
235
- * @return {T} The newly created instance
236
- */
237
- static build(name, ...args) {
238
- return Injectables.getRegistry().build(name, ...args);
239
- }
240
- /**
241
- * @description Replaces the current registry implementation.
242
- * @summary Sets a new {@link InjectablesRegistry} implementation, allowing for custom registry behavior.
243
- * @param {InjectablesRegistry} operationsRegistry The new implementation of Registry to use
244
- * @return {void}
245
- */
246
- static setRegistry(operationsRegistry) {
247
- Injectables.actingInjectablesRegistry = operationsRegistry;
248
- }
249
- /**
250
- * @description Provides access to the current registry instance.
251
- * @summary Returns the current {@link InjectablesRegistry} or creates a default one if none exists.
252
- * @return {InjectablesRegistry} The current registry instance
253
- */
254
- static getRegistry() {
255
- if (!Injectables.actingInjectablesRegistry)
256
- Injectables.actingInjectablesRegistry = new InjectableRegistryImp();
257
- return Injectables.actingInjectablesRegistry;
258
- }
259
- /**
260
- * @description Clears all registered injectables.
261
- * @summary Resets the registry to a clean state by creating a new empty registry instance.
262
- * @return {void}
263
- */
264
- static reset() {
265
- Injectables.setRegistry(new InjectableRegistryImp());
266
- }
267
- /**
268
- * @description Removes specific injectables from the registry based on a pattern.
269
- * @summary Selectively resets the registry by removing only the injectables whose names match the provided pattern.
270
- * @param {string | RegExp} match A string or regular expression pattern to match against injectable names
271
- * @return {void}
272
- */
273
- static selectiveReset(match) {
274
- const regexp = typeof match === "string" ? new RegExp(match) : match;
275
- Injectables.actingInjectablesRegistry["cache"] = Object.entries(Injectables.actingInjectablesRegistry["cache"]).reduce((accum, [key, val]) => {
276
- if (!key.match(regexp))
277
- accum[key] = val;
278
- return accum;
279
- }, {});
280
- }
281
- }
282
-
283
- function injectableBaseDecorator(category, cfg) {
284
- cfg =
285
- cfg ||
286
- (typeof category === "object"
287
- ? Object.assign(category, DefaultInjectablesConfig)
288
- : DefaultInjectablesConfig);
289
- category =
290
- typeof category === "object"
291
- ? undefined
292
- : typeof category === "string"
293
- ? category
294
- : typeof category === "function" && category.name
295
- ? category
296
- : undefined;
297
- return function injectableInnerDecorator(original) {
298
- const symbol = Symbol.for(category || original.toString());
299
- category = category || original.name;
300
- const metadata = {
301
- class: category,
302
- symbol: symbol,
303
- };
304
- Reflect.defineMetadata(getInjectKey(InjectablesKeys.INJECTABLE), metadata, original);
305
- // the new constructor behaviour
306
- const newConstructor = function (...args) {
307
- return Injectables.get(symbol, ...args);
308
- };
309
- // copy prototype so instanceof operator still works
310
- newConstructor.prototype = original.prototype;
311
- // newConstructor.__proto__ = original.__proto__;
312
- // Sets the proper constructor name for type verification
313
- Object.defineProperty(newConstructor, "name", {
314
- writable: false,
315
- enumerable: true,
316
- configurable: false,
317
- value: original.prototype.constructor.name,
318
- });
319
- Reflect.defineMetadata(getInjectKey(InjectablesKeys.INJECTABLE), metadata, newConstructor);
320
- Injectables.register(original, symbol, cfg);
321
- // return new constructor (will override original)
322
- return newConstructor;
323
- };
324
- }
325
- /**
326
- * @description Decorator that marks a class as available for dependency injection.
327
- * @summary Defines a class as an injectable that can be retrieved from the registry.
328
- * When applied to a class, replaces its constructor with one that returns an instance.
329
- *
330
- * @param {string | Constructor} [category] Defaults to the class category. Useful when minification occurs and names are changed,
331
- * or when you want to upcast the object to a different type.
332
- * @param {Partial<InjectableConfig>} [cfg=DefaultInjectableConfig] Allows overriding the default singleton behavior and adding a callback function.
333
- *
334
- * @return {function(any): any} A decorator function that transforms the class into an injectable.
335
- *
336
- * @function injectable
337
- * @category Class Decorators
338
- *
339
- * @mermaid
340
- * sequenceDiagram
341
- * participant Client
342
- * participant Decorator
343
- * participant Injectables
344
- *
345
- * Client->>Decorator: @injectable()
346
- * Decorator->>Decorator: Create new constructor
347
- *
348
- * Note over Decorator: When new instance requested
349
- * Decorator->>Injectables: get(category)
350
- * alt Instance exists
351
- * Injectables-->>Decorator: Return existing instance
352
- * else No instance
353
- * Decorator->>Injectables: register(original, category)
354
- * Decorator->>Injectables: get(category)
355
- * Injectables-->>Decorator: Return new instance
356
- * opt Has callback
357
- * Decorator->>Decorator: Call instanceCallback
358
- * end
359
- * end
360
- * Decorator->>Decorator: Define metadata
361
- * Decorator-->>Client: Return instance
362
- */
363
- function injectable(category, cfg) {
364
- return decoration.Decoration.for(InjectablesKeys.INJECTABLE)
365
- .define({ decorator: injectableBaseDecorator, args: [category, cfg] })
366
- .apply();
367
- }
368
- /**
369
- * @description Convenience decorator to register an injectable as a singleton.
370
- * @summary Wraps {@link injectable} forcing the singleton lifecycle so only one instance is created and reused.
371
- * @param {string|Constructor} [category] Optional explicit category/symbol source; defaults to the class.
372
- * @param {Omit<InjectableConfig, "singleton">} [cfg] Additional injectable configuration excluding the singleton flag.
373
- * @return {function(any): any} A class decorator that registers the target as a singleton injectable.
374
- * @function singleton
375
- * @category Class Decorators
376
- */
377
- function singleton(category, cfg) {
378
- return injectable(category, Object.assign({}, cfg || {}, { singleton: true }));
379
- }
380
- /**
381
- * @description Convenience decorator to register an injectable as on-demand (non-singleton).
382
- * @summary Wraps {@link injectable} forcing new instances to be created on every injection or retrieval.
383
- * @param {string|Constructor} [category] Optional explicit category/symbol source; defaults to the class.
384
- * @param {Omit<InjectableConfig, "singleton">} [cfg] Additional injectable configuration excluding the singleton flag.
385
- * @return {function(any): any} A class decorator that registers the target as a non-singleton injectable.
386
- * @function onDemand
387
- * @category Class Decorators
388
- */
389
- function onDemand(category, cfg) {
390
- return injectable(category, Object.assign({}, cfg || {}, { singleton: false }));
391
- }
392
- function injectBaseDecorator(category, cfg) {
393
- return function injectInnerDecorator(target, propertyKey) {
394
- const config = (cfg || typeof category === "object" ? category : {});
395
- if (propertyKey) {
396
- decoration.prop()(target, propertyKey);
397
- }
398
- const name = (typeof category !== "object" &&
399
- category) ||
400
- decoration.Metadata.type(target.constructor, propertyKey);
401
- if (!name) {
402
- throw new Error(`Could not get Type from decorator`);
403
- }
404
- // prop()(target, propertyKey);
405
- Reflect.defineMetadata(getInjectKey(InjectablesKeys.INJECT), {
406
- injectable: name,
407
- }, target, propertyKey);
408
- const values = new WeakMap();
409
- Object.defineProperty(target, propertyKey, {
410
- configurable: true,
411
- get() {
412
- const descriptor = Object.getOwnPropertyDescriptor(target, propertyKey);
413
- if (descriptor.configurable) {
414
- // let /obj: any;
415
- Object.defineProperty(this, propertyKey, {
416
- enumerable: true,
417
- configurable: false,
418
- get() {
419
- let obj = values.get(this);
420
- if (obj)
421
- return obj;
422
- obj = Injectables.get(name, ...(config.args || []));
423
- if (!obj)
424
- throw new Error(`Could not get Injectable ${name.toString()} to inject in ${target.constructor ? target.constructor.name : target.name}'s ${propertyKey}`);
425
- if (config.transformer)
426
- try {
427
- obj = config.transformer(obj, target);
428
- }
429
- catch (e) {
430
- console.error(e);
431
- }
432
- values.set(this, obj);
433
- return obj;
434
- },
435
- });
436
- return this[propertyKey];
437
- }
438
- },
439
- });
440
- };
441
- }
442
- /**
443
- * @description Property decorator that injects a dependency into a class property.
444
- * @summary Allows for the injection of an {@link injectable} decorated dependency into a class property.
445
- * The property must be typed for the requested dependency. Only concrete classes are supported; generics are not.
446
- *
447
- * Injected properties should be described like so:
448
- * <pre>
449
- * class ClassName {
450
- * ...
451
- *
452
- * @inject()
453
- * propertyName!: InjectableClass;
454
- *
455
- * ...
456
- * }
457
- * </pre>
458
- *
459
- * where InjectableClass is the class you want to inject.
460
- * Notice the use of '!:' to ensure the transpiler the property will be set outside the constructor but will always be defined.
461
- * For projects where minification occurs, you should use the category param to ensure the name is the same throughout.
462
- *
463
- * @param {string} [category] Defaults to the class name derived from the property type. Useful when minification occurs
464
- * and names are changed, or when you want to upcast the object to a different type.
465
- * @param {Partial<InjectOptions>} [cfg={}] Optional function to transform the injectable instance before it's injected, or arguments to pass the constructor when injecting onDemand
466
- * @return {function(any, any): void} A property decorator function that sets up the dependency injection.
467
- *
468
- * @function inject
469
- * @category Property Decorators
470
- *
471
- * @mermaid
472
- * sequenceDiagram
473
- * participant Client
474
- * participant Decorator
475
- * participant Injectables
476
- *
477
- * Client->>Decorator: @inject()
478
- * Decorator->>Decorator: Get type from property
479
- * Decorator->>Decorator: Define metadata
480
- * Decorator->>Decorator: Define property getter
481
- *
482
- * Note over Decorator: When property accessed
483
- * Client->>Decorator: access property
484
- * Decorator->>Decorator: Check if instance exists
485
- * alt Instance exists in WeakMap
486
- * Decorator-->>Client: Return cached instance
487
- * else No instance
488
- * Decorator->>Injectables: get(name)
489
- * alt Injectable found
490
- * Injectables-->>Decorator: Return injectable instance
491
- * opt Has transformer
492
- * Decorator->>Decorator: Call transformer
493
- * end
494
- * Decorator->>Decorator: Store in WeakMap
495
- * Decorator-->>Client: Return instance
496
- * else No injectable
497
- * Decorator-->>Client: Throw error
498
- * end
499
- * end
500
- */
501
- function inject(category, cfg) {
502
- return decoration.Decoration.for(InjectablesKeys.INJECT)
503
- .define({ decorator: injectBaseDecorator, args: [category, cfg] })
504
- .apply();
505
- }
506
-
507
- /**
508
- * @description A lightweight dependency injection library for TypeScript applications.
509
- * @summary Adds a simple Injectables implementation to create singleton instances of an object
510
- * and easily inject it into other objects. Provides decorators for marking classes as injectable
511
- * and for injecting dependencies into class properties.
512
- *
513
- * @module injectable-decorators
514
- */
515
- /**
516
- * @description Current version of the injectable-decorators library.
517
- * @summary Defined on library build. Holds the library's current version string.
518
- * @const VERSION
519
- * @memberOf module:injectable-decorators
520
- */
521
- const VERSION = "1.6.16";
522
- const PACKAGE_NAME = "@decaf-ts/injectable-decorators";
523
- decoration.Metadata.registerLibrary(PACKAGE_NAME, VERSION);
524
-
525
- exports.DefaultInjectablesConfig = DefaultInjectablesConfig;
526
- exports.InjectableRegistryImp = InjectableRegistryImp;
527
- exports.Injectables = Injectables;
528
- exports.InjectablesKeys = InjectablesKeys;
529
- exports.PACKAGE_NAME = PACKAGE_NAME;
530
- exports.TypeKey = TypeKey;
531
- exports.VERSION = VERSION;
532
- exports.getInjectKey = getInjectKey;
533
- exports.inject = inject;
534
- exports.injectBaseDecorator = injectBaseDecorator;
535
- exports.injectable = injectable;
536
- exports.injectableBaseDecorator = injectableBaseDecorator;
537
- exports.onDemand = onDemand;
538
- exports.singleton = singleton;
539
-
540
- }));
541
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"injectable-decorators.cjs","sources":["../src/constants.ts","../src/utils.ts","../src/registry.ts","../src/Injectables.ts","../src/decorators.ts","../src/index.ts"],"sourcesContent":["import { InjectableConfig } from \"./decorators\";\n\n/**\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 * @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 * @const InjectablesKeys\n * @memberOf module:injectable-decorators\n */\nexport const InjectablesKeys = {\n  REFLECT: \"inject.db.\",\n  INJECTABLE: \"injectable\",\n  INJECT: \"inject\",\n};\n\n/**\n * @description Default configuration applied by the @injectable decorator when none is provided.\n * @summary Sets sensible defaults such as singleton lifecycle for newly registered injectables.\n * @const DefaultInjectablesConfig\n * @memberOf module:injectable-decorators\n */\nexport const DefaultInjectablesConfig: InjectableConfig = {\n  singleton: true,\n};\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","import { InjectablesKeys } from \"./constants\";\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 */\nexport const getInjectKey = (key: string) => InjectablesKeys.REFLECT + key;\n","import { InjectableDef, InjectableOptions } from \"./types\";\nimport { InjectablesKeys } from \"./constants\";\nimport { getInjectKey } from \"./utils\";\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 {symbol} 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>(\n    name: symbol | string | { new (...args: any[]): T },\n    ...args: any[]\n  ): 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 options\n   * @param {any[]} args Additional arguments for registration (category, singleton flag, etc.)\n   * @return {void}\n   * @memberOf module:injectable-decorators\n   */\n  register<T>(\n    constructor: Injectable<T>,\n    category: symbol | undefined,\n    options: InjectableOptions<T>,\n    ...args: any[]\n  ): 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 {symbol} name 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>(name: symbol, ...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: Record<symbol, InjectableDef> = {};\n\n  has<T>(name: symbol | { new (...args: any[]): T }): boolean {\n    if (typeof name === \"symbol\") return name in this.cache;\n    return Symbol.for(name.toString()) in this.cache;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  get<T>(\n    name: symbol | string | { new (...args: any[]): T },\n    ...args: any[]\n  ): T | undefined {\n    if (typeof name === \"string\") name = Symbol.for(name);\n    if (typeof name !== \"symbol\") {\n      const meta = Reflect.getMetadata(\n        getInjectKey(InjectablesKeys.INJECTABLE),\n        name\n      );\n      name = (meta?.symbol as symbol) || Symbol.for(name.toString());\n    }\n    if (!name) throw new Error(`Injectable ${name} not found`);\n\n    if (!((name as symbol) in this.cache)) {\n      return undefined;\n    }\n    const cache = this.cache[name];\n    if (!cache.options.singleton && !cache.instance)\n      return this.build<T>(name, ...args);\n    return cache.instance || this.build<T>(name, ...args);\n  }\n  /**\n   * @inheritDoc\n   */\n  register<T>(\n    obj: Injectable<T>,\n    category: symbol | undefined,\n    options: InjectableOptions<T>,\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 = category || Symbol.for((obj as any).toString());\n\n    if (!this.cache[name] || force)\n      this.cache[name] = {\n        instance: options.singleton && constructor ? obj : undefined,\n        constructor: !constructor ? obj : (obj as any).constructor,\n        options: options,\n      };\n  }\n  /**\n   * @inheritDoc\n   */\n  build<T>(name: symbol, ...args: any[]): T {\n    const { constructor, options } = this.cache[name];\n    let instance: T;\n    try {\n      instance = new constructor(...args);\n    } catch (e: unknown) {\n      throw new Error(\n        `failed to build ${name.toString()} with args ${args}: ${e}`\n      );\n    }\n    if (options.singleton) {\n      this.cache[name].instance = instance;\n    }\n    if (options.callback) instance = options.callback(instance, ...args);\n    return instance;\n  }\n}\n","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","import { DefaultInjectablesConfig, InjectablesKeys } from \"./constants\";\nimport { Injectables } from \"./Injectables\";\nimport { getInjectKey } from \"./utils\";\nimport { InjectableMetadata, InstanceCallback } from \"./types\";\nimport { Decoration, Metadata, prop } from \"@decaf-ts/decoration\";\n\n/**\n * @description Configuration options for the @injectable decorator.\n * @summary Controls lifecycle (singleton vs on-demand) and an optional instance transformation callback executed post-construction.\n * @template T The instance type affected by the callback when provided.\n * @property {boolean} singleton When true, a single instance is shared (singleton). When false, instances are created on demand.\n * @property {InstanceCallback<T>} [callback] Optional hook to transform the instance after it is constructed.\n * @typedef InjectableConfig\n * @memberOf module:injectable-decorators\n */\nexport type InjectableConfig = {\n  singleton: boolean;\n  callback?: InstanceCallback<any>;\n};\n\nexport function injectableBaseDecorator(\n  category?: string | Constructor | Partial<InjectableConfig>,\n  cfg?: Partial<InjectableConfig>\n) {\n  cfg =\n    cfg ||\n    (typeof category === \"object\"\n      ? Object.assign(category as Record<any, any>, DefaultInjectablesConfig)\n      : DefaultInjectablesConfig);\n  category =\n    typeof category === \"object\"\n      ? undefined\n      : typeof category === \"string\"\n        ? category\n        : typeof category === \"function\" && category.name\n          ? category\n          : undefined;\n  return function injectableInnerDecorator(original: any) {\n    const symbol = Symbol.for(category || original.toString());\n    category = category || original.name;\n\n    const metadata: InjectableMetadata = {\n      class: category as string,\n      symbol: symbol,\n    };\n\n    Reflect.defineMetadata(\n      getInjectKey(InjectablesKeys.INJECTABLE),\n      metadata,\n      original\n    );\n    // the new constructor behaviour\n    const newConstructor: any = function (...args: any[]) {\n      return Injectables.get<any>(symbol, ...args);\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\n    Reflect.defineMetadata(\n      getInjectKey(InjectablesKeys.INJECTABLE),\n      metadata,\n      newConstructor\n    );\n\n    Injectables.register(original, symbol, cfg);\n    // return new constructor (will override original)\n    return newConstructor;\n  };\n}\n\n/**\n * @description Generic constructor type for class-like values.\n * @summary Represents any class that can be instantiated with arbitrary arguments, producing an instance of type T.\n * @template T The instance type created by the constructor.\n * @typedef Constructor\n * @example\n * // Using Constructor to type a factory\n * function make<T>(Ctor: Constructor<T>, ...args: any[]): T {\n *   return new Ctor(...args);\n * }\n * @memberOf module:injectable-decorators\n */\nexport type Constructor<T = any> = { new (...args: any[]): T };\n\n/**\n * @description Decorator that marks a class as available for dependency injection.\n * @summary Defines a class as an injectable that can be retrieved from the registry.\n * When applied to a class, replaces its constructor with one that returns an instance.\n *\n * @return {function(any): any} A decorator function that transforms the class into an injectable.\n *\n * @function injectable\n */\nexport function injectable(): (original: any) => any;\n/**\n * @description Decorator that marks a class as available for dependency injection.\n * @summary Defines a class as an injectable that can be retrieved from the registry.\n * When applied to a class, replaces its constructor with one that returns an instance.\n *\n * @param {string | Constructor} category Defaults to the class category. Useful when minification occurs and names are changed,\n * or when you want to upcast the object to a different type.\n *\n * @return {function(any): any} A decorator function that transforms the class into an injectable.\n *\n * @function injectable\n */\nexport function injectable(\n  category: string | Constructor\n): (original: any) => any;\n/**\n * @description Decorator that marks a class as available for dependency injection.\n * @summary Defines a class as an injectable that can be retrieved from the registry.\n * When applied to a class, replaces its constructor with one that returns an instance.\n *\n * @param {Partial<InjectableConfig>} cfg=DefaultInjectableConfig Allows overriding the default singleton behavior and adding a callback function.\n *\n * @return {function(any): any} A decorator function that transforms the class into an injectable.\n *\n * @function injectable\n */\nexport function injectable(\n  cfg: Partial<InjectableConfig>\n): (original: any) => any;\n\n/**\n * @description Decorator that marks a class as available for dependency injection.\n * @summary Defines a class as an injectable that can be retrieved from the registry.\n * When applied to a class, replaces its constructor with one that returns an instance.\n *\n * @param category Defaults to the class category. Useful when minification occurs and names are changed,\n * or when you want to upcast the object to a different type.\n * @param {Partial<InjectableConfig>} cfg=DefaultInjectableConfig Allows overriding the default singleton behavior and adding a callback function.\n *\n * @return {function(any): any} A decorator function that transforms the class into an injectable.\n *\n * @function injectable\n */\nexport function injectable(\n  category: string | Constructor,\n  cfg: Partial<InjectableConfig>\n): (original: any) => any;\n/**\n * @description Decorator that marks a class as available for dependency injection.\n * @summary Defines a class as an injectable that can be retrieved from the registry.\n * When applied to a class, replaces its constructor with one that returns an instance.\n *\n * @param {string | Constructor} [category] Defaults to the class category. Useful when minification occurs and names are changed,\n * or when you want to upcast the object to a different type.\n * @param {Partial<InjectableConfig>} [cfg=DefaultInjectableConfig] Allows overriding the default singleton behavior and adding a callback function.\n *\n * @return {function(any): any} 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(category)\n *   alt Instance exists\n *     Injectables-->>Decorator: Return existing instance\n *   else No instance\n *     Decorator->>Injectables: register(original, category)\n *     Decorator->>Injectables: get(category)\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 | Constructor | Partial<InjectableConfig>,\n  cfg?: Partial<InjectableConfig>\n) {\n  return Decoration.for(InjectablesKeys.INJECTABLE)\n    .define({ decorator: injectableBaseDecorator, args: [category, cfg] })\n    .apply();\n}\n\n/**\n * @description Convenience decorator to register an injectable as a singleton.\n * @summary Wraps {@link injectable} forcing the singleton lifecycle so only one instance is created and reused.\n * @param {string|Constructor} [category] Optional explicit category/symbol source; defaults to the class.\n * @param {Omit<InjectableConfig, \"singleton\">} [cfg] Additional injectable configuration excluding the singleton flag.\n * @return {function(any): any} A class decorator that registers the target as a singleton injectable.\n * @function singleton\n * @category Class Decorators\n */\nexport function singleton(\n  category?: string | Constructor,\n  cfg?: Omit<InjectableConfig, \"singleton\">\n) {\n  return injectable(\n    category as any,\n    Object.assign({}, cfg || {}, { singleton: true })\n  );\n}\n\n/**\n * @description Convenience decorator to register an injectable as on-demand (non-singleton).\n * @summary Wraps {@link injectable} forcing new instances to be created on every injection or retrieval.\n * @param {string|Constructor} [category] Optional explicit category/symbol source; defaults to the class.\n * @param {Omit<InjectableConfig, \"singleton\">} [cfg] Additional injectable configuration excluding the singleton flag.\n * @return {function(any): any} A class decorator that registers the target as a non-singleton injectable.\n * @function onDemand\n * @category Class Decorators\n */\nexport function onDemand(\n  category?: string | Constructor,\n  cfg?: Omit<InjectableConfig, \"singleton\">\n) {\n  return injectable(\n    category as any,\n    Object.assign({}, cfg || {}, { singleton: false })\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 * @category Decorators\n * @memberOf module:injectable-decorators\n */\nexport type InstanceTransformer = (injectable: any, obj: any) => any;\n\n/**\n * @description Options for the property-level @inject decorator.\n * @summary Allows specifying constructor arguments and an optional transformer to be applied to the resolved instance.\n * @property {any[]} [args] Optional constructor arguments to use when building the injectable instance.\n * @property {InstanceTransformer} [transformer] Optional function to transform the instance before assignment.\n * @typedef InjectOptions\n * @memberOf module:injectable-decorators\n */\nexport type InjectOptions = {\n  args?: any[];\n  transformer?: InstanceTransformer;\n};\n\nexport function injectBaseDecorator(\n  category?: symbol | string | Constructor | Partial<InjectOptions>,\n  cfg?: Partial<InjectOptions>\n) {\n  return function injectInnerDecorator(target: any, propertyKey?: any) {\n    const config: InjectOptions = (\n      cfg || typeof category === \"object\" ? category : {}\n    ) as InjectOptions;\n\n    if (propertyKey) {\n      prop()(target, propertyKey);\n    }\n\n    const name: symbol | string | Constructor | undefined =\n      (typeof category !== \"object\" &&\n        (category as symbol | string | Constructor)) ||\n      Metadata.type(target.constructor, propertyKey);\n    if (!name) {\n      throw new Error(`Could not get Type from decorator`);\n    }\n\n    // prop()(target, propertyKey);\n    Reflect.defineMetadata(\n      getInjectKey(InjectablesKeys.INJECT),\n      {\n        injectable: name,\n      },\n      target,\n      propertyKey\n    );\n\n    const values = new WeakMap();\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          // let /obj: any;\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get(this: any) {\n              let obj = values.get(this);\n              if (obj) return obj;\n              obj = Injectables.get(name, ...(config.args || []));\n              if (!obj)\n                throw new Error(\n                  `Could not get Injectable ${name.toString()} to inject in ${target.constructor ? target.constructor.name : target.name}'s ${propertyKey}`\n                );\n              if (config.transformer)\n                try {\n                  obj = config.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/**\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 * @return {function(any, any): void} A property decorator function that sets up the dependency injection.\n *\n * @function inject\n */\nexport function inject(): (target: any, propertyKey: any) => void;\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 * @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 * @return {function(any, any): void} A property decorator function that sets up the dependency injection.\n *\n * @function inject\n */\nexport function inject(\n  category: string | Constructor\n): (target: any, propertyKey: any) => void;\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 * @param {Partial<InjectOptions>} [cfg={}] Optional function to transform the injectable instance before it's injected, or arguments to pass the constructor when injecting onDemand\n * @return {function(any, any): void} A property decorator function that sets up the dependency injection.\n *\n * @function inject\n */\nexport function inject(\n  cfg: Partial<InjectOptions>\n): (target: any, propertyKey: any) => void;\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 * @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 {Partial<InjectOptions>} cfg={} Optional function to transform the injectable instance before it's injected, or arguments to pass the constructor when injecting onDemand\n * @return {function(any, any): void} A property decorator function that sets up the dependency injection.\n *\n * @function inject\n */\nexport function inject(\n  category: string | Constructor,\n  cfg: Partial<InjectOptions>\n): (target: any, propertyKey: any) => void;\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 {Partial<InjectOptions>} [cfg={}] Optional function to transform the injectable instance before it's injected, or arguments to pass the constructor when injecting onDemand\n * @return {function(any, any): void} 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(\n  category?: symbol | string | Constructor | Partial<InjectOptions>,\n  cfg?: Partial<InjectOptions>\n) {\n  return Decoration.for(InjectablesKeys.INJECT)\n    .define({ decorator: injectBaseDecorator, args: [category, cfg] })\n    .apply();\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\nimport { Metadata } from \"@decaf-ts/decoration\";\n\nexport * from \"./constants\";\nexport * from \"./decorators\";\nexport * from \"./Injectables\";\nexport * from \"./registry\";\nexport * from \"./types\";\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##\";\nexport const PACKAGE_NAME = \"##PACKAGE##\";\nMetadata.registerLibrary(PACKAGE_NAME, VERSION);\n"],"names":["Decoration","prop","Metadata"],"mappings":";;;;;;IAEA;;;;;;;;IAQG;AACU,UAAA,eAAe,GAAG;IAC7B,IAAA,OAAO,EAAE,YAAY;IACrB,IAAA,UAAU,EAAE,YAAY;IACxB,IAAA,MAAM,EAAE,QAAQ;;IAGlB;;;;;IAKG;AACU,UAAA,wBAAwB,GAAqB;IACxD,IAAA,SAAS,EAAE,IAAI;;IAGjB;;;;;IAKG;AACI,UAAM,OAAO,GAAG;;IC/BvB;;;;;;;IAOG;AACI,UAAM,YAAY,GAAG,CAAC,GAAW,KAAK,eAAe,CAAC,OAAO,GAAG;;ICsDvE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAyCG;UACU,qBAAqB,CAAA;IAAlC,IAAA,WAAA,GAAA;YACU,IAAK,CAAA,KAAA,GAAkC,EAAE;;IAEjD,IAAA,GAAG,CAAI,IAA0C,EAAA;YAC/C,IAAI,OAAO,IAAI,KAAK,QAAQ;IAAE,YAAA,OAAO,IAAI,IAAI,IAAI,CAAC,KAAK;IACvD,QAAA,OAAO,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,IAAI,CAAC,KAAK;;IAGlD;;IAEG;IACH,IAAA,GAAG,CACD,IAAmD,EACnD,GAAG,IAAW,EAAA;YAEd,IAAI,OAAO,IAAI,KAAK,QAAQ;IAAE,YAAA,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;IACrD,QAAA,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;IAC5B,YAAA,MAAM,IAAI,GAAG,OAAO,CAAC,WAAW,CAC9B,YAAY,CAAC,eAAe,CAAC,UAAU,CAAC,EACxC,IAAI,CACL;IACD,YAAA,IAAI,GAAI,IAAI,EAAE,MAAiB,IAAI,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;;IAEhE,QAAA,IAAI,CAAC,IAAI;IAAE,YAAA,MAAM,IAAI,KAAK,CAAC,cAAc,IAAI,CAAA,UAAA,CAAY,CAAC;YAE1D,IAAI,EAAG,IAAe,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE;IACrC,YAAA,OAAO,SAAS;;YAElB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,IAAI,CAAC,KAAK,CAAC,QAAQ;gBAC7C,OAAO,IAAI,CAAC,KAAK,CAAI,IAAI,EAAE,GAAG,IAAI,CAAC;IACrC,QAAA,OAAO,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAI,IAAI,EAAE,GAAG,IAAI,CAAC;;IAEvD;;IAEG;QACH,QAAQ,CACN,GAAkB,EAClB,QAA4B,EAC5B,OAA6B,EAC7B,QAAiB,KAAK,EAAA;YAEtB,MAAM,OAAO,GAAwB,GAA0B;YAE/D,MAAM,WAAW,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,WAAW;IACxD,QAAA,IAAI,OAAO,OAAO,KAAK,UAAU,IAAI,CAAC,WAAW;IAC/C,YAAA,MAAM,IAAI,KAAK,CACb,CAAA,gEAAA,CAAkE,CACnE;IAEH,QAAA,MAAM,IAAI,GAAG,QAAQ,IAAI,MAAM,CAAC,GAAG,CAAE,GAAW,CAAC,QAAQ,EAAE,CAAC;YAE5D,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK;IAC5B,YAAA,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG;IACjB,gBAAA,QAAQ,EAAE,OAAO,CAAC,SAAS,IAAI,WAAW,GAAG,GAAG,GAAG,SAAS;IAC5D,gBAAA,WAAW,EAAE,CAAC,WAAW,GAAG,GAAG,GAAI,GAAW,CAAC,WAAW;IAC1D,gBAAA,OAAO,EAAE,OAAO;iBACjB;;IAEL;;IAEG;IACH,IAAA,KAAK,CAAI,IAAY,EAAE,GAAG,IAAW,EAAA;IACnC,QAAA,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;IACjD,QAAA,IAAI,QAAW;IACf,QAAA,IAAI;IACF,YAAA,QAAQ,GAAG,IAAI,WAAW,CAAC,GAAG,IAAI,CAAC;;YACnC,OAAO,CAAU,EAAE;IACnB,YAAA,MAAM,IAAI,KAAK,CACb,CAAA,gBAAA,EAAmB,IAAI,CAAC,QAAQ,EAAE,CAAA,WAAA,EAAc,IAAI,CAAA,EAAA,EAAK,CAAC,CAAA,CAAE,CAC7D;;IAEH,QAAA,IAAI,OAAO,CAAC,SAAS,EAAE;gBACrB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,QAAQ,GAAG,QAAQ;;YAEtC,IAAI,OAAO,CAAC,QAAQ;gBAAE,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC;IACpE,QAAA,OAAO,QAAQ;;IAElB;;ICjLD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAyCG;UACU,WAAW,CAAA;IACtB;;;;IAIG;iBACY,IAAyB,CAAA,yBAAA,GAAyB,SAAS,CAAC;IAE3E,IAAA,WAAA,GAAA;IAEA;;;;;;;;IAQG;IACH,IAAA,OAAO,GAAG,CACR,IAAmD,EACnD,GAAG,IAAW,EAAA;IAEd,QAAA,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC;;IAGrD;;;;;;;IAOG;IACH,IAAA,OAAO,QAAQ,CAAI,WAA0B,EAAE,GAAG,IAAW,EAAA;IAC3D,QAAA,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CACvC,WAAW,EACX,GAAI,IAAuC,CAC5C;;IAGH;;;;;;;IAOG;IACH,IAAA,OAAO,KAAK,CAAI,IAAY,EAAE,GAAG,IAAW,EAAA;IAC1C,QAAA,OAAO,WAAW,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC;;IAGvD;;;;;IAKG;QACH,OAAO,WAAW,CAAC,kBAAuC,EAAA;IACxD,QAAA,WAAW,CAAC,yBAAyB,GAAG,kBAAkB;;IAE5D;;;;IAIG;IACK,IAAA,OAAO,WAAW,GAAA;YACxB,IAAI,CAAC,WAAW,CAAC,yBAAyB;IACxC,YAAA,WAAW,CAAC,yBAAyB,GAAG,IAAI,qBAAqB,EAAE;YACrE,OAAO,WAAW,CAAC,yBAAyB;;IAG9C;;;;IAIG;IACH,IAAA,OAAO,KAAK,GAAA;IACV,QAAA,WAAW,CAAC,WAAW,CAAC,IAAI,qBAAqB,EAAE,CAAC;;IAGtD;;;;;IAKG;QACH,OAAO,cAAc,CAAC,KAAsB,EAAA;IAC1C,QAAA,MAAM,MAAM,GAAG,OAAO,KAAK,KAAK,QAAQ,GAAG,IAAI,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK;IACnE,QAAA,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,KAAI;IAClD,YAAA,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC;IAAE,gBAAA,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG;IACxC,YAAA,OAAO,KAAK;aACb,EAAE,EAAE,CAAC;;;;IC5HM,SAAA,uBAAuB,CACrC,QAA2D,EAC3D,GAA+B,EAAA;QAE/B,GAAG;YACD,GAAG;iBACF,OAAO,QAAQ,KAAK;sBACjB,MAAM,CAAC,MAAM,CAAC,QAA4B,EAAE,wBAAwB;sBACpE,wBAAwB,CAAC;QAC/B,QAAQ;YACN,OAAO,QAAQ,KAAK;IAClB,cAAE;IACF,cAAE,OAAO,QAAQ,KAAK;IACpB,kBAAE;sBACA,OAAO,QAAQ,KAAK,UAAU,IAAI,QAAQ,CAAC;IAC3C,sBAAE;0BACA,SAAS;QACnB,OAAO,SAAS,wBAAwB,CAAC,QAAa,EAAA;IACpD,QAAA,MAAM,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC1D,QAAA,QAAQ,GAAG,QAAQ,IAAI,QAAQ,CAAC,IAAI;IAEpC,QAAA,MAAM,QAAQ,GAAuB;IACnC,YAAA,KAAK,EAAE,QAAkB;IACzB,YAAA,MAAM,EAAE,MAAM;aACf;IAED,QAAA,OAAO,CAAC,cAAc,CACpB,YAAY,CAAC,eAAe,CAAC,UAAU,CAAC,EACxC,QAAQ,EACR,QAAQ,CACT;;IAED,QAAA,MAAM,cAAc,GAAQ,UAAU,GAAG,IAAW,EAAA;gBAClD,OAAO,WAAW,CAAC,GAAG,CAAM,MAAM,EAAE,GAAG,IAAI,CAAC;IAC9C,SAAC;;IAGD,QAAA,cAAc,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS;;;IAG7C,QAAA,MAAM,CAAC,cAAc,CAAC,cAAc,EAAE,MAAM,EAAE;IAC5C,YAAA,QAAQ,EAAE,KAAK;IACf,YAAA,UAAU,EAAE,IAAI;IAChB,YAAA,YAAY,EAAE,KAAK;IACnB,YAAA,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI;IAC3C,SAAA,CAAC;IAEF,QAAA,OAAO,CAAC,cAAc,CACpB,YAAY,CAAC,eAAe,CAAC,UAAU,CAAC,EACxC,QAAQ,EACR,cAAc,CACf;YAED,WAAW,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,CAAC;;IAE3C,QAAA,OAAO,cAAc;IACvB,KAAC;IACH;IAyEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAqCG;IACa,SAAA,UAAU,CACxB,QAA2D,EAC3D,GAA+B,EAAA;IAE/B,IAAA,OAAOA,qBAAU,CAAC,GAAG,CAAC,eAAe,CAAC,UAAU;IAC7C,SAAA,MAAM,CAAC,EAAE,SAAS,EAAE,uBAAuB,EAAE,IAAI,EAAE,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE;IACpE,SAAA,KAAK,EAAE;IACZ;IAEA;;;;;;;;IAQG;IACa,SAAA,SAAS,CACvB,QAA+B,EAC/B,GAAyC,EAAA;QAEzC,OAAO,UAAU,CACf,QAAe,EACf,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAClD;IACH;IAEA;;;;;;;;IAQG;IACa,SAAA,QAAQ,CACtB,QAA+B,EAC/B,GAAyC,EAAA;QAEzC,OAAO,UAAU,CACf,QAAe,EACf,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CACnD;IACH;IA4BgB,SAAA,mBAAmB,CACjC,QAAiE,EACjE,GAA4B,EAAA;IAE5B,IAAA,OAAO,SAAS,oBAAoB,CAAC,MAAW,EAAE,WAAiB,EAAA;IACjE,QAAA,MAAM,MAAM,IACV,GAAG,IAAI,OAAO,QAAQ,KAAK,QAAQ,GAAG,QAAQ,GAAG,EAAE,CACnC;YAElB,IAAI,WAAW,EAAE;IACf,YAAAC,eAAI,EAAE,CAAC,MAAM,EAAE,WAAW,CAAC;;IAG7B,QAAA,MAAM,IAAI,GACR,CAAC,OAAO,QAAQ,KAAK,QAAQ;IAC1B,YAAA,QAA0C;gBAC7CC,mBAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,WAAW,CAAC;YAChD,IAAI,CAAC,IAAI,EAAE;IACT,YAAA,MAAM,IAAI,KAAK,CAAC,CAAA,iCAAA,CAAmC,CAAC;;;YAItD,OAAO,CAAC,cAAc,CACpB,YAAY,CAAC,eAAe,CAAC,MAAM,CAAC,EACpC;IACE,YAAA,UAAU,EAAE,IAAI;IACjB,SAAA,EACD,MAAM,EACN,WAAW,CACZ;IAED,QAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE;IAE5B,QAAA,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE;IACzC,YAAA,YAAY,EAAE,IAAI;gBAClB,GAAG,GAAA;oBACD,MAAM,UAAU,GAAuB,MAAM,CAAC,wBAAwB,CACpE,MAAM,EACN,WAAW,CACU;IACvB,gBAAA,IAAI,UAAU,CAAC,YAAY,EAAE;;IAE3B,oBAAA,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,WAAW,EAAE;IACvC,wBAAA,UAAU,EAAE,IAAI;IAChB,wBAAA,YAAY,EAAE,KAAK;4BACnB,GAAG,GAAA;gCACD,IAAI,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;IAC1B,4BAAA,IAAI,GAAG;IAAE,gCAAA,OAAO,GAAG;IACnB,4BAAA,GAAG,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;IACnD,4BAAA,IAAI,CAAC,GAAG;IACN,gCAAA,MAAM,IAAI,KAAK,CACb,CAAA,yBAAA,EAA4B,IAAI,CAAC,QAAQ,EAAE,CAAiB,cAAA,EAAA,MAAM,CAAC,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA,GAAA,EAAM,WAAW,CAAA,CAAE,CAC1I;gCACH,IAAI,MAAM,CAAC,WAAW;IACpB,gCAAA,IAAI;wCACF,GAAG,GAAG,MAAM,CAAC,WAAW,CAAC,GAAG,EAAE,MAAM,CAAC;;oCACrC,OAAO,CAAC,EAAE;IACV,oCAAA,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;;IAEpB,4BAAA,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC;IAErB,4BAAA,OAAO,GAAG;6BACX;IACF,qBAAA,CAAC;IACF,oBAAA,OAAO,IAAI,CAAC,WAAW,CAAC;;iBAE3B;IACF,SAAA,CAAC;IACJ,KAAC;IACH;IAuDA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IA0DG;IACa,SAAA,MAAM,CACpB,QAAiE,EACjE,GAA4B,EAAA;IAE5B,IAAA,OAAOF,qBAAU,CAAC,GAAG,CAAC,eAAe,CAAC,MAAM;IACzC,SAAA,MAAM,CAAC,EAAE,SAAS,EAAE,mBAAmB,EAAE,IAAI,EAAE,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE;IAChE,SAAA,KAAK,EAAE;IACZ;;ICncA;;;;;;;IAOG;IAWH;;;;;IAKG;AACI,UAAM,OAAO,GAAG;AAChB,UAAM,YAAY,GAAG;AAC5BE,uBAAQ,CAAC,eAAe,CAAC,YAAY,EAAE,OAAO,CAAC;;;;;;;;;;;;;;;;;;;;;"}
1
+ var t,e;t=this,e=function(t,e){"use strict";const n={REFLECT:"inject.db.",INJECTABLE:"injectable",INJECT:"inject"},r={singleton:!0},o=t=>n.REFLECT+t;class c{constructor(){this.cache={}}has(t){return"symbol"==typeof t?t in this.cache:Symbol.for(t.toString())in this.cache}get(t,...e){if("string"==typeof t&&(t=Symbol.for(t)),"symbol"!=typeof t){const e=Reflect.getMetadata(o(n.INJECTABLE),t);t=e?.symbol||Symbol.for(t.toString())}if(!t)throw Error(`Injectable ${t} not found`);if(!(t in this.cache))return;const r=this.cache[t];return(r.options.singleton||r.instance)&&r.instance||this.build(t,...e)}register(t,e,n,r=!1){const o=t,c=!o.name&&o.constructor;if("function"!=typeof o&&!c)throw Error("Injectable registering failed. Missing Class name or constructor");const i=e||Symbol.for(t.toString());this.cache[i]&&!r||(this.cache[i]={instance:n.singleton&&c?t:void 0,constructor:c?t.constructor:t,options:n})}build(t,...e){const{constructor:n,options:r}=this.cache[t];let o;try{o=new n(...e)}catch(n){throw Error(`failed to build ${t.toString()} with args ${e}: ${n}`)}return r.singleton&&(this.cache[t].instance=o),r.callback&&(o=r.callback(o,...e)),o}}class i{static{this.actingInjectablesRegistry=void 0}constructor(){}static get(t,...e){return i.getRegistry().get(t,...e)}static register(t,...e){return i.getRegistry().register(t,...e)}static build(t,...e){return i.getRegistry().build(t,...e)}static setRegistry(t){i.actingInjectablesRegistry=t}static getRegistry(){return i.actingInjectablesRegistry||(i.actingInjectablesRegistry=new c),i.actingInjectablesRegistry}static reset(){i.setRegistry(new c)}static selectiveReset(t){const e="string"==typeof t?RegExp(t):t;i.actingInjectablesRegistry.cache=Object.entries(i.actingInjectablesRegistry.cache).reduce((t,[n,r])=>(n.match(e)||(t[n]=r),t),{})}}function s(t,e){return e=e||("object"==typeof t?Object.assign(t,r):r),t="object"==typeof t?void 0:"string"==typeof t||"function"==typeof t&&t.name?t:void 0,r=>{const c=Symbol.for(t||r.toString()),s={class:t=t||r.name,symbol:c};Reflect.defineMetadata(o(n.INJECTABLE),s,r);const a=(...t)=>i.get(c,...t);return a.prototype=r.prototype,Object.defineProperty(a,"name",{writable:!1,enumerable:!0,configurable:!1,value:r.prototype.constructor.name}),Reflect.defineMetadata(o(n.INJECTABLE),s,a),i.register(r,c,e),a}}function a(t,r){return e.Decoration.for(n.INJECTABLE).define({decorator:s,args:[t,r]}).apply()}function g(t,r){return function(c,s){const a=r||"object"==typeof t?t:{};s&&e.prop()(c,s);const g="object"!=typeof t&&t||e.Metadata.type(c.constructor,s);if(!g)throw Error("Could not get Type from decorator");Reflect.defineMetadata(o(n.INJECT),{injectable:g},c,s);const l=new WeakMap;Object.defineProperty(c,s,{configurable:!0,get(){if(Object.getOwnPropertyDescriptor(c,s).configurable)return Object.defineProperty(this,s,{enumerable:!0,configurable:!1,get(){let t=l.get(this);if(t)return t;if(t=i.get(g,...a.args||[]),!t)throw Error(`Could not get Injectable ${g.toString()} to inject in ${c.constructor?c.constructor.name:c.name}'s ${s}`);if(a.transformer)try{t=a.transformer(t,c)}catch(t){}return l.set(this,t),t}}),this[s]}})}}const l="##VERSION##",f="##PACKAGE##";e.Metadata.registerLibrary(f,l),t.DefaultInjectablesConfig=r,t.InjectableRegistryImp=c,t.Injectables=i,t.InjectablesKeys=n,t.PACKAGE_NAME=f,t.TypeKey="design:type",t.VERSION=l,t.getInjectKey=o,t.inject=(t,r)=>e.Decoration.for(n.INJECT).define({decorator:g,args:[t,r]}).apply(),t.injectBaseDecorator=g,t.injectable=a,t.injectableBaseDecorator=s,t.onDemand=(t,e)=>a(t,Object.assign({},e||{},{singleton:!1})),t.singleton=(t,e)=>a(t,Object.assign({},e||{},{singleton:!0}))},"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@decaf-ts/decoration")):"function"==typeof define&&define.amd?define(["exports","@decaf-ts/decoration"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["injectable-decorators"]={},t.decafTsDecoration);
2
+ //# sourceMappingURL=injectable-decorators.cjs.map