@decaf-ts/ui-decorators 0.5.9 → 0.5.11
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/LICENSE.md +21 -157
- package/README.md +422 -12
- package/dist/ui-decorators.cjs +609 -55
- package/dist/ui-decorators.esm.cjs +607 -56
- package/lib/esm/index.d.ts +7 -3
- package/lib/esm/index.js +8 -4
- package/lib/esm/model/Renderable.d.ts +15 -0
- package/lib/esm/model/Renderable.js +1 -1
- package/lib/esm/model/decorators.d.ts +93 -14
- package/lib/esm/model/decorators.js +102 -16
- package/lib/esm/model/index.d.ts +0 -4
- package/lib/esm/model/index.js +1 -5
- package/lib/esm/model/model.d.ts +156 -50
- package/lib/esm/model/model.js +1 -1
- package/lib/esm/model/overrides.d.ts +8 -0
- package/lib/esm/model/overrides.js +19 -1
- package/lib/esm/ui/Rendering.js +43 -8
- package/lib/esm/ui/constants.d.ts +149 -4
- package/lib/esm/ui/constants.js +150 -5
- package/lib/esm/ui/decorators.d.ts +229 -21
- package/lib/esm/ui/decorators.js +242 -25
- package/lib/esm/ui/errors.d.ts +28 -0
- package/lib/esm/ui/errors.js +29 -1
- package/lib/esm/ui/handlers.d.ts +17 -0
- package/lib/esm/ui/handlers.js +18 -0
- package/lib/esm/ui/index.d.ts +1 -4
- package/lib/esm/ui/index.js +2 -5
- package/lib/esm/ui/interfaces.d.ts +25 -0
- package/lib/esm/ui/interfaces.js +9 -1
- package/lib/esm/ui/types.d.ts +63 -5
- package/lib/esm/ui/types.js +9 -1
- package/lib/esm/ui/utils.d.ts +1 -1
- package/lib/esm/ui/utils.js +2 -2
- package/lib/index.cjs +8 -4
- package/lib/index.d.ts +7 -3
- package/lib/model/Renderable.cjs +1 -1
- package/lib/model/Renderable.d.ts +15 -0
- package/lib/model/decorators.cjs +103 -16
- package/lib/model/decorators.d.ts +93 -14
- package/lib/model/index.cjs +1 -5
- package/lib/model/index.d.ts +0 -4
- package/lib/model/model.cjs +1 -1
- package/lib/model/model.d.ts +156 -50
- package/lib/model/overrides.cjs +19 -1
- package/lib/model/overrides.d.ts +8 -0
- package/lib/ui/Rendering.cjs +43 -8
- package/lib/ui/constants.cjs +150 -5
- package/lib/ui/constants.d.ts +149 -4
- package/lib/ui/decorators.cjs +243 -25
- package/lib/ui/decorators.d.ts +229 -21
- package/lib/ui/errors.cjs +29 -1
- package/lib/ui/errors.d.ts +28 -0
- package/lib/ui/handlers.cjs +22 -0
- package/lib/ui/handlers.d.ts +17 -0
- package/lib/ui/index.cjs +2 -5
- package/lib/ui/index.d.ts +1 -4
- package/lib/ui/interfaces.cjs +9 -1
- package/lib/ui/interfaces.d.ts +25 -0
- package/lib/ui/types.cjs +9 -1
- package/lib/ui/types.d.ts +63 -5
- package/lib/ui/utils.cjs +2 -2
- package/lib/ui/utils.d.ts +1 -1
- package/package.json +2 -2
package/lib/esm/index.d.ts
CHANGED
|
@@ -1,12 +1,16 @@
|
|
|
1
1
|
/**
|
|
2
|
+
* @description UI decorators module for TypeScript applications
|
|
3
|
+
* @summary A collection of decorators and utilities for building UI components in TypeScript applications.
|
|
4
|
+
* This module exports functionality from both the model and UI submodules, providing decorators for
|
|
5
|
+
* rendering, component definition, and UI state management.
|
|
2
6
|
* @module ui-decorators
|
|
3
7
|
*/
|
|
4
8
|
export * from "./model";
|
|
5
9
|
export * from "./ui";
|
|
6
10
|
/**
|
|
7
|
-
* @
|
|
8
|
-
* @
|
|
11
|
+
* @description Current package version string
|
|
12
|
+
* @summary Stores the current package version for reference
|
|
9
13
|
* @const VERSION
|
|
10
14
|
* @memberOf module:ui-decorators
|
|
11
15
|
*/
|
|
12
|
-
export declare const VERSION = "0.5.
|
|
16
|
+
export declare const VERSION = "0.5.11";
|
package/lib/esm/index.js
CHANGED
|
@@ -1,13 +1,17 @@
|
|
|
1
1
|
/**
|
|
2
|
+
* @description UI decorators module for TypeScript applications
|
|
3
|
+
* @summary A collection of decorators and utilities for building UI components in TypeScript applications.
|
|
4
|
+
* This module exports functionality from both the model and UI submodules, providing decorators for
|
|
5
|
+
* rendering, component definition, and UI state management.
|
|
2
6
|
* @module ui-decorators
|
|
3
7
|
*/
|
|
4
8
|
export * from "./model";
|
|
5
9
|
export * from "./ui";
|
|
6
10
|
/**
|
|
7
|
-
* @
|
|
8
|
-
* @
|
|
11
|
+
* @description Current package version string
|
|
12
|
+
* @summary Stores the current package version for reference
|
|
9
13
|
* @const VERSION
|
|
10
14
|
* @memberOf module:ui-decorators
|
|
11
15
|
*/
|
|
12
|
-
export const VERSION = "0.5.
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
export const VERSION = "0.5.11";
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxNQUFNLENBQUM7QUFFckI7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAZGVzY3JpcHRpb24gVUkgZGVjb3JhdG9ycyBtb2R1bGUgZm9yIFR5cGVTY3JpcHQgYXBwbGljYXRpb25zXG4gKiBAc3VtbWFyeSBBIGNvbGxlY3Rpb24gb2YgZGVjb3JhdG9ycyBhbmQgdXRpbGl0aWVzIGZvciBidWlsZGluZyBVSSBjb21wb25lbnRzIGluIFR5cGVTY3JpcHQgYXBwbGljYXRpb25zLlxuICogVGhpcyBtb2R1bGUgZXhwb3J0cyBmdW5jdGlvbmFsaXR5IGZyb20gYm90aCB0aGUgbW9kZWwgYW5kIFVJIHN1Ym1vZHVsZXMsIHByb3ZpZGluZyBkZWNvcmF0b3JzIGZvclxuICogcmVuZGVyaW5nLCBjb21wb25lbnQgZGVmaW5pdGlvbiwgYW5kIFVJIHN0YXRlIG1hbmFnZW1lbnQuXG4gKiBAbW9kdWxlIHVpLWRlY29yYXRvcnNcbiAqL1xuXG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdWlcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gQ3VycmVudCBwYWNrYWdlIHZlcnNpb24gc3RyaW5nXG4gKiBAc3VtbWFyeSBTdG9yZXMgdGhlIGN1cnJlbnQgcGFja2FnZSB2ZXJzaW9uIGZvciByZWZlcmVuY2VcbiAqIEBjb25zdCBWRVJTSU9OXG4gKiBAbWVtYmVyT2YgbW9kdWxlOnVpLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
|
|
@@ -1,3 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description Interface for objects that can be rendered
|
|
3
|
+
* @summary Defines the contract for objects that can be rendered to a specific output format
|
|
4
|
+
* This interface provides a generic render method that can transform the implementing object
|
|
5
|
+
* into any desired output format.
|
|
6
|
+
* @interface Renderable
|
|
7
|
+
* @memberOf module:ui-decorators/model
|
|
8
|
+
*/
|
|
1
9
|
export interface Renderable {
|
|
10
|
+
/**
|
|
11
|
+
* @description Renders the object to a specific output format
|
|
12
|
+
* @summary Transforms the object into the desired output representation
|
|
13
|
+
* @template R The return type of the render operation
|
|
14
|
+
* @param {any[]} args Additional arguments needed for rendering
|
|
15
|
+
* @return {R} The rendered output in the specified format
|
|
16
|
+
*/
|
|
2
17
|
render<R>(...args: any[]): R;
|
|
3
18
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVuZGVyYWJsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2RlbC9SZW5kZXJhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBJbnRlcmZhY2UgZm9yIG9iamVjdHMgdGhhdCBjYW4gYmUgcmVuZGVyZWRcbiAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIGNvbnRyYWN0IGZvciBvYmplY3RzIHRoYXQgY2FuIGJlIHJlbmRlcmVkIHRvIGEgc3BlY2lmaWMgb3V0cHV0IGZvcm1hdFxuICogVGhpcyBpbnRlcmZhY2UgcHJvdmlkZXMgYSBnZW5lcmljIHJlbmRlciBtZXRob2QgdGhhdCBjYW4gdHJhbnNmb3JtIHRoZSBpbXBsZW1lbnRpbmcgb2JqZWN0XG4gKiBpbnRvIGFueSBkZXNpcmVkIG91dHB1dCBmb3JtYXQuXG4gKiBAaW50ZXJmYWNlIFJlbmRlcmFibGVcbiAqIEBtZW1iZXJPZiBtb2R1bGU6dWktZGVjb3JhdG9ycy9tb2RlbFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlbmRlcmFibGUge1xuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIFJlbmRlcnMgdGhlIG9iamVjdCB0byBhIHNwZWNpZmljIG91dHB1dCBmb3JtYXRcbiAgICogQHN1bW1hcnkgVHJhbnNmb3JtcyB0aGUgb2JqZWN0IGludG8gdGhlIGRlc2lyZWQgb3V0cHV0IHJlcHJlc2VudGF0aW9uXG4gICAqIEB0ZW1wbGF0ZSBSIFRoZSByZXR1cm4gdHlwZSBvZiB0aGUgcmVuZGVyIG9wZXJhdGlvblxuICAgKiBAcGFyYW0ge2FueVtdfSBhcmdzIEFkZGl0aW9uYWwgYXJndW1lbnRzIG5lZWRlZCBmb3IgcmVuZGVyaW5nXG4gICAqIEByZXR1cm4ge1J9IFRoZSByZW5kZXJlZCBvdXRwdXQgaW4gdGhlIHNwZWNpZmllZCBmb3JtYXRcbiAgICovXG4gIHJlbmRlcjxSPiguLi5hcmdzOiBhbnlbXSk6IFI7XG59XG4iXX0=
|
|
@@ -1,11 +1,33 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* @description Decorator that tags a class as a UI model
|
|
3
|
+
* @summary Adds rendering capabilities to a model class by providing a render method
|
|
4
|
+
* This decorator applies metadata to the class that enables it to be rendered by the UI rendering engine.
|
|
5
|
+
* The model will be rendered with the specified tag and properties.
|
|
3
6
|
*
|
|
4
|
-
* @param {string} [tag]
|
|
5
|
-
* @param {
|
|
6
|
-
* @
|
|
7
|
+
* @param {string} [tag] The HTML tag to use when rendering this model (defaults to class name)
|
|
8
|
+
* @param {Record<string, any>} [props] Additional properties to pass to the rendered element
|
|
9
|
+
* @return {Function} A class decorator function
|
|
7
10
|
*
|
|
8
|
-
* @
|
|
11
|
+
* @function uimodel
|
|
12
|
+
* @category Class Decorators
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* // Basic usage with default tag (class name)
|
|
16
|
+
* @uimodel()
|
|
17
|
+
* class UserProfile extends Model {
|
|
18
|
+
* @attribute()
|
|
19
|
+
* name: string;
|
|
20
|
+
*
|
|
21
|
+
* @attribute()
|
|
22
|
+
* email: string;
|
|
23
|
+
* }
|
|
24
|
+
*
|
|
25
|
+
* // Usage with custom tag and properties
|
|
26
|
+
* @uimodel('div', { class: 'user-card' })
|
|
27
|
+
* class UserCard extends Model {
|
|
28
|
+
* @attribute()
|
|
29
|
+
* username: string;
|
|
30
|
+
* }
|
|
9
31
|
*
|
|
10
32
|
* @mermaid
|
|
11
33
|
* sequenceDiagram
|
|
@@ -18,28 +40,85 @@
|
|
|
18
40
|
* constructor->>uimodel: returns instance
|
|
19
41
|
* uimodel->>instance: adds the render method
|
|
20
42
|
* uimodel->>System: returns UIModel instance
|
|
21
|
-
*
|
|
22
|
-
* @category Decorators
|
|
23
43
|
*/
|
|
24
44
|
export declare function uimodel(tag?: string, props?: Record<string, any>): (original: any, propertyKey?: any) => void;
|
|
45
|
+
/**
|
|
46
|
+
* @description Decorator that specifies which rendering engine to use for a model
|
|
47
|
+
* @summary Associates a model with a specific rendering engine implementation
|
|
48
|
+
* This decorator allows you to override the default rendering engine for a specific model class,
|
|
49
|
+
* enabling different rendering strategies for different models.
|
|
50
|
+
*
|
|
51
|
+
* @param {string} engine The name of the rendering engine to use
|
|
52
|
+
* @return {Function} A class decorator function
|
|
53
|
+
*
|
|
54
|
+
* @function renderedBy
|
|
55
|
+
* @category Class Decorators
|
|
56
|
+
*
|
|
57
|
+
* @example
|
|
58
|
+
* // Specify a custom rendering engine for a model
|
|
59
|
+
* @uimodel()
|
|
60
|
+
* @renderedBy('react')
|
|
61
|
+
* class ReactComponent extends Model {
|
|
62
|
+
* @attribute()
|
|
63
|
+
* title: string;
|
|
64
|
+
* }
|
|
65
|
+
*
|
|
66
|
+
* @mermaid
|
|
67
|
+
* sequenceDiagram
|
|
68
|
+
* participant System
|
|
69
|
+
* participant renderedBy
|
|
70
|
+
* participant Model
|
|
71
|
+
* participant RenderingEngine
|
|
72
|
+
* System->>renderedBy: apply to Model
|
|
73
|
+
* renderedBy->>Model: adds engine metadata
|
|
74
|
+
* Model->>RenderingEngine: uses specified engine
|
|
75
|
+
* RenderingEngine->>System: renders with custom engine
|
|
76
|
+
*/
|
|
25
77
|
export declare function renderedBy(engine: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
26
78
|
/**
|
|
27
|
-
*
|
|
79
|
+
* @description Decorator that tags a model as a list item for UI rendering
|
|
80
|
+
* @summary Specifies how a model should be rendered when displayed in a list context
|
|
81
|
+
* This decorator applies metadata to the class that enables it to be rendered as a list item
|
|
82
|
+
* by the UI rendering engine. The model will be rendered with the specified tag and properties
|
|
83
|
+
* when it appears in a list.
|
|
28
84
|
*
|
|
29
|
-
* @param {string} [tag]
|
|
30
|
-
* @param {
|
|
85
|
+
* @param {string} [tag] The HTML tag to use when rendering this model as a list item (defaults to class name)
|
|
86
|
+
* @param {Record<string, any>} [props] Additional properties to pass to the rendered list item element
|
|
87
|
+
* @return {Function} A class decorator function
|
|
31
88
|
*
|
|
32
|
-
* @
|
|
89
|
+
* @function uilistitem
|
|
90
|
+
* @category Class Decorators
|
|
91
|
+
*
|
|
92
|
+
* @example
|
|
93
|
+
* // Basic usage with default tag (class name)
|
|
94
|
+
* @uimodel()
|
|
95
|
+
* @uilistitem()
|
|
96
|
+
* class TodoItem extends Model {
|
|
97
|
+
* @attribute()
|
|
98
|
+
* title: string;
|
|
99
|
+
*
|
|
100
|
+
* @attribute()
|
|
101
|
+
* completed: boolean;
|
|
102
|
+
* }
|
|
103
|
+
*
|
|
104
|
+
* // Usage with custom tag and properties
|
|
105
|
+
* @uimodel()
|
|
106
|
+
* @uilistitem('li', { class: 'list-group-item' })
|
|
107
|
+
* class ListItem extends Model {
|
|
108
|
+
* @attribute()
|
|
109
|
+
* text: string;
|
|
110
|
+
* }
|
|
33
111
|
*
|
|
34
112
|
* @mermaid
|
|
35
113
|
* sequenceDiagram
|
|
36
114
|
* participant System
|
|
37
115
|
* participant uilistitem
|
|
38
116
|
* participant Model
|
|
117
|
+
* participant RenderingEngine
|
|
39
118
|
* System->>uilistitem: apply to Model
|
|
40
119
|
* uilistitem->>Model: adds list item metadata
|
|
41
|
-
* Model->>
|
|
42
|
-
*
|
|
43
|
-
* @category Decorators
|
|
120
|
+
* Model->>RenderingEngine: uses list item metadata when in list context
|
|
121
|
+
* RenderingEngine->>System: renders with list item styling
|
|
44
122
|
*/
|
|
45
123
|
export declare function uilistitem(tag?: string, props?: Record<string, any>): (original: any, propertyKey?: any) => void;
|
|
124
|
+
export declare function uihandlers(props?: Record<string, any>): (original: any) => void;
|
|
@@ -2,13 +2,35 @@ import { UIKeys } from "../ui/constants";
|
|
|
2
2
|
import { apply, metadata } from "@decaf-ts/reflection";
|
|
3
3
|
import { RenderingEngine } from "../ui/Rendering";
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
5
|
+
* @description Decorator that tags a class as a UI model
|
|
6
|
+
* @summary Adds rendering capabilities to a model class by providing a render method
|
|
7
|
+
* This decorator applies metadata to the class that enables it to be rendered by the UI rendering engine.
|
|
8
|
+
* The model will be rendered with the specified tag and properties.
|
|
6
9
|
*
|
|
7
|
-
* @param {string} [tag]
|
|
8
|
-
* @param {
|
|
9
|
-
* @
|
|
10
|
+
* @param {string} [tag] The HTML tag to use when rendering this model (defaults to class name)
|
|
11
|
+
* @param {Record<string, any>} [props] Additional properties to pass to the rendered element
|
|
12
|
+
* @return {Function} A class decorator function
|
|
10
13
|
*
|
|
11
|
-
* @
|
|
14
|
+
* @function uimodel
|
|
15
|
+
* @category Class Decorators
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* // Basic usage with default tag (class name)
|
|
19
|
+
* @uimodel()
|
|
20
|
+
* class UserProfile extends Model {
|
|
21
|
+
* @attribute()
|
|
22
|
+
* name: string;
|
|
23
|
+
*
|
|
24
|
+
* @attribute()
|
|
25
|
+
* email: string;
|
|
26
|
+
* }
|
|
27
|
+
*
|
|
28
|
+
* // Usage with custom tag and properties
|
|
29
|
+
* @uimodel('div', { class: 'user-card' })
|
|
30
|
+
* class UserCard extends Model {
|
|
31
|
+
* @attribute()
|
|
32
|
+
* username: string;
|
|
33
|
+
* }
|
|
12
34
|
*
|
|
13
35
|
* @mermaid
|
|
14
36
|
* sequenceDiagram
|
|
@@ -21,8 +43,6 @@ import { RenderingEngine } from "../ui/Rendering";
|
|
|
21
43
|
* constructor->>uimodel: returns instance
|
|
22
44
|
* uimodel->>instance: adds the render method
|
|
23
45
|
* uimodel->>System: returns UIModel instance
|
|
24
|
-
*
|
|
25
|
-
* @category Decorators
|
|
26
46
|
*/
|
|
27
47
|
export function uimodel(tag, props) {
|
|
28
48
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
@@ -34,27 +54,85 @@ export function uimodel(tag, props) {
|
|
|
34
54
|
return metadata(RenderingEngine.key(UIKeys.UIMODEL), meta)(original);
|
|
35
55
|
};
|
|
36
56
|
}
|
|
57
|
+
/**
|
|
58
|
+
* @description Decorator that specifies which rendering engine to use for a model
|
|
59
|
+
* @summary Associates a model with a specific rendering engine implementation
|
|
60
|
+
* This decorator allows you to override the default rendering engine for a specific model class,
|
|
61
|
+
* enabling different rendering strategies for different models.
|
|
62
|
+
*
|
|
63
|
+
* @param {string} engine The name of the rendering engine to use
|
|
64
|
+
* @return {Function} A class decorator function
|
|
65
|
+
*
|
|
66
|
+
* @function renderedBy
|
|
67
|
+
* @category Class Decorators
|
|
68
|
+
*
|
|
69
|
+
* @example
|
|
70
|
+
* // Specify a custom rendering engine for a model
|
|
71
|
+
* @uimodel()
|
|
72
|
+
* @renderedBy('react')
|
|
73
|
+
* class ReactComponent extends Model {
|
|
74
|
+
* @attribute()
|
|
75
|
+
* title: string;
|
|
76
|
+
* }
|
|
77
|
+
*
|
|
78
|
+
* @mermaid
|
|
79
|
+
* sequenceDiagram
|
|
80
|
+
* participant System
|
|
81
|
+
* participant renderedBy
|
|
82
|
+
* participant Model
|
|
83
|
+
* participant RenderingEngine
|
|
84
|
+
* System->>renderedBy: apply to Model
|
|
85
|
+
* renderedBy->>Model: adds engine metadata
|
|
86
|
+
* Model->>RenderingEngine: uses specified engine
|
|
87
|
+
* RenderingEngine->>System: renders with custom engine
|
|
88
|
+
*/
|
|
37
89
|
export function renderedBy(engine) {
|
|
38
90
|
return apply(metadata(RenderingEngine.key(UIKeys.RENDERED_BY), engine));
|
|
39
91
|
}
|
|
40
92
|
/**
|
|
41
|
-
*
|
|
93
|
+
* @description Decorator that tags a model as a list item for UI rendering
|
|
94
|
+
* @summary Specifies how a model should be rendered when displayed in a list context
|
|
95
|
+
* This decorator applies metadata to the class that enables it to be rendered as a list item
|
|
96
|
+
* by the UI rendering engine. The model will be rendered with the specified tag and properties
|
|
97
|
+
* when it appears in a list.
|
|
98
|
+
*
|
|
99
|
+
* @param {string} [tag] The HTML tag to use when rendering this model as a list item (defaults to class name)
|
|
100
|
+
* @param {Record<string, any>} [props] Additional properties to pass to the rendered list item element
|
|
101
|
+
* @return {Function} A class decorator function
|
|
102
|
+
*
|
|
103
|
+
* @function uilistitem
|
|
104
|
+
* @category Class Decorators
|
|
105
|
+
*
|
|
106
|
+
* @example
|
|
107
|
+
* // Basic usage with default tag (class name)
|
|
108
|
+
* @uimodel()
|
|
109
|
+
* @uilistitem()
|
|
110
|
+
* class TodoItem extends Model {
|
|
111
|
+
* @attribute()
|
|
112
|
+
* title: string;
|
|
42
113
|
*
|
|
43
|
-
*
|
|
44
|
-
*
|
|
114
|
+
* @attribute()
|
|
115
|
+
* completed: boolean;
|
|
116
|
+
* }
|
|
45
117
|
*
|
|
46
|
-
*
|
|
118
|
+
* // Usage with custom tag and properties
|
|
119
|
+
* @uimodel()
|
|
120
|
+
* @uilistitem('li', { class: 'list-group-item' })
|
|
121
|
+
* class ListItem extends Model {
|
|
122
|
+
* @attribute()
|
|
123
|
+
* text: string;
|
|
124
|
+
* }
|
|
47
125
|
*
|
|
48
126
|
* @mermaid
|
|
49
127
|
* sequenceDiagram
|
|
50
128
|
* participant System
|
|
51
129
|
* participant uilistitem
|
|
52
130
|
* participant Model
|
|
131
|
+
* participant RenderingEngine
|
|
53
132
|
* System->>uilistitem: apply to Model
|
|
54
133
|
* uilistitem->>Model: adds list item metadata
|
|
55
|
-
* Model->>
|
|
56
|
-
*
|
|
57
|
-
* @category Decorators
|
|
134
|
+
* Model->>RenderingEngine: uses list item metadata when in list context
|
|
135
|
+
* RenderingEngine->>System: renders with list item styling
|
|
58
136
|
*/
|
|
59
137
|
export function uilistitem(tag, props) {
|
|
60
138
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
@@ -63,9 +141,17 @@ export function uilistitem(tag, props) {
|
|
|
63
141
|
item: {
|
|
64
142
|
tag: tag || original.name,
|
|
65
143
|
props: props,
|
|
66
|
-
}
|
|
144
|
+
},
|
|
67
145
|
};
|
|
68
146
|
return metadata(RenderingEngine.key(UIKeys.UILISTITEM), meta)(original);
|
|
69
147
|
};
|
|
70
148
|
}
|
|
71
|
-
|
|
149
|
+
export function uihandlers(props) {
|
|
150
|
+
return (original) => {
|
|
151
|
+
const meta = {
|
|
152
|
+
handlers: props
|
|
153
|
+
};
|
|
154
|
+
return metadata(RenderingEngine.key(UIKeys.HANDLERS), meta)(original);
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/model/decorators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAGlD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CG;AACH,MAAM,UAAU,OAAO,CAAC,GAAY,EAAE,KAA2B;IAC/D,6DAA6D;IAC7D,OAAO,CAAC,QAAa,EAAE,WAAiB,EAAE,EAAE;QAC1C,MAAM,IAAI,GAAoB;YAC5B,GAAG,EAAE,GAAG,IAAI,QAAQ,CAAC,IAAI;YACzB,KAAK,EAAE,KAAK;SACb,CAAC;QACF,OAAO,QAAQ,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC;IACvE,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AACH,MAAM,UAAU,UAAU,CAAC,MAAc;IACvC,OAAO,KAAK,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;AAC1E,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CG;AACH,MAAM,UAAU,UAAU,CAAC,GAAY,EAAE,KAA2B;IAClE,6DAA6D;IAC7D,OAAO,CAAC,QAAa,EAAE,WAAiB,EAAE,EAAE;QAC1C,MAAM,IAAI,GAA4B;YACpC,IAAI,EAAE;gBACJ,GAAG,EAAE,GAAG,IAAI,QAAQ,CAAC,IAAI;gBACzB,KAAK,EAAE,KAAK;aACb;SACF,CAAC;QACF,OAAO,QAAQ,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC;IAC1E,CAAC,CAAC;AACJ,CAAC;AAGD,MAAM,UAAU,UAAU,CAAC,KAA2B;IACpD,OAAO,CAAC,QAAa,EAAE,EAAE;QACvB,MAAM,IAAI,GAAG;YACX,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,OAAO,QAAQ,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC;IACxE,CAAC,CAAC;AACJ,CAAC","sourcesContent":["import { UIKeys } from \"../ui/constants\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { RenderingEngine } from \"../ui/Rendering\";\nimport { UIListItemModelMetadata, UIModelMetadata } from \"../ui/types\";\n\n/**\n * @description Decorator that tags a class as a UI model\n * @summary Adds rendering capabilities to a model class by providing a render method\n * This decorator applies metadata to the class that enables it to be rendered by the UI rendering engine.\n * The model will be rendered with the specified tag and properties.\n *\n * @param {string} [tag] The HTML tag to use when rendering this model (defaults to class name)\n * @param {Record<string, any>} [props] Additional properties to pass to the rendered element\n * @return {Function} A class decorator function\n *\n * @function uimodel\n * @category Class Decorators\n *\n * @example\n * // Basic usage with default tag (class name)\n * @uimodel()\n * class UserProfile extends Model {\n *   @attribute()\n *   name: string;\n *\n *   @attribute()\n *   email: string;\n * }\n *\n * // Usage with custom tag and properties\n * @uimodel('div', { class: 'user-card' })\n * class UserCard extends Model {\n *   @attribute()\n *   username: string;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant System\n *   participant uimodel\n *   participant constructor\n *   participant instance\n *   System->>uimodel:do(constructor)\n *   uimodel->>constructor: Executes the constructor\n *   constructor->>uimodel: returns instance\n *   uimodel->>instance: adds the render method\n *   uimodel->>System: returns UIModel instance\n */\nexport function uimodel(tag?: string, props?: Record<string, any>) {\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  return (original: any, propertyKey?: any) => {\n    const meta: UIModelMetadata = {\n      tag: tag || original.name,\n      props: props,\n    };\n    return metadata(RenderingEngine.key(UIKeys.UIMODEL), meta)(original);\n  };\n}\n\n/**\n * @description Decorator that specifies which rendering engine to use for a model\n * @summary Associates a model with a specific rendering engine implementation\n * This decorator allows you to override the default rendering engine for a specific model class,\n * enabling different rendering strategies for different models.\n *\n * @param {string} engine The name of the rendering engine to use\n * @return {Function} A class decorator function\n *\n * @function renderedBy\n * @category Class Decorators\n *\n * @example\n * // Specify a custom rendering engine for a model\n * @uimodel()\n * @renderedBy('react')\n * class ReactComponent extends Model {\n *   @attribute()\n *   title: string;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant System\n *   participant renderedBy\n *   participant Model\n *   participant RenderingEngine\n *   System->>renderedBy: apply to Model\n *   renderedBy->>Model: adds engine metadata\n *   Model->>RenderingEngine: uses specified engine\n *   RenderingEngine->>System: renders with custom engine\n */\nexport function renderedBy(engine: string) {\n  return apply(metadata(RenderingEngine.key(UIKeys.RENDERED_BY), engine));\n}\n\n/**\n * @description Decorator that tags a model as a list item for UI rendering\n * @summary Specifies how a model should be rendered when displayed in a list context\n * This decorator applies metadata to the class that enables it to be rendered as a list item\n * by the UI rendering engine. The model will be rendered with the specified tag and properties\n * when it appears in a list.\n *\n * @param {string} [tag] The HTML tag to use when rendering this model as a list item (defaults to class name)\n * @param {Record<string, any>} [props] Additional properties to pass to the rendered list item element\n * @return {Function} A class decorator function\n *\n * @function uilistitem\n * @category Class Decorators\n *\n * @example\n * // Basic usage with default tag (class name)\n * @uimodel()\n * @uilistitem()\n * class TodoItem extends Model {\n *   @attribute()\n *   title: string;\n *\n *   @attribute()\n *   completed: boolean;\n * }\n *\n * // Usage with custom tag and properties\n * @uimodel()\n * @uilistitem('li', { class: 'list-group-item' })\n * class ListItem extends Model {\n *   @attribute()\n *   text: string;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant System\n *   participant uilistitem\n *   participant Model\n *   participant RenderingEngine\n *   System->>uilistitem: apply to Model\n *   uilistitem->>Model: adds list item metadata\n *   Model->>RenderingEngine: uses list item metadata when in list context\n *   RenderingEngine->>System: renders with list item styling\n */\nexport function uilistitem(tag?: string, props?: Record<string, any>) {\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  return (original: any, propertyKey?: any) => {\n    const meta: UIListItemModelMetadata = {\n      item: {\n        tag: tag || original.name,\n        props: props,\n      },\n    };\n    return metadata(RenderingEngine.key(UIKeys.UILISTITEM), meta)(original);\n  };\n}\n\n\nexport function uihandlers(props?: Record<string, any>) {\n  return (original: any) => {\n    const meta = {\n      handlers: props\n    };\n    return metadata(RenderingEngine.key(UIKeys.HANDLERS), meta)(original);\n  };\n}"]}
|
package/lib/esm/model/index.d.ts
CHANGED
package/lib/esm/model/index.js
CHANGED
|
@@ -1,9 +1,5 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @namespace model
|
|
3
|
-
* @memberOf ui-decorators
|
|
4
|
-
*/
|
|
5
1
|
import "./model";
|
|
6
2
|
export * from "./decorators";
|
|
7
3
|
export * from "./overrides";
|
|
8
4
|
export * from "./Renderable";
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxTQUFTLENBQUM7QUFFakIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXCIuL21vZGVsXCI7XG5cbmV4cG9ydCAqIGZyb20gXCIuL2RlY29yYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL292ZXJyaWRlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vUmVuZGVyYWJsZVwiO1xuIl19
|