@decaf-ts/ui-decorators 0.5.15 → 0.5.16

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.
@@ -13,4 +13,4 @@ export * from "./ui";
13
13
  * @const VERSION
14
14
  * @memberOf module:ui-decorators
15
15
  */
16
- export declare const VERSION = "0.5.15";
16
+ export declare const VERSION = "0.5.16";
package/lib/esm/index.js CHANGED
@@ -13,5 +13,5 @@ export * from "./ui/index.js";
13
13
  * @const VERSION
14
14
  * @memberOf module:ui-decorators
15
15
  */
16
- export const VERSION = "0.5.15";
16
+ export const VERSION = "0.5.16";
17
17
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsaUNBQXdCO0FBQ3hCLDhCQUFxQjtBQUVyQjs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBVSSBkZWNvcmF0b3JzIG1vZHVsZSBmb3IgVHlwZVNjcmlwdCBhcHBsaWNhdGlvbnNcbiAqIEBzdW1tYXJ5IEEgY29sbGVjdGlvbiBvZiBkZWNvcmF0b3JzIGFuZCB1dGlsaXRpZXMgZm9yIGJ1aWxkaW5nIFVJIGNvbXBvbmVudHMgaW4gVHlwZVNjcmlwdCBhcHBsaWNhdGlvbnMuXG4gKiBUaGlzIG1vZHVsZSBleHBvcnRzIGZ1bmN0aW9uYWxpdHkgZnJvbSBib3RoIHRoZSBtb2RlbCBhbmQgVUkgc3VibW9kdWxlcywgcHJvdmlkaW5nIGRlY29yYXRvcnMgZm9yXG4gKiByZW5kZXJpbmcsIGNvbXBvbmVudCBkZWZpbml0aW9uLCBhbmQgVUkgc3RhdGUgbWFuYWdlbWVudC5cbiAqIEBtb2R1bGUgdWktZGVjb3JhdG9yc1xuICovXG5cbmV4cG9ydCAqIGZyb20gXCIuL21vZGVsXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91aVwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBDdXJyZW50IHBhY2thZ2UgdmVyc2lvbiBzdHJpbmdcbiAqIEBzdW1tYXJ5IFN0b3JlcyB0aGUgY3VycmVudCBwYWNrYWdlIHZlcnNpb24gZm9yIHJlZmVyZW5jZVxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6dWktZGVjb3JhdG9yc1xuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcbiJdfQ==
@@ -1,3 +1,4 @@
1
+ import { UIMediaBreakPoints } from "../ui/types";
1
2
  /**
2
3
  * @description Decorator that tags a class as a UI model
3
4
  * @summary Adds rendering capabilities to a model class by providing a render method
@@ -121,4 +122,116 @@ export declare function renderedBy(engine: string): (target: object, propertyKey
121
122
  * RenderingEngine->>System: renders with list item styling
122
123
  */
123
124
  export declare function uilistitem(tag?: string, props?: Record<string, any>): (original: any, propertyKey?: any) => void;
