@mediusinc/mng-commons-audit 3.0.0-rc.0 → 3.0.0-rc.1

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 (44) hide show
  1. package/README.md +32 -4
  2. package/assets/i18n/en.json +23 -21
  3. package/assets/i18n/sl.json +25 -14
  4. package/esm2022/lib/api/models/guiPropertyModel.mjs +6 -1
  5. package/esm2022/lib/api/models/index.mjs +1 -4
  6. package/esm2022/lib/api/services/audit-revisions-api.service.mjs +38 -21
  7. package/esm2022/lib/api/services/audit.service.mjs +45 -0
  8. package/esm2022/lib/audit.routes.mjs +33 -10
  9. package/esm2022/lib/components/entity-changes-field/entity-changes-field.component.mjs +49 -35
  10. package/esm2022/lib/components/pages/audit/audit-page.component.mjs +12 -0
  11. package/esm2022/lib/components/pages/entity-revisions/audit-entity-revisions-page.component.mjs +90 -32
  12. package/esm2022/lib/components/pages/revisions/audit-revisions-page.component.mjs +41 -45
  13. package/esm2022/lib/models/config.model.mjs +2 -0
  14. package/esm2022/lib/models/new-filter-match-type.model.mjs +19 -0
  15. package/esm2022/lib/models/revEntityWithId.model.mjs +9 -0
  16. package/esm2022/lib/service/module-config.token.mjs +3 -0
  17. package/esm2022/lib/utils/audit.util.mjs +300 -0
  18. package/fesm2022/mediusinc-mng-commons-audit.mjs +615 -306
  19. package/fesm2022/mediusinc-mng-commons-audit.mjs.map +1 -1
  20. package/lib/api/models/guiPropertyModel.d.ts +1 -0
  21. package/lib/api/models/index.d.ts +0 -3
  22. package/lib/api/services/audit-revisions-api.service.d.ts +16 -10
  23. package/lib/api/services/audit.service.d.ts +20 -0
  24. package/lib/audit.routes.d.ts +3 -2
  25. package/lib/components/entity-changes-field/entity-changes-field.component.d.ts +9 -6
  26. package/lib/components/pages/audit/audit-page.component.d.ts +5 -0
  27. package/lib/components/pages/entity-revisions/audit-entity-revisions-page.component.d.ts +21 -12
  28. package/lib/components/pages/revisions/audit-revisions-page.component.d.ts +8 -5
  29. package/lib/models/config.model.d.ts +4 -0
  30. package/lib/models/new-filter-match-type.model.d.ts +17 -0
  31. package/lib/models/revEntityWithId.model.d.ts +4 -0
  32. package/lib/service/module-config.token.d.ts +3 -0
  33. package/lib/utils/audit.util.d.ts +9 -0
  34. package/package.json +2 -3
  35. package/esm2022/lib/api/models/revEntityChangeDto.mjs +0 -52
  36. package/esm2022/lib/api/models/revEntityDto.mjs +0 -42
  37. package/esm2022/lib/api/models/revisionTypeEnumDto.mjs +0 -20
  38. package/esm2022/lib/api/services/audit-entity-revisions-api.service.mjs +0 -47
  39. package/esm2022/lib/components/pages/entity-revisions/entity-dropdown-page.component.mjs +0 -32
  40. package/lib/api/models/revEntityChangeDto.d.ts +0 -25
  41. package/lib/api/models/revEntityDto.d.ts +0 -20
  42. package/lib/api/models/revisionTypeEnumDto.d.ts +0 -5
  43. package/lib/api/services/audit-entity-revisions-api.service.d.ts +0 -14
  44. package/lib/components/pages/entity-revisions/entity-dropdown-page.component.d.ts +0 -12
