@decaf-ts/decoration 0.0.23 → 0.1.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 +3 -1
  2. package/dist/decoration.cjs +2 -999
  3. package/dist/decoration.cjs.map +1 -0
  4. package/dist/decoration.js +2 -0
  5. package/dist/decoration.js.map +1 -0
  6. package/lib/constants.cjs +1 -0
  7. package/lib/constants.js.map +1 -0
  8. package/lib/decoration/Decoration.cjs +1 -0
  9. package/lib/decoration/Decoration.js.map +1 -0
  10. package/lib/decoration/index.cjs +1 -0
  11. package/lib/decoration/index.js.map +1 -0
  12. package/lib/decoration/types.cjs +1 -0
  13. package/lib/decoration/types.js.map +1 -0
  14. package/lib/decorators.cjs +1 -0
  15. package/lib/decorators.js.map +1 -0
  16. package/lib/esm/constants.js +1 -0
  17. package/lib/esm/constants.js.map +1 -0
  18. package/lib/esm/decoration/Decoration.js +1 -0
  19. package/lib/esm/decoration/Decoration.js.map +1 -0
  20. package/lib/esm/decoration/index.js +1 -0
  21. package/lib/esm/decoration/index.js.map +1 -0
  22. package/lib/esm/decoration/types.js +1 -0
  23. package/lib/esm/decoration/types.js.map +1 -0
  24. package/lib/esm/decorators.js +1 -0
  25. package/lib/esm/decorators.js.map +1 -0
  26. package/lib/esm/index.d.ts +1 -1
  27. package/lib/esm/index.js +2 -1
  28. package/lib/esm/index.js.map +1 -0
  29. package/lib/esm/metadata/Metadata.js +1 -0
  30. package/lib/esm/metadata/Metadata.js.map +1 -0
  31. package/lib/esm/metadata/index.js +1 -0
  32. package/lib/esm/metadata/index.js.map +1 -0
  33. package/lib/esm/metadata/types.js +1 -0
  34. package/lib/esm/metadata/types.js.map +1 -0
  35. package/lib/index.cjs +2 -1
  36. package/lib/index.d.ts +1 -1
  37. package/lib/index.js.map +1 -0
  38. package/lib/metadata/Metadata.cjs +1 -0
  39. package/lib/metadata/Metadata.js.map +1 -0
  40. package/lib/metadata/index.cjs +1 -0
  41. package/lib/metadata/index.js.map +1 -0
  42. package/lib/metadata/types.cjs +1 -0
  43. package/lib/metadata/types.js.map +1 -0
  44. package/package.json +2 -2
  45. package/dist/decoration.esm.cjs +0 -977
