ngx-material-entity 18.1.0 → 18.2.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 (85) hide show
  1. package/README.md +10 -13
  2. package/components/create-page/create-page.component.d.ts +3 -0
  3. package/components/edit-page/edit-page.component.d.ts +3 -0
  4. package/components/input/file/file-default-input/file-default-input.component.d.ts +1 -1
  5. package/components/input/file/file-image-input/file-image-input.component.d.ts +3 -0
  6. package/components/input/file/file-input/file-input.component.d.ts +8 -2
  7. package/components/input/input.component.d.ts +2 -0
  8. package/components/input/number/number-dropdown-input/number-dropdown-input.component.d.ts +2 -0
  9. package/components/input/relations/references-many-input/references-many-input.component.d.ts +2 -0
  10. package/components/input/string/string-dropdown-input/string-dropdown-input.component.d.ts +2 -0
  11. package/components/input/string/string-password-input/string-password-input.component.d.ts +3 -0
  12. package/components/tooltip/tooltip.component.d.ts +2 -0
  13. package/decorators/array/array-decorator-internal.data.d.ts +3 -2
  14. package/decorators/array/array-decorator.data.d.ts +7 -6
  15. package/decorators/base/property-decorator.data.d.ts +2 -2
  16. package/decorators/file/file-decorator-internal.data.d.ts +3 -2
  17. package/decorators/file/file-decorator.data.d.ts +4 -3
  18. package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +4 -4
  19. package/esm2022/components/create-page/create-page.component.mjs +18 -8
  20. package/esm2022/components/custom-table/custom-table.component.mjs +4 -4
  21. package/esm2022/components/edit-page/edit-page.component.mjs +18 -8
  22. package/esm2022/components/form/form.component.mjs +5 -5
  23. package/esm2022/components/input/array/array-date-input/array-date-input.component.mjs +5 -5
  24. package/esm2022/components/input/array/array-date-range-input/array-date-range-input.component.mjs +3 -3
  25. package/esm2022/components/input/array/array-date-time-input/array-date-time-input.component.mjs +3 -3
  26. package/esm2022/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +8 -6
  27. package/esm2022/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +8 -6
  28. package/esm2022/components/input/array/array-table.class.mjs +3 -3
  29. package/esm2022/components/input/base-input.component.mjs +3 -3
  30. package/esm2022/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +4 -4
  31. package/esm2022/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +3 -3
  32. package/esm2022/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +4 -4
  33. package/esm2022/components/input/custom/custom.component.mjs +3 -3
  34. package/esm2022/components/input/date/date-input/date-input.component.mjs +3 -3
  35. package/esm2022/components/input/date/date-range-input/date-range-input.component.mjs +3 -3
  36. package/esm2022/components/input/date/date-time-input/date-time-input.component.mjs +3 -3
  37. package/esm2022/components/input/file/file-default-input/file-default-input.component.mjs +5 -5
  38. package/esm2022/components/input/file/file-image-input/file-image-input.component.mjs +9 -5
  39. package/esm2022/components/input/file/file-input/file-input.component.mjs +25 -12
  40. package/esm2022/components/input/input.component.mjs +23 -12
  41. package/esm2022/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +10 -6
  42. package/esm2022/components/input/number/number-input/number-input.component.mjs +3 -3
  43. package/esm2022/components/input/number/number-slider-input/number-slider-input.component.mjs +4 -4
  44. package/esm2022/components/input/relations/references-many-input/references-many-input.component.mjs +10 -6
  45. package/esm2022/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +3 -3
  46. package/esm2022/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +10 -6
  47. package/esm2022/components/input/string/string-input/string-input.component.mjs +3 -3
  48. package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs +11 -6
  49. package/esm2022/components/input/string/string-textbox-input/string-textbox-input.component.mjs +3 -3
  50. package/esm2022/components/table/create-dialog/create-entity-dialog.component.mjs +9 -6
  51. package/esm2022/components/table/display-column-value/base-display-column-value.component.mjs +3 -3
  52. package/esm2022/components/table/display-column-value/display-column-value.component.mjs +3 -3
  53. package/esm2022/components/table/edit-dialog/edit-data.builder.mjs +1 -1
  54. package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +9 -7
  55. package/esm2022/components/table/table-data.builder.mjs +3 -1
  56. package/esm2022/components/table/table-data.mjs +1 -1
  57. package/esm2022/components/table/table.component.mjs +5 -11
  58. package/esm2022/components/tooltip/tooltip.component.mjs +9 -5
  59. package/esm2022/decorators/array/array-decorator-internal.data.mjs +5 -3
  60. package/esm2022/decorators/array/array-decorator.data.mjs +1 -1
  61. package/esm2022/decorators/array/array.decorator.mjs +15 -8
  62. package/esm2022/decorators/base/property-decorator.data.mjs +2 -2
  63. package/esm2022/decorators/file/file-decorator-internal.data.mjs +4 -3
  64. package/esm2022/decorators/file/file-decorator.data.mjs +3 -3
  65. package/esm2022/decorators/file/file.decorator.mjs +7 -4
  66. package/esm2022/decorators/number/number.decorator.mjs +7 -4
  67. package/esm2022/decorators/object/object.decorator.mjs +5 -3
  68. package/esm2022/decorators/string/string-decorator-internal.data.mjs +2 -1
  69. package/esm2022/decorators/string/string.decorator.mjs +11 -6
  70. package/esm2022/directives/drag-drop.directive.mjs +3 -3
  71. package/esm2022/directives/dynamic-style-class.directive.mjs +3 -3
  72. package/esm2022/directives/included-in.directive.mjs +3 -3
  73. package/esm2022/directives/number.directive.mjs +3 -3
  74. package/esm2022/directives/password-match.directive.mjs +3 -3
  75. package/esm2022/directives/tooltip.directive.mjs +3 -3
  76. package/esm2022/functions/dropdown-values-to-function.function.mjs +2 -1
  77. package/esm2022/functions/table-column-value-to-sort-value.function.mjs +9 -5
  78. package/esm2022/utilities/date.utilities.mjs +1 -1
  79. package/esm2022/utilities/entity.utilities.mjs +36 -21
  80. package/esm2022/utilities/file.utilities.mjs +7 -4
  81. package/esm2022/utilities/validation.utilities.mjs +41 -21
  82. package/fesm2022/ngx-material-entity.mjs +367 -254
  83. package/fesm2022/ngx-material-entity.mjs.map +1 -1
  84. package/package.json +4 -2
  85. package/utilities/entity.utilities.d.ts +4 -4
@@ -7,7 +7,7 @@
7
7
  */