125
+ /**
126
+ * @description Decorator that adds event handlers to a UI model
127
+ * @summary Specifies event handlers that should be attached to the rendered model
128
+ * This decorator allows you to define event handlers that will be automatically
129
+ * attached to the rendered UI element. The handlers are passed as properties
130
+ * to the rendering engine.
131
+ *
132
+ * @param {Record<string, any>} [props] Object containing event handler functions and other properties
133
+ * @return {Function} A class decorator function
134
+ *
135
+ * @function uihandlers
136
+ * @category Class Decorators
137
+ *
138
+ * @example
139
+ * // Add event handlers to a model
140
+ * @uimodel('button')
141
+ * @uihandlers({
142
+ * onClick: (event) => console.log('Button clicked'),
143
+ * onMouseOver: (event) => console.log('Mouse over button'),
144
+ * disabled: false
145
+ * })
146
+ * class ClickableButton extends Model {
147
+ * @attribute()
148
+ * label: string;
149
+ * }
150
+ *
151
+ * // Add form submission handlers
152
+ * @uimodel('form')
153
+ * @uihandlers({
154
+ * onSubmit: (event) => {
155
+ * event.preventDefault();
156
+ * console.log('Form submitted');
157
+ * },
158
+ * onReset: (event) => console.log('Form reset')
159
+ * })
160
+ * class ContactForm extends Model {
161
+ * @attribute()
162
+ * email: string;
163
+ * }
164
+ *
165
+ * @mermaid
166
+ * sequenceDiagram
167
+ * participant System
168
+ * participant uihandlers
169
+ * participant Model
170
+ * participant RenderingEngine
171
+ * participant UI
172
+ * System->>uihandlers: apply to Model
173
+ * uihandlers->>Model: adds handler metadata
174
+ * Model->>RenderingEngine: requests rendering with handlers
175
+ * RenderingEngine->>UI: renders element with event handlers attached
176
+ * UI->>Model: triggers handlers on events
177
+ */
124
178
  export declare function uihandlers(props?: Record<string, any>): (original: any) => void;
179
+ /**
180
+ * @description Decorator that creates a layout container with grid specifications
181
+ * @summary Combines UI model functionality with layout grid configuration
182
+ * This decorator creates a UI model that acts as a layout container with specified
183
+ * column and row configurations. It's a convenience decorator that combines
184
+ * @uimodel with layout-specific properties for responsive grid layouts.
185
+ *
186
+ * @param {string} tag The HTML tag to use for the layout container
187
+ * @param {number} [cols=1] Number of columns in the grid layout
188
+ * @param {number|string[]} [rows=1] Number of rows or array of row definitions
189
+ * @param {UIMediaBreakPoints} [breakpoint='m'] Media breakpoint for responsive behavior
190
+ * @return {Function} A class decorator function
191
+ *
192
+ * @function uilayout
193
+ * @category Class Decorators
194
+ *
195
+ * @example
196
+ * // Create a simple 2-column layout
197
+ * @uilayout('div', 2, 3)
198
+ * class TwoColumnLayout extends Model {
199
+ * @attribute()
200
+ * @uilayoutitem(1, 1)
201
+ * header: string;
202
+ *
203
+ * @attribute()
204
+ * @uilayoutitem(1, 2)
205
+ * leftContent: string;
206
+ *
207
+ * @attribute()
208
+ * @uilayoutitem(2, 2)
209
+ * rightContent: string;
210
+ * }
211
+ *
212
+ * // Create a responsive layout with custom breakpoint
213
+ * @uilayout('section', 3, 2, 'l')
214
+ * class ResponsiveLayout extends Model {
215
+ * @attribute()
216
+ * @uilayoutitem(1, 1)
217
+ * title: string;
218
+ *
219
+ * @attribute()
220
+ * @uilayoutitem(2, 1)
221
+ * subtitle: string;
222
+ * }
223
+ *
224
+ * @mermaid
225
+ * sequenceDiagram
226
+ * participant System
227
+ * participant uilayout
228
+ * participant uimodel
229
+ * participant Model
230
+ * participant RenderingEngine
231
+ * System->>uilayout: apply to Model
232
+ * uilayout->>uimodel: call with layout props
233
+ * uimodel->>Model: adds model metadata with layout config
234
+ * Model->>RenderingEngine: requests rendering as layout container
235
+ * RenderingEngine->>System: renders grid layout with specified dimensions
236
+ */
237
+ export declare function uilayout(tag: string, cols?: number, rows?: number | string[], breakpoint?: UIMediaBreakPoints): (original: any, propertyKey?: any) => void;
@@ -146,6 +146,59 @@ export function uilistitem(tag, props) {
146
146
  return metadata(RenderingEngine.key(UIKeys.UILISTITEM), meta)(original);
147
147
  };
148
148
  }