@@ -1,977 +0,0 @@
1
- import 'reflect-metadata';
2
-
3
- /**
4
- * @description Default flavour identifier for the decorator system.
5
- * @summary Defines the fallback flavour used when no specific value is provided, ensuring consistent decorator selection across the library.
6
- * @type {string}
7
- * @const DefaultFlavour
8
- * @memberOf module:decoration
9
- */
10
- const DefaultFlavour = "decaf";
11
- /**
12
- * @description Character used to split nested metadata keys.
13
- * @summary Defines the delimiter applied by the metadata store when traversing nested object paths for read and write operations.
14
- * @type {string}
15
- * @const ObjectKeySplitter
16
- * @memberOf module:decoration
17
- */
18
- const ObjectKeySplitter = ".";
19
- /**
20
- * @description Metadata token registry for the decoration system.
21
- * @summary Enumerates the keys used during reflection and metadata storage for classes, properties, methods, descriptions, and registered libraries.
22
- * @enum {string}
23
- * @readonly
24
- * @const DecorationKeys
25
- * @memberOf module:decoration
26
- */
27
- var DecorationKeys;
28
- (function (DecorationKeys) {
29
- /** @description Storage bucket for decoration-aware library registrations. */
30
- DecorationKeys["LIBRARIES"] = "libraries";
31
- /** @description Storage key mirrored on constructors that holds runtime metadata. */
32
- DecorationKeys["REFLECT"] = "__decaf";
33
- /** @description Container of reflected property metadata for a model. */
34
- DecorationKeys["PROPERTIES"] = "properties";
35
- /** @description Container of reflected method metadata for a model. */
36
- DecorationKeys["METHODS"] = "methods";
37
- /** @description Key under which the model constructor reference is persisted. */
38
- DecorationKeys["CLASS"] = "class";
39
- /** @description Human-readable descriptions for classes and members. */
40
- DecorationKeys["DESCRIPTION"] = "description";
41
- /** @description Storage slot tracking the original constructor when overridden. */
42
- DecorationKeys["CONSTRUCTOR"] = "__original";
43
- /** @description Collected parameter metadata for configured decorators. */
44
- DecorationKeys["PARAMETERS"] = "parameters";
45
- /** @description Reflect metadata key for a property's design type. */
46
- DecorationKeys["DESIGN_TYPE"] = "design:type";
47
- /** @description Reflect metadata key for recorded constructor parameter types. */
48
- DecorationKeys["DESIGN_PARAMS"] = "design:paramtypes";
49
- /** @description Reflect metadata key for a method's return type. */
50
- DecorationKeys["DESIGN_RETURN"] = "design:returntype";
51
- })(DecorationKeys || (DecorationKeys = {}));
52
- /**
53
- * @description Default metadata instance.
54
- * @summary Provides the default metadata shape used when initialising new metadata entries for a model.
55
- * @type {module:decoration.BasicMetadata<any>}
56
- * @const DefaultMetadata
57
- * @memberOf module:decoration
58
- */
59
- const DefaultMetadata = {
60
- [DecorationKeys.PROPERTIES]: [],
61
- };
62
-
63
- /**
64
- * @description Retrieves a nested value from an object given a path.
65
- * @summary Walks an object structure using a splitter-delimited path and returns the value at that location or `undefined` if any key is missing.
66
- * @param {Record<string, any>} obj Object to traverse for the lookup.
67
- * @param {string} path Splitter-delimited path to the desired value (e.g., "a.b.c").
68
- * @param {string} [splitter=ObjectKeySplitter] Delimiter used to separate the path segments.
69
- * @return {any|undefined} Value resolved at the given path or `undefined` when not found.
70
- * @function getValueBySplitter
71
- * @mermaid
72
- * sequenceDiagram
73
- * participant C as Caller
74
- * participant F as getValueBySplitter
75
- * participant O as Object
76
- * C->>F: (obj, path, splitter)
77
- * F->>F: split path into keys
78
- * loop for each key
79
- * F->>O: access current[key]
80
- * alt missing or nullish
81
- * F-->>C: return undefined
82
- * end
83
- * end
84
- * F-->>C: return final value
85
- * @memberOf module:decoration
86
- */
87
- function getValueBySplitter(obj, path, splitter = ObjectKeySplitter) {
88
- const keys = path.split(splitter);
89
- let current = obj;
90
- for (const key of keys) {
91
- if (current === null ||
92
- current === undefined ||
93
- !Object.prototype.hasOwnProperty.call(current, key))
94
- return undefined;
95
- current = current[key];
96
- }
97
- return current;
98
- }
99
- /**
100
- * @description Sets a nested value on an object given a path.
101
- * @summary Traverses or creates intermediate objects following a splitter-delimited path and assigns the provided value at the destination key.
102
- * @param {Record<string, any>} obj Object to mutate while drilling into nested keys.
103
- * @param {string} path Splitter-delimited destination path (e.g., "a.b.c").
104
- * @param {any} value Value to set at the destination node.
105
- * @param {string} [splitter=ObjectKeySplitter] Delimiter used to separate the path segments.
106
- * @return {void}
107
- * @function setValueBySplitter
108
- * @mermaid
109
- * sequenceDiagram
110
- * participant C as Caller
111
- * participant F as setValueBySplitter
112
- * participant O as Object
113
- * C->>F: (obj, path, value, splitter)
114
- * F->>F: split path into keys
115
- * loop for each key
116
- * alt key missing
117
- * F->>O: create intermediate object
118
- * else key exists
119
- * F->>O: descend into existing object
120
- * end
121
- * end
122
- * F-->>C: void
123
- * @memberOf module:decoration
124
- */
125
- function setValueBySplitter(obj, path, value, splitter = ObjectKeySplitter) {
126
- const keys = path.split(splitter).filter((k) => k.length > 0);
127
- if (keys.length === 0)
128
- return;
129
- let current = obj;
130
- for (let i = 0; i < keys.length - 1; i++) {
131
- const key = keys[i];
132
- if (current[key] === undefined ||
133
- current[key] === null ||
134
- typeof current[key] !== "object") {
135
- current[key] = {};
136
- }
137
- current = current[key];
138
- }
139
- const lastKey = keys[keys.length - 1];
140
- current[lastKey] = value;
141
- }
142
- /**
143
- * @description Centralized runtime metadata store bound to constructors.
144
- * @summary Provides utilities to read and write structured metadata for classes and their members, with optional mirroring onto the constructor via a well-known symbol key. Supports nested key paths using a configurable splitter and offers both instance and static APIs.
145
- * @template M The model type the metadata belongs to.
146
- * @template META Extends BasicMetadata<M> representing the metadata structure.
147
- * @param {string} [flavour=DefaultFlavour] Optional flavour identifier applied when instantiating helper builders.
148
- * @class
149
- * @example
150
- * // Define and read metadata for a class
151
- * class User { name!: string }
152
- * Metadata.set(User, "description.class", "A user model");
153
- * Metadata.set(User, "properties.name", String);
154
- * const desc = Metadata.get(User, "description.class"); // "A user model"
155
- * const type = Metadata.type(User, "name"); // String
156
- * @mermaid
157
- * sequenceDiagram
158
- * participant C as Constructor
159
- * participant S as Metadata (static)
160
- * C->>S: set(User, "properties.name", String)
161
- * C->>S: get(User, "properties.name")
162
- * S-->>C: String
163
- */
164
- class Metadata {
165
- /**
166
- * @description In-memory storage of metadata by constructor symbol
167
- * @summary Maps a Symbol derived from the constructor to its metadata object, enabling efficient lookup.
168
- */
169
- static { this._metadata = {}; }
170
- /**
171
- * @description Path delimiter for nested metadata keys
172
- * @summary Used by get/set operations to navigate nested structures, defaults to ObjectKeySplitter.
173
- */
174
- static { this.splitter = ObjectKeySplitter; }
175
- /**
176
- * @description Symbol key used to mirror metadata on the constructor
177
- * @summary When mirroring is enabled, the metadata object is defined on the constructor under this non-enumerable key.
178
- */
179
- static { this.baseKey = DecorationKeys.REFLECT; }
180
- /**
181
- * @description Controls whether metadata is mirrored onto the constructor
182
- * @summary When true, the metadata object is defined on the constructor under the non-enumerable baseKey.
183
- */
184
- static { this.mirror = true; }
185
- constructor() { }
186
- static Symbol(obj) {
187
- return Symbol.for([obj.toString(), obj.name].join(" - "));
188
- }
189
- /**
190
- * @description Lists known property keys for a model.
191
- * @summary Reads the metadata entry and returns the names of properties that have recorded type information.
192
- * @param {Constructor} model Target constructor whose property metadata should be inspected.
193
- * @return {string[]|undefined} Array of property names or `undefined` if no metadata exists.
194
- */
195
- static properties(model) {
196
- const meta = this.get(model);
197
- if (!meta)
198
- return undefined;
199
- return Object.keys(meta.properties);
200
- }
201
- /**
202
- * @description Lists known methods for a model.
203
- * @summary Reads the metadata entry and returns the method names that have recorded signature metadata for the provided constructor.
204
- * @param {Constructor} model Target constructor whose method metadata should be inspected.
205
- * @return {string[]|undefined} Array of method names or `undefined` if no metadata exists.
206
- */
207
- static methods(model) {
208
- const meta = this.get(model, DecorationKeys.METHODS);
209
- if (!meta)
210
- return undefined;
211
- return Object.keys(meta);
212
- }
213
- /**
214
- * @description Retrieves a human-readable description for a class or a property.
215
- * @summary Looks up the description stored under the metadata "description" map. If a property key is provided, returns the property's description; otherwise returns the class description.
216
- * @template M
217
- * @param {Constructor<M>} model Target constructor whose description is being retrieved.
218
- * @param {string} [prop] Optional property key (typed as `keyof M`) for which to fetch the description.
219
- * @return {string|undefined} Description text if present, otherwise `undefined`.
220
- */
221
- static description(model, prop) {
222
- return this.get(model, this.key(DecorationKeys.DESCRIPTION, (prop ? prop : DecorationKeys.CLASS)));
223
- }
224
- /**
225
- * @description Retrieves the recorded params for a method.
226
- * @summary Reads the metadata entry under `methods.<prop>.design:paramtypes` to return the parameter constructors for the given method.
227
- * @template M
228
- * @param {Constructor<M>} model Target constructor owning the method metadata.
229
- * @param {string} prop Method name whose parameters should be fetched.
230
- * @return {any[]|undefined} Array of constructor references describing each parameter or `undefined` when not available.
231
- */
232
- static params(model, prop) {
233
- return this.get(model, this.key(DecorationKeys.METHODS, prop, DecorationKeys.DESIGN_PARAMS));
234
- }
235
- /**
236
- * @description Retrieves a single recorded parameter type for a method.
237
- * @summary Looks up the parameter metadata for the provided index, enforcing bounds and returning the constructor reference for that argument.
238
- * @template M
239
- * @param {Constructor<M>} model Target constructor owning the method metadata.
240
- * @param {string} prop Method name whose parameter should be returned.
241
- * @param {number} index Zero-based index of the desired parameter metadata.
242
- * @return {any|undefined} Constructor reference for the parameter or `undefined` if not recorded.
243
- */
244
- static param(model, prop, index) {
245
- const params = this.params(model, prop);
246
- if (!params)
247
- return undefined;
248
- if (index > params.length - 1)
249
- throw new Error(`Parameter index ${index} out of range for ${String(prop)}`);
250
- return params[index];
251
- }
252
- /**
253
- * @description Retrieves the recorded return type for a method.
254
- * @summary Reads the metadata entry under `methods.<prop>.design:returntype` to return the return type for the given method.
255
- * @template M
256
- * @param {Constructor<M>} model Target constructor whose method metadata should be inspected.
257
- * @param {string} prop Method name whose return type should be fetched.
258
- * @return {any|undefined} Constructor reference for the return type or `undefined` when not available.
259
- */
260
- static return(model, prop) {
261
- return this.get(model, this.key(DecorationKeys.METHODS, prop, DecorationKeys.DESIGN_RETURN));
262
- }
263
- /**
264
- * @description Retrieves the recorded design type for a property.
265
- * @summary Reads the metadata entry under `properties.<prop>` to return the constructor recorded for the given property name.
266
- * @param {Constructor} model Target constructor whose property metadata should be inspected.
267
- * @param {string} prop Property name whose type metadata should be returned.
268
- * @return {Constructor|undefined} Constructor reference for the property type or `undefined` if not available.
269
- */
270
- static type(model, prop) {
271
- return this.get(model, this.key(DecorationKeys.PROPERTIES, prop));
272
- }
273
- /**
274
- * @description Resolves the canonical constructor associated with the provided model handle and metadata.
275
- * @summary Returns the stored constructor reference when the provided model is a proxy or reduced value. Falls back to the original model when no constructor metadata has been recorded yet.
276
- * @template M
277
- * @param {Constructor<M>} model Model used when recording metadata.
278
- * @return {Constructor<M>} Canonical constructor if stored, otherwise the provided one`.
279
- */
280
- static constr(model) {
281
- return model[DecorationKeys.CONSTRUCTOR] || model;
282
- }
283
- /**
284
- * @description Retrieves metadata for a model or a specific key within it.
285
- * @summary When called with a constructor only, returns the entire metadata object associated with the model. When a key path is provided, returns the value stored at that nested key.
286
- * @template M
287
- * @template META
288
- * @param {Constructor<M>|string} model Target constructor used to locate the metadata record or a pre-resolved symbol identifier.
289
- * @param {string} [key] Optional nested key path to fetch a specific value.
290
- * @return {META|*|undefined} Metadata object, the value at the key path, or `undefined` if nothing exists.
291
- */
292
- static get(model, key) {
293
- if (key === DecorationKeys.CONSTRUCTOR)
294
- return this.constr(model);
295
- const resolvedModel = this.constr(model);
296
- const constructors = this.collectConstructorChain(resolvedModel);
297
- if (constructors.length === 0) {
298
- const fallbackSymbol = Symbol.for(resolvedModel.toString());
299
- return this.innerGet(fallbackSymbol, key);
300
- }
301
- const collectedValues = constructors
302
- .map((ctor) => this.innerGet(this.Symbol(ctor), key))
303
- .filter((value) => value !== undefined);
304
- if (collectedValues.length === 0)
305
- return undefined;
306
- return this.mergeMetadataChain(collectedValues);
307
- }
308
- /**
309
- * @description Retrieves metadata stored under a symbol key.
310
- * @summary Internal helper that resolves and optionally drills into the in-memory metadata map for the provided symbol and key path.
311
- * @param {symbol} symbol Symbol representing the metadata bucket.
312
- * @param {string|symbol} [key] Optional nested key referencing a specific metadata entry.
313
- * @return {any} Stored metadata object or value for the provided key, or `undefined` when absent.
314
- */
315
- static innerGet(symbol, key) {
316
- if (!this._metadata[symbol])
317
- return undefined;
318
- if (!key)
319
- return this._metadata[symbol];
320
- if (typeof key === "string")
321
- return getValueBySplitter(this._metadata[symbol], key, this.splitter);
322
- return this._metadata[symbol][key];
323
- }
324
- /**
325
- * @description Builds the inheritance chain for a constructor, ordered from base to most-specific class.
326
- * @summary Walks the prototype chain starting from the provided constructor until reaching Function/Object and returns the collected constructors.
327
- * @param {Constructor} model Constructor whose chain should be collected.
328
- * @return {Constructor[]} Array of constructors ordered from base to leaf.
329
- */
330
- static collectConstructorChain(model) {
331
- const chain = [];
332
- let current = model;
333
- while (typeof current === "function" && current !== Function) {
334
- chain.push(current);
335
- const parent = Object.getPrototypeOf(current);
336
- if (!parent || parent === Function || parent === Object)
337
- break;
338
- current = parent;
339
- }
340
- return chain.reverse();
341
- }
342
- /**
343
- * @description Merges metadata values collected across the inheritance chain.
344
- * @summary Performs a deep merge for plain objects while letting non-object values override earlier ones to preserve child metadata precedence.
345
- * @param {any[]} values Metadata values gathered from base to child.
346
- * @return {any} Aggregated metadata value respecting inheritance precedence.
347
- */
348
- static mergeMetadataChain(values) {
349
- let acc = undefined;
350
- for (const value of values) {
351
- if (acc === undefined) {
352
- acc = this.cloneMetadataValue(value);
353
- continue;
354
- }
355
- if (this.isPlainObject(acc) && this.isPlainObject(value)) {
356
- acc = this.mergePlainObjects(acc, value);
357
- continue;
358
- }
359
- acc = this.cloneMetadataValue(value);
360
- }
361
- return acc;
362
- }
363
- /**
364
- * @description Produces a deep clone of a metadata value when necessary.
365
- * @summary Arrays are shallow-cloned, plain objects are deep-cloned, and primitive/function values are returned as-is.
366
- * @param {any} value Metadata value to clone.
367
- * @return {any} Cloned metadata value preventing mutation of the backing store.
368
- */
369
- static cloneMetadataValue(value) {
370
- if (Array.isArray(value))
371
- return [...value];
372
- if (this.isPlainObject(value))
373
- return this.mergePlainObjects({}, value);
374
- return value;
375
- }
376
- /**
377
- * @description Deeply merges two plain metadata objects.
378
- * @summary Recursively merges nested plain objects while cloning arrays; values from `source` override those from `target` when conflicts occur.
379
- * @param {Record<string, any>} target Base object to merge into.
380
- * @param {Record<string, any>} source Object providing overriding metadata.
381
- * @return {Record<string, any>} Newly merged metadata object.
382
- */
383
- static mergePlainObjects(target, source) {
384
- const result = { ...target };
385
- for (const key of Object.keys(source)) {
386
- const sourceValue = source[key];
387
- const targetValue = result[key];
388
- if (this.isPlainObject(sourceValue)) {
389
- result[key] = this.isPlainObject(targetValue)
390
- ? this.mergePlainObjects(targetValue, sourceValue)
391
- : this.mergePlainObjects({}, sourceValue);
392
- continue;
393
- }
394
- if (Array.isArray(sourceValue)) {
395
- result[key] = [...sourceValue];
396
- continue;
397
- }
398
- result[key] = sourceValue;
399
- }
400
- return result;
401
- }
402
- /**
403
- * @description Checks if a value is a plain object suitable for deep merging.
404
- * @summary Ensures arrays and null are excluded while accepting objects created via literal/class syntax.
405
- * @param {any} value Value to inspect.
406
- * @return {boolean} True when the value is a plain object.
407
- */
408
- static isPlainObject(value) {
409
- if (value === null || typeof value !== "object" || Array.isArray(value))
410
- return false;
411
- const proto = Object.getPrototypeOf(value);
412
- return proto === Object.prototype || proto === null;
413
- }
414
- /**
415
- * @description Writes metadata under a symbol key.
416
- * @summary Internal helper that ensures the metadata bucket exists for the provided symbol and persists the given value, drilling into nested structures when the key is a string path.
417
- * @param {symbol} symbol Symbol representing the metadata bucket.
418
- * @param {string|symbol} key Nested key path or direct symbol under which to store the metadata value.
419
- * @param {any} value Value persisted in the metadata store.
420
- * @return {void}
421
- */
422
- static innerSet(symbol, key, value) {
423
- if (!this._metadata[symbol])
424
- this._metadata[symbol] = {};
425
- if (typeof key === "string")
426
- return setValueBySplitter(this._metadata[symbol], key, value, this.splitter);
427
- this._metadata[symbol][key] = value;
428
- }
429
- /**
430
- * @description Writes a metadata value at a given nested key path.
431
- * @summary Ensures the metadata record exists for the constructor, mirrors it on the constructor when enabled, and sets the provided value on the nested key path using the configured splitter.
432
- * @template M
433
- * @param {Constructor<M>|string} model Target constructor to which the metadata belongs or a direct identifier string.
434
- * @param {string} key Nested key path at which to store the value.
435
- * @param {any} value Value to store in the metadata.
436
- * @return {void}
437
- */
438
- static set(model, key, value) {
439
- if (key === DecorationKeys.CONSTRUCTOR) {
440
- Object.defineProperty(model, DecorationKeys.CONSTRUCTOR, {
441
- enumerable: false,
442
- configurable: false,
443
- writable: false,
444
- value: value,
445
- });
446
- return;
447
- }
448
- if (typeof model !== "string")
449
- model = this.constr(model) || model;
450
- const symbol = typeof model === "string" ? Symbol.for(model) : this.Symbol(model);
451
- this.innerSet(symbol, key, value);
452
- if (typeof model !== "string" &&
453
- Metadata.mirror &&
454
- !Object.prototype.hasOwnProperty.call(model, this.baseKey)) {
455
- Object.defineProperty(model, this.baseKey, {
456
- enumerable: false,
457
- configurable: false,
458
- writable: false,
459
- value: this._metadata[symbol],
460
- });
461
- }
462
- }
463
- /**
464
- * @description Registers a decoration-aware library and its version.
465
- * @summary Stores the version string for an integrating library under the shared libraries metadata symbol, preventing duplicate registrations for the same library identifier.
466
- * @param {string} library Package name or identifier to register.
467
- * @param {string} version Semantic version string associated with the library.
468
- * @return {void}
469
- * @throws {Error} If the library has already been registered.
470
- */
471
- static registerLibrary(library, version) {
472
- const symbol = Symbol.for(DecorationKeys.LIBRARIES);
473
- const lib = this.innerGet(symbol, library);
474
- if (lib)
475
- throw new Error(`Library already ${library} registered with version ${version}`);
476
- this.innerSet(symbol, library, version);
477
- }
478
- /**
479
- * @description Lists registered decoration-aware libraries.
480
- * @summary Returns the in-memory map of library identifiers to semantic versions that have been registered with the Decoration metadata store.
481
- * @return {Record<string, string>} Map of registered library identifiers to their version strings.
482
- */
483
- static libraries() {
484
- const symbol = Symbol.for(DecorationKeys.LIBRARIES);
485
- return this.innerGet(symbol) || {};
486
- }
487
- /**
488
- * @description Joins path segments using the current splitter.
489
- * @summary Constructs a nested metadata key by concatenating string segments with the configured splitter for use with the metadata store.
490
- * @param {...string} strs Key segments to join into a full metadata path.
491
- * @return {string} Splitter-joined metadata key.
492
- */
493
- static key(...strs) {
494
- return strs.join(this.splitter);
495
- }
496
- }
497
-
498
- /**
499
- * @description Default resolver that returns the current default flavour.
500
- * @summary Resolves the flavour for a given target by always returning the library's `DefaultFlavour` value.
501
- * @param {object} target Target object being decorated.
502
- * @return {string} Resolved flavour identifier.
503
- * @function defaultFlavourResolver
504
- * @memberOf module:decoration
505
- */
506
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
507
- function defaultFlavourResolver(target) {
508
- return DefaultFlavour;
509
- }
510
- /**
511
- * @description A decorator management class that handles flavoured decorators.
512
- * @summary The Decoration class provides a builder pattern for creating and managing decorators with different flavours. It supports registering, extending, and applying decorators with context-aware flavour resolution, allowing framework-specific implementations while maintaining a consistent API.
513
- * @template T Type of the decorator (ClassDecorator | PropertyDecorator | MethodDecorator).
514
- * @param {string} [flavour=DefaultFlavour] Optional flavour parameter for the decorator context.
515
- * @class
516
- * @example
517
- * ```typescript
518
- * // Create a new decoration for 'component' with default flavour
519
- * const componentDecorator = new Decoration()
520
- * .for('component')
521
- * .define(customComponentDecorator);
522
- *
523
- * // Create a flavoured decoration
524
- * const vueComponent = new Decoration('vue')
525
- * .for('component')
526
- * .define(vueComponentDecorator);
527
- *
528
- * // Apply the decoration
529
- * @componentDecorator
530
- * class MyComponent {}
531
- * ```
532
- * @mermaid
533
- * sequenceDiagram
534
- * participant C as Client
535
- * participant D as Decoration
536
- * participant R as FlavourResolver
537
- * participant F as DecoratorFactory
538
- *
539
- * C->>D: new Decoration(flavour)
540
- * C->>D: for(key)
541
- * C->>D: define(decorators)
542
- * D->>D: register(key, flavour, decorators)
543
- * D->>F: decoratorFactory(key, flavour)
544
- * F->>R: resolve(target)
545
- * R-->>F: resolved flavour
546
- * F->>F: apply decorators
547
- * F-->>C: decorated target
548
- */
549
- class Decoration {
550
- /**
551
- * @description Static map of registered decorators.
552
- * @summary Stores all registered decorators organised by key and flavour.
553
- */
554
- static { this.decorators = {}; }
555
- /**
556
- * @description Function to resolve flavour from a target.
557
- * @summary Resolver function that determines the appropriate flavour for a given target.
558
- */
559
- static { this.flavourResolver = defaultFlavourResolver; }
560
- constructor(flavour = DefaultFlavour) {
561
- this.flavour = flavour;
562
- }
563
- /**
564
- * @description Sets the key for the decoration builder.
565
- * @summary Initialises a new decoration chain with the specified key.
566
- * @param {string} key Identifier for the decorator.
567
- * @return {DecorationBuilderMid} Builder instance for method chaining.
568
- */
569
- for(key) {
570
- this.key = key;
571
- return this;
572
- }
573
- /**
574
- * @description Adds decorators to the current context.
575
- * @summary Internal method to add decorators with addon support.
576
- * @param {boolean} [addon=false] Indicates whether the decorators are additive extras.
577
- * @param {...DecoratorData} decorators Decorators to register for the configured key.
578
- * @return {this} Current instance for chaining.
579
- */
580
- decorate(addon = false, ...decorators) {
581
- if (!this.key)
582
- throw new Error("key must be provided before decorators can be added");
583
- if ((!decorators || !decorators.length) &&
584
- !addon &&
585
- this.flavour !== DefaultFlavour)
586
- throw new Error("Must provide overrides or addons to override or extend decaf's decorators");
587
- this[addon ? "extras" : "decorators"] = new Set([
588
- ...(this[addon ? "extras" : "decorators"] || new Set()).values(),
589
- ...decorators,
590
- ]);
591
- return this;
592
- }
593
- /**
594
- * @description Defines the base decorators.
595
- * @summary Sets the primary decorators for the current context.
596
- * @param {...DecoratorData} decorators Decorators to define.
597
- * @return {DecorationBuilderEnd} Builder instance for finishing the chain (also implements DecorationBuilderBuild).
598
- */
599
- define(...decorators) {
600
- if (decorators.find((d) => typeof d === "object") &&
601
- decorators.length !== 1)
602
- throw new Error(`When using an overridable decorator, only one is allowed`);
603
- return this.decorate(false, ...decorators);
604
- }
605
- /**
606
- * @description Extends existing decorators.
607
- * @summary Adds additional decorators to the current context.
608
- * @param {...DecoratorData} decorators Additional decorators to register as addons.
609
- * @return {DecorationBuilderBuild} Builder instance for building the decorator.
610
- */
611
- extend(...decorators) {
612
- if (decorators.find((d) => typeof d === "object") &&
613
- decorators.length !== 1)
614
- throw new Error(`When extending using an overridable decorator, only one is allowed`);
615
- return this.decorate(true, ...decorators);
616
- }
617
- /**
618
- * @description Factory that creates a context-aware decorator for a key/flavour.
619
- * @summary Produces a decorator function bound to the provided key and flavour. The resulting decorator resolves the actual decorators to apply at invocation time based on the target's resolved flavour and the registered base and extra decorators.
620
- * @param {string} key Decoration key used to look up registered decorators.
621
- * @param {string} [f=DefaultFlavour] Explicit flavour to bind the factory to.
622
- * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that applies the resolved decorators.
623
- * @mermaid
624
- * sequenceDiagram
625
- * participant U as User Code
626
- * participant B as Decoration (builder)
627
- * participant F as decoratorFactory(key, f)
628
- * participant R as flavourResolver
629
- * participant A as Applied Decorators
630
- * U->>B: define()/extend() and apply()
631
- * B->>F: create context decorator
632
- * F->>R: resolve(target)
633
- * R-->>F: flavour
634
- * F->>A: collect base + extras
635
- * loop each decorator
636
- * A->>U: invoke decorator(target, key?, desc?)
637
- * end
638
- */
639
- decoratorFactory(key, f = DefaultFlavour) {
640
- function contextDecorator(target, propertyKey, descriptor) {
641
- const flavour = Decoration.flavourResolver(target);
642
- const cache = Decoration.decorators[key];
643
- let decorators;
644
- const extras = cache[flavour]
645
- ? cache[flavour].extras
646
- : cache[DefaultFlavour].extras;
647
- if (cache &&
648
- cache[flavour] &&
649
- cache[flavour].decorators &&
650
- cache[flavour].decorators.size) {
651
- decorators = cache[flavour].decorators;
652
- }
653
- else {
654
- decorators = cache[DefaultFlavour].decorators;
655
- }
656
- const baseDecoratorsList = [...(decorators ? decorators.values() : [])];
657
- const defaultDecoratorsList = [
658
- ...(cache[DefaultFlavour]?.decorators || new Set()).values(),
659
- ];
660
- const baseArgsByIndex = baseDecoratorsList.reduce((accum, entry, index) => {
661
- if (typeof entry === "object" &&
662
- "args" in entry &&
663
- Array.isArray(entry.args)) {
664
- accum[index] = entry.args;
665
- }
666
- return accum;
667
- }, {});
668
- const defaultArgsByIndex = defaultDecoratorsList.reduce((accum, entry, index) => {
669
- if (typeof entry === "object" &&
670
- "args" in entry &&
671
- Array.isArray(entry.args)) {
672
- accum[index] = entry.args;
673
- }
674
- return accum;
675
- }, {});
676
- const toApply = [
677
- ...baseDecoratorsList,
678
- ...(extras ? extras.values() : []),
679
- ];
680
- const baseLength = baseDecoratorsList.length;
681
- return toApply.reduce((_, d, index) => {
682
- switch (typeof d) {
683
- case "object": {
684
- const entry = d;
685
- const candidateIndex = index < baseLength ? index : 0;
686
- const args = "args" in entry && Array.isArray(entry.args)
687
- ? entry.args
688
- : (baseArgsByIndex[candidateIndex] ??
689
- defaultArgsByIndex[candidateIndex] ??
690
- defaultArgsByIndex[0] ??
691
- []);
692
- return entry.decorator(...args)(target, propertyKey, descriptor);
693
- }
694
- case "function":
695
- return d(target, propertyKey, descriptor);
696
- default:
697
- throw new Error(`Unexpected decorator type: ${typeof d}`);
698
- }
699
- }, { target, propertyKey, descriptor });
700
- }
701
- Object.defineProperty(contextDecorator, "name", {
702
- value: [f, key].join("_decorator_for_"),
703
- writable: false,
704
- });
705
- return contextDecorator;
706
- }
707
- /**
708
- * @description Creates the final decorator function.
709
- * @summary Builds and returns the decorator factory function.
710
- * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Generated decorator function ready for application.
711
- */
712
- apply() {
713
- if (!this.key)
714
- throw new Error("No key provided for the decoration builder");
715
- const existingDecorators = Decoration.decorators[this.key]?.[this.flavour]?.decorators;
716
- const decoratorsToRegister = this.decorators || existingDecorators || new Set();
717
- Decoration.register(this.key, this.flavour, decoratorsToRegister, this.extras);
718
- return this.decoratorFactory(this.key, this.flavour);
719
- }
720
- /**
721
- * @description Registers decorators for a specific key and flavour.
722
- * @summary Internal method to store decorators in the static registry.
723
- * @param {string} key Decorator key.
724
- * @param {string} flavour Decorator flavour.
725
- * @param {Set<DecoratorData>} [decorators] Primary decorators registered for the key.
726
- * @param {Set<DecoratorData>} [extras] Additional decorators registered as flavour-specific addons.
727
- * @return {void}
728
- */
729
- static register(key, flavour, decorators, extras) {
730
- if (!key) {
731
- throw new Error("No key provided for the decoration builder");
732
- }
733
- if (!decorators)
734
- throw new Error("No decorators provided for the decoration builder");
735
- if (!flavour)
736
- throw new Error("No flavour provided for the decoration builder");
737
- if (!Decoration.decorators[key])
738
- Decoration.decorators[key] = {};
739
- if (!Decoration.decorators[key][flavour])
740
- Decoration.decorators[key][flavour] = {};
741
- if (decorators)
742
- Decoration.decorators[key][flavour].decorators = decorators;
743
- if (extras)
744
- Decoration.decorators[key][flavour].extras = extras;
745
- }
746
- /**
747
- * @description Sets the global flavour resolver.
748
- * @summary Configures the function used to determine decorator flavours.
749
- * @param {FlavourResolver} resolver Function to resolve flavours.
750
- * @return {void}
751
- */
752
- static setFlavourResolver(resolver) {
753
- Decoration.flavourResolver = resolver;
754
- }
755
- /**
756
- * @description Convenience static entry to start a decoration builder.
757
- * @summary Creates a new Decoration instance and initiates the builder chain with the provided key.
758
- * @param {string} key Decoration key to configure.
759
- * @return {DecorationBuilderMid} Builder instance for chaining definitions.
760
- */
761
- static for(key) {
762
- return new Decoration().for(key);
763
- }
764
- /**
765
- * @description Starts a builder for a specific flavour.
766
- * @summary Convenience method to begin a Decoration builder chain bound to the given flavour identifier, allowing registration of flavour-specific decorators.
767
- * @param {string} flavour Flavour name to bind to the builder.
768
- * @return {DecorationBuilderStart} Builder start interface to continue configuration.
769
- */
770
- static flavouredAs(flavour) {
771
- return new Decoration(flavour);
772
- }
773
- }
774
-
775
- /**
776
- * @description Assigns arbitrary metadata to a target using a string key.
777
- * @summary Decorator factory that stores a key/value pair in the central metadata store for the provided class or member.
778
- * @param {string} key Metadata key to associate with the target.
779
- * @param {any} value Metadata value to store under the given key.
780
- * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator that writes the metadata when applied.
781
- * @function metadata
782
- * @category Decorators
783
- */
784
- function metadata(key, value) {
785
- return function metadata(model, prop,
786
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
787
- descriptor) {
788
- Metadata.set(prop ? model.constructor : model, key, value);
789
- };
790
- }
791
- /**
792
- * @description Captures and stores a property's design type.
793
- * @summary Decorator factory that reads the reflected `design:type` for a property and registers it in the metadata store under the properties map.
794
- * @return {PropertyDecorator} Decorator that records the property's type metadata when applied.
795
- * @function prop
796
- * @category Property Decorators
797
- */
798
- function prop() {
799
- function innerProp() {
800
- return function innerProp(model, prop) {
801
- const designType = Reflect.getOwnMetadata(DecorationKeys.DESIGN_TYPE, model, prop);
802
- return metadata(Metadata.key(DecorationKeys.PROPERTIES, prop), designType)(model, prop);
803
- };
804
- }
805
- return Decoration.for(DecorationKeys.PROPERTIES)
806
- .define({
807
- decorator: innerProp,
808
- args: [],
809
- })
810
- .apply();
811
- }
812
- /**
813
- * @description Captures a single parameter type for the decorated method.
814
- * @summary Decorator factory that ensures the method metadata is initialised and stores the reflected parameter constructor at the provided index.
815
- * @return {ParameterDecorator} Decorator that records the parameter type when applied.
816
- * @function param
817
- * @category Parameter Decorators
818
- * @mermaid
819
- * sequenceDiagram
820
- * participant U as User Code
821
- * participant P as param()
822
- * participant M as Metadata
823
- * U->>P: param()(target, key, index)
824
- * P->>U: method()(target, key, descriptor)
825
- * P->>M: params(constructor, key)
826
- * M-->>P: parameter constructors[]
827
- * P->>M: set(methods.key.index, constructor)
828
- * P-->>U: parameter recorded
829
- */
830
- function param() {
831
- return function param(model, prop, index) {
832
- if (!prop)
833
- throw new Error(`The @param decorator can only be applied to methods`);
834
- method()(model, prop, Object.getOwnPropertyDescriptor(model, prop));
835
- const paramTpes = Metadata.params(model.constructor, prop);
836
- if (!paramTpes)
837
- throw new Error(`Missing parameter types for ${String(prop)}`);
838
- if (index >= paramTpes.length)
839
- throw new Error(`Parameter index ${index} out of range for ${String(prop)}`);
840
- metadata(Metadata.key(DecorationKeys.METHODS, prop, index.toString()), paramTpes[index])(model, prop);
841
- };
842
- }
843
- /**
844
- * @description Extends a parameter decorator with additional metadata.
845
- * @summary Applies the default `param()` decorator and augments the stored metadata with an arbitrary key/value pair.
846
- * @param {string} key Metadata key to associate with the parameter.
847
- * @param {any} value Metadata value persisted under the given key.
848
- * @return {ParameterDecorator} Decorator that records both the parameter design type and additional metadata.
849
- * @function paramMetadata
850
- * @category Parameter Decorators
851
- */
852
- function paramMetadata(key, value) {
853
- return function paramMetadata(target, prop, index) {
854
- return apply(param(), metadata(Metadata.key(DecorationKeys.METHODS, prop, key), value))(target, prop, index);
855
- };
856
- }
857
- /**
858
- * @description Records method design-time metadata.
859
- * @summary Decorator factory that captures a method's reflected parameter and return types, storing them under the appropriate metadata keys so they can be inspected at runtime.
860
- * @return {MethodDecorator} Decorator that persists the method's signature information into the metadata store when applied.
861
- * @function method
862
- * @mermaid
863
- * sequenceDiagram
864
- * participant U as User Code
865
- * participant F as method()
866
- * participant M as Metadata
867
- * U->>F: method()(target, key, descriptor)
868
- * F->>U: Reflect.getOwnMetadata(design:paramtypes)
869
- * F->>U: Reflect.getOwnMetadata(design:returntype)
870
- * F->>M: set(methods.key.design:paramtypes, params)
871
- * F->>M: set(methods.key.design:returntype, returnType)
872
- * F-->>U: decorated function
873
- * @category Method Decorators
874
- */
875
- function method() {
876
- return function method(obj, prop, descriptor) {
877
- const designParams = Reflect.getOwnMetadata(DecorationKeys.DESIGN_PARAMS, obj, prop);
878
- const designReturn = Reflect.getOwnMetadata(DecorationKeys.DESIGN_RETURN, obj, prop);
879
- return apply(metadata(Metadata.key(DecorationKeys.METHODS, prop, DecorationKeys.DESIGN_PARAMS), designParams), metadata(Metadata.key(DecorationKeys.METHODS, prop, DecorationKeys.DESIGN_RETURN), designReturn))(obj, prop, descriptor);
880
- };
881
- }
882
- /**
883
- * @description Decorator factory that applies multiple decorators to a single target.
884
- * @summary Creates a composite decorator that applies multiple decorators in sequence, correctly handling class, method, property, and parameter decorators.
885
- * @param {Array<ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator>} decorators Collection of decorators to apply.
886
- * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that applies all provided decorators to the target.
887
- * @function apply
888
- * @mermaid
889
- * sequenceDiagram
890
- * participant U as User Code
891
- * participant A as apply(...decorators)
892
- * participant D as Decorator
893
- * U->>A: get decorator(...decorators)
894
- * A->>U: returns (target, key?, desc?) => void
895
- * U->>A: invoke on target
896
- * loop for each decorator
897
- * A->>D: invoke appropriate decorator type
898
- * end
899
- * @category Decorators
900
- */
901
- function apply(...decorators) {
902
- return (target, propertyKey, descriptor) => {
903
- for (const decorator of decorators) {
904
- if (target instanceof Function && !descriptor) {
905
- decorator(target);
906
- continue;
907
- }
908
- decorator(target, propertyKey, descriptor);
909
- }
910
- };
911
- }
912
- /**
913
- * @description Creates a property metadata decorator.
914
- * @summary Convenience factory that combines `metadata(key, value)` and `prop()` to both set an arbitrary metadata key and record the property's design type.
915
- * @param {string} key Metadata key to set for the property.
916
- * @param {any} value Metadata value to associate with the key.
917
- * @return {PropertyDecorator} Decorator that sets the metadata and captures the property's type.
918
- * @function propMetadata
919
- * @category Property Decorators
920
- */
921
- function propMetadata(key, value) {
922
- return apply(metadata(key, value), prop());
923
- }
924
- /**
925
- * @description Creates a method metadata decorator.
926
- * @summary Convenience factory that combines `metadata(key, value)` and `method()` to both set an arbitrary metadata key and record the method's design return and param types.
927
- * @param {string} key Metadata key to set for the property.
928
- * @param {any} value Metadata value to associate with the key.
929
- * @return {MethodDecorator} Decorator that sets the metadata and captures the method's signature metadata.
930
- * @function methodMetadata
931
- * @category Method Decorators
932
- */
933
- function methodMetadata(key, value) {
934
- return apply(metadata(key, value), method());
935
- }
936
- /**
937
- * @description Attaches a human-readable description to a class or member.
938
- * @summary Decorator factory that stores a textual description in the metadata store under the appropriate description key for a class or its property.
939
- * @param {string} desc Descriptive text to associate with the class or property.
940
- * @return {ClassDecorator|MethodDecorator|PropertyDecorator} Decorator that records the description when applied.
941
- * @function description
942
- * @category Decorators
943
- */
944
- function description(desc) {
945
- function innerDescription(desc) {
946
- return function innerDescription(original, prop, descriptor) {
947
- return metadata([
948
- DecorationKeys.DESCRIPTION,
949
- prop ? prop.toString() : DecorationKeys.CLASS,
950
- ].join(Metadata.splitter), desc)(original, prop, descriptor);
951
- };
952
- }
953
- return Decoration.for(DecorationKeys.DESCRIPTION)
954
- .define({
955
- decorator: innerDescription,
956
- args: [desc],
957
- })
958
- .apply();
959
- }
960
-
961
- /**
962
- * @description Root entry point for the decoration package.
963
- * @summary Re-exports the builder API, decorator helpers, metadata utilities, and shared constants so consumers can import {@link Decoration}, {@link Metadata}, {@link DecorationKeys}, and {@link DefaultFlavour} from a single surface.
964
- * @module decoration
965
- */
966
- /**
967
- * @description Current version of the decoration package.
968
- * @summary Stores the semantic version string registered through {@link Metadata.registerLibrary}.
969
- * @type {string}
970
- * @const VERSION
971
- * @memberOf module:decoration
972
- */
973
- const VERSION = "0.0.22";
974
- Metadata.registerLibrary("@decaf-ts/decoration", VERSION);
975
-
976
- export { Decoration, DecorationKeys, DefaultFlavour, DefaultMetadata, Metadata, ObjectKeySplitter, VERSION, apply, description, getValueBySplitter, metadata, method, methodMetadata, param, paramMetadata, prop, propMetadata, setValueBySplitter };
977
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdGlvbi5lc20uY2pzIiwic291cmNlcyI6WyIuLi9zcmMvY29uc3RhbnRzLnRzIiwiLi4vc3JjL21ldGFkYXRhL01ldGFkYXRhLnRzIiwiLi4vc3JjL2RlY29yYXRpb24vRGVjb3JhdGlvbi50cyIsIi4uL3NyYy9kZWNvcmF0b3JzLnRzIiwiLi4vc3JjL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbbnVsbCxudWxsLG51bGwsbnVsbCxudWxsXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQTs7Ozs7O0FBTUc7QUFDSSxNQUFNLGNBQWMsR0FBRyxRQUFRO0FBRXRDOzs7Ozs7QUFNRztBQUNJLE1BQU0saUJBQWlCLEdBQUcsSUFBSTtBQUVyQzs7Ozs7OztBQU9HO0lBQ1MsZUF1Qlg7QUF2QkQsQ0FBQSxVQUFZLGNBQWMsRUFBQTs7QUFFeEIsSUFBQSxjQUFBLENBQUEsV0FBQSxDQUFBLEdBQUEsV0FBdUIsQ0FBQTs7QUFFdkIsSUFBQSxjQUFBLENBQUEsU0FBQSxDQUFBLEdBQUEsU0FBK0IsQ0FBQTs7QUFFL0IsSUFBQSxjQUFBLENBQUEsWUFBQSxDQUFBLEdBQUEsWUFBeUIsQ0FBQTs7QUFFekIsSUFBQSxjQUFBLENBQUEsU0FBQSxDQUFBLEdBQUEsU0FBbUIsQ0FBQTs7QUFFbkIsSUFBQSxjQUFBLENBQUEsT0FBQSxDQUFBLEdBQUEsT0FBZSxDQUFBOztBQUVmLElBQUEsY0FBQSxDQUFBLGFBQUEsQ0FBQSxHQUFBLGFBQTJCLENBQUE7O0FBRTNCLElBQUEsY0FBQSxDQUFBLGFBQUEsQ0FBQSxHQUFBLFlBQTBCLENBQUE7O0FBRTFCLElBQUEsY0FBQSxDQUFBLFlBQUEsQ0FBQSxHQUFBLFlBQXlCLENBQUE7O0FBRXpCLElBQUEsY0FBQSxDQUFBLGFBQUEsQ0FBQSxHQUFBLGFBQTJCLENBQUE7O0FBRTNCLElBQUEsY0FBQSxDQUFBLGVBQUEsQ0FBQSxHQUFBLG1CQUFtQyxDQUFBOztBQUVuQyxJQUFBLGNBQUEsQ0FBQSxlQUFBLENBQUEsR0FB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