8
8
  export function tableColumnValueToSortValue(value) {
9
9
  switch (typeof value) {
10
- case 'string':
10
+ case 'string': {
11
11
  const stringDate = new Date(value);
12
12
  if (!Number.isNaN(stringDate.getTime())) {
13
13
  return stringDate.getTime();
@@ -17,13 +17,17 @@ export function tableColumnValueToSortValue(value) {
17
17
  return number;
18
18
  }
19
19
  return value;
20
- case 'number':
20
+ }
21
+ case 'number': {
21
22
  return value;
22
- case 'object':
23
+ }
24
+ case 'object': {
23
25
  const date = new Date(value);
24
26
  return date.getTime();
25
- default:
27
+ }
28
+ default: {
26
29
  throw new Error(`Unsupported type for table value: ${typeof value}`);
30
+ }
27
31
  }
28
32
  }
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sdW1uLXZhbHVlLXRvLXNvcnQtdmFsdWUuZnVuY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9mdW5jdGlvbnMvdGFibGUtY29sdW1uLXZhbHVlLXRvLXNvcnQtdmFsdWUuZnVuY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7Ozs7OztHQU1HO0FBQ0gsTUFBTSxVQUFVLDJCQUEyQixDQUFDLEtBQXVCO0lBQy9ELFFBQVEsT0FBTyxLQUFLLEVBQUUsQ0FBQztRQUNuQixLQUFLLFFBQVE7WUFDVCxNQUFNLFVBQVUsR0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUN6QyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDO2dCQUN0QyxPQUFPLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQyxDQUFDO1lBQ0QsTUFBTSxNQUFNLEdBQVcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNoRCxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO2dCQUN4QixPQUFPLE1BQU0sQ0FBQztZQUNsQixDQUFDO1lBQ0QsT0FBTyxLQUFLLENBQUM7UUFDakIsS0FBSyxRQUFRO1lBQ1QsT0FBTyxLQUFLLENBQUM7UUFDakIsS0FBSyxRQUFRO1lBQ1QsTUFBTSxJQUFJLEdBQVMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbkMsT0FBTyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDMUI7WUFDSSxNQUFNLElBQUksS0FBSyxDQUFDLHFDQUFxQyxPQUFPLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDN0UsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUYWJsZUNvbHVtblZhbHVlIH0gZnJvbSAnLi4vY29tcG9uZW50cy90YWJsZS90YWJsZS1kYXRhJztcblxuLyoqXG4gKiBDb252ZXJ0cyB0aGUgZ2l2ZW4gdGFibGUgY29sdW1uIHZhbHVlIHRvIGEgc3RyaW5nL251bWJlciBmb3Igc29ydGluZy5cbiAqIFRoaXMgYWxzbyBzdXBwb3J0cyBzdHJpbmcgZGF0ZXMsIGlmIHlvdSBlZy4gTmVlZGVkIHRvIGZvcm1hdCB0aGVtLlxuICogQHBhcmFtIHZhbHVlIC0gVGhlIHZhbHVlIHRvIGNvbnZlcnQuXG4gKiBAcmV0dXJucyBBIHN0cmluZyBvciBhIG51bWJlciB0byBzb3J0IGJ5LlxuICogQHRocm93cyBXaGVuIGEgdmFsdWUgd2l0aCBhbiB1bmtub3duIHR5cGUgaGFzIGJlZW4gcHJvdmlkZWQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB0YWJsZUNvbHVtblZhbHVlVG9Tb3J0VmFsdWUodmFsdWU6IFRhYmxlQ29sdW1uVmFsdWUpOiBzdHJpbmcgfCBudW1iZXIge1xuICAgIHN3aXRjaCAodHlwZW9mIHZhbHVlKSB7XG4gICAgICAgIGNhc2UgJ3N0cmluZyc6XG4gICAgICAgICAgICBjb25zdCBzdHJpbmdEYXRlOiBEYXRlID0gbmV3IERhdGUodmFsdWUpO1xuICAgICAgICAgICAgaWYgKCFOdW1iZXIuaXNOYU4oc3RyaW5nRGF0ZS5nZXRUaW1lKCkpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHN0cmluZ0RhdGUuZ2V0VGltZSgpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgY29uc3QgbnVtYmVyOiBudW1iZXIgPSBOdW1iZXIucGFyc2VGbG9hdCh2YWx1ZSk7XG4gICAgICAgICAgICBpZiAoIU51bWJlci5pc05hTihudW1iZXIpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIG51bWJlcjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgY2FzZSAnbnVtYmVyJzpcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgY2FzZSAnb2JqZWN0JzpcbiAgICAgICAgICAgIGNvbnN0IGRhdGU6IERhdGUgPSBuZXcgRGF0ZSh2YWx1ZSk7XG4gICAgICAgICAgICByZXR1cm4gZGF0ZS5nZXRUaW1lKCk7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYFVuc3VwcG9ydGVkIHR5cGUgZm9yIHRhYmxlIHZhbHVlOiAke3R5cGVvZiB2YWx1ZX1gKTtcbiAgICB9XG59Il19
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sdW1uLXZhbHVlLXRvLXNvcnQtdmFsdWUuZnVuY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9mdW5jdGlvbnMvdGFibGUtY29sdW1uLXZhbHVlLXRvLXNvcnQtdmFsdWUuZnVuY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7Ozs7OztHQU1HO0FBQ0gsTUFBTSxVQUFVLDJCQUEyQixDQUFDLEtBQXVCO0lBQy9ELFFBQVEsT0FBTyxLQUFLLEVBQUUsQ0FBQztRQUNuQixLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDWixNQUFNLFVBQVUsR0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUN6QyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDO2dCQUN0QyxPQUFPLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQyxDQUFDO1lBQ0QsTUFBTSxNQUFNLEdBQVcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNoRCxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO2dCQUN4QixPQUFPLE1BQU0sQ0FBQztZQUNsQixDQUFDO1lBQ0QsT0FBTyxLQUFLLENBQUM7UUFDakIsQ0FBQztRQUNELEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQztZQUNaLE9BQU8sS0FBSyxDQUFDO1FBQ2pCLENBQUM7UUFDRCxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDWixNQUFNLElBQUksR0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNuQyxPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUMxQixDQUFDO1FBQ0QsT0FBTyxDQUFDLENBQUMsQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMscUNBQXFDLE9BQU8sS0FBSyxFQUFFLENBQUMsQ0FBQztRQUN6RSxDQUFDO0lBQ0wsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUYWJsZUNvbHVtblZhbHVlIH0gZnJvbSAnLi4vY29tcG9uZW50cy90YWJsZS90YWJsZS1kYXRhJztcblxuLyoqXG4gKiBDb252ZXJ0cyB0aGUgZ2l2ZW4gdGFibGUgY29sdW1uIHZhbHVlIHRvIGEgc3RyaW5nL251bWJlciBmb3Igc29ydGluZy5cbiAqIFRoaXMgYWxzbyBzdXBwb3J0cyBzdHJpbmcgZGF0ZXMsIGlmIHlvdSBlZy4gTmVlZGVkIHRvIGZvcm1hdCB0aGVtLlxuICogQHBhcmFtIHZhbHVlIC0gVGhlIHZhbHVlIHRvIGNvbnZlcnQuXG4gKiBAcmV0dXJucyBBIHN0cmluZyBvciBhIG51bWJlciB0byBzb3J0IGJ5LlxuICogQHRocm93cyBXaGVuIGEgdmFsdWUgd2l0aCBhbiB1bmtub3duIHR5cGUgaGFzIGJlZW4gcHJvdmlkZWQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB0YWJsZUNvbHVtblZhbHVlVG9Tb3J0VmFsdWUodmFsdWU6IFRhYmxlQ29sdW1uVmFsdWUpOiBzdHJpbmcgfCBudW1iZXIge1xuICAgIHN3aXRjaCAodHlwZW9mIHZhbHVlKSB7XG4gICAgICAgIGNhc2UgJ3N0cmluZyc6IHtcbiAgICAgICAgICAgIGNvbnN0IHN0cmluZ0RhdGU6IERhdGUgPSBuZXcgRGF0ZSh2YWx1ZSk7XG4gICAgICAgICAgICBpZiAoIU51bWJlci5pc05hTihzdHJpbmdEYXRlLmdldFRpbWUoKSkpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gc3RyaW5nRGF0ZS5nZXRUaW1lKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjb25zdCBudW1iZXI6IG51bWJlciA9IE51bWJlci5wYXJzZUZsb2F0KHZhbHVlKTtcbiAgICAgICAgICAgIGlmICghTnVtYmVyLmlzTmFOKG51bWJlcikpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gbnVtYmVyO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICB9XG4gICAgICAgIGNhc2UgJ251bWJlcic6IHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfVxuICAgICAgICBjYXNlICdvYmplY3QnOiB7XG4gICAgICAgICAgICBjb25zdCBkYXRlOiBEYXRlID0gbmV3IERhdGUodmFsdWUpO1xuICAgICAgICAgICAgcmV0dXJuIGRhdGUuZ2V0VGltZSgpO1xuICAgICAgICB9XG4gICAgICAgIGRlZmF1bHQ6IHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgVW5zdXBwb3J0ZWQgdHlwZSBmb3IgdGFibGUgdmFsdWU6ICR7dHlwZW9mIHZhbHVlfWApO1xuICAgICAgICB9XG4gICAgfVxufSJdfQ==
@@ -135,4 +135,4 @@ export class DateUtilities {
135
135
  || Number.isNaN(time.minutes);
136
136
  }
137
137
  }
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/utilities/date.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { DateFilterFn } from '@angular/material/datepicker';\n\nimport { DropdownValue } from '../decorators/base/dropdown-value.interface';\nimport { LodashUtilities } from '../encapsulation/lodash.utilities';\nimport { defaultTrue } from '../functions/default-true.function';\n\nconst DAY_IN_MS: number = 1000 * 60 * 60 * 24;\n\n/**\n * Helper type for hours and minutes.\n */\ntype Enumerate<N extends number, Acc extends number[] = []> = Acc['length'] extends N\n    ? Acc[number]\n    : Enumerate<N, [...Acc, Acc['length']]>;\n\n/**\n * Helper type for hours and minutes.\n */\ntype Range<F extends number, T extends number> = Exclude<Enumerate<T>, Enumerate<F>>;\n\n/**\n * The possible hour values. Ranges from 0 to 23.\n */\nexport type Hour = Range<0, 24>;\n\n/**\n * The possible minute values. Ranges from 0 to 59.\n */\nexport type Minute = Range<0, 60>;\n\n/**\n * Represents a time value with hours and minutes.\n */\nexport type Time = {\n    /**\n     * The hours in the 24 hour format.\n     */\n    hours: Hour,\n    /**\n     * The minutes of the time.\n     */\n    minutes: Minute\n};\n\n/**\n * Valid steps from one time value to the next. Needs to be able to divide 60 minutes without remainder.\n */\ntype MinuteSteps = 1 | 2 | 3 | 4 | 5 | 6 | 10 | 12 | 15 | 20 | 30 | 60;\n\n/**\n * Contains Helper Functions for handling date properties.\n */\nexport abstract class DateUtilities {\n\n    /**\n     * The default filter function to user when none was provided by the user.\n     */\n    static defaultDateFilter: DateFilterFn<Date | null | undefined> = defaultTrue;\n\n    /**\n     * Gets the given value as a date value.\n     * @param value - The value to get as a date.\n     * @returns The given value as a date.\n     */\n    static asDate(value: unknown): Date {\n        return value as Date;\n    }\n\n    /**\n     * Gets the default times used by the DateTime picker when nothing is specified by the user.\n     * @param format - The time format. Defaults to 24.\n     * @param minuteSteps - The steps from one time value to the next. Defaults to 30.\n     * @returns Times in the 24 hour format from 0:00 until 23:30 in 30 minute steps.\n     */\n    static getDefaultTimes(format: 12 | 24 = 24, minuteSteps: MinuteSteps = 30): DropdownValue<Time>[] {\n        const res: DropdownValue<Time>[] = [{ displayName: '-', value: undefined as unknown as Time }];\n        for (let hour: Hour = 0; hour < 24; hour++) {\n            for (let minute: Minute = 0; minute < 60; minute += minuteSteps) {\n                res.push(DateUtilities.getTimeDropdownValue(format, hour as Hour, minute as Minute));\n            }\n        }\n        return res;\n    }\n\n    private static getTimeDropdownValue(format: 12 | 24, hour: Hour, minute: Minute): DropdownValue<Time> {\n        const displayHour: number = DateUtilities.getFormattedHour(format, LodashUtilities.cloneDeep(hour));\n        const displayMinute: string = DateUtilities.getFormattedMinute(format, hour, minute);\n        return {\n            displayName: `${displayHour}:${displayMinute}`,\n            value: {\n                hours: hour,\n                minutes: minute\n            }\n        };\n    }\n\n    private static getFormattedHour(format: 12 | 24, hour: number): number {\n        if (format === 12 && hour > 12) {\n            hour -= 12;\n        }\n        return hour;\n    }\n\n    private static getFormattedMinute(format: 12 | 24, hour: number, minute: number): string {\n        let res: string = `${minute}`;\n        if (format === 12) {\n            res = hour > 12 ? `${minute} PM` : `${minute} AM`;\n        }\n        if (minute.toString().length === 1) {\n            res = '0'.concat(res);\n        }\n        return res;\n    }\n\n    /**\n     * Gets the Time object from the given date.\n     * @param value - The date to get the time object from.\n     * @returns The Time object build from the date value.\n     */\n    static getTimeFromDate(value?: Date): Time | undefined {\n        if (!value) {\n            return undefined;\n        }\n        return {\n            hours: new Date(value).getHours() as Hour,\n            minutes: new Date(value).getMinutes() as Minute\n        };\n    }\n\n    /**\n     * Gets the dates between the two given gates. Does additional filtering based on the provided DateRange metadata.\n     * @param startDate - The start date.\n     * @param endDate - The end date.\n     * @param filter - The custom filter from the metadata.\n     * @returns All dates between the two provided dates. Includes start and end date.\n     */\n    static getDatesBetween(startDate: Date, endDate: Date, filter?: DateFilterFn<Date>): Date[] {\n        const clonedStartDate: Date = new Date(startDate);\n        const res: Date[] = [];\n        while (\n            clonedStartDate.getFullYear() < endDate.getFullYear()\n            || clonedStartDate.getMonth() < endDate.getMonth()\n            || clonedStartDate.getDate() <= endDate.getDate()\n        ) {\n            res.push(new Date(clonedStartDate));\n            clonedStartDate.setTime(clonedStartDate.getTime() + DAY_IN_MS);\n        }\n        return filter ? res.filter(d => filter(d)) : res;\n    }\n\n    /**\n     * Get all valid times for the dropdown of a datetime property.\n     * @param times - All given times to filter.\n     * @param date - The date of the datetime.\n     * @param min - The function that defines the minimum time.\n     * @param max - The function that defines the maximum time.\n     * @param filter - A filter function to do more specific time filtering. This could be e.g. The removal of lunch breaks.\n     * @returns All valid dropdown values for the datetime property.\n     */\n    static getValidTimesForDropdown(\n        times: DropdownValue<Time | undefined>[],\n        date?: Date,\n        min?: (date?: Date) => Time,\n        max?: (date?: Date) => Time,\n        filter?: ((time: Time) => boolean) | (() => boolean)\n    ): DropdownValue<Time | undefined>[] {\n        if (min) {\n            const minTime: Time = min(date);\n            times = times.filter(t => !t.value\n            || t.value.hours > minTime.hours\n            || (\n                t.value.hours === minTime.hours\n                && t.value.minutes >= minTime.minutes\n            ));\n        }\n        if (max) {\n            const maxTime: Time = max(date);\n            times = times.filter(t => !t.value\n            || t.value.hours < maxTime.hours\n            || (\n                t.value.hours === maxTime.hours\n                && t.value.minutes <= maxTime.minutes\n            ));\n        }\n        if (filter) {\n            times = times.filter(t => !t.value || filter(t.value));\n        }\n\n        return times;\n    }\n\n    /**\n     * Checks if the time object has processable hours and minutes properties.\n     * Doesn't check custom validators like min/max from the metadata configuration.\n     * @param time - The time to check.\n     * @returns Whether or not the time object is unprocessable.\n     */\n    static timeIsUnprocessable(time?: Time): boolean {\n        return time?.hours == undefined\n            || typeof time.hours !== 'number'\n            || Number.isNaN(time.hours)\n            || time.minutes == undefined\n            || typeof time.minutes !== 'number'\n            || Number.isNaN(time.minutes);\n    }\n}"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/utilities/date.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { DateFilterFn } from '@angular/material/datepicker';\n\nimport { DropdownValue } from '../decorators/base/dropdown-value.interface';\nimport { LodashUtilities } from '../encapsulation/lodash.utilities';\nimport { defaultTrue } from '../functions/default-true.function';\n\nconst DAY_IN_MS: number = 1000 * 60 * 60 * 24;\n\n/**\n * Helper type for hours and minutes.\n */\ntype Enumerate<N extends number, Acc extends number[] = []> = Acc['length'] extends N\n    ? Acc[number]\n    : Enumerate<N, [...Acc, Acc['length']]>;\n\n/**\n * Helper type for hours and minutes.\n */\ntype Range<F extends number, T extends number> = Exclude<Enumerate<T>, Enumerate<F>>;\n\n/**\n * The possible hour values. Ranges from 0 to 23.\n */\nexport type Hour = Range<0, 24>;\n\n/**\n * The possible minute values. Ranges from 0 to 59.\n */\nexport type Minute = Range<0, 60>;\n\n/**\n * Represents a time value with hours and minutes.\n */\nexport type Time = {\n    /**\n     * The hours in the 24 hour format.\n     */\n    hours: Hour,\n    /**\n     * The minutes of the time.\n     */\n    minutes: Minute\n};\n\n/**\n * Valid steps from one time value to the next. Needs to be able to divide 60 minutes without remainder.\n */\ntype MinuteSteps = 1 | 2 | 3 | 4 | 5 | 6 | 10 | 12 | 15 | 20 | 30 | 60;\n\n/**\n * Contains Helper Functions for handling date properties.\n */\nexport abstract class DateUtilities {\n\n    /**\n     * The default filter function to user when none was provided by the user.\n     */\n    static defaultDateFilter: DateFilterFn<Date | null | undefined> = defaultTrue;\n\n    /**\n     * Gets the given value as a date value.\n     * @param value - The value to get as a date.\n     * @returns The given value as a date.\n     */\n    static asDate(value: unknown): Date {\n        return value as Date;\n    }\n\n    /**\n     * Gets the default times used by the DateTime picker when nothing is specified by the user.\n     * @param format - The time format. Defaults to 24.\n     * @param minuteSteps - The steps from one time value to the next. Defaults to 30.\n     * @returns Times in the 24 hour format from 0:00 until 23:30 in 30 minute steps.\n     */\n    static getDefaultTimes(format: 12 | 24 = 24, minuteSteps: MinuteSteps = 30): DropdownValue<Time>[] {\n        const res: DropdownValue<Time>[] = [{ displayName: '-', value: undefined as unknown as Time }];\n        for (let hour: Hour = 0; hour < 24; hour++) {\n            for (let minute: Minute = 0; minute < 60; minute += minuteSteps) {\n                res.push(DateUtilities.getTimeDropdownValue(format, hour as Hour, minute as Minute));\n            }\n        }\n        return res;\n    }\n\n    private static getTimeDropdownValue(format: 12 | 24, hour: Hour, minute: Minute): DropdownValue<Time> {\n        const displayHour: number = DateUtilities.getFormattedHour(format, LodashUtilities.cloneDeep(hour));\n        const displayMinute: string = DateUtilities.getFormattedMinute(format, hour, minute);\n        return {\n            displayName: `${displayHour}:${displayMinute}`,\n            value: {\n                hours: hour,\n                minutes: minute\n            }\n        };\n    }\n\n    private static getFormattedHour(format: 12 | 24, hour: number): number {\n        if (format === 12 && hour > 12) {\n            hour -= 12;\n        }\n        return hour;\n    }\n\n    private static getFormattedMinute(format: 12 | 24, hour: number, minute: number): string {\n        let res: string = `${minute}`;\n        if (format === 12) {\n            res = hour > 12 ? `${minute} PM` : `${minute} AM`;\n        }\n        if (minute.toString().length === 1) {\n            res = '0'.concat(res);\n        }\n        return res;\n    }\n\n    /**\n     * Gets the Time object from the given date.\n     * @param value - The date to get the time object from.\n     * @returns The Time object build from the date value.\n     */\n    static getTimeFromDate(value?: Date): Time | undefined {\n        if (!value) {\n            return undefined;\n        }\n        return {\n            hours: new Date(value).getHours() as Hour,\n            minutes: new Date(value).getMinutes() as Minute\n        };\n    }\n\n    /**\n     * Gets the dates between the two given gates. Does additional filtering based on the provided DateRange metadata.\n     * @param startDate - The start date.\n     * @param endDate - The end date.\n     * @param filter - The custom filter from the metadata.\n     * @returns All dates between the two provided dates. Includes start and end date.\n     */\n    static getDatesBetween(startDate: Date, endDate: Date, filter?: DateFilterFn<Date>): Date[] {\n        const clonedStartDate: Date = new Date(startDate);\n        const res: Date[] = [];\n        while (\n            clonedStartDate.getFullYear() < endDate.getFullYear()\n            || clonedStartDate.getMonth() < endDate.getMonth()\n            || clonedStartDate.getDate() <= endDate.getDate()\n        ) {\n            res.push(new Date(clonedStartDate));\n            clonedStartDate.setTime(clonedStartDate.getTime() + DAY_IN_MS);\n        }\n        return filter ? res.filter(d => filter(d)) : res;\n    }\n\n    /**\n     * Get all valid times for the dropdown of a datetime property.\n     * @param times - All given times to filter.\n     * @param date - The date of the datetime.\n     * @param min - The function that defines the minimum time.\n     * @param max - The function that defines the maximum time.\n     * @param filter - A filter function to do more specific time filtering. This could be e.g. The removal of lunch breaks.\n     * @returns All valid dropdown values for the datetime property.\n     */\n    static getValidTimesForDropdown(\n        times: DropdownValue<Time | undefined>[],\n        date?: Date,\n        min?: (date?: Date) => Time,\n        max?: (date?: Date) => Time,\n        filter?: ((time: Time) => boolean) | (() => boolean)\n    ): DropdownValue<Time | undefined>[] {\n        if (min) {\n            const minTime: Time = min(date);\n            times = times.filter(t => !t.value\n                || t.value.hours > minTime.hours\n                || (\n                    t.value.hours === minTime.hours\n                    && t.value.minutes >= minTime.minutes\n                ));\n        }\n        if (max) {\n            const maxTime: Time = max(date);\n            times = times.filter(t => !t.value\n                || t.value.hours < maxTime.hours\n                || (\n                    t.value.hours === maxTime.hours\n                    && t.value.minutes <= maxTime.minutes\n                ));\n        }\n        if (filter) {\n            times = times.filter(t => !t.value || filter(t.value));\n        }\n\n        return times;\n    }\n\n    /**\n     * Checks if the time object has processable hours and minutes properties.\n     * Doesn't check custom validators like min/max from the metadata configuration.\n     * @param time - The time to check.\n     * @returns Whether or not the time object is unprocessable.\n     */\n    static timeIsUnprocessable(time?: Time): boolean {\n        return time?.hours == undefined\n            || typeof time.hours !== 'number'\n            || Number.isNaN(time.hours)\n            || time.minutes == undefined\n            || typeof time.minutes !== 'number'\n            || Number.isNaN(time.minutes);\n    }\n}"]}
@@ -86,17 +86,20 @@ export class EntityUtilities {
86
86
  const type = this.getPropertyType(entity, key);
87
87
  if (!await this.isEqual(entity[key], entityPriorChanges[key], metadata, type, http)) {
88
88
  switch (type) {
89
- case DecoratorTypes.OBJECT:
89
+ case DecoratorTypes.OBJECT: {
90
90
  // eslint-disable-next-line typescript/no-explicit-any
91
91
  res[key] = LodashUtilities.omit(entity[key], this.getOmitForCreate(entity[key]));
92
92
  break;
93
- case DecoratorTypes.ARRAY:
93
+ }
94
+ case DecoratorTypes.ARRAY: {
94
95
  res[key] = entity[key]
95
96
  .map(value => LodashUtilities.omit(value, this.getOmitForCreate(value)));
96
97
  break;
97
- default:
98
+ }
99
+ default: {
98
100
  res[key] = entity[key];
99
101
  break;
102
+ }
100
103
  }
101
104
  }
102
105
  }
