@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.
Files changed (63) hide show
  1. package/LICENSE.md +21 -157
  2. package/README.md +422 -12
  3. package/dist/ui-decorators.cjs +609 -55
  4. package/dist/ui-decorators.esm.cjs +607 -56
  5. package/lib/esm/index.d.ts +7 -3
  6. package/lib/esm/index.js +8 -4
  7. package/lib/esm/model/Renderable.d.ts +15 -0
  8. package/lib/esm/model/Renderable.js +1 -1
  9. package/lib/esm/model/decorators.d.ts +93 -14
  10. package/lib/esm/model/decorators.js +102 -16
  11. package/lib/esm/model/index.d.ts +0 -4
  12. package/lib/esm/model/index.js +1 -5
  13. package/lib/esm/model/model.d.ts +156 -50
  14. package/lib/esm/model/model.js +1 -1
  15. package/lib/esm/model/overrides.d.ts +8 -0
  16. package/lib/esm/model/overrides.js +19 -1
  17. package/lib/esm/ui/Rendering.js +43 -8
  18. package/lib/esm/ui/constants.d.ts +149 -4
  19. package/lib/esm/ui/constants.js +150 -5
  20. package/lib/esm/ui/decorators.d.ts +229 -21
  21. package/lib/esm/ui/decorators.js +242 -25
  22. package/lib/esm/ui/errors.d.ts +28 -0
  23. package/lib/esm/ui/errors.js +29 -1
  24. package/lib/esm/ui/handlers.d.ts +17 -0
  25. package/lib/esm/ui/handlers.js +18 -0
  26. package/lib/esm/ui/index.d.ts +1 -4
  27. package/lib/esm/ui/index.js +2 -5
  28. package/lib/esm/ui/interfaces.d.ts +25 -0
  29. package/lib/esm/ui/interfaces.js +9 -1
  30. package/lib/esm/ui/types.d.ts +63 -5
  31. package/lib/esm/ui/types.js +9 -1
  32. package/lib/esm/ui/utils.d.ts +1 -1
  33. package/lib/esm/ui/utils.js +2 -2
  34. package/lib/index.cjs +8 -4
  35. package/lib/index.d.ts +7 -3
  36. package/lib/model/Renderable.cjs +1 -1
  37. package/lib/model/Renderable.d.ts +15 -0
  38. package/lib/model/decorators.cjs +103 -16
  39. package/lib/model/decorators.d.ts +93 -14
  40. package/lib/model/index.cjs +1 -5
  41. package/lib/model/index.d.ts +0 -4
  42. package/lib/model/model.cjs +1 -1
  43. package/lib/model/model.d.ts +156 -50
  44. package/lib/model/overrides.cjs +19 -1
  45. package/lib/model/overrides.d.ts +8 -0
  46. package/lib/ui/Rendering.cjs +43 -8
  47. package/lib/ui/constants.cjs +150 -5
  48. package/lib/ui/constants.d.ts +149 -4
  49. package/lib/ui/decorators.cjs +243 -25
  50. package/lib/ui/decorators.d.ts +229 -21
  51. package/lib/ui/errors.cjs +29 -1
  52. package/lib/ui/errors.d.ts +28 -0
  53. package/lib/ui/handlers.cjs +22 -0
  54. package/lib/ui/handlers.d.ts +17 -0
  55. package/lib/ui/index.cjs +2 -5
  56. package/lib/ui/index.d.ts +1 -4
  57. package/lib/ui/interfaces.cjs +9 -1
  58. package/lib/ui/interfaces.d.ts +25 -0
  59. package/lib/ui/types.cjs +9 -1
  60. package/lib/ui/types.d.ts +63 -5
  61. package/lib/ui/utils.cjs +2 -2
  62. package/lib/ui/utils.d.ts +1 -1
  63. package/package.json +2 -2