149
+ /**
150
+ * @description Decorator that adds event handlers to a UI model
151
+ * @summary Specifies event handlers that should be attached to the rendered model
152
+ * This decorator allows you to define event handlers that will be automatically
153
+ * attached to the rendered UI element. The handlers are passed as properties
154
+ * to the rendering engine.
155
+ *
156
+ * @param {Record<string, any>} [props] Object containing event handler functions and other properties
157
+ * @return {Function} A class decorator function
158
+ *
159
+ * @function uihandlers
160
+ * @category Class Decorators
161
+ *
162
+ * @example
163
+ * // Add event handlers to a model
164
+ * @uimodel('button')
165
+ * @uihandlers({
166
+ * onClick: (event) => console.log('Button clicked'),
167
+ * onMouseOver: (event) => console.log('Mouse over button'),
168
+ * disabled: false
169
+ * })
170
+ * class ClickableButton extends Model {
171
+ * @attribute()
172
+ * label: string;
173
+ * }
174
+ *
175
+ * // Add form submission handlers
176
+ * @uimodel('form')
177
+ * @uihandlers({
178
+ * onSubmit: (event) => {
179
+ * event.preventDefault();
180
+ * console.log('Form submitted');
181
+ * },
182
+ * onReset: (event) => console.log('Form reset')
183
+ * })
184
+ * class ContactForm extends Model {
185
+ * @attribute()
186
+ * email: string;
187
+ * }
188
+ *
189
+ * @mermaid
190
+ * sequenceDiagram
191
+ * participant System
192
+ * participant uihandlers
193
+ * participant Model
194
+ * participant RenderingEngine
195
+ * participant UI
196
+ * System->>uihandlers: apply to Model
197
+ * uihandlers->>Model: adds handler metadata
198
+ * Model->>RenderingEngine: requests rendering with handlers
199
+ * RenderingEngine->>UI: renders element with event handlers attached
200
+ * UI->>Model: triggers handlers on events
201
+ */
149
202
  export function uihandlers(props) {
150
203
  return (original) => {
151
204
  const meta = {
@@ -154,4 +207,67 @@ export function uihandlers(props) {
154
207
  return metadata(RenderingEngine.key(UIKeys.HANDLERS), meta)(original);
155
208
  };
156
209
  }
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/model/decorators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,6BAAwB;AACzC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,6BAAwB;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}"]}
210
+ /**
211
+ * @description Decorator that creates a layout container with grid specifications
212
+ * @summary Combines UI model functionality with layout grid configuration
213
+ * This decorator creates a UI model that acts as a layout container with specified
214
+ * column and row configurations. It's a convenience decorator that combines
215
+ * @uimodel with layout-specific properties for responsive grid layouts.
216
+ *
217
+ * @param {string} tag The HTML tag to use for the layout container
218
+ * @param {number} [cols=1] Number of columns in the grid layout
219
+ * @param {number|string[]} [rows=1] Number of rows or array of row definitions
220
+ * @param {UIMediaBreakPoints} [breakpoint='m'] Media breakpoint for responsive behavior
221
+ * @return {Function} A class decorator function
222
+ *
223
+ * @function uilayout
224
+ * @category Class Decorators
225
+ *
226
+ * @example
227
+ * // Create a simple 2-column layout
228
+ * @uilayout('div', 2, 3)
229
+ * class TwoColumnLayout extends Model {
230
+ * @attribute()
231
+ * @uilayoutitem(1, 1)
232
+ * header: string;
233
+ *
234
+ * @attribute()
235
+ * @uilayoutitem(1, 2)
236
+ * leftContent: string;
237
+ *
238
+ * @attribute()
239
+ * @uilayoutitem(2, 2)
240
+ * rightContent: string;
241
+ * }
242
+ *
243
+ * // Create a responsive layout with custom breakpoint
244
+ * @uilayout('section', 3, 2, 'l')
245
+ * class ResponsiveLayout extends Model {
246
+ * @attribute()
247
+ * @uilayoutitem(1, 1)
248
+ * title: string;
249
+ *
250
+ * @attribute()
251
+ * @uilayoutitem(2, 1)
252
+ * subtitle: string;
253
+ * }
254
+ *
255
+ * @mermaid
256
+ * sequenceDiagram
257
+ * participant System
258
+ * participant uilayout
259
+ * participant uimodel
260
+ * participant Model
261
+ * participant RenderingEngine
262
+ * System->>uilayout: apply to Model
263
+ * uilayout->>uimodel: call with layout props
264
+ * uimodel->>Model: adds model metadata with layout config
265
+ * Model->>RenderingEngine: requests rendering as layout container
266
+ * RenderingEngine->>System: renders grid layout with specified dimensions
267
+ */
268
+ export function uilayout(tag, cols = 1, rows = 1, breakpoint = 'm') {
269
+ return (original, propertyKey) => {
270
+ return uimodel(tag, { cols, rows, breakpoint })(original, propertyKey);
271
+ };
272
+ }
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/model/decorators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,6BAAwB;AACzC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,6BAAwB;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;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoDG;AACH,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;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyDG;AACH,MAAM,UAAU,QAAQ,CAAC,GAAW,EAAE,OAAe,CAAC,EAAE,OAA0B,CAAC,EAAE,aAAiC,GAAG;IACvH,OAAO,CAAC,QAAa,EAAE,WAAiB,EAAE,EAAE;QAC1C,OAAO,OAAO,CAAC,GAAG,EAAE,EAAC,IAAI,EAAE,IAAI,EAAE,UAAU,EAAC,CAAC,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;IACvE,CAAC,CAAC;AACJ,CAAC","sourcesContent":["import { UIKeys } from \"../ui/constants\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { RenderingEngine } from \"../ui/Rendering\";\nimport { UIListItemModelMetadata, UIMediaBreakPoints, 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/**\n * @description Decorator that adds event handlers to a UI model\n * @summary Specifies event handlers that should be attached to the rendered model\n * This decorator allows you to define event handlers that will be automatically\n * attached to the rendered UI element. The handlers are passed as properties\n * to the rendering engine.\n *\n * @param {Record<string, any>} [props] Object containing event handler functions and other properties\n * @return {Function} A class decorator function\n *\n * @function uihandlers\n * @category Class Decorators\n *\n * @example\n * // Add event handlers to a model\n * @uimodel('button')\n * @uihandlers({\n *   onClick: (event) => console.log('Button clicked'),\n *   onMouseOver: (event) => console.log('Mouse over button'),\n *   disabled: false\n * })\n * class ClickableButton extends Model {\n *   @attribute()\n *   label: string;\n * }\n *\n * // Add form submission handlers\n * @uimodel('form')\n * @uihandlers({\n *   onSubmit: (event) => {\n *     event.preventDefault();\n *     console.log('Form submitted');\n *   },\n *   onReset: (event) => console.log('Form reset')\n * })\n * class ContactForm extends Model {\n *   @attribute()\n *   email: string;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant System\n *   participant uihandlers\n *   participant Model\n *   participant RenderingEngine\n *   participant UI\n *   System->>uihandlers: apply to Model\n *   uihandlers->>Model: adds handler metadata\n *   Model->>RenderingEngine: requests rendering with handlers\n *   RenderingEngine->>UI: renders element with event handlers attached\n *   UI->>Model: triggers handlers on events\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}\n\n/**\n * @description Decorator that creates a layout container with grid specifications\n * @summary Combines UI model functionality with layout grid configuration\n * This decorator creates a UI model that acts as a layout container with specified\n * column and row configurations. It's a convenience decorator that combines\n * @uimodel with layout-specific properties for responsive grid layouts.\n *\n * @param {string} tag The HTML tag to use for the layout container\n * @param {number} [cols=1] Number of columns in the grid layout\n * @param {number|string[]} [rows=1] Number of rows or array of row definitions\n * @param {UIMediaBreakPoints} [breakpoint='m'] Media breakpoint for responsive behavior\n * @return {Function} A class decorator function\n *\n * @function uilayout\n * @category Class Decorators\n *\n * @example\n * // Create a simple 2-column layout\n * @uilayout('div', 2, 3)\n * class TwoColumnLayout extends Model {\n *   @attribute()\n *   @uilayoutitem(1, 1)\n *   header: string;\n *\n *   @attribute()\n *   @uilayoutitem(1, 2)\n *   leftContent: string;\n *\n *   @attribute()\n *   @uilayoutitem(2, 2)\n *   rightContent: string;\n * }\n *\n * // Create a responsive layout with custom breakpoint\n * @uilayout('section', 3, 2, 'l')\n * class ResponsiveLayout extends Model {\n *   @attribute()\n *   @uilayoutitem(1, 1)\n *   title: string;\n *\n *   @attribute()\n *   @uilayoutitem(2, 1)\n *   subtitle: string;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant System\n *   participant uilayout\n *   participant uimodel\n *   participant Model\n *   participant RenderingEngine\n *   System->>uilayout: apply to Model\n *   uilayout->>uimodel: call with layout props\n *   uimodel->>Model: adds model metadata with layout config\n *   Model->>RenderingEngine: requests rendering as layout container\n *   RenderingEngine->>System: renders grid layout with specified dimensions\n */\nexport function uilayout(tag: string, cols: number = 1, rows: number | string[] = 1, breakpoint: UIMediaBreakPoints = 'm') {\n  return (original: any, propertyKey?: any) => {\n    return uimodel(tag, {cols, rows, breakpoint})(original, propertyKey);\n  };\n}"]}
@@ -51,6 +51,19 @@ export declare abstract class RenderingEngine<T = void, R = FieldDefinition<T>>
51
51
  * @returns {string} The translated type.
