ngx-material-entity 0.1.0 → 0.1.3

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 (120) hide show
  1. package/CONTRIBUTING.md +7 -1
  2. package/README.md +3 -2
  3. package/classes/base-builder.class.d.ts +35 -0
  4. package/classes/entity-model.class.d.ts +1 -1
  5. package/classes/entity-service.class.d.ts +27 -17
  6. package/classes/entity-utilities.class.d.ts +96 -46
  7. package/components/confirm-dialog/confirm-dialog-data.builder.d.ts +23 -0
  8. package/components/confirm-dialog/confirm-dialog-data.d.ts +18 -8
  9. package/components/confirm-dialog/confirm-dialog.component.d.ts +15 -5
  10. package/components/get-validation-error-message.function.d.ts +3 -2
  11. package/components/input/add-array-item-dialog-data.builder.d.ts +21 -0
  12. package/components/input/add-array-item-dialog-data.d.ts +20 -0
  13. package/components/input/input.component.d.ts +116 -26
  14. package/components/input/input.module.d.ts +6 -4
  15. package/components/table/create-dialog/create-dialog-data.builder.d.ts +21 -0
  16. package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +22 -0
  17. package/components/table/create-dialog/create-entity-dialog-data.d.ts +2 -2
  18. package/components/table/create-dialog/create-entity-dialog.component.d.ts +19 -5
  19. package/components/table/edit-dialog/edit-dialog-data.builder.d.ts +25 -0
  20. package/components/table/edit-dialog/edit-entity-dialog-data.d.ts +5 -5
  21. package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +23 -0
  22. package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +23 -5
  23. package/components/table/table-data.builder.d.ts +51 -0
  24. package/components/table/table-data.d.ts +40 -24
  25. package/components/table/table.component.d.ts +52 -5
  26. package/components/table/table.module.d.ts +3 -1
  27. package/decorators/array/array-decorator-internal.data.d.ts +45 -0
  28. package/decorators/array/array-decorator.data.d.ts +129 -0
  29. package/decorators/array/array.decorator.d.ts +10 -0
  30. package/decorators/base/base-property.decorator.d.ts +7 -6
  31. package/decorators/base/decorator-types.enum.d.ts +7 -7
  32. package/decorators/base/property-decorator-internal.data.d.ts +24 -0
  33. package/decorators/base/property-decorator.data.d.ts +70 -0
  34. package/decorators/boolean/boolean-decorator-internal.data.d.ts +25 -0
  35. package/decorators/boolean/boolean-decorator.data.d.ts +37 -0
  36. package/decorators/boolean/boolean.decorator.d.ts +8 -0
  37. package/decorators/number/number-decorator-internal.data.d.ts +22 -0
  38. package/decorators/number/number-decorator.data.d.ts +38 -0
  39. package/decorators/number/number.decorator.d.ts +8 -0
  40. package/decorators/object/object-decorator-internal.data.d.ts +11 -0
  41. package/decorators/object/object-decorator.data.d.ts +25 -0
  42. package/decorators/object/object.decorator.d.ts +9 -0
  43. package/decorators/string/string-decorator-internal.data.d.ts +43 -0
  44. package/decorators/string/string-decorator.data.d.ts +79 -0
  45. package/decorators/string/string.decorator.d.ts +8 -0
  46. package/esm2020/classes/base-builder.class.mjs +43 -0
  47. package/esm2020/classes/entity-model.class.mjs +2 -2
  48. package/esm2020/classes/entity-service.class.mjs +20 -14
  49. package/esm2020/classes/entity-utilities.class.mjs +182 -101
  50. package/esm2020/components/confirm-dialog/confirm-dialog-data.builder.mjs +44 -0
  51. package/esm2020/components/confirm-dialog/confirm-dialog-data.mjs +1 -1
  52. package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +18 -22
  53. package/esm2020/components/get-validation-error-message.function.mjs +8 -3
  54. package/esm2020/components/input/add-array-item-dialog-data.builder.mjs +30 -0
  55. package/esm2020/components/input/add-array-item-dialog-data.mjs +2 -0
  56. package/esm2020/components/input/input.component.mjs +168 -32
  57. package/esm2020/components/input/input.module.mjs +19 -9
  58. package/esm2020/components/table/create-dialog/create-dialog-data.builder.mjs +32 -0
  59. package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +26 -0
  60. package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
  61. package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +30 -30
  62. package/esm2020/components/table/create-dialog/create-entity-dialog.module.mjs +20 -4
  63. package/esm2020/components/table/edit-dialog/edit-dialog-data.builder.mjs +41 -0
  64. package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +1 -1
  65. package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +27 -0
  66. package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +43 -47
  67. package/esm2020/components/table/table-data.builder.mjs +105 -0
  68. package/esm2020/components/table/table-data.mjs +1 -1
  69. package/esm2020/components/table/table.component.mjs +90 -82
  70. package/esm2020/components/table/table.module.mjs +12 -4
  71. package/esm2020/decorators/array/array-decorator-internal.data.mjs +51 -0
  72. package/esm2020/decorators/array/array-decorator.data.mjs +7 -0
  73. package/esm2020/decorators/array/array.decorator.mjs +24 -0
  74. package/esm2020/decorators/base/base-property.decorator.mjs +6 -5
  75. package/esm2020/decorators/base/decorator-types.enum.mjs +1 -1
  76. package/esm2020/decorators/base/property-decorator-internal.data.mjs +38 -0
  77. package/esm2020/decorators/base/property-decorator.data.mjs +6 -0
  78. package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +33 -0
  79. package/esm2020/decorators/boolean/boolean-decorator.data.mjs +7 -0
  80. package/esm2020/decorators/boolean/boolean.decorator.mjs +21 -0
  81. package/esm2020/decorators/number/number-decorator-internal.data.mjs +23 -0
  82. package/esm2020/decorators/number/number-decorator.data.mjs +7 -0
  83. package/esm2020/decorators/number/number.decorator.mjs +18 -0
  84. package/esm2020/decorators/object/object-decorator-internal.data.mjs +12 -0
  85. package/esm2020/decorators/object/object-decorator.data.mjs +7 -0
  86. package/esm2020/decorators/object/object.decorator.mjs +13 -0
  87. package/esm2020/decorators/string/string-decorator-internal.data.mjs +48 -0
  88. package/esm2020/decorators/string/string-decorator.data.mjs +7 -0
  89. package/esm2020/decorators/string/string.decorator.mjs +24 -0
  90. package/esm2020/public-api.mjs +15 -10
  91. package/fesm2015/ngx-material-entity.mjs +1221 -880
  92. package/fesm2015/ngx-material-entity.mjs.map +1 -1
  93. package/fesm2020/ngx-material-entity.mjs +1225 -877
  94. package/fesm2020/ngx-material-entity.mjs.map +1 -1
  95. package/package.json +2 -1
  96. package/public-api.d.ts +15 -7
  97. package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.d.ts +0 -35
  98. package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.d.ts +0 -12
  99. package/components/input/array-table/array-table.component.d.ts +0 -34
  100. package/components/input/array-table/array-table.module.d.ts +0 -19
  101. package/components/input/internal-input/internal-input.component.d.ts +0 -57
  102. package/components/input/internal-input/internal-input.module.d.ts +0 -16
  103. package/decorators/array.decorator.d.ts +0 -125
  104. package/decorators/base/property-decorator-config.interface.d.ts +0 -50
  105. package/decorators/boolean.decorator.d.ts +0 -42
  106. package/decorators/number.decorator.d.ts +0 -40
  107. package/decorators/object.decorator.d.ts +0 -27
  108. package/decorators/string.decorator.d.ts +0 -76
  109. package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.mjs +0 -43
  110. package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.mjs +0 -22
  111. package/esm2020/components/input/array-table/array-table.component.mjs +0 -116
  112. package/esm2020/components/input/array-table/array-table.module.mjs +0 -66
  113. package/esm2020/components/input/internal-input/internal-input.component.mjs +0 -73
  114. package/esm2020/components/input/internal-input/internal-input.module.mjs +0 -54
  115. package/esm2020/decorators/array.decorator.mjs +0 -70
  116. package/esm2020/decorators/base/property-decorator-config.interface.mjs +0 -31
  117. package/esm2020/decorators/boolean.decorator.mjs +0 -44
  118. package/esm2020/decorators/number.decorator.mjs +0 -36
  119. package/esm2020/decorators/object.decorator.mjs +0 -23
  120. package/esm2020/decorators/string.decorator.mjs +0 -61
@@ -2,17 +2,19 @@ var _a;
2
2
  import { isEqual } from 'lodash';
3
3
  import { DecoratorTypes } from '../decorators/base/decorator-types.enum';