@@ -0,0 +1,300 @@
1
+ import { MediusFilterMatchType, ObjectSerializer } from '@mediusinc/mng-commons';
2
+ import { GuiPropertyType, RevisionType } from '../api/models';
3
+ import { NewMediusFilterMatchType } from '../models/new-filter-match-type.model';
4
+ export class AuditUtil {
5
+ static addColumnsFromModel(descriptor, propertyList) {
6
+ for (const property of propertyList) {
7
+ if (property.propertyType === GuiPropertyType.Enum) {
8
+ // TODO is there a nicer way than appending "Dto" at the end of the simple name to match
9
+ descriptor
10
+ .addColumn(property.resolvedPropertyName)
11
+ .withSort()
12
+ .asEnum(ObjectSerializer.get().findEnum(property.enumClassSimpleName + 'Dto'))
13
+ .withFilterLookupEnum(property.possibleEnumValues);
14
+ }
15
+ else if (property.propertyType === GuiPropertyType.Number) {
16
+ descriptor.addColumn(property.resolvedPropertyName).withSort().asNumber().withFilter();
17
+ }
18
+ else if (property.propertyType === GuiPropertyType.Boolean) {
19
+ descriptor.addColumn(property.resolvedPropertyName).withSort().asBoolean().withFilter();
20
+ }
21
+ else if (property.propertyType === GuiPropertyType.LocalDate) {
22
+ descriptor.addColumn(property.resolvedPropertyName).withSort().asDate('dd. MMM yyyy').withFilter();
23
+ }
24
+ else if (property.propertyType === GuiPropertyType.OffsetDateTime) {
25
+ descriptor.addColumn(property.resolvedPropertyName).withSort().asDate('dd. MMM yyyy HH:mm').withFilter();
26
+ }
27
+ else {
28
+ // string / wildcard
29
+ descriptor.addColumn(property.resolvedPropertyName).withSort().withFilter();
30
+ }
31
+ }
32
+ return descriptor;
33
+ }
34
+ static addFieldsFromModel(descriptor, revModel) {
35
+ for (const property of revModel.properties) {
36
+ if (property.propertyType === GuiPropertyType.Enum) {
37
+ descriptor
38
+ .addFieldLookupEnum('revEntity.' + property.resolvedPropertyName, ObjectSerializer.get().findEnum(property.enumClassSimpleName), property.possibleEnumValues)
39
+ .withLabel(property.resolvedPropertyName)
40
+ .withDisabled();
41
+ }
42
+ else if (property.propertyType === GuiPropertyType.Number) {
43
+ descriptor
44
+ .addField('revEntity.' + property.resolvedPropertyName)
45
+ .withLabel(property.resolvedPropertyName)
46
+ .asNumber()
47
+ .withDisabled();
48
+ }
49
+ else if (property.propertyType === GuiPropertyType.Boolean) {
50
+ descriptor
51
+ .addField('revEntity.' + property.resolvedPropertyName)
52
+ .withLabel(property.resolvedPropertyName)
53
+ .withDisabled();
54
+ }
55
+ else if (property.propertyType === GuiPropertyType.LocalDate) {
56
+ descriptor
57
+ .addField('revEntity.' + property.resolvedPropertyName)
58
+ .withLabel(property.resolvedPropertyName)
59
+ .asDatePicker('dd. MMM yyyy')
60
+ .withDisabled();
61
+ }
62
+ else if (property.propertyType === GuiPropertyType.OffsetDateTime) {
63
+ descriptor
64
+ .addField('revEntity.' + property.resolvedPropertyName)
65
+ .withLabel(property.resolvedPropertyName)
66
+ .asDatePicker('dd. MM yy', undefined, undefined, true, false)
67
+ .withDisabled();
68
+ }
69
+ else {
70
+ // string / wildcard
71
+ descriptor
72
+ .addField('revEntity.' + property.resolvedPropertyName)
73
+ .withLabel(property.resolvedPropertyName)
74
+ .withDisabled();
75
+ }
76
+ }
77
+ return descriptor;
78
+ }
79
+ static buildDescriptorForEntityRevision(descriptor, revModel, entityModel) {
80
+ descriptor
81
+ .addColumn('revType')
82
+ .withTitle('revType')
83
+ .asEnum(ObjectSerializer.get().findEnum('RevisionType'))
84
+ .withFilterLookupEnum([RevisionType.Add, RevisionType.Mod, RevisionType.Del]);
85
+ descriptor.addFieldLookupEnum('revType', ObjectSerializer.get().findEnum('RevisionType'), [RevisionType.Add, RevisionType.Mod, RevisionType.Del]).withLabel('revType');
86
+ for (const property of revModel.properties) {
87
+ if (property.propertyType === GuiPropertyType.Enum) {
88
+ // TODO is there a nicer way than appending "Dto" at the end of the simple name to match
89
+ descriptor
90
+ .addColumn('revEntity.' + property.resolvedPropertyName)
91
+ .withTitle(property.resolvedPropertyName)
92
+ .asEnum(ObjectSerializer.get().findEnum(property.enumClassSimpleName + 'Dto'))
93
+ .withSort()
94
+ .withFilterLookupEnum(property.possibleEnumValues);
95
+ descriptor
96
+ .addFieldLookupEnum('revEntity.' + property.resolvedPropertyName, ObjectSerializer.get().findEnum(property.enumClassSimpleName + 'Dto'), property.possibleEnumValues)
97
+ .withLabel(property.resolvedPropertyName);
98
+ }
99
+ else if (property.propertyType === GuiPropertyType.Number) {
100
+ descriptor
101
+ .addColumn('revEntity.' + property.resolvedPropertyName)
102
+ .withTitle(property.resolvedPropertyName)
103
+ .asNumber()
104
+ .withSort()
105
+ .withFilter();
106
+ descriptor
107
+ .addField('revEntity.' + property.resolvedPropertyName)
108
+ .withLabel(property.resolvedPropertyName)
109
+ .asNumber();
110
+ }
111
+ else if (property.propertyType === GuiPropertyType.Boolean) {
112
+ descriptor
113
+ .addColumn('revEntity.' + property.resolvedPropertyName)
114
+ .withTitle(property.resolvedPropertyName)
115
+ .asBoolean()
116
+ .withSort()
117
+ .withFilter();
118
+ descriptor.addField('revEntity.' + property.resolvedPropertyName).withLabel(property.resolvedPropertyName);
119
+ }
120
+ else if (property.propertyType === GuiPropertyType.LocalDate) {
121
+ descriptor
122
+ .addColumn('revEntity.' + property.resolvedPropertyName)
123
+ .withTitle(property.resolvedPropertyName)
124
+ .asDate('dd. MMM yyyy')
125
+ .withSort()
126
+ .withFilter();
127
+ descriptor
128
+ .addField('revEntity.' + property.resolvedPropertyName)
129
+ .withLabel(property.resolvedPropertyName)
130
+ .asDatePicker('dd. MMM yyyy');
131
+ }
132
+ else if (property.propertyType === GuiPropertyType.OffsetDateTime) {
133
+ descriptor
134
+ .addColumn('revEntity.' + property.resolvedPropertyName)
135
+ .withTitle(property.resolvedPropertyName)
136
+ .asDate('dd. MMM yyyy HH:mm')
137
+ .withSort()
138
+ .withFilter();
139
+ descriptor
140
+ .addField('revEntity.' + property.resolvedPropertyName)
141
+ .withLabel(property.resolvedPropertyName)
142
+ .asDatePicker('dd. MM yy', undefined, undefined, true, false);
143
+ }
144
+ else {
145
+ // string / wildcard
146
+ descriptor
147
+ .addColumn('revEntity.' + property.resolvedPropertyName)
148
+ .withTitle(property.resolvedPropertyName)
149
+ .withSort()
150
+ .withFilter();
151
+ descriptor.addField('revEntity.' + property.resolvedPropertyName).withLabel(property.resolvedPropertyName);
152
+ }
153
+ }
154
+ for (const property of entityModel.properties) {
155
+ if (property.propertyType === GuiPropertyType.Enum) {
156
+ // TODO is there a nicer way than appending "Dto" at the end of the simple name to match
157
+ descriptor
158
+ .addColumn('entityState.' + property.resolvedPropertyName)
159
+ .withTitle(property.resolvedPropertyName)
160
+ .asEnum(ObjectSerializer.get().findEnum(property.enumClassSimpleName + 'Dto'))
161
+ .withSort()
162
+ .withFilterLookupEnum(property.possibleEnumValues);
163
+ descriptor
164
+ .addFieldLookupEnum('entityState.' + property.resolvedPropertyName, ObjectSerializer.get().findEnum(property.enumClassSimpleName + 'Dto'), property.possibleEnumValues)
165
+ .withLabel(property.resolvedPropertyName);
166
+ }
167
+ else if (property.propertyType === GuiPropertyType.Number) {
168
+ descriptor
169
+ .addColumn('entityState.' + property.resolvedPropertyName)
170
+ .withTitle(property.resolvedPropertyName)
171
+ .asNumber()
172
+ .withSort()
173
+ .withFilter();
174
+ descriptor
175
+ .addField('entityState.' + property.resolvedPropertyName)
176
+ .withLabel(property.resolvedPropertyName)
177
+ .asNumber();
178
+ }
179
+ else if (property.propertyType === GuiPropertyType.Boolean) {
180
+ descriptor
181
+ .addColumn('entityState.' + property.resolvedPropertyName)
182
+ .withTitle(property.resolvedPropertyName)
183
+ .asBoolean()
184
+ .withSort()
185
+ .withFilter();
186
+ descriptor.addField('entityState.' + property.resolvedPropertyName).withLabel(property.resolvedPropertyName);
187
+ }
188
+ else if (property.propertyType === GuiPropertyType.LocalDate) {
189
+ descriptor
190
+ .addColumn('entityState.' + property.resolvedPropertyName)
191
+ .withTitle(property.resolvedPropertyName)
192
+ .asDate('dd. MMM yyyy')
193
+ .withSort()
194
+ .withFilter();
195
+ descriptor
196
+ .addField('entityState.' + property.resolvedPropertyName)
197
+ .withLabel(property.resolvedPropertyName)
198
+ .asDatePicker('dd. MMM yyyy');
199
+ }
200
+ else if (property.propertyType === GuiPropertyType.OffsetDateTime) {
201
+ descriptor
202
+ .addColumn('entityState.' + property.resolvedPropertyName)
203
+ .withTitle(property.resolvedPropertyName)
204
+ .asDate('dd. MMM yyyy HH:mm')
205
+ .withSort()
206
+ .withFilter();
207
+ descriptor
208
+ .addField('entityState.' + property.resolvedPropertyName)
209
+ .withLabel(property.resolvedPropertyName)
210
+ .asDatePicker('dd. MM yy', undefined, undefined, true, false);
211
+ }
212
+ else {
213
+ // string / wildcard
214
+ descriptor
215
+ .addColumn('entityState.' + property.resolvedPropertyName)
216
+ .withTitle(property.resolvedPropertyName)
217
+ .withSort()
218
+ .withFilter();
219
+ descriptor.addField('entityState.' + property.resolvedPropertyName).withLabel(property.resolvedPropertyName);
220
+ }
221
+ }
222
+ return descriptor;
223
+ }
224
+ static extractPropertyName(fullPropertyName) {
225
+ if (fullPropertyName?.includes('entityState.')) {
226
+ return fullPropertyName.replace('entityState.', '');
227
+ }
228
+ else if (fullPropertyName?.includes('revEntity.')) {
229
+ return fullPropertyName?.replace('revEntity.', '');
230
+ }
231
+ return fullPropertyName;
232
+ }
233
+ static appendMediusQueryParamsToUrl(queryParams) {
234
+ let url = `?firstResult=${queryParams.itemsOffset}&maxResults=${queryParams.itemsPerPage}`;
235
+ if (queryParams.sortProperty && queryParams.sortProperty.length > 0) {
236
+ url += '&sorts=';
237
+ const sortingQPs = [];
238
+ for (let i = 0; i < queryParams.sortProperty.length; i++) {
239
+ if (queryParams.sortAsc[i]) {
240
+ sortingQPs.push(`asc:${this.extractPropertyName(queryParams.sortProperty[i])}`);
241
+ }
242
+ else {
243
+ sortingQPs.push(`desc:${this.extractPropertyName(queryParams.sortProperty[i])}`);
244
+ }
245
+ }
246
+ url += sortingQPs.join(',');
247
+ }
248
+ if (queryParams.filterParams && queryParams.filterParams.length > 0) {
249
+ const filterQPs = [];
250
+ for (const mfp of queryParams.filterParams) {
251
+ switch (mfp.filterMatchType) {
252
+ case MediusFilterMatchType.Equals: {
253
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.Equals}:${mfp.filterValue}`);
254
+ break;
255
+ }
256
+ case MediusFilterMatchType.NotEquals: {
257
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.NotEquals}:${mfp.filterValue}`);
258
+ break;
259
+ }
260
+ case MediusFilterMatchType.FromTo: {
261
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.Between}:${mfp.filterValue},${mfp.filterValueTo}`);
262
+ break;
263
+ }
264
+ case MediusFilterMatchType.Contains: {
265
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.Contains}:${mfp.filterValue}`);
266
+ break;
267
+ }
268
+ case MediusFilterMatchType.StartsWith: {
269
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.StartsWith}:${mfp.filterValue}`);
270
+ break;
271
+ }
272
+ case MediusFilterMatchType.EndsWith: {
273
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.EndsWith}:${mfp.filterValue}`);
274
+ break;
275
+ }
276
+ case MediusFilterMatchType.In: {
277
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.In}:${mfp.filterValue}`);
278
+ break;
279
+ }
280
+ case MediusFilterMatchType.NotIn: {
281
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.NotIn}:${mfp.filterValue}`);
282
+ break;
283
+ }
284
+ case MediusFilterMatchType.SmallerThan: {
285
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.LessThan}:${mfp.filterValue}`);
286
+ break;
287
+ }
288
+ case MediusFilterMatchType.GreaterThan: {
289
+ filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.GreaterThan}:${mfp.filterValue}`);
290
+ break;
291
+ }
292
+ }
293
+ }
294
+ url += '&';
295
+ url += filterQPs.join('&');
296
+ }
297
+ return url;
298
+ }
299
+ }
300
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audit.util.js","sourceRoot":"","sources":["../../../../src/lib/utils/audit.util.ts"],"names":[],"mappings":"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","sourcesContent":["import {EditorDescriptor, MediusFilterMatchType, MediusQueryParam, ObjectSerializer, TableDescriptor, TableviewDescriptor} from '@mediusinc/mng-commons';\n\nimport {GuiEntityModel, GuiPropertyModel, GuiPropertyType, RevEntityWithStateDto, RevisionType} from '../api/models';\nimport {NewMediusFilterMatchType} from '../models/new-filter-match-type.model';\n\nexport class AuditUtil {\n    public static addColumnsFromModel(descriptor: TableDescriptor<any>, propertyList: GuiPropertyModel[]): TableDescriptor<any> {\n        for (const property of propertyList) {\n            if (property.propertyType === GuiPropertyType.Enum) {\n                // TODO is there a nicer way than appending \"Dto\" at the end of the simple name to match\n                descriptor\n                    .addColumn(property.resolvedPropertyName!)\n                    .withSort()\n                    .asEnum(ObjectSerializer.get().findEnum(property.enumClassSimpleName + 'Dto'))\n                    .withFilterLookupEnum(property.possibleEnumValues);\n            } else if (property.propertyType === GuiPropertyType.Number) {\n                descriptor.addColumn(property.resolvedPropertyName!).withSort().asNumber().withFilter();\n            } else if (property.propertyType === GuiPropertyType.Boolean) {\n                descriptor.addColumn(property.resolvedPropertyName!).withSort().asBoolean().withFilter();\n            } else if (property.propertyType === GuiPropertyType.LocalDate) {\n                descriptor.addColumn(property.resolvedPropertyName!).withSort().asDate('dd. MMM yyyy').withFilter();\n            } else if (property.propertyType === GuiPropertyType.OffsetDateTime) {\n                descriptor.addColumn(property.resolvedPropertyName!).withSort().asDate('dd. MMM yyyy HH:mm').withFilter();\n            } else {\n                // string / wildcard\n                descriptor.addColumn(property.resolvedPropertyName!).withSort().withFilter();\n            }\n        }\n        return descriptor;\n    }\n\n    public static addFieldsFromModel<T>(descriptor: EditorDescriptor<T>, revModel: GuiEntityModel): EditorDescriptor<T> {\n        for (const property of revModel.properties!) {\n            if (property.propertyType === GuiPropertyType.Enum) {\n                descriptor\n                    .addFieldLookupEnum('revEntity.' + property.resolvedPropertyName!, ObjectSerializer.get().findEnum(property.enumClassSimpleName!), property.possibleEnumValues)\n                    .withLabel(property.resolvedPropertyName!)\n                    .withDisabled();\n            } else if (property.propertyType === GuiPropertyType.Number) {\n                descriptor\n                    .addField('revEntity.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asNumber()\n                    .withDisabled();\n            } else if (property.propertyType === GuiPropertyType.Boolean) {\n                descriptor\n                    .addField('revEntity.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .withDisabled();\n            } else if (property.propertyType === GuiPropertyType.LocalDate) {\n                descriptor\n                    .addField('revEntity.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asDatePicker('dd. MMM yyyy')\n                    .withDisabled();\n            } else if (property.propertyType === GuiPropertyType.OffsetDateTime) {\n                descriptor\n                    .addField('revEntity.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asDatePicker('dd. MM yy', undefined, undefined, true, false)\n                    .withDisabled();\n            } else {\n                // string / wildcard\n                descriptor\n                    .addField('revEntity.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .withDisabled();\n            }\n        }\n        return descriptor;\n    }\n\n    public static buildDescriptorForEntityRevision(\n        descriptor: TableviewDescriptor<RevEntityWithStateDto>,\n        revModel: GuiEntityModel,\n        entityModel: GuiEntityModel\n    ): TableviewDescriptor<RevEntityWithStateDto> {\n        descriptor\n            .addColumn('revType')\n            .withTitle('revType')\n            .asEnum(ObjectSerializer.get().findEnum('RevisionType'))\n            .withFilterLookupEnum([RevisionType.Add, RevisionType.Mod, RevisionType.Del]);\n        descriptor.addFieldLookupEnum('revType', ObjectSerializer.get().findEnum('RevisionType'), [RevisionType.Add, RevisionType.Mod, RevisionType.Del]).withLabel('revType');\n        for (const property of revModel.properties!) {\n            if (property.propertyType === GuiPropertyType.Enum) {\n                // TODO is there a nicer way than appending \"Dto\" at the end of the simple name to match\n                descriptor\n                    .addColumn('revEntity.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asEnum(ObjectSerializer.get().findEnum(property.enumClassSimpleName + 'Dto'))\n                    .withSort()\n                    .withFilterLookupEnum(property.possibleEnumValues);\n\n                descriptor\n                    .addFieldLookupEnum(\n                        'revEntity.' + property.resolvedPropertyName!,\n                        ObjectSerializer.get().findEnum(property.enumClassSimpleName! + 'Dto'),\n                        property.possibleEnumValues\n                    )\n                    .withLabel(property.resolvedPropertyName!);\n            } else if (property.propertyType === GuiPropertyType.Number) {\n                descriptor\n                    .addColumn('revEntity.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asNumber()\n                    .withSort()\n                    .withFilter();\n                descriptor\n                    .addField('revEntity.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asNumber();\n            } else if (property.propertyType === GuiPropertyType.Boolean) {\n                descriptor\n                    .addColumn('revEntity.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asBoolean()\n                    .withSort()\n                    .withFilter();\n                descriptor.addField('revEntity.' + property.resolvedPropertyName!).withLabel(property.resolvedPropertyName!);\n            } else if (property.propertyType === GuiPropertyType.LocalDate) {\n                descriptor\n                    .addColumn('revEntity.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asDate('dd. MMM yyyy')\n                    .withSort()\n                    .withFilter();\n                descriptor\n                    .addField('revEntity.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asDatePicker('dd. MMM yyyy');\n            } else if (property.propertyType === GuiPropertyType.OffsetDateTime) {\n                descriptor\n                    .addColumn('revEntity.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asDate('dd. MMM yyyy HH:mm')\n                    .withSort()\n                    .withFilter();\n                descriptor\n                    .addField('revEntity.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asDatePicker('dd. MM yy', undefined, undefined, true, false);\n            } else {\n                // string / wildcard\n                descriptor\n                    .addColumn('revEntity.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .withSort()\n                    .withFilter();\n                descriptor.addField('revEntity.' + property.resolvedPropertyName!).withLabel(property.resolvedPropertyName!);\n            }\n        }\n        for (const property of entityModel.properties!) {\n            if (property.propertyType === GuiPropertyType.Enum) {\n                // TODO is there a nicer way than appending \"Dto\" at the end of the simple name to match\n                descriptor\n                    .addColumn('entityState.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asEnum(ObjectSerializer.get().findEnum(property.enumClassSimpleName + 'Dto'))\n                    .withSort()\n                    .withFilterLookupEnum(property.possibleEnumValues);\n                descriptor\n                    .addFieldLookupEnum(\n                        'entityState.' + property.resolvedPropertyName!,\n                        ObjectSerializer.get().findEnum(property.enumClassSimpleName! + 'Dto'),\n                        property.possibleEnumValues\n                    )\n                    .withLabel(property.resolvedPropertyName!);\n            } else if (property.propertyType === GuiPropertyType.Number) {\n                descriptor\n                    .addColumn('entityState.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asNumber()\n                    .withSort()\n                    .withFilter();\n                descriptor\n                    .addField('entityState.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asNumber();\n            } else if (property.propertyType === GuiPropertyType.Boolean) {\n                descriptor\n                    .addColumn('entityState.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asBoolean()\n                    .withSort()\n                    .withFilter();\n                descriptor.addField('entityState.' + property.resolvedPropertyName!).withLabel(property.resolvedPropertyName!);\n            } else if (property.propertyType === GuiPropertyType.LocalDate) {\n                descriptor\n                    .addColumn('entityState.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asDate('dd. MMM yyyy')\n                    .withSort()\n                    .withFilter();\n                descriptor\n                    .addField('entityState.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asDatePicker('dd. MMM yyyy');\n            } else if (property.propertyType === GuiPropertyType.OffsetDateTime) {\n                descriptor\n                    .addColumn('entityState.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .asDate('dd. MMM yyyy HH:mm')\n                    .withSort()\n                    .withFilter();\n                descriptor\n                    .addField('entityState.' + property.resolvedPropertyName!)\n                    .withLabel(property.resolvedPropertyName!)\n                    .asDatePicker('dd. MM yy', undefined, undefined, true, false);\n            } else {\n                // string / wildcard\n                descriptor\n                    .addColumn('entityState.' + property.resolvedPropertyName!)\n                    .withTitle(property.resolvedPropertyName!)\n                    .withSort()\n                    .withFilter();\n                descriptor.addField('entityState.' + property.resolvedPropertyName!).withLabel(property.resolvedPropertyName!);\n            }\n        }\n        return descriptor;\n    }\n\n    private static extractPropertyName(fullPropertyName: string | undefined): string | undefined {\n        if (fullPropertyName?.includes('entityState.')) {\n            return fullPropertyName.replace('entityState.', '');\n        } else if (fullPropertyName?.includes('revEntity.')) {\n            return fullPropertyName?.replace('revEntity.', '');\n        }\n        return fullPropertyName;\n    }\n\n    public static appendMediusQueryParamsToUrl(queryParams: MediusQueryParam): string {\n        let url = `?firstResult=${queryParams.itemsOffset}&maxResults=${queryParams.itemsPerPage}`;\n        if (queryParams.sortProperty && queryParams.sortProperty.length > 0) {\n            url += '&sorts=';\n            const sortingQPs = [];\n            for (let i = 0; i < queryParams.sortProperty.length; i++) {\n                if (queryParams.sortAsc![i]) {\n                    sortingQPs.push(`asc:${this.extractPropertyName(queryParams.sortProperty[i])}`);\n                } else {\n                    sortingQPs.push(`desc:${this.extractPropertyName(queryParams.sortProperty[i])}`);\n                }\n            }\n            url += sortingQPs.join(',');\n        }\n        if (queryParams.filterParams && queryParams.filterParams.length > 0) {\n            const filterQPs = [];\n            for (const mfp of queryParams.filterParams) {\n                switch (mfp.filterMatchType) {\n                    case MediusFilterMatchType.Equals: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.Equals}:${mfp.filterValue}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.NotEquals: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.NotEquals}:${mfp.filterValue}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.FromTo: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.Between}:${mfp.filterValue},${mfp.filterValueTo}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.Contains: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.Contains}:${mfp.filterValue}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.StartsWith: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.StartsWith}:${mfp.filterValue}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.EndsWith: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.EndsWith}:${mfp.filterValue}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.In: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.In}:${mfp.filterValue}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.NotIn: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.NotIn}:${mfp.filterValue}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.SmallerThan: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.LessThan}:${mfp.filterValue}`);\n                        break;\n                    }\n                    case MediusFilterMatchType.GreaterThan: {\n                        filterQPs.push(`${this.extractPropertyName(mfp.property)}=${NewMediusFilterMatchType.GreaterThan}:${mfp.filterValue}`);\n                        break;\n                    }\n                }\n            }\n            url += '&';\n            url += filterQPs.join('&');\n        }\n        return url;\n    }\n}\n"]}