52
52
  */
53
53
  translate(key: string, toView?: boolean): string;
54
+ /**
55
+ * @description Retrieves class decorator metadata for a model instance
56
+ * @summary Extracts UI-related class decorators from a model and returns them as an array
57
+ * This method collects metadata from various UI class decorators including @uimodel,
58
+ * @uilistitem, @uihandlers, and @uilayout applied to the model class.
59
+ *
60
+ * @template M Type extending Model
61
+ * @param {M} model - The model instance to extract metadata from
62
+ * @returns {UIClassMetadata[]} Array of UI class metadata objects
63
+ *
64
+ * @private
65
+ */
66
+ private getClassDecoratorsMetadata;
54
67
  /**
55
68
  * @description Checks if a type is validatable by its nature.
56
69
  * @summary Determines if a given UI key represents a type that is inherently validatable.
@@ -109,6 +122,21 @@ export declare abstract class RenderingEngine<T = void, R = FieldDefinition<T>>
109
122
  * RE-->>C: FieldDefinition<T>
110
123
  */
111
124
  protected toFieldDefinition<M extends Model>(model: M, globalProps?: Record<string, unknown>, generateId?: boolean): FieldDefinition<T>;
125
+ /**
126
+ * @description Processes layout items for grid positioning
127
+ * @summary Maps child field definitions to their corresponding layout positions
128
+ * This method iterates through child field definitions and applies layout metadata
129
+ * from @uilayoutitem decorators to position them correctly in a grid layout.
130
+ *
131
+ * @param {FieldDefinition[]} children - Array of child field definitions to process
132
+ * @param {Record<string, any>} uiDecorators - UI decorator metadata keyed by property name
133
+ * @returns {FieldDefinition[]} Array of field definitions with layout positioning applied
134
+ *
135
+ * @example
136
+ * // Internal usage - positions children in grid layout
137
+ * const layoutChildren = this.getLayoutItems(childDefinitions, decoratorMetadata);
138
+ */
139
+ getLayoutItems(children: FieldDefinition<any>[], uiDecorators: Record<string, any>): FieldDefinition<any>[];
112
140
  /**
113
141
  * @description Renders a model with global properties and additional arguments.
114
142
  * @summary Abstract method to be implemented by subclasses to define specific rendering behavior.