4
4
  /**
5
- * Contains HelperMethods around handling Entities and their property-metadata
5
+ * Contains HelperMethods around handling Entities and their property-metadata.
6
6
  */
7
7
  export class EntityUtilities {
8
8
  /**
9
- * Gets the properties to omit when updating the entity
10
- * @returns The properties which should be left out for updating a new Entity
9
+ * Gets the properties to omit when updating the entity.
10
+ *
11
+ * @param entity - The entity to get the properties which should be left out for updating from.
12
+ * @returns The properties which should be left out for updating an Entity.
11
13
  */
12
14
  static getOmitForUpdate(entity) {
13
15
  const res = [];
14
- for (const key of Reflect.ownKeys(entity)) {
15
- const metadata = Reflect.getMetadata('metadata', entity, key);
16
+ for (const key of EntityUtilities.keysOf(entity)) {
17
+ const metadata = EntityUtilities.getPropertyMetadata(entity, key);
16
18
  if (metadata.omitForUpdate) {
17
19
  res.push(key);
18
20
  }
@@ -20,13 +22,15 @@ export class EntityUtilities {
20
22
  return res;
21
23
  }
22
24
  /**
23
- * Gets the properties to omit when creating new entities
24
- * @returns The properties which should be left out for creating a new Entity
25
+ * Gets the properties to omit when creating new entities.
26
+ *
27
+ * @param entity - The entity to get the properties which should be left out for creating from.
28
+ * @returns The properties which should be left out for creating a new Entity.
25
29
  */
26
30
  static getOmitForCreate(entity) {
27
31
  const res = [];
28
- for (const key of Reflect.ownKeys(entity)) {
29
- const metadata = Reflect.getMetadata('metadata', entity, key);
32
+ for (const key of EntityUtilities.keysOf(entity)) {
33
+ const metadata = EntityUtilities.getPropertyMetadata(entity, key);
30
34
  if (metadata.omitForCreate) {
31
35
  res.push(key);
32
36
  }
@@ -34,11 +38,13 @@ export class EntityUtilities {
34
38
  return res;
35
39
  }
36
40
  /**
37
- * Gets the metadata included in an property
38
- * @param entity The entity with the property to get the metadata from
39
- * @param propertyKey The property on the given Entity to get the metadata from
40
- * @param type For secure Typing, defines the returned PropertyConfig
41
- * @returns The metadata of the property
41
+ * Gets the metadata included in an property.
42
+ *
43
+ * @param entity - The entity with the property to get the metadata from.
44
+ * @param propertyKey - The property on the given Entity to get the metadata from.
45
+ * @param type - For secure Typing, defines the returned PropertyConfig.
46
+ * @returns The metadata of the property.
47
+ * @throws When no metadata can be found for the given property.
42
48
  */
43
49
  static getPropertyMetadata(entity, propertyKey,
44
50
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
@@ -46,58 +52,78 @@ export class EntityUtilities {
46
52
  try {
47
53
  const metadata = Reflect.getMetadata('metadata', entity, propertyKey);
48
54
  if (!metadata) {
49
- throw new Error(`Could not find metadata for property ${String(propertyKey)}
50
- on the entity ${JSON.stringify(entity)}`);
55
+ throw new Error(`Could not find metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`);
51
56
  }
52
57
  return metadata;
53
58
  }
54
59
  catch (error) {
55
- throw new Error(`Could not find metadata for property ${String(propertyKey)}
56
- on the entity ${JSON.stringify(entity)}`);
60
+ throw new Error(`Could not find metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`);
57
61
  }
58
62
  }
59
63
  /**
60
64
  * Gets the type of the property-metadata.
61
- * @param entity The entity with the property to get the type from
62
- * @param propertyKey The property on the given Entity to get the type from
63
- * @returns The type of the metadata
65
+ *
66
+ * @param entity - The entity with the property to get the type from.
67
+ * @param propertyKey - The property on the given Entity to get the type from.
68
+ * @returns The type of the metadata.
69
+ * @throws Will throw an error if no metadata can be found for the given property.
64
70
  */
65
71
  static getPropertyType(entity, propertyKey) {
66
72
  try {
67
73
  const propertyType = Reflect.getMetadata('type', entity, propertyKey);
68
74
  if (!propertyType) {
69
- throw new Error(`Could not find type metadata for property ${String(propertyKey)}
70
- on the entity ${JSON.stringify(entity)}`);
75
+ throw new Error(`Could not find type metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`);
71
76
  }
72
77
  return propertyType;
73
78
  }
74
79
  catch (error) {
75
- throw new Error(`Could not find type metadata for property ${String(propertyKey)}
76
- on the entity ${JSON.stringify(entity)}`);
80
+ throw new Error(`Could not find type metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`);
77
81
  }
78
82
  }
79
83
  /**
80
84
  * Sets all property values based on a given entity data-object.
81
- * @param entity The data object to get the property values from.
82
- * @param target
83
- * the target object that needs to be constructed
84
- * (if called inside a Entity constructor its usually this)
85
+ *
86
+ * @param target - The target object that needs to be constructed (if called inside an Entity constructor its usually this).
87
+ * @param entity - The data object to get the property values from.
85
88
  * @alias new
86
89
  * @alias build
87
90
  * @alias construct
88
91
  */
89
92
  static new(target, entity) {
90
- if (entity) {
91
- for (const key in entity) {
92
- Reflect.set(target, key, Reflect.get(entity, key));
93
+ for (const key in target) {
94
+ const type = EntityUtilities.getPropertyType(target, key);
95
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
96
+ let value = entity ? Reflect.get(entity, key) : undefined;
97
+ switch (type) {
98
+ case DecoratorTypes.OBJECT:
99
+ const objectMetadata = EntityUtilities.getPropertyMetadata(target, key, DecoratorTypes.OBJECT);
100
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-argument
101
+ value = new objectMetadata.type(value);
102
+ break;
103
+ case DecoratorTypes.ARRAY:
104
+ const inputArray = value;
105
+ const resArray = [];
106
+ if (inputArray) {
107
+ const arrayMetadata = EntityUtilities.getPropertyMetadata(target, key, DecoratorTypes.ARRAY);
108
+ for (const item of inputArray) {
109
+ const itemWithMetadata = new arrayMetadata.EntityClass(item);
110
+ resArray.push(itemWithMetadata);
111
+ }
112
+ }
113
+ value = resArray;
114
+ break;
115
+ default:
116
+ break;
93
117
  }
118
+ Reflect.set(target, key, value);
94
119
  }
95
120
  }
96
121
  /**
97
122
  * Checks if the values on an entity are valid.
98
- * Also checks all the validators given by the metadata ("required", "maxLength" etc.)
99
- * @param entity The entity to validate.
100
- * @param omit Whether to check for creatiung or editing validity
123
+ * Also checks all the validators given by the metadata ("required", "maxLength" etc.).
124
+ *
125
+ * @param entity - The entity to validate.
126
+ * @param omit - Whether to check for creating or editing validity.
101
127
  * @returns Whether or not the entity is valid.
102
128
  */
103
129
  static isEntityValid(entity, omit) {
@@ -109,17 +135,19 @@ export class EntityUtilities {
109
135
  return true;
110
136
  }
111
137
  /**
112
- * Checks if a single property value is valid
113
- * @param entity The entity where the property is from
114
- * @param key The name of the property
115
- * @returns Whether or not the property value is valid
138
+ * Checks if a single property value is valid.
139
+ *
140
+ * @param entity - The entity where the property is from.
141
+ * @param key - The name of the property.
142
+ * @param omit - Whether to check if the given entity is valid for creation or updating.
143
+ * @returns Whether or not the property value is valid.
144
+ * @throws Throws when it extracts an unknown metadata type.
116
145
  */
117
146
  static isPropertyValid(entity, key, omit) {
118
147
  const type = this.getPropertyType(entity, key);
119
148
  const metadata = this.getPropertyMetadata(entity, key, type);
120
149
  const metadataDefaultString = metadata;
121
150
  const metadataTextboxString = metadata;
122
- const metadataAutocompleteString = metadata;
123
151
  const metadataDefaultNumber = metadata;
124
152
  const objectProperty = entity[key];
125
153
  const metadataEntityArray = metadata;
@@ -127,14 +155,21 @@ export class EntityUtilities {
127
155
  if (metadata.omitForCreate && omit === 'create') {
128
156
  return true;
129
157
  }
130
- if (metadata.omitForUpdate && omit === 'edit') {
158
+ if (metadata.omitForUpdate && omit === 'update') {
131
159
  return true;
132
160
  }
133
161
  if (metadata.required && !entity[key]) {
134
162
  return false;
135
163
  }
136
164
  switch (type) {
165
+ case DecoratorTypes.BOOLEAN_DROPDOWN:
166
+ case DecoratorTypes.BOOLEAN_CHECKBOX:
167
+ case DecoratorTypes.BOOLEAN_TOGGLE:
168
+ return true;
169
+ case DecoratorTypes.STRING_DROPDOWN:
170
+ return true;
137
171
  case DecoratorTypes.STRING:
172
+ case DecoratorTypes.STRING_AUTOCOMPLETE:
138
173
  if (metadataDefaultString.maxLength
139
174
  && entity[key].length > metadataDefaultString.maxLength) {
140
175
  return false;
@@ -148,20 +183,6 @@ export class EntityUtilities {
148
183
  return false;
149
184
  }
150
185
  break;
151
- case DecoratorTypes.STRING_AUTOCOMPLETE:
152
- if (metadataAutocompleteString.maxLength
153
- && entity[key].length > metadataAutocompleteString.maxLength) {
154
- return false;
155
- }
156
- if (metadataAutocompleteString.minLength
157
- && entity[key].length < metadataAutocompleteString.minLength) {
158
- return false;
159
- }
160
- if (metadataAutocompleteString.regex
161
- && entity[key].match(metadataAutocompleteString.regex)) {
162
- return false;
163
- }
164
- break;
165
186
  case DecoratorTypes.STRING_TEXTBOX:
166
187
  if (metadataTextboxString.maxLength
167
188
  && entity[key].length > metadataTextboxString.maxLength) {
@@ -172,11 +193,13 @@ export class EntityUtilities {
172
193
  return false;
173
194
  }
174
195
  break;
196
+ case DecoratorTypes.NUMBER_DROPDOWN:
197
+ return true;
175
198
  case DecoratorTypes.NUMBER:
176
199
  if (metadataDefaultNumber.max && entity[key] > metadataDefaultNumber.max) {
177
200
  return false;
178
201
  }
179
- if (metadataDefaultNumber.min && entity[key] > metadataDefaultNumber.min) {
202
+ if (metadataDefaultNumber.min && entity[key] < metadataDefaultNumber.min) {
180
203
  return false;
181
204
  }
182
205
  break;
@@ -200,10 +223,11 @@ export class EntityUtilities {
200
223
  return true;
201
224
  }
202
225
  /**
203
- * Checks if an entity is "dirty" (if its values have changed)
204
- * @param entity The entity after all changes
205
- * @param entityPriorChanges The entity before the changes
206
- * @returns Whether or not the entity is dirty
226
+ * Checks if an entity is "dirty" (if its values have changed).
227
+ *
228
+ * @param entity - The entity after all changes.
229
+ * @param entityPriorChanges - The entity before the changes.
230
+ * @returns Whether or not the entity is dirty.
207
231
  */
208
232
  static dirty(entity, entityPriorChanges) {
209
233
  if (!entityPriorChanges) {
@@ -220,10 +244,11 @@ export class EntityUtilities {
220
244
  }
221
245
  }
222
246
  /**
223
- * Compares two Entities and returns their difference in an object
224
- * @param entity The first entity to compare
225
- * @param entityPriorChanges The second entity to compare
226
- * @returns The difference between the two Entities in form of a Partial
247
+ * Compares two Entities and returns their difference in an object.
248
+ *
249
+ * @param entity - The first entity to compare.
250
+ * @param entityPriorChanges - The second entity to compare.
251
+ * @returns The difference between the two Entities in form of a Partial.
227
252
  */
228
253
  static difference(entity, entityPriorChanges) {
229
254
  const res = {};
@@ -234,63 +259,119 @@ export class EntityUtilities {
234
259
  }
235
260
  return res;
236
261
  }
262
+ //TODO X Y
237
263
  /**
238
- * compare function for sorting entity keys by their order value
239
- * @param a first key of entity
240
- * @param b second key of entity
241
- * @param entity current entity (used to get metadata of entity keys)
264
+ * Compare function for sorting entity keys by their order value.
265
+ *
266
+ * @param a - First key of entity.
267
+ * @param b - Second key of entity.
268
+ * @param entity - Current entity (used to get metadata of entity keys).
269
+ * @returns 0 if both values have the same order, a negative value if X, a positive value if Y.
242
270
  */
243
271
  static compareOrder(a, b, entity) {
244
- const metadataA = EntityUtilities.getPropertyMetadata(entity, a, EntityUtilities.getPropertyType(entity, a));
245
- const metadataB = EntityUtilities.getPropertyMetadata(entity, b, EntityUtilities.getPropertyType(entity, b));
246
- if (metadataA.order === -1) {
272
+ const metadataA = EntityUtilities.getPropertyMetadata(entity, a);
273
+ const metadataB = EntityUtilities.getPropertyMetadata(entity, b);
274
+ if (metadataA.position.order === -1) {
275
+ if (metadataB.position.order === -1) {
276
+ return 0;
277
+ }
247
278
  return 1;
248
279
  }
249
- else if (metadataB.order === -1) {
250
- return 0;
280
+ else if (metadataB.position.order === -1) {
281
+ return -1;
251
282
  }
252
- return (metadataA.order - metadataB.order);
283
+ return ((metadataA.position.order) - (metadataB.position.order));
253
284
  }
254
285
  /**
255
- * gets the bootstrap column values for "lg", "md", "sm"
256
- * @param entity entity to get the bootstrap column values of the key
257
- * @param key key of the property to get bootstrap column values from
258
- * @param type defines for which screensize the column values should be returned
259
- * @returns bootstrap column value
286
+ * Gets the bootstrap column values for "lg", "md", "sm".
287
+ *
288
+ * @param entity - Entity to get the bootstrap column values of the key.
289
+ * @param key - Key of the property to get bootstrap column values from.
290
+ * @param type - Defines for which screen size the column values should be returned.
291
+ * @returns Bootstrap column value.
260
292
  */
261
293
  static getWidth(entity, key, type) {
262
- const propertyType = EntityUtilities.getPropertyType(entity, key);
263
- const metadata = EntityUtilities.getPropertyMetadata(entity, key, propertyType);
264
- if (metadata.defaultWidths) {
265
- switch (type) {
266
- case 'lg':
267
- return metadata.defaultWidths[0];
268
- case 'md':
269
- return metadata.defaultWidths[1];
270
- case 'sm':
271
- return metadata.defaultWidths[2];
272
- default:
273
- throw new Error('Something went wrong getting the width');
274
- }
275
- }
276
- else {
277
- throw new Error('Something went wrong getting the width');
294
+ const metadata = EntityUtilities.getPropertyMetadata(entity, key);
295
+ switch (type) {
296
+ case 'lg':
297
+ return metadata.defaultWidths[0];
298
+ case 'md':
299
+ return metadata.defaultWidths[1];
300
+ case 'sm':
301
+ return metadata.defaultWidths[2];
278
302
  }
279
303
  }
280
304
  /**
281
- * Resets all changes on an entity
282
- * @param entity The entity to reset
283
- * @param entityPriorChanges The entity before any changes
305
+ * Resets all changes on an entity.
306
+ *
307
+ * @param entity - The entity to reset.
308
+ * @param entityPriorChanges - The entity before any changes.
284
309
  */
285
310
  static resetChangesOnEntity(entity, entityPriorChanges) {
286
311
  for (const key in entityPriorChanges) {
287
312
  Reflect.set(entity, key, Reflect.get(entityPriorChanges, key));
288
313
  }
289
314
  }
315
+ /**
316
+ * Gets the rows that are used to display the given entity.
317
+ *
318
+ * @param entity - The entity to get the rows from.
319
+ * @param hideOmitForCreate - Whether or not keys with the metadata omitForCreate should be filtered out.
320
+ * @param hideOmitForEdit - Whether or not keys with the metadata omitForUpdate should be filtered out.
321
+ * @returns The sorted Rows containing the row number and the keys to display in that row.
322
+ */
323
+ static getEntityRows(entity, hideOmitForCreate = false, hideOmitForEdit = false) {
324
+ const res = [];
325
+ const keys = EntityUtilities.keysOf(entity, hideOmitForCreate, hideOmitForEdit);
326
+ const numberOfRows = EntityUtilities.getNumberOfRows(keys, entity);
327
+ for (let i = 1; i <= numberOfRows; i++) {
328
+ const row = {
329
+ row: i,
330
+ keys: EntityUtilities.getKeysForRow(keys, entity, i)
331
+ };
332
+ res.push(row);
333
+ }
334
+ const lastRow = {
335
+ row: numberOfRows + 1,
336
+ keys: EntityUtilities.getKeysForRow(keys, entity, -1)
337
+ };
338
+ res.push(lastRow);
339
+ return res;
340
+ }
341
+ static getKeysForRow(keys, entity, i) {
342
+ return keys
343
+ .filter(k => EntityUtilities.getPropertyMetadata(entity, k).position.row === i)
344
+ .sort((a, b) => EntityUtilities.compareOrder(a, b, entity));
345
+ }
346
+ static getNumberOfRows(keys, entity) {
347
+ return keys
348
+ .map(k => EntityUtilities.getPropertyMetadata(entity, k).position.row)
349
+ .sort((a, b) => (a > b ? -1 : 1))[0];
350
+ }
351
+ /**
352
+ * Gets the keys of the provided entity correctly typed.
353
+ *
354
+ * @param entity - The entity to get the keys of.
355
+ * @param hideOmitForCreate - Whether or not keys with the metadata omitForCreate should be filtered out.
356
+ * @param hideOmitForEdit - Whether or not keys with the metadata omitForUpdate should be filtered out.
357
+ * @returns An array of keys of the entity.
358
+ */
359
+ static keysOf(entity, hideOmitForCreate = false, hideOmitForEdit = false) {
360
+ let keys = Reflect.ownKeys(entity);
361
+ if (hideOmitForCreate) {
362
+ const omitForCreateKeys = EntityUtilities.getOmitForCreate(entity);
363
+ keys = keys.filter(k => !omitForCreateKeys.includes(k));
364
+ }
365
+ if (hideOmitForEdit) {
366
+ const omitForUpdateKeys = EntityUtilities.getOmitForUpdate(entity);
367
+ keys = keys.filter(k => !omitForUpdateKeys.includes(k));
368
+ }
369
+ return keys;
370
+ }
290
371
  }
291
372
  _a = EntityUtilities;
292
- // eslint-disable-next-line @typescript-eslint/member-ordering
373
+ // eslint-disable-next-line @typescript-eslint/member-ordering, jsdoc/require-jsdoc
293
374
  EntityUtilities.construct = _a.new;
294
- // eslint-disable-next-line @typescript-eslint/member-ordering
375
+ // eslint-disable-next-line @typescript-eslint/member-ordering, jsdoc/require-jsdoc
295
376
  EntityUtilities.build = _a.new;
296
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-utilities.class.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/classes/entity-utilities.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { isEqual } from 'lodash';\nimport { DecoratorType, DecoratorTypes } from '../decorators/base/decorator-types.enum';\nimport { PropertyDecoratorConfig } from '../decorators/base/property-decorator-config.interface';\nimport { DefaultNumberDecoratorConfig } from '../decorators/number.decorator';\nimport { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, TextboxStringDecoratorConfig } from '../decorators/string.decorator';\nimport { EntityArrayDecoratorConfig } from '../decorators/array.decorator';\nimport { Entity } from './entity-model.class';\n\n/**\n * Contains HelperMethods around handling Entities and their property-metadata\n */\nexport abstract class EntityUtilities {\n    /**\n     * Gets the properties to omit when updating the entity\n     * @returns The properties which should be left out for updating a new Entity\n     */\n    static getOmitForUpdate<EntityType extends Entity>(entity: EntityType): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key of Reflect.ownKeys(entity)) {\n            const metadata = Reflect.getMetadata('metadata', entity, key) as PropertyDecoratorConfig;\n            if (metadata.omitForUpdate) {\n                res.push(key as keyof EntityType);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Gets the properties to omit when creating new entities\n     * @returns The properties which should be left out for creating a new Entity\n     */\n    static getOmitForCreate<EntityType extends Entity>(entity: EntityType): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key of Reflect.ownKeys(entity)) {\n            const metadata = Reflect.getMetadata('metadata', entity, key) as PropertyDecoratorConfig;\n            if (metadata.omitForCreate) {\n                res.push(key as keyof EntityType);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Gets the metadata included in an property\n     * @param entity The entity with the property to get the metadata from\n     * @param propertyKey The property on the given Entity to get the metadata from\n     * @param type For secure Typing, defines the returned PropertyConfig\n     * @returns The metadata of the property\n     */\n    static getPropertyMetadata<EntityType extends Entity, T extends DecoratorTypes>(\n        entity: EntityType,\n        propertyKey: keyof EntityType,\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        type: T\n    ): DecoratorType<T> {\n        try {\n            const metadata = Reflect.getMetadata('metadata', entity, propertyKey as string) as DecoratorType<T>;\n            if (!metadata) {\n                throw new Error(\n                    `Could not find metadata for property ${String(propertyKey)}\n                    on the entity ${JSON.stringify(entity)}`\n                );\n            }\n            return metadata ;\n        }\n        catch (error) {\n            throw new Error(\n                `Could not find metadata for property ${String(propertyKey)}\n                on the entity ${JSON.stringify(entity)}`\n            );\n        }\n    }\n\n    /**\n     * Gets the type of the property-metadata.\n     * @param entity The entity with the property to get the type from\n     * @param propertyKey The property on the given Entity to get the type from\n     * @returns The type of the metadata\n     */\n    static getPropertyType<EntityType extends Entity>(\n        entity: EntityType, propertyKey: keyof EntityType\n    ): DecoratorTypes {\n        try {\n            const propertyType = Reflect.getMetadata('type', entity, propertyKey as string) as DecoratorTypes;\n            if (!propertyType) {\n                throw new Error(\n                    `Could not find type metadata for property ${String(propertyKey)}\n                    on the entity ${JSON.stringify(entity)}`\n                );\n            }\n            return propertyType;\n        }\n        catch (error) {\n            throw new Error(\n                `Could not find type metadata for property ${String(propertyKey)}\n                on the entity ${JSON.stringify(entity)}`\n            );\n        }\n    }\n\n    /**\n     * Sets all property values based on a given entity data-object.\n     * @param entity The data object to get the property values from.\n     * @param target\n     * the target object that needs to be constructed\n     * (if called inside a Entity constructor its usually this)\n     * @alias new\n     * @alias build\n     * @alias construct\n     */\n    static new<EntityType extends Entity>(target: EntityType, entity?: EntityType): void {\n        if (entity) {\n            for (const key in entity) {\n                Reflect.set(target, key, Reflect.get(entity, key));\n            }\n        }\n    }\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    static construct = this.new;\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    static build = this.new;\n\n    /**\n     * Checks if the values on an entity are valid.\n     * Also checks all the validators given by the metadata (\"required\", \"maxLength\" etc.)\n     * @param entity The entity to validate.\n     * @param omit Whether to check for creatiung or editing validity\n     * @returns Whether or not the entity is valid.\n     */\n    static isEntityValid<EntityType extends Entity>(entity: EntityType, omit: 'create' | 'edit'): boolean {\n        for (const key in entity) {\n            if (!this.isPropertyValid(entity, key, omit)) {\n                return false;\n            }\n        }\n        return true;\n    }\n    /**\n     * Checks if a single property value is valid\n     * @param entity The entity where the property is from\n     * @param key The name of the property\n     * @returns Whether or not the property value is valid\n     */\n    private static isPropertyValid<EntityType extends Entity>(entity: EntityType, key: keyof EntityType, omit: 'create' | 'edit'): boolean {\n        const type = this.getPropertyType(entity, key);\n        const metadata: PropertyDecoratorConfig = this.getPropertyMetadata(entity, key, type);\n        const metadataDefaultString = metadata as DefaultStringDecoratorConfig;\n        const metadataTextboxString = metadata as TextboxStringDecoratorConfig;\n        const metadataAutocompleteString = metadata as AutocompleteStringDecoratorConfig;\n        const metadataDefaultNumber = metadata as DefaultNumberDecoratorConfig;\n        const objectProperty = entity[key] as unknown as EntityType;\n        const metadataEntityArray = metadata as EntityArrayDecoratorConfig<Entity>;\n        const arrayItems = entity[key] as unknown as [];\n\n        if (metadata.omitForCreate && omit === 'create') {\n            return true;\n        }\n        if (metadata.omitForUpdate && omit === 'edit') {\n            return true;\n        }\n        if (metadata.required && !entity[key]) {\n            return false;\n        }\n        switch (type) {\n            case DecoratorTypes.STRING:\n                if (\n                    metadataDefaultString.maxLength\n                    && (entity[key] as unknown as string).length > metadataDefaultString.maxLength\n                ) {\n                    return false;\n                }\n                if (\n                    metadataDefaultString.minLength\n                    && (entity[key] as unknown as string).length < metadataDefaultString.minLength\n                ) {\n                    return false;\n                }\n                if (\n                    metadataDefaultString.regex\n                    && !(entity[key] as unknown as string).match(metadataDefaultString.regex)\n                ) {\n                    return false;\n                }\n                break;\n            case DecoratorTypes.STRING_AUTOCOMPLETE:\n                if (\n                    metadataAutocompleteString.maxLength\n                    && (entity[key] as unknown as string).length > metadataAutocompleteString.maxLength\n                ) {\n                    return false;\n                }\n                if (\n                    metadataAutocompleteString.minLength\n                    && (entity[key] as unknown as string).length < metadataAutocompleteString.minLength\n                ) {\n                    return false;\n                }\n                if (\n                    metadataAutocompleteString.regex\n                    && (entity[key] as unknown as string).match(metadataAutocompleteString.regex)\n                ) {\n                    return false;\n                }\n                break;\n            case DecoratorTypes.STRING_TEXTBOX:\n                if (\n                    metadataTextboxString.maxLength\n                    && (entity[key] as unknown as string).length > metadataTextboxString.maxLength\n                ) {\n                    return false;\n                }\n                if (\n                    metadataTextboxString.minLength\n                    && (entity[key] as unknown as string).length < metadataTextboxString.minLength\n                ) {\n                    return false;\n                }\n                break;\n            case DecoratorTypes.NUMBER:\n                if (metadataDefaultNumber.max && (entity[key] as unknown as number) > metadataDefaultNumber.max) {\n                    return false;\n                }\n                if (metadataDefaultNumber.min && (entity[key] as unknown as number) > metadataDefaultNumber.min) {\n                    return false;\n                }\n                break;\n            case DecoratorTypes.OBJECT:\n                for (const parameterKey in objectProperty) {\n                    if (!this.isPropertyValid(objectProperty, parameterKey, omit)) {\n                        return false;\n                    }\n                }\n                break;\n            case DecoratorTypes.ARRAY_STRING_CHIPS:\n            case DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS:\n            case DecoratorTypes.ARRAY:\n                if (metadataEntityArray.required && !arrayItems.length) {\n                    return false;\n                }\n                break;\n            default:\n                throw new Error(`Could not validate the input because the DecoratorType ${type} is not known`);\n        }\n        return true;\n    }\n\n    /**\n     * Checks if an entity is \"dirty\" (if its values have changed)\n     * @param entity The entity after all changes\n     * @param entityPriorChanges The entity before the changes\n     * @returns Whether or not the entity is dirty\n     */\n    static dirty(entity: Entity, entityPriorChanges: Entity): boolean {\n        if (!entityPriorChanges) {\n            return false;\n        }\n        else {\n            const diff = this.difference(entity, entityPriorChanges);\n            if (JSON.stringify(diff) === '{}') {\n                return false;\n            }\n            else {\n                return true;\n            }\n        }\n    }\n\n    /**\n     * Compares two Entities and returns their difference in an object\n     * @param entity The first entity to compare\n     * @param entityPriorChanges The second entity to compare\n     * @returns The difference between the two Entities in form of a Partial\n     */\n    static difference<EntityType extends Entity>(\n        entity: EntityType,\n        entityPriorChanges: EntityType\n    ): Partial<EntityType> {\n        const res: Partial<EntityType> = {};\n        for (const key in entity) {\n            if (!isEqual(entity[key], entityPriorChanges[key])) {\n                res[key] = entity[key];\n            }\n        }\n        return res;\n    }\n\n    /**\n     * compare function for sorting entity keys by their order value\n     * @param a first key of entity\n     * @param b second key of entity\n     * @param entity current entity (used to get metadata of entity keys)\n     */\n    static compareOrder<EntityType extends Entity>(a: keyof EntityType, b: keyof EntityType, entity: EntityType): number {\n        const metadataA = EntityUtilities.getPropertyMetadata(entity, a, EntityUtilities.getPropertyType(entity, a));\n        const metadataB = EntityUtilities.getPropertyMetadata(entity, b, EntityUtilities.getPropertyType(entity, b));\n\n        if (metadataA.order === -1) {\n            return 1;\n        }\n        else if (metadataB.order === -1) {\n            return 0;\n        }\n\n        return ((metadataA.order as number) - (metadataB.order as number));\n    }\n\n    /**\n     * gets the bootstrap column values for \"lg\", \"md\", \"sm\"\n     * @param entity entity to get the bootstrap column values of the key\n     * @param key key of the property to get bootstrap column values from\n     * @param type defines for which screensize the column values should be returned\n     * @returns bootstrap column value\n     */\n    static getWidth<EntityType extends Entity>(entity: EntityType, key: keyof EntityType, type: 'lg' | 'md' | 'sm'): number {\n        const propertyType = EntityUtilities.getPropertyType(entity, key);\n        const metadata = EntityUtilities.getPropertyMetadata(entity, key, propertyType);\n        if (metadata.defaultWidths) {\n            switch (type) {\n                case 'lg':\n                    return metadata.defaultWidths[0];\n                case 'md':\n                    return metadata.defaultWidths[1];\n                case 'sm':\n                    return metadata.defaultWidths[2];\n                default:\n                    throw new Error('Something went wrong getting the width');\n            }\n        }\n        else {\n            throw new Error('Something went wrong getting the width');\n        }\n    }\n\n    /**\n     * Resets all changes on an entity\n     * @param entity The entity to reset\n     * @param entityPriorChanges The entity before any changes\n     */\n    static resetChangesOnEntity<EntityType extends Entity>(entity: EntityType, entityPriorChanges: EntityType): void {\n        for (const key in entityPriorChanges) {\n            Reflect.set(entity, key, Reflect.get(entityPriorChanges, key));\n        }\n    }\n}"]}
377
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-utilities.class.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/classes/entity-utilities.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { isEqual } from 'lodash';\nimport { DecoratorType, DecoratorTypes } from '../decorators/base/decorator-types.enum';\nimport { Entity } from './entity-model.class';\nimport { PropertyDecoratorConfigInternal } from '../decorators/base/property-decorator-internal.data';\nimport { EntityArrayDecoratorConfigInternal } from '../decorators/array/array-decorator-internal.data';\nimport { DefaultStringDecoratorConfigInternal, TextboxStringDecoratorConfigInternal } from '../decorators/string/string-decorator-internal.data';\nimport { DefaultNumberDecoratorConfigInternal } from '../decorators/number/number-decorator-internal.data';\n\n/**\n * Contains HelperMethods around handling Entities and their property-metadata.\n */\nexport abstract class EntityUtilities {\n\n    /**\n     * Gets the properties to omit when updating the entity.\n     *\n     * @param entity - The entity to get the properties which should be left out for updating from.\n     * @returns The properties which should be left out for updating an Entity.\n     */\n    static getOmitForUpdate<EntityType extends Entity>(entity: EntityType): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key of EntityUtilities.keysOf(entity)) {\n            const metadata = EntityUtilities.getPropertyMetadata(entity, key);\n            if (metadata.omitForUpdate) {\n                res.push(key);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Gets the properties to omit when creating new entities.\n     *\n     * @param entity - The entity to get the properties which should be left out for creating from.\n     * @returns The properties which should be left out for creating a new Entity.\n     */\n    static getOmitForCreate<EntityType extends Entity>(entity: EntityType): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key of EntityUtilities.keysOf(entity)) {\n            const metadata = EntityUtilities.getPropertyMetadata(entity, key);\n            if (metadata.omitForCreate) {\n                res.push(key);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Gets the metadata included in an property.\n     *\n     * @param entity - The entity with the property to get the metadata from.\n     * @param propertyKey - The property on the given Entity to get the metadata from.\n     * @param type - For secure Typing, defines the returned PropertyConfig.\n     * @returns The metadata of the property.\n     * @throws When no metadata can be found for the given property.\n     */\n    static getPropertyMetadata<EntityType extends Entity, T extends DecoratorTypes>(\n        entity: EntityType,\n        propertyKey: keyof EntityType,\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        type?: T\n    ): DecoratorType<T> {\n        try {\n            const metadata = Reflect.getMetadata('metadata', entity, propertyKey as string) as DecoratorType<T>;\n            if (!metadata) {\n                throw new Error(\n                    `Could not find metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`\n                );\n            }\n            return metadata;\n        }\n        catch (error) {\n            throw new Error(\n                `Could not find metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`\n            );\n        }\n    }\n\n    /**\n     * Gets the type of the property-metadata.\n     *\n     * @param entity - The entity with the property to get the type from.\n     * @param propertyKey - The property on the given Entity to get the type from.\n     * @returns The type of the metadata.\n     * @throws Will throw an error if no metadata can be found for the given property.\n     */\n    static getPropertyType<EntityType extends Entity>(\n        entity: EntityType, propertyKey: keyof EntityType\n    ): DecoratorTypes {\n        try {\n            const propertyType = Reflect.getMetadata('type', entity, propertyKey as string) as DecoratorTypes;\n            if (!propertyType) {\n                throw new Error(\n                    `Could not find type metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`\n                );\n            }\n            return propertyType;\n        }\n        catch (error) {\n            throw new Error(\n                `Could not find type metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`\n            );\n        }\n    }\n\n    /**\n     * Sets all property values based on a given entity data-object.\n     *\n     * @param target - The target object that needs to be constructed (if called inside an Entity constructor its usually this).\n     * @param entity - The data object to get the property values from.\n     * @alias new\n     * @alias build\n     * @alias construct\n     */\n    static new<EntityType extends Entity>(target: EntityType, entity?: EntityType): void {\n        for (const key in target) {\n            const type = EntityUtilities.getPropertyType(target, key);\n            // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n            let value = entity ? Reflect.get(entity, key) : undefined;\n            switch (type) {\n                case DecoratorTypes.OBJECT:\n                    const objectMetadata = EntityUtilities.getPropertyMetadata(target, key, DecoratorTypes.OBJECT);\n                    // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n                    value = new objectMetadata.type(value) as EntityType;\n                    break;\n                case DecoratorTypes.ARRAY:\n                    const inputArray: EntityType[] = value as EntityType[];\n                    const resArray: EntityType[] = [];\n                    if (inputArray) {\n                        const arrayMetadata = EntityUtilities.getPropertyMetadata(target, key, DecoratorTypes.ARRAY);\n                        for (const item of inputArray) {\n                            const itemWithMetadata = new arrayMetadata.EntityClass(item) as EntityType;\n                            resArray.push(itemWithMetadata);\n                        }\n                    }\n                    value = resArray;\n                    break;\n                default:\n                    break;\n            }\n            Reflect.set(target, key, value);\n        }\n    }\n    // eslint-disable-next-line @typescript-eslint/member-ordering, jsdoc/require-jsdoc\n    static construct = this.new;\n    // eslint-disable-next-line @typescript-eslint/member-ordering, jsdoc/require-jsdoc\n    static build = this.new;\n\n    /**\n     * Checks if the values on an entity are valid.\n     * Also checks all the validators given by the metadata (\"required\", \"maxLength\" etc.).\n     *\n     * @param entity - The entity to validate.\n     * @param omit - Whether to check for creating or editing validity.\n     * @returns Whether or not the entity is valid.\n     */\n    static isEntityValid<EntityType extends Entity>(entity: EntityType, omit: 'create' | 'update'): boolean {\n        for (const key in entity) {\n            if (!this.isPropertyValid(entity, key, omit)) {\n                return false;\n            }\n        }\n        return true;\n    }\n    /**\n     * Checks if a single property value is valid.\n     *\n     * @param entity - The entity where the property is from.\n     * @param key - The name of the property.\n     * @param omit - Whether to check if the given entity is valid for creation or updating.\n     * @returns Whether or not the property value is valid.\n     * @throws Throws when it extracts an unknown metadata type.\n     */\n    private static isPropertyValid<EntityType extends Entity>(\n        entity: EntityType,\n        key: keyof EntityType,\n        omit: 'create' | 'update'\n    ): boolean {\n        const type = this.getPropertyType(entity, key);\n        const metadata: PropertyDecoratorConfigInternal = this.getPropertyMetadata(entity, key, type);\n        const metadataDefaultString = metadata as DefaultStringDecoratorConfigInternal;\n        const metadataTextboxString = metadata as TextboxStringDecoratorConfigInternal;\n        const metadataDefaultNumber = metadata as DefaultNumberDecoratorConfigInternal;\n        const objectProperty = entity[key] as unknown as EntityType;\n        const metadataEntityArray = metadata as EntityArrayDecoratorConfigInternal<Entity>;\n        const arrayItems = entity[key] as unknown as [];\n\n        if (metadata.omitForCreate && omit === 'create') {\n            return true;\n        }\n        if (metadata.omitForUpdate && omit === 'update') {\n            return true;\n        }\n        if (metadata.required && !entity[key]) {\n            return false;\n        }\n        switch (type) {\n            case DecoratorTypes.BOOLEAN_DROPDOWN:\n            case DecoratorTypes.BOOLEAN_CHECKBOX:\n            case DecoratorTypes.BOOLEAN_TOGGLE:\n                return true;\n            case DecoratorTypes.STRING_DROPDOWN:\n                return true;\n            case DecoratorTypes.STRING:\n            case DecoratorTypes.STRING_AUTOCOMPLETE:\n                if (\n                    metadataDefaultString.maxLength\n                    && (entity[key] as unknown as string).length > metadataDefaultString.maxLength\n                ) {\n                    return false;\n                }\n                if (\n                    metadataDefaultString.minLength\n                    && (entity[key] as unknown as string).length < metadataDefaultString.minLength\n                ) {\n                    return false;\n                }\n                if (\n                    metadataDefaultString.regex\n                    && !(entity[key] as unknown as string).match(metadataDefaultString.regex)\n                ) {\n                    return false;\n                }\n                break;\n            case DecoratorTypes.STRING_TEXTBOX:\n                if (\n                    metadataTextboxString.maxLength\n                    && (entity[key] as unknown as string).length > metadataTextboxString.maxLength\n                ) {\n                    return false;\n                }\n                if (\n                    metadataTextboxString.minLength\n                    && (entity[key] as unknown as string).length < metadataTextboxString.minLength\n                ) {\n                    return false;\n                }\n                break;\n            case DecoratorTypes.NUMBER_DROPDOWN:\n                return true;\n            case DecoratorTypes.NUMBER:\n                if (metadataDefaultNumber.max && (entity[key] as unknown as number) > metadataDefaultNumber.max) {\n                    return false;\n                }\n                if (metadataDefaultNumber.min && (entity[key] as unknown as number) < metadataDefaultNumber.min) {\n                    return false;\n                }\n                break;\n            case DecoratorTypes.OBJECT:\n                for (const parameterKey in objectProperty) {\n                    if (!this.isPropertyValid(objectProperty, parameterKey, omit)) {\n                        return false;\n                    }\n                }\n                break;\n            case DecoratorTypes.ARRAY_STRING_CHIPS:\n            case DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS:\n            case DecoratorTypes.ARRAY:\n                if (metadataEntityArray.required && !arrayItems.length) {\n                    return false;\n                }\n                break;\n            default:\n                throw new Error(`Could not validate the input because the DecoratorType ${type} is not known`);\n        }\n        return true;\n    }\n\n    /**\n     * Checks if an entity is \"dirty\" (if its values have changed).\n     *\n     * @param entity - The entity after all changes.\n     * @param entityPriorChanges - The entity before the changes.\n     * @returns Whether or not the entity is dirty.\n     */\n    static dirty(entity: Entity, entityPriorChanges: Entity): boolean {\n        if (!entityPriorChanges) {\n            return false;\n        }\n        else {\n            const diff = this.difference(entity, entityPriorChanges);\n            if (JSON.stringify(diff) === '{}') {\n                return false;\n            }\n            else {\n                return true;\n            }\n        }\n    }\n\n    /**\n     * Compares two Entities and returns their difference in an object.\n     *\n     * @param entity - The first entity to compare.\n     * @param entityPriorChanges - The second entity to compare.\n     * @returns The difference between the two Entities in form of a Partial.\n     */\n    static difference<EntityType extends Entity>(\n        entity: EntityType,\n        entityPriorChanges: EntityType\n    ): Partial<EntityType> {\n        const res: Partial<EntityType> = {};\n        for (const key in entity) {\n            if (!isEqual(entity[key], entityPriorChanges[key])) {\n                res[key] = entity[key];\n            }\n        }\n        return res;\n    }\n\n    //TODO X Y\n    /**\n     * Compare function for sorting entity keys by their order value.\n     *\n     * @param a - First key of entity.\n     * @param b - Second key of entity.\n     * @param entity - Current entity (used to get metadata of entity keys).\n     * @returns 0 if both values have the same order, a negative value if X, a positive value if Y.\n     */\n    static compareOrder<EntityType extends Entity>(a: keyof EntityType, b: keyof EntityType, entity: EntityType): number {\n        const metadataA = EntityUtilities.getPropertyMetadata(entity, a);\n        const metadataB = EntityUtilities.getPropertyMetadata(entity, b);\n\n        if (metadataA.position.order === -1) {\n            if (metadataB.position.order === -1) {\n                return 0;\n            }\n            return 1;\n        }\n        else if (metadataB.position.order === -1) {\n            return -1;\n        }\n\n        return ((metadataA.position.order ) - (metadataB.position.order ));\n    }\n\n    /**\n     * Gets the bootstrap column values for \"lg\", \"md\", \"sm\".\n     *\n     * @param entity - Entity to get the bootstrap column values of the key.\n     * @param key - Key of the property to get bootstrap column values from.\n     * @param type - Defines for which screen size the column values should be returned.\n     * @returns Bootstrap column value.\n     */\n    static getWidth<EntityType extends Entity>(entity: EntityType, key: keyof EntityType, type: 'lg' | 'md' | 'sm'): number {\n        const metadata = EntityUtilities.getPropertyMetadata(entity, key);\n        switch (type) {\n            case 'lg':\n                return metadata.defaultWidths[0];\n            case 'md':\n                return metadata.defaultWidths[1];\n            case 'sm':\n                return metadata.defaultWidths[2];\n        }\n    }\n\n    /**\n     * Resets all changes on an entity.\n     *\n     * @param entity - The entity to reset.\n     * @param entityPriorChanges - The entity before any changes.\n     */\n    static resetChangesOnEntity<EntityType extends Entity>(entity: EntityType, entityPriorChanges: EntityType): void {\n        for (const key in entityPriorChanges) {\n            Reflect.set(entity, key, Reflect.get(entityPriorChanges, key));\n        }\n    }\n\n    /**\n     * Gets the rows that are used to display the given entity.\n     *\n     * @param entity - The entity to get the rows from.\n     * @param hideOmitForCreate - Whether or not keys with the metadata omitForCreate should be filtered out.\n     * @param hideOmitForEdit - Whether or not keys with the metadata omitForUpdate should be filtered out.\n     * @returns The sorted Rows containing the row number and the keys to display in that row.\n     */\n    static getEntityRows<EntityType extends Entity>(\n        entity: EntityType,\n        hideOmitForCreate: boolean = false,\n        hideOmitForEdit: boolean = false\n    ): EntityRow<EntityType>[] {\n        const res: EntityRow<EntityType>[] = [];\n\n        const keys: (keyof EntityType)[] = EntityUtilities.keysOf(entity, hideOmitForCreate, hideOmitForEdit);\n        const numberOfRows: number = EntityUtilities.getNumberOfRows<EntityType>(keys, entity);\n        for (let i = 1; i <= numberOfRows; i++) {\n            const row: EntityRow<EntityType> = {\n                row: i,\n                keys: EntityUtilities.getKeysForRow<EntityType>(keys, entity, i)\n            };\n            res.push(row);\n        }\n        const lastRow: EntityRow<EntityType> = {\n            row: numberOfRows + 1,\n            keys: EntityUtilities.getKeysForRow<EntityType>(keys, entity, -1)\n        };\n        res.push(lastRow);\n        return res;\n    }\n\n    private static getKeysForRow<EntityType extends Entity>(\n        keys: (keyof EntityType)[],\n        entity: EntityType,\n        i: number\n    ): (keyof EntityType)[] {\n        return keys\n            .filter(k => EntityUtilities.getPropertyMetadata(entity, k).position.row === i)\n            .sort((a, b) => EntityUtilities.compareOrder(a, b, entity));\n    }\n\n    private static getNumberOfRows<EntityType extends Entity>(keys: (keyof EntityType)[], entity: EntityType): number {\n        return keys\n            .map(k => EntityUtilities.getPropertyMetadata(entity, k).position.row)\n            .sort((a, b) => (a > b ? -1 : 1))[0];\n    }\n\n    /**\n     * Gets the keys of the provided entity correctly typed.\n     *\n     * @param entity - The entity to get the keys of.\n     * @param hideOmitForCreate - Whether or not keys with the metadata omitForCreate should be filtered out.\n     * @param hideOmitForEdit - Whether or not keys with the metadata omitForUpdate should be filtered out.\n     * @returns An array of keys of the entity.\n     */\n    static keysOf<EntityType extends Entity>(\n        entity: EntityType,\n        hideOmitForCreate: boolean = false,\n        hideOmitForEdit: boolean = false\n    ): (keyof EntityType)[] {\n        let keys: (keyof EntityType)[] = Reflect.ownKeys(entity) as (keyof EntityType)[];\n        if (hideOmitForCreate) {\n            const omitForCreateKeys: (keyof EntityType)[] = EntityUtilities.getOmitForCreate(entity);\n            keys = keys.filter(k => !omitForCreateKeys.includes(k));\n        }\n        if (hideOmitForEdit) {\n            const omitForUpdateKeys: (keyof EntityType)[] = EntityUtilities.getOmitForUpdate(entity);\n            keys = keys.filter(k => !omitForUpdateKeys.includes(k));\n        }\n        return keys;\n    }\n}\n\n/**\n * A row that contains all the information about how to display an entity.\n */\nexport interface EntityRow<EntityType extends Entity> {\n    /**\n     * The row in which this should be displayed.\n     */\n    row: number,\n    /**\n     * The keys of the values that should be displayed in that row.\n     */\n    keys: (keyof EntityType)[]\n}"]}
@@ -0,0 +1,44 @@
1
+ import { BaseBuilder } from '../../classes/base-builder.class';
2
+ /**
3
+ * The internal ConfirmDialogData. Requires all default values the user can leave out.
4
+ */
5
+ export class ConfirmDialogDataInternal {
6
+ constructor(text, type, confirmButtonLabel, cancelButtonLabel, title, requireConfirmation, confirmationText) {
7
+ this.text = text;
8
+ this.type = type;
9
+ this.confirmButtonLabel = confirmButtonLabel;
10
+ this.cancelButtonLabel = cancelButtonLabel;
11
+ this.title = title;
12
+ this.requireConfirmation = requireConfirmation;
13
+ this.confirmationText = confirmationText;
14
+ }
15
+ }
16
+ /**
17
+ * The Builder for the ConfirmDialogData. Sets default values.
18
+ */
19
+ export class ConfirmDialogDataBuilder extends BaseBuilder {
20
+ constructor(data) {
21
+ super(data);
22
+ }
23
+ // eslint-disable-next-line jsdoc/require-jsdoc
24
+ generateBaseData(data) {
25
+ return new ConfirmDialogDataInternal(data?.text ? data.text : ['Do you really want to do this?'], data?.type ? data.type : 'default', data?.confirmButtonLabel ? data.confirmButtonLabel : 'Confirm', data?.cancelButtonLabel ? data.cancelButtonLabel : 'Cancel', data?.title ? data.title : 'Confirmation', data?.requireConfirmation ? data.requireConfirmation : false, data?.confirmationText);
26
+ }
27
+ // eslint-disable-next-line jsdoc/require-jsdoc
28
+ validateInput(data) {
29
+ if (!data) {
30
+ return;
31
+ }
32
+ if (data.requireConfirmation && !data.confirmationText) {
33
+ throw new Error(`Missing required Input data "confirmationText".
34
+ You can only omit this value when "requireConfirmation" is false.`);
35
+ }
36
+ if (!data.requireConfirmation && data.confirmationText) {
37
+ throw new Error('The "confirmationText" will never be shown because "requireConfirmation" is not set to true');
38
+ }
39
+ if (data.type === 'info-only' && data.cancelButtonLabel) {
40
+ throw new Error('The "cancelButtonLabel" will never be shown because "type" is set to "info-only"');
41
+ }
42
+ }
43
+ }
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1kaWFsb2ctZGF0YS5idWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9jb25maXJtLWRpYWxvZy9jb25maXJtLWRpYWxvZy1kYXRhLmJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBRy9EOztHQUVHO0FBQ0gsTUFBTSxPQUFPLHlCQUF5QjtJQWdCbEMsWUFDSSxJQUFjLEVBQ2QsSUFBd0IsRUFDeEIsa0JBQTBCLEVBQzFCLGlCQUF5QixFQUN6QixLQUFhLEVBQ2IsbUJBQTRCLEVBQzVCLGdCQUF5QjtRQUV6QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNqQixJQUFJLENBQUMsa0JBQWtCLEdBQUcsa0JBQWtCLENBQUM7UUFDN0MsSUFBSSxDQUFDLGlCQUFpQixHQUFHLGlCQUFpQixDQUFDO1FBQzNDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxtQkFBbUIsQ0FBQztRQUMvQyxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsZ0JBQWdCLENBQUM7SUFDN0MsQ0FBQztDQUNKO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sd0JBQXlCLFNBQVEsV0FBeUQ7SUFFbkcsWUFBWSxJQUF3QjtRQUNoQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEIsQ0FBQztJQUVELCtDQUErQztJQUM1QixnQkFBZ0IsQ0FBQyxJQUF3QjtRQUN4RCxPQUFPLElBQUkseUJBQXlCLENBQ2hDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsZ0NBQWdDLENBQUMsRUFDM0QsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsU0FBUyxFQUNsQyxJQUFJLEVBQUUsa0JBQWtCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUMsU0FBUyxFQUM5RCxJQUFJLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUMzRCxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxjQUFjLEVBQ3pDLElBQUksRUFBRSxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQzVELElBQUksRUFBRSxnQkFBZ0IsQ0FDekIsQ0FBQztJQUNOLENBQUM7SUFFRCwrQ0FBK0M7SUFDNUIsYUFBYSxDQUFDLElBQXdCO1FBQ3JELElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDUCxPQUFPO1NBQ1Y7UUFDRCxJQUFJLElBQUksQ0FBQyxtQkFBbUIsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRTtZQUNwRCxNQUFNLElBQUksS0FBSyxDQUFDOzhFQUNrRCxDQUFDLENBQUM7U0FDdkU7UUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLG1CQUFtQixJQUFJLElBQUksQ0FBQyxnQkFBZ0IsRUFBRTtZQUNwRCxNQUFNLElBQUksS0FBSyxDQUFDLDZGQUE2RixDQUFDLENBQUM7U0FDbEg7UUFDRCxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssV0FBVyxJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUNyRCxNQUFNLElBQUksS0FBSyxDQUFDLGtGQUFrRixDQUFDLENBQUM7U0FDdkc7SUFDTCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlQnVpbGRlciB9IGZyb20gJy4uLy4uL2NsYXNzZXMvYmFzZS1idWlsZGVyLmNsYXNzJztcbmltcG9ydCB7IENvbmZpcm1EaWFsb2dEYXRhLCBDb25maXJtRGlhbG9nVHlwZXMgfSBmcm9tICcuL2NvbmZpcm0tZGlhbG9nLWRhdGEnO1xuXG4vKipcbiAqIFRoZSBpbnRlcm5hbCBDb25maXJtRGlhbG9nRGF0YS4gUmVxdWlyZXMgYWxsIGRlZmF1bHQgdmFsdWVzIHRoZSB1c2VyIGNhbiBsZWF2ZSBvdXQuXG4gKi9cbmV4cG9ydCBjbGFzcyBDb25maXJtRGlhbG9nRGF0YUludGVybmFsIGltcGxlbWVudHMgQ29uZmlybURpYWxvZ0RhdGEge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgdGV4dDogc3RyaW5nW107XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICB0eXBlOiBDb25maXJtRGlhbG9nVHlwZXM7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBjb25maXJtQnV0dG9uTGFiZWw6IHN0cmluZztcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUganNkb2MvcmVxdWlyZS1qc2RvY1xuICAgIGNhbmNlbEJ1dHRvbkxhYmVsOiBzdHJpbmc7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICB0aXRsZTogc3RyaW5nO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgcmVxdWlyZUNvbmZpcm1hdGlvbjogYm9vbGVhbjtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUganNkb2MvcmVxdWlyZS1qc2RvY1xuICAgIGNvbmZpcm1hdGlvblRleHQ/OiBzdHJpbmc7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgdGV4dDogc3RyaW5nW10sXG4gICAgICAgIHR5cGU6IENvbmZpcm1EaWFsb2dUeXBlcyxcbiAgICAgICAgY29uZmlybUJ1dHRvbkxhYmVsOiBzdHJpbmcsXG4gICAgICAgIGNhbmNlbEJ1dHRvbkxhYmVsOiBzdHJpbmcsXG4gICAgICAgIHRpdGxlOiBzdHJpbmcsXG4gICAgICAgIHJlcXVpcmVDb25maXJtYXRpb246IGJvb2xlYW4sXG4gICAgICAgIGNvbmZpcm1hdGlvblRleHQ/OiBzdHJpbmdcbiAgICApIHtcbiAgICAgICAgdGhpcy50ZXh0ID0gdGV4dDtcbiAgICAgICAgdGhpcy50eXBlID0gdHlwZTtcbiAgICAgICAgdGhpcy5jb25maXJtQnV0dG9uTGFiZWwgPSBjb25maXJtQnV0dG9uTGFiZWw7XG4gICAgICAgIHRoaXMuY2FuY2VsQnV0dG9uTGFiZWwgPSBjYW5jZWxCdXR0b25MYWJlbDtcbiAgICAgICAgdGhpcy50aXRsZSA9IHRpdGxlO1xuICAgICAgICB0aGlzLnJlcXVpcmVDb25maXJtYXRpb24gPSByZXF1aXJlQ29uZmlybWF0aW9uO1xuICAgICAgICB0aGlzLmNvbmZpcm1hdGlvblRleHQgPSBjb25maXJtYXRpb25UZXh0O1xuICAgIH1cbn1cblxuLyoqXG4gKiBUaGUgQnVpbGRlciBmb3IgdGhlIENvbmZpcm1EaWFsb2dEYXRhLiBTZXRzIGRlZmF1bHQgdmFsdWVzLlxuICovXG5leHBvcnQgY2xhc3MgQ29uZmlybURpYWxvZ0RhdGFCdWlsZGVyIGV4dGVuZHMgQmFzZUJ1aWxkZXI8Q29uZmlybURpYWxvZ0RhdGFJbnRlcm5hbCwgQ29uZmlybURpYWxvZ0RhdGE+IHtcblxuICAgIGNvbnN0cnVjdG9yKGRhdGE/OiBDb25maXJtRGlhbG9nRGF0YSkge1xuICAgICAgICBzdXBlcihkYXRhKTtcbiAgICB9XG5cbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUganNkb2MvcmVxdWlyZS1qc2RvY1xuICAgIHByb3RlY3RlZCBvdmVycmlkZSBnZW5lcmF0ZUJhc2VEYXRhKGRhdGE/OiBDb25maXJtRGlhbG9nRGF0YSk6IENvbmZpcm1EaWFsb2dEYXRhSW50ZXJuYWwge1xuICAgICAgICByZXR1cm4gbmV3IENvbmZpcm1EaWFsb2dEYXRhSW50ZXJuYWwoXG4gICAgICAgICAgICBkYXRhPy50ZXh0ID8gZGF0YS50ZXh0IDogWydEbyB5b3UgcmVhbGx5IHdhbnQgdG8gZG8gdGhpcz8nXSxcbiAgICAgICAgICAgIGRhdGE/LnR5cGUgPyBkYXRhLnR5cGUgOiAnZGVmYXVsdCcsXG4gICAgICAgICAgICBkYXRhPy5jb25maXJtQnV0dG9uTGFiZWwgPyBkYXRhLmNvbmZpcm1CdXR0b25MYWJlbCA6ICdDb25maXJtJyxcbiAgICAgICAgICAgIGRhdGE/LmNhbmNlbEJ1dHRvbkxhYmVsID8gZGF0YS5jYW5jZWxCdXR0b25MYWJlbCA6ICdDYW5jZWwnLFxuICAgICAgICAgICAgZGF0YT8udGl0bGUgPyBkYXRhLnRpdGxlIDogJ0NvbmZpcm1hdGlvbicsXG4gICAgICAgICAgICBkYXRhPy5yZXF1aXJlQ29uZmlybWF0aW9uID8gZGF0YS5yZXF1aXJlQ29uZmlybWF0aW9uIDogZmFsc2UsXG4gICAgICAgICAgICBkYXRhPy5jb25maXJtYXRpb25UZXh0XG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgdmFsaWRhdGVJbnB1dChkYXRhPzogQ29uZmlybURpYWxvZ0RhdGEpOiB2b2lkIHtcbiAgICAgICAgaWYgKCFkYXRhKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGRhdGEucmVxdWlyZUNvbmZpcm1hdGlvbiAmJiAhZGF0YS5jb25maXJtYXRpb25UZXh0KSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYE1pc3NpbmcgcmVxdWlyZWQgSW5wdXQgZGF0YSBcImNvbmZpcm1hdGlvblRleHRcIi5cbiAgICAgICAgICAgIFlvdSBjYW4gb25seSBvbWl0IHRoaXMgdmFsdWUgd2hlbiBcInJlcXVpcmVDb25maXJtYXRpb25cIiBpcyBmYWxzZS5gKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIWRhdGEucmVxdWlyZUNvbmZpcm1hdGlvbiAmJiBkYXRhLmNvbmZpcm1hdGlvblRleHQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignVGhlIFwiY29uZmlybWF0aW9uVGV4dFwiIHdpbGwgbmV2ZXIgYmUgc2hvd24gYmVjYXVzZSBcInJlcXVpcmVDb25maXJtYXRpb25cIiBpcyBub3Qgc2V0IHRvIHRydWUnKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoZGF0YS50eXBlID09PSAnaW5mby1vbmx5JyAmJiBkYXRhLmNhbmNlbEJ1dHRvbkxhYmVsKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1RoZSBcImNhbmNlbEJ1dHRvbkxhYmVsXCIgd2lsbCBuZXZlciBiZSBzaG93biBiZWNhdXNlIFwidHlwZVwiIGlzIHNldCB0byBcImluZm8tb25seVwiJyk7XG4gICAgICAgIH1cbiAgICB9XG59Il19