@@ -175,14 +178,15 @@ export class EntityUtilities {
175
178
  const type = this.getPropertyType(target, key);
176
179
  let value = entity ? ReflectUtilities.get(entity, key) : undefined;
177
180
  switch (type) {
178
- case DecoratorTypes.OBJECT:
181
+ case DecoratorTypes.OBJECT: {
179
182
  // eslint-disable-next-line typescript/no-explicit-any
180
183
  const objectMetadata
181
184
  // eslint-disable-next-line typescript/no-explicit-any
182
185
  = this.getPropertyMetadata(target, key, DecoratorTypes.OBJECT);
183
186
  value = new objectMetadata.EntityClass(value);
184
187
  break;
185
- case DecoratorTypes.ARRAY:
188
+ }
189
+ case DecoratorTypes.ARRAY: {
186
190
  const inputArray = value;
187
191
  const resArray = [];
188
192
  if (inputArray) {
@@ -197,8 +201,10 @@ export class EntityUtilities {
197
201
  }
198
202
  value = resArray;
199
203
  break;
200
- default:
204
+ }
205
+ default: {
201
206
  break;
207
+ }
202
208
  }
203
209
  ReflectUtilities.set(target, key, value);
204
210
  }
@@ -267,28 +273,37 @@ export class EntityUtilities {
267
273
  return true;
268
274
  }
269
275
  switch (type) {
270
- case DecoratorTypes.DATE_RANGE:
276
+ case DecoratorTypes.DATE_RANGE: {
271
277
  return this.isEqualDateRange(value, valuePriorChanges, metadata.filter);
272
- case DecoratorTypes.DATE:
278
+ }
279
+ case DecoratorTypes.DATE: {
273
280
  return this.isEqualDate(value, valuePriorChanges);
274
- case DecoratorTypes.DATE_TIME:
281
+ }
282
+ case DecoratorTypes.DATE_TIME: {
275
283
  return this.isEqualDateTime(value, valuePriorChanges);
284
+ }
276
285
  case DecoratorTypes.ARRAY_DATE:
277
- case DecoratorTypes.ARRAY_DATE_TIME:
286
+ case DecoratorTypes.ARRAY_DATE_TIME: {
278
287
  return this.isEqualArrayDate(value, valuePriorChanges);
279
- case DecoratorTypes.ARRAY_DATE_RANGE:
288
+ }
289
+ case DecoratorTypes.ARRAY_DATE_RANGE: {
280
290
  return this.isEqualArrayDateRange(value, valuePriorChanges, metadata.filter);
291
+ }
281
292
  case DecoratorTypes.ARRAY_STRING_CHIPS:
282
- case DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS:
293
+ case DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS: {
283
294
  return this.isEqualArrayString(value, valuePriorChanges);
295
+ }
284
296
  case DecoratorTypes.FILE_IMAGE:
285
- case DecoratorTypes.FILE_DEFAULT:
297
+ case DecoratorTypes.FILE_DEFAULT: {
286
298
  return this.isEqualFile(value, valuePriorChanges, metadata.multiple, http);
287
- case DecoratorTypes.CUSTOM:
299
+ }
300
+ case DecoratorTypes.CUSTOM: {
288
301
  // eslint-disable-next-line typescript/no-explicit-any
289
302
  return this.isEqualCustom(value, valuePriorChanges, metadata);
290
- default:
303
+ }
304
+ default: {
291
305
  return LodashUtilities.isEqual(value, valuePriorChanges);
306
+ }
292
307
  }
293
308
  }