@@ -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
- * @summary stores the current package version
8
- * @description this is how you should document a constant
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.9";
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
- * @summary stores the current package version
8
- * @description this is how you should document a constant
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.9";
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLE1BQU0sQ0FBQztBQUVyQjs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBtb2R1bGUgdWktZGVjb3JhdG9yc1xuICovXG5cbmV4cG9ydCAqIGZyb20gXCIuL21vZGVsXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91aVwiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IHN0b3JlcyB0aGUgY3VycmVudCBwYWNrYWdlIHZlcnNpb25cbiAqIEBkZXNjcmlwdGlvbiB0aGlzIGlzIGhvdyB5b3Ugc2hvdWxkIGRvY3VtZW50IGEgY29uc3RhbnRcbiAqIEBjb25zdCBWRVJTSU9OXG4gKiBAbWVtYmVyT2YgbW9kdWxlOnVpLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVuZGVyYWJsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2RlbC9SZW5kZXJhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFJlbmRlcmFibGUge1xuICByZW5kZXI8Uj4oLi4uYXJnczogYW55W10pOiBSO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVuZGVyYWJsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2RlbC9SZW5kZXJhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBJbnRlcmZhY2UgZm9yIG9iamVjdHMgdGhhdCBjYW4gYmUgcmVuZGVyZWRcbiAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIGNvbnRyYWN0IGZvciBvYmplY3RzIHRoYXQgY2FuIGJlIHJlbmRlcmVkIHRvIGEgc3BlY2lmaWMgb3V0cHV0IGZvcm1hdFxuICogVGhpcyBpbnRlcmZhY2UgcHJvdmlkZXMgYSBnZW5lcmljIHJlbmRlciBtZXRob2QgdGhhdCBjYW4gdHJhbnNmb3JtIHRoZSBpbXBsZW1lbnRpbmcgb2JqZWN0XG4gKiBpbnRvIGFueSBkZXNpcmVkIG91dHB1dCBmb3JtYXQuXG4gKiBAaW50ZXJmYWNlIFJlbmRlcmFibGVcbiAqIEBtZW1iZXJPZiBtb2R1bGU6dWktZGVjb3JhdG9ycy9tb2RlbFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlbmRlcmFibGUge1xuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIFJlbmRlcnMgdGhlIG9iamVjdCB0byBhIHNwZWNpZmljIG91dHB1dCBmb3JtYXRcbiAgICogQHN1bW1hcnkgVHJhbnNmb3JtcyB0aGUgb2JqZWN0IGludG8gdGhlIGRlc2lyZWQgb3V0cHV0IHJlcHJlc2VudGF0aW9uXG4gICAqIEB0ZW1wbGF0ZSBSIFRoZSByZXR1cm4gdHlwZSBvZiB0aGUgcmVuZGVyIG9wZXJhdGlvblxuICAgKiBAcGFyYW0ge2FueVtdfSBhcmdzIEFkZGl0aW9uYWwgYXJndW1lbnRzIG5lZWRlZCBmb3IgcmVuZGVyaW5nXG4gICAqIEByZXR1cm4ge1J9IFRoZSByZW5kZXJlZCBvdXRwdXQgaW4gdGhlIHNwZWNpZmllZCBmb3JtYXRcbiAgICovXG4gIHJlbmRlcjxSPiguLi5hcmdzOiBhbnlbXSk6IFI7XG59XG4iXX0=
@@ -1,11 +1,33 @@
1
1
  /**
2
- * Tags the model as a uimodel, giving it the 'render' method
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] optional param. will render the provided elment wrapping the attribute uielements
5
- * @param {{}} [props] optional param. Attributes to be passed to the tag element
6
- * @param {function(any): void} [instanceCallback] optional callback returning the instance after creation for additional logic
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
- * @decorator uimodel
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
- * Tags the model as a list item for UI rendering, specifying how it should be rendered in list contexts
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] optional param. will render the provided element as the list item container
30
- * @param {{}} [props] optional param. Attributes to be passed to the tag element
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
- * @decorator uilistitem
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->>System: returns Model with list item rendering capabilities
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
- * Tags the model as a uimodel, giving it the 'render' method
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] optional param. will render the provided elment wrapping the attribute uielements
8
- * @param {{}} [props] optional param. Attributes to be passed to the tag element
9
- * @param {function(any): void} [instanceCallback] optional callback returning the instance after creation for additional logic
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
- * @decorator uimodel
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
- * Tags the model as a list item for UI rendering, specifying how it should be rendered in list contexts
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
- * @param {string} [tag] optional param. will render the provided element as the list item container
44
- * @param {{}} [props] optional param. Attributes to be passed to the tag element
114
+ * @attribute()
115
+ * completed: boolean;
116
+ * }
45
117
  *
46
- * @decorator uilistitem
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->>System: returns Model with list item rendering capabilities
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2RlbC9kZWNvcmF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QyxPQUFPLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUdsRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXNCRztBQUNILE1BQU0sVUFBVSxPQUFPLENBQUMsR0FBWSxFQUFFLEtBQTJCO0lBQy9ELDZEQUE2RDtJQUM3RCxPQUFPLENBQUMsUUFBYSxFQUFFLFdBQWlCLEVBQUUsRUFBRTtRQUMxQyxNQUFNLElBQUksR0FBb0I7WUFDNUIsR0FBRyxFQUFFLEdBQUcsSUFBSSxRQUFRLENBQUMsSUFBSTtZQUN6QixLQUFLLEVBQUUsS0FBSztTQUNiLENBQUM7UUFDRixPQUFPLFFBQVEsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN2RSxDQUFDLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLFVBQVUsQ0FBQyxNQUFjO0lBQ3ZDLE9BQU8sS0FBSyxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO0FBQzFFLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0JHO0FBQ0gsTUFBTSxVQUFVLFVBQVUsQ0FBQyxHQUFZLEVBQUcsS0FBMkI7SUFDbkUsNkRBQTZEO0lBQzdELE9BQU8sQ0FBQyxRQUFhLEVBQUUsV0FBaUIsRUFBRSxFQUFFO1FBQzFDLE1BQU0sSUFBSSxHQUE0QjtZQUNwQyxJQUFJLEVBQUU7Z0JBQ0osR0FBRyxFQUFFLEdBQUcsSUFBSSxRQUFRLENBQUMsSUFBSTtnQkFDekIsS0FBSyxFQUFFLEtBQUs7YUFDYjtTQUVGLENBQUM7UUFDRixPQUFPLFFBQVEsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUMxRSxDQUFDLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVUlLZXlzIH0gZnJvbSBcIi4uL3VpL2NvbnN0YW50c1wiO1xuaW1wb3J0IHsgYXBwbHksIG1ldGFkYXRhIH0gZnJvbSBcIkBkZWNhZi10cy9yZWZsZWN0aW9uXCI7XG5pbXBvcnQgeyBSZW5kZXJpbmdFbmdpbmUgfSBmcm9tIFwiLi4vdWkvUmVuZGVyaW5nXCI7XG5pbXBvcnQgeyBVSUxpc3RJdGVtTW9kZWxNZXRhZGF0YSwgVUlNb2RlbE1ldGFkYXRhIH0gZnJvbSBcIi4uL3VpL3R5cGVzXCI7XG5cbi8qKlxuICogVGFncyB0aGUgbW9kZWwgYXMgYSB1aW1vZGVsLCBnaXZpbmcgaXQgdGhlICdyZW5kZXInIG1ldGhvZFxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBbdGFnXSBvcHRpb25hbCBwYXJhbS4gd2lsbCByZW5kZXIgdGhlIHByb3ZpZGVkIGVsbWVudCB3cmFwcGluZyB0aGUgYXR0cmlidXRlIHVpZWxlbWVudHNcbiAqIEBwYXJhbSB7e319IFtwcm9wc10gb3B0aW9uYWwgcGFyYW0uIEF0dHJpYnV0ZXMgdG8gYmUgcGFzc2VkIHRvIHRoZSB0YWcgZWxlbWVudFxuICogQHBhcmFtIHtmdW5jdGlvbihhbnkpOiB2b2lkfSBbaW5zdGFuY2VDYWxsYmFja10gb3B0aW9uYWwgY2FsbGJhY2sgcmV0dXJuaW5nIHRoZSBpbnN0YW5jZSBhZnRlciBjcmVhdGlvbiBmb3IgYWRkaXRpb25hbCBsb2dpY1xuICpcbiAqIEBkZWNvcmF0b3IgdWltb2RlbFxuICpcbiAqIEBtZXJtYWlkXG4gKiBzZXF1ZW5jZURpYWdyYW1cbiAqICAgcGFydGljaXBhbnQgU3lzdGVtXG4gKiAgIHBhcnRpY2lwYW50IHVpbW9kZWxcbiAqICAgcGFydGljaXBhbnQgY29uc3RydWN0b3JcbiAqICAgcGFydGljaXBhbnQgaW5zdGFuY2VcbiAqICAgU3lzdGVtLT4+dWltb2RlbDpkbyhjb25zdHJ1Y3RvcilcbiAqICAgdWltb2RlbC0+PmNvbnN0cnVjdG9yOiBFeGVjdXRlcyB0aGUgY29uc3RydWN0b3JcbiAqICAgY29uc3RydWN0b3ItPj51aW1vZGVsOiByZXR1cm5zIGluc3RhbmNlXG4gKiAgIHVpbW9kZWwtPj5pbnN0YW5jZTogYWRkcyB0aGUgcmVuZGVyIG1ldGhvZFxuICogICB1aW1vZGVsLT4+U3lzdGVtOiByZXR1cm5zIFVJTW9kZWwgaW5zdGFuY2VcbiAqXG4gKiBAY2F0ZWdvcnkgRGVjb3JhdG9yc1xuICovXG5leHBvcnQgZnVuY3Rpb24gdWltb2RlbCh0YWc/OiBzdHJpbmcsIHByb3BzPzogUmVjb3JkPHN0cmluZywgYW55Pikge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gIHJldHVybiAob3JpZ2luYWw6IGFueSwgcHJvcGVydHlLZXk/OiBhbnkpID0+IHtcbiAgICBjb25zdCBtZXRhOiBVSU1vZGVsTWV0YWRhdGEgPSB7XG4gICAgICB0YWc6IHRhZyB8fCBvcmlnaW5hbC5uYW1lLFxuICAgICAgcHJvcHM6IHByb3BzLFxuICAgIH07XG4gICAgcmV0dXJuIG1ldGFkYXRhKFJlbmRlcmluZ0VuZ2luZS5rZXkoVUlLZXlzLlVJTU9ERUwpLCBtZXRhKShvcmlnaW5hbCk7XG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJlZEJ5KGVuZ2luZTogc3RyaW5nKSB7XG4gIHJldHVybiBhcHBseShtZXRhZGF0YShSZW5kZXJpbmdFbmdpbmUua2V5KFVJS2V5cy5SRU5ERVJFRF9CWSksIGVuZ2luZSkpO1xufVxuXG4vKipcbiAqIFRhZ3MgdGhlIG1vZGVsIGFzIGEgbGlzdCBpdGVtIGZvciBVSSByZW5kZXJpbmcsIHNwZWNpZnlpbmcgaG93IGl0IHNob3VsZCBiZSByZW5kZXJlZCBpbiBsaXN0IGNvbnRleHRzXG4gKlxuICogQHBhcmFtIHtzdHJpbmd9IFt0YWddIG9wdGlvbmFsIHBhcmFtLiB3aWxsIHJlbmRlciB0aGUgcHJvdmlkZWQgZWxlbWVudCBhcyB0aGUgbGlzdCBpdGVtIGNvbnRhaW5lclxuICogQHBhcmFtIHt7fX0gW3Byb3BzXSBvcHRpb25hbCBwYXJhbS4gQXR0cmlidXRlcyB0byBiZSBwYXNzZWQgdG8gdGhlIHRhZyBlbGVtZW50XG4gKlxuICogQGRlY29yYXRvciB1aWxpc3RpdGVtXG4gKlxuICogQG1lcm1haWRcbiAqIHNlcXVlbmNlRGlhZ3JhbVxuICogICBwYXJ0aWNpcGFudCBTeXN0ZW1cbiAqICAgcGFydGljaXBhbnQgdWlsaXN0aXRlbVxuICogICBwYXJ0aWNpcGFudCBNb2RlbFxuICogICBTeXN0ZW0tPj51aWxpc3RpdGVtOiBhcHBseSB0byBNb2RlbFxuICogICB1aWxpc3RpdGVtLT4+TW9kZWw6IGFkZHMgbGlzdCBpdGVtIG1ldGFkYXRhXG4gKiAgIE1vZGVsLT4+U3lzdGVtOiByZXR1cm5zIE1vZGVsIHdpdGggbGlzdCBpdGVtIHJlbmRlcmluZyBjYXBhYmlsaXRpZXNcbiAqXG4gKiBAY2F0ZWdvcnkgRGVjb3JhdG9yc1xuICovXG5leHBvcnQgZnVuY3Rpb24gdWlsaXN0aXRlbSh0YWc/OiBzdHJpbmcsICBwcm9wcz86IFJlY29yZDxzdHJpbmcsIGFueT4pIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICByZXR1cm4gKG9yaWdpbmFsOiBhbnksIHByb3BlcnR5S2V5PzogYW55KSA9PiB7XG4gICAgY29uc3QgbWV0YTogVUlMaXN0SXRlbU1vZGVsTWV0YWRhdGEgPSB7IFxuICAgICAgaXRlbToge1xuICAgICAgICB0YWc6IHRhZyB8fCBvcmlnaW5hbC5uYW1lLFxuICAgICAgICBwcm9wczogcHJvcHMsXG4gICAgICB9IFxuICAgICAgXG4gICAgfTtcbiAgICByZXR1cm4gbWV0YWRhdGEoUmVuZGVyaW5nRW5naW5lLmtleShVSUtleXMuVUlMSVNUSVRFTSksIG1ldGEpKG9yaWdpbmFsKTtcbiAgfTtcbn0iXX0=
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}"]}
@@ -1,7 +1,3 @@
1
- /**
2
- * @namespace model
3
- * @memberOf ui-decorators
4
- */
5
1
  import "./model";
6
2
  export * from "./decorators";
7
3
  export * from "./overrides";
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBRUgsT0FBTyxTQUFTLENBQUM7QUFFakIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBuYW1lc3BhY2UgbW9kZWxcbiAqIEBtZW1iZXJPZiB1aS1kZWNvcmF0b3JzXG4gKi9cblxuaW1wb3J0IFwiLi9tb2RlbFwiO1xuXG5leHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9vdmVycmlkZXNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL1JlbmRlcmFibGVcIjtcbiJdfQ==
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxTQUFTLENBQUM7QUFFakIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXCIuL21vZGVsXCI7XG5cbmV4cG9ydCAqIGZyb20gXCIuL2RlY29yYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL292ZXJyaWRlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vUmVuZGVyYWJsZVwiO1xuIl19