@decaf-ts/ui-decorators 0.5.9 → 0.5.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/README.md +422 -12
  2. package/dist/ui-decorators.cjs +497 -51
  3. package/dist/ui-decorators.esm.cjs +497 -51
  4. package/lib/esm/index.d.ts +7 -3
  5. package/lib/esm/index.js +8 -4
  6. package/lib/esm/model/Renderable.d.ts +15 -0
  7. package/lib/esm/model/Renderable.js +1 -1
  8. package/lib/esm/model/decorators.d.ts +92 -14
  9. package/lib/esm/model/decorators.js +94 -16
  10. package/lib/esm/model/index.d.ts +0 -4
  11. package/lib/esm/model/index.js +1 -5
  12. package/lib/esm/model/model.d.ts +156 -50
  13. package/lib/esm/model/model.js +1 -1
  14. package/lib/esm/model/overrides.d.ts +8 -0
  15. package/lib/esm/model/overrides.js +19 -1
  16. package/lib/esm/ui/Rendering.js +15 -4
  17. package/lib/esm/ui/constants.d.ts +147 -4
  18. package/lib/esm/ui/constants.js +148 -5
  19. package/lib/esm/ui/decorators.d.ts +185 -21
  20. package/lib/esm/ui/decorators.js +189 -25
  21. package/lib/esm/ui/errors.d.ts +28 -0
  22. package/lib/esm/ui/errors.js +29 -1
  23. package/lib/esm/ui/index.d.ts +0 -4
  24. package/lib/esm/ui/index.js +1 -5
  25. package/lib/esm/ui/interfaces.d.ts +25 -0
  26. package/lib/esm/ui/interfaces.js +9 -1
  27. package/lib/esm/ui/types.d.ts +63 -5
  28. package/lib/esm/ui/types.js +9 -1
  29. package/lib/esm/ui/utils.d.ts +1 -1
  30. package/lib/esm/ui/utils.js +2 -2
  31. package/lib/index.cjs +8 -4
  32. package/lib/index.d.ts +7 -3
  33. package/lib/model/Renderable.cjs +1 -1
  34. package/lib/model/Renderable.d.ts +15 -0
  35. package/lib/model/decorators.cjs +94 -16
  36. package/lib/model/decorators.d.ts +92 -14
  37. package/lib/model/index.cjs +1 -5
  38. package/lib/model/index.d.ts +0 -4
  39. package/lib/model/model.cjs +1 -1
  40. package/lib/model/model.d.ts +156 -50
  41. package/lib/model/overrides.cjs +19 -1
  42. package/lib/model/overrides.d.ts +8 -0
  43. package/lib/ui/Rendering.cjs +15 -4
  44. package/lib/ui/constants.cjs +148 -5
  45. package/lib/ui/constants.d.ts +147 -4
  46. package/lib/ui/decorators.cjs +189 -25
  47. package/lib/ui/decorators.d.ts +185 -21
  48. package/lib/ui/errors.cjs +29 -1
  49. package/lib/ui/errors.d.ts +28 -0
  50. package/lib/ui/index.cjs +1 -5
  51. package/lib/ui/index.d.ts +0 -4
  52. package/lib/ui/interfaces.cjs +9 -1
  53. package/lib/ui/interfaces.d.ts +25 -0
  54. package/lib/ui/types.cjs +9 -1
  55. package/lib/ui/types.d.ts +63 -5
  56. package/lib/ui/utils.cjs +2 -2
  57. package/lib/ui/utils.d.ts +1 -1
  58. package/package.json +1 -1
@@ -1,7 +1,56 @@
1
+ /**
2
+ * @description Constants and enums for UI rendering and validation
3
+ * @summary Defines keys, mappings, and HTML5 input types for UI components
4
+ * This module provides constants used throughout the UI decorators library for
5
+ * rendering, validation, and HTML element generation.
6
+ * @module ui/constants
7
+ * @memberOf module:ui-decorators
8
+ */
1
9
  import { Constructor, Validator } from "@decaf-ts/decorator-validation";
2
10
  /**
3
- * @enum UIKeys
4
- * @category Constants
11
+ * @description Key constants used for UI metadata and rendering
12
+ * @summary Collection of string constants used as keys for UI-related metadata
13
+ * These keys are used throughout the library to store and retrieve metadata related to
14
+ * UI models, elements, properties, and validation rules.
15
+ *
16
+ * @typedef {Object} UIKeysType
17
+ * @property {string} REFLECT - Base reflection key for UI metadata
18
+ * @property {string} UIMODEL - Key for UI model metadata
19
+ * @property {string} RENDERED_BY - Key for specifying rendering engine
20
+ * @property {string} ELEMENT - Key for element metadata
21
+ * @property {string} PROP - Key for property metadata
22
+ * @property {string} NAME - Key for name attribute
23
+ * @property {string} NAME_PREFIX - Prefix for input names
24
+ * @property {string} CUSTOM_PROPS - Key for custom validation properties
25
+ * @property {string} UILISTITEM - Key for list item metadata
26
+ * @property {string} UILISTPROP - Key for list property metadata
27
+ * @property {string} TYPE - Key for type metadata
28
+ * @property {string} SUB_TYPE - Key for subtype metadata
29
+ * @property {string} HIDDEN - Key for hidden attribute
30
+ * @property {string} FORMAT - Key for format metadata
31
+ * @property {string} READ_ONLY - Key for readonly attribute
32
+ * @property {string} REQUIRED - Key for required validation
33
+ * @property {string} MIN - Key for minimum value validation
34
+ * @property {string} MIN_LENGTH - Key for minimum length validation
35
+ * @property {string} MAX - Key for maximum value validation
36
+ * @property {string} MAX_LENGTH - Key for maximum length validation
37
+ * @property {string} PATTERN - Key for pattern validation
38
+ * @property {string} URL - Key for URL validation
39
+ * @property {string} STEP - Key for step validation
40
+ * @property {string} DATE - Key for date validation
41
+ * @property {string} EMAIL - Key for email validation
42
+ * @property {string} PASSWORD - Key for password validation
43
+ * @property {string} EQUALS - Key for equality validation
44
+ * @property {string} DIFF - Key for difference validation
45
+ * @property {string} LESS_THAN - Key for less than validation
46
+ * @property {string} LESS_THAN_OR_EQUAL - Key for less than or equal validation
47
+ * @property {string} GREATER_THAN - Key for greater than validation
48
+ * @property {string} GREATER_THAN_OR_EQUAL - Key for greater than or equal validation
49
+ *
50
+ * @const UIKeys
51
+ * @type {UIKeysType}
52
+ * @readonly
53
+ * @memberOf module:ui-decorators
5
54
  */
