ngx-material-entity 0.1.1 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CONTRIBUTING.md +7 -1
- package/README.md +3 -2
- package/classes/entity-model.class.d.ts +1 -1
- package/classes/entity-service.class.d.ts +27 -17
- package/classes/entity-utilities.class.d.ts +62 -45
- package/components/confirm-dialog/confirm-dialog-data.builder.d.ts +24 -0
- package/components/confirm-dialog/confirm-dialog-data.d.ts +14 -8
- package/components/confirm-dialog/confirm-dialog.component.d.ts +4 -5
- package/components/get-validation-error-message.function.d.ts +3 -2
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog-data.builder.d.ts +17 -0
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog-data.d.ts +17 -0
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.d.ts +5 -18
- package/components/input/array-table/array-table.component.d.ts +3 -3
- package/components/input/input.component.d.ts +18 -21
- package/components/input/internal-input/internal-input.component.d.ts +14 -17
- package/components/table/create-dialog/create-dialog-data.builder.d.ts +20 -0
- package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +16 -0
- package/components/table/create-dialog/create-entity-dialog-data.d.ts +2 -2
- package/components/table/create-dialog/create-entity-dialog.component.d.ts +4 -2
- package/components/table/edit-dialog/edit-dialog-data.builder.d.ts +27 -0
- package/components/table/edit-dialog/edit-entity-dialog-data.d.ts +5 -5
- package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +17 -0
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +4 -2
- package/components/table/table-data.builder.d.ts +40 -0
- package/components/table/table-data.d.ts +26 -22
- package/components/table/table.component.d.ts +6 -5
- package/decorators/array/array-decorator-internal.data.d.ts +34 -0
- package/decorators/{array.decorator.d.ts → array/array-decorator.data.d.ts} +32 -37
- package/decorators/array/array.decorator.d.ts +10 -0
- package/decorators/base/base-property.decorator.d.ts +7 -6
- package/decorators/base/decorator-types.enum.d.ts +7 -7
- package/decorators/base/property-decorator-internal.data.d.ts +11 -0
- package/decorators/base/{property-decorator-config.interface.d.ts → property-decorator.data.d.ts} +11 -12
- package/decorators/boolean/boolean-decorator-internal.data.d.ts +16 -0
- package/decorators/boolean/boolean-decorator.data.d.ts +28 -0
- package/decorators/boolean/boolean.decorator.d.ts +8 -0
- package/decorators/number/number-decorator-internal.data.d.ts +16 -0
- package/decorators/number/number-decorator.data.d.ts +32 -0
- package/decorators/number/number.decorator.d.ts +8 -0
- package/decorators/object/object-decorator-internal.data.d.ts +8 -0
- package/decorators/object/object-decorator.data.d.ts +22 -0
- package/decorators/object/object.decorator.d.ts +9 -0
- package/decorators/string/string-decorator-internal.data.d.ts +31 -0
- package/decorators/string/string-decorator.data.d.ts +67 -0
- package/decorators/string/string.decorator.d.ts +8 -0
- package/esm2020/classes/entity-model.class.mjs +2 -2
- package/esm2020/classes/entity-service.class.mjs +20 -14
- package/esm2020/classes/entity-utilities.class.mjs +108 -75
- package/esm2020/components/confirm-dialog/confirm-dialog-data.builder.mjs +77 -0
- package/esm2020/components/confirm-dialog/confirm-dialog-data.mjs +1 -1
- package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +7 -22
- package/esm2020/components/get-validation-error-message.function.mjs +4 -3
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog-data.builder.mjs +33 -0
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog-data.mjs +2 -0
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.mjs +7 -5
- package/esm2020/components/input/array-table/array-table.component.mjs +14 -11
- package/esm2020/components/input/input.component.mjs +3 -6
- package/esm2020/components/input/internal-input/internal-input.component.mjs +1 -4
- package/esm2020/components/table/create-dialog/create-dialog-data.builder.mjs +54 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +18 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +14 -21
- package/esm2020/components/table/edit-dialog/edit-dialog-data.builder.mjs +81 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +19 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +21 -36
- package/esm2020/components/table/table-data.builder.mjs +89 -0
- package/esm2020/components/table/table-data.mjs +1 -1
- package/esm2020/components/table/table.component.mjs +41 -80
- package/esm2020/decorators/array/array-decorator-internal.data.mjs +40 -0
- package/esm2020/decorators/array/array-decorator.data.mjs +7 -0
- package/esm2020/decorators/array/array.decorator.mjs +24 -0
- package/esm2020/decorators/base/base-property.decorator.mjs +6 -5
- package/esm2020/decorators/base/decorator-types.enum.mjs +1 -1
- package/esm2020/decorators/base/property-decorator-internal.data.mjs +15 -0
- package/esm2020/decorators/base/property-decorator.data.mjs +6 -0
- package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +22 -0
- package/esm2020/decorators/boolean/boolean-decorator.data.mjs +7 -0
- package/esm2020/decorators/boolean/boolean.decorator.mjs +21 -0
- package/esm2020/decorators/number/number-decorator-internal.data.mjs +17 -0
- package/esm2020/decorators/number/number-decorator.data.mjs +7 -0
- package/esm2020/decorators/number/number.decorator.mjs +18 -0
- package/esm2020/decorators/object/object-decorator-internal.data.mjs +9 -0
- package/esm2020/decorators/object/object-decorator.data.mjs +7 -0
- package/esm2020/decorators/object/object.decorator.mjs +13 -0
- package/esm2020/decorators/string/string-decorator-internal.data.mjs +36 -0
- package/esm2020/decorators/string/string-decorator.data.mjs +7 -0
- package/esm2020/decorators/string/string.decorator.mjs +24 -0
- package/esm2020/public-api.mjs +15 -10
- package/fesm2015/ngx-material-entity.mjs +1019 -683
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +1005 -684
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +16 -7
- package/decorators/boolean.decorator.d.ts +0 -42
- package/decorators/number.decorator.d.ts +0 -40
- package/decorators/object.decorator.d.ts +0 -27
- package/decorators/string.decorator.d.ts +0 -76
- package/esm2020/decorators/array.decorator.mjs +0 -70
- package/esm2020/decorators/base/property-decorator-config.interface.mjs +0 -31
- package/esm2020/decorators/boolean.decorator.mjs +0 -44
- package/esm2020/decorators/number.decorator.mjs +0 -36
- package/esm2020/decorators/object.decorator.mjs +0 -23
- package/esm2020/decorators/string.decorator.mjs +0 -61
|
@@ -2,12 +2,14 @@ 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
|
-
*
|
|
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 = [];
|
|
@@ -20,8 +22,10 @@ export class EntityUtilities {
|
|
|
20
22
|
return res;
|
|
21
23
|
}
|
|
22
24
|
/**
|
|
23
|
-
* Gets the properties to omit when creating new entities
|
|
24
|
-
*
|
|
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 = [];
|
|
@@ -34,11 +38,13 @@ export class EntityUtilities {
|
|
|
34
38
|
return res;
|
|
35
39
|
}
|
|
36
40
|
/**
|
|
37
|
-
* Gets the metadata included in an property
|
|
38
|
-
*
|
|
39
|
-
* @param
|
|
40
|
-
* @param
|
|
41
|
-
* @
|
|
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
|
-
*
|
|
62
|
-
* @param
|
|
63
|
-
* @
|
|
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
|
-
*
|
|
82
|
-
* @param target
|
|
83
|
-
*
|
|
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
|
-
|
|
91
|
-
|
|
92
|
-
|
|
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
|
-
*
|
|
100
|
-
* @param
|
|
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 creatiung or editing validity.
|
|
101
127
|
* @returns Whether or not the entity is valid.
|
|
102
128
|
*/
|
|
103
129
|
static isEntityValid(entity, omit) {
|
|
@@ -109,10 +135,13 @@ export class EntityUtilities {
|
|
|
109
135
|
return true;
|
|
110
136
|
}
|
|
111
137
|
/**
|
|
112
|
-
* Checks if a single property value is valid
|
|
113
|
-
*
|
|
114
|
-
* @param
|
|
115
|
-
* @
|
|
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);
|
|
@@ -127,7 +156,7 @@ export class EntityUtilities {
|
|
|
127
156
|
if (metadata.omitForCreate && omit === 'create') {
|
|
128
157
|
return true;
|
|
129
158
|
}
|
|
130
|
-
if (metadata.omitForUpdate && omit === '
|
|
159
|
+
if (metadata.omitForUpdate && omit === 'update') {
|
|
131
160
|
return true;
|
|
132
161
|
}
|
|
133
162
|
if (metadata.required && !entity[key]) {
|
|
@@ -158,7 +187,7 @@ export class EntityUtilities {
|
|
|
158
187
|
return false;
|
|
159
188
|
}
|
|
160
189
|
if (metadataAutocompleteString.regex
|
|
161
|
-
&& entity[key].match(metadataAutocompleteString.regex)) {
|
|
190
|
+
&& !entity[key].match(metadataAutocompleteString.regex)) {
|
|
162
191
|
return false;
|
|
163
192
|
}
|
|
164
193
|
break;
|
|
@@ -176,7 +205,7 @@ export class EntityUtilities {
|
|
|
176
205
|
if (metadataDefaultNumber.max && entity[key] > metadataDefaultNumber.max) {
|
|
177
206
|
return false;
|
|
178
207
|
}
|
|
179
|
-
if (metadataDefaultNumber.min && entity[key]
|
|
208
|
+
if (metadataDefaultNumber.min && entity[key] < metadataDefaultNumber.min) {
|
|
180
209
|
return false;
|
|
181
210
|
}
|
|
182
211
|
break;
|
|
@@ -200,10 +229,11 @@ export class EntityUtilities {
|
|
|
200
229
|
return true;
|
|
201
230
|
}
|
|
202
231
|
/**
|
|
203
|
-
* Checks if an entity is "dirty" (if its values have changed)
|
|
204
|
-
*
|
|
205
|
-
* @param
|
|
206
|
-
* @
|
|
232
|
+
* Checks if an entity is "dirty" (if its values have changed).
|
|
233
|
+
*
|
|
234
|
+
* @param entity - The entity after all changes.
|
|
235
|
+
* @param entityPriorChanges - The entity before the changes.
|
|
236
|
+
* @returns Whether or not the entity is dirty.
|
|
207
237
|
*/
|
|
208
238
|
static dirty(entity, entityPriorChanges) {
|
|
209
239
|
if (!entityPriorChanges) {
|
|
@@ -220,10 +250,11 @@ export class EntityUtilities {
|
|
|
220
250
|
}
|
|
221
251
|
}
|
|
222
252
|
/**
|
|
223
|
-
* Compares two Entities and returns their difference in an object
|
|
224
|
-
*
|
|
225
|
-
* @param
|
|
226
|
-
* @
|
|
253
|
+
* Compares two Entities and returns their difference in an object.
|
|
254
|
+
*
|
|
255
|
+
* @param entity - The first entity to compare.
|
|
256
|
+
* @param entityPriorChanges - The second entity to compare.
|
|
257
|
+
* @returns The difference between the two Entities in form of a Partial.
|
|
227
258
|
*/
|
|
228
259
|
static difference(entity, entityPriorChanges) {
|
|
229
260
|
const res = {};
|
|
@@ -234,53 +265,55 @@ export class EntityUtilities {
|
|
|
234
265
|
}
|
|
235
266
|
return res;
|
|
236
267
|
}
|
|
268
|
+
//TODO X Y
|
|
237
269
|
/**
|
|
238
|
-
*
|
|
239
|
-
*
|
|
240
|
-
* @param
|
|
241
|
-
* @param
|
|
270
|
+
* Compare function for sorting entity keys by their order value.
|
|
271
|
+
*
|
|
272
|
+
* @param a - First key of entity.
|
|
273
|
+
* @param b - Second key of entity.
|
|
274
|
+
* @param entity - Current entity (used to get metadata of entity keys).
|
|
275
|
+
* @returns 0 if both values have the same order, a negative value if X, a positive value if Y.
|
|
242
276
|
*/
|
|
243
277
|
static compareOrder(a, b, entity) {
|
|
244
278
|
const metadataA = EntityUtilities.getPropertyMetadata(entity, a, EntityUtilities.getPropertyType(entity, a));
|
|
245
279
|
const metadataB = EntityUtilities.getPropertyMetadata(entity, b, EntityUtilities.getPropertyType(entity, b));
|
|
246
280
|
if (metadataA.order === -1) {
|
|
281
|
+
if (metadataB.order === -1) {
|
|
282
|
+
return 0;
|
|
283
|
+
}
|
|
247
284
|
return 1;
|
|
248
285
|
}
|
|
249
286
|
else if (metadataB.order === -1) {
|
|
250
|
-
return
|
|
287
|
+
return -1;
|
|
251
288
|
}
|
|
252
|
-
return (metadataA.order - metadataB.order);
|
|
289
|
+
return ((metadataA.order) - (metadataB.order));
|
|
253
290
|
}
|
|
254
291
|
/**
|
|
255
|
-
*
|
|
256
|
-
*
|
|
257
|
-
* @param
|
|
258
|
-
* @param
|
|
259
|
-
* @
|
|
292
|
+
* Gets the bootstrap column values for "lg", "md", "sm".
|
|
293
|
+
*
|
|
294
|
+
* @param entity - Entity to get the bootstrap column values of the key.
|
|
295
|
+
* @param key - Key of the property to get bootstrap column values from.
|
|
296
|
+
* @param type - Defines for which screensize the column values should be returned.
|
|
297
|
+
* @returns Bootstrap column value.
|
|
260
298
|
*/
|
|
261
299
|
static getWidth(entity, key, type) {
|
|
262
300
|
const propertyType = EntityUtilities.getPropertyType(entity, key);
|
|
263
301
|
const metadata = EntityUtilities.getPropertyMetadata(entity, key, propertyType);
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
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');
|
|
302
|
+
metadata.defaultWidths = metadata.defaultWidths;
|
|
303
|
+
switch (type) {
|
|
304
|
+
case 'lg':
|
|
305
|
+
return metadata.defaultWidths[0];
|
|
306
|
+
case 'md':
|
|
307
|
+
return metadata.defaultWidths[1];
|
|
308
|
+
case 'sm':
|
|
309
|
+
return metadata.defaultWidths[2];
|
|
278
310
|
}
|
|
279
311
|
}
|
|
280
312
|
/**
|
|
281
|
-
* Resets all changes on an entity
|
|
282
|
-
*
|
|
283
|
-
* @param
|
|
313
|
+
* Resets all changes on an entity.
|
|
314
|
+
*
|
|
315
|
+
* @param entity - The entity to reset.
|
|
316
|
+
* @param entityPriorChanges - The entity before any changes.
|
|
284
317
|
*/
|
|
285
318
|
static resetChangesOnEntity(entity, entityPriorChanges) {
|
|
286
319
|
for (const key in entityPriorChanges) {
|
|
@@ -293,4 +326,4 @@ _a = EntityUtilities;
|
|
|
293
326
|
EntityUtilities.construct = _a.new;
|
|
294
327
|
// eslint-disable-next-line @typescript-eslint/member-ordering
|
|
295
328
|
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":";AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AACjC,OAAO,EAAiB,cAAc,EAAE,MAAM,yCAAyC,CAAC;AAOxF;;GAEG;AACH,MAAM,OAAgB,eAAe;IACjC;;;OAGG;IACH,MAAM,CAAC,gBAAgB,CAA4B,MAAkB;QACjE,MAAM,GAAG,GAAyB,EAAE,CAAC;QACrC,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACvC,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,CAA4B,CAAC;YACzF,IAAI,QAAQ,CAAC,aAAa,EAAE;gBACxB,GAAG,CAAC,IAAI,CAAC,GAAuB,CAAC,CAAC;aACrC;SACJ;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,gBAAgB,CAA4B,MAAkB;QACjE,MAAM,GAAG,GAAyB,EAAE,CAAC;QACrC,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACvC,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,CAA4B,CAAC;YACzF,IAAI,QAAQ,CAAC,aAAa,EAAE;gBACxB,GAAG,CAAC,IAAI,CAAC,GAAuB,CAAC,CAAC;aACrC;SACJ;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,mBAAmB,CACtB,MAAkB,EAClB,WAA6B;IAC7B,6DAA6D;IAC7D,IAAO;QAEP,IAAI;YACA,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,WAAqB,CAAqB,CAAC;YACpG,IAAI,CAAC,QAAQ,EAAE;gBACX,MAAM,IAAI,KAAK,CACX,wCAAwC,MAAM,CAAC,WAAW,CAAC;oCAC3C,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAC3C,CAAC;aACL;YACD,OAAO,QAAQ,CAAE;SACpB;QACD,OAAO,KAAK,EAAE;YACV,MAAM,IAAI,KAAK,CACX,wCAAwC,MAAM,CAAC,WAAW,CAAC;gCAC3C,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAC3C,CAAC;SACL;IACL,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,eAAe,CAClB,MAAkB,EAAE,WAA6B;QAEjD,IAAI;YACA,MAAM,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,WAAqB,CAAmB,CAAC;YAClG,IAAI,CAAC,YAAY,EAAE;gBACf,MAAM,IAAI,KAAK,CACX,6CAA6C,MAAM,CAAC,WAAW,CAAC;oCAChD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAC3C,CAAC;aACL;YACD,OAAO,YAAY,CAAC;SACvB;QACD,OAAO,KAAK,EAAE;YACV,MAAM,IAAI,KAAK,CACX,6CAA6C,MAAM,CAAC,WAAW,CAAC;gCAChD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAC3C,CAAC;SACL;IACL,CAAC;IAED;;;;;;;;;OASG;IACH,MAAM,CAAC,GAAG,CAA4B,MAAkB,EAAE,MAAmB;QACzE,IAAI,MAAM,EAAE;YACR,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE;gBACtB,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC;aACtD;SACJ;IACL,CAAC;IAMD;;;;;;OAMG;IACH,MAAM,CAAC,aAAa,CAA4B,MAAkB,EAAE,IAAuB;QACvF,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE;YACtB,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE;gBAC1C,OAAO,KAAK,CAAC;aAChB;SACJ;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IACD;;;;;OAKG;IACK,MAAM,CAAC,eAAe,CAA4B,MAAkB,EAAE,GAAqB,EAAE,IAAuB;QACxH,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAA4B,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACtF,MAAM,qBAAqB,GAAG,QAAwC,CAAC;QACvE,MAAM,qBAAqB,GAAG,QAAwC,CAAC;QACvE,MAAM,0BAA0B,GAAG,QAA6C,CAAC;QACjF,MAAM,qBAAqB,GAAG,QAAwC,CAAC;QACvE,MAAM,cAAc,GAAG,MAAM,CAAC,GAAG,CAA0B,CAAC;QAC5D,MAAM,mBAAmB,GAAG,QAA8C,CAAC;QAC3E,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAkB,CAAC;QAEhD,IAAI,QAAQ,CAAC,aAAa,IAAI,IAAI,KAAK,QAAQ,EAAE;YAC7C,OAAO,IAAI,CAAC;SACf;QACD,IAAI,QAAQ,CAAC,aAAa,IAAI,IAAI,KAAK,MAAM,EAAE;YAC3C,OAAO,IAAI,CAAC;SACf;QACD,IAAI,QAAQ,CAAC,QAAQ,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE;YACnC,OAAO,KAAK,CAAC;SAChB;QACD,QAAQ,IAAI,EAAE;YACV,KAAK,cAAc,CAAC,MAAM;gBACtB,IACI,qBAAqB,CAAC,SAAS;uBAC3B,MAAM,CAAC,GAAG,CAAuB,CAAC,MAAM,GAAG,qBAAqB,CAAC,SAAS,EAChF;oBACE,OAAO,KAAK,CAAC;iBAChB;gBACD,IACI,qBAAqB,CAAC,SAAS;uBAC3B,MAAM,CAAC,GAAG,CAAuB,CAAC,MAAM,GAAG,qBAAqB,CAAC,SAAS,EAChF;oBACE,OAAO,KAAK,CAAC;iBAChB;gBACD,IACI,qBAAqB,CAAC,KAAK;uBACxB,CAAE,MAAM,CAAC,GAAG,CAAuB,CAAC,KAAK,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAC3E;oBACE,OAAO,KAAK,CAAC;iBAChB;gBACD,MAAM;YACV,KAAK,cAAc,CAAC,mBAAmB;gBACnC,IACI,0BAA0B,CAAC,SAAS;uBAChC,MAAM,CAAC,GAAG,CAAuB,CAAC,MAAM,GAAG,0BAA0B,CAAC,SAAS,EACrF;oBACE,OAAO,KAAK,CAAC;iBAChB;gBACD,IACI,0BAA0B,CAAC,SAAS;uBAChC,MAAM,CAAC,GAAG,CAAuB,CAAC,MAAM,GAAG,0BAA0B,CAAC,SAAS,EACrF;oBACE,OAAO,KAAK,CAAC;iBAChB;gBACD,IACI,0BAA0B,CAAC,KAAK;uBAC5B,MAAM,CAAC,GAAG,CAAuB,CAAC,KAAK,CAAC,0BAA0B,CAAC,KAAK,CAAC,EAC/E;oBACE,OAAO,KAAK,CAAC;iBAChB;gBACD,MAAM;YACV,KAAK,cAAc,CAAC,cAAc;gBAC9B,IACI,qBAAqB,CAAC,SAAS;uBAC3B,MAAM,CAAC,GAAG,CAAuB,CAAC,MAAM,GAAG,qBAAqB,CAAC,SAAS,EAChF;oBACE,OAAO,KAAK,CAAC;iBAChB;gBACD,IACI,qBAAqB,CAAC,SAAS;uBAC3B,MAAM,CAAC,GAAG,CAAuB,CAAC,MAAM,GAAG,qBAAqB,CAAC,SAAS,EAChF;oBACE,OAAO,KAAK,CAAC;iBAChB;gBACD,MAAM;YACV,KAAK,cAAc,CAAC,MAAM;gBACtB,IAAI,qBAAqB,CAAC,GAAG,IAAK,MAAM,CAAC,GAAG,CAAuB,GAAG,qBAAqB,CAAC,GAAG,EAAE;oBAC7F,OAAO,KAAK,CAAC;iBAChB;gBACD,IAAI,qBAAqB,CAAC,GAAG,IAAK,MAAM,CAAC,GAAG,CAAuB,GAAG,qBAAqB,CAAC,GAAG,EAAE;oBAC7F,OAAO,KAAK,CAAC;iBAChB;gBACD,MAAM;YACV,KAAK,cAAc,CAAC,MAAM;gBACtB,KAAK,MAAM,YAAY,IAAI,cAAc,EAAE;oBACvC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,YAAY,EAAE,IAAI,CAAC,EAAE;wBAC3D,OAAO,KAAK,CAAC;qBAChB;iBACJ;gBACD,MAAM;YACV,KAAK,cAAc,CAAC,kBAAkB,CAAC;YACvC,KAAK,cAAc,CAAC,+BAA+B,CAAC;YACpD,KAAK,cAAc,CAAC,KAAK;gBACrB,IAAI,mBAAmB,CAAC,QAAQ,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE;oBACpD,OAAO,KAAK,CAAC;iBAChB;gBACD,MAAM;YACV;gBACI,MAAM,IAAI,KAAK,CAAC,0DAA0D,IAAI,eAAe,CAAC,CAAC;SACtG;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,MAAc,EAAE,kBAA0B;QACnD,IAAI,CAAC,kBAAkB,EAAE;YACrB,OAAO,KAAK,CAAC;SAChB;aACI;YACD,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC;YACzD,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;gBAC/B,OAAO,KAAK,CAAC;aAChB;iBACI;gBACD,OAAO,IAAI,CAAC;aACf;SACJ;IACL,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,UAAU,CACb,MAAkB,EAClB,kBAA8B;QAE9B,MAAM,GAAG,GAAwB,EAAE,CAAC;QACpC,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE;YACtB,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,kBAAkB,CAAC,GAAG,CAAC,CAAC,EAAE;gBAChD,GAAG,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;aAC1B;SACJ;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,YAAY,CAA4B,CAAmB,EAAE,CAAmB,EAAE,MAAkB;QACvG,MAAM,SAAS,GAAG,eAAe,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC,EAAE,eAAe,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7G,MAAM,SAAS,GAAG,eAAe,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC,EAAE,eAAe,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QAE7G,IAAI,SAAS,CAAC,KAAK,KAAK,CAAC,CAAC,EAAE;YACxB,OAAO,CAAC,CAAC;SACZ;aACI,IAAI,SAAS,CAAC,KAAK,KAAK,CAAC,CAAC,EAAE;YAC7B,OAAO,CAAC,CAAC;SACZ;QAED,OAAO,CAAE,SAAS,CAAC,KAAgB,GAAI,SAAS,CAAC,KAAgB,CAAC,CAAC;IACvE,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,QAAQ,CAA4B,MAAkB,EAAE,GAAqB,EAAE,IAAwB;QAC1G,MAAM,YAAY,GAAG,eAAe,CAAC,eAAe,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAClE,MAAM,QAAQ,GAAG,eAAe,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,EAAE,YAAY,CAAC,CAAC;QAChF,IAAI,QAAQ,CAAC,aAAa,EAAE;YACxB,QAAQ,IAAI,EAAE;gBACV,KAAK,IAAI;oBACL,OAAO,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBACrC,KAAK,IAAI;oBACL,OAAO,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBACrC,KAAK,IAAI;oBACL,OAAO,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBACrC;oBACI,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;aACjE;SACJ;aACI;YACD,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;SAC7D;IACL,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,oBAAoB,CAA4B,MAAkB,EAAE,kBAA8B;QACrG,KAAK,MAAM,GAAG,IAAI,kBAAkB,EAAE;YAClC,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAC,CAAC;SAClE;IACL,CAAC;;;AAjOD,8DAA8D;AACvD,yBAAS,GAAG,EAAI,CAAC,GAAG,CAAC;AAC5B,8DAA8D;AACvD,qBAAK,GAAG,EAAI,CAAC,GAAG,CAAC","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}"]}
|
|
329
|
+
//# 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 { cols } from '../decorators/base/property-decorator.data';\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 { AutocompleteStringDecoratorConfigInternal, 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 Reflect.ownKeys(entity)) {\n            const metadata = Reflect.getMetadata('metadata', entity, key) as PropertyDecoratorConfigInternal;\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     *\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 Reflect.ownKeys(entity)) {\n            const metadata = Reflect.getMetadata('metadata', entity, key) as PropertyDecoratorConfigInternal;\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     *\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\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     *\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' | '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 metadataAutocompleteString = metadata as AutocompleteStringDecoratorConfigInternal;\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.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     *\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, EntityUtilities.getPropertyType(entity, a));\n        const metadataB = EntityUtilities.getPropertyMetadata(entity, b, EntityUtilities.getPropertyType(entity, b));\n\n        if (metadataA.order === -1) {\n            if (metadataB.order === -1) {\n                return 0;\n            }\n            return 1;\n        }\n        else if (metadataB.order === -1) {\n            return -1;\n        }\n\n        return ((metadataA.order ) - (metadataB.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 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        metadata.defaultWidths = metadata.defaultWidths as [cols, cols, cols];\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}"]}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
export class ConfirmDialogDataInternal {
|
|
2
|
+
constructor(text, type, confirmButtonLabel, cancelButtonLabel, title, requireConfirmation, confirmationText) {
|
|
3
|
+
this.text = text;
|
|
4
|
+
this.type = type;
|
|
5
|
+
this.confirmButtonLabel = confirmButtonLabel;
|
|
6
|
+
this.cancelButtonLabel = cancelButtonLabel;
|
|
7
|
+
this.title = title;
|
|
8
|
+
this.requireConfirmation = requireConfirmation;
|
|
9
|
+
this.confirmationText = confirmationText;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export class ConfirmDialogDataBuilder {
|
|
13
|
+
constructor(data) {
|
|
14
|
+
this.validateInput(data);
|
|
15
|
+
this.dataInput = data;
|
|
16
|
+
this.confirmDialogData = 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);
|
|
17
|
+
return this;
|
|
18
|
+
}
|
|
19
|
+
validateInput(data) {
|
|
20
|
+
if (!data) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
if (data.requireConfirmation && !data.confirmationText) {
|
|
24
|
+
throw new Error(`Missing required Input data "confirmationText".
|
|
25
|
+
You can only omit this value when "requireConfirmation" is false.`);
|
|
26
|
+
}
|
|
27
|
+
if (!data.requireConfirmation && data.confirmationText) {
|
|
28
|
+
throw new Error('The "confirmationText" will never be shown because "requireConfirmation" is not set to true');
|
|
29
|
+
}
|
|
30
|
+
if (data.type === 'info-only' && data.cancelButtonLabel) {
|
|
31
|
+
throw new Error('The "cancelButtonLabel" will never be shown because "type" is set to "info-only"');
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
withDefaultText(text) {
|
|
35
|
+
if (!this.dataInput?.text) {
|
|
36
|
+
this.confirmDialogData.text = text;
|
|
37
|
+
}
|
|
38
|
+
return this;
|
|
39
|
+
}
|
|
40
|
+
withDefaultType(type) {
|
|
41
|
+
if (!this.dataInput?.type) {
|
|
42
|
+
this.confirmDialogData.type = type;
|
|
43
|
+
}
|
|
44
|
+
return this;
|
|
45
|
+
}
|
|
46
|
+
withDefaultConfirmButtonLabel(label) {
|
|
47
|
+
if (!this.dataInput?.confirmButtonLabel) {
|
|
48
|
+
this.confirmDialogData.confirmButtonLabel = label;
|
|
49
|
+
}
|
|
50
|
+
return this;
|
|
51
|
+
}
|
|
52
|
+
withDefaultCancelButtonLabel(label) {
|
|
53
|
+
if (!this.dataInput?.cancelButtonLabel) {
|
|
54
|
+
this.confirmDialogData.cancelButtonLabel = label;
|
|
55
|
+
}
|
|
56
|
+
return this;
|
|
57
|
+
}
|
|
58
|
+
withDefaultTitle(title) {
|
|
59
|
+
if (!this.dataInput?.title) {
|
|
60
|
+
this.confirmDialogData.title = title;
|
|
61
|
+
}
|
|
62
|
+
return this;
|
|
63
|
+
}
|
|
64
|
+
withDefaultRequireConfirmation(requireConfirmation) {
|
|
65
|
+
if (this.dataInput?.requireConfirmation === undefined) {
|
|
66
|
+
this.confirmDialogData.requireConfirmation = requireConfirmation;
|
|
67
|
+
}
|
|
68
|
+
return this;
|
|
69
|
+
}
|
|
70
|
+
withDefaultConfirmationText(confirmationText) {
|
|
71
|
+
if (!this.dataInput?.confirmationText) {
|
|
72
|
+
this.confirmDialogData.confirmationText = confirmationText;
|
|
73
|
+
}
|
|
74
|
+
return this;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirm-dialog-data.builder.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/confirm-dialog/confirm-dialog-data.builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConfirmDialogData, ConfirmDialogTypes } from './confirm-dialog-data';\n\nexport class ConfirmDialogDataInternal implements ConfirmDialogData {\n    text: string[];\n    type: ConfirmDialogTypes;\n    confirmButtonLabel: string;\n    cancelButtonLabel: string;\n    title: string;\n    requireConfirmation: boolean;\n    confirmationText?: string;\n\n    constructor(\n        text: string[],\n        type: ConfirmDialogTypes,\n        confirmButtonLabel: string,\n        cancelButtonLabel: string,\n        title: string,\n        requireConfirmation: boolean,\n        confirmationText?: string\n    ) {\n        this.text = text;\n        this.type = type;\n        this.confirmButtonLabel = confirmButtonLabel;\n        this.cancelButtonLabel = cancelButtonLabel;\n        this.title = title;\n        this.requireConfirmation = requireConfirmation;\n        this.confirmationText = confirmationText;\n    }\n}\n\nexport class ConfirmDialogDataBuilder {\n    confirmDialogData: ConfirmDialogDataInternal;\n    private readonly dataInput?: ConfirmDialogData;\n\n    constructor(data?: ConfirmDialogData) {\n        this.validateInput(data);\n        this.dataInput = data;\n        this.confirmDialogData = new ConfirmDialogDataInternal(\n            data?.text ? data.text : ['Do you really want to do this?'],\n            data?.type ? data.type : 'default',\n            data?.confirmButtonLabel ? data.confirmButtonLabel : 'Confirm',\n            data?.cancelButtonLabel ? data.cancelButtonLabel : 'Cancel',\n            data?.title ? data.title : 'Confirmation',\n            data?.requireConfirmation ? data.requireConfirmation : false,\n            data?.confirmationText\n        );\n        return this;\n    }\n\n    private validateInput(data?: ConfirmDialogData): void {\n        if (!data) {\n            return;\n        }\n        if (data.requireConfirmation && !data.confirmationText) {\n            throw new Error(`Missing required Input data \"confirmationText\".\n            You can only omit this value when \"requireConfirmation\" is false.`);\n        }\n        if (!data.requireConfirmation && data.confirmationText) {\n            throw new Error('The \"confirmationText\" will never be shown because \"requireConfirmation\" is not set to true');\n        }\n        if (data.type === 'info-only' && data.cancelButtonLabel) {\n            throw new Error('The \"cancelButtonLabel\" will never be shown because \"type\" is set to \"info-only\"');\n        }\n    }\n\n    withDefaultText(text: string[]): ConfirmDialogDataBuilder {\n        if (!this.dataInput?.text) {\n            this.confirmDialogData.text = text;\n        }\n        return this;\n    }\n\n    withDefaultType(type: ConfirmDialogTypes): ConfirmDialogDataBuilder {\n        if (!this.dataInput?.type) {\n            this.confirmDialogData.type = type;\n        }\n        return this;\n    }\n\n    withDefaultConfirmButtonLabel(label: string): ConfirmDialogDataBuilder {\n        if (!this.dataInput?.confirmButtonLabel) {\n            this.confirmDialogData.confirmButtonLabel = label;\n        }\n        return this;\n    }\n\n    withDefaultCancelButtonLabel(label: string): ConfirmDialogDataBuilder {\n        if (!this.dataInput?.cancelButtonLabel) {\n            this.confirmDialogData.cancelButtonLabel = label;\n        }\n        return this;\n    }\n\n    withDefaultTitle(title: string): ConfirmDialogDataBuilder {\n        if (!this.dataInput?.title) {\n            this.confirmDialogData.title = title;\n        }\n        return this;\n    }\n\n    withDefaultRequireConfirmation(requireConfirmation: boolean): ConfirmDialogDataBuilder {\n        if (this.dataInput?.requireConfirmation === undefined) {\n            this.confirmDialogData.requireConfirmation = requireConfirmation;\n        }\n        return this;\n    }\n\n    withDefaultConfirmationText(confirmationText: string): ConfirmDialogDataBuilder {\n        if (!this.dataInput?.confirmationText) {\n            this.confirmDialogData.confirmationText = confirmationText;\n        }\n        return this;\n    }\n}"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1kaWFsb2ctZGF0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvY29uZmlybS1kaWFsb2cvY29uZmlybS1kaWFsb2ctZGF0YS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgQ29uZmlybURpYWxvZ1R5cGVzID0gJ2RlZmF1bHQnIHwgJ2RlbGV0ZScgfCAnaW5mby1vbmx5JztcblxuLyoqXG4gKiBUaGUgRGVmaW5pdGlvbiBvZiB0aGUgQ29uZmlybSBEaWFsb2cgRGF0YS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDb25maXJtRGlhbG9nRGF0YSB7XG4gICAgLyoqXG4gICAgICogQW4gYXJyYXkgb2YgcGFyYWdyYXBocyB0byBkaXNwbGF5IGluc2lkZSB0aGUgZGlhbG9nIGJvZHkuXG4gICAgICovXG4gICAgdGV4dD86IHN0cmluZ1tdLFxuICAgIC8qKlxuICAgICAqIFRoZSB0eXBlIG9mIHRoZSBDb25maXJtIERpYWxvZy4gQ2hhbmdlcyB0aGUgYnV0dG9uIGxheW91dC4gQ2FuIGJlIGVpdGhlcjpcbiAgICAgKlxuICAgICAqICdkZWZhdWx0JzogQSBjb25maXJtLSBhbmQgYSBjYW5jZWwtYnV0dG9uLlxuICAgICAqXG4gICAgICogJ2RlbGV0ZSc6IExpa2UgZGVmYXVsdCBidXQgdGhlIGNvbmZpcm0tYnV0dG9uIGlzIHJlZC5cbiAgICAgKlxuICAgICAqICdpbmZvLW9ubHknOiBPbmx5IGEgY2FuY2VsLWJ1dHRvbi5cbiAgICAgKi9cbiAgICB0eXBlPzogQ29uZmlybURpYWxvZ1R5cGVzLFxuICAgIC8qKlxuICAgICAqIFRoZSBsYWJlbCBvZiB0aGUgYnV0dG9uIHRoYXQgY29uZmlybXMgdGhlIGRpYWxvZy5cbiAgICAgKiBJbiBjYXNlIG9mIHRoZSAnZGVsZXRlJyBEaWFsb2cgdGhpcyBpcyB0aGUgc3RyaW5nIHRoYXQgaXMgc2hvd24gb24gdGhlIGRlbGV0ZS1idXR0b24uXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCAnQ29uZmlybScgb3IgJ0RlbGV0ZScsIGRlcGVuZGluZyBvbiB0aGUgdHlwZVxuICAgICAqL1xuICAgIGNvbmZpcm1CdXR0b25MYWJlbD86IHN0cmluZyxcbiAgICAvKipcbiAgICAgKiBUaGUgbGFiZWwgb2YgdGhlIGJ1dHRvbiB0aGF0IGNsb3NlcyB0aGUgZGlhbG9nIHdpdGhvdXQgZG9pbmcgYW55dGhpbmcuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCAnQ2FuY2VsJ1xuICAgICAqL1xuICAgIGNhbmNlbEJ1dHRvbkxhYmVsPzogc3RyaW5nLFxuICAgIC8qKlxuICAgICAqIFRoZSB0aXRsZSBvZiB0aGUgZGlhbG9nLlxuICAgICAqL1xuICAgIHRpdGxlPzogc3RyaW5nLFxuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgb3Igbm90IGEgY2hlY2tib3ggbmVlZHMgdG8gYmUgc2VsZWN0ZWQgYmVmb3JlIHRoZSB1c2VyIGNhbiBjb25maXJtIHRoZSBkaWFsb2cuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgICAqL1xuICAgIHJlcXVpcmVDb25maXJtYXRpb24/OiBib29sZWFuLFxuICAgIC8qKlxuICAgICAqIFRoZSB0ZXh0IHRvIGRpc3BsYXkgb24gdGhlIGNoZWNrYm94IGlmICdyZXF1aXJlQ29uZmlybWF0aW9uJyBpcyBzZXQgdG8gdHJ1ZS5cbiAgICAgKi9cbiAgICBjb25maXJtYXRpb25UZXh0Pzogc3RyaW5nXG59Il19
|