@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.
- package/dist/ui-decorators.cjs +266 -22
- package/dist/ui-decorators.esm.cjs +265 -23
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +1 -1
- package/lib/esm/model/decorators.d.ts +113 -0
- package/lib/esm/model/decorators.js +117 -1
- package/lib/esm/ui/Rendering.d.ts +28 -0
- package/lib/esm/ui/Rendering.js +74 -13
- package/lib/esm/ui/constants.d.ts +2 -0
- package/lib/esm/ui/constants.js +3 -1
- package/lib/esm/ui/decorators.d.ts +50 -0
- package/lib/esm/ui/decorators.js +61 -1
- package/lib/esm/ui/types.d.ts +38 -1
- package/lib/esm/ui/types.js +1 -1
- package/lib/esm/ui/utils.js +13 -9
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/model/decorators.cjs +118 -1
- package/lib/model/decorators.d.ts +113 -0
- package/lib/ui/Rendering.cjs +74 -13
- package/lib/ui/Rendering.d.ts +28 -0
- package/lib/ui/constants.cjs +3 -1
- package/lib/ui/constants.d.ts +2 -0
- package/lib/ui/decorators.cjs +62 -1
- package/lib/ui/decorators.d.ts +50 -0
- package/lib/ui/types.cjs +1 -1
- package/lib/ui/types.d.ts +38 -1
- package/lib/ui/utils.cjs +13 -9
- package/package.json +1 -1
package/lib/esm/index.d.ts
CHANGED
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.
|
|
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
|
-
|
|
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.
|