@decaf-ts/decoration 0.0.16 → 0.0.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decoration.cjs +116 -18
- package/dist/decoration.esm.cjs +116 -18
- package/lib/constants.cjs +7 -4
- package/lib/constants.d.ts +6 -3
- package/lib/decoration/types.cjs +1 -1
- package/lib/decoration/types.d.ts +1 -4
- package/lib/decorators.cjs +2 -2
- package/lib/decorators.d.ts +1 -1
- package/lib/esm/constants.d.ts +6 -3
- package/lib/esm/constants.js +7 -4
- package/lib/esm/decoration/types.d.ts +1 -4
- package/lib/esm/decoration/types.js +1 -1
- package/lib/esm/decorators.d.ts +1 -1
- package/lib/esm/decorators.js +2 -2
- package/lib/esm/index.d.ts +6 -9
- package/lib/esm/index.js +7 -10
- package/lib/esm/metadata/Metadata.d.ts +36 -0
- package/lib/esm/metadata/Metadata.js +103 -5
- package/lib/esm/metadata/types.d.ts +22 -10
- package/lib/esm/metadata/types.js +1 -1
- package/lib/index.cjs +7 -10
- package/lib/index.d.ts +6 -9
- package/lib/metadata/Metadata.cjs +103 -5
- package/lib/metadata/Metadata.d.ts +36 -0
- package/lib/metadata/types.cjs +1 -1
- package/lib/metadata/types.d.ts +22 -10
- package/package.json +2 -2
package/lib/constants.cjs
CHANGED
|
@@ -3,14 +3,16 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.DefaultMetadata = exports.DecorationKeys = exports.ObjectKeySplitter = exports.DefaultFlavour = void 0;
|
|
4
4
|
/**
|
|
5
5
|
* @description Default flavour identifier for the decorator system.
|
|
6
|
-
* @summary Defines the
|
|
6
|
+
* @summary Defines the fallback flavour used when no specific value is provided, ensuring consistent decorator selection across the library.
|
|
7
|
+
* @type {string}
|
|
7
8
|
* @const DefaultFlavour
|
|
8
9
|
* @memberOf module:decoration
|
|
9
10
|
*/
|
|
10
11
|
exports.DefaultFlavour = "decaf";
|
|
11
12
|
/**
|
|
12
13
|
* @description Character used to split nested metadata keys.
|
|
13
|
-
* @summary Defines the delimiter the metadata store
|
|
14
|
+
* @summary Defines the delimiter applied by the metadata store when traversing nested object paths for read and write operations.
|
|
15
|
+
* @type {string}
|
|
14
16
|
* @const ObjectKeySplitter
|
|
15
17
|
* @memberOf module:decoration
|
|
16
18
|
*/
|
|
@@ -50,11 +52,12 @@ var DecorationKeys;
|
|
|
50
52
|
})(DecorationKeys || (exports.DecorationKeys = DecorationKeys = {}));
|
|
51
53
|
/**
|
|
52
54
|
* @description Default metadata instance.
|
|
53
|
-
* @summary Provides the default metadata shape used when
|
|
55
|
+
* @summary Provides the default metadata shape used when initialising new metadata entries for a model.
|
|
56
|
+
* @type {module:decoration.BasicMetadata<any>}
|
|
54
57
|
* @const DefaultMetadata
|
|
55
58
|
* @memberOf module:decoration
|
|
56
59
|
*/
|
|
57
60
|
exports.DefaultMetadata = {
|
|
58
61
|
[DecorationKeys.PROPERTIES]: [],
|
|
59
62
|
};
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQTs7Ozs7O0dBTUc7QUFDVSxRQUFBLGNBQWMsR0FBRyxPQUFPLENBQUM7QUFFdEM7Ozs7OztHQU1HO0FBQ1UsUUFBQSxpQkFBaUIsR0FBRyxHQUFHLENBQUM7QUFFckM7Ozs7Ozs7R0FPRztBQUNILElBQVksY0F1Qlg7QUF2QkQsV0FBWSxjQUFjO0lBQ3hCLDhFQUE4RTtJQUM5RSx5Q0FBdUIsQ0FBQTtJQUN2QixxRkFBcUY7SUFDckYscUNBQStCLENBQUE7SUFDL0IseUVBQXlFO0lBQ3pFLDJDQUF5QixDQUFBO0lBQ3pCLHVFQUF1RTtJQUN2RSxxQ0FBbUIsQ0FBQTtJQUNuQixpRkFBaUY7SUFDakYsaUNBQWUsQ0FBQTtJQUNmLHdFQUF3RTtJQUN4RSw2Q0FBMkIsQ0FBQTtJQUMzQixtRkFBbUY7SUFDbkYsNENBQTBCLENBQUE7SUFDMUIsMkVBQTJFO0lBQzNFLDJDQUF5QixDQUFBO0lBQ3pCLHNFQUFzRTtJQUN0RSw2Q0FBMkIsQ0FBQTtJQUMzQixrRkFBa0Y7SUFDbEYscURBQW1DLENBQUE7SUFDbkMsb0VBQW9FO0lBQ3BFLHFEQUFtQyxDQUFBO0FBQ3JDLENBQUMsRUF2QlcsY0FBYyw4QkFBZCxjQUFjLFFBdUJ6QjtBQUVEOzs7Ozs7R0FNRztBQUNVLFFBQUEsZUFBZSxHQUF1QjtJQUNqRCxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsRUFBRSxFQUFFO0NBQ0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2ljTWV0YWRhdGEgfSBmcm9tIFwiLi9tZXRhZGF0YS90eXBlc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEZWZhdWx0IGZsYXZvdXIgaWRlbnRpZmllciBmb3IgdGhlIGRlY29yYXRvciBzeXN0ZW0uXG4gKiBAc3VtbWFyeSBEZWZpbmVzIHRoZSBmYWxsYmFjayBmbGF2b3VyIHVzZWQgd2hlbiBubyBzcGVjaWZpYyB2YWx1ZSBpcyBwcm92aWRlZCwgZW5zdXJpbmcgY29uc2lzdGVudCBkZWNvcmF0b3Igc2VsZWN0aW9uIGFjcm9zcyB0aGUgbGlicmFyeS5cbiAqIEB0eXBlIHtzdHJpbmd9XG4gKiBAY29uc3QgRGVmYXVsdEZsYXZvdXJcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdGlvblxuICovXG5leHBvcnQgY29uc3QgRGVmYXVsdEZsYXZvdXIgPSBcImRlY2FmXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIENoYXJhY3RlciB1c2VkIHRvIHNwbGl0IG5lc3RlZCBtZXRhZGF0YSBrZXlzLlxuICogQHN1bW1hcnkgRGVmaW5lcyB0aGUgZGVsaW1pdGVyIGFwcGxpZWQgYnkgdGhlIG1ldGFkYXRhIHN0b3JlIHdoZW4gdHJhdmVyc2luZyBuZXN0ZWQgb2JqZWN0IHBhdGhzIGZvciByZWFkIGFuZCB3cml0ZSBvcGVyYXRpb25zLlxuICogQHR5cGUge3N0cmluZ31cbiAqIEBjb25zdCBPYmplY3RLZXlTcGxpdHRlclxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0aW9uXG4gKi9cbmV4cG9ydCBjb25zdCBPYmplY3RLZXlTcGxpdHRlciA9IFwiLlwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBNZXRhZGF0YSB0b2tlbiByZWdpc3RyeSBmb3IgdGhlIGRlY29yYXRpb24gc3lzdGVtLlxuICogQHN1bW1hcnkgRW51bWVyYXRlcyB0aGUga2V5cyB1c2VkIGR1cmluZyByZWZsZWN0aW9uIGFuZCBtZXRhZGF0YSBzdG9yYWdlIGZvciBjbGFzc2VzLCBwcm9wZXJ0aWVzLCBtZXRob2RzLCBkZXNjcmlwdGlvbnMsIGFuZCByZWdpc3RlcmVkIGxpYnJhcmllcy5cbiAqIEBlbnVtIHtzdHJpbmd9XG4gKiBAcmVhZG9ubHlcbiAqIEBjb25zdCBEZWNvcmF0aW9uS2V5c1xuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0aW9uXG4gKi9cbmV4cG9ydCBlbnVtIERlY29yYXRpb25LZXlzIHtcbiAgLyoqIEBkZXNjcmlwdGlvbiBTdG9yYWdlIGJ1Y2tldCBmb3IgZGVjb3JhdGlvbi1hd2FyZSBsaWJyYXJ5IHJlZ2lzdHJhdGlvbnMuICovXG4gIExJQlJBUklFUyA9IFwibGlicmFyaWVzXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gU3RvcmFnZSBrZXkgbWlycm9yZWQgb24gY29uc3RydWN0b3JzIHRoYXQgaG9sZHMgcnVudGltZSBtZXRhZGF0YS4gKi9cbiAgUkVGTEVDVCA9IGBfXyR7RGVmYXVsdEZsYXZvdXJ9YCxcbiAgLyoqIEBkZXNjcmlwdGlvbiBDb250YWluZXIgb2YgcmVmbGVjdGVkIHByb3BlcnR5IG1ldGFkYXRhIGZvciBhIG1vZGVsLiAqL1xuICBQUk9QRVJUSUVTID0gXCJwcm9wZXJ0aWVzXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gQ29udGFpbmVyIG9mIHJlZmxlY3RlZCBtZXRob2QgbWV0YWRhdGEgZm9yIGEgbW9kZWwuICovXG4gIE1FVEhPRFMgPSBcIm1ldGhvZHNcIixcbiAgLyoqIEBkZXNjcmlwdGlvbiBLZXkgdW5kZXIgd2hpY2ggdGhlIG1vZGVsIGNvbnN0cnVjdG9yIHJlZmVyZW5jZSBpcyBwZXJzaXN0ZWQuICovXG4gIENMQVNTID0gXCJjbGFzc1wiLFxuICAvKiogQGRlc2NyaXB0aW9uIEh1bWFuLXJlYWRhYmxlIGRlc2NyaXB0aW9ucyBmb3IgY2xhc3NlcyBhbmQgbWVtYmVycy4gKi9cbiAgREVTQ1JJUFRJT04gPSBcImRlc2NyaXB0aW9uXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gU3RvcmFnZSBzbG90IHRyYWNraW5nIHRoZSBvcmlnaW5hbCBjb25zdHJ1Y3RvciB3aGVuIG92ZXJyaWRkZW4uICovXG4gIENPTlNUUlVDVE9SID0gXCJfX29yaWdpbmFsXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gQ29sbGVjdGVkIHBhcmFtZXRlciBtZXRhZGF0YSBmb3IgY29uZmlndXJlZCBkZWNvcmF0b3JzLiAqL1xuICBQQVJBTUVURVJTID0gXCJwYXJhbWV0ZXJzXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gUmVmbGVjdCBtZXRhZGF0YSBrZXkgZm9yIGEgcHJvcGVydHkncyBkZXNpZ24gdHlwZS4gKi9cbiAgREVTSUdOX1RZUEUgPSBcImRlc2lnbjp0eXBlXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gUmVmbGVjdCBtZXRhZGF0YSBrZXkgZm9yIHJlY29yZGVkIGNvbnN0cnVjdG9yIHBhcmFtZXRlciB0eXBlcy4gKi9cbiAgREVTSUdOX1BBUkFNUyA9IFwiZGVzaWduOnBhcmFtdHlwZXNcIixcbiAgLyoqIEBkZXNjcmlwdGlvbiBSZWZsZWN0IG1ldGFkYXRhIGtleSBmb3IgYSBtZXRob2QncyByZXR1cm4gdHlwZS4gKi9cbiAgREVTSUdOX1JFVFVSTiA9IFwiZGVzaWduOnJldHVybnR5cGVcIixcbn1cblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRGVmYXVsdCBtZXRhZGF0YSBpbnN0YW5jZS5cbiAqIEBzdW1tYXJ5IFByb3ZpZGVzIHRoZSBkZWZhdWx0IG1ldGFkYXRhIHNoYXBlIHVzZWQgd2hlbiBpbml0aWFsaXNpbmcgbmV3IG1ldGFkYXRhIGVudHJpZXMgZm9yIGEgbW9kZWwuXG4gKiBAdHlwZSB7bW9kdWxlOmRlY29yYXRpb24uQmFzaWNNZXRhZGF0YTxhbnk+fVxuICogQGNvbnN0IERlZmF1bHRNZXRhZGF0YVxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0aW9uXG4gKi9cbmV4cG9ydCBjb25zdCBEZWZhdWx0TWV0YWRhdGE6IEJhc2ljTWV0YWRhdGE8YW55PiA9IHtcbiAgW0RlY29yYXRpb25LZXlzLlBST1BFUlRJRVNdOiBbXSxcbn0gYXMgdW5rbm93biBhcyBCYXNpY01ldGFkYXRhPGFueT47XG4iXX0=
|
package/lib/constants.d.ts
CHANGED
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
import { BasicMetadata } from "./metadata/types";
|
|
2
2
|
/**
|
|
3
3
|
* @description Default flavour identifier for the decorator system.
|
|
4
|
-
* @summary Defines the
|
|
4
|
+
* @summary Defines the fallback flavour used when no specific value is provided, ensuring consistent decorator selection across the library.
|
|
5
|
+
* @type {string}
|
|
5
6
|
* @const DefaultFlavour
|
|
6
7
|
* @memberOf module:decoration
|
|
7
8
|
*/
|
|
8
9
|
export declare const DefaultFlavour = "decaf";
|
|
9
10
|
/**
|
|
10
11
|
* @description Character used to split nested metadata keys.
|
|
11
|
-
* @summary Defines the delimiter the metadata store
|
|
12
|
+
* @summary Defines the delimiter applied by the metadata store when traversing nested object paths for read and write operations.
|
|
13
|
+
* @type {string}
|
|
12
14
|
* @const ObjectKeySplitter
|
|
13
15
|
* @memberOf module:decoration
|
|
14
16
|
*/
|
|
@@ -47,7 +49,8 @@ export declare enum DecorationKeys {
|
|
|
47
49
|
}
|
|
48
50
|
/**
|
|
49
51
|
* @description Default metadata instance.
|
|
50
|
-
* @summary Provides the default metadata shape used when
|
|
52
|
+
* @summary Provides the default metadata shape used when initialising new metadata entries for a model.
|
|
53
|
+
* @type {module:decoration.BasicMetadata<any>}
|
|
51
54
|
* @const DefaultMetadata
|
|
52
55
|
* @memberOf module:decoration
|
|
53
56
|
*/
|
package/lib/decoration/types.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZGVjb3JhdGlvbi90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVjb3JhdG9yRGF0YSB9IGZyb20gXCIuL0RlY29yYXRpb25cIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gSW50ZXJmYWNlIGZvciB0aGUgZmluYWwgc3RhZ2Ugb2YgdGhlIGRlY29yYXRpb24gYnVpbGRlciBwYXR0ZXJuLlxuICogQHN1bW1hcnkgUmVwcmVzZW50cyB0aGUgYnVpbGQgc3RhZ2Ugb2YgdGhlIGRlY29yYXRpb24gYnVpbGRlciwgcHJvdmlkaW5nIHRoZSBhYmlsaXR5IHRvIGFwcGx5IHRoZSBjb25maWd1cmVkIGRlY29yYXRvciB0byBhIHRhcmdldC4gVGhpcyBpcyB0aGUgZmluYWwgc3RhZ2UgaW4gdGhlIGJ1aWxkZXIgY2hhaW4uXG4gKiBAaW50ZXJmYWNlIERlY29yYXRpb25CdWlsZGVyQnVpbGRcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIERlY29yYXRpb25CdWlsZGVyQnVpbGQge1xuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIENyZWF0ZXMgYW5kIHJldHVybnMgdGhlIGRlY29yYXRvciBmdW5jdGlvbi5cbiAgICogQHN1bW1hcnkgRmluYWxpc2VzIHRoZSBidWlsZGVyIHByb2Nlc3MgYW5kIHJldHVybnMgYSBkZWNvcmF0b3IgZnVuY3Rpb24gdGhhdCBjYW4gYmUgYXBwbGllZCB0byBhIGNsYXNzLCBwcm9wZXJ0eSwgb3IgbWV0aG9kLlxuICAgKiBAcmV0dXJuIHtmdW5jdGlvbihhbnksIGFueSwgVHlwZWRQcm9wZXJ0eURlc2NyaXB0b3I8YW55Pik6Q2xhc3NEZWNvcmF0b3J8TWV0aG9kRGVjb3JhdG9yfFByb3BlcnR5RGVjb3JhdG9yfFBhcmFtZXRlckRlY29yYXRvcn0gRGVjb3JhdG9yIGZ1bmN0aW9uIHRoYXQgY2FuIGJlIGFwcGxpZWQgdG8gYSB0YXJnZXQuXG4gICAqL1xuICBhcHBseSgpOiAoXG4gICAgdGFyZ2V0OiBhbnksXG4gICAgcHJvcGVydHlLZXk/OiBhbnksXG4gICAgZGVzY3JpcHRvcj86IFR5cGVkUHJvcGVydHlEZXNjcmlwdG9yPGFueT5cbiAgKSA9PiBhbnk7XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEludGVyZmFjZSBmb3IgdGhlIGV4dGVuc2lvbiBzdGFnZSBvZiB0aGUgZGVjb3JhdGlvbiBidWlsZGVyIHBhdHRlcm4uXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIHRoZSBleHRlbnNpb24gc3RhZ2Ugb2YgdGhlIGRlY29yYXRpb24gYnVpbGRlciwgcHJvdmlkaW5nIHRoZSBhYmlsaXR5IHRvIGFkZCBhZGRpdGlvbmFsIGRlY29yYXRvcnMgdG8gdGhlIGV4aXN0aW5nIGNvbmZpZ3VyYXRpb24uXG4gKiBAaW50ZXJmYWNlIERlY29yYXRpb25CdWlsZGVyRW5kXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEZWNvcmF0aW9uQnVpbGRlckVuZCB7XG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gQWRkcyBhZGRpdGlvbmFsIGRlY29yYXRvcnMgdG8gdGhlIGV4aXN0aW5nIGNvbmZpZ3VyYXRpb24uXG4gICAqIEBzdW1tYXJ5IEV4dGVuZHMgdGhlIGN1cnJlbnQgZGVjb3JhdG9yIGNvbmZpZ3VyYXRpb24gd2l0aCBhZGRpdGlvbmFsIGRlY29yYXRvcnMsIG1ha2luZyBpdCB1c2VmdWwgZm9yIGF1Z21lbnRpbmcgcHJldmlvdXNseSBkZWZpbmVkIGJlaGF2aW91ci5cbiAgICogQHBhcmFtIHsuLi5EZWNvcmF0b3JEYXRhfSBkZWNvcmF0b3JzIEFkZGl0aW9uYWwgZGVjb3JhdG9ycyB0byBhZGQuXG4gICAqIEByZXR1cm4ge0RlY29yYXRpb25CdWlsZGVyQnVpbGR9IFRoZSBidWlsZCBzdGFnZSBvZiB0aGUgYnVpbGRlciBwYXR0ZXJuLlxuICAgKi9cbiAgZXh0ZW5kKC4uLmRlY29yYXRvcnM6IERlY29yYXRvckRhdGFbXSk6IERlY29yYXRpb25CdWlsZGVyQnVpbGQ7XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEludGVyZmFjZSBmb3IgdGhlIG1pZGRsZSBzdGFnZSBvZiB0aGUgZGVjb3JhdGlvbiBidWlsZGVyIHBhdHRlcm4uXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIHRoZSBtaWRkbGUgc3RhZ2Ugb2YgdGhlIGRlY29yYXRpb24gYnVpbGRlciwgZXh0ZW5kaW5nIHRoZSBlbmQgc3RhZ2UgYW5kIHByb3ZpZGluZyB0aGUgYWJpbGl0eSB0byBkZWZpbmUgdGhlIHByaW1hcnkgZGVjb3JhdG9ycyBmb3IgdGhlIGNvbmZpZ3VyYXRpb24uXG4gKiBAaW50ZXJmYWNlIERlY29yYXRpb25CdWlsZGVyTWlkXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEZWNvcmF0aW9uQnVpbGRlck1pZCBleHRlbmRzIERlY29yYXRpb25CdWlsZGVyRW5kIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBEZWZpbmVzIHRoZSBwcmltYXJ5IGRlY29yYXRvcnMgZm9yIHRoZSBjb25maWd1cmF0aW9uLlxuICAgKiBAc3VtbWFyeSBTZXRzIHRoZSBtYWluIGRlY29yYXRvcnMgZm9yIHRoZSBjdXJyZW50IGNvbnRleHQgYWZ0ZXIgc3BlY2lmeWluZyB0aGUga2V5IHdpdGggdGhlIGBmb3JgIG1ldGhvZC5cbiAgICogQHBhcmFtIHsuLi5EZWNvcmF0b3JEYXRhfSBkZWNvcmF0b3JzIERlY29yYXRvcnMgdG8gZGVmaW5lIGZvciB0aGUgY3VycmVudCBrZXkgYW5kIGZsYXZvdXIuXG4gICAqIEByZXR1cm4ge0RlY29yYXRpb25CdWlsZGVyRW5kfSBJbnRlcmZhY2UgcmVwcmVzZW50aW5nIHRoZSByZW1haW5pbmcgYnVpbGRlciBzdGFnZXMgKGFsc28gaW1wbGVtZW50cyBEZWNvcmF0aW9uQnVpbGRlckJ1aWxkKS5cbiAgICovXG4gIGRlZmluZShcbiAgICAuLi5kZWNvcmF0b3JzOiBEZWNvcmF0b3JEYXRhW11cbiAgKTogRGVjb3JhdGlvbkJ1aWxkZXJFbmQgJiBEZWNvcmF0aW9uQnVpbGRlckJ1aWxkO1xufVxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBJbnRlcmZhY2UgZm9yIHRoZSBzdGFydGluZyBzdGFnZSBvZiB0aGUgZGVjb3JhdGlvbiBidWlsZGVyIHBhdHRlcm4uXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIHRoZSBpbml0aWFsIHN0YWdlIG9mIHRoZSBkZWNvcmF0aW9uIGJ1aWxkZXIsIHByb3ZpZGluZyB0aGUgZW50cnkgcG9pbnQgZm9yIHRoZSBidWlsZGVyIHBhdHRlcm4gYnkgc3BlY2lmeWluZyB0aGUga2V5IGZvciB0aGUgZGVjb3JhdG9yLlxuICogQGludGVyZmFjZSBEZWNvcmF0aW9uQnVpbGRlclN0YXJ0XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEZWNvcmF0aW9uQnVpbGRlclN0YXJ0IHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBTcGVjaWZpZXMgdGhlIGtleSBmb3IgdGhlIGRlY29yYXRvci5cbiAgICogQHN1bW1hcnkgU2V0cyB0aGUgaWRlbnRpZmllciBmb3IgdGhlIGRlY29yYXRvciwgd2hpY2ggaXMgdXNlZCB0byByZWdpc3RlciBhbmQgcmV0cmlldmUgdGhlIGRlY29yYXRvciBpbiB0aGUgZGVjb3JhdGlvbiByZWdpc3RyeS5cbiAgICogQHBhcmFtIHtzdHJpbmd9IGlkIElkZW50aWZpZXIgZm9yIHRoZSBkZWNvcmF0b3IuXG4gICAqIEByZXR1cm4ge0RlY29yYXRpb25CdWlsZGVyTWlkfSBUaGUgbWlkZGxlIHN0YWdlIG9mIHRoZSBidWlsZGVyIHBhdHRlcm4uXG4gICAqL1xuICBmb3IoaWQ6IHN0cmluZyk6IERlY29yYXRpb25CdWlsZGVyTWlkO1xufVxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBDb21wcmVoZW5zaXZlIGludGVyZmFjZSBmb3IgdGhlIGNvbXBsZXRlIGRlY29yYXRpb24gYnVpbGRlciBwYXR0ZXJuLlxuICogQHN1bW1hcnkgVW5pZmllZCBpbnRlcmZhY2UgdGhhdCBjb21iaW5lcyBhbGwgc3RhZ2VzIG9mIHRoZSBkZWNvcmF0aW9uIGJ1aWxkZXIgcGF0dGVybiwgcHJvdmlkaW5nIGEgY29tcGxldGUgQVBJIGZvciBjcmVhdGluZywgY29uZmlndXJpbmcsIGFuZCBhcHBseWluZyBkZWNvcmF0b3JzLiBUaGlzIGludGVyZmFjZSBpcyBpbXBsZW1lbnRlZCBieSB0aGUgRGVjb3JhdGlvbiBjbGFzcy5cbiAqIEBpbnRlcmZhY2UgSURlY29yYXRpb25CdWlsZGVyXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJRGVjb3JhdGlvbkJ1aWxkZXJcbiAgZXh0ZW5kcyBEZWNvcmF0aW9uQnVpbGRlclN0YXJ0LFxuICAgIERlY29yYXRpb25CdWlsZGVyTWlkLFxuICAgIERlY29yYXRpb25CdWlsZGVyRW5kLFxuICAgIERlY29yYXRpb25CdWlsZGVyQnVpbGQge31cblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gVHlwZSBkZWZpbml0aW9uIGZvciBhIGZ1bmN0aW9uIHRoYXQgcmVzb2x2ZXMgdGhlIGZsYXZvdXIgZm9yIGEgdGFyZ2V0LlxuICogQHN1bW1hcnkgRGVmaW5lcyBhIGZ1bmN0aW9uIHR5cGUgdGhhdCBkZXRlcm1pbmVzIHRoZSBhcHByb3ByaWF0ZSBmbGF2b3VyIGZvciBhIGdpdmVuIHRhcmdldCBvYmplY3QsIGVuYWJsaW5nIGZsYXZvdXItYXdhcmUgZGVjb3JhdG9yIHNlbGVjdGlvbi5cbiAqIEBwYXJhbSB7b2JqZWN0fSB0YXJnZXQgVGFyZ2V0IG9iamVjdCB0byByZXNvbHZlIHRoZSBmbGF2b3VyIGZvci5cbiAqIEByZXR1cm4ge3N0cmluZ30gUmVzb2x2ZWQgZmxhdm91ciBpZGVudGlmaWVyLlxuICogQHR5cGVEZWYgRmxhdm91clJlc29sdmVyXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IHR5cGUgRmxhdm91clJlc29sdmVyID0gKHRhcmdldDogb2JqZWN0KSA9PiBzdHJpbmc7XG4iXX0=
|
|
@@ -9,10 +9,7 @@ export interface DecorationBuilderBuild {
|
|
|
9
9
|
/**
|
|
10
10
|
* @description Creates and returns the decorator function.
|
|
11
11
|
* @summary Finalises the builder process and returns a decorator function that can be applied to a class, property, or method.
|
|
12
|
-
* @
|
|
13
|
-
* @param {any} [propertyKey] Property key when decorating a class member.
|
|
14
|
-
* @param {TypedPropertyDescriptor<any>} [descriptor] Descriptor supplied for method or accessor decoration.
|
|
15
|
-
* @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that can be applied to a target.
|
|
12
|
+
* @return {function(any, any, TypedPropertyDescriptor<any>):ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that can be applied to a target.
|
|
16
13
|
*/
|
|
17
14
|
apply(): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
|
18
15
|
}
|
package/lib/decorators.cjs
CHANGED
|
@@ -157,7 +157,7 @@ function propMetadata(key, value) {
|
|
|
157
157
|
* @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.
|
|
158
158
|
* @param {string} key Metadata key to set for the property.
|
|
159
159
|
* @param {any} value Metadata value to associate with the key.
|
|
160
|
-
* @return {
|
|
160
|
+
* @return {MethodDecorator} Decorator that sets the metadata and captures the method's signature metadata.
|
|
161
161
|
* @function methodMetadata
|
|
162
162
|
* @category Method Decorators
|
|
163
163
|
*/
|
|
@@ -180,4 +180,4 @@ function description(desc) {
|
|
|
180
180
|
].join(Metadata_1.Metadata.splitter), desc)(original, prop, descriptor);
|
|
181
181
|
};
|
|
182
182
|
}
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { Metadata } from \"./metadata/Metadata\";\nimport { DecorationKeys } from \"./constants\";\n\n/**\n * @description Assigns arbitrary metadata to a target using a string key.\n * @summary Decorator factory that stores a key/value pair in the central metadata store for the provided class or member.\n * @param {string} key Metadata key to associate with the target.\n * @param {any} value Metadata value to store under the given key.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator that writes the metadata when applied.\n * @function metadata\n * @category Decorators\n */\nexport function metadata(key: string, value: any) {\n  return function metadata(\n    model: any,\n\n    prop?: any,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    descriptor?: PropertyDescriptor | number\n  ) {\n    Metadata.set(prop ? model.constructor : model, key, value);\n  };\n}\n\n/**\n * @description Captures and stores a property's design type.\n * @summary Decorator factory that reads the reflected `design:type` for a property and registers it in the metadata store under the properties map.\n * @return {PropertyDecorator} Decorator that records the property's type metadata when applied.\n * @function prop\n * @category Property Decorators\n */\nexport function prop() {\n  return function prop(model: object, prop: any) {\n    const designType = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_TYPE,\n      model,\n      prop\n    );\n    return metadata(Metadata.key(DecorationKeys.PROPERTIES, prop), designType)(\n      model,\n      prop\n    );\n  };\n}\n\n/**\n * @description Captures a single parameter type for the decorated method.\n * @summary Decorator factory that ensures the method metadata is initialised and stores the reflected parameter constructor at the provided index.\n * @return {ParameterDecorator} Decorator that records the parameter type when applied.\n * @function param\n * @category Parameter Decorators\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant P as param()\n *   participant M as Metadata\n *   U->>P: param()(target, key, index)\n *   P->>U: method()(target, key, descriptor)\n *   P->>M: params(constructor, key)\n *   M-->>P: parameter constructors[]\n *   P->>M: set(methods.key.index, constructor)\n *   P-->>U: parameter recorded\n */\nexport function param() {\n  return function param(\n    model: object,\n    prop: string | symbol | undefined,\n    index: number\n  ) {\n    if (!prop)\n      throw new Error(`The @param decorator can only be applied to methods`);\n    method()(model, prop, Object.getOwnPropertyDescriptor(model, prop));\n    const paramTpes = Metadata.params(model.constructor as any, prop as string);\n    if (!paramTpes)\n      throw new Error(`Missing parameter types for ${String(prop)}`);\n    if (index >= paramTpes.length)\n      throw new Error(\n        `Parameter index ${index} out of range for ${String(prop)}`\n      );\n    metadata(\n      Metadata.key(DecorationKeys.METHODS, prop as string, index.toString()),\n      paramTpes[index]\n    )(model, prop);\n  };\n}\n\n/**\n * @description Extends a parameter decorator with additional metadata.\n * @summary Applies the default `param()` decorator and augments the stored metadata with an arbitrary key/value pair.\n * @param {string} key Metadata key to associate with the parameter.\n * @param {any} value Metadata value persisted under the given key.\n * @return {ParameterDecorator} Decorator that records both the parameter design type and additional metadata.\n * @function paramMetadata\n * @category Parameter Decorators\n */\nexport function paramMetadata(key: string, value: any) {\n  return function paramMetadata(target: any, prop: any, index: number) {\n    return apply(\n      param(),\n      metadata(Metadata.key(DecorationKeys.METHODS, prop, key), value)\n    )(target, prop, index);\n  };\n}\n\n/**\n * @description Records method design-time metadata.\n * @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.\n * @return {MethodDecorator} Decorator that persists the method's signature information into the metadata store when applied.\n * @function method\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant F as method()\n *   participant M as Metadata\n *   U->>F: method()(target, key, descriptor)\n *   F->>U: Reflect.getOwnMetadata(design:paramtypes)\n *   F->>U: Reflect.getOwnMetadata(design:returntype)\n *   F->>M: set(methods.key.design:paramtypes, params)\n *   F->>M: set(methods.key.design:returntype, returnType)\n *   F-->>U: decorated function\n * @category Method Decorators\n */\nexport function method() {\n  return function method(obj: any, prop?: any, descriptor?: any) {\n    const designParams = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_PARAMS,\n      obj,\n      prop\n    );\n    const designReturn = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_RETURN,\n      obj,\n      prop\n    );\n    return apply(\n      metadata(\n        Metadata.key(\n          DecorationKeys.METHODS,\n          prop,\n          DecorationKeys.DESIGN_PARAMS\n        ),\n        designParams\n      ),\n      metadata(\n        Metadata.key(\n          DecorationKeys.METHODS,\n          prop,\n          DecorationKeys.DESIGN_RETURN\n        ),\n        designReturn\n      )\n    )(obj, prop, descriptor);\n  };\n}\n\n/**\n * @description Decorator factory that applies multiple decorators to a single target.\n * @summary Creates a composite decorator that applies multiple decorators in sequence, correctly handling class, method, property, and parameter decorators.\n * @param {Array<ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator>} decorators Collection of decorators to apply.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that applies all provided decorators to the target.\n * @function apply\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant A as apply(...decorators)\n *   participant D as Decorator\n *   U->>A: get decorator(...decorators)\n *   A->>U: returns (target, key?, desc?) => void\n *   U->>A: invoke on target\n *   loop for each decorator\n *     A->>D: invoke appropriate decorator type\n *   end\n * @category Decorators\n */\nexport function apply(\n  ...decorators: Array<\n    ClassDecorator | MethodDecorator | PropertyDecorator | ParameterDecorator\n  >\n) {\n  return (\n    target: object,\n    propertyKey?: string | symbol | unknown,\n    descriptor?: PropertyDescriptor | number\n  ) => {\n    for (const decorator of decorators) {\n      if (target instanceof Function && !descriptor) {\n        (decorator as ClassDecorator)(target);\n        continue;\n      }\n      (decorator as MethodDecorator | PropertyDecorator)(\n        target,\n        propertyKey as string | symbol,\n        descriptor as TypedPropertyDescriptor<unknown>\n      );\n    }\n  };\n}\n\n/**\n * @description Creates a property metadata decorator.\n * @summary Convenience factory that combines `metadata(key, value)` and `prop()` to both set an arbitrary metadata key and record the property's design type.\n * @param {string} key Metadata key to set for the property.\n * @param {any} value Metadata value to associate with the key.\n * @return {PropertyDecorator} Decorator that sets the metadata and captures the property's type.\n * @function propMetadata\n * @category Property Decorators\n */\nexport function propMetadata(key: string, value: any) {\n  return apply(metadata(key, value), prop());\n}\n\n/**\n * @description Creates a method metadata decorator.\n * @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.\n * @param {string} key Metadata key to set for the property.\n * @param {any} value Metadata value to associate with the key.\n * @return {PropertyDecorator} Decorator that sets the metadata and captures the property's type.\n * @function methodMetadata\n * @category Method Decorators\n */\nexport function methodMetadata(key: string, value: any) {\n  return apply(metadata(key, value), method());\n}\n\n/**\n * @description Attaches a human-readable description to a class or member.\n * @summary Decorator factory that stores a textual description in the metadata store under the appropriate description key for a class or its property.\n * @param {string} desc Descriptive text to associate with the class or property.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator} Decorator that records the description when applied.\n * @function description\n * @category Decorators\n */\nexport function description(desc: string) {\n  return function description(original: any, prop?: any, descriptor?: any) {\n    return metadata(\n      [\n        DecorationKeys.DESCRIPTION,\n        prop ? prop.toString() : DecorationKeys.CLASS,\n      ].join(Metadata.splitter),\n      desc\n    )(original, prop, descriptor);\n  };\n}\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { Metadata } from \"./metadata/Metadata\";\nimport { DecorationKeys } from \"./constants\";\n\n/**\n * @description Assigns arbitrary metadata to a target using a string key.\n * @summary Decorator factory that stores a key/value pair in the central metadata store for the provided class or member.\n * @param {string} key Metadata key to associate with the target.\n * @param {any} value Metadata value to store under the given key.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator that writes the metadata when applied.\n * @function metadata\n * @category Decorators\n */\nexport function metadata(key: string, value: any) {\n  return function metadata(\n    model: any,\n\n    prop?: any,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    descriptor?: PropertyDescriptor | number\n  ) {\n    Metadata.set(prop ? model.constructor : model, key, value);\n  };\n}\n\n/**\n * @description Captures and stores a property's design type.\n * @summary Decorator factory that reads the reflected `design:type` for a property and registers it in the metadata store under the properties map.\n * @return {PropertyDecorator} Decorator that records the property's type metadata when applied.\n * @function prop\n * @category Property Decorators\n */\nexport function prop() {\n  return function prop(model: object, prop: any) {\n    const designType = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_TYPE,\n      model,\n      prop\n    );\n    return metadata(Metadata.key(DecorationKeys.PROPERTIES, prop), designType)(\n      model,\n      prop\n    );\n  };\n}\n\n/**\n * @description Captures a single parameter type for the decorated method.\n * @summary Decorator factory that ensures the method metadata is initialised and stores the reflected parameter constructor at the provided index.\n * @return {ParameterDecorator} Decorator that records the parameter type when applied.\n * @function param\n * @category Parameter Decorators\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant P as param()\n *   participant M as Metadata\n *   U->>P: param()(target, key, index)\n *   P->>U: method()(target, key, descriptor)\n *   P->>M: params(constructor, key)\n *   M-->>P: parameter constructors[]\n *   P->>M: set(methods.key.index, constructor)\n *   P-->>U: parameter recorded\n */\nexport function param() {\n  return function param(\n    model: object,\n    prop: string | symbol | undefined,\n    index: number\n  ) {\n    if (!prop)\n      throw new Error(`The @param decorator can only be applied to methods`);\n    method()(model, prop, Object.getOwnPropertyDescriptor(model, prop));\n    const paramTpes = Metadata.params(model.constructor as any, prop as string);\n    if (!paramTpes)\n      throw new Error(`Missing parameter types for ${String(prop)}`);\n    if (index >= paramTpes.length)\n      throw new Error(\n        `Parameter index ${index} out of range for ${String(prop)}`\n      );\n    metadata(\n      Metadata.key(DecorationKeys.METHODS, prop as string, index.toString()),\n      paramTpes[index]\n    )(model, prop);\n  };\n}\n\n/**\n * @description Extends a parameter decorator with additional metadata.\n * @summary Applies the default `param()` decorator and augments the stored metadata with an arbitrary key/value pair.\n * @param {string} key Metadata key to associate with the parameter.\n * @param {any} value Metadata value persisted under the given key.\n * @return {ParameterDecorator} Decorator that records both the parameter design type and additional metadata.\n * @function paramMetadata\n * @category Parameter Decorators\n */\nexport function paramMetadata(key: string, value: any) {\n  return function paramMetadata(target: any, prop: any, index: number) {\n    return apply(\n      param(),\n      metadata(Metadata.key(DecorationKeys.METHODS, prop, key), value)\n    )(target, prop, index);\n  };\n}\n\n/**\n * @description Records method design-time metadata.\n * @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.\n * @return {MethodDecorator} Decorator that persists the method's signature information into the metadata store when applied.\n * @function method\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant F as method()\n *   participant M as Metadata\n *   U->>F: method()(target, key, descriptor)\n *   F->>U: Reflect.getOwnMetadata(design:paramtypes)\n *   F->>U: Reflect.getOwnMetadata(design:returntype)\n *   F->>M: set(methods.key.design:paramtypes, params)\n *   F->>M: set(methods.key.design:returntype, returnType)\n *   F-->>U: decorated function\n * @category Method Decorators\n */\nexport function method() {\n  return function method(obj: any, prop?: any, descriptor?: any) {\n    const designParams = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_PARAMS,\n      obj,\n      prop\n    );\n    const designReturn = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_RETURN,\n      obj,\n      prop\n    );\n    return apply(\n      metadata(\n        Metadata.key(\n          DecorationKeys.METHODS,\n          prop,\n          DecorationKeys.DESIGN_PARAMS\n        ),\n        designParams\n      ),\n      metadata(\n        Metadata.key(\n          DecorationKeys.METHODS,\n          prop,\n          DecorationKeys.DESIGN_RETURN\n        ),\n        designReturn\n      )\n    )(obj, prop, descriptor);\n  };\n}\n\n/**\n * @description Decorator factory that applies multiple decorators to a single target.\n * @summary Creates a composite decorator that applies multiple decorators in sequence, correctly handling class, method, property, and parameter decorators.\n * @param {Array<ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator>} decorators Collection of decorators to apply.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that applies all provided decorators to the target.\n * @function apply\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant A as apply(...decorators)\n *   participant D as Decorator\n *   U->>A: get decorator(...decorators)\n *   A->>U: returns (target, key?, desc?) => void\n *   U->>A: invoke on target\n *   loop for each decorator\n *     A->>D: invoke appropriate decorator type\n *   end\n * @category Decorators\n */\nexport function apply(\n  ...decorators: Array<\n    ClassDecorator | MethodDecorator | PropertyDecorator | ParameterDecorator\n  >\n) {\n  return (\n    target: object,\n    propertyKey?: string | symbol | unknown,\n    descriptor?: PropertyDescriptor | number\n  ) => {\n    for (const decorator of decorators) {\n      if (target instanceof Function && !descriptor) {\n        (decorator as ClassDecorator)(target);\n        continue;\n      }\n      (decorator as MethodDecorator | PropertyDecorator)(\n        target,\n        propertyKey as string | symbol,\n        descriptor as TypedPropertyDescriptor<unknown>\n      );\n    }\n  };\n}\n\n/**\n * @description Creates a property metadata decorator.\n * @summary Convenience factory that combines `metadata(key, value)` and `prop()` to both set an arbitrary metadata key and record the property's design type.\n * @param {string} key Metadata key to set for the property.\n * @param {any} value Metadata value to associate with the key.\n * @return {PropertyDecorator} Decorator that sets the metadata and captures the property's type.\n * @function propMetadata\n * @category Property Decorators\n */\nexport function propMetadata(key: string, value: any) {\n  return apply(metadata(key, value), prop());\n}\n\n/**\n * @description Creates a method metadata decorator.\n * @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.\n * @param {string} key Metadata key to set for the property.\n * @param {any} value Metadata value to associate with the key.\n * @return {MethodDecorator} Decorator that sets the metadata and captures the method's signature metadata.\n * @function methodMetadata\n * @category Method Decorators\n */\nexport function methodMetadata(key: string, value: any) {\n  return apply(metadata(key, value), method());\n}\n\n/**\n * @description Attaches a human-readable description to a class or member.\n * @summary Decorator factory that stores a textual description in the metadata store under the appropriate description key for a class or its property.\n * @param {string} desc Descriptive text to associate with the class or property.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator} Decorator that records the description when applied.\n * @function description\n * @category Decorators\n */\nexport function description(desc: string) {\n  return function description(original: any, prop?: any, descriptor?: any) {\n    return metadata(\n      [\n        DecorationKeys.DESCRIPTION,\n        prop ? prop.toString() : DecorationKeys.CLASS,\n      ].join(Metadata.splitter),\n      desc\n    )(original, prop, descriptor);\n  };\n}\n"]}
|
package/lib/decorators.d.ts
CHANGED
|
@@ -99,7 +99,7 @@ export declare function propMetadata(key: string, value: any): (target: object,
|
|
|
99
99
|
* @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.
|
|
100
100
|
* @param {string} key Metadata key to set for the property.
|
|
101
101
|
* @param {any} value Metadata value to associate with the key.
|
|
102
|
-
* @return {
|
|
102
|
+
* @return {MethodDecorator} Decorator that sets the metadata and captures the method's signature metadata.
|
|
103
103
|
* @function methodMetadata
|
|
104
104
|
* @category Method Decorators
|
|
105
105
|
*/
|
package/lib/esm/constants.d.ts
CHANGED
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
import { BasicMetadata } from "./metadata/types";
|
|
2
2
|
/**
|
|
3
3
|
* @description Default flavour identifier for the decorator system.
|
|
4
|
-
* @summary Defines the
|
|
4
|
+
* @summary Defines the fallback flavour used when no specific value is provided, ensuring consistent decorator selection across the library.
|
|
5
|
+
* @type {string}
|
|
5
6
|
* @const DefaultFlavour
|
|
6
7
|
* @memberOf module:decoration
|
|
7
8
|
*/
|
|
8
9
|
export declare const DefaultFlavour = "decaf";
|
|
9
10
|
/**
|
|
10
11
|
* @description Character used to split nested metadata keys.
|
|
11
|
-
* @summary Defines the delimiter the metadata store
|
|
12
|
+
* @summary Defines the delimiter applied by the metadata store when traversing nested object paths for read and write operations.
|
|
13
|
+
* @type {string}
|
|
12
14
|
* @const ObjectKeySplitter
|
|
13
15
|
* @memberOf module:decoration
|
|
14
16
|
*/
|
|
@@ -47,7 +49,8 @@ export declare enum DecorationKeys {
|
|
|
47
49
|
}
|
|
48
50
|
/**
|
|
49
51
|
* @description Default metadata instance.
|
|
50
|
-
* @summary Provides the default metadata shape used when
|
|
52
|
+
* @summary Provides the default metadata shape used when initialising new metadata entries for a model.
|
|
53
|
+
* @type {module:decoration.BasicMetadata<any>}
|
|
51
54
|
* @const DefaultMetadata
|
|
52
55
|
* @memberOf module:decoration
|
|
53
56
|
*/
|
package/lib/esm/constants.js
CHANGED
|
@@ -1,13 +1,15 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @description Default flavour identifier for the decorator system.
|
|
3
|
-
* @summary Defines the
|
|
3
|
+
* @summary Defines the fallback flavour used when no specific value is provided, ensuring consistent decorator selection across the library.
|
|
4
|
+
* @type {string}
|
|
4
5
|
* @const DefaultFlavour
|
|
5
6
|
* @memberOf module:decoration
|
|
6
7
|
*/
|
|
7
8
|
export const DefaultFlavour = "decaf";
|
|
8
9
|
/**
|
|
9
10
|
* @description Character used to split nested metadata keys.
|
|
10
|
-
* @summary Defines the delimiter the metadata store
|
|
11
|
+
* @summary Defines the delimiter applied by the metadata store when traversing nested object paths for read and write operations.
|
|
12
|
+
* @type {string}
|
|
11
13
|
* @const ObjectKeySplitter
|
|
12
14
|
* @memberOf module:decoration
|
|
13
15
|
*/
|
|
@@ -47,11 +49,12 @@ export var DecorationKeys;
|
|
|
47
49
|
})(DecorationKeys || (DecorationKeys = {}));
|
|
48
50
|
/**
|
|
49
51
|
* @description Default metadata instance.
|
|
50
|
-
* @summary Provides the default metadata shape used when
|
|
52
|
+
* @summary Provides the default metadata shape used when initialising new metadata entries for a model.
|
|
53
|
+
* @type {module:decoration.BasicMetadata<any>}
|
|
51
54
|
* @const DefaultMetadata
|
|
52
55
|
* @memberOf module:decoration
|
|
53
56
|
*/
|
|
54
57
|
export const DefaultMetadata = {
|
|
55
58
|
[DecorationKeys.PROPERTIES]: [],
|
|
56
59
|
};
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDO0FBRXRDOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLEdBQUcsQ0FBQztBQUVyQzs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxDQUFOLElBQVksY0F1Qlg7QUF2QkQsV0FBWSxjQUFjO0lBQ3hCLDhFQUE4RTtJQUM5RSx5Q0FBdUIsQ0FBQTtJQUN2QixxRkFBcUY7SUFDckYscUNBQStCLENBQUE7SUFDL0IseUVBQXlFO0lBQ3pFLDJDQUF5QixDQUFBO0lBQ3pCLHVFQUF1RTtJQUN2RSxxQ0FBbUIsQ0FBQTtJQUNuQixpRkFBaUY7SUFDakYsaUNBQWUsQ0FBQTtJQUNmLHdFQUF3RTtJQUN4RSw2Q0FBMkIsQ0FBQTtJQUMzQixtRkFBbUY7SUFDbkYsNENBQTBCLENBQUE7SUFDMUIsMkVBQTJFO0lBQzNFLDJDQUF5QixDQUFBO0lBQ3pCLHNFQUFzRTtJQUN0RSw2Q0FBMkIsQ0FBQTtJQUMzQixrRkFBa0Y7SUFDbEYscURBQW1DLENBQUE7SUFDbkMsb0VBQW9FO0lBQ3BFLHFEQUFtQyxDQUFBO0FBQ3JDLENBQUMsRUF2QlcsY0FBYyxLQUFkLGNBQWMsUUF1QnpCO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUF1QjtJQUNqRCxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsRUFBRSxFQUFFO0NBQ0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2ljTWV0YWRhdGEgfSBmcm9tIFwiLi9tZXRhZGF0YS90eXBlc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEZWZhdWx0IGZsYXZvdXIgaWRlbnRpZmllciBmb3IgdGhlIGRlY29yYXRvciBzeXN0ZW0uXG4gKiBAc3VtbWFyeSBEZWZpbmVzIHRoZSBmYWxsYmFjayBmbGF2b3VyIHVzZWQgd2hlbiBubyBzcGVjaWZpYyB2YWx1ZSBpcyBwcm92aWRlZCwgZW5zdXJpbmcgY29uc2lzdGVudCBkZWNvcmF0b3Igc2VsZWN0aW9uIGFjcm9zcyB0aGUgbGlicmFyeS5cbiAqIEB0eXBlIHtzdHJpbmd9XG4gKiBAY29uc3QgRGVmYXVsdEZsYXZvdXJcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdGlvblxuICovXG5leHBvcnQgY29uc3QgRGVmYXVsdEZsYXZvdXIgPSBcImRlY2FmXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIENoYXJhY3RlciB1c2VkIHRvIHNwbGl0IG5lc3RlZCBtZXRhZGF0YSBrZXlzLlxuICogQHN1bW1hcnkgRGVmaW5lcyB0aGUgZGVsaW1pdGVyIGFwcGxpZWQgYnkgdGhlIG1ldGFkYXRhIHN0b3JlIHdoZW4gdHJhdmVyc2luZyBuZXN0ZWQgb2JqZWN0IHBhdGhzIGZvciByZWFkIGFuZCB3cml0ZSBvcGVyYXRpb25zLlxuICogQHR5cGUge3N0cmluZ31cbiAqIEBjb25zdCBPYmplY3RLZXlTcGxpdHRlclxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0aW9uXG4gKi9cbmV4cG9ydCBjb25zdCBPYmplY3RLZXlTcGxpdHRlciA9IFwiLlwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBNZXRhZGF0YSB0b2tlbiByZWdpc3RyeSBmb3IgdGhlIGRlY29yYXRpb24gc3lzdGVtLlxuICogQHN1bW1hcnkgRW51bWVyYXRlcyB0aGUga2V5cyB1c2VkIGR1cmluZyByZWZsZWN0aW9uIGFuZCBtZXRhZGF0YSBzdG9yYWdlIGZvciBjbGFzc2VzLCBwcm9wZXJ0aWVzLCBtZXRob2RzLCBkZXNjcmlwdGlvbnMsIGFuZCByZWdpc3RlcmVkIGxpYnJhcmllcy5cbiAqIEBlbnVtIHtzdHJpbmd9XG4gKiBAcmVhZG9ubHlcbiAqIEBjb25zdCBEZWNvcmF0aW9uS2V5c1xuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0aW9uXG4gKi9cbmV4cG9ydCBlbnVtIERlY29yYXRpb25LZXlzIHtcbiAgLyoqIEBkZXNjcmlwdGlvbiBTdG9yYWdlIGJ1Y2tldCBmb3IgZGVjb3JhdGlvbi1hd2FyZSBsaWJyYXJ5IHJlZ2lzdHJhdGlvbnMuICovXG4gIExJQlJBUklFUyA9IFwibGlicmFyaWVzXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gU3RvcmFnZSBrZXkgbWlycm9yZWQgb24gY29uc3RydWN0b3JzIHRoYXQgaG9sZHMgcnVudGltZSBtZXRhZGF0YS4gKi9cbiAgUkVGTEVDVCA9IGBfXyR7RGVmYXVsdEZsYXZvdXJ9YCxcbiAgLyoqIEBkZXNjcmlwdGlvbiBDb250YWluZXIgb2YgcmVmbGVjdGVkIHByb3BlcnR5IG1ldGFkYXRhIGZvciBhIG1vZGVsLiAqL1xuICBQUk9QRVJUSUVTID0gXCJwcm9wZXJ0aWVzXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gQ29udGFpbmVyIG9mIHJlZmxlY3RlZCBtZXRob2QgbWV0YWRhdGEgZm9yIGEgbW9kZWwuICovXG4gIE1FVEhPRFMgPSBcIm1ldGhvZHNcIixcbiAgLyoqIEBkZXNjcmlwdGlvbiBLZXkgdW5kZXIgd2hpY2ggdGhlIG1vZGVsIGNvbnN0cnVjdG9yIHJlZmVyZW5jZSBpcyBwZXJzaXN0ZWQuICovXG4gIENMQVNTID0gXCJjbGFzc1wiLFxuICAvKiogQGRlc2NyaXB0aW9uIEh1bWFuLXJlYWRhYmxlIGRlc2NyaXB0aW9ucyBmb3IgY2xhc3NlcyBhbmQgbWVtYmVycy4gKi9cbiAgREVTQ1JJUFRJT04gPSBcImRlc2NyaXB0aW9uXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gU3RvcmFnZSBzbG90IHRyYWNraW5nIHRoZSBvcmlnaW5hbCBjb25zdHJ1Y3RvciB3aGVuIG92ZXJyaWRkZW4uICovXG4gIENPTlNUUlVDVE9SID0gXCJfX29yaWdpbmFsXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gQ29sbGVjdGVkIHBhcmFtZXRlciBtZXRhZGF0YSBmb3IgY29uZmlndXJlZCBkZWNvcmF0b3JzLiAqL1xuICBQQVJBTUVURVJTID0gXCJwYXJhbWV0ZXJzXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gUmVmbGVjdCBtZXRhZGF0YSBrZXkgZm9yIGEgcHJvcGVydHkncyBkZXNpZ24gdHlwZS4gKi9cbiAgREVTSUdOX1RZUEUgPSBcImRlc2lnbjp0eXBlXCIsXG4gIC8qKiBAZGVzY3JpcHRpb24gUmVmbGVjdCBtZXRhZGF0YSBrZXkgZm9yIHJlY29yZGVkIGNvbnN0cnVjdG9yIHBhcmFtZXRlciB0eXBlcy4gKi9cbiAgREVTSUdOX1BBUkFNUyA9IFwiZGVzaWduOnBhcmFtdHlwZXNcIixcbiAgLyoqIEBkZXNjcmlwdGlvbiBSZWZsZWN0IG1ldGFkYXRhIGtleSBmb3IgYSBtZXRob2QncyByZXR1cm4gdHlwZS4gKi9cbiAgREVTSUdOX1JFVFVSTiA9IFwiZGVzaWduOnJldHVybnR5cGVcIixcbn1cblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRGVmYXVsdCBtZXRhZGF0YSBpbnN0YW5jZS5cbiAqIEBzdW1tYXJ5IFByb3ZpZGVzIHRoZSBkZWZhdWx0IG1ldGFkYXRhIHNoYXBlIHVzZWQgd2hlbiBpbml0aWFsaXNpbmcgbmV3IG1ldGFkYXRhIGVudHJpZXMgZm9yIGEgbW9kZWwuXG4gKiBAdHlwZSB7bW9kdWxlOmRlY29yYXRpb24uQmFzaWNNZXRhZGF0YTxhbnk+fVxuICogQGNvbnN0IERlZmF1bHRNZXRhZGF0YVxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0aW9uXG4gKi9cbmV4cG9ydCBjb25zdCBEZWZhdWx0TWV0YWRhdGE6IEJhc2ljTWV0YWRhdGE8YW55PiA9IHtcbiAgW0RlY29yYXRpb25LZXlzLlBST1BFUlRJRVNdOiBbXSxcbn0gYXMgdW5rbm93biBhcyBCYXNpY01ldGFkYXRhPGFueT47XG4iXX0=
|
|
@@ -9,10 +9,7 @@ export interface DecorationBuilderBuild {
|
|
|
9
9
|
/**
|
|
10
10
|
* @description Creates and returns the decorator function.
|
|
11
11
|
* @summary Finalises the builder process and returns a decorator function that can be applied to a class, property, or method.
|
|
12
|
-
* @
|
|
13
|
-
* @param {any} [propertyKey] Property key when decorating a class member.
|
|
14
|
-
* @param {TypedPropertyDescriptor<any>} [descriptor] Descriptor supplied for method or accessor decoration.
|
|
15
|
-
* @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that can be applied to a target.
|
|
12
|
+
* @return {function(any, any, TypedPropertyDescriptor<any>):ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that can be applied to a target.
|
|
16
13
|
*/
|
|
17
14
|
apply(): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
|
18
15
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZGVjb3JhdGlvbi90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVjb3JhdG9yRGF0YSB9IGZyb20gXCIuL0RlY29yYXRpb25cIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gSW50ZXJmYWNlIGZvciB0aGUgZmluYWwgc3RhZ2Ugb2YgdGhlIGRlY29yYXRpb24gYnVpbGRlciBwYXR0ZXJuLlxuICogQHN1bW1hcnkgUmVwcmVzZW50cyB0aGUgYnVpbGQgc3RhZ2Ugb2YgdGhlIGRlY29yYXRpb24gYnVpbGRlciwgcHJvdmlkaW5nIHRoZSBhYmlsaXR5IHRvIGFwcGx5IHRoZSBjb25maWd1cmVkIGRlY29yYXRvciB0byBhIHRhcmdldC4gVGhpcyBpcyB0aGUgZmluYWwgc3RhZ2UgaW4gdGhlIGJ1aWxkZXIgY2hhaW4uXG4gKiBAaW50ZXJmYWNlIERlY29yYXRpb25CdWlsZGVyQnVpbGRcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIERlY29yYXRpb25CdWlsZGVyQnVpbGQge1xuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIENyZWF0ZXMgYW5kIHJldHVybnMgdGhlIGRlY29yYXRvciBmdW5jdGlvbi5cbiAgICogQHN1bW1hcnkgRmluYWxpc2VzIHRoZSBidWlsZGVyIHByb2Nlc3MgYW5kIHJldHVybnMgYSBkZWNvcmF0b3IgZnVuY3Rpb24gdGhhdCBjYW4gYmUgYXBwbGllZCB0byBhIGNsYXNzLCBwcm9wZXJ0eSwgb3IgbWV0aG9kLlxuICAgKiBAcmV0dXJuIHtmdW5jdGlvbihhbnksIGFueSwgVHlwZWRQcm9wZXJ0eURlc2NyaXB0b3I8YW55Pik6Q2xhc3NEZWNvcmF0b3J8TWV0aG9kRGVjb3JhdG9yfFByb3BlcnR5RGVjb3JhdG9yfFBhcmFtZXRlckRlY29yYXRvcn0gRGVjb3JhdG9yIGZ1bmN0aW9uIHRoYXQgY2FuIGJlIGFwcGxpZWQgdG8gYSB0YXJnZXQuXG4gICAqL1xuICBhcHBseSgpOiAoXG4gICAgdGFyZ2V0OiBhbnksXG4gICAgcHJvcGVydHlLZXk/OiBhbnksXG4gICAgZGVzY3JpcHRvcj86IFR5cGVkUHJvcGVydHlEZXNjcmlwdG9yPGFueT5cbiAgKSA9PiBhbnk7XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEludGVyZmFjZSBmb3IgdGhlIGV4dGVuc2lvbiBzdGFnZSBvZiB0aGUgZGVjb3JhdGlvbiBidWlsZGVyIHBhdHRlcm4uXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIHRoZSBleHRlbnNpb24gc3RhZ2Ugb2YgdGhlIGRlY29yYXRpb24gYnVpbGRlciwgcHJvdmlkaW5nIHRoZSBhYmlsaXR5IHRvIGFkZCBhZGRpdGlvbmFsIGRlY29yYXRvcnMgdG8gdGhlIGV4aXN0aW5nIGNvbmZpZ3VyYXRpb24uXG4gKiBAaW50ZXJmYWNlIERlY29yYXRpb25CdWlsZGVyRW5kXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEZWNvcmF0aW9uQnVpbGRlckVuZCB7XG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gQWRkcyBhZGRpdGlvbmFsIGRlY29yYXRvcnMgdG8gdGhlIGV4aXN0aW5nIGNvbmZpZ3VyYXRpb24uXG4gICAqIEBzdW1tYXJ5IEV4dGVuZHMgdGhlIGN1cnJlbnQgZGVjb3JhdG9yIGNvbmZpZ3VyYXRpb24gd2l0aCBhZGRpdGlvbmFsIGRlY29yYXRvcnMsIG1ha2luZyBpdCB1c2VmdWwgZm9yIGF1Z21lbnRpbmcgcHJldmlvdXNseSBkZWZpbmVkIGJlaGF2aW91ci5cbiAgICogQHBhcmFtIHsuLi5EZWNvcmF0b3JEYXRhfSBkZWNvcmF0b3JzIEFkZGl0aW9uYWwgZGVjb3JhdG9ycyB0byBhZGQuXG4gICAqIEByZXR1cm4ge0RlY29yYXRpb25CdWlsZGVyQnVpbGR9IFRoZSBidWlsZCBzdGFnZSBvZiB0aGUgYnVpbGRlciBwYXR0ZXJuLlxuICAgKi9cbiAgZXh0ZW5kKC4uLmRlY29yYXRvcnM6IERlY29yYXRvckRhdGFbXSk6IERlY29yYXRpb25CdWlsZGVyQnVpbGQ7XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEludGVyZmFjZSBmb3IgdGhlIG1pZGRsZSBzdGFnZSBvZiB0aGUgZGVjb3JhdGlvbiBidWlsZGVyIHBhdHRlcm4uXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIHRoZSBtaWRkbGUgc3RhZ2Ugb2YgdGhlIGRlY29yYXRpb24gYnVpbGRlciwgZXh0ZW5kaW5nIHRoZSBlbmQgc3RhZ2UgYW5kIHByb3ZpZGluZyB0aGUgYWJpbGl0eSB0byBkZWZpbmUgdGhlIHByaW1hcnkgZGVjb3JhdG9ycyBmb3IgdGhlIGNvbmZpZ3VyYXRpb24uXG4gKiBAaW50ZXJmYWNlIERlY29yYXRpb25CdWlsZGVyTWlkXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEZWNvcmF0aW9uQnVpbGRlck1pZCBleHRlbmRzIERlY29yYXRpb25CdWlsZGVyRW5kIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBEZWZpbmVzIHRoZSBwcmltYXJ5IGRlY29yYXRvcnMgZm9yIHRoZSBjb25maWd1cmF0aW9uLlxuICAgKiBAc3VtbWFyeSBTZXRzIHRoZSBtYWluIGRlY29yYXRvcnMgZm9yIHRoZSBjdXJyZW50IGNvbnRleHQgYWZ0ZXIgc3BlY2lmeWluZyB0aGUga2V5IHdpdGggdGhlIGBmb3JgIG1ldGhvZC5cbiAgICogQHBhcmFtIHsuLi5EZWNvcmF0b3JEYXRhfSBkZWNvcmF0b3JzIERlY29yYXRvcnMgdG8gZGVmaW5lIGZvciB0aGUgY3VycmVudCBrZXkgYW5kIGZsYXZvdXIuXG4gICAqIEByZXR1cm4ge0RlY29yYXRpb25CdWlsZGVyRW5kfSBJbnRlcmZhY2UgcmVwcmVzZW50aW5nIHRoZSByZW1haW5pbmcgYnVpbGRlciBzdGFnZXMgKGFsc28gaW1wbGVtZW50cyBEZWNvcmF0aW9uQnVpbGRlckJ1aWxkKS5cbiAgICovXG4gIGRlZmluZShcbiAgICAuLi5kZWNvcmF0b3JzOiBEZWNvcmF0b3JEYXRhW11cbiAgKTogRGVjb3JhdGlvbkJ1aWxkZXJFbmQgJiBEZWNvcmF0aW9uQnVpbGRlckJ1aWxkO1xufVxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBJbnRlcmZhY2UgZm9yIHRoZSBzdGFydGluZyBzdGFnZSBvZiB0aGUgZGVjb3JhdGlvbiBidWlsZGVyIHBhdHRlcm4uXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIHRoZSBpbml0aWFsIHN0YWdlIG9mIHRoZSBkZWNvcmF0aW9uIGJ1aWxkZXIsIHByb3ZpZGluZyB0aGUgZW50cnkgcG9pbnQgZm9yIHRoZSBidWlsZGVyIHBhdHRlcm4gYnkgc3BlY2lmeWluZyB0aGUga2V5IGZvciB0aGUgZGVjb3JhdG9yLlxuICogQGludGVyZmFjZSBEZWNvcmF0aW9uQnVpbGRlclN0YXJ0XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEZWNvcmF0aW9uQnVpbGRlclN0YXJ0IHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBTcGVjaWZpZXMgdGhlIGtleSBmb3IgdGhlIGRlY29yYXRvci5cbiAgICogQHN1bW1hcnkgU2V0cyB0aGUgaWRlbnRpZmllciBmb3IgdGhlIGRlY29yYXRvciwgd2hpY2ggaXMgdXNlZCB0byByZWdpc3RlciBhbmQgcmV0cmlldmUgdGhlIGRlY29yYXRvciBpbiB0aGUgZGVjb3JhdGlvbiByZWdpc3RyeS5cbiAgICogQHBhcmFtIHtzdHJpbmd9IGlkIElkZW50aWZpZXIgZm9yIHRoZSBkZWNvcmF0b3IuXG4gICAqIEByZXR1cm4ge0RlY29yYXRpb25CdWlsZGVyTWlkfSBUaGUgbWlkZGxlIHN0YWdlIG9mIHRoZSBidWlsZGVyIHBhdHRlcm4uXG4gICAqL1xuICBmb3IoaWQ6IHN0cmluZyk6IERlY29yYXRpb25CdWlsZGVyTWlkO1xufVxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBDb21wcmVoZW5zaXZlIGludGVyZmFjZSBmb3IgdGhlIGNvbXBsZXRlIGRlY29yYXRpb24gYnVpbGRlciBwYXR0ZXJuLlxuICogQHN1bW1hcnkgVW5pZmllZCBpbnRlcmZhY2UgdGhhdCBjb21iaW5lcyBhbGwgc3RhZ2VzIG9mIHRoZSBkZWNvcmF0aW9uIGJ1aWxkZXIgcGF0dGVybiwgcHJvdmlkaW5nIGEgY29tcGxldGUgQVBJIGZvciBjcmVhdGluZywgY29uZmlndXJpbmcsIGFuZCBhcHBseWluZyBkZWNvcmF0b3JzLiBUaGlzIGludGVyZmFjZSBpcyBpbXBsZW1lbnRlZCBieSB0aGUgRGVjb3JhdGlvbiBjbGFzcy5cbiAqIEBpbnRlcmZhY2UgSURlY29yYXRpb25CdWlsZGVyXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJRGVjb3JhdGlvbkJ1aWxkZXJcbiAgZXh0ZW5kcyBEZWNvcmF0aW9uQnVpbGRlclN0YXJ0LFxuICAgIERlY29yYXRpb25CdWlsZGVyTWlkLFxuICAgIERlY29yYXRpb25CdWlsZGVyRW5kLFxuICAgIERlY29yYXRpb25CdWlsZGVyQnVpbGQge31cblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gVHlwZSBkZWZpbml0aW9uIGZvciBhIGZ1bmN0aW9uIHRoYXQgcmVzb2x2ZXMgdGhlIGZsYXZvdXIgZm9yIGEgdGFyZ2V0LlxuICogQHN1bW1hcnkgRGVmaW5lcyBhIGZ1bmN0aW9uIHR5cGUgdGhhdCBkZXRlcm1pbmVzIHRoZSBhcHByb3ByaWF0ZSBmbGF2b3VyIGZvciBhIGdpdmVuIHRhcmdldCBvYmplY3QsIGVuYWJsaW5nIGZsYXZvdXItYXdhcmUgZGVjb3JhdG9yIHNlbGVjdGlvbi5cbiAqIEBwYXJhbSB7b2JqZWN0fSB0YXJnZXQgVGFyZ2V0IG9iamVjdCB0byByZXNvbHZlIHRoZSBmbGF2b3VyIGZvci5cbiAqIEByZXR1cm4ge3N0cmluZ30gUmVzb2x2ZWQgZmxhdm91ciBpZGVudGlmaWVyLlxuICogQHR5cGVEZWYgRmxhdm91clJlc29sdmVyXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRpb25cbiAqL1xuZXhwb3J0IHR5cGUgRmxhdm91clJlc29sdmVyID0gKHRhcmdldDogb2JqZWN0KSA9PiBzdHJpbmc7XG4iXX0=
|
package/lib/esm/decorators.d.ts
CHANGED
|
@@ -99,7 +99,7 @@ export declare function propMetadata(key: string, value: any): (target: object,
|
|
|
99
99
|
* @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.
|
|
100
100
|
* @param {string} key Metadata key to set for the property.
|
|
101
101
|
* @param {any} value Metadata value to associate with the key.
|
|
102
|
-
* @return {
|
|
102
|
+
* @return {MethodDecorator} Decorator that sets the metadata and captures the method's signature metadata.
|
|
103
103
|
* @function methodMetadata
|
|
104
104
|
* @category Method Decorators
|
|
105
105
|
*/
|
package/lib/esm/decorators.js
CHANGED
|
@@ -146,7 +146,7 @@ export function propMetadata(key, value) {
|
|
|
146
146
|
* @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.
|
|
147
147
|
* @param {string} key Metadata key to set for the property.
|
|
148
148
|
* @param {any} value Metadata value to associate with the key.
|
|
149
|
-
* @return {
|
|
149
|
+
* @return {MethodDecorator} Decorator that sets the metadata and captures the method's signature metadata.
|
|
150
150
|
* @function methodMetadata
|
|
151
151
|
* @category Method Decorators
|
|
152
152
|
*/
|
|
@@ -169,4 +169,4 @@ export function description(desc) {
|
|
|
169
169
|
].join(Metadata.splitter), desc)(original, prop, descriptor);
|
|
170
170
|
};
|
|
171
171
|
}
|
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { Metadata } from \"./metadata/Metadata\";\nimport { DecorationKeys } from \"./constants\";\n\n/**\n * @description Assigns arbitrary metadata to a target using a string key.\n * @summary Decorator factory that stores a key/value pair in the central metadata store for the provided class or member.\n * @param {string} key Metadata key to associate with the target.\n * @param {any} value Metadata value to store under the given key.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator that writes the metadata when applied.\n * @function metadata\n * @category Decorators\n */\nexport function metadata(key: string, value: any) {\n  return function metadata(\n    model: any,\n\n    prop?: any,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    descriptor?: PropertyDescriptor | number\n  ) {\n    Metadata.set(prop ? model.constructor : model, key, value);\n  };\n}\n\n/**\n * @description Captures and stores a property's design type.\n * @summary Decorator factory that reads the reflected `design:type` for a property and registers it in the metadata store under the properties map.\n * @return {PropertyDecorator} Decorator that records the property's type metadata when applied.\n * @function prop\n * @category Property Decorators\n */\nexport function prop() {\n  return function prop(model: object, prop: any) {\n    const designType = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_TYPE,\n      model,\n      prop\n    );\n    return metadata(Metadata.key(DecorationKeys.PROPERTIES, prop), designType)(\n      model,\n      prop\n    );\n  };\n}\n\n/**\n * @description Captures a single parameter type for the decorated method.\n * @summary Decorator factory that ensures the method metadata is initialised and stores the reflected parameter constructor at the provided index.\n * @return {ParameterDecorator} Decorator that records the parameter type when applied.\n * @function param\n * @category Parameter Decorators\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant P as param()\n *   participant M as Metadata\n *   U->>P: param()(target, key, index)\n *   P->>U: method()(target, key, descriptor)\n *   P->>M: params(constructor, key)\n *   M-->>P: parameter constructors[]\n *   P->>M: set(methods.key.index, constructor)\n *   P-->>U: parameter recorded\n */\nexport function param() {\n  return function param(\n    model: object,\n    prop: string | symbol | undefined,\n    index: number\n  ) {\n    if (!prop)\n      throw new Error(`The @param decorator can only be applied to methods`);\n    method()(model, prop, Object.getOwnPropertyDescriptor(model, prop));\n    const paramTpes = Metadata.params(model.constructor as any, prop as string);\n    if (!paramTpes)\n      throw new Error(`Missing parameter types for ${String(prop)}`);\n    if (index >= paramTpes.length)\n      throw new Error(\n        `Parameter index ${index} out of range for ${String(prop)}`\n      );\n    metadata(\n      Metadata.key(DecorationKeys.METHODS, prop as string, index.toString()),\n      paramTpes[index]\n    )(model, prop);\n  };\n}\n\n/**\n * @description Extends a parameter decorator with additional metadata.\n * @summary Applies the default `param()` decorator and augments the stored metadata with an arbitrary key/value pair.\n * @param {string} key Metadata key to associate with the parameter.\n * @param {any} value Metadata value persisted under the given key.\n * @return {ParameterDecorator} Decorator that records both the parameter design type and additional metadata.\n * @function paramMetadata\n * @category Parameter Decorators\n */\nexport function paramMetadata(key: string, value: any) {\n  return function paramMetadata(target: any, prop: any, index: number) {\n    return apply(\n      param(),\n      metadata(Metadata.key(DecorationKeys.METHODS, prop, key), value)\n    )(target, prop, index);\n  };\n}\n\n/**\n * @description Records method design-time metadata.\n * @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.\n * @return {MethodDecorator} Decorator that persists the method's signature information into the metadata store when applied.\n * @function method\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant F as method()\n *   participant M as Metadata\n *   U->>F: method()(target, key, descriptor)\n *   F->>U: Reflect.getOwnMetadata(design:paramtypes)\n *   F->>U: Reflect.getOwnMetadata(design:returntype)\n *   F->>M: set(methods.key.design:paramtypes, params)\n *   F->>M: set(methods.key.design:returntype, returnType)\n *   F-->>U: decorated function\n * @category Method Decorators\n */\nexport function method() {\n  return function method(obj: any, prop?: any, descriptor?: any) {\n    const designParams = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_PARAMS,\n      obj,\n      prop\n    );\n    const designReturn = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_RETURN,\n      obj,\n      prop\n    );\n    return apply(\n      metadata(\n        Metadata.key(\n          DecorationKeys.METHODS,\n          prop,\n          DecorationKeys.DESIGN_PARAMS\n        ),\n        designParams\n      ),\n      metadata(\n        Metadata.key(\n          DecorationKeys.METHODS,\n          prop,\n          DecorationKeys.DESIGN_RETURN\n        ),\n        designReturn\n      )\n    )(obj, prop, descriptor);\n  };\n}\n\n/**\n * @description Decorator factory that applies multiple decorators to a single target.\n * @summary Creates a composite decorator that applies multiple decorators in sequence, correctly handling class, method, property, and parameter decorators.\n * @param {Array<ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator>} decorators Collection of decorators to apply.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that applies all provided decorators to the target.\n * @function apply\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant A as apply(...decorators)\n *   participant D as Decorator\n *   U->>A: get decorator(...decorators)\n *   A->>U: returns (target, key?, desc?) => void\n *   U->>A: invoke on target\n *   loop for each decorator\n *     A->>D: invoke appropriate decorator type\n *   end\n * @category Decorators\n */\nexport function apply(\n  ...decorators: Array<\n    ClassDecorator | MethodDecorator | PropertyDecorator | ParameterDecorator\n  >\n) {\n  return (\n    target: object,\n    propertyKey?: string | symbol | unknown,\n    descriptor?: PropertyDescriptor | number\n  ) => {\n    for (const decorator of decorators) {\n      if (target instanceof Function && !descriptor) {\n        (decorator as ClassDecorator)(target);\n        continue;\n      }\n      (decorator as MethodDecorator | PropertyDecorator)(\n        target,\n        propertyKey as string | symbol,\n        descriptor as TypedPropertyDescriptor<unknown>\n      );\n    }\n  };\n}\n\n/**\n * @description Creates a property metadata decorator.\n * @summary Convenience factory that combines `metadata(key, value)` and `prop()` to both set an arbitrary metadata key and record the property's design type.\n * @param {string} key Metadata key to set for the property.\n * @param {any} value Metadata value to associate with the key.\n * @return {PropertyDecorator} Decorator that sets the metadata and captures the property's type.\n * @function propMetadata\n * @category Property Decorators\n */\nexport function propMetadata(key: string, value: any) {\n  return apply(metadata(key, value), prop());\n}\n\n/**\n * @description Creates a method metadata decorator.\n * @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.\n * @param {string} key Metadata key to set for the property.\n * @param {any} value Metadata value to associate with the key.\n * @return {PropertyDecorator} Decorator that sets the metadata and captures the property's type.\n * @function methodMetadata\n * @category Method Decorators\n */\nexport function methodMetadata(key: string, value: any) {\n  return apply(metadata(key, value), method());\n}\n\n/**\n * @description Attaches a human-readable description to a class or member.\n * @summary Decorator factory that stores a textual description in the metadata store under the appropriate description key for a class or its property.\n * @param {string} desc Descriptive text to associate with the class or property.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator} Decorator that records the description when applied.\n * @function description\n * @category Decorators\n */\nexport function description(desc: string) {\n  return function description(original: any, prop?: any, descriptor?: any) {\n    return metadata(\n      [\n        DecorationKeys.DESCRIPTION,\n        prop ? prop.toString() : DecorationKeys.CLASS,\n      ].join(Metadata.splitter),\n      desc\n    )(original, prop, descriptor);\n  };\n}\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { Metadata } from \"./metadata/Metadata\";\nimport { DecorationKeys } from \"./constants\";\n\n/**\n * @description Assigns arbitrary metadata to a target using a string key.\n * @summary Decorator factory that stores a key/value pair in the central metadata store for the provided class or member.\n * @param {string} key Metadata key to associate with the target.\n * @param {any} value Metadata value to store under the given key.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator that writes the metadata when applied.\n * @function metadata\n * @category Decorators\n */\nexport function metadata(key: string, value: any) {\n  return function metadata(\n    model: any,\n\n    prop?: any,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    descriptor?: PropertyDescriptor | number\n  ) {\n    Metadata.set(prop ? model.constructor : model, key, value);\n  };\n}\n\n/**\n * @description Captures and stores a property's design type.\n * @summary Decorator factory that reads the reflected `design:type` for a property and registers it in the metadata store under the properties map.\n * @return {PropertyDecorator} Decorator that records the property's type metadata when applied.\n * @function prop\n * @category Property Decorators\n */\nexport function prop() {\n  return function prop(model: object, prop: any) {\n    const designType = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_TYPE,\n      model,\n      prop\n    );\n    return metadata(Metadata.key(DecorationKeys.PROPERTIES, prop), designType)(\n      model,\n      prop\n    );\n  };\n}\n\n/**\n * @description Captures a single parameter type for the decorated method.\n * @summary Decorator factory that ensures the method metadata is initialised and stores the reflected parameter constructor at the provided index.\n * @return {ParameterDecorator} Decorator that records the parameter type when applied.\n * @function param\n * @category Parameter Decorators\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant P as param()\n *   participant M as Metadata\n *   U->>P: param()(target, key, index)\n *   P->>U: method()(target, key, descriptor)\n *   P->>M: params(constructor, key)\n *   M-->>P: parameter constructors[]\n *   P->>M: set(methods.key.index, constructor)\n *   P-->>U: parameter recorded\n */\nexport function param() {\n  return function param(\n    model: object,\n    prop: string | symbol | undefined,\n    index: number\n  ) {\n    if (!prop)\n      throw new Error(`The @param decorator can only be applied to methods`);\n    method()(model, prop, Object.getOwnPropertyDescriptor(model, prop));\n    const paramTpes = Metadata.params(model.constructor as any, prop as string);\n    if (!paramTpes)\n      throw new Error(`Missing parameter types for ${String(prop)}`);\n    if (index >= paramTpes.length)\n      throw new Error(\n        `Parameter index ${index} out of range for ${String(prop)}`\n      );\n    metadata(\n      Metadata.key(DecorationKeys.METHODS, prop as string, index.toString()),\n      paramTpes[index]\n    )(model, prop);\n  };\n}\n\n/**\n * @description Extends a parameter decorator with additional metadata.\n * @summary Applies the default `param()` decorator and augments the stored metadata with an arbitrary key/value pair.\n * @param {string} key Metadata key to associate with the parameter.\n * @param {any} value Metadata value persisted under the given key.\n * @return {ParameterDecorator} Decorator that records both the parameter design type and additional metadata.\n * @function paramMetadata\n * @category Parameter Decorators\n */\nexport function paramMetadata(key: string, value: any) {\n  return function paramMetadata(target: any, prop: any, index: number) {\n    return apply(\n      param(),\n      metadata(Metadata.key(DecorationKeys.METHODS, prop, key), value)\n    )(target, prop, index);\n  };\n}\n\n/**\n * @description Records method design-time metadata.\n * @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.\n * @return {MethodDecorator} Decorator that persists the method's signature information into the metadata store when applied.\n * @function method\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant F as method()\n *   participant M as Metadata\n *   U->>F: method()(target, key, descriptor)\n *   F->>U: Reflect.getOwnMetadata(design:paramtypes)\n *   F->>U: Reflect.getOwnMetadata(design:returntype)\n *   F->>M: set(methods.key.design:paramtypes, params)\n *   F->>M: set(methods.key.design:returntype, returnType)\n *   F-->>U: decorated function\n * @category Method Decorators\n */\nexport function method() {\n  return function method(obj: any, prop?: any, descriptor?: any) {\n    const designParams = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_PARAMS,\n      obj,\n      prop\n    );\n    const designReturn = Reflect.getOwnMetadata(\n      DecorationKeys.DESIGN_RETURN,\n      obj,\n      prop\n    );\n    return apply(\n      metadata(\n        Metadata.key(\n          DecorationKeys.METHODS,\n          prop,\n          DecorationKeys.DESIGN_PARAMS\n        ),\n        designParams\n      ),\n      metadata(\n        Metadata.key(\n          DecorationKeys.METHODS,\n          prop,\n          DecorationKeys.DESIGN_RETURN\n        ),\n        designReturn\n      )\n    )(obj, prop, descriptor);\n  };\n}\n\n/**\n * @description Decorator factory that applies multiple decorators to a single target.\n * @summary Creates a composite decorator that applies multiple decorators in sequence, correctly handling class, method, property, and parameter decorators.\n * @param {Array<ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator>} decorators Collection of decorators to apply.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator|ParameterDecorator} Decorator function that applies all provided decorators to the target.\n * @function apply\n * @mermaid\n * sequenceDiagram\n *   participant U as User Code\n *   participant A as apply(...decorators)\n *   participant D as Decorator\n *   U->>A: get decorator(...decorators)\n *   A->>U: returns (target, key?, desc?) => void\n *   U->>A: invoke on target\n *   loop for each decorator\n *     A->>D: invoke appropriate decorator type\n *   end\n * @category Decorators\n */\nexport function apply(\n  ...decorators: Array<\n    ClassDecorator | MethodDecorator | PropertyDecorator | ParameterDecorator\n  >\n) {\n  return (\n    target: object,\n    propertyKey?: string | symbol | unknown,\n    descriptor?: PropertyDescriptor | number\n  ) => {\n    for (const decorator of decorators) {\n      if (target instanceof Function && !descriptor) {\n        (decorator as ClassDecorator)(target);\n        continue;\n      }\n      (decorator as MethodDecorator | PropertyDecorator)(\n        target,\n        propertyKey as string | symbol,\n        descriptor as TypedPropertyDescriptor<unknown>\n      );\n    }\n  };\n}\n\n/**\n * @description Creates a property metadata decorator.\n * @summary Convenience factory that combines `metadata(key, value)` and `prop()` to both set an arbitrary metadata key and record the property's design type.\n * @param {string} key Metadata key to set for the property.\n * @param {any} value Metadata value to associate with the key.\n * @return {PropertyDecorator} Decorator that sets the metadata and captures the property's type.\n * @function propMetadata\n * @category Property Decorators\n */\nexport function propMetadata(key: string, value: any) {\n  return apply(metadata(key, value), prop());\n}\n\n/**\n * @description Creates a method metadata decorator.\n * @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.\n * @param {string} key Metadata key to set for the property.\n * @param {any} value Metadata value to associate with the key.\n * @return {MethodDecorator} Decorator that sets the metadata and captures the method's signature metadata.\n * @function methodMetadata\n * @category Method Decorators\n */\nexport function methodMetadata(key: string, value: any) {\n  return apply(metadata(key, value), method());\n}\n\n/**\n * @description Attaches a human-readable description to a class or member.\n * @summary Decorator factory that stores a textual description in the metadata store under the appropriate description key for a class or its property.\n * @param {string} desc Descriptive text to associate with the class or property.\n * @return {ClassDecorator|MethodDecorator|PropertyDecorator} Decorator that records the description when applied.\n * @function description\n * @category Decorators\n */\nexport function description(desc: string) {\n  return function description(original: any, prop?: any, descriptor?: any) {\n    return metadata(\n      [\n        DecorationKeys.DESCRIPTION,\n        prop ? prop.toString() : DecorationKeys.CLASS,\n      ].join(Metadata.splitter),\n      desc\n    )(original, prop, descriptor);\n  };\n}\n"]}
|
package/lib/esm/index.d.ts
CHANGED
|
@@ -1,10 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @description Root entry point for the decoration
|
|
3
|
-
* @summary
|
|
4
|
-
* - Core builder: {@link Decoration}
|
|
5
|
-
* - Decorator utilities: {@link module:decoration|decorators in ./decorators}
|
|
6
|
-
* - Metadata utilities: {@link Metadata}
|
|
7
|
-
* - Constants and enums: {@link DecorationKeys}, {@link DefaultFlavour}
|
|
2
|
+
* @description Root entry point for the decoration package.
|
|
3
|
+
* @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.
|
|
8
4
|
* @module decoration
|
|
9
5
|
*/
|
|
10
6
|
export * from "./decoration";
|
|
@@ -12,9 +8,10 @@ export * from "./metadata";
|
|
|
12
8
|
export * from "./constants";
|
|
13
9
|
export * from "./decorators";
|
|
14
10
|
/**
|
|
15
|
-
* @description Current version of the
|
|
16
|
-
* @summary Stores the semantic version
|
|
11
|
+
* @description Current version of the decoration package.
|
|
12
|
+
* @summary Stores the semantic version string registered through {@link Metadata.registerLibrary}.
|
|
13
|
+
* @type {string}
|
|
17
14
|
* @const VERSION
|
|
18
15
|
* @memberOf module:decoration
|
|
19
16
|
*/
|
|
20
|
-
export declare const VERSION = "0.0.
|
|
17
|
+
export declare const VERSION = "0.0.17";
|
package/lib/esm/index.js
CHANGED
|
@@ -1,10 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @description Root entry point for the decoration
|
|
3
|
-
* @summary
|
|
4
|
-
* - Core builder: {@link Decoration}
|
|
5
|
-
* - Decorator utilities: {@link module:decoration|decorators in ./decorators}
|
|
6
|
-
* - Metadata utilities: {@link Metadata}
|
|
7
|
-
* - Constants and enums: {@link DecorationKeys}, {@link DefaultFlavour}
|
|
2
|
+
* @description Root entry point for the decoration package.
|
|
3
|
+
* @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.
|
|
8
4
|
* @module decoration
|
|
9
5
|
*/
|
|
10
6
|
import { Metadata } from "./metadata/index.js";
|
|
@@ -13,11 +9,12 @@ export * from "./metadata/index.js";
|
|
|
13
9
|
export * from "./constants.js";
|
|
14
10
|
export * from "./decorators.js";
|
|
15
11
|
/**
|
|
16
|
-
* @description Current version of the
|
|
17
|
-
* @summary Stores the semantic version
|
|
12
|
+
* @description Current version of the decoration package.
|
|
13
|
+
* @summary Stores the semantic version string registered through {@link Metadata.registerLibrary}.
|
|
14
|
+
* @type {string}
|
|
18
15
|
* @const VERSION
|
|
19
16
|
* @memberOf module:decoration
|
|
20
17
|
*/
|
|
21
|
-
export const VERSION = "0.0.
|
|
18
|
+
export const VERSION = "0.0.17";
|
|
22
19
|
Metadata.registerLibrary("@decaf-ts/decoration", VERSION);
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUVILE9BQU8sRUFBRSxRQUFRLEVBQUUsNEJBQXlCO0FBRTVDLHNDQUE2QjtBQUM3QixvQ0FBMkI7QUFDM0IsK0JBQTRCO0FBQzVCLGdDQUE2QjtBQUU3Qjs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsYUFBYSxDQUFDO0FBRXJDLFFBQVEsQ0FBQyxlQUFlLENBQUMsc0JBQXNCLEVBQUUsT0FBTyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBSb290IGVudHJ5IHBvaW50IGZvciB0aGUgZGVjb3JhdGlvbiBwYWNrYWdlLlxuICogQHN1bW1hcnkgUmUtZXhwb3J0cyB0aGUgYnVpbGRlciBBUEksIGRlY29yYXRvciBoZWxwZXJzLCBtZXRhZGF0YSB1dGlsaXRpZXMsIGFuZCBzaGFyZWQgY29uc3RhbnRzIHNvIGNvbnN1bWVycyBjYW4gaW1wb3J0IHtAbGluayBEZWNvcmF0aW9ufSwge0BsaW5rIE1ldGFkYXRhfSwge0BsaW5rIERlY29yYXRpb25LZXlzfSwgYW5kIHtAbGluayBEZWZhdWx0Rmxhdm91cn0gZnJvbSBhIHNpbmdsZSBzdXJmYWNlLlxuICogQG1vZHVsZSBkZWNvcmF0aW9uXG4gKi9cblxuaW1wb3J0IHsgTWV0YWRhdGEgfSBmcm9tIFwiLi9tZXRhZGF0YS9pbmRleFwiO1xuXG5leHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tZXRhZGF0YVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEN1cnJlbnQgdmVyc2lvbiBvZiB0aGUgZGVjb3JhdGlvbiBwYWNrYWdlLlxuICogQHN1bW1hcnkgU3RvcmVzIHRoZSBzZW1hbnRpYyB2ZXJzaW9uIHN0cmluZyByZWdpc3RlcmVkIHRocm91Z2gge0BsaW5rIE1ldGFkYXRhLnJlZ2lzdGVyTGlicmFyeX0uXG4gKiBAdHlwZSB7c3RyaW5nfVxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdGlvblxuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcblxuTWV0YWRhdGEucmVnaXN0ZXJMaWJyYXJ5KFwiQGRlY2FmLXRzL2RlY29yYXRpb25cIiwgVkVSU0lPTik7XG4iXX0=
|
|
@@ -191,6 +191,42 @@ export declare class Metadata {
|
|
|
191
191
|
* @return {any} Stored metadata object or value for the provided key, or `undefined` when absent.
|
|
192
192
|
*/
|
|
193
193
|
private static innerGet;
|
|
194
|
+
/**
|
|
195
|
+
* @description Builds the inheritance chain for a constructor, ordered from base to most-specific class.
|
|
196
|
+
* @summary Walks the prototype chain starting from the provided constructor until reaching Function/Object and returns the collected constructors.
|
|
197
|
+
* @param {Constructor} model Constructor whose chain should be collected.
|
|
198
|
+
* @return {Constructor[]} Array of constructors ordered from base to leaf.
|
|
199
|
+
*/
|
|
200
|
+
private static collectConstructorChain;
|
|
201
|
+
/**
|
|
202
|
+
* @description Merges metadata values collected across the inheritance chain.
|
|
203
|
+
* @summary Performs a deep merge for plain objects while letting non-object values override earlier ones to preserve child metadata precedence.
|
|
204
|
+
* @param {any[]} values Metadata values gathered from base to child.
|
|
205
|
+
* @return {any} Aggregated metadata value respecting inheritance precedence.
|
|
206
|
+
*/
|
|
207
|
+
private static mergeMetadataChain;
|
|
208
|
+
/**
|
|
209
|
+
* @description Produces a deep clone of a metadata value when necessary.
|
|
210
|
+
* @summary Arrays are shallow-cloned, plain objects are deep-cloned, and primitive/function values are returned as-is.
|
|
211
|
+
* @param {any} value Metadata value to clone.
|
|
212
|
+
* @return {any} Cloned metadata value preventing mutation of the backing store.
|
|
213
|
+
*/
|
|
214
|
+
private static cloneMetadataValue;
|
|
215
|
+
/**
|
|
216
|
+
* @description Deeply merges two plain metadata objects.
|
|
217
|
+
* @summary Recursively merges nested plain objects while cloning arrays; values from `source` override those from `target` when conflicts occur.
|
|
218
|
+
* @param {Record<string, any>} target Base object to merge into.
|
|
219
|
+
* @param {Record<string, any>} source Object providing overriding metadata.
|
|
220
|
+
* @return {Record<string, any>} Newly merged metadata object.
|
|
221
|
+
*/
|
|
222
|
+
private static mergePlainObjects;
|
|
223
|
+
/**
|
|
224
|
+
* @description Checks if a value is a plain object suitable for deep merging.
|
|
225
|
+
* @summary Ensures arrays and null are excluded while accepting objects created via literal/class syntax.
|
|
226
|
+
* @param {any} value Value to inspect.
|
|
227
|
+
* @return {boolean} True when the value is a plain object.
|
|
228
|
+
*/
|
|
229
|
+
private static isPlainObject;
|
|
194
230
|
/**
|
|
195
231
|
* @description Writes metadata under a symbol key.
|
|
196
232
|
* @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.
|