6
55
  export declare const UIKeys: {
7
56
  REFLECT: string;
@@ -37,14 +86,97 @@ export declare const UIKeys: {
37
86
  GREATER_THAN: "greaterThan";
38
87
  GREATER_THAN_OR_EQUAL: "greaterThanOrEqual";
39
88
  };
89
+ /**
90
+ * @description Mapping of input types to their corresponding validators
91
+ * @summary Maps special input types to their validator classes
92
+ * This constant maps input types like email, URL, date, and password to their
93
+ * corresponding validator classes from the decorator-validation library.
94
+ *
95
+ * @typedef {Object.<string, Constructor<Validator>>} ValidatableByTypeMap
96
+ * @property {Constructor<EmailValidator>} email - Validator for email inputs
97
+ * @property {Constructor<URLValidator>} url - Validator for URL inputs
98
+ * @property {Constructor<DateValidator>} date - Validator for date inputs
99
+ * @property {Constructor<PasswordValidator>} password - Validator for password inputs
100
+ *
101
+ * @const ValidatableByType
102
+ * @type {ValidatableByTypeMap}
103
+ * @readonly
104
+ * @memberOf module:ui-decorators
105
+ */
40
106
  export declare const ValidatableByType: Record<string, Constructor<Validator>>;
41
107
  /**
42
- * @constant ValidatableByAttribute
108
+ * @description Mapping of validation attributes to their corresponding validators
109
+ * @summary Maps HTML validation attributes to their validator classes
110
+ * This constant maps HTML validation attributes like required, min, max, pattern, etc.
111
+ * to their corresponding validator classes from the decorator-validation library.
43
112
  *
44
- * @memberOf ui-decorators-web.ui
113
+ * @typedef {Object.<string, Constructor<Validator>>} ValidatableByAttributeMap
114
+ * @property {Constructor<RequiredValidator>} required - Validator for required fields
115
+ * @property {Constructor<MinValidator>} min - Validator for minimum value
116
+ * @property {Constructor<MaxValidator>} max - Validator for maximum value
117
+ * @property {Constructor<StepValidator>} step - Validator for step value
118
+ * @property {Constructor<MinLengthValidator>} minlength - Validator for minimum length
119
+ * @property {Constructor<MaxLengthValidator>} maxlength - Validator for maximum length
120
+ * @property {Constructor<PatternValidator>} pattern - Validator for regex pattern
121
+ * @property {Constructor<EqualsValidator>} equals - Validator for equality
122
+ * @property {Constructor<DiffValidator>} diff - Validator for difference
123
+ * @property {Constructor<LessThanValidator>} lessthan - Validator for less than comparison
124
+ * @property {Constructor<LessThanOrEqualValidator>} lessthanorequal - Validator for less than or equal comparison
125
+ * @property {Constructor<GreaterThanValidator>} greaterthan - Validator for greater than comparison
126
+ * @property {Constructor<GreaterThanOrEqualValidator>} greaterthanorequal - Validator for greater than or equal comparison
127
+ *
128
+ * @const ValidatableByAttribute
129
+ * @type {ValidatableByAttributeMap}
130
+ * @readonly
131
+ * @memberOf module:ui-decorators
45
132
  */
46
133
  export declare const ValidatableByAttribute: Record<string, Constructor<Validator>>;
134
+ /**
135
+ * @description Standard date format string for HTML5 date inputs
136
+ * @summary Format string for HTML5 date inputs (yyyy-MM-dd)
137
+ * This constant defines the standard date format string used for HTML5 date inputs.
138
+ *
139
+ * @const HTML5DateFormat
140
+ * @type {string}
141
+ * @readonly
142
+ * @memberOf module:ui-decorators
143
+ */
47
144
  export declare const HTML5DateFormat = "yyyy-MM-dd";
145
+ /**
146
+ * @description Collection of HTML5 input type values
147
+ * @summary Maps input type constants to their HTML attribute values
148
+ * This constant provides a mapping of input type constants to their corresponding
149
+ * HTML attribute values for use in form elements.
150
+ *
151
+ * @typedef {Object} HTML5InputTypesMap
152
+ * @property {string} BUTTON - Button input type
153
+ * @property {string} CHECKBOX - Checkbox input type
154
+ * @property {string} COLOR - Color picker input type
155
+ * @property {string} DATE - Date picker input type
156
+ * @property {string} DATETIME_LOCAL - Local datetime picker input type
157
+ * @property {string} EMAIL - Email input type with validation
158
+ * @property {string} FILE - File upload input type
159
+ * @property {string} HIDDEN - Hidden input type
160
+ * @property {string} IMAGE - Image input type
161
+ * @property {string} MONTH - Month picker input type
162
+ * @property {string} NUMBER - Numeric input type
163
+ * @property {string} PASSWORD - Password input type with masked text
164
+ * @property {string} RADIO - Radio button input type
165
+ * @property {string} RANGE - Range slider input type
166
+ * @property {string} RESET - Form reset button input type
167
+ * @property {string} SEARCH - Search input type
168
+ * @property {string} SUBMIT - Form submit button input type
169
+ * @property {string} TEL - Telephone number input type
170
+ * @property {string} TEXT - Basic text input type
171
+ * @property {string} TIME - Time picker input type
172
+ * @property {string} URL - URL input type with validation
173
+ * @property {string} WEEK - Week picker input type
174
+ *
175
+ * @const HTML5InputTypes
176
+ * @type {HTML5InputTypesMap}
177
+ * @readonly
178
+ * @memberOf module:ui-decorators
179
+ */
48
180
  export declare const HTML5InputTypes: {
49
181
  BUTTON: string;
50
182
  CHECKBOX: string;
@@ -69,4 +201,15 @@ export declare const HTML5InputTypes: {
69
201
  URL: "url";
70
202
  WEEK: string;
71
203
  };
204
+ /**
205
+ * @description Array of HTML5 input types that use checkboxes
206
+ * @summary List of input types that represent checkable controls
207
+ * This constant defines an array of HTML5 input types that represent
208
+ * checkable controls (checkbox and radio).
209
+ *
210
+ * @const HTML5CheckTypes
211
+ * @type {string[]}
212
+ * @readonly
213
+ * @memberOf module:ui-decorators
214
+ */
72
215
  export declare const HTML5CheckTypes: string[];
@@ -1,7 +1,56 @@
1
+ /**
2
+ * @description Constants and enums for UI rendering and validation
3
+ * @summary Defines keys, mappings, and HTML5 input types for UI components
4
+ * This module provides constants used throughout the UI decorators library for
5
+ * rendering, validation, and HTML element generation.
6
+ * @module ui/constants
7
+ * @memberOf module:ui-decorators
8
+ */
1
9
  import { DateValidator, DiffValidator, EmailValidator, EqualsValidator, GreaterThanOrEqualValidator, GreaterThanValidator, LessThanOrEqualValidator, LessThanValidator, MaxLengthValidator, MaxValidator, MinLengthValidator, MinValidator, ModelKeys, PasswordValidator, PatternValidator, RequiredValidator, StepValidator, URLValidator, ValidationKeys, } from "@decaf-ts/decorator-validation";
2
10
  /**
3
- * @enum UIKeys
4
- * @category Constants
11
+ * @description Key constants used for UI metadata and rendering
12
+ * @summary Collection of string constants used as keys for UI-related metadata
13
+ * These keys are used throughout the library to store and retrieve metadata related to
14
+ * UI models, elements, properties, and validation rules.
15
+ *
16
+ * @typedef {Object} UIKeysType
17
+ * @property {string} REFLECT - Base reflection key for UI metadata
18
+ * @property {string} UIMODEL - Key for UI model metadata
19
+ * @property {string} RENDERED_BY - Key for specifying rendering engine
20
+ * @property {string} ELEMENT - Key for element metadata
21
+ * @property {string} PROP - Key for property metadata
22
+ * @property {string} NAME - Key for name attribute
23
+ * @property {string} NAME_PREFIX - Prefix for input names
24
+ * @property {string} CUSTOM_PROPS - Key for custom validation properties
25
+ * @property {string} UILISTITEM - Key for list item metadata
26
+ * @property {string} UILISTPROP - Key for list property metadata
27
+ * @property {string} TYPE - Key for type metadata
28
+ * @property {string} SUB_TYPE - Key for subtype metadata
29
+ * @property {string} HIDDEN - Key for hidden attribute
30
+ * @property {string} FORMAT - Key for format metadata
31
+ * @property {string} READ_ONLY - Key for readonly attribute
32
+ * @property {string} REQUIRED - Key for required validation
33
+ * @property {string} MIN - Key for minimum value validation
34
+ * @property {string} MIN_LENGTH - Key for minimum length validation
35
+ * @property {string} MAX - Key for maximum value validation
36
+ * @property {string} MAX_LENGTH - Key for maximum length validation
37
+ * @property {string} PATTERN - Key for pattern validation
38
+ * @property {string} URL - Key for URL validation
39
+ * @property {string} STEP - Key for step validation
40
+ * @property {string} DATE - Key for date validation
41
+ * @property {string} EMAIL - Key for email validation
42
+ * @property {string} PASSWORD - Key for password validation
43
+ * @property {string} EQUALS - Key for equality validation
44
+ * @property {string} DIFF - Key for difference validation
45
+ * @property {string} LESS_THAN - Key for less than validation
46
+ * @property {string} LESS_THAN_OR_EQUAL - Key for less than or equal validation
47
+ * @property {string} GREATER_THAN - Key for greater than validation
48
+ * @property {string} GREATER_THAN_OR_EQUAL - Key for greater than or equal validation
49
+ *
50
+ * @const UIKeys
51
+ * @type {UIKeysType}
52
+ * @readonly
53
+ * @memberOf module:ui-decorators
5
54
  */
6
55
  export const UIKeys = {
7
56
  REFLECT: `${ModelKeys.REFLECT}.ui.`,
@@ -37,6 +86,23 @@ export const UIKeys = {
37
86
  GREATER_THAN: ValidationKeys.GREATER_THAN,
38
87
  GREATER_THAN_OR_EQUAL: ValidationKeys.GREATER_THAN_OR_EQUAL,
39
88
  };
89
+ /**
90
+ * @description Mapping of input types to their corresponding validators
91
+ * @summary Maps special input types to their validator classes
92
+ * This constant maps input types like email, URL, date, and password to their
93
+ * corresponding validator classes from the decorator-validation library.
94
+ *
95
+ * @typedef {Object.<string, Constructor<Validator>>} ValidatableByTypeMap
96
+ * @property {Constructor<EmailValidator>} email - Validator for email inputs
97
+ * @property {Constructor<URLValidator>} url - Validator for URL inputs
98
+ * @property {Constructor<DateValidator>} date - Validator for date inputs
99
+ * @property {Constructor<PasswordValidator>} password - Validator for password inputs
100
+ *
101
+ * @const ValidatableByType
102
+ * @type {ValidatableByTypeMap}
103
+ * @readonly
104
+ * @memberOf module:ui-decorators
105
+ */
40
106
  export const ValidatableByType = {
41
107
  [UIKeys.EMAIL]: EmailValidator,
42
108
  [UIKeys.URL]: URLValidator,
@@ -44,9 +110,30 @@ export const ValidatableByType = {
44
110
  [UIKeys.PASSWORD]: PasswordValidator,
45
111
  };
46
112
  /**
47
- * @constant ValidatableByAttribute
113
+ * @description Mapping of validation attributes to their corresponding validators
114
+ * @summary Maps HTML validation attributes to their validator classes
115
+ * This constant maps HTML validation attributes like required, min, max, pattern, etc.
116
+ * to their corresponding validator classes from the decorator-validation library.
48
117
  *
49
- * @memberOf ui-decorators-web.ui
118
+ * @typedef {Object.<string, Constructor<Validator>>} ValidatableByAttributeMap
119
+ * @property {Constructor<RequiredValidator>} required - Validator for required fields
120
+ * @property {Constructor<MinValidator>} min - Validator for minimum value
121
+ * @property {Constructor<MaxValidator>} max - Validator for maximum value
122
+ * @property {Constructor<StepValidator>} step - Validator for step value
123
+ * @property {Constructor<MinLengthValidator>} minlength - Validator for minimum length
124
+ * @property {Constructor<MaxLengthValidator>} maxlength - Validator for maximum length
125
+ * @property {Constructor<PatternValidator>} pattern - Validator for regex pattern
126
+ * @property {Constructor<EqualsValidator>} equals - Validator for equality
127
+ * @property {Constructor<DiffValidator>} diff - Validator for difference
128
+ * @property {Constructor<LessThanValidator>} lessthan - Validator for less than comparison
129
+ * @property {Constructor<LessThanOrEqualValidator>} lessthanorequal - Validator for less than or equal comparison
130
+ * @property {Constructor<GreaterThanValidator>} greaterthan - Validator for greater than comparison
131
+ * @property {Constructor<GreaterThanOrEqualValidator>} greaterthanorequal - Validator for greater than or equal comparison
132
+ *
133
+ * @const ValidatableByAttribute
134
+ * @type {ValidatableByAttributeMap}
135
+ * @readonly
136
+ * @memberOf module:ui-decorators
50
137
  */
51
138
  export const ValidatableByAttribute = {
52
139
  [UIKeys.REQUIRED]: RequiredValidator,
@@ -63,7 +150,52 @@ export const ValidatableByAttribute = {
63
150
  [UIKeys.GREATER_THAN]: GreaterThanValidator,
64
151
  [UIKeys.GREATER_THAN_OR_EQUAL]: GreaterThanOrEqualValidator,
65
152
  };
153
+ /**
154
+ * @description Standard date format string for HTML5 date inputs
155
+ * @summary Format string for HTML5 date inputs (yyyy-MM-dd)
156
+ * This constant defines the standard date format string used for HTML5 date inputs.
157
+ *
158
+ * @const HTML5DateFormat
159
+ * @type {string}
160
+ * @readonly
161
+ * @memberOf module:ui-decorators
162
+ */
66
163
  export const HTML5DateFormat = "yyyy-MM-dd";
164
+ /**
165
+ * @description Collection of HTML5 input type values
166
+ * @summary Maps input type constants to their HTML attribute values
167
+ * This constant provides a mapping of input type constants to their corresponding
168
+ * HTML attribute values for use in form elements.
169
+ *
170
+ * @typedef {Object} HTML5InputTypesMap
171
+ * @property {string} BUTTON - Button input type
172
+ * @property {string} CHECKBOX - Checkbox input type
173
+ * @property {string} COLOR - Color picker input type
174
+ * @property {string} DATE - Date picker input type
175
+ * @property {string} DATETIME_LOCAL - Local datetime picker input type
176
+ * @property {string} EMAIL - Email input type with validation
177
+ * @property {string} FILE - File upload input type
178
+ * @property {string} HIDDEN - Hidden input type
179
+ * @property {string} IMAGE - Image input type
180
+ * @property {string} MONTH - Month picker input type
181
+ * @property {string} NUMBER - Numeric input type
182
+ * @property {string} PASSWORD - Password input type with masked text
183
+ * @property {string} RADIO - Radio button input type
184
+ * @property {string} RANGE - Range slider input type
185
+ * @property {string} RESET - Form reset button input type
186
+ * @property {string} SEARCH - Search input type
187
+ * @property {string} SUBMIT - Form submit button input type
188
+ * @property {string} TEL - Telephone number input type
189
+ * @property {string} TEXT - Basic text input type
190
+ * @property {string} TIME - Time picker input type
191
+ * @property {string} URL - URL input type with validation
192
+ * @property {string} WEEK - Week picker input type
193
+ *
194
+ * @const HTML5InputTypes
195
+ * @type {HTML5InputTypesMap}
196
+ * @readonly
197
+ * @memberOf module:ui-decorators
198
+ */
67
199
  export const HTML5InputTypes = {
68
200
  BUTTON: "button",
69
201
  CHECKBOX: "checkbox",
@@ -88,8 +220,19 @@ export const HTML5InputTypes = {
88
220
  URL: UIKeys.URL,
89
221
  WEEK: "week",
90
222
  };
223
+ /**
224
+ * @description Array of HTML5 input types that use checkboxes
225
+ * @summary List of input types that represent checkable controls
226
+ * This constant defines an array of HTML5 input types that represent
227
+ * checkable controls (checkbox and radio).
228
+ *
229
+ * @const HTML5CheckTypes
230
+ * @type {string[]}
231
+ * @readonly
232
+ * @memberOf module:ui-decorators
233
+ */
91
234
  export const HTML5CheckTypes = [
92
235
  HTML5InputTypes.CHECKBOX,
93
236
  HTML5InputTypes.RADIO,
94
237
  ];
95
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VpL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsYUFBYSxFQUNiLGFBQWEsRUFDYixjQUFjLEVBQ2QsZUFBZSxFQUNmLDJCQUEyQixFQUMzQixvQkFBb0IsRUFDcEIsd0JBQXdCLEVBQ3hCLGlCQUFpQixFQUNqQixrQkFBa0IsRUFDbEIsWUFBWSxFQUNaLGtCQUFrQixFQUNsQixZQUFZLEVBQ1osU0FBUyxFQUNULGlCQUFpQixFQUNqQixnQkFBZ0IsRUFDaEIsaUJBQWlCLEVBQ2pCLGFBQWEsRUFDYixZQUFZLEVBQ1osY0FBYyxHQUVmLE1BQU0sZ0NBQWdDLENBQUM7QUFFeEM7OztHQUdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHO0lBQ3BCLE9BQU8sRUFBRSxHQUFHLFNBQVMsQ0FBQyxPQUFPLE1BQU07SUFDbkMsT0FBTyxFQUFFLFNBQVM7SUFDbEIsV0FBVyxFQUFFLGFBQWE7SUFDMUIsT0FBTyxFQUFFLFNBQVM7SUFDbEIsSUFBSSxFQUFFLE1BQU07SUFDWixJQUFJLEVBQUUsTUFBTTtJQUNaLFdBQVcsRUFBRSxRQUFRO0lBQ3JCLFlBQVksRUFBRSx1QkFBdUI7SUFFckMsVUFBVSxFQUFFLFlBQVk7SUFDeEIsVUFBVSxFQUFFLFVBQVU7SUFFdEIsSUFBSSxFQUFFLE1BQU07SUFDWixRQUFRLEVBQUUsU0FBUztJQUVuQixNQUFNLEVBQUUsUUFBUTtJQUNoQixNQUFNLEVBQUUsUUFBUTtJQUVoQixTQUFTLEVBQUUsVUFBVTtJQUNyQixRQUFRLEVBQUUsY0FBYyxDQUFDLFFBQVE7SUFDakMsR0FBRyxFQUFFLGNBQWMsQ0FBQyxHQUFHO0lBQ3ZCLFVBQVUsRUFBRSxjQUFjLENBQUMsVUFBVTtJQUNyQyxHQUFHLEVBQUUsY0FBYyxDQUFDLEdBQUc7SUFDdkIsVUFBVSxFQUFFLGNBQWMsQ0FBQyxVQUFVO0lB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QU0sZUFBZSxHQUFHO0lBQzdCLGVBQWUsQ0FBQyxRQUFRO0lBQ3hCLGVBQWUsQ0FBQyxLQUFLO0NBQ3RCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb25zdHJ1Y3RvcixcbiAgRGF0ZVZhbGlkYXRvcixcbiAgRGlmZlZhbGlkYXRvcixcbiAgRW1haWxWYWxpZGF0b3IsXG4gIEVxdWFsc1ZhbGlkYXRvcixcbiAgR3JlYXRlclRoYW5PckVxdWFsVmFsaWRhdG9yLFxuICBHcmVhdGVyVGhhblZhbGlkYXRvcixcbiAgTGVzc1RoYW5PckVxdWFsVmFsaWRhdG9yLFxuICBMZXNzVGhhblZhbGlkYXRvcixcbiAgTWF4TGVuZ3RoVmFsaWRhdG9yLFxuICBNYXhWYWxpZGF0b3IsXG4gIE1pbkxlbmd0aFZhbGlkYXRvcixcbiAgTWluVmFsaWRhdG9yLFxuICBNb2RlbEtleXMsXG4gIFBhc3N3b3JkVmFsaWRhdG9yLFxuICBQYXR0ZXJuVmFsaWRhdG9yLFxuICBSZXF1aXJlZFZhbGlkYXRvcixcbiAgU3RlcFZhbGlkYXRvcixcbiAgVVJMVmFsaWRhdG9yLFxuICBWYWxpZGF0aW9uS2V5cyxcbiAgVmFsaWRhdG9yLFxufSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5cbi8qKlxuICogQGVudW0gVUlLZXlzXG4gKiBAY2F0ZWdvcnkgQ29uc3RhbnRzXG4gKi9cbmV4cG9ydCBjb25zdCBVSUtleXMgPSB7XG4gIFJFRkxFQ1Q6IGAke01vZGVsS2V5cy5SRUZMRUNUfS51aS5gLFxuICBVSU1PREVMOiBcInVpbW9kZWxcIixcbiAgUkVOREVSRURfQlk6IFwicmVuZGVyZWQtYnlcIixcbiAgRUxFTUVOVDogXCJlbGVtZW50XCIsXG4gIFBST1A6IFwicHJvcFwiLFxuICBOQU1FOiBcIm5hbWVcIixcbiAgTkFNRV9QUkVGSVg6IFwiaW5wdXQtXCIsXG4gIENVU1RPTV9QUk9QUzogXCJjdXN0b21WYWxpZGF0aW9uUHJvcHNcIixcblxuICBVSUxJU1RJVEVNOiBcInVpbGlzdGl0ZW1cIixcbiAgVUlMSVNUUFJPUDogXCJsaXN0cHJvcFwiLFxuXG4gIFRZUEU6IFwidHlwZVwiLFxuICBTVUJfVFlQRTogXCJzdWJ0eXBlXCIsXG5cbiAgSElEREVOOiBcImhpZGRlblwiLFxuICBGT1JNQVQ6IFwiZm9ybWF0XCIsXG5cbiAgUkVBRF9PTkxZOiBcInJlYWRvbmx5XCIsXG4gIFJFUVVJUkVEOiBWYWxpZGF0aW9uS2V5cy5SRVFVSVJFRCxcbiAgTUlOOiBWYWxpZGF0aW9uS2V5cy5NSU4sXG4gIE1JTl9MRU5HVEg6IFZhbGlkYXRpb25LZXlzLk1JTl9MRU5HVEgsXG4gIE1BWDogVmFsaWRhdGlvbktleXMuTUFYLFxuICBNQVhfTEVOR1RIOiBWYWxpZGF0aW9uS2V5cy5NQVhfTEVOR1RILFxuICBQQVRURVJOOiBWYWxpZGF0aW9uS2V5cy5QQVRURVJOLFxuICBVUkw6IFZhbGlkYXRpb25LZXlzLlVSTCxcbiAgU1RFUDogVmFsaWRhdGlvbktleXMuU1RFUCxcbiAgREFURTogVmFsaWRhdGlvbktleXMuREFURSxcbiAgRU1BSUw6IFZhbGlkYXRpb25LZXlzLkVNQUlMLFxuICBQQVNTV09SRDogVmFsaWRhdGlvbktleXMuUEFTU1dPUkQsXG4gIEVRVUFMUzogVmFsaWRhdGlvbktleXMuRVFVQUxTLFxuICBESUZGOiBWYWxpZGF0aW9uS2V5cy5ESUZGLFxuICBMRVNTX1RIQU46IFZhbGlkYXRpb25LZXlzLkxFU1NfVEhBTixcbiAgTEVTU19USEFOX09SX0VRVUFMOiBWYWxpZGF0aW9uS2V5cy5MRVNTX1RIQU5fT1JfRVFVQUwsXG4gIEdSRUFURVJfVEhBTjogVmFsaWRhdGlvbktleXMuR1JFQVRFUl9USEFOLFxuICBHUkVBVEVSX1RIQU5fT1JfRVFVQUw6IFZhbGlkYXRpb25LZXlzLkdSRUFURVJfVEhBTl9PUl9FUVVBTCxcbn07XG5cbmV4cG9ydCBjb25zdCBWYWxpZGF0YWJsZUJ5VHlwZTogUmVjb3JkPHN0cmluZywgQ29uc3RydWN0b3I8VmFsaWRhdG9yPj4gPSB7XG4gIFtVSUtleXMuRU1BSUxdOiBFbWFpbFZhbGlkYXRvcixcbiAgW1VJS2V5cy5VUkxdOiBVUkxWYWxpZGF0b3IsXG4gIFtVSUtleXMuREFURV06IERhdGVWYWxpZGF0b3IsXG4gIFtVSUtleXMuUEFTU1dPUkRdOiBQYXNzd29yZFZhbGlkYXRvcixcbn07XG5cbi8qKlxuICogQGNvbnN0YW50IFZhbGlkYXRhYmxlQnlBdHRyaWJ1dGVcbiAqXG4gKiBAbWVtYmVyT2YgdWktZGVjb3JhdG9ycy13ZWIudWlcbiAqL1xuZXhwb3J0IGNvbnN0IFZhbGlkYXRhYmxlQnlBdHRyaWJ1dGU6IFJlY29yZDxzdHJpbmcsIENvbnN0cnVjdG9yPFZhbGlkYXRvcj4+ID0ge1xuICBbVUlLZXlzLlJFUVVJUkVEXTogUmVxdWlyZWRWYWxpZGF0b3IsXG4gIFtVSUtleXMuTUlOXTogTWluVmFsaWRhdG9yLFxuICBbVUlLZXlzLk1BWF06IE1heFZhbGlkYXRvcixcbiAgW1VJS2V5cy5TVEVQXTogU3RlcFZhbGlkYXRvcixcbiAgW1VJS2V5cy5NSU5fTEVOR1RIXTogTWluTGVuZ3RoVmFsaWRhdG9yLFxuICBbVUlLZXlzLk1BWF9MRU5HVEhdOiBNYXhMZW5ndGhWYWxpZGF0b3IsXG4gIFtVSUtleXMuUEFUVEVSTl06IFBhdHRlcm5WYWxpZGF0b3IsXG4gIFtVSUtleXMuRVFVQUxTXTogRXF1YWxzVmFsaWRhdG9yLFxuICBbVUlLZXlzLkRJRkZdOiBEaWZmVmFsaWRhdG9yLFxuICBbVUlLZXlzLkxFU1NfVEhBTl06IExlc3NUaGFuVmFsaWRhdG9yLFxuICBbVUlLZXlzLkxFU1NfVEhBTl9PUl9FUVVBTF06IExlc3NUaGFuT3JFcXVhbFZhbGlkYXRvcixcbiAgW1VJS2V5cy5HUkVBVEVSX1RIQU5dOiBHcmVhdGVyVGhhblZhbGlkYXRvcixcbiAgW1VJS2V5cy5HUkVBVEVSX1RIQU5fT1JfRVFVQUxdOiBHcmVhdGVyVGhhbk9yRXF1YWxWYWxpZGF0b3IsXG59O1xuXG5leHBvcnQgY29uc3QgSFRNTDVEYXRlRm9ybWF0ID0gXCJ5eXl5LU1NLWRkXCI7XG5cbmV4cG9ydCBjb25zdCBIVE1MNUlucHV0VHlwZXMgPSB7XG4gIEJVVFRPTjogXCJidXR0b25cIixcbiAgQ0hFQ0tCT1g6IFwiY2hlY2tib3hcIixcbiAgQ09MT1I6IFwiY29sb3JcIixcbiAgREFURTogVUlLZXlzLkRBVEUsXG4gIERBVEVUSU1FX0xPQ0FMOiBcImRhdGV0aW1lLWxvY2FsXCIsXG4gIEVNQUlMOiBVSUtleXMuRU1BSUwsXG4gIEZJTEU6IFwiZmlsZVwiLFxuICBISURERU46IFwiaGlkZGVuXCIsXG4gIElNQUdFOiBcImltYWdlXCIsXG4gIE1PTlRIOiBcIm1vbnRoXCIsXG4gIE5VTUJFUjogXCJudW1iZXJcIixcbiAgUEFTU1dPUkQ6IFVJS2V5cy5QQVNTV09SRCxcbiAgUkFESU86IFwicmFkaW9cIixcbiAgUkFOR0U6IFwicmFuZ2VcIixcbiAgUkVTRVQ6IFwicmVzZXRcIixcbiAgU0VBUkNIOiBcInNlYXJjaFwiLFxuICBTVUJNSVQ6IFwic3VibWl0XCIsXG4gIFRFTDogXCJ0ZWxcIixcbiAgVEVYVDogXCJ0ZXh0XCIsXG4gIFRJTUU6IFwidGltZVwiLFxuICBVUkw6IFVJS2V5cy5VUkwsXG4gIFdFRUs6IFwid2Vla1wiLFxufTtcblxuZXhwb3J0IGNvbnN0IEhUTUw1Q2hlY2tUeXBlcyA9IFtcbiAgSFRNTDVJbnB1dFR5cGVzLkNIRUNLQk9YLFxuICBIVE1MNUlucHV0VHlwZXMuUkFESU8sXG5dO1xuIl19
238
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VpL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztHQU9HO0FBRUgsT0FBTyxFQUVMLGFBQWEsRUFDYixhQUFhLEVBQ2IsY0FBYyxFQUNkLGVBQWUsRUFDZiwyQkFBMkIsRUFDM0Isb0JBQW9CLEVBQ3BCLHdCQUF3QixFQUN4QixpQkFBaUIsRUFDakIsa0JBQWtCLEVBQ2xCLFlBQVksRUFDWixrQkFBa0IsRUFDbEIsWUFBWSxFQUNaLFNBQVMsRUFDVCxpQkFBaUIsRUFDakIsZ0JBQWdCLEVBQ2hCLGlCQUFpQixFQUNqQixhQUFhLEVBQ2IsWUFBWSxFQUNaLGNBQWMsR0FFZixNQUFNLGdDQUFnQyxDQUFDO0FBRXhDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTRDRztBQUNILE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRztJQUNwQixPQUFPLEVBQUUsR0FBRyxTQUFTLENBQUMsT0FBTyxNQUFNO0lBQ25DLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLFdBQVcsRUFBRSxhQUFhO0lBQzFCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLElBQUksRUFBRSxNQUFNO0lBQ1osSUFBSSxFQUFFLE1BQU07SUFDWixXQUFXLEVBQUUsUUFBUTtJQUNyQixZQUFZLEVBQUUsdUJBQXVCO0lBRXJDLFVBQVUsRUFBRSxZQUFZO0lBQ3hCLFVBQVUsRUFBRSxVQUFVO0lBRXRCLElBQUksRUFBRSxNQUFNO0lBQ1osUUFBUSxFQUFFLFNBQVM7SUFFbkIsTUFBTSxFQUFFLFFBQVE7SUFDaEIsTUFBTSxFQUFFLFFBQVE7SUFFaEIsU0FBUyxFQUFFLFVBQVU7SUFDckIsUUFBUSxFQUFFLGNBQWMsQ0FBQyxRQUFRO0lBQ2pDLEdBQUcsRUFBRSxjQUFjLENBQUMsR0FBRztJQUN2QixVQUFVLEVBQUUsY0FBYyxDQUFDLFVBQVU7SUFDckMs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QUFFLFFBQVE7SUFDaEIsTUFBTSxFQUFFLFFBQVE7SUFDaEIsR0FBRyxFQUFFLEtBQUs7SUFDVixJQUFJLEVBQUUsTUFBTTtJQUNaLElBQUksRUFBRSxNQUFNO0lBQ1osR0FBRyxFQUFFLE1BQU0sQ0FBQyxHQUFHO0lBQ2YsSUFBSSxFQUFFLE1BQU07Q0FDYixDQUFDO0FBRUY7Ozs7Ozs7Ozs7R0FVRztBQUNILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRztJQUM3QixlQUFlLENBQUMsUUFBUTtJQUN4QixlQUFlLENBQUMsS0FBSztDQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAZGVzY3JpcHRpb24gQ29uc3RhbnRzIGFuZCBlbnVtcyBmb3IgVUkgcmVuZGVyaW5nIGFuZCB2YWxpZGF0aW9uXG4gKiBAc3VtbWFyeSBEZWZpbmVzIGtleXMsIG1hcHBpbmdzLCBhbmQgSFRNTDUgaW5wdXQgdHlwZXMgZm9yIFVJIGNvbXBvbmVudHNcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIGNvbnN0YW50cyB1c2VkIHRocm91Z2hvdXQgdGhlIFVJIGRlY29yYXRvcnMgbGlicmFyeSBmb3JcbiAqIHJlbmRlcmluZywgdmFsaWRhdGlvbiwgYW5kIEhUTUwgZWxlbWVudCBnZW5lcmF0aW9uLlxuICogQG1vZHVsZSB1aS9jb25zdGFudHNcbiAqIEBtZW1iZXJPZiBtb2R1bGU6dWktZGVjb3JhdG9yc1xuICovXG5cbmltcG9ydCB7XG4gIENvbnN0cnVjdG9yLFxuICBEYXRlVmFsaWRhdG9yLFxuICBEaWZmVmFsaWRhdG9yLFxuICBFbWFpbFZhbGlkYXRvcixcbiAgRXF1YWxzVmFsaWRhdG9yLFxuICBHcmVhdGVyVGhhbk9yRXF1YWxWYWxpZGF0b3IsXG4gIEdyZWF0ZXJUaGFuVmFsaWRhdG9yLFxuICBMZXNzVGhhbk9yRXF1YWxWYWxpZGF0b3IsXG4gIExlc3NUaGFuVmFsaWRhdG9yLFxuICBNYXhMZW5ndGhWYWxpZGF0b3IsXG4gIE1heFZhbGlkYXRvcixcbiAgTWluTGVuZ3RoVmFsaWRhdG9yLFxuICBNaW5WYWxpZGF0b3IsXG4gIE1vZGVsS2V5cyxcbiAgUGFzc3dvcmRWYWxpZGF0b3IsXG4gIFBhdHRlcm5WYWxpZGF0b3IsXG4gIFJlcXVpcmVkVmFsaWRhdG9yLFxuICBTdGVwVmFsaWRhdG9yLFxuICBVUkxWYWxpZGF0b3IsXG4gIFZhbGlkYXRpb25LZXlzLFxuICBWYWxpZGF0b3IsXG59IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gS2V5IGNvbnN0YW50cyB1c2VkIGZvciBVSSBtZXRhZGF0YSBhbmQgcmVuZGVyaW5nXG4gKiBAc3VtbWFyeSBDb2xsZWN0aW9uIG9mIHN0cmluZyBjb25zdGFudHMgdXNlZCBhcyBrZXlzIGZvciBVSS1yZWxhdGVkIG1ldGFkYXRhXG4gKiBUaGVzZSBrZXlzIGFyZSB1c2VkIHRocm91Z2hvdXQgdGhlIGxpYnJhcnkgdG8gc3RvcmUgYW5kIHJldHJpZXZlIG1ldGFkYXRhIHJlbGF0ZWQgdG9cbiAqIFVJIG1vZGVscywgZWxlbWVudHMsIHByb3BlcnRpZXMsIGFuZCB2YWxpZGF0aW9uIHJ1bGVzLlxuICpcbiAqIEB0eXBlZGVmIHtPYmplY3R9IFVJS2V5c1R5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBSRUZMRUNUIC0gQmFzZSByZWZsZWN0aW9uIGtleSBmb3IgVUkgbWV0YWRhdGFcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBVSU1PREVMIC0gS2V5IGZvciBVSSBtb2RlbCBtZXRhZGF0YVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFJFTkRFUkVEX0JZIC0gS2V5IGZvciBzcGVjaWZ5aW5nIHJlbmRlcmluZyBlbmdpbmVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBFTEVNRU5UIC0gS2V5IGZvciBlbGVtZW50IG1ldGFkYXRhXG4gKiBAcHJvcGVydHkge3N0cmluZ30gUFJPUCAtIEtleSBmb3IgcHJvcGVydHkgbWV0YWRhdGFcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBOQU1FIC0gS2V5IGZvciBuYW1lIGF0dHJpYnV0ZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IE5BTUVfUFJFRklYIC0gUHJlZml4IGZvciBpbnB1dCBuYW1lc1xuICogQHByb3BlcnR5IHtzdHJpbmd9IENVU1RPTV9QUk9QUyAtIEtleSBmb3IgY3VzdG9tIHZhbGlkYXRpb24gcHJvcGVydGllc1xuICogQHByb3BlcnR5IHtzdHJpbmd9IFVJTElTVElURU0gLSBLZXkgZm9yIGxpc3QgaXRlbSBtZXRhZGF0YVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFVJTElTVFBST1AgLSBLZXkgZm9yIGxpc3QgcHJvcGVydHkgbWV0YWRhdGFcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBUWVBFIC0gS2V5IGZvciB0eXBlIG1ldGFkYXRhXG4gKiBAcHJvcGVydHkge3N0cmluZ30gU1VCX1RZUEUgLSBLZXkgZm9yIHN1YnR5cGUgbWV0YWRhdGFcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBISURERU4gLSBLZXkgZm9yIGhpZGRlbiBhdHRyaWJ1dGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBGT1JNQVQgLSBLZXkgZm9yIGZvcm1hdCBtZXRhZGF0YVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFJFQURfT05MWSAtIEtleSBmb3IgcmVhZG9ubHkgYXR0cmlidXRlXG4gKiBAcHJvcGVydHkge3N0cmluZ30gUkVRVUlSRUQgLSBLZXkgZm9yIHJlcXVpcmVkIHZhbGlkYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBNSU4gLSBLZXkgZm9yIG1pbmltdW0gdmFsdWUgdmFsaWRhdGlvblxuICogQHByb3BlcnR5IHtzdHJpbmd9IE1JTl9MRU5HVEggLSBLZXkgZm9yIG1pbmltdW0gbGVuZ3RoIHZhbGlkYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBNQVggLSBLZXkgZm9yIG1heGltdW0gdmFsdWUgdmFsaWRhdGlvblxuICogQHByb3BlcnR5IHtzdHJpbmd9IE1BWF9MRU5HVEggLSBLZXkgZm9yIG1heGltdW0gbGVuZ3RoIHZhbGlkYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBQQVRURVJOIC0gS2V5IGZvciBwYXR0ZXJuIHZhbGlkYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBVUkwgLSBLZXkgZm9yIFVSTCB2YWxpZGF0aW9uXG4gKiBAcHJvcGVydHkge3N0cmluZ30gU1RFUCAtIEtleSBmb3Igc3RlcCB2YWxpZGF0aW9uXG4gKiBAcHJvcGVydHkge3N0cmluZ30gREFURSAtIEtleSBmb3IgZGF0ZSB2YWxpZGF0aW9uXG4gKiBAcHJvcGVydHkge3N0cmluZ30gRU1BSUwgLSBLZXkgZm9yIGVtYWlsIHZhbGlkYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBQQVNTV09SRCAtIEtleSBmb3IgcGFzc3dvcmQgdmFsaWRhdGlvblxuICogQHByb3BlcnR5IHtzdHJpbmd9IEVRVUFMUyAtIEtleSBmb3IgZXF1YWxpdHkgdmFsaWRhdGlvblxuICogQHByb3BlcnR5IHtzdHJpbmd9IERJRkYgLSBLZXkgZm9yIGRpZmZlcmVuY2UgdmFsaWRhdGlvblxuICogQHByb3BlcnR5IHtzdHJpbmd9IExFU1NfVEhBTiAtIEtleSBmb3IgbGVzcyB0aGFuIHZhbGlkYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBMRVNTX1RIQU5fT1JfRVFVQUwgLSBLZXkgZm9yIGxlc3MgdGhhbiBvciBlcXVhbCB2YWxpZGF0aW9uXG4gKiBAcHJvcGVydHkge3N0cmluZ30gR1JFQVRFUl9USEFOIC0gS2V5IGZvciBncmVhdGVyIHRoYW4gdmFsaWRhdGlvblxuICogQHByb3BlcnR5IHtzdHJpbmd9IEdSRUFURVJfVEhBTl9PUl9FUVVBTCAtIEtleSBmb3IgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHZhbGlkYXRpb25cbiAqXG4gKiBAY29uc3QgVUlLZXlzXG4gKiBAdHlwZSB7VUlLZXlzVHlwZX1cbiAqIEByZWFkb25seVxuICogQG1lbWJlck9mIG1vZHVsZTp1aS1kZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBjb25zdCBVSUtleXMgPSB7XG4gIFJFRkxFQ1Q6IGAke01vZGVsS2V5cy5SRUZMRUNUfS51aS5gLFxuICBVSU1PREVMOiBcInVpbW9kZWxcIixcbiAgUkVOREVSRURfQlk6IFwicmVuZGVyZWQtYnlcIixcbiAgRUxFTUVOVDogXCJlbGVtZW50XCIsXG4gIFBST1A6IFwicHJvcFwiLFxuICBOQU1FOiBcIm5hbWVcIixcbiAgTkFNRV9QUkVGSVg6IFwiaW5wdXQtXCIsXG4gIENVU1RPTV9QUk9QUzogXCJjdXN0b21WYWxpZGF0aW9uUHJvcHNcIixcblxuICBVSUxJU1RJVEVNOiBcInVpbGlzdGl0ZW1cIixcbiAgVUlMSVNUUFJPUDogXCJsaXN0cHJvcFwiLFxuXG4gIFRZUEU6IFwidHlwZVwiLFxuICBTVUJfVFlQRTogXCJzdWJ0eXBlXCIsXG5cbiAgSElEREVOOiBcImhpZGRlblwiLFxuICBGT1JNQVQ6IFwiZm9ybWF0XCIsXG5cbiAgUkVBRF9PTkxZOiBcInJlYWRvbmx5XCIsXG4gIFJFUVVJUkVEOiBWYWxpZGF0aW9uS2V5cy5SRVFVSVJFRCxcbiAgTUlOOiBWYWxpZGF0aW9uS2V5cy5NSU4sXG4gIE1JTl9MRU5HVEg6IFZhbGlkYXRpb25LZXlzLk1JTl9MRU5HVEgsXG4gIE1BWDogVmFsaWRhdGlvbktleXMuTUFYLFxuICBNQVhfTEVOR1RIOiBWYWxpZGF0aW9uS2V5cy5NQVhfTEVOR1RILFxuICBQQVRURVJOOiBWYWxpZGF0aW9uS2V5cy5QQVRURVJOLFxuICBVUkw6IFZhbGlkYXRpb25LZXlzLlVSTCxcbiAgU1RFUDogVmFsaWRhdGlvbktleXMuU1RFUCxcbiAgREFURTogVmFsaWRhdGlvbktleXMuREFURSxcbiAgRU1BSUw6IFZhbGlkYXRpb25LZXlzLkVNQUlMLFxuICBQQVNTV09SRDogVmFsaWRhdGlvbktleXMuUEFTU1dPUkQsXG4gIEVRVUFMUzogVmFsaWRhdGlvbktleXMuRVFVQUxTLFxuICBESUZGOiBWYWxpZGF0aW9uS2V5cy5ESUZGLFxuICBMRVNTX1RIQU46IFZhbGlkYXRpb25LZXlzLkxFU1NfVEhBTixcbiAgTEVTU19USEFOX09SX0VRVUFMOiBWYWxpZGF0aW9uS2V5cy5MRVNTX1RIQU5fT1JfRVFVQUwsXG4gIEdSRUFURVJfVEhBTjogVmFsaWRhdGlvbktleXMuR1JFQVRFUl9USEFOLFxuICBHUkVBVEVSX1RIQU5fT1JfRVFVQUw6IFZhbGlkYXRpb25LZXlzLkdSRUFURVJfVEhBTl9PUl9FUVVBTCxcbn07XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIE1hcHBpbmcgb2YgaW5wdXQgdHlwZXMgdG8gdGhlaXIgY29ycmVzcG9uZGluZyB2YWxpZGF0b3JzXG4gKiBAc3VtbWFyeSBNYXBzIHNwZWNpYWwgaW5wdXQgdHlwZXMgdG8gdGhlaXIgdmFsaWRhdG9yIGNsYXNzZXNcbiAqIFRoaXMgY29uc3RhbnQgbWFwcyBpbnB1dCB0eXBlcyBsaWtlIGVtYWlsLCBVUkwsIGRhdGUsIGFuZCBwYXNzd29yZCB0byB0aGVpclxuICogY29ycmVzcG9uZGluZyB2YWxpZGF0b3IgY2xhc3NlcyBmcm9tIHRoZSBkZWNvcmF0b3ItdmFsaWRhdGlvbiBsaWJyYXJ5LlxuICpcbiAqIEB0eXBlZGVmIHtPYmplY3QuPHN0cmluZywgQ29uc3RydWN0b3I8VmFsaWRhdG9yPj59IFZhbGlkYXRhYmxlQnlUeXBlTWFwXG4gKiBAcHJvcGVydHkge0NvbnN0cnVjdG9yPEVtYWlsVmFsaWRhdG9yPn0gZW1haWwgLSBWYWxpZGF0b3IgZm9yIGVtYWlsIGlucHV0c1xuICogQHByb3BlcnR5IHtDb25zdHJ1Y3RvcjxVUkxWYWxpZGF0b3I+fSB1cmwgLSBWYWxpZGF0b3IgZm9yIFVSTCBpbnB1dHNcbiAqIEBwcm9wZXJ0eSB7Q29uc3RydWN0b3I8RGF0ZVZhbGlkYXRvcj59IGRhdGUgLSBWYWxpZGF0b3IgZm9yIGRhdGUgaW5wdXRzXG4gKiBAcHJvcGVydHkge0NvbnN0cnVjdG9yPFBhc3N3b3JkVmFsaWRhdG9yPn0gcGFzc3dvcmQgLSBWYWxpZGF0b3IgZm9yIHBhc3N3b3JkIGlucHV0c1xuICpcbiAqIEBjb25zdCBWYWxpZGF0YWJsZUJ5VHlwZVxuICogQHR5cGUge1ZhbGlkYXRhYmxlQnlUeXBlTWFwfVxuICogQHJlYWRvbmx5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOnVpLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IFZhbGlkYXRhYmxlQnlUeXBlOiBSZWNvcmQ8c3RyaW5nLCBDb25zdHJ1Y3RvcjxWYWxpZGF0b3I+PiA9IHtcbiAgW1VJS2V5cy5FTUFJTF06IEVtYWlsVmFsaWRhdG9yLFxuICBbVUlLZXlzLlVSTF06IFVSTFZhbGlkYXRvcixcbiAgW1VJS2V5cy5EQVRFXTogRGF0ZVZhbGlkYXRvcixcbiAgW1VJS2V5cy5QQVNTV09SRF06IFBhc3N3b3JkVmFsaWRhdG9yLFxufTtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gTWFwcGluZyBvZiB2YWxpZGF0aW9uIGF0dHJpYnV0ZXMgdG8gdGhlaXIgY29ycmVzcG9uZGluZyB2YWxpZGF0b3JzXG4gKiBAc3VtbWFyeSBNYXBzIEhUTUwgdmFsaWRhdGlvbiBhdHRyaWJ1dGVzIHRvIHRoZWlyIHZhbGlkYXRvciBjbGFzc2VzXG4gKiBUaGlzIGNvbnN0YW50IG1hcHMgSFRNTCB2YWxpZGF0aW9uIGF0dHJpYnV0ZXMgbGlrZSByZXF1aXJlZCwgbWluLCBtYXgsIHBhdHRlcm4sIGV0Yy5cbiAqIHRvIHRoZWlyIGNvcnJlc3BvbmRpbmcgdmFsaWRhdG9yIGNsYXNzZXMgZnJvbSB0aGUgZGVjb3JhdG9yLXZhbGlkYXRpb24gbGlicmFyeS5cbiAqXG4gKiBAdHlwZWRlZiB7T2JqZWN0LjxzdHJpbmcsIENvbnN0cnVjdG9yPFZhbGlkYXRvcj4+fSBWYWxpZGF0YWJsZUJ5QXR0cmlidXRlTWFwXG4gKiBAcHJvcGVydHkge0NvbnN0cnVjdG9yPFJlcXVpcmVkVmFsaWRhdG9yPn0gcmVxdWlyZWQgLSBWYWxpZGF0b3IgZm9yIHJlcXVpcmVkIGZpZWxkc1xuICogQHByb3BlcnR5IHtDb25zdHJ1Y3RvcjxNaW5WYWxpZGF0b3I+fSBtaW4gLSBWYWxpZGF0b3IgZm9yIG1pbmltdW0gdmFsdWVcbiAqIEBwcm9wZXJ0eSB7Q29uc3RydWN0b3I8TWF4VmFsaWRhdG9yPn0gbWF4IC0gVmFsaWRhdG9yIGZvciBtYXhpbXVtIHZhbHVlXG4gKiBAcHJvcGVydHkge0NvbnN0cnVjdG9yPFN0ZXBWYWxpZGF0b3I+fSBzdGVwIC0gVmFsaWRhdG9yIGZvciBzdGVwIHZhbHVlXG4gKiBAcHJvcGVydHkge0NvbnN0cnVjdG9yPE1pbkxlbmd0aFZhbGlkYXRvcj59IG1pbmxlbmd0aCAtIFZhbGlkYXRvciBmb3IgbWluaW11bSBsZW5ndGhcbiAqIEBwcm9wZXJ0eSB7Q29uc3RydWN0b3I8TWF4TGVuZ3RoVmFsaWRhdG9yPn0gbWF4bGVuZ3RoIC0gVmFsaWRhdG9yIGZvciBtYXhpbXVtIGxlbmd0aFxuICogQHByb3BlcnR5IHtDb25zdHJ1Y3RvcjxQYXR0ZXJuVmFsaWRhdG9yPn0gcGF0dGVybiAtIFZhbGlkYXRvciBmb3IgcmVnZXggcGF0dGVyblxuICogQHByb3BlcnR5IHtDb25zdHJ1Y3RvcjxFcXVhbHNWYWxpZGF0b3I+fSBlcXVhbHMgLSBWYWxpZGF0b3IgZm9yIGVxdWFsaXR5XG4gKiBAcHJvcGVydHkge0NvbnN0cnVjdG9yPERpZmZWYWxpZGF0b3I+fSBkaWZmIC0gVmFsaWRhdG9yIGZvciBkaWZmZXJlbmNlXG4gKiBAcHJvcGVydHkge0NvbnN0cnVjdG9yPExlc3NUaGFuVmFsaWRhdG9yPn0gbGVzc3RoYW4gLSBWYWxpZGF0b3IgZm9yIGxlc3MgdGhhbiBjb21wYXJpc29uXG4gKiBAcHJvcGVydHkge0NvbnN0cnVjdG9yPExlc3NUaGFuT3JFcXVhbFZhbGlkYXRvcj59IGxlc3N0aGFub3JlcXVhbCAtIFZhbGlkYXRvciBmb3IgbGVzcyB0aGFuIG9yIGVxdWFsIGNvbXBhcmlzb25cbiAqIEBwcm9wZXJ0eSB7Q29uc3RydWN0b3I8R3JlYXRlclRoYW5WYWxpZGF0b3I+fSBncmVhdGVydGhhbiAtIFZhbGlkYXRvciBmb3IgZ3JlYXRlciB0aGFuIGNvbXBhcmlzb25cbiAqIEBwcm9wZXJ0eSB7Q29uc3RydWN0b3I8R3JlYXRlclRoYW5PckVxdWFsVmFsaWRhdG9yPn0gZ3JlYXRlcnRoYW5vcmVxdWFsIC0gVmFsaWRhdG9yIGZvciBncmVhdGVyIHRoYW4gb3IgZXF1YWwgY29tcGFyaXNvblxuICpcbiAqIEBjb25zdCBWYWxpZGF0YWJsZUJ5QXR0cmlidXRlXG4gKiBAdHlwZSB7VmFsaWRhdGFibGVCeUF0dHJpYnV0ZU1hcH1cbiAqIEByZWFkb25seVxuICogQG1lbWJlck9mIG1vZHVsZTp1aS1kZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBjb25zdCBWYWxpZGF0YWJsZUJ5QXR0cmlidXRlOiBSZWNvcmQ8c3RyaW5nLCBDb25zdHJ1Y3RvcjxWYWxpZGF0b3I+PiA9IHtcbiAgW1VJS2V5cy5SRVFVSVJFRF06IFJlcXVpcmVkVmFsaWRhdG9yLFxuICBbVUlLZXlzLk1JTl06IE1pblZhbGlkYXRvcixcbiAgW1VJS2V5cy5NQVhdOiBNYXhWYWxpZGF0b3IsXG4gIFtVSUtleXMuU1RFUF06IFN0ZXBWYWxpZGF0b3IsXG4gIFtVSUtleXMuTUlOX0xFTkdUSF06IE1pbkxlbmd0aFZhbGlkYXRvcixcbiAgW1VJS2V5cy5NQVhfTEVOR1RIXTogTWF4TGVuZ3RoVmFsaWRhdG9yLFxuICBbVUlLZXlzLlBBVFRFUk5dOiBQYXR0ZXJuVmFsaWRhdG9yLFxuICBbVUlLZXlzLkVRVUFMU106IEVxdWFsc1ZhbGlkYXRvcixcbiAgW1VJS2V5cy5ESUZGXTogRGlmZlZhbGlkYXRvcixcbiAgW1VJS2V5cy5MRVNTX1RIQU5dOiBMZXNzVGhhblZhbGlkYXRvcixcbiAgW1VJS2V5cy5MRVNTX1RIQU5fT1JfRVFVQUxdOiBMZXNzVGhhbk9yRXF1YWxWYWxpZGF0b3IsXG4gIFtVSUtleXMuR1JFQVRFUl9USEFOXTogR3JlYXRlclRoYW5WYWxpZGF0b3IsXG4gIFtVSUtleXMuR1JFQVRFUl9USEFOX09SX0VRVUFMXTogR3JlYXRlclRoYW5PckVxdWFsVmFsaWRhdG9yLFxufTtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gU3RhbmRhcmQgZGF0ZSBmb3JtYXQgc3RyaW5nIGZvciBIVE1MNSBkYXRlIGlucHV0c1xuICogQHN1bW1hcnkgRm9ybWF0IHN0cmluZyBmb3IgSFRNTDUgZGF0ZSBpbnB1dHMgKHl5eXktTU0tZGQpXG4gKiBUaGlzIGNvbnN0YW50IGRlZmluZXMgdGhlIHN0YW5kYXJkIGRhdGUgZm9ybWF0IHN0cmluZyB1c2VkIGZvciBIVE1MNSBkYXRlIGlucHV0cy5cbiAqXG4gKiBAY29uc3QgSFRNTDVEYXRlRm9ybWF0XG4gKiBAdHlwZSB7c3RyaW5nfVxuICogQHJlYWRvbmx5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOnVpLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IEhUTUw1RGF0ZUZvcm1hdCA9IFwieXl5eS1NTS1kZFwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBDb2xsZWN0aW9uIG9mIEhUTUw1IGlucHV0IHR5cGUgdmFsdWVzXG4gKiBAc3VtbWFyeSBNYXBzIGlucHV0IHR5cGUgY29uc3RhbnRzIHRvIHRoZWlyIEhUTUwgYXR0cmlidXRlIHZhbHVlc1xuICogVGhpcyBjb25zdGFudCBwcm92aWRlcyBhIG1hcHBpbmcgb2YgaW5wdXQgdHlwZSBjb25zdGFudHMgdG8gdGhlaXIgY29ycmVzcG9uZGluZ1xuICogSFRNTCBhdHRyaWJ1dGUgdmFsdWVzIGZvciB1c2UgaW4gZm9ybSBlbGVtZW50cy5cbiAqXG4gKiBAdHlwZWRlZiB7T2JqZWN0fSBIVE1MNUlucHV0VHlwZXNNYXBcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBCVVRUT04gLSBCdXR0b24gaW5wdXQgdHlwZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IENIRUNLQk9YIC0gQ2hlY2tib3ggaW5wdXQgdHlwZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IENPTE9SIC0gQ29sb3IgcGlja2VyIGlucHV0IHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBEQVRFIC0gRGF0ZSBwaWNrZXIgaW5wdXQgdHlwZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IERBVEVUSU1FX0xPQ0FMIC0gTG9jYWwgZGF0ZXRpbWUgcGlja2VyIGlucHV0IHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBFTUFJTCAtIEVtYWlsIGlucHV0IHR5cGUgd2l0aCB2YWxpZGF0aW9uXG4gKiBAcHJvcGVydHkge3N0cmluZ30gRklMRSAtIEZpbGUgdXBsb2FkIGlucHV0IHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBISURERU4gLSBIaWRkZW4gaW5wdXQgdHlwZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IElNQUdFIC0gSW1hZ2UgaW5wdXQgdHlwZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IE1PTlRIIC0gTW9udGggcGlja2VyIGlucHV0IHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBOVU1CRVIgLSBOdW1lcmljIGlucHV0IHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBQQVNTV09SRCAtIFBhc3N3b3JkIGlucHV0IHR5cGUgd2l0aCBtYXNrZWQgdGV4dFxuICogQHByb3BlcnR5IHtzdHJpbmd9IFJBRElPIC0gUmFkaW8gYnV0dG9uIGlucHV0IHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBSQU5HRSAtIFJhbmdlIHNsaWRlciBpbnB1dCB0eXBlXG4gKiBAcHJvcGVydHkge3N0cmluZ30gUkVTRVQgLSBGb3JtIHJlc2V0IGJ1dHRvbiBpbnB1dCB0eXBlXG4gKiBAcHJvcGVydHkge3N0cmluZ30gU0VBUkNIIC0gU2VhcmNoIGlucHV0IHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBTVUJNSVQgLSBGb3JtIHN1Ym1pdCBidXR0b24gaW5wdXQgdHlwZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFRFTCAtIFRlbGVwaG9uZSBudW1iZXIgaW5wdXQgdHlwZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFRFWFQgLSBCYXNpYyB0ZXh0IGlucHV0IHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBUSU1FIC0gVGltZSBwaWNrZXIgaW5wdXQgdHlwZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFVSTCAtIFVSTCBpbnB1dCB0eXBlIHdpdGggdmFsaWRhdGlvblxuICogQHByb3BlcnR5IHtzdHJpbmd9IFdFRUsgLSBXZWVrIHBpY2tlciBpbnB1dCB0eXBlXG4gKlxuICogQGNvbnN0IEhUTUw1SW5wdXRUeXBlc1xuICogQHR5cGUge0hUTUw1SW5wdXRUeXBlc01hcH1cbiAqIEByZWFkb25seVxuICogQG1lbWJlck9mIG1vZHVsZTp1aS1kZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBjb25zdCBIVE1MNUlucHV0VHlwZXMgPSB7XG4gIEJVVFRPTjogXCJidXR0b25cIixcbiAgQ0hFQ0tCT1g6IFwiY2hlY2tib3hcIixcbiAgQ09MT1I6IFwiY29sb3JcIixcbiAgREFURTogVUlLZXlzLkRBVEUsXG4gIERBVEVUSU1FX0xPQ0FMOiBcImRhdGV0aW1lLWxvY2FsXCIsXG4gIEVNQUlMOiBVSUtleXMuRU1BSUwsXG4gIEZJTEU6IFwiZmlsZVwiLFxuICBISURERU46IFwiaGlkZGVuXCIsXG4gIElNQUdFOiBcImltYWdlXCIsXG4gIE1PTlRIOiBcIm1vbnRoXCIsXG4gIE5VTUJFUjogXCJudW1iZXJcIixcbiAgUEFTU1dPUkQ6IFVJS2V5cy5QQVNTV09SRCxcbiAgUkFESU86IFwicmFkaW9cIixcbiAgUkFOR0U6IFwicmFuZ2VcIixcbiAgUkVTRVQ6IFwicmVzZXRcIixcbiAgU0VBUkNIOiBcInNlYXJjaFwiLFxuICBTVUJNSVQ6IFwic3VibWl0XCIsXG4gIFRFTDogXCJ0ZWxcIixcbiAgVEVYVDogXCJ0ZXh0XCIsXG4gIFRJTUU6IFwidGltZVwiLFxuICBVUkw6IFVJS2V5cy5VUkwsXG4gIFdFRUs6IFwid2Vla1wiLFxufTtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gQXJyYXkgb2YgSFRNTDUgaW5wdXQgdHlwZXMgdGhhdCB1c2UgY2hlY2tib3hlc1xuICogQHN1bW1hcnkgTGlzdCBvZiBpbnB1dCB0eXBlcyB0aGF0IHJlcHJlc2VudCBjaGVja2FibGUgY29udHJvbHNcbiAqIFRoaXMgY29uc3RhbnQgZGVmaW5lcyBhbiBhcnJheSBvZiBIVE1MNSBpbnB1dCB0eXBlcyB0aGF0IHJlcHJlc2VudFxuICogY2hlY2thYmxlIGNvbnRyb2xzIChjaGVja2JveCBhbmQgcmFkaW8pLlxuICpcbiAqIEBjb25zdCBIVE1MNUNoZWNrVHlwZXNcbiAqIEB0eXBlIHtzdHJpbmdbXX1cbiAqIEByZWFkb25seVxuICogQG1lbWJlck9mIG1vZHVsZTp1aS1kZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBjb25zdCBIVE1MNUNoZWNrVHlwZXMgPSBbXG4gIEhUTUw1SW5wdXRUeXBlcy5DSEVDS0JPWCxcbiAgSFRNTDVJbnB1dFR5cGVzLlJBRElPLFxuXTtcbiJdfQ==
@@ -1,47 +1,211 @@
1
1
  import "reflect-metadata";
2
2
  import { CrudOperationKeys } from "./types";
3
3
  /**
4
- * @namespace ui-decorators.ui.decorators
5
- * @memberOf ui-decorators.ui
4
+ * @description Decorator that hides a property during specific CRUD operations
5
+ * @summary Controls property visibility based on operation type
6
+ * This decorator allows you to specify which CRUD operations should hide a property
7
+ * in the UI. The property will only be visible during operations not specified.
8
+ *
9
+ * @param operations - The CRUD operations during which the property should be hidden
10
+ * @return {Function} A property decorator function
11
+ *
12
+ * @function hideOn
13
+ * @category Property Decorators
14
+ *
15
+ * @example
16
+ * // Hide the password field during READ operations
17
+ * class User {
18
+ * @attribute()
19
+ * username: string;
20
+ *
21
+ * @attribute()
22
+ * @hideOn(OperationKeys.READ)
23
+ * password: string;
24
+ * }
25
+ *
26
+ * @mermaid
27
+ * sequenceDiagram
28
+ * participant Model
29
+ * participant hideOn
30
+ * participant RenderingEngine
31
+ * participant UI
32
+ * Model->>hideOn: Apply to property
33
+ * hideOn->>Model: Add hidden metadata
34
+ * RenderingEngine->>Model: Check if property should be hidden
35
+ * Model->>RenderingEngine: Return hidden operations
36
+ * RenderingEngine->>UI: Render or hide based on current operation
6
37
  */
7
38
  export declare function hideOn(...operations: CrudOperationKeys[]): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
39
+ /**
40
+ * @description Decorator that completely hides a property in all UI operations
41
+ * @summary Makes a property invisible in all CRUD operations
42
+ * This decorator is a convenience wrapper around hideOn that hides a property
43
+ * during all CRUD operations (CREATE, READ, UPDATE, DELETE).
44
+ *
45
+ * @return {Function} A property decorator function
46
+ *
47
+ * @function hidden
48
+ * @category Property Decorators
49
+ *
50
+ * @example
51
+ * // Completely hide the internalId field in the UI
52
+ * class Product {
53
+ * @attribute()
54
+ * name: string;
55
+ *
56
+ * @attribute()
57
+ * @hidden()
58
+ * internalId: string;
59
+ * }
60
+ *
61
+ * @mermaid
62
+ * sequenceDiagram
63
+ * participant Model
64
+ * participant hidden
65
+ * participant hideOn
66
+ * participant RenderingEngine
67
+ * Model->>hidden: Apply to property
68
+ * hidden->>hideOn: Call with all operations
69
+ * hideOn->>Model: Add hidden metadata
70
+ * RenderingEngine->>Model: Check if property should be hidden
71
+ * Model->>RenderingEngine: Return all operations
72
+ * RenderingEngine->>UI: Always hide property
73
+ */
8
74
  export declare function hidden(): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
9
75
  /**
10
- * Adds the UIElement definition as metadata to the property, allowing it to be read by any {@link RenderStrategy}
76
+ * @description Decorator that specifies how a property should be rendered as a UI element
77
+ * @summary Maps a model property to a specific UI element with custom properties
78
+ * This decorator allows you to define which HTML element or component should be used
79
+ * to render a specific property, along with any additional properties to pass to that element.
80
+ *
81
+ * @param {string} tag The HTML element or component tag name to use for rendering
82
+ * @param {Record<string, any>} [props] Additional properties to pass to the element
83
+ * @param {boolean} [serialize=false] Whether the property should be serialized
84
+ * @return {Function} A property decorator function
85
+ *
86
+ * @function uielement
87
+ * @category Property Decorators
88
+ *
89
+ * @example
90
+ * // Render a property as a text input
91
+ * class LoginForm {
92
+ * @attribute()
93
+ * @uielement('input', { type: 'text', placeholder: 'Enter username' })
94
+ * username: string;
11
95
  *
12
- * @param {string} tag The component/HTML element tag name
13
- * @param {{}} [props] The properties to pass to that component/HTML Element
14
- * @param serialize
96
+ * @attribute()
97
+ * @uielement('input', { type: 'password', placeholder: 'Enter password' })
98
+ * password: string;
15
99
  *
16
- * @decorator uielement
100
+ * @attribute()
101
+ * @uielement('button', { class: 'btn-primary' })
102
+ * submit: string = 'Login';
103
+ * }
17
104
  *
18
- * @category Decorators
19
- * @subcategory ui-decorators
105
+ * @mermaid
106
+ * sequenceDiagram
107
+ * participant Model
108
+ * participant uielement
109
+ * participant RenderingEngine
110
+ * participant UI
111
+ * Model->>uielement: Apply to property
112
+ * uielement->>Model: Add element metadata
113
+ * RenderingEngine->>Model: Get element metadata
114
+ * Model->>RenderingEngine: Return tag and props
115
+ * RenderingEngine->>UI: Render with specified element
20
116
  */
21
117
  export declare function uielement(tag: string, props?: Record<string, any>, serialize?: boolean): (original: any, propertyKey?: any) => void;
22
118
  /**
23
- * Adds the UIProp definition as metadata to the property, allowing it to be read by any {@link RenderStrategy}
119
+ * @description Decorator that maps a model property to a UI component property
120
+ * @summary Specifies how a property should be passed to a UI component
121
+ * This decorator allows you to define how a model property should be mapped to
122
+ * a property of the UI component when rendering. It requires the class to be
123
+ * decorated with @uimodel.
24
124
  *
25
- * this requires a '@uimodel' with a defined tag
125
+ * @param {string} [propName] The name of the property to pass to the component (defaults to the property key)
126
+ * @param {boolean} [stringify=false] Whether to stringify the property value
127
+ * @return {Function} A property decorator function
26
128
  *
27
- * @param {string} [propName] the property name that will be passed to the component. defaults to the PropertyKey
129
+ * @function uiprop
130
+ * @category Property Decorators
28
131
  *
29
- * @decorator uiprop
132
+ * @example
133
+ * // Map model properties to component properties
134
+ * @uimodel('user-profile')
135
+ * class UserProfile {
136
+ * @attribute()
137
+ * @uiprop() // Will be passed as 'fullName' to the component
138
+ * fullName: string;
30
139
  *
31
- * @category Decorators
32
- * @subcategory ui-decorators
140
+ * @attribute()
141
+ * @uiprop('userEmail') // Will be passed as 'userEmail' to the component
142
+ * email: string;
143
+ *
144
+ * @attribute()
145
+ * @uiprop('userData', true) // Will be passed as stringified JSON
146
+ * userData: Record<string, any>;
147
+ * }
148
+ *
149
+ * @mermaid
150
+ * sequenceDiagram
151
+ * participant Model
152
+ * participant uiprop
153
+ * participant RenderingEngine
154
+ * participant Component
155
+ * Model->>uiprop: Apply to property
156
+ * uiprop->>Model: Add prop metadata
157
+ * RenderingEngine->>Model: Get prop metadata
158
+ * Model->>RenderingEngine: Return prop name and stringify flag
159
+ * RenderingEngine->>Component: Pass property with specified name
33
160
  */
34
161
  export declare function uiprop(propName?: string | undefined, stringify?: boolean): (target: any, propertyKey: string) => void;
35
162
  /**
36
- * Adds the UIListProp definition as metadata to the property, allowing it to be read by any {@link RenderStrategy}
163
+ * @description Decorator that maps a model property to a list item component
164
+ * @summary Specifies how a property should be rendered in a list context
165
+ * This decorator allows you to define how a model property containing a list
166
+ * should be rendered. It requires the class to be decorated with @uilistitem.
167
+ *
168
+ * @param {string} [propName] The name of the property to pass to the list component (defaults to the property key)
169
+ * @param {Record<string, any>} [props] Additional properties to pass to the list container
170
+ * @return {Function} A property decorator function
171
+ *
172
+ * @function uilistprop
173
+ * @category Property Decorators
174
+ *
175
+ * @example
176
+ * // Define a list property with custom rendering
177
+ * @uimodel('todo-list')
178
+ * class TodoList {
179
+ * @attribute()
180
+ * title: string;
37
181
  *
38
- * this requires a '@uilistitem' with a defined tag
182
+ * @attribute()
183
+ * @uilistprop('items', { class: 'todo-items-container' })
184
+ * items: TodoItem[];
185
+ * }
39
186
  *
40
- * @param {string} [propName] the property name that will be passed to the component. defaults to the PropertyKey
187
+ * @uilistitem('li', { class: 'todo-item' })
188
+ * class TodoItem extends Model {
189
+ * @attribute()
190
+ * text: string;
41
191
  *
42
- * @decorator uiprop
192
+ * @attribute()
193
+ * completed: boolean;
194
+ * }
43
195
  *
44
- * @category Decorators
45
- * @subcategory ui-decorators
196
+ * @mermaid
197
+ * sequenceDiagram
198
+ * participant Model
199
+ * participant uilistprop
200
+ * participant RenderingEngine
201
+ * participant ListContainer
202
+ * participant ListItems
203
+ * Model->>uilistprop: Apply to property
204
+ * uilistprop->>Model: Add list prop metadata
205
+ * RenderingEngine->>Model: Get list prop metadata
206
+ * Model->>RenderingEngine: Return prop name and container props
207
+ * RenderingEngine->>ListContainer: Create container with props
208
+ * RenderingEngine->>ListItems: Render each item using @uilistitem
209
+ * ListContainer->>RenderingEngine: Return rendered list
46
210
  */
47
211
  export declare function uilistprop(propName?: string | undefined, props?: Record<string, any>): (target: any, propertyKey: string) => void;