@decaf-ts/ui-decorators 0.5.9 → 0.5.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +21 -157
- package/README.md +422 -12
- package/dist/ui-decorators.cjs +609 -55
- package/dist/ui-decorators.esm.cjs +607 -56
- package/lib/esm/index.d.ts +7 -3
- package/lib/esm/index.js +8 -4
- package/lib/esm/model/Renderable.d.ts +15 -0
- package/lib/esm/model/Renderable.js +1 -1
- package/lib/esm/model/decorators.d.ts +93 -14
- package/lib/esm/model/decorators.js +102 -16
- package/lib/esm/model/index.d.ts +0 -4
- package/lib/esm/model/index.js +1 -5
- package/lib/esm/model/model.d.ts +156 -50
- package/lib/esm/model/model.js +1 -1
- package/lib/esm/model/overrides.d.ts +8 -0
- package/lib/esm/model/overrides.js +19 -1
- package/lib/esm/ui/Rendering.js +43 -8
- package/lib/esm/ui/constants.d.ts +149 -4
- package/lib/esm/ui/constants.js +150 -5
- package/lib/esm/ui/decorators.d.ts +229 -21
- package/lib/esm/ui/decorators.js +242 -25
- package/lib/esm/ui/errors.d.ts +28 -0
- package/lib/esm/ui/errors.js +29 -1
- package/lib/esm/ui/handlers.d.ts +17 -0
- package/lib/esm/ui/handlers.js +18 -0
- package/lib/esm/ui/index.d.ts +1 -4
- package/lib/esm/ui/index.js +2 -5
- package/lib/esm/ui/interfaces.d.ts +25 -0
- package/lib/esm/ui/interfaces.js +9 -1
- package/lib/esm/ui/types.d.ts +63 -5
- package/lib/esm/ui/types.js +9 -1
- package/lib/esm/ui/utils.d.ts +1 -1
- package/lib/esm/ui/utils.js +2 -2
- package/lib/index.cjs +8 -4
- package/lib/index.d.ts +7 -3
- package/lib/model/Renderable.cjs +1 -1
- package/lib/model/Renderable.d.ts +15 -0
- package/lib/model/decorators.cjs +103 -16
- package/lib/model/decorators.d.ts +93 -14
- package/lib/model/index.cjs +1 -5
- package/lib/model/index.d.ts +0 -4
- package/lib/model/model.cjs +1 -1
- package/lib/model/model.d.ts +156 -50
- package/lib/model/overrides.cjs +19 -1
- package/lib/model/overrides.d.ts +8 -0
- package/lib/ui/Rendering.cjs +43 -8
- package/lib/ui/constants.cjs +150 -5
- package/lib/ui/constants.d.ts +149 -4
- package/lib/ui/decorators.cjs +243 -25
- package/lib/ui/decorators.d.ts +229 -21
- package/lib/ui/errors.cjs +29 -1
- package/lib/ui/errors.d.ts +28 -0
- package/lib/ui/handlers.cjs +22 -0
- package/lib/ui/handlers.d.ts +17 -0
- package/lib/ui/index.cjs +2 -5
- package/lib/ui/index.d.ts +1 -4
- package/lib/ui/interfaces.cjs +9 -1
- package/lib/ui/interfaces.d.ts +25 -0
- package/lib/ui/types.cjs +9 -1
- package/lib/ui/types.d.ts +63 -5
- package/lib/ui/utils.cjs +2 -2
- package/lib/ui/utils.d.ts +1 -1
- package/package.json +2 -2
package/lib/esm/ui/decorators.js
CHANGED
|
@@ -4,50 +4,177 @@ import { propMetadata } from "@decaf-ts/decorator-validation";
|
|
|
4
4
|
import { RenderingEngine } from "./Rendering";
|
|
5
5
|
import { OperationKeys } from "@decaf-ts/db-decorators";
|
|
6
6
|
/**
|
|
7
|
-
* @
|
|
8
|
-
* @
|
|
7
|
+
* @description Decorator that hides a property during specific CRUD operations
|
|
8
|
+
* @summary Controls property visibility based on operation type
|
|
9
|
+
* This decorator allows you to specify which CRUD operations should hide a property
|
|
10
|
+
* in the UI. The property will only be visible during operations not specified.
|
|
11
|
+
*
|
|
12
|
+
* @param operations - The CRUD operations during which the property should be hidden
|
|
13
|
+
* @return {Function} A property decorator function
|
|
14
|
+
*
|
|
15
|
+
* @function hideOn
|
|
16
|
+
* @category Property Decorators
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* // Hide the password field during READ operations
|
|
20
|
+
* class User {
|
|
21
|
+
* @attribute()
|
|
22
|
+
* username: string;
|
|
23
|
+
*
|
|
24
|
+
* @attribute()
|
|
25
|
+
* @hideOn(OperationKeys.READ)
|
|
26
|
+
* password: string;
|
|
27
|
+
* }
|
|
28
|
+
*
|
|
29
|
+
* @mermaid
|
|
30
|
+
* sequenceDiagram
|
|
31
|
+
* participant Model
|
|
32
|
+
* participant hideOn
|
|
33
|
+
* participant RenderingEngine
|
|
34
|
+
* participant UI
|
|
35
|
+
* Model->>hideOn: Apply to property
|
|
36
|
+
* hideOn->>Model: Add hidden metadata
|
|
37
|
+
* RenderingEngine->>Model: Check if property should be hidden
|
|
38
|
+
* Model->>RenderingEngine: Return hidden operations
|
|
39
|
+
* RenderingEngine->>UI: Render or hide based on current operation
|
|
9
40
|
*/
|
|
10
41
|
export function hideOn(...operations) {
|
|
11
42
|
return propMetadata(RenderingEngine.key(UIKeys.HIDDEN), operations);
|
|
12
43
|
}
|
|
44
|
+
/**
|
|
45
|
+
* @description Decorator that completely hides a property in all UI operations
|
|
46
|
+
* @summary Makes a property invisible in all CRUD operations
|
|
47
|
+
* This decorator is a convenience wrapper around hideOn that hides a property
|
|
48
|
+
* during all CRUD operations (CREATE, READ, UPDATE, DELETE).
|
|
49
|
+
*
|
|
50
|
+
* @return {Function} A property decorator function
|
|
51
|
+
*
|
|
52
|
+
* @function hidden
|
|
53
|
+
* @category Property Decorators
|
|
54
|
+
*
|
|
55
|
+
* @example
|
|
56
|
+
* // Completely hide the internalId field in the UI
|
|
57
|
+
* class Product {
|
|
58
|
+
* @attribute()
|
|
59
|
+
* name: string;
|
|
60
|
+
*
|
|
61
|
+
* @attribute()
|
|
62
|
+
* @hidden()
|
|
63
|
+
* internalId: string;
|
|
64
|
+
* }
|
|
65
|
+
*
|
|
66
|
+
* @mermaid
|
|
67
|
+
* sequenceDiagram
|
|
68
|
+
* participant Model
|
|
69
|
+
* participant hidden
|
|
70
|
+
* participant hideOn
|
|
71
|
+
* participant RenderingEngine
|
|
72
|
+
* Model->>hidden: Apply to property
|
|
73
|
+
* hidden->>hideOn: Call with all operations
|
|
74
|
+
* hideOn->>Model: Add hidden metadata
|
|
75
|
+
* RenderingEngine->>Model: Check if property should be hidden
|
|
76
|
+
* Model->>RenderingEngine: Return all operations
|
|
77
|
+
* RenderingEngine->>UI: Always hide property
|
|
78
|
+
*/
|
|
13
79
|
export function hidden() {
|
|
14
80
|
return hideOn(OperationKeys.CREATE, OperationKeys.READ, OperationKeys.UPDATE, OperationKeys.DELETE);
|
|
15
81
|
}
|
|
16
82
|
/**
|
|
17
|
-
*
|
|
83
|
+
* @description Decorator that specifies how a property should be rendered as a UI element
|
|
84
|
+
* @summary Maps a model property to a specific UI element with custom properties
|
|
85
|
+
* This decorator allows you to define which HTML element or component should be used
|
|
86
|
+
* to render a specific property, along with any additional properties to pass to that element.
|
|
87
|
+
*
|
|
88
|
+
* @param {string} tag The HTML element or component tag name to use for rendering
|
|
89
|
+
* @param {Record<string, any>} [props] Additional properties to pass to the element
|
|
90
|
+
* @param {boolean} [serialize=false] Whether the property should be serialized
|
|
91
|
+
* @return {Function} A property decorator function
|
|
92
|
+
*
|
|
93
|
+
* @function uielement
|
|
94
|
+
* @category Property Decorators
|
|
18
95
|
*
|
|
19
|
-
* @
|
|
20
|
-
*
|
|
21
|
-
*
|
|
96
|
+
* @example
|
|
97
|
+
* // Render a property as a text input
|
|
98
|
+
* class LoginForm {
|
|
99
|
+
* @attribute()
|
|
100
|
+
* @uielement('input', { type: 'text', placeholder: 'Enter username' })
|
|
101
|
+
* username: string;
|
|
22
102
|
*
|
|
23
|
-
*
|
|
103
|
+
* @attribute()
|
|
104
|
+
* @uielement('input', { type: 'password', placeholder: 'Enter password' })
|
|
105
|
+
* password: string;
|
|
24
106
|
*
|
|
25
|
-
*
|
|
26
|
-
*
|
|
107
|
+
* @attribute()
|
|
108
|
+
* @uielement('button', { class: 'btn-primary' })
|
|
109
|
+
* submit: string = 'Login';
|
|
110
|
+
* }
|
|
111
|
+
*
|
|
112
|
+
* @mermaid
|
|
113
|
+
* sequenceDiagram
|
|
114
|
+
* participant Model
|
|
115
|
+
* participant uielement
|
|
116
|
+
* participant RenderingEngine
|
|
117
|
+
* participant UI
|
|
118
|
+
* Model->>uielement: Apply to property
|
|
119
|
+
* uielement->>Model: Add element metadata
|
|
120
|
+
* RenderingEngine->>Model: Get element metadata
|
|
121
|
+
* Model->>RenderingEngine: Return tag and props
|
|
122
|
+
* RenderingEngine->>UI: Render with specified element
|
|
27
123
|
*/
|
|
28
124
|
export function uielement(tag, props, serialize = false) {
|
|
29
125
|
return (original, propertyKey) => {
|
|
30
126
|
const metadata = {
|
|
31
127
|
tag: tag,
|
|
32
128
|
serialize: serialize,
|
|
33
|
-
props: Object.assign({
|
|
129
|
+
props: Object.assign({}, props || {}, {
|
|
34
130
|
name: propertyKey,
|
|
35
|
-
}
|
|
131
|
+
}),
|
|
36
132
|
};
|
|
37
133
|
return propMetadata(RenderingEngine.key(UIKeys.ELEMENT), metadata)(original, propertyKey);
|
|
38
134
|
};
|
|
39
135
|
}
|
|
40
136
|
/**
|
|
41
|
-
*
|
|
137
|
+
* @description Decorator that maps a model property to a UI component property
|
|
138
|
+
* @summary Specifies how a property should be passed to a UI component
|
|
139
|
+
* This decorator allows you to define how a model property should be mapped to
|
|
140
|
+
* a property of the UI component when rendering. It requires the class to be
|
|
141
|
+
* decorated with @uimodel.
|
|
142
|
+
*
|
|
143
|
+
* @param {string} [propName] The name of the property to pass to the component (defaults to the property key)
|
|
144
|
+
* @param {boolean} [stringify=false] Whether to stringify the property value
|
|
145
|
+
* @return {Function} A property decorator function
|
|
42
146
|
*
|
|
43
|
-
*
|
|
147
|
+
* @function uiprop
|
|
148
|
+
* @category Property Decorators
|
|
44
149
|
*
|
|
45
|
-
* @
|
|
150
|
+
* @example
|
|
151
|
+
* // Map model properties to component properties
|
|
152
|
+
* @uimodel('user-profile')
|
|
153
|
+
* class UserProfile {
|
|
154
|
+
* @attribute()
|
|
155
|
+
* @uiprop() // Will be passed as 'fullName' to the component
|
|
156
|
+
* fullName: string;
|
|
46
157
|
*
|
|
47
|
-
*
|
|
158
|
+
* @attribute()
|
|
159
|
+
* @uiprop('userEmail') // Will be passed as 'userEmail' to the component
|
|
160
|
+
* email: string;
|
|
48
161
|
*
|
|
49
|
-
*
|
|
50
|
-
*
|
|
162
|
+
* @attribute()
|
|
163
|
+
* @uiprop('userData', true) // Will be passed as stringified JSON
|
|
164
|
+
* userData: Record<string, any>;
|
|
165
|
+
* }
|
|
166
|
+
*
|
|
167
|
+
* @mermaid
|
|
168
|
+
* sequenceDiagram
|
|
169
|
+
* participant Model
|
|
170
|
+
* participant uiprop
|
|
171
|
+
* participant RenderingEngine
|
|
172
|
+
* participant Component
|
|
173
|
+
* Model->>uiprop: Apply to property
|
|
174
|
+
* uiprop->>Model: Add prop metadata
|
|
175
|
+
* RenderingEngine->>Model: Get prop metadata
|
|
176
|
+
* Model->>RenderingEngine: Return prop name and stringify flag
|
|
177
|
+
* RenderingEngine->>Component: Pass property with specified name
|
|
51
178
|
*/
|
|
52
179
|
export function uiprop(propName = undefined, stringify = false) {
|
|
53
180
|
return (target, propertyKey) => {
|
|
@@ -59,24 +186,114 @@ export function uiprop(propName = undefined, stringify = false) {
|
|
|
59
186
|
};
|
|
60
187
|
}
|
|
61
188
|
/**
|
|
62
|
-
*
|
|
189
|
+
* @description Decorator that maps a model property to a UI component property
|
|
190
|
+
* @summary Specifies how a property should be passed to a UI component
|
|
191
|
+
* This decorator allows you to define how a model property should be mapped to
|
|
192
|
+
* a property of the UI component when rendering. It requires the class to be
|
|
193
|
+
* decorated with @uimodel.
|
|
194
|
+
*
|
|
195
|
+
* @param {string} [propName] The name of the property to pass to the component (defaults to the property key)
|
|
196
|
+
* @param {boolean} [stringify=false] Whether to stringify the property value
|
|
197
|
+
* @return {Function} A property decorator function
|
|
198
|
+
*
|
|
199
|
+
* @function uiprop
|
|
200
|
+
* @category Property Decorators
|
|
201
|
+
*
|
|
202
|
+
* @example
|
|
203
|
+
* // Map model properties to component properties
|
|
204
|
+
* @uimodel('user-profile')
|
|
205
|
+
* class UserProfile {
|
|
206
|
+
* @attribute()
|
|
207
|
+
* @uiprop() // Will be passed as 'fullName' to the component
|
|
208
|
+
* fullName: string;
|
|
209
|
+
*
|
|
210
|
+
* @attribute()
|
|
211
|
+
* @uiprop('userEmail') // Will be passed as 'userEmail' to the component
|
|
212
|
+
* email: string;
|
|
213
|
+
*
|
|
214
|
+
* @attribute()
|
|
215
|
+
* @uiprop('userData', true) // Will be passed as stringified JSON
|
|
216
|
+
* userData: Record<string, any>;
|
|
217
|
+
* }
|
|
218
|
+
*
|
|
219
|
+
* @mermaid
|
|
220
|
+
* sequenceDiagram
|
|
221
|
+
* participant Model
|
|
222
|
+
* participant uiprop
|
|
223
|
+
* participant RenderingEngine
|
|
224
|
+
* participant Component
|
|
225
|
+
* Model->>uiprop: Apply to property
|
|
226
|
+
* uiprop->>Model: Add prop metadata
|
|
227
|
+
* RenderingEngine->>Model: Get prop metadata
|
|
228
|
+
* Model->>RenderingEngine: Return prop name and stringify flag
|
|
229
|
+
* RenderingEngine->>Component: Pass property with specified name
|
|
230
|
+
*/
|
|
231
|
+
export function uichild(propName = undefined, stringify = false, tag) {
|
|
232
|
+
return (target, propertyKey) => {
|
|
233
|
+
const metadata = {
|
|
234
|
+
name: propName || propertyKey,
|
|
235
|
+
stringify: stringify,
|
|
236
|
+
tag: tag,
|
|
237
|
+
};
|
|
238
|
+
propMetadata(RenderingEngine.key(UIKeys.CHILD), metadata)(target, propertyKey);
|
|
239
|
+
};
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* @description Decorator that maps a model property to a list item component
|
|
243
|
+
* @summary Specifies how a property should be rendered in a list context
|
|
244
|
+
* This decorator allows you to define how a model property containing a list
|
|
245
|
+
* should be rendered. It requires the class to be decorated with @uilistitem.
|
|
246
|
+
*
|
|
247
|
+
* @param {string} [propName] The name of the property to pass to the list component (defaults to the property key)
|
|
248
|
+
* @param {Record<string, any>} [props] Additional properties to pass to the list container
|
|
249
|
+
* @return {Function} A property decorator function
|
|
250
|
+
*
|
|
251
|
+
* @function uilistprop
|
|
252
|
+
* @category Property Decorators
|
|
253
|
+
*
|
|
254
|
+
* @example
|
|
255
|
+
* // Define a list property with custom rendering
|
|
256
|
+
* @uimodel('todo-list')
|
|
257
|
+
* class TodoList {
|
|
258
|
+
* @attribute()
|
|
259
|
+
* title: string;
|
|
63
260
|
*
|
|
64
|
-
*
|
|
261
|
+
* @attribute()
|
|
262
|
+
* @uilistprop('items', { class: 'todo-items-container' })
|
|
263
|
+
* items: TodoItem[];
|
|
264
|
+
* }
|
|
65
265
|
*
|
|
66
|
-
* @
|
|
266
|
+
* @uilistitem('li', { class: 'todo-item' })
|
|
267
|
+
* class TodoItem extends Model {
|
|
268
|
+
* @attribute()
|
|
269
|
+
* text: string;
|
|
67
270
|
*
|
|
68
|
-
*
|
|
271
|
+
* @attribute()
|
|
272
|
+
* completed: boolean;
|
|
273
|
+
* }
|
|
69
274
|
*
|
|
70
|
-
* @
|
|
71
|
-
*
|
|
275
|
+
* @mermaid
|
|
276
|
+
* sequenceDiagram
|
|
277
|
+
* participant Model
|
|
278
|
+
* participant uilistprop
|
|
279
|
+
* participant RenderingEngine
|
|
280
|
+
* participant ListContainer
|
|
281
|
+
* participant ListItems
|
|
282
|
+
* Model->>uilistprop: Apply to property
|
|
283
|
+
* uilistprop->>Model: Add list prop metadata
|
|
284
|
+
* RenderingEngine->>Model: Get list prop metadata
|
|
285
|
+
* Model->>RenderingEngine: Return prop name and container props
|
|
286
|
+
* RenderingEngine->>ListContainer: Create container with props
|
|
287
|
+
* RenderingEngine->>ListItems: Render each item using @uilistitem
|
|
288
|
+
* ListContainer->>RenderingEngine: Return rendered list
|
|
72
289
|
*/
|
|
73
290
|
export function uilistprop(propName = undefined, props) {
|
|
74
291
|
return (target, propertyKey) => {
|
|
75
292
|
const metadata = {
|
|
76
293
|
name: propName || propertyKey,
|
|
77
|
-
props: props || {}
|
|
294
|
+
props: props || {},
|
|
78
295
|
};
|
|
79
296
|
propMetadata(RenderingEngine.key(UIKeys.UILISTPROP), metadata)(target, propertyKey);
|
|
80
297
|
};
|
|
81
298
|
}
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91aS9kZWNvcmF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sa0JBQWtCLENBQUM7QUFDMUIsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUNyQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFFOUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM5QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFeEQ7OztHQUdHO0FBRUgsTUFBTSxVQUFVLE1BQU0sQ0FBQyxHQUFHLFVBQStCO0lBQ3ZELE9BQU8sWUFBWSxDQUNqQixlQUFlLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFDbEMsVUFBVSxDQUNYLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLE1BQU07SUFDcEIsT0FBTyxNQUFNLENBQ1gsYUFBYSxDQUFDLE1BQU0sRUFDcEIsYUFBYSxDQUFDLElBQUksRUFDbEIsYUFBYSxDQUFDLE1BQU0sRUFDcEIsYUFBYSxDQUFDLE1BQU0sQ0FDckIsQ0FBQztBQUNKLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sVUFBVSxTQUFTLENBQ3ZCLEdBQVcsRUFDWCxLQUEyQixFQUMzQixZQUFxQixLQUFLO0lBRTFCLE9BQU8sQ0FBQyxRQUFhLEVBQUUsV0FBaUIsRUFBRSxFQUFFO1FBQzFDLE1BQU0sUUFBUSxHQUFzQjtZQUNsQyxHQUFHLEVBQUUsR0FBRztZQUNSLFNBQVMsRUFBRSxTQUFTO1lBQ3BCLEtBQUssRUFBRSxNQUFNLENBQUMsTUFBTSxDQUNsQjtnQkFDRSxJQUFJLEVBQUUsV0FBVzthQUNsQixFQUNELEtBQUssSUFBSSxFQUFFLENBQ1o7U0FDRixDQUFDO1FBRUYsT0FBTyxZQUFZLENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLEVBQUUsUUFBUSxDQUFDLENBQ2hFLFFBQVEsRUFDUixXQUFXLENBQ1osQ0FBQztJQUNKLENBQUMsQ0FBQztBQUNKLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sVUFBVSxNQUFNLENBQ3BCLFdBQStCLFNBQVMsRUFDeEMsWUFBcUIsS0FBSztJQUUxQixPQUFPLENBQUMsTUFBVyxFQUFFLFdBQW1CLEVBQUUsRUFBRTtRQUMxQyxNQUFNLFFBQVEsR0FBbUI7WUFDL0IsSUFBSSxFQUFFLFFBQVEsSUFBSSxXQUFXO1lBQzdCLFNBQVMsRUFBRSxTQUFTO1NBQ3JCLENBQUM7UUFDRixZQUFZLENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsUUFBUSxDQUFDLENBQ3RELE1BQU0sRUFDTixXQUFXLENBQ1osQ0FBQztJQUNKLENBQUMsQ0FBQztBQUNKLENBQUM7QUFHRDs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sVUFBVSxVQUFVLENBQ3hCLFdBQStCLFNBQVMsRUFDeEMsS0FBMkI7SUFFM0IsT0FBTyxDQUFDLE1BQVcsRUFBRSxXQUFtQixFQUFFLEVBQUU7UUFDeEMsTUFBTSxRQUFRLEdBQWdDO1lBQzlDLElBQUksRUFBRSxRQUFRLElBQUksV0FBVztZQUM3QixLQUFLLEVBQUUsS0FBSyxJQUFJLEVBQUU7U0FDbkIsQ0FBQztRQUNGLFlBQVksQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FDNUQsTUFBTSxFQUNOLFdBQVcsQ0FDWixDQUFDO0lBQ0osQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBcInJlZmxlY3QtbWV0YWRhdGFcIjtcbmltcG9ydCB7IFVJS2V5cyB9IGZyb20gXCIuL2NvbnN0YW50c1wiO1xuaW1wb3J0IHsgcHJvcE1ldGFkYXRhIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuaW1wb3J0IHsgQ3J1ZE9wZXJhdGlvbktleXMsIFVJRWxlbWVudE1ldGFkYXRhLCBVSUxpc3RQcm9wTWV0YWRhdGEsIFVJUHJvcE1ldGFkYXRhIH0gZnJvbSBcIi4vdHlwZXNcIjtcbmltcG9ydCB7IFJlbmRlcmluZ0VuZ2luZSB9IGZyb20gXCIuL1JlbmRlcmluZ1wiO1xuaW1wb3J0IHsgT3BlcmF0aW9uS2V5cyB9IGZyb20gXCJAZGVjYWYtdHMvZGItZGVjb3JhdG9yc1wiO1xuXG4vKipcbiAqIEBuYW1lc3BhY2UgdWktZGVjb3JhdG9ycy51aS5kZWNvcmF0b3JzXG4gKiBAbWVtYmVyT2YgdWktZGVjb3JhdG9ycy51aVxuICovXG5cbmV4cG9ydCBmdW5jdGlvbiBoaWRlT24oLi4ub3BlcmF0aW9uczogQ3J1ZE9wZXJhdGlvbktleXNbXSkge1xuICByZXR1cm4gcHJvcE1ldGFkYXRhPENydWRPcGVyYXRpb25LZXlzW10+KFxuICAgIFJlbmRlcmluZ0VuZ2luZS5rZXkoVUlLZXlzLkhJRERFTiksXG4gICAgb3BlcmF0aW9uc1xuICApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaGlkZGVuKCkge1xuICByZXR1cm4gaGlkZU9uKFxuICAgIE9wZXJhdGlvbktleXMuQ1JFQVRFLFxuICAgIE9wZXJhdGlvbktleXMuUkVBRCxcbiAgICBPcGVyYXRpb25LZXlzLlVQREFURSxcbiAgICBPcGVyYXRpb25LZXlzLkRFTEVURVxuICApO1xufVxuXG4vKipcbiAqIEFkZHMgdGhlIFVJRWxlbWVudCBkZWZpbml0aW9uIGFzIG1ldGFkYXRhIHRvIHRoZSBwcm9wZXJ0eSwgYWxsb3dpbmcgaXQgdG8gYmUgcmVhZCBieSBhbnkge0BsaW5rIFJlbmRlclN0cmF0ZWd5fVxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSB0YWcgVGhlIGNvbXBvbmVudC9IVE1MIGVsZW1lbnQgdGFnIG5hbWVcbiAqIEBwYXJhbSB7e319IFtwcm9wc10gVGhlIHByb3BlcnRpZXMgdG8gcGFzcyB0byB0aGF0IGNvbXBvbmVudC9IVE1MIEVsZW1lbnRcbiAqIEBwYXJhbSBzZXJpYWxpemVcbiAqXG4gKiBAZGVjb3JhdG9yIHVpZWxlbWVudFxuICpcbiAqIEBjYXRlZ29yeSBEZWNvcmF0b3JzXG4gKiBAc3ViY2F0ZWdvcnkgdWktZGVjb3JhdG9yc1xuICovXG5leHBvcnQgZnVuY3Rpb24gdWllbGVtZW50KFxuICB0YWc6IHN0cmluZyxcbiAgcHJvcHM/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICBzZXJpYWxpemU6IGJvb2xlYW4gPSBmYWxzZVxuKSB7XG4gIHJldHVybiAob3JpZ2luYWw6IGFueSwgcHJvcGVydHlLZXk/OiBhbnkpID0+IHtcbiAgICBjb25zdCBtZXRhZGF0YTogVUlFbGVtZW50TWV0YWRhdGEgPSB7XG4gICAgICB0YWc6IHRhZyxcbiAgICAgIHNlcmlhbGl6ZTogc2VyaWFsaXplLFxuICAgICAgcHJvcHM6IE9iamVjdC5hc3NpZ24oXG4gICAgICAgIHtcbiAgICAgICAgICBuYW1lOiBwcm9wZXJ0eUtleSxcbiAgICAgICAgfSxcbiAgICAgICAgcHJvcHMgfHwge31cbiAgICAgICksXG4gICAgfTtcblxuICAgIHJldHVybiBwcm9wTWV0YWRhdGEoUmVuZGVyaW5nRW5naW5lLmtleShVSUtleXMuRUxFTUVOVCksIG1ldGFkYXRhKShcbiAgICAgIG9yaWdpbmFsLFxuICAgICAgcHJvcGVydHlLZXlcbiAgICApO1xuICB9O1xufVxuXG4vKipcbiAqIEFkZHMgdGhlIFVJUHJvcCBkZWZpbml0aW9uIGFzIG1ldGFkYXRhIHRvIHRoZSBwcm9wZXJ0eSwgYWxsb3dpbmcgaXQgdG8gYmUgcmVhZCBieSBhbnkge0BsaW5rIFJlbmRlclN0cmF0ZWd5fVxuICpcbiAqIHRoaXMgcmVxdWlyZXMgYSAnQHVpbW9kZWwnIHdpdGggYSBkZWZpbmVkIHRhZ1xuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBbcHJvcE5hbWVdIHRoZSBwcm9wZXJ0eSBuYW1lIHRoYXQgd2lsbCBiZSBwYXNzZWQgdG8gdGhlIGNvbXBvbmVudC4gZGVmYXVsdHMgdG8gdGhlIFByb3BlcnR5S2V5XG4gKlxuICogQGRlY29yYXRvciB1aXByb3BcbiAqXG4gKiBAY2F0ZWdvcnkgRGVjb3JhdG9yc1xuICogQHN1YmNhdGVnb3J5IHVpLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVpcHJvcChcbiAgcHJvcE5hbWU6IHN0cmluZyB8IHVuZGVmaW5lZCA9IHVuZGVmaW5lZCxcbiAgc3RyaW5naWZ5OiBib29sZWFuID0gZmFsc2Vcbikge1xuICByZXR1cm4gKHRhcmdldDogYW55LCBwcm9wZXJ0eUtleTogc3RyaW5nKSA9PiB7XG4gICAgY29uc3QgbWV0YWRhdGE6IFVJUHJvcE1ldGFkYXRhID0ge1xuICAgICAgbmFtZTogcHJvcE5hbWUgfHwgcHJvcGVydHlLZXksXG4gICAgICBzdHJpbmdpZnk6IHN0cmluZ2lmeSxcbiAgICB9O1xuICAgIHByb3BNZXRhZGF0YShSZW5kZXJpbmdFbmdpbmUua2V5KFVJS2V5cy5QUk9QKSwgbWV0YWRhdGEpKFxuICAgICAgdGFyZ2V0LFxuICAgICAgcHJvcGVydHlLZXlcbiAgICApO1xuICB9O1xufVxuXG5cbi8qKlxuICogQWRkcyB0aGUgVUlMaXN0UHJvcCBkZWZpbml0aW9uIGFzIG1ldGFkYXRhIHRvIHRoZSBwcm9wZXJ0eSwgYWxsb3dpbmcgaXQgdG8gYmUgcmVhZCBieSBhbnkge0BsaW5rIFJlbmRlclN0cmF0ZWd5fVxuICpcbiAqIHRoaXMgcmVxdWlyZXMgYSAnQHVpbGlzdGl0ZW0nIHdpdGggYSBkZWZpbmVkIHRhZ1xuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBbcHJvcE5hbWVdIHRoZSBwcm9wZXJ0eSBuYW1lIHRoYXQgd2lsbCBiZSBwYXNzZWQgdG8gdGhlIGNvbXBvbmVudC4gZGVmYXVsdHMgdG8gdGhlIFByb3BlcnR5S2V5XG4gKlxuICogQGRlY29yYXRvciB1aXByb3BcbiAqXG4gKiBAY2F0ZWdvcnkgRGVjb3JhdG9yc1xuICogQHN1YmNhdGVnb3J5IHVpLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVpbGlzdHByb3AoXG4gIHByb3BOYW1lOiBzdHJpbmcgfCB1bmRlZmluZWQgPSB1bmRlZmluZWQsXG4gIHByb3BzPzogUmVjb3JkPHN0cmluZywgYW55Pixcbikge1xuICByZXR1cm4gKHRhcmdldDogYW55LCBwcm9wZXJ0eUtleTogc3RyaW5nKSA9PiB7XG4gICAgICBjb25zdCBtZXRhZGF0YTogUGFydGlhbDxVSUxpc3RQcm9wTWV0YWRhdGE+ID0ge1xuICAgICAgbmFtZTogcHJvcE5hbWUgfHwgcHJvcGVydHlLZXksXG4gICAgICBwcm9wczogcHJvcHMgfHwge31cbiAgICB9O1xuICAgIHByb3BNZXRhZGF0YShSZW5kZXJpbmdFbmdpbmUua2V5KFVJS2V5cy5VSUxJU1RQUk9QKSwgbWV0YWRhdGEpKFxuICAgICAgdGFyZ2V0LFxuICAgICAgcHJvcGVydHlLZXlcbiAgICApO1xuICB9O1xufVxuIl19
|
|
299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/ui/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"reflect-metadata\";\nimport { UIKeys } from \"./constants\";\nimport { propMetadata } from \"@decaf-ts/decorator-validation\";\nimport {\n  CrudOperationKeys,\n  UIElementMetadata,\n  UIListPropMetadata,\n  UIPropMetadata,\n} from \"./types\";\nimport { RenderingEngine } from \"./Rendering\";\nimport { OperationKeys } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Decorator that hides a property during specific CRUD operations\n * @summary Controls property visibility based on operation type\n * This decorator allows you to specify which CRUD operations should hide a property\n * in the UI. The property will only be visible during operations not specified.\n *\n * @param operations - The CRUD operations during which the property should be hidden\n * @return {Function} A property decorator function\n *\n * @function hideOn\n * @category Property Decorators\n *\n * @example\n * // Hide the password field during READ operations\n * class User {\n *   @attribute()\n *   username: string;\n *\n *   @attribute()\n *   @hideOn(OperationKeys.READ)\n *   password: string;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant hideOn\n *   participant RenderingEngine\n *   participant UI\n *   Model->>hideOn: Apply to property\n *   hideOn->>Model: Add hidden metadata\n *   RenderingEngine->>Model: Check if property should be hidden\n *   Model->>RenderingEngine: Return hidden operations\n *   RenderingEngine->>UI: Render or hide based on current operation\n */\nexport function hideOn(...operations: CrudOperationKeys[]) {\n  return propMetadata<CrudOperationKeys[]>(\n    RenderingEngine.key(UIKeys.HIDDEN),\n    operations\n  );\n}\n\n/**\n * @description Decorator that completely hides a property in all UI operations\n * @summary Makes a property invisible in all CRUD operations\n * This decorator is a convenience wrapper around hideOn that hides a property\n * during all CRUD operations (CREATE, READ, UPDATE, DELETE).\n *\n * @return {Function} A property decorator function\n *\n * @function hidden\n * @category Property Decorators\n *\n * @example\n * // Completely hide the internalId field in the UI\n * class Product {\n *   @attribute()\n *   name: string;\n *\n *   @attribute()\n *   @hidden()\n *   internalId: string;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant hidden\n *   participant hideOn\n *   participant RenderingEngine\n *   Model->>hidden: Apply to property\n *   hidden->>hideOn: Call with all operations\n *   hideOn->>Model: Add hidden metadata\n *   RenderingEngine->>Model: Check if property should be hidden\n *   Model->>RenderingEngine: Return all operations\n *   RenderingEngine->>UI: Always hide property\n */\nexport function hidden() {\n  return hideOn(\n    OperationKeys.CREATE,\n    OperationKeys.READ,\n    OperationKeys.UPDATE,\n    OperationKeys.DELETE\n  );\n}\n\n/**\n * @description Decorator that specifies how a property should be rendered as a UI element\n * @summary Maps a model property to a specific UI element with custom properties\n * This decorator allows you to define which HTML element or component should be used\n * to render a specific property, along with any additional properties to pass to that element.\n *\n * @param {string} tag The HTML element or component tag name to use for rendering\n * @param {Record<string, any>} [props] Additional properties to pass to the element\n * @param {boolean} [serialize=false] Whether the property should be serialized\n * @return {Function} A property decorator function\n *\n * @function uielement\n * @category Property Decorators\n *\n * @example\n * // Render a property as a text input\n * class LoginForm {\n *   @attribute()\n *   @uielement('input', { type: 'text', placeholder: 'Enter username' })\n *   username: string;\n *\n *   @attribute()\n *   @uielement('input', { type: 'password', placeholder: 'Enter password' })\n *   password: string;\n *\n *   @attribute()\n *   @uielement('button', { class: 'btn-primary' })\n *   submit: string = 'Login';\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant uielement\n *   participant RenderingEngine\n *   participant UI\n *   Model->>uielement: Apply to property\n *   uielement->>Model: Add element metadata\n *   RenderingEngine->>Model: Get element metadata\n *   Model->>RenderingEngine: Return tag and props\n *   RenderingEngine->>UI: Render with specified element\n */\nexport function uielement(\n  tag: string,\n  props?: Record<string, any>,\n  serialize: boolean = false\n) {\n  return (original: any, propertyKey?: any) => {\n    const metadata: UIElementMetadata = {\n      tag: tag,\n      serialize: serialize,\n      props: Object.assign({}, props || {}, {\n        name: propertyKey,\n      }),\n    };\n\n    return propMetadata(RenderingEngine.key(UIKeys.ELEMENT), metadata)(\n      original,\n      propertyKey\n    );\n  };\n}\n\n/**\n * @description Decorator that maps a model property to a UI component property\n * @summary Specifies how a property should be passed to a UI component\n * This decorator allows you to define how a model property should be mapped to\n * a property of the UI component when rendering. It requires the class to be\n * decorated with @uimodel.\n *\n * @param {string} [propName] The name of the property to pass to the component (defaults to the property key)\n * @param {boolean} [stringify=false] Whether to stringify the property value\n * @return {Function} A property decorator function\n *\n * @function uiprop\n * @category Property Decorators\n *\n * @example\n * // Map model properties to component properties\n * @uimodel('user-profile')\n * class UserProfile {\n *   @attribute()\n *   @uiprop() // Will be passed as 'fullName' to the component\n *   fullName: string;\n *\n *   @attribute()\n *   @uiprop('userEmail') // Will be passed as 'userEmail' to the component\n *   email: string;\n *\n *   @attribute()\n *   @uiprop('userData', true) // Will be passed as stringified JSON\n *   userData: Record<string, any>;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant uiprop\n *   participant RenderingEngine\n *   participant Component\n *   Model->>uiprop: Apply to property\n *   uiprop->>Model: Add prop metadata\n *   RenderingEngine->>Model: Get prop metadata\n *   Model->>RenderingEngine: Return prop name and stringify flag\n *   RenderingEngine->>Component: Pass property with specified name\n */\nexport function uiprop(\n  propName: string | undefined = undefined,\n  stringify: boolean = false\n) {\n  return (target: any, propertyKey: string) => {\n    const metadata: UIPropMetadata = {\n      name: propName || propertyKey,\n      stringify: stringify,\n    };\n    propMetadata(RenderingEngine.key(UIKeys.PROP), metadata)(\n      target,\n      propertyKey\n    );\n  };\n}\n\n/**\n * @description Decorator that maps a model property to a UI component property\n * @summary Specifies how a property should be passed to a UI component\n * This decorator allows you to define how a model property should be mapped to\n * a property of the UI component when rendering. It requires the class to be\n * decorated with @uimodel.\n *\n * @param {string} [propName] The name of the property to pass to the component (defaults to the property key)\n * @param {boolean} [stringify=false] Whether to stringify the property value\n * @return {Function} A property decorator function\n *\n * @function uiprop\n * @category Property Decorators\n *\n * @example\n * // Map model properties to component properties\n * @uimodel('user-profile')\n * class UserProfile {\n *   @attribute()\n *   @uiprop() // Will be passed as 'fullName' to the component\n *   fullName: string;\n *\n *   @attribute()\n *   @uiprop('userEmail') // Will be passed as 'userEmail' to the component\n *   email: string;\n *\n *   @attribute()\n *   @uiprop('userData', true) // Will be passed as stringified JSON\n *   userData: Record<string, any>;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant uiprop\n *   participant RenderingEngine\n *   participant Component\n *   Model->>uiprop: Apply to property\n *   uiprop->>Model: Add prop metadata\n *   RenderingEngine->>Model: Get prop metadata\n *   Model->>RenderingEngine: Return prop name and stringify flag\n *   RenderingEngine->>Component: Pass property with specified name\n */\nexport function uichild(\n  propName: string | undefined = undefined,\n  stringify: boolean = false,\n  tag?: string\n) {\n  return (target: any, propertyKey: string) => {\n    const metadata: UIPropMetadata = {\n      name: propName || propertyKey,\n      stringify: stringify,\n      tag: tag,\n    } as any;\n    propMetadata(RenderingEngine.key(UIKeys.CHILD), metadata)(\n      target,\n      propertyKey\n    );\n  };\n}\n\n/**\n * @description Decorator that maps a model property to a list item component\n * @summary Specifies how a property should be rendered in a list context\n * This decorator allows you to define how a model property containing a list\n * should be rendered. It requires the class to be decorated with @uilistitem.\n *\n * @param {string} [propName] The name of the property to pass to the list component (defaults to the property key)\n * @param {Record<string, any>} [props] Additional properties to pass to the list container\n * @return {Function} A property decorator function\n *\n * @function uilistprop\n * @category Property Decorators\n *\n * @example\n * // Define a list property with custom rendering\n * @uimodel('todo-list')\n * class TodoList {\n *   @attribute()\n *   title: string;\n *\n *   @attribute()\n *   @uilistprop('items', { class: 'todo-items-container' })\n *   items: TodoItem[];\n * }\n *\n * @uilistitem('li', { class: 'todo-item' })\n * class TodoItem extends Model {\n *   @attribute()\n *   text: string;\n *\n *   @attribute()\n *   completed: boolean;\n * }\n *\n * @mermaid\n * sequenceDiagram\n *   participant Model\n *   participant uilistprop\n *   participant RenderingEngine\n *   participant ListContainer\n *   participant ListItems\n *   Model->>uilistprop: Apply to property\n *   uilistprop->>Model: Add list prop metadata\n *   RenderingEngine->>Model: Get list prop metadata\n *   Model->>RenderingEngine: Return prop name and container props\n *   RenderingEngine->>ListContainer: Create container with props\n *   RenderingEngine->>ListItems: Render each item using @uilistitem\n *   ListContainer->>RenderingEngine: Return rendered list\n */\nexport function uilistprop(\n  propName: string | undefined = undefined,\n  props?: Record<string, any>\n) {\n  return (target: any, propertyKey: string) => {\n    const metadata: Partial<UIListPropMetadata> = {\n      name: propName || propertyKey,\n      props: props || {},\n    };\n    propMetadata(RenderingEngine.key(UIKeys.UILISTPROP), metadata)(\n      target,\n      propertyKey\n    );\n  };\n}\n"]}
|
package/lib/esm/ui/errors.d.ts
CHANGED
|
@@ -1,4 +1,32 @@
|
|
|
1
1
|
import { BaseError } from "@decaf-ts/db-decorators";
|
|
2
|
+
/**
|
|
3
|
+
* @description Error thrown when a rendering operation fails
|
|
4
|
+
* @summary Specialized error for rendering failures in UI components
|
|
5
|
+
* This error is thrown when the rendering engine encounters an error while
|
|
6
|
+
* attempting to render a UI component or model.
|
|
7
|
+
*
|
|
8
|
+
* @param {string|Error} msg The error message or original error
|
|
9
|
+
*
|
|
10
|
+
* @class RenderingError
|
|
11
|
+
* @extends BaseError
|
|
12
|
+
* @category Errors
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* // Throwing a rendering error
|
|
16
|
+
* try {
|
|
17
|
+
* // Rendering code that might fail
|
|
18
|
+
* if (!component.canRender()) {
|
|
19
|
+
* throw new RenderingError('Component cannot be rendered');
|
|
20
|
+
* }
|
|
21
|
+
* } catch (error) {
|
|
22
|
+
* console.error('Rendering failed:', error.message);
|
|
23
|
+
* }
|
|
24
|
+
*/
|
|
2
25
|
export declare class RenderingError extends BaseError {
|
|
26
|
+
/**
|
|
27
|
+
* @description Creates a new RenderingError instance
|
|
28
|
+
* @summary Initializes the error with a message or original error
|
|
29
|
+
* @param {string|Error} msg The error message or original error
|
|
30
|
+
*/
|
|
3
31
|
constructor(msg: string | Error);
|
|
4
32
|
}
|
package/lib/esm/ui/errors.js
CHANGED
|
@@ -1,7 +1,35 @@
|
|
|
1
1
|
import { BaseError } from "@decaf-ts/db-decorators";
|
|
2
|
+
/**
|
|
3
|
+
* @description Error thrown when a rendering operation fails
|
|
4
|
+
* @summary Specialized error for rendering failures in UI components
|
|
5
|
+
* This error is thrown when the rendering engine encounters an error while
|
|
6
|
+
* attempting to render a UI component or model.
|
|
7
|
+
*
|
|
8
|
+
* @param {string|Error} msg The error message or original error
|
|
9
|
+
*
|
|
10
|
+
* @class RenderingError
|
|
11
|
+
* @extends BaseError
|
|
12
|
+
* @category Errors
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* // Throwing a rendering error
|
|
16
|
+
* try {
|
|
17
|
+
* // Rendering code that might fail
|
|
18
|
+
* if (!component.canRender()) {
|
|
19
|
+
* throw new RenderingError('Component cannot be rendered');
|
|
20
|
+
* }
|
|
21
|
+
* } catch (error) {
|
|
22
|
+
* console.error('Rendering failed:', error.message);
|
|
23
|
+
* }
|
|
24
|
+
*/
|
|
2
25
|
export class RenderingError extends BaseError {
|
|
26
|
+
/**
|
|
27
|
+
* @description Creates a new RenderingError instance
|
|
28
|
+
* @summary Initializes the error with a message or original error
|
|
29
|
+
* @param {string|Error} msg The error message or original error
|
|
30
|
+
*/
|
|
3
31
|
constructor(msg) {
|
|
4
32
|
super(RenderingError.name, msg);
|
|
5
33
|
}
|
|
6
34
|
}
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VpL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFcEQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FzQkc7QUFDSCxNQUFNLE9BQU8sY0FBZSxTQUFRLFNBQVM7SUFDM0M7Ozs7T0FJRztJQUNILFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDbEMsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUVycm9yIH0gZnJvbSBcIkBkZWNhZi10cy9kYi1kZWNvcmF0b3JzXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEVycm9yIHRocm93biB3aGVuIGEgcmVuZGVyaW5nIG9wZXJhdGlvbiBmYWlsc1xuICogQHN1bW1hcnkgU3BlY2lhbGl6ZWQgZXJyb3IgZm9yIHJlbmRlcmluZyBmYWlsdXJlcyBpbiBVSSBjb21wb25lbnRzXG4gKiBUaGlzIGVycm9yIGlzIHRocm93biB3aGVuIHRoZSByZW5kZXJpbmcgZW5naW5lIGVuY291bnRlcnMgYW4gZXJyb3Igd2hpbGVcbiAqIGF0dGVtcHRpbmcgdG8gcmVuZGVyIGEgVUkgY29tcG9uZW50IG9yIG1vZGVsLlxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfEVycm9yfSBtc2cgVGhlIGVycm9yIG1lc3NhZ2Ugb3Igb3JpZ2luYWwgZXJyb3JcbiAqXG4gKiBAY2xhc3MgUmVuZGVyaW5nRXJyb3JcbiAqIEBleHRlbmRzIEJhc2VFcnJvclxuICogQGNhdGVnb3J5IEVycm9yc1xuICpcbiAqIEBleGFtcGxlXG4gKiAvLyBUaHJvd2luZyBhIHJlbmRlcmluZyBlcnJvclxuICogdHJ5IHtcbiAqICAgLy8gUmVuZGVyaW5nIGNvZGUgdGhhdCBtaWdodCBmYWlsXG4gKiAgIGlmICghY29tcG9uZW50LmNhblJlbmRlcigpKSB7XG4gKiAgICAgdGhyb3cgbmV3IFJlbmRlcmluZ0Vycm9yKCdDb21wb25lbnQgY2Fubm90IGJlIHJlbmRlcmVkJyk7XG4gKiAgIH1cbiAqIH0gY2F0Y2ggKGVycm9yKSB7XG4gKiAgIGNvbnNvbGUuZXJyb3IoJ1JlbmRlcmluZyBmYWlsZWQ6JywgZXJyb3IubWVzc2FnZSk7XG4gKiB9XG4gKi9cbmV4cG9ydCBjbGFzcyBSZW5kZXJpbmdFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gQ3JlYXRlcyBhIG5ldyBSZW5kZXJpbmdFcnJvciBpbnN0YW5jZVxuICAgKiBAc3VtbWFyeSBJbml0aWFsaXplcyB0aGUgZXJyb3Igd2l0aCBhIG1lc3NhZ2Ugb3Igb3JpZ2luYWwgZXJyb3JcbiAgICogQHBhcmFtIHtzdHJpbmd8RXJyb3J9IG1zZyBUaGUgZXJyb3IgbWVzc2FnZSBvciBvcmlnaW5hbCBlcnJvclxuICAgKi9cbiAgY29uc3RydWN0b3IobXNnOiBzdHJpbmcgfCBFcnJvcikge1xuICAgIHN1cGVyKFJlbmRlcmluZ0Vycm9yLm5hbWUsIG1zZyk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description Class representing an event handler
|
|
3
|
+
* @summary Defines the structure for handling events in the UI decorators system
|
|
4
|
+
* This class provides a foundation for managing and processing events that occur
|
|
5
|
+
* within the UI components generated by the decorators.
|
|
6
|
+
* @class EventHandler
|
|
7
|
+
* @memberOf module:ui-decorators/ui
|
|
8
|
+
*/
|
|
9
|
+
export declare class EventHandler {
|
|
10
|
+
/**
|
|
11
|
+
* @description Creates an instance of EventHandler
|
|
12
|
+
* @summary Initializes a new EventHandler object
|
|
13
|
+
* This constructor currently doesn't take any parameters, but it can be
|
|
14
|
+
* extended in the future to accept configuration options if needed.
|
|
15
|
+
*/
|
|
16
|
+
constructor();
|
|
17
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description Class representing an event handler
|
|
3
|
+
* @summary Defines the structure for handling events in the UI decorators system
|
|
4
|
+
* This class provides a foundation for managing and processing events that occur
|
|
5
|
+
* within the UI components generated by the decorators.
|
|
6
|
+
* @class EventHandler
|
|
7
|
+
* @memberOf module:ui-decorators/ui
|
|
8
|
+
*/
|
|
9
|
+
export class EventHandler {
|
|
10
|
+
/**
|
|
11
|
+
* @description Creates an instance of EventHandler
|
|
12
|
+
* @summary Initializes a new EventHandler object
|
|
13
|
+
* This constructor currently doesn't take any parameters, but it can be
|
|
14
|
+
* extended in the future to accept configuration options if needed.
|
|
15
|
+
*/
|
|
16
|
+
constructor() { }
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFuZGxlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdWkvaGFuZGxlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7R0FPRztBQUNILE1BQU0sT0FBTyxZQUFZO0lBQ3ZCOzs7OztPQUtHO0lBQ0gsZ0JBQWUsQ0FBQztDQUNqQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGRlc2NyaXB0aW9uIENsYXNzIHJlcHJlc2VudGluZyBhbiBldmVudCBoYW5kbGVyXG4gKiBAc3VtbWFyeSBEZWZpbmVzIHRoZSBzdHJ1Y3R1cmUgZm9yIGhhbmRsaW5nIGV2ZW50cyBpbiB0aGUgVUkgZGVjb3JhdG9ycyBzeXN0ZW1cbiAqIFRoaXMgY2xhc3MgcHJvdmlkZXMgYSBmb3VuZGF0aW9uIGZvciBtYW5hZ2luZyBhbmQgcHJvY2Vzc2luZyBldmVudHMgdGhhdCBvY2N1clxuICogd2l0aGluIHRoZSBVSSBjb21wb25lbnRzIGdlbmVyYXRlZCBieSB0aGUgZGVjb3JhdG9ycy5cbiAqIEBjbGFzcyBFdmVudEhhbmRsZXJcbiAqIEBtZW1iZXJPZiBtb2R1bGU6dWktZGVjb3JhdG9ycy91aVxuICovXG5leHBvcnQgY2xhc3MgRXZlbnRIYW5kbGVyIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBDcmVhdGVzIGFuIGluc3RhbmNlIG9mIEV2ZW50SGFuZGxlclxuICAgKiBAc3VtbWFyeSBJbml0aWFsaXplcyBhIG5ldyBFdmVudEhhbmRsZXIgb2JqZWN0XG4gICAqIFRoaXMgY29uc3RydWN0b3IgY3VycmVudGx5IGRvZXNuJ3QgdGFrZSBhbnkgcGFyYW1ldGVycywgYnV0IGl0IGNhbiBiZVxuICAgKiBleHRlbmRlZCBpbiB0aGUgZnV0dXJlIHRvIGFjY2VwdCBjb25maWd1cmF0aW9uIG9wdGlvbnMgaWYgbmVlZGVkLlxuICAgKi9cbiAgY29uc3RydWN0b3IoKSB7fVxufSJdfQ==
|
package/lib/esm/ui/index.d.ts
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @namespace ui-decorators.ui
|
|
3
|
-
* @memberOf ui-decorators
|
|
4
|
-
*/
|
|
5
1
|
export * from "./constants";
|
|
6
2
|
export * from "./decorators";
|
|
7
3
|
export * from "./errors";
|
|
8
4
|
export * from "./interfaces";
|
|
9
5
|
export * from "./Rendering";
|
|
10
6
|
export * from "./types";
|
|
7
|
+
export * from "./handlers";
|
|
11
8
|
export * from "./utils";
|
package/lib/esm/ui/index.js
CHANGED
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @namespace ui-decorators.ui
|
|
3
|
-
* @memberOf ui-decorators
|
|
4
|
-
*/
|
|
5
1
|
export * from "./constants";
|
|
6
2
|
export * from "./decorators";
|
|
7
3
|
export * from "./errors";
|
|
8
4
|
export * from "./interfaces";
|
|
9
5
|
export * from "./Rendering";
|
|
10
6
|
export * from "./types";
|
|
7
|
+
export * from "./handlers";
|
|
11
8
|
export * from "./utils";
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdWkvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RlY29yYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2Vycm9yc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vaW50ZXJmYWNlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vUmVuZGVyaW5nXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90eXBlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vaGFuZGxlcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxzXCI7XG4iXX0=
|
|
@@ -1,5 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description Interfaces for UI form components
|
|
3
|
+
* @summary Defines interfaces for form fields with CRUD operations
|
|
4
|
+
* This module contains interfaces that extend basic field properties with
|
|
5
|
+
* CRUD operation information for form generation.
|
|
6
|
+
* @module ui/interfaces
|
|
7
|
+
* @memberOf module:ui-decorators
|
|
8
|
+
*/
|
|
1
9
|
import { FieldProperties } from "./types";
|
|
2
10
|
import { CrudOperations } from "@decaf-ts/db-decorators";
|
|
11
|
+
/**
|
|
12
|
+
* @description Form field interface with CRUD operation information
|
|
13
|
+
* @summary Extends basic field properties with a specific CRUD operation
|
|
14
|
+
* This interface represents a form field that is associated with a specific
|
|
15
|
+
* CRUD operation (Create, Read, Update, Delete). It combines all the standard
|
|
16
|
+
* field properties with an operation property.
|
|
17
|
+
*
|
|
18
|
+
* @interface CrudFormField
|
|
19
|
+
* @extends FieldProperties
|
|
20
|
+
* @memberOf module:ui-decorators
|
|
21
|
+
*
|
|
22
|
+
* @property {CrudOperations} operation - The CRUD operation associated with this field
|
|
23
|
+
*/
|
|
3
24
|
export interface CrudFormField extends FieldProperties {
|
|
25
|
+
/**
|
|
26
|
+
* @description The CRUD operation associated with this field
|
|
27
|
+
* @summary Specifies which operation (Create, Read, Update, Delete) this field is for
|
|
28
|
+
*/
|
|
4
29
|
operation: CrudOperations;
|
|
5
30
|
}
|
package/lib/esm/ui/interfaces.js
CHANGED
|
@@ -1,2 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description Interfaces for UI form components
|
|
3
|
+
* @summary Defines interfaces for form fields with CRUD operations
|
|
4
|
+
* This module contains interfaces that extend basic field properties with
|
|
5
|
+
* CRUD operation information for form generation.
|
|
6
|
+
* @module ui/interfaces
|
|
7
|
+
* @memberOf module:ui-decorators
|
|
8
|
+
*/
|
|
1
9
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91aS9pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0dBT0ciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBJbnRlcmZhY2VzIGZvciBVSSBmb3JtIGNvbXBvbmVudHNcbiAqIEBzdW1tYXJ5IERlZmluZXMgaW50ZXJmYWNlcyBmb3IgZm9ybSBmaWVsZHMgd2l0aCBDUlVEIG9wZXJhdGlvbnNcbiAqIFRoaXMgbW9kdWxlIGNvbnRhaW5zIGludGVyZmFjZXMgdGhhdCBleHRlbmQgYmFzaWMgZmllbGQgcHJvcGVydGllcyB3aXRoXG4gKiBDUlVEIG9wZXJhdGlvbiBpbmZvcm1hdGlvbiBmb3IgZm9ybSBnZW5lcmF0aW9uLlxuICogQG1vZHVsZSB1aS9pbnRlcmZhY2VzXG4gKiBAbWVtYmVyT2YgbW9kdWxlOnVpLWRlY29yYXRvcnNcbiAqL1xuXG5pbXBvcnQgeyBGaWVsZFByb3BlcnRpZXMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHsgQ3J1ZE9wZXJhdGlvbnMgfSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRm9ybSBmaWVsZCBpbnRlcmZhY2Ugd2l0aCBDUlVEIG9wZXJhdGlvbiBpbmZvcm1hdGlvblxuICogQHN1bW1hcnkgRXh0ZW5kcyBiYXNpYyBmaWVsZCBwcm9wZXJ0aWVzIHdpdGggYSBzcGVjaWZpYyBDUlVEIG9wZXJhdGlvblxuICogVGhpcyBpbnRlcmZhY2UgcmVwcmVzZW50cyBhIGZvcm0gZmllbGQgdGhhdCBpcyBhc3NvY2lhdGVkIHdpdGggYSBzcGVjaWZpY1xuICogQ1JVRCBvcGVyYXRpb24gKENyZWF0ZSwgUmVhZCwgVXBkYXRlLCBEZWxldGUpLiBJdCBjb21iaW5lcyBhbGwgdGhlIHN0YW5kYXJkXG4gKiBmaWVsZCBwcm9wZXJ0aWVzIHdpdGggYW4gb3BlcmF0aW9uIHByb3BlcnR5LlxuICpcbiAqIEBpbnRlcmZhY2UgQ3J1ZEZvcm1GaWVsZFxuICogQGV4dGVuZHMgRmllbGRQcm9wZXJ0aWVzXG4gKiBAbWVtYmVyT2YgbW9kdWxlOnVpLWRlY29yYXRvcnNcbiAqXG4gKiBAcHJvcGVydHkge0NydWRPcGVyYXRpb25zfSBvcGVyYXRpb24gLSBUaGUgQ1JVRCBvcGVyYXRpb24gYXNzb2NpYXRlZCB3aXRoIHRoaXMgZmllbGRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDcnVkRm9ybUZpZWxkIGV4dGVuZHMgRmllbGRQcm9wZXJ0aWVzIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBUaGUgQ1JVRCBvcGVyYXRpb24gYXNzb2NpYXRlZCB3aXRoIHRoaXMgZmllbGRcbiAgICogQHN1bW1hcnkgU3BlY2lmaWVzIHdoaWNoIG9wZXJhdGlvbiAoQ3JlYXRlLCBSZWFkLCBVcGRhdGUsIERlbGV0ZSkgdGhpcyBmaWVsZCBpcyBmb3JcbiAgICovXG4gIG9wZXJhdGlvbjogQ3J1ZE9wZXJhdGlvbnM7XG59XG4iXX0=
|