294
309
  static differenceIsUndefinedAndEmptyString(value, valuePriorChanges) {
@@ -442,10 +457,10 @@ export class EntityUtilities {
442
457
  return metadataA.position.order - metadataB.position.order;
443
458
  }
444
459
  /**
445
- * Gets the bootstrap column classes for "lg", "md" and "sm".
446
- * @param entity - Entity to get the bootstrap column values of the key.
447
- * @param key - Key of the property to get bootstrap column values from.
448
- * @returns Bootstrap column classes.
460
+ * Gets the responsive column classes for "lg", "md" and "sm".
461
+ * @param entity - Entity to get the responsive column classes for.
462
+ * @param key - Key of the property to get the responsive column classes from.
463
+ * @returns Responsive column classes for large, middle and small displays.
449
464
  * @throws When no metadata for the given key was found.
450
465
  */
451
466
  static getWidthClasses(entity, key) {
@@ -453,7 +468,7 @@ export class EntityUtilities {
453
468
  if (!metadata) {
454
469
  throw new Error(`Could not get metadata for property "${key.toString()}"`);
455
470
  }
456
- return `col-lg-${metadata.defaultWidths[0]} col-md-${metadata.defaultWidths[1]} col-sm-${metadata.defaultWidths[2]}`;
471
+ return `lg:col-span-${metadata.defaultWidths[0]} md:col-span-${metadata.defaultWidths[1]} col-span-${metadata.defaultWidths[2]}`;
457
472
  }
458
473
  /**
459
474
  * Resets all changes on an entity.
@@ -593,4 +608,4 @@ export class EntityUtilities {
593
608
  return res;
594
609
  }
595
610
  }
596
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/utilities/entity.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { EnvironmentInjector, runInInjectionContext } from '@angular/core';\nimport { DateFilterFn } from '@angular/material/datepicker';\n\nimport { DateUtilities } from './date.utilities';\nimport { FileUtilities } from './file.utilities';\nimport { BaseEntityType } from '../classes/entity.model';\nimport { DateRangeArrayDecoratorConfigInternal, EntityArrayDecoratorConfigInternal } from '../decorators/array/array-decorator-internal.data';\nimport { DecoratorType, DecoratorTypes } from '../decorators/base/decorator-types.enum';\nimport { PropertyDecoratorConfigInternal } from '../decorators/base/property-decorator-internal.data';\nimport { CustomDecoratorConfigInternal } from '../decorators/custom/custom-decorator-internal.data';\nimport { DateRangeDateDecoratorConfigInternal } from '../decorators/date/date-decorator-internal.data';\nimport { DateRange } from '../decorators/date/date-decorator.data';\nimport { DefaultFileDecoratorConfigInternal } from '../decorators/file/file-decorator-internal.data';\nimport { FileData } from '../decorators/file/file-decorator.data';\nimport { DefaultObjectDecoratorConfigInternal } from '../decorators/object/object-decorator-internal.data';\nimport { LodashUtilities } from '../encapsulation/lodash.utilities';\nimport { ReflectUtilities } from '../encapsulation/reflect.utilities';\n\n/**\n * Shows information about differences between two entities.\n */\nexport interface Difference<EntityType extends BaseEntityType<EntityType>> {\n    /**\n     * The key where the two entities have different values.\n     */\n    key: keyof EntityType,\n    /**\n     * The value before any changes.\n     */\n    before: unknown,\n    /**\n     * The current value after changes.\n     */\n    after: unknown\n}\n\n/**\n * Contains HelperMethods around handling Entities and their property-metadata.\n */\nexport abstract class EntityUtilities {\n\n    /**\n     * The key for all keys of metadata that should be set to undefined when the entity gets reset.\n     */\n    static readonly METADATA_KEYS_TO_RESET_KEY: string = 'metadataKeysToReset';\n\n    /**\n     * The key for the metadata that saves the single preview image value on image properties.\n     */\n    static readonly SINGLE_PREVIEW_IMAGE_KEY: string = 'singlePreviewImage';\n\n    /**\n     * The key for the metadata that saves the multi preview images value on image properties.\n     */\n    static readonly MULTI_PREVIEW_IMAGES_KEY: string = 'multiPreviewImages';\n\n    /**\n     * The key for the metadata that saves the filenames value on file properties.\n     */\n    static readonly FILENAMES_KEY: string = 'fileNames';\n\n    /**\n     * The key for the metadata that saves the confirm password value on password properties.\n     */\n    static readonly CONFIRM_PASSWORD_KEY: string = 'confirmPassword';\n\n    /**\n     * The key for the metadata that saves the time value on date time properties.\n     */\n    static readonly TIME_KEY: string = 'time';\n\n    /**\n     * Gets the properties to omit when updating the entity.\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 BaseEntityType<EntityType>>(entity: EntityType): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key in entity) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            if (!metadata || metadata.omitForUpdate) {\n                res.push(key);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Gets the properties to omit when creating new entities.\n     * @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 BaseEntityType<EntityType>>(entity: EntityType): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key in entity) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            if (!metadata || metadata.omitForCreate) {\n                res.push(key);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Returns the given entity without the values that should be omitted for creation.\n     * @param entity - The entity with all its values.\n     * @returns The reduced entity object.\n     */\n    static getWithoutOmitCreateValues<EntityType extends BaseEntityType<EntityType>>(entity: EntityType): Partial<EntityType> {\n        return LodashUtilities.omit(entity, this.getOmitForCreate(entity)) as Partial<EntityType>;\n    }\n\n    /**\n     * Returns the given entity without the values that should be omitted for updating.\n     * This also handles omitting keys for @object or @array values and removes values that haven't been changed by default.\n     * @param entity - The entity with all its values.\n     * @param entityPriorChanges - The entity before any changes were applied.\n     * @param http - The angular HttpClient. Used to fetch files.\n     * @param injector - An angular environment injector.\n     * @returns The reduced entity object.\n     */\n    static async getWithoutOmitUpdateValues<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        entityPriorChanges: EntityType,\n        http: HttpClient,\n        injector: EnvironmentInjector\n    ): Promise<Partial<EntityType>> {\n        const res: Partial<EntityType> = {};\n        for (const key of this.keysOf(entity, injector, false, true)) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            const type: DecoratorTypes | undefined = this.getPropertyType(entity, key);\n            if (!await this.isEqual(entity[key], entityPriorChanges[key], metadata, type, http)) {\n                switch (type) {\n                    case DecoratorTypes.OBJECT:\n                        // eslint-disable-next-line typescript/no-explicit-any\n                        (res[key] as object) = LodashUtilities.omit(entity[key] as any, this.getOmitForCreate(entity[key]));\n                        break;\n                    case DecoratorTypes.ARRAY:\n                        (res[key] as object[]) = (entity[key] as object[])\n                            .map(value => LodashUtilities.omit(value, this.getOmitForCreate(value)));\n                        break;\n                    default:\n                        res[key] = entity[key];\n                        break;\n                }\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Sets all default values on the given entity.\n     * @param entity - The entity to set the default values on.\n     */\n    static setDefaultValues<EntityType extends BaseEntityType<EntityType>>(entity: EntityType): void {\n        for (const key in entity) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            if (metadata?.default) {\n                // eslint-disable-next-line typescript/no-unsafe-assignment, typescript/no-explicit-any\n                entity[key] = metadata.default() as any;\n            }\n        }\n    }\n\n    /**\n     * Gets all properties on the given entity which are files.\n     * @param entity - The entity to check for file properties.\n     * @param omit - Whether to leave out values that are omitted for create or delete.\n     * @returns The keys of all file properties on the given entity.\n     */\n    static getFileProperties<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        omit?: 'create' | 'update'\n    ): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key in entity) {\n            const type: DecoratorTypes | undefined = this.getPropertyType(entity, key);\n            if (type === DecoratorTypes.FILE_DEFAULT || type === DecoratorTypes.FILE_IMAGE) {\n                // eslint-disable-next-line stylistic/max-len\n                const metadata: PropertyDecoratorConfigInternal<unknown> = this.getPropertyMetadata(entity, key) as PropertyDecoratorConfigInternal<unknown>;\n                if (!(metadata.omitForCreate && omit === 'create') && !(metadata.omitForUpdate && omit === 'update')) {\n                    res.push(key);\n                }\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     * @throws When no metadata can be found for the given property.\n     */\n    static getPropertyMetadata<\n        EntityType extends BaseEntityType<EntityType>,\n        T extends DecoratorTypes,\n        CustomMetadataType extends Record<string, unknown>\n    >(\n        entity: EntityType,\n        propertyKey: keyof EntityType,\n        // eslint-disable-next-line unusedImports/no-unused-vars\n        type?: T\n    ): DecoratorType<T, CustomMetadataType> | undefined {\n        const metadata: unknown = ReflectUtilities.getMetadata('metadata', entity, propertyKey);\n        // if (metadata == null) {\n        //     throw new Error(`Could not find metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`);\n        // }\n        return metadata as DecoratorType<T, CustomMetadataType> | undefined;\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     * @throws Will throw an error if no metadata can be found for the given property.\n     */\n    static getPropertyType<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType, propertyKey: keyof EntityType\n    ): DecoratorTypes | undefined {\n        return ReflectUtilities.getMetadata('type', entity, propertyKey) as DecoratorTypes | undefined;\n    }\n\n    /**\n     * Sets all property values based on a given entity data-object.\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 BaseEntityType<EntityType>>(target: EntityType, entity?: EntityType): void {\n        for (const key in target) {\n            const type: DecoratorTypes | undefined = this.getPropertyType(target, key);\n            let value: unknown = entity ? ReflectUtilities.get(entity, key) : undefined;\n            switch (type) {\n                case DecoratorTypes.OBJECT:\n                    // eslint-disable-next-line typescript/no-explicit-any\n                    const objectMetadata: DefaultObjectDecoratorConfigInternal<any>\n                        // eslint-disable-next-line typescript/no-explicit-any\n                        = this.getPropertyMetadata(target, key, DecoratorTypes.OBJECT) as DefaultObjectDecoratorConfigInternal<any>;\n                    value = new objectMetadata.EntityClass(value as object | undefined);\n                    break;\n                case DecoratorTypes.ARRAY:\n                    const inputArray: EntityType[] | undefined = value as EntityType[] | undefined;\n                    const resArray: EntityType[] = [];\n                    if (inputArray) {\n                        // eslint-disable-next-line typescript/no-explicit-any\n                        const arrayMetadata: EntityArrayDecoratorConfigInternal<any>\n                            // eslint-disable-next-line typescript/no-explicit-any\n                            = this.getPropertyMetadata(target, key, DecoratorTypes.ARRAY) as EntityArrayDecoratorConfigInternal<any>;\n                        for (const item of inputArray) {\n                            const itemWithMetadata: EntityType = new arrayMetadata.EntityClass(item) as EntityType;\n                            resArray.push(itemWithMetadata);\n                        }\n                    }\n                    value = resArray;\n                    break;\n                default:\n                    break;\n            }\n            ReflectUtilities.set(target, key, value);\n        }\n    }\n    // eslint-disable-next-line typescript/member-ordering, jsdoc/require-jsdoc, typescript/typedef\n    static construct = this.new;\n    // eslint-disable-next-line typescript/member-ordering, jsdoc/require-jsdoc, typescript/typedef\n    static build = this.new;\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     * @param http - The angular HttpClient. Used to fetch files.\n     * @param injector - An angular environment injector.\n     * @returns Whether or not the entity is dirty.\n     */\n    static async isDirty<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        entityPriorChanges: EntityType,\n        http: HttpClient,\n        injector: EnvironmentInjector\n    ): Promise<boolean> {\n        if (!(entityPriorChanges as EntityType | undefined)) {\n            return false;\n        }\n        const differences: Difference<EntityType>[] = await this.getDifferencesBetweenEntities(entity, entityPriorChanges, http, injector);\n        return !!differences.length;\n    }\n\n    /**\n     * Gets the differences between the two given entities. Only checks properties which are decorated.\n     * @param entity - The entity as is.\n     * @param entityPriorChanges - The entity before any changes have been made.\n     * @param http - The angular http client, is needed to check if files are equal.\n     * @param injector - An angular environment injector.\n     * @returns The differences as an array consisting of key, before and after.\n     */\n    static async getDifferencesBetweenEntities<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        entityPriorChanges: EntityType,\n        http: HttpClient,\n        injector: EnvironmentInjector\n    ): Promise<Difference<EntityType>[]> {\n        const res: Difference<EntityType>[] = [];\n        // values that are not decorated can be ignored, as they are not transferred via http.\n        for (const key of this.keysOf(entity, injector)) {\n            const type: DecoratorTypes | undefined = this.getPropertyType(entity, key);\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            if (!await this.isEqual(entity[key], entityPriorChanges[key], metadata, type, http)) {\n                res.push({\n                    key: key,\n                    before: entityPriorChanges[key],\n                    after: entity[key]\n                });\n            }\n            else {\n                // This is needed to set blob file data so that it is only requested once.\n                entityPriorChanges[key] = LodashUtilities.cloneDeep(entity[key]);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Checks if two given values are equal.\n     * It uses the isEqual method from LodashUtilities and extends it with functionality regarding Dates.\n     * @param value - The updated value.\n     * @param valuePriorChanges - The value before any changes.\n     * @param metadata - The metadata of the property.\n     * @param type - The type of the property.\n     * @param http - The angular HttpClient. Used to fetch files.\n     * @returns Whether or not the given values are equal.\n     */\n    static async isEqual(\n        value: unknown,\n        valuePriorChanges: unknown,\n        metadata: PropertyDecoratorConfigInternal<unknown> | undefined,\n        type: DecoratorTypes | undefined,\n        http: HttpClient\n    ): Promise<boolean> {\n        if ((value == undefined && valuePriorChanges == undefined)\n            || this.differenceIsUndefinedAndEmptyArray(value, valuePriorChanges)\n            || this.differenceIsUndefinedAndEmptyString(value, valuePriorChanges)\n        ) {\n            return true;\n        }\n        switch (type) {\n            case DecoratorTypes.DATE_RANGE:\n                return this.isEqualDateRange(\n                    value,\n                    valuePriorChanges,\n                    (metadata as DateRangeDateDecoratorConfigInternal).filter\n                );\n            case DecoratorTypes.DATE:\n                return this.isEqualDate(value, valuePriorChanges);\n            case DecoratorTypes.DATE_TIME:\n                return this.isEqualDateTime(value, valuePriorChanges);\n            case DecoratorTypes.ARRAY_DATE:\n            case DecoratorTypes.ARRAY_DATE_TIME:\n                return this.isEqualArrayDate(value, valuePriorChanges);\n            case DecoratorTypes.ARRAY_DATE_RANGE:\n                return this.isEqualArrayDateRange(\n                    value,\n                    valuePriorChanges,\n                    (metadata as DateRangeArrayDecoratorConfigInternal).filter\n                );\n            case DecoratorTypes.ARRAY_STRING_CHIPS:\n            case DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS:\n                return this.isEqualArrayString(value, valuePriorChanges);\n            case DecoratorTypes.FILE_IMAGE:\n            case DecoratorTypes.FILE_DEFAULT:\n                return this.isEqualFile(value, valuePriorChanges, (metadata as DefaultFileDecoratorConfigInternal).multiple, http);\n            case DecoratorTypes.CUSTOM:\n                // eslint-disable-next-line typescript/no-explicit-any\n                return this.isEqualCustom(value, valuePriorChanges, metadata as CustomDecoratorConfigInternal<any, any, any, any>);\n            default:\n                return LodashUtilities.isEqual(value, valuePriorChanges);\n        }\n    }\n\n    private static differenceIsUndefinedAndEmptyString(value: unknown, valuePriorChanges: unknown): boolean {\n        return (valuePriorChanges == undefined && typeof value === 'string' && !value.length)\n            || (value == undefined && typeof valuePriorChanges === 'string' && !valuePriorChanges.length);\n    }\n\n    private static differenceIsUndefinedAndEmptyArray(value: unknown, valuePriorChanges: unknown): boolean {\n        return (valuePriorChanges == undefined && Array.isArray(value) && !value.length)\n            || (value == undefined && Array.isArray(valuePriorChanges) && !valuePriorChanges.length);\n    }\n\n    private static isEqualArrayString(value: unknown, valuePriorChanges: unknown): boolean | PromiseLike<boolean> {\n        let stringArray: string[] | undefined = LodashUtilities.cloneDeep(value as string[] | undefined);\n        if (stringArray) {\n            stringArray = stringArray.sort();\n        }\n        let stringArrayPriorChanges: string[] | undefined = LodashUtilities.cloneDeep(valuePriorChanges as string[] | undefined);\n        if (stringArrayPriorChanges) {\n            stringArrayPriorChanges = stringArrayPriorChanges.sort();\n        }\n        return LodashUtilities.isEqual(stringArray, stringArrayPriorChanges);\n    }\n\n    private static isEqualArrayDate(value: unknown, valuePriorChanges: unknown): boolean {\n        let newValue: Date[] | undefined = LodashUtilities.cloneDeep(value as Date[] | undefined);\n        if (newValue) {\n            newValue = newValue.map(v => new Date(v)).sort();\n        }\n        let newValuePriorChanges: Date[] | undefined = LodashUtilities.cloneDeep(valuePriorChanges as Date[] | undefined);\n        if (newValuePriorChanges) {\n            newValuePriorChanges = newValuePriorChanges.map(v => new Date(v)).sort();\n        }\n        return LodashUtilities.isEqual(newValue, newValuePriorChanges);\n    }\n\n    private static isEqualArrayDateRange(value: unknown, valuePriorChanges: unknown, filter?: DateFilterFn<Date>): boolean {\n        let dateRanges: DateRange[] | undefined = LodashUtilities.cloneDeep(value as DateRange[] | undefined);\n        if (dateRanges) {\n            dateRanges = dateRanges.sort();\n        }\n        let dateRangesPriorChanges: DateRange[] | undefined = LodashUtilities.cloneDeep(valuePriorChanges as DateRange[] | undefined);\n        if (dateRangesPriorChanges) {\n            dateRangesPriorChanges = dateRangesPriorChanges.sort();\n        }\n        if (dateRanges?.length !== dateRangesPriorChanges?.length) {\n            return false;\n        }\n        if (dateRanges?.length) {\n            for (let i: number = 0; i < dateRanges?.length; i++) {\n                if (!this.isEqualDateRange(dateRanges?.[i], dateRangesPriorChanges?.[i], filter)) {\n                    return false;\n                }\n            }\n        }\n        return true;\n    }\n\n    private static isEqualDateTime(value: unknown, valuePriorChanges: unknown): boolean {\n        const date: Date = new Date(value as Date);\n        const datePriorChanges: Date = new Date(valuePriorChanges as Date);\n        return LodashUtilities.isEqual(date, datePriorChanges);\n    }\n\n    private static isEqualDate(value: unknown, valuePriorChanges: unknown): boolean {\n        const date: Date = new Date(value as Date);\n        const datePriorChanges: Date = new Date(valuePriorChanges as Date);\n        date.setHours(0, 0, 0, 0);\n        datePriorChanges.setHours(0, 0, 0, 0);\n        return LodashUtilities.isEqual(date, datePriorChanges);\n    }\n\n    private static isEqualDateRange(value: unknown, valuePriorChanges: unknown, filter?: DateFilterFn<Date>): boolean {\n        const dateRange: Partial<DateRange> | undefined = LodashUtilities.cloneDeep(value) as Partial<DateRange> | undefined;\n        if (dateRange?.start) {\n            dateRange.start = new Date(dateRange.start);\n        }\n        if (dateRange?.end) {\n            dateRange.end = new Date(dateRange.end);\n        }\n        if (dateRange?.start && dateRange.end) {\n            dateRange.values = DateUtilities.getDatesBetween(\n                dateRange.start,\n                dateRange.end,\n                filter\n            );\n        }\n        // eslint-disable-next-line stylistic/max-len\n        const dateRangePriorChanges: Partial<DateRange> | undefined = LodashUtilities.cloneDeep(valuePriorChanges) as Partial<DateRange> | undefined;\n        if (dateRangePriorChanges?.start) {\n            dateRangePriorChanges.start = new Date(dateRangePriorChanges.start);\n        }\n        if (dateRangePriorChanges?.end) {\n            dateRangePriorChanges.end = new Date(dateRangePriorChanges.end);\n        }\n        if (dateRangePriorChanges?.start && dateRangePriorChanges.end) {\n            dateRangePriorChanges.values = DateUtilities.getDatesBetween(\n                dateRangePriorChanges.start,\n                dateRangePriorChanges.end,\n                filter\n            );\n        }\n        return LodashUtilities.isEqual(dateRange, dateRangePriorChanges);\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    // eslint-disable-next-line sonar/cognitive-complexity\n    private static async isEqualFile(value: unknown, valuePriorChanges: unknown, multiple: boolean, http: HttpClient): Promise<boolean> {\n        if (value == undefined) {\n            return valuePriorChanges == undefined;\n        }\n        if (valuePriorChanges == undefined) {\n            return false;\n        }\n        const files: FileData[] = multiple ? (value as FileData[]).sort() : [value as FileData].sort();\n        const filesPriorChanges: FileData[] = multiple ? (valuePriorChanges as FileData[]).sort() : [valuePriorChanges as FileData].sort();\n        if (files.length !== filesPriorChanges.length) {\n            return false;\n        }\n        for (let i: number = 0; i < files.length; i++) {\n            // checks this before actually getting any files due to performance reasons.\n            if (!LodashUtilities.isEqual(LodashUtilities.omit(files[i], 'file'), LodashUtilities.omit(filesPriorChanges[i], 'file'))) {\n                return false;\n            }\n            if (filesPriorChanges[i].file && !files[i].file) {\n                files[i] = await FileUtilities.getFileData(files[i], http);\n                value = files[i];\n            }\n            if (files[i].file && !filesPriorChanges[i].file) {\n                filesPriorChanges[i] = await FileUtilities.getFileData(filesPriorChanges[i], http);\n                valuePriorChanges = filesPriorChanges[i];\n            }\n            if (!LodashUtilities.isEqual(await files[i].file?.text(), await filesPriorChanges[i].file?.text())) {\n                return false;\n            }\n        }\n        return true;\n    }\n\n    private static isEqualCustom(\n        value: unknown,\n        valuePriorChanges: unknown,\n        // eslint-disable-next-line typescript/no-explicit-any\n        metadata: CustomDecoratorConfigInternal<any, any, any, any>\n    ): boolean {\n        return metadata.isEqual(value, valuePriorChanges, metadata);\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     * @returns 0 if both values have the same order, a negative value if 'a' comes before 'b', a positive value if 'a' comes behind 'b'.\n     */\n    static compareOrder<EntityType extends BaseEntityType<EntityType>>(\n        a: keyof EntityType,\n        b: keyof EntityType,\n        entity: EntityType\n    ): number {\n        const metadataA: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, a);\n        const metadataB: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, b);\n\n        if (!metadataA || !metadataB) {\n            return 0;\n        }\n\n        if (metadataA.position.order === -1) {\n            if (metadataB.position.order === -1) {\n                return 0;\n            }\n            return 1;\n        }\n        else if (metadataB.position.order === -1) {\n            return -1;\n        }\n        return metadataA.position.order - metadataB.position.order;\n    }\n\n    /**\n     * Gets the bootstrap column classes for \"lg\", \"md\" and \"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     * @returns Bootstrap column classes.\n     * @throws When no metadata for the given key was found.\n     */\n    static getWidthClasses<EntityType extends BaseEntityType<EntityType>>(entity: EntityType, key: keyof EntityType): string {\n        const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n        if (!metadata) {\n            throw new Error(`Could not get metadata for property \"${key.toString()}\"`);\n        }\n        return `col-lg-${metadata.defaultWidths[0]} col-md-${metadata.defaultWidths[1]} col-sm-${metadata.defaultWidths[2]}`;\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 BaseEntityType<EntityType>>(entity: EntityType, entityPriorChanges: EntityType): void {\n        for (const key in entityPriorChanges) {\n            ReflectUtilities.set(entity, key, ReflectUtilities.get(entityPriorChanges, key));\n            if (ReflectUtilities.hasMetadata(this.METADATA_KEYS_TO_RESET_KEY, entity, key)) {\n                for (const k of (ReflectUtilities.getMetadata(this.METADATA_KEYS_TO_RESET_KEY, entity, key) as string[])) {\n                    if (ReflectUtilities.hasMetadata(k, entity, key)) {\n                        ReflectUtilities.defineMetadata(k, undefined, entity, key);\n                    }\n                }\n            }\n        }\n    }\n\n    private static getEntityRows<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        tab: number,\n        hideOmitForCreate: boolean,\n        hideOmitForEdit: boolean,\n        additionalOmitValues: (keyof EntityType)[],\n        injector: EnvironmentInjector\n    ): EntityRow<EntityType>[] {\n        const res: EntityRow<EntityType>[] = [];\n\n        const keys: (keyof EntityType)[] = this.keysOf(entity, injector, hideOmitForCreate, hideOmitForEdit)\n            .filter(k => !additionalOmitValues.includes(k));\n        const numberOfRows: number = this.getNumberOfRows<EntityType>(keys, entity, tab);\n        for (let i: number = 1; i <= numberOfRows; i++) {\n            const row: EntityRow<EntityType> = {\n                row: i,\n                keys: this.getKeysForRow<EntityType>(keys, entity, i, tab)\n            };\n            res.push(row);\n        }\n\n        if (this.getKeysForRow<EntityType>(keys, entity, -1, tab).length) {\n            const lastRow: EntityRow<EntityType> = {\n                row: numberOfRows + 1,\n                keys: this.getKeysForRow<EntityType>(keys, entity, -1, tab)\n            };\n            res.push(lastRow);\n        }\n\n        return res;\n    }\n\n    /**\n     * Gets the tabs that are used to display the given entity.\n     * @param entity - The entity to get the rows from.\n     * @param injector - An angular environment injector.\n     * @param hideOmitForCreate - Whether or not keys with the metadata omitForCreate should be filtered out.\n     * @param hideOmitForEdit - Whether or not keys with the metadata omitForUpdate should be filtered out.\n     * @param additionalOmitKeys - Additional omit values.\n     * @returns The sorted Tabs containing the rows and the keys to display in that row.\n     */\n    static getEntityTabs<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        injector: EnvironmentInjector,\n        hideOmitForCreate: boolean = false,\n        hideOmitForEdit: boolean = false,\n        additionalOmitKeys: (keyof EntityType)[] = []\n    ): EntityTab<EntityType>[] {\n        const res: EntityTab<EntityType>[] = [];\n        const keys: (keyof EntityType)[] = this.keysOf(entity, injector, hideOmitForCreate, hideOmitForEdit)\n            .filter(k => !additionalOmitKeys.includes(k));\n        const numberOfTabs: number = this.getNumberOfTabs<EntityType>(keys, entity);\n\n        const firstTabRows: EntityRow<EntityType>[] = this.getEntityRows<EntityType>(\n            entity,\n            -1,\n            hideOmitForCreate,\n            hideOmitForEdit,\n            additionalOmitKeys,\n            injector\n        );\n        if (firstTabRows.length) {\n            const firstTab: EntityTab<EntityType> = {\n                tabName: this.getFirstTabName(entity),\n                tab: -1,\n                rows: firstTabRows\n            };\n            res.push(firstTab);\n        }\n\n        for (let i: number = 2; i <= numberOfTabs; i++) {\n            const rows: EntityRow<EntityType>[] = this.getEntityRows<EntityType>(\n                entity, i, hideOmitForCreate, hideOmitForEdit, additionalOmitKeys, injector\n            );\n            if (rows.length) {\n                const tab: EntityTab<EntityType> = {\n                    tabName: this.getTabName(entity, i),\n                    tab: i,\n                    rows: rows\n                };\n                res.push(tab);\n            }\n        }\n\n        return res;\n    }\n\n    private static getKeysForRow<EntityType extends BaseEntityType<EntityType>>(\n        keys: (keyof EntityType)[],\n        entity: EntityType,\n        row: number,\n        tab: number\n    ): (keyof EntityType)[] {\n        return keys\n            .filter(k => this.getPropertyMetadata(entity, k)?.position.row === row)\n            .filter(k => this.getPropertyMetadata(entity, k)?.position.tab === tab)\n            .sort((a, b) => this.compareOrder(a, b, entity));\n    }\n\n    private static getNumberOfRows<EntityType extends BaseEntityType<EntityType>>(\n        keys: (keyof EntityType)[],\n        entity: EntityType,\n        tab: number\n    ): number {\n        return (keys\n            .filter(k => this.getPropertyMetadata(entity, k)?.position.tab === tab)\n            .map(k => this.getPropertyMetadata(entity, k)?.position.row) as number[])\n            .sort((a, b) => a > b ? -1 : 1)[0];\n    }\n\n    private static getNumberOfTabs<EntityType extends BaseEntityType<EntityType>>(keys: (keyof EntityType)[], entity: EntityType): number {\n        return (keys\n            .filter(k => this.getPropertyMetadata(entity, k) != undefined)\n            .map(k => this.getPropertyMetadata(entity, k)?.position.tab) as number[])\n            .sort((a, b) => a > b ? -1 : 1)[0];\n    }\n\n    private static getTabName<EntityType extends BaseEntityType<EntityType>>(entity: EntityType, tab: number): string {\n        const providedTabName: string | undefined = ReflectUtilities.ownKeys(entity)\n            .map(k => this.getPropertyMetadata(entity, k))\n            .find(m => m?.position.tab === tab && m.position.tabName)?.position.tabName;\n        return providedTabName ?? `Tab ${tab}`;\n    }\n\n    private static getFirstTabName<EntityType extends BaseEntityType<EntityType>>(entity: EntityType): string {\n        const providedTabName: string | undefined = ReflectUtilities.ownKeys(entity)\n            .map(k => this.getPropertyMetadata(entity, k))\n            .find(m => m?.position.tabName && m.position.tab === -1)?.position.tabName;\n        return providedTabName ?? 'Tab 1';\n    }\n\n    /**\n     * Gets the keys of the provided entity correctly typed.\n     * @param entity - The entity to get the keys of.\n     * @param injector - An angular environment injector.\n     * @param hideOmitForCreate - Whether or not keys with the metadata omitForCreate should be filtered out.\n     * @param hideOmitForEdit - Whether or not keys with the metadata omitForUpdate should be filtered out.\n     * @returns An array of keys of the entity.\n     */\n    static keysOf<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        injector: EnvironmentInjector,\n        hideOmitForCreate: boolean = false,\n        hideOmitForEdit: boolean = false\n    ): (keyof EntityType)[] {\n        let keys: (keyof EntityType)[] = ReflectUtilities.ownKeys(entity);\n        const dontDisplayKeys: (keyof EntityType)[] = this.getDontDisplayKeys(entity, injector);\n        keys = keys.filter(k => !dontDisplayKeys.includes(k));\n        if (hideOmitForCreate) {\n            const omitForCreateKeys: (keyof EntityType)[] = this.getOmitForCreate(entity);\n            keys = keys.filter(k => !omitForCreateKeys.includes(k));\n        }\n        if (hideOmitForEdit) {\n            const omitForUpdateKeys: (keyof EntityType)[] = this.getOmitForUpdate(entity);\n            keys = keys.filter(k => !omitForUpdateKeys.includes(k));\n        }\n        return keys;\n    }\n\n    private static getDontDisplayKeys<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        injector: EnvironmentInjector\n    ): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key in entity) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            // eslint-disable-next-line typescript/strict-boolean-expressions\n            if (runInInjectionContext(injector, () => !metadata?.display(entity))) {\n                res.push(key);\n            }\n        }\n        return res;\n    }\n}\n\n/**\n * A row that contains information about how to display an entity.\n */\nexport interface EntityRow<EntityType extends BaseEntityType<EntityType>> {\n    /**\n     * The row in which this should be displayed.\n     */\n    row: number,\n    /**\n     * The keys of the values that should be displayed in that row.\n     */\n    keys: (keyof EntityType)[]\n}\n\n/**\n * A tab that contains all the information about how to display an entity.\n */\nexport interface EntityTab<EntityType extends BaseEntityType<EntityType>> {\n    /**\n     * The tab in which the rows should be displayed.\n     */\n    tab: number,\n    /**\n     * The name to display inside the tab.\n     */\n    tabName: string,\n    /**\n     * The rows that should be displayed inside this tab,.\n     */\n    rows: EntityRow<EntityType>[]\n}"]}
611
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/utilities/entity.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { EnvironmentInjector, runInInjectionContext } from '@angular/core';\nimport { DateFilterFn } from '@angular/material/datepicker';\n\nimport { DateUtilities } from './date.utilities';\nimport { FileUtilities } from './file.utilities';\nimport { BaseEntityType } from '../classes/entity.model';\nimport { DateRangeArrayDecoratorConfigInternal, EntityArrayDecoratorConfigInternal } from '../decorators/array/array-decorator-internal.data';\nimport { DecoratorType, DecoratorTypes } from '../decorators/base/decorator-types.enum';\nimport { PropertyDecoratorConfigInternal } from '../decorators/base/property-decorator-internal.data';\nimport { CustomDecoratorConfigInternal } from '../decorators/custom/custom-decorator-internal.data';\nimport { DateRangeDateDecoratorConfigInternal } from '../decorators/date/date-decorator-internal.data';\nimport { DateRange } from '../decorators/date/date-decorator.data';\nimport { DefaultFileDecoratorConfigInternal } from '../decorators/file/file-decorator-internal.data';\nimport { FileData } from '../decorators/file/file-decorator.data';\nimport { DefaultObjectDecoratorConfigInternal } from '../decorators/object/object-decorator-internal.data';\nimport { LodashUtilities } from '../encapsulation/lodash.utilities';\nimport { ReflectUtilities } from '../encapsulation/reflect.utilities';\n\n/**\n * Shows information about differences between two entities.\n */\nexport interface Difference<EntityType extends BaseEntityType<EntityType>> {\n    /**\n     * The key where the two entities have different values.\n     */\n    key: keyof EntityType,\n    /**\n     * The value before any changes.\n     */\n    before: unknown,\n    /**\n     * The current value after changes.\n     */\n    after: unknown\n}\n\n/**\n * Contains HelperMethods around handling Entities and their property-metadata.\n */\nexport abstract class EntityUtilities {\n\n    /**\n     * The key for all keys of metadata that should be set to undefined when the entity gets reset.\n     */\n    static readonly METADATA_KEYS_TO_RESET_KEY: string = 'metadataKeysToReset';\n\n    /**\n     * The key for the metadata that saves the single preview image value on image properties.\n     */\n    static readonly SINGLE_PREVIEW_IMAGE_KEY: string = 'singlePreviewImage';\n\n    /**\n     * The key for the metadata that saves the multi preview images value on image properties.\n     */\n    static readonly MULTI_PREVIEW_IMAGES_KEY: string = 'multiPreviewImages';\n\n    /**\n     * The key for the metadata that saves the filenames value on file properties.\n     */\n    static readonly FILENAMES_KEY: string = 'fileNames';\n\n    /**\n     * The key for the metadata that saves the confirm password value on password properties.\n     */\n    static readonly CONFIRM_PASSWORD_KEY: string = 'confirmPassword';\n\n    /**\n     * The key for the metadata that saves the time value on date time properties.\n     */\n    static readonly TIME_KEY: string = 'time';\n\n    /**\n     * Gets the properties to omit when updating the entity.\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 BaseEntityType<EntityType>>(entity: EntityType): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key in entity) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            if (!metadata || metadata.omitForUpdate) {\n                res.push(key);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Gets the properties to omit when creating new entities.\n     * @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 BaseEntityType<EntityType>>(entity: EntityType): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key in entity) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            if (!metadata || metadata.omitForCreate) {\n                res.push(key);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Returns the given entity without the values that should be omitted for creation.\n     * @param entity - The entity with all its values.\n     * @returns The reduced entity object.\n     */\n    static getWithoutOmitCreateValues<EntityType extends BaseEntityType<EntityType>>(entity: EntityType): Partial<EntityType> {\n        return LodashUtilities.omit(entity, this.getOmitForCreate(entity)) as Partial<EntityType>;\n    }\n\n    /**\n     * Returns the given entity without the values that should be omitted for updating.\n     * This also handles omitting keys for @object or @array values and removes values that haven't been changed by default.\n     * @param entity - The entity with all its values.\n     * @param entityPriorChanges - The entity before any changes were applied.\n     * @param http - The angular HttpClient. Used to fetch files.\n     * @param injector - An angular environment injector.\n     * @returns The reduced entity object.\n     */\n    static async getWithoutOmitUpdateValues<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        entityPriorChanges: EntityType,\n        http: HttpClient,\n        injector: EnvironmentInjector\n    ): Promise<Partial<EntityType>> {\n        const res: Partial<EntityType> = {};\n        for (const key of this.keysOf(entity, injector, false, true)) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            const type: DecoratorTypes | undefined = this.getPropertyType(entity, key);\n            if (!await this.isEqual(entity[key], entityPriorChanges[key], metadata, type, http)) {\n                switch (type) {\n                    case DecoratorTypes.OBJECT: {\n                        // eslint-disable-next-line typescript/no-explicit-any\n                        (res[key] as object) = LodashUtilities.omit(entity[key] as any, this.getOmitForCreate(entity[key]));\n                        break;\n                    }\n                    case DecoratorTypes.ARRAY: {\n                        (res[key] as object[]) = (entity[key] as object[])\n                            .map(value => LodashUtilities.omit(value, this.getOmitForCreate(value)));\n                        break;\n                    }\n                    default: {\n                        res[key] = entity[key];\n                        break;\n                    }\n                }\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Sets all default values on the given entity.\n     * @param entity - The entity to set the default values on.\n     */\n    static setDefaultValues<EntityType extends BaseEntityType<EntityType>>(entity: EntityType): void {\n        for (const key in entity) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            if (metadata?.default) {\n                // eslint-disable-next-line typescript/no-unsafe-assignment, typescript/no-explicit-any\n                entity[key] = metadata.default() as any;\n            }\n        }\n    }\n\n    /**\n     * Gets all properties on the given entity which are files.\n     * @param entity - The entity to check for file properties.\n     * @param omit - Whether to leave out values that are omitted for create or delete.\n     * @returns The keys of all file properties on the given entity.\n     */\n    static getFileProperties<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        omit?: 'create' | 'update'\n    ): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key in entity) {\n            const type: DecoratorTypes | undefined = this.getPropertyType(entity, key);\n            if (type === DecoratorTypes.FILE_DEFAULT || type === DecoratorTypes.FILE_IMAGE) {\n                // eslint-disable-next-line stylistic/max-len\n                const metadata: PropertyDecoratorConfigInternal<unknown> = this.getPropertyMetadata(entity, key) as PropertyDecoratorConfigInternal<unknown>;\n                if (!(metadata.omitForCreate && omit === 'create') && !(metadata.omitForUpdate && omit === 'update')) {\n                    res.push(key);\n                }\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     * @throws When no metadata can be found for the given property.\n     */\n    static getPropertyMetadata<\n        EntityType extends BaseEntityType<EntityType>,\n        T extends DecoratorTypes,\n        CustomMetadataType extends Record<string, unknown>\n    >(\n        entity: EntityType,\n        propertyKey: keyof EntityType,\n        // eslint-disable-next-line unusedImports/no-unused-vars\n        type?: T\n    ): DecoratorType<T, CustomMetadataType> | undefined {\n        const metadata: unknown = ReflectUtilities.getMetadata('metadata', entity, propertyKey);\n        // if (metadata == null) {\n        //     throw new Error(`Could not find metadata for property ${String(propertyKey)} on the entity ${JSON.stringify(entity)}`);\n        // }\n        return metadata as DecoratorType<T, CustomMetadataType> | undefined;\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     * @throws Will throw an error if no metadata can be found for the given property.\n     */\n    static getPropertyType<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType, propertyKey: keyof EntityType\n    ): DecoratorTypes | undefined {\n        return ReflectUtilities.getMetadata('type', entity, propertyKey) as DecoratorTypes | undefined;\n    }\n\n    /**\n     * Sets all property values based on a given entity data-object.\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 BaseEntityType<EntityType>>(target: EntityType, entity?: EntityType): void {\n        for (const key in target) {\n            const type: DecoratorTypes | undefined = this.getPropertyType(target, key);\n            let value: unknown = entity ? ReflectUtilities.get(entity, key) : undefined;\n            switch (type) {\n                case DecoratorTypes.OBJECT: {\n                    // eslint-disable-next-line typescript/no-explicit-any\n                    const objectMetadata: DefaultObjectDecoratorConfigInternal<any>\n                        // eslint-disable-next-line typescript/no-explicit-any\n                        = this.getPropertyMetadata(target, key, DecoratorTypes.OBJECT) as DefaultObjectDecoratorConfigInternal<any>;\n                    value = new objectMetadata.EntityClass(value as object | undefined);\n                    break;\n                }\n                case DecoratorTypes.ARRAY: {\n                    const inputArray: EntityType[] | undefined = value as EntityType[] | undefined;\n                    const resArray: EntityType[] = [];\n                    if (inputArray) {\n                        // eslint-disable-next-line typescript/no-explicit-any\n                        const arrayMetadata: EntityArrayDecoratorConfigInternal<any>\n                            // eslint-disable-next-line typescript/no-explicit-any\n                            = this.getPropertyMetadata(target, key, DecoratorTypes.ARRAY) as EntityArrayDecoratorConfigInternal<any>;\n                        for (const item of inputArray) {\n                            const itemWithMetadata: EntityType = new arrayMetadata.EntityClass(item) as EntityType;\n                            resArray.push(itemWithMetadata);\n                        }\n                    }\n                    value = resArray;\n                    break;\n                }\n                default: {\n                    break;\n                }\n            }\n            ReflectUtilities.set(target, key, value);\n        }\n    }\n    // eslint-disable-next-line typescript/member-ordering, jsdoc/require-jsdoc, typescript/typedef\n    static construct = this.new;\n    // eslint-disable-next-line typescript/member-ordering, jsdoc/require-jsdoc, typescript/typedef\n    static build = this.new;\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     * @param http - The angular HttpClient. Used to fetch files.\n     * @param injector - An angular environment injector.\n     * @returns Whether or not the entity is dirty.\n     */\n    static async isDirty<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        entityPriorChanges: EntityType,\n        http: HttpClient,\n        injector: EnvironmentInjector\n    ): Promise<boolean> {\n        if (!(entityPriorChanges as EntityType | undefined)) {\n            return false;\n        }\n        const differences: Difference<EntityType>[] = await this.getDifferencesBetweenEntities(entity, entityPriorChanges, http, injector);\n        return !!differences.length;\n    }\n\n    /**\n     * Gets the differences between the two given entities. Only checks properties which are decorated.\n     * @param entity - The entity as is.\n     * @param entityPriorChanges - The entity before any changes have been made.\n     * @param http - The angular http client, is needed to check if files are equal.\n     * @param injector - An angular environment injector.\n     * @returns The differences as an array consisting of key, before and after.\n     */\n    static async getDifferencesBetweenEntities<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        entityPriorChanges: EntityType,\n        http: HttpClient,\n        injector: EnvironmentInjector\n    ): Promise<Difference<EntityType>[]> {\n        const res: Difference<EntityType>[] = [];\n        // values that are not decorated can be ignored, as they are not transferred via http.\n        for (const key of this.keysOf(entity, injector)) {\n            const type: DecoratorTypes | undefined = this.getPropertyType(entity, key);\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            if (!await this.isEqual(entity[key], entityPriorChanges[key], metadata, type, http)) {\n                res.push({\n                    key: key,\n                    before: entityPriorChanges[key],\n                    after: entity[key]\n                });\n            }\n            else {\n                // This is needed to set blob file data so that it is only requested once.\n                entityPriorChanges[key] = LodashUtilities.cloneDeep(entity[key]);\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Checks if two given values are equal.\n     * It uses the isEqual method from LodashUtilities and extends it with functionality regarding Dates.\n     * @param value - The updated value.\n     * @param valuePriorChanges - The value before any changes.\n     * @param metadata - The metadata of the property.\n     * @param type - The type of the property.\n     * @param http - The angular HttpClient. Used to fetch files.\n     * @returns Whether or not the given values are equal.\n     */\n    static async isEqual(\n        value: unknown,\n        valuePriorChanges: unknown,\n        metadata: PropertyDecoratorConfigInternal<unknown> | undefined,\n        type: DecoratorTypes | undefined,\n        http: HttpClient\n    ): Promise<boolean> {\n        if ((value == undefined && valuePriorChanges == undefined)\n            || this.differenceIsUndefinedAndEmptyArray(value, valuePriorChanges)\n            || this.differenceIsUndefinedAndEmptyString(value, valuePriorChanges)\n        ) {\n            return true;\n        }\n        switch (type) {\n            case DecoratorTypes.DATE_RANGE: {\n                return this.isEqualDateRange(\n                    value,\n                    valuePriorChanges,\n                    (metadata as DateRangeDateDecoratorConfigInternal).filter\n                );\n            }\n            case DecoratorTypes.DATE: {\n                return this.isEqualDate(value, valuePriorChanges);\n            }\n            case DecoratorTypes.DATE_TIME: {\n                return this.isEqualDateTime(value, valuePriorChanges);\n            }\n            case DecoratorTypes.ARRAY_DATE:\n            case DecoratorTypes.ARRAY_DATE_TIME: {\n                return this.isEqualArrayDate(value, valuePriorChanges);\n            }\n            case DecoratorTypes.ARRAY_DATE_RANGE: {\n                return this.isEqualArrayDateRange(\n                    value,\n                    valuePriorChanges,\n                    (metadata as DateRangeArrayDecoratorConfigInternal).filter\n                );\n            }\n            case DecoratorTypes.ARRAY_STRING_CHIPS:\n            case DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS: {\n                return this.isEqualArrayString(value, valuePriorChanges);\n            }\n            case DecoratorTypes.FILE_IMAGE:\n            case DecoratorTypes.FILE_DEFAULT: {\n                return this.isEqualFile(value, valuePriorChanges, (metadata as DefaultFileDecoratorConfigInternal).multiple, http);\n            }\n            case DecoratorTypes.CUSTOM: {\n                // eslint-disable-next-line typescript/no-explicit-any\n                return this.isEqualCustom(value, valuePriorChanges, metadata as CustomDecoratorConfigInternal<any, any, any, any>);\n            }\n            default: {\n                return LodashUtilities.isEqual(value, valuePriorChanges);\n            }\n        }\n    }\n\n    private static differenceIsUndefinedAndEmptyString(value: unknown, valuePriorChanges: unknown): boolean {\n        return (valuePriorChanges == undefined && typeof value === 'string' && !value.length)\n            || (value == undefined && typeof valuePriorChanges === 'string' && !valuePriorChanges.length);\n    }\n\n    private static differenceIsUndefinedAndEmptyArray(value: unknown, valuePriorChanges: unknown): boolean {\n        return (valuePriorChanges == undefined && Array.isArray(value) && !value.length)\n            || (value == undefined && Array.isArray(valuePriorChanges) && !valuePriorChanges.length);\n    }\n\n    private static isEqualArrayString(value: unknown, valuePriorChanges: unknown): boolean | PromiseLike<boolean> {\n        let stringArray: string[] | undefined = LodashUtilities.cloneDeep(value as string[] | undefined);\n        if (stringArray) {\n            stringArray = stringArray.sort();\n        }\n        let stringArrayPriorChanges: string[] | undefined = LodashUtilities.cloneDeep(valuePriorChanges as string[] | undefined);\n        if (stringArrayPriorChanges) {\n            stringArrayPriorChanges = stringArrayPriorChanges.sort();\n        }\n        return LodashUtilities.isEqual(stringArray, stringArrayPriorChanges);\n    }\n\n    private static isEqualArrayDate(value: unknown, valuePriorChanges: unknown): boolean {\n        let newValue: Date[] | undefined = LodashUtilities.cloneDeep(value as Date[] | undefined);\n        if (newValue) {\n            newValue = newValue.map(v => new Date(v)).sort();\n        }\n        let newValuePriorChanges: Date[] | undefined = LodashUtilities.cloneDeep(valuePriorChanges as Date[] | undefined);\n        if (newValuePriorChanges) {\n            newValuePriorChanges = newValuePriorChanges.map(v => new Date(v)).sort();\n        }\n        return LodashUtilities.isEqual(newValue, newValuePriorChanges);\n    }\n\n    private static isEqualArrayDateRange(value: unknown, valuePriorChanges: unknown, filter?: DateFilterFn<Date>): boolean {\n        let dateRanges: DateRange[] | undefined = LodashUtilities.cloneDeep(value as DateRange[] | undefined);\n        if (dateRanges) {\n            dateRanges = dateRanges.sort();\n        }\n        let dateRangesPriorChanges: DateRange[] | undefined = LodashUtilities.cloneDeep(valuePriorChanges as DateRange[] | undefined);\n        if (dateRangesPriorChanges) {\n            dateRangesPriorChanges = dateRangesPriorChanges.sort();\n        }\n        if (dateRanges?.length !== dateRangesPriorChanges?.length) {\n            return false;\n        }\n        if (dateRanges?.length) {\n            for (let i: number = 0; i < dateRanges?.length; i++) {\n                if (!this.isEqualDateRange(dateRanges?.[i], dateRangesPriorChanges?.[i], filter)) {\n                    return false;\n                }\n            }\n        }\n        return true;\n    }\n\n    private static isEqualDateTime(value: unknown, valuePriorChanges: unknown): boolean {\n        const date: Date = new Date(value as Date);\n        const datePriorChanges: Date = new Date(valuePriorChanges as Date);\n        return LodashUtilities.isEqual(date, datePriorChanges);\n    }\n\n    private static isEqualDate(value: unknown, valuePriorChanges: unknown): boolean {\n        const date: Date = new Date(value as Date);\n        const datePriorChanges: Date = new Date(valuePriorChanges as Date);\n        date.setHours(0, 0, 0, 0);\n        datePriorChanges.setHours(0, 0, 0, 0);\n        return LodashUtilities.isEqual(date, datePriorChanges);\n    }\n\n    private static isEqualDateRange(value: unknown, valuePriorChanges: unknown, filter?: DateFilterFn<Date>): boolean {\n        const dateRange: Partial<DateRange> | undefined = LodashUtilities.cloneDeep(value) as Partial<DateRange> | undefined;\n        if (dateRange?.start) {\n            dateRange.start = new Date(dateRange.start);\n        }\n        if (dateRange?.end) {\n            dateRange.end = new Date(dateRange.end);\n        }\n        if (dateRange?.start && dateRange.end) {\n            dateRange.values = DateUtilities.getDatesBetween(\n                dateRange.start,\n                dateRange.end,\n                filter\n            );\n        }\n        // eslint-disable-next-line stylistic/max-len\n        const dateRangePriorChanges: Partial<DateRange> | undefined = LodashUtilities.cloneDeep(valuePriorChanges) as Partial<DateRange> | undefined;\n        if (dateRangePriorChanges?.start) {\n            dateRangePriorChanges.start = new Date(dateRangePriorChanges.start);\n        }\n        if (dateRangePriorChanges?.end) {\n            dateRangePriorChanges.end = new Date(dateRangePriorChanges.end);\n        }\n        if (dateRangePriorChanges?.start && dateRangePriorChanges.end) {\n            dateRangePriorChanges.values = DateUtilities.getDatesBetween(\n                dateRangePriorChanges.start,\n                dateRangePriorChanges.end,\n                filter\n            );\n        }\n        return LodashUtilities.isEqual(dateRange, dateRangePriorChanges);\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    // eslint-disable-next-line sonar/cognitive-complexity\n    private static async isEqualFile(value: unknown, valuePriorChanges: unknown, multiple: boolean, http: HttpClient): Promise<boolean> {\n        if (value == undefined) {\n            return valuePriorChanges == undefined;\n        }\n        if (valuePriorChanges == undefined) {\n            return false;\n        }\n        const files: FileData[] = multiple ? (value as FileData[]).sort() : [value as FileData].sort();\n        const filesPriorChanges: FileData[] = multiple ? (valuePriorChanges as FileData[]).sort() : [valuePriorChanges as FileData].sort();\n        if (files.length !== filesPriorChanges.length) {\n            return false;\n        }\n        for (let i: number = 0; i < files.length; i++) {\n            // checks this before actually getting any files due to performance reasons.\n            if (!LodashUtilities.isEqual(LodashUtilities.omit(files[i], 'file'), LodashUtilities.omit(filesPriorChanges[i], 'file'))) {\n                return false;\n            }\n            if (filesPriorChanges[i].file && !files[i].file) {\n                files[i] = await FileUtilities.getFileData(files[i], http);\n                value = files[i];\n            }\n            if (files[i].file && !filesPriorChanges[i].file) {\n                filesPriorChanges[i] = await FileUtilities.getFileData(filesPriorChanges[i], http);\n                valuePriorChanges = filesPriorChanges[i];\n            }\n            if (!LodashUtilities.isEqual(await files[i].file?.text(), await filesPriorChanges[i].file?.text())) {\n                return false;\n            }\n        }\n        return true;\n    }\n\n    private static isEqualCustom(\n        value: unknown,\n        valuePriorChanges: unknown,\n        // eslint-disable-next-line typescript/no-explicit-any\n        metadata: CustomDecoratorConfigInternal<any, any, any, any>\n    ): boolean {\n        return metadata.isEqual(value, valuePriorChanges, metadata);\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     * @returns 0 if both values have the same order, a negative value if 'a' comes before 'b', a positive value if 'a' comes behind 'b'.\n     */\n    static compareOrder<EntityType extends BaseEntityType<EntityType>>(\n        a: keyof EntityType,\n        b: keyof EntityType,\n        entity: EntityType\n    ): number {\n        const metadataA: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, a);\n        const metadataB: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, b);\n\n        if (!metadataA || !metadataB) {\n            return 0;\n        }\n\n        if (metadataA.position.order === -1) {\n            if (metadataB.position.order === -1) {\n                return 0;\n            }\n            return 1;\n        }\n        else if (metadataB.position.order === -1) {\n            return -1;\n        }\n        return metadataA.position.order - metadataB.position.order;\n    }\n\n    /**\n     * Gets the responsive column classes for \"lg\", \"md\" and \"sm\".\n     * @param entity - Entity to get the responsive column classes for.\n     * @param key - Key of the property to get the responsive column classes from.\n     * @returns Responsive column classes for large, middle and small displays.\n     * @throws When no metadata for the given key was found.\n     */\n    static getWidthClasses<EntityType extends BaseEntityType<EntityType>>(entity: EntityType, key: keyof EntityType): string {\n        const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n        if (!metadata) {\n            throw new Error(`Could not get metadata for property \"${key.toString()}\"`);\n        }\n        return `lg:col-span-${metadata.defaultWidths[0]} md:col-span-${metadata.defaultWidths[1]} col-span-${metadata.defaultWidths[2]}`;\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 BaseEntityType<EntityType>>(entity: EntityType, entityPriorChanges: EntityType): void {\n        for (const key in entityPriorChanges) {\n            ReflectUtilities.set(entity, key, ReflectUtilities.get(entityPriorChanges, key));\n            if (ReflectUtilities.hasMetadata(this.METADATA_KEYS_TO_RESET_KEY, entity, key)) {\n                for (const k of (ReflectUtilities.getMetadata(this.METADATA_KEYS_TO_RESET_KEY, entity, key) as string[])) {\n                    if (ReflectUtilities.hasMetadata(k, entity, key)) {\n                        ReflectUtilities.defineMetadata(k, undefined, entity, key);\n                    }\n                }\n            }\n        }\n    }\n\n    private static getEntityRows<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        tab: number,\n        hideOmitForCreate: boolean,\n        hideOmitForEdit: boolean,\n        additionalOmitValues: (keyof EntityType)[],\n        injector: EnvironmentInjector\n    ): EntityRow<EntityType>[] {\n        const res: EntityRow<EntityType>[] = [];\n\n        const keys: (keyof EntityType)[] = this.keysOf(entity, injector, hideOmitForCreate, hideOmitForEdit)\n            .filter(k => !additionalOmitValues.includes(k));\n        const numberOfRows: number = this.getNumberOfRows<EntityType>(keys, entity, tab);\n        for (let i: number = 1; i <= numberOfRows; i++) {\n            const row: EntityRow<EntityType> = {\n                row: i,\n                keys: this.getKeysForRow<EntityType>(keys, entity, i, tab)\n            };\n            res.push(row);\n        }\n\n        if (this.getKeysForRow<EntityType>(keys, entity, -1, tab).length) {\n            const lastRow: EntityRow<EntityType> = {\n                row: numberOfRows + 1,\n                keys: this.getKeysForRow<EntityType>(keys, entity, -1, tab)\n            };\n            res.push(lastRow);\n        }\n\n        return res;\n    }\n\n    /**\n     * Gets the tabs that are used to display the given entity.\n     * @param entity - The entity to get the rows from.\n     * @param injector - An angular environment injector.\n     * @param hideOmitForCreate - Whether or not keys with the metadata omitForCreate should be filtered out.\n     * @param hideOmitForEdit - Whether or not keys with the metadata omitForUpdate should be filtered out.\n     * @param additionalOmitKeys - Additional omit values.\n     * @returns The sorted Tabs containing the rows and the keys to display in that row.\n     */\n    static getEntityTabs<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        injector: EnvironmentInjector,\n        hideOmitForCreate: boolean = false,\n        hideOmitForEdit: boolean = false,\n        additionalOmitKeys: (keyof EntityType)[] = []\n    ): EntityTab<EntityType>[] {\n        const res: EntityTab<EntityType>[] = [];\n        const keys: (keyof EntityType)[] = this.keysOf(entity, injector, hideOmitForCreate, hideOmitForEdit)\n            .filter(k => !additionalOmitKeys.includes(k));\n        const numberOfTabs: number = this.getNumberOfTabs<EntityType>(keys, entity);\n\n        const firstTabRows: EntityRow<EntityType>[] = this.getEntityRows<EntityType>(\n            entity,\n            -1,\n            hideOmitForCreate,\n            hideOmitForEdit,\n            additionalOmitKeys,\n            injector\n        );\n        if (firstTabRows.length) {\n            const firstTab: EntityTab<EntityType> = {\n                tabName: this.getFirstTabName(entity),\n                tab: -1,\n                rows: firstTabRows\n            };\n            res.push(firstTab);\n        }\n\n        for (let i: number = 2; i <= numberOfTabs; i++) {\n            const rows: EntityRow<EntityType>[] = this.getEntityRows<EntityType>(\n                entity, i, hideOmitForCreate, hideOmitForEdit, additionalOmitKeys, injector\n            );\n            if (rows.length) {\n                const tab: EntityTab<EntityType> = {\n                    tabName: this.getTabName(entity, i),\n                    tab: i,\n                    rows: rows\n                };\n                res.push(tab);\n            }\n        }\n\n        return res;\n    }\n\n    private static getKeysForRow<EntityType extends BaseEntityType<EntityType>>(\n        keys: (keyof EntityType)[],\n        entity: EntityType,\n        row: number,\n        tab: number\n    ): (keyof EntityType)[] {\n        return keys\n            .filter(k => this.getPropertyMetadata(entity, k)?.position.row === row)\n            .filter(k => this.getPropertyMetadata(entity, k)?.position.tab === tab)\n            .sort((a, b) => this.compareOrder(a, b, entity));\n    }\n\n    private static getNumberOfRows<EntityType extends BaseEntityType<EntityType>>(\n        keys: (keyof EntityType)[],\n        entity: EntityType,\n        tab: number\n    ): number {\n        return (keys\n            .filter(k => this.getPropertyMetadata(entity, k)?.position.tab === tab)\n            .map(k => this.getPropertyMetadata(entity, k)?.position.row) as number[])\n            .sort((a, b) => a > b ? -1 : 1)[0];\n    }\n\n    private static getNumberOfTabs<EntityType extends BaseEntityType<EntityType>>(keys: (keyof EntityType)[], entity: EntityType): number {\n        return (keys\n            .filter(k => this.getPropertyMetadata(entity, k) != undefined)\n            .map(k => this.getPropertyMetadata(entity, k)?.position.tab) as number[])\n            .sort((a, b) => a > b ? -1 : 1)[0];\n    }\n\n    private static getTabName<EntityType extends BaseEntityType<EntityType>>(entity: EntityType, tab: number): string {\n        const providedTabName: string | undefined = ReflectUtilities.ownKeys(entity)\n            .map(k => this.getPropertyMetadata(entity, k))\n            .find(m => m?.position.tab === tab && m.position.tabName)?.position.tabName;\n        return providedTabName ?? `Tab ${tab}`;\n    }\n\n    private static getFirstTabName<EntityType extends BaseEntityType<EntityType>>(entity: EntityType): string {\n        const providedTabName: string | undefined = ReflectUtilities.ownKeys(entity)\n            .map(k => this.getPropertyMetadata(entity, k))\n            .find(m => m?.position.tabName && m.position.tab === -1)?.position.tabName;\n        return providedTabName ?? 'Tab 1';\n    }\n\n    /**\n     * Gets the keys of the provided entity correctly typed.\n     * @param entity - The entity to get the keys of.\n     * @param injector - An angular environment injector.\n     * @param hideOmitForCreate - Whether or not keys with the metadata omitForCreate should be filtered out.\n     * @param hideOmitForEdit - Whether or not keys with the metadata omitForUpdate should be filtered out.\n     * @returns An array of keys of the entity.\n     */\n    static keysOf<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        injector: EnvironmentInjector,\n        hideOmitForCreate: boolean = false,\n        hideOmitForEdit: boolean = false\n    ): (keyof EntityType)[] {\n        let keys: (keyof EntityType)[] = ReflectUtilities.ownKeys(entity);\n        const dontDisplayKeys: (keyof EntityType)[] = this.getDontDisplayKeys(entity, injector);\n        keys = keys.filter(k => !dontDisplayKeys.includes(k));\n        if (hideOmitForCreate) {\n            const omitForCreateKeys: (keyof EntityType)[] = this.getOmitForCreate(entity);\n            keys = keys.filter(k => !omitForCreateKeys.includes(k));\n        }\n        if (hideOmitForEdit) {\n            const omitForUpdateKeys: (keyof EntityType)[] = this.getOmitForUpdate(entity);\n            keys = keys.filter(k => !omitForUpdateKeys.includes(k));\n        }\n        return keys;\n    }\n\n    private static getDontDisplayKeys<EntityType extends BaseEntityType<EntityType>>(\n        entity: EntityType,\n        injector: EnvironmentInjector\n    ): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const key in entity) {\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = this.getPropertyMetadata(entity, key);\n            // eslint-disable-next-line typescript/strict-boolean-expressions\n            if (runInInjectionContext(injector, () => !metadata?.display(entity))) {\n                res.push(key);\n            }\n        }\n        return res;\n    }\n}\n\n/**\n * A row that contains information about how to display an entity.\n */\nexport interface EntityRow<EntityType extends BaseEntityType<EntityType>> {\n    /**\n     * The row in which this should be displayed.\n     */\n    row: number,\n    /**\n     * The keys of the values that should be displayed in that row.\n     */\n    keys: (keyof EntityType)[]\n}\n\n/**\n * A tab that contains all the information about how to display an entity.\n */\nexport interface EntityTab<EntityType extends BaseEntityType<EntityType>> {\n    /**\n     * The tab in which the rows should be displayed.\n     */\n    tab: number,\n    /**\n     * The name to display inside the tab.\n     */\n    tabName: string,\n    /**\n     * The rows that should be displayed inside this tab,.\n     */\n    rows: EntityRow<EntityType>[]\n}"]}