ngx-material-entity 15.3.0 → 16.0.0

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 (210) hide show
  1. package/classes/entity.model.d.ts +2 -2
  2. package/components/confirm-dialog/confirm-dialog-data.d.ts +1 -1
  3. package/components/edit-page/edit-page.component.d.ts +4 -2
  4. package/components/edit-page/page-edit-data.builder.d.ts +1 -1
  5. package/components/input/array/array-string-chips-input/array-string-chips-input.component.d.ts +1 -0
  6. package/components/input/array/array-table.class.d.ts +4 -2
  7. package/components/input/base-input.component.d.ts +5 -1
  8. package/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.d.ts +1 -1
  9. package/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.d.ts +1 -1
  10. package/components/input/file/file-default-input/file-default-input.component.d.ts +0 -2
  11. package/components/input/file/file-image-input/file-image-input.component.d.ts +3 -2
  12. package/components/input/file/file-input/file-input.component.d.ts +4 -2
  13. package/components/input/input.component.d.ts +9 -4
  14. package/components/input/input.module.d.ts +2 -1
  15. package/components/table/display-column-value/base-display-column-value.component.d.ts +1 -1
  16. package/components/table/display-column-value/display-column-value.component.d.ts +1 -1
  17. package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +3 -1
  18. package/components/table/table-data.builder.d.ts +1 -1
  19. package/components/table/table-data.d.ts +1 -1
  20. package/components/table/table.component.d.ts +1 -1
  21. package/decorators/base/decorator-types.enum.d.ts +1 -1
  22. package/decorators/base/property-decorator.data.d.ts +1 -1
  23. package/decorators/file/file-decorator.data.d.ts +1 -1
  24. package/decorators/number/number-decorator.data.d.ts +1 -1
  25. package/decorators/string/string-decorator.data.d.ts +1 -1
  26. package/encapsulation/jszip.utilities.d.ts +1 -1
  27. package/encapsulation/uuid.utilities.d.ts +11 -0
  28. package/esm2022/classes/base.builder.mjs +44 -0
  29. package/esm2022/classes/entity.model.mjs +26 -0
  30. package/esm2022/components/confirm-dialog/confirm-dialog-data.builder.mjs +58 -0
  31. package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +60 -0
  32. package/esm2022/components/edit-page/edit-page.component.mjs +291 -0
  33. package/esm2022/components/input/array/array-date-input/array-date-input.component.mjs +23 -0
  34. package/esm2022/components/input/array/array-date-range-input/array-date-range-input.component.mjs +49 -0
  35. package/esm2022/components/input/array/array-date-time-input/array-date-time-input.component.mjs +49 -0
  36. package/esm2022/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +50 -0
  37. package/esm2022/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +69 -0
  38. package/esm2022/components/input/array/array-table.class.mjs +100 -0
  39. package/esm2022/components/input/base-input.component.mjs +88 -0
  40. package/esm2022/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +21 -0
  41. package/esm2022/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +17 -0
  42. package/esm2022/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +21 -0
  43. package/esm2022/components/input/custom/custom.component.mjs +28 -0
  44. package/esm2022/components/input/date/date-input/date-input.component.mjs +19 -0
  45. package/esm2022/components/input/date/date-range-input/date-range-input.component.mjs +68 -0
  46. package/esm2022/components/input/date/date-time-input/date-time-input.component.mjs +69 -0
  47. package/esm2022/components/input/file/file-default-input/file-default-input.component.mjs +18 -0
  48. package/esm2022/components/input/file/file-image-input/file-image-input.component.mjs +101 -0
  49. package/esm2022/components/input/file/file-input/dragDrop.directive.mjs +62 -0
  50. package/esm2022/components/input/file/file-input/file-input.component.mjs +206 -0
  51. package/esm2022/components/input/input.component.mjs +849 -0
  52. package/esm2022/components/input/input.module.mjs +172 -0
  53. package/esm2022/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +23 -0
  54. package/esm2022/components/input/number/number-input/number-input.component.mjs +16 -0
  55. package/esm2022/components/input/number/number-slider-input/number-slider-input.component.mjs +17 -0
  56. package/esm2022/components/input/relations/references-many-input/references-many-input.component.mjs +102 -0
  57. package/esm2022/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +36 -0
  58. package/esm2022/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +23 -0
  59. package/esm2022/components/input/string/string-input/string-input.component.mjs +16 -0
  60. package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs +39 -0
  61. package/esm2022/components/input/string/string-textbox-input/string-textbox-input.component.mjs +17 -0
  62. package/esm2022/components/table/create-dialog/create-dialog-data.builder.mjs +42 -0
  63. package/esm2022/components/table/create-dialog/create-entity-dialog-data.builder.mjs +32 -0
  64. package/esm2022/components/table/create-dialog/create-entity-dialog.component.mjs +107 -0
  65. package/esm2022/components/table/display-column-value/base-display-column-value.component.mjs +28 -0
  66. package/esm2022/components/table/display-column-value/display-column-value.component.mjs +37 -0
  67. package/esm2022/components/table/edit-dialog/edit-data.builder.mjs +106 -0
  68. package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +209 -0
  69. package/esm2022/components/table/edit-dialog/edit-entity.builder.mjs +39 -0
  70. package/esm2022/components/table/table-data.builder.mjs +269 -0
  71. package/esm2022/components/table/table.component.mjs +348 -0
  72. package/esm2022/decorators/array/array-decorator-internal.data.mjs +286 -0
  73. package/esm2022/decorators/array/array-decorator.data.mjs +21 -0
  74. package/esm2022/decorators/base/property-decorator-internal.data.mjs +82 -0
  75. package/esm2022/decorators/base/property-decorator.data.mjs +56 -0
  76. package/esm2022/decorators/boolean/boolean-decorator-internal.data.mjs +43 -0
  77. package/esm2022/decorators/boolean/boolean-decorator.data.mjs +11 -0
  78. package/esm2022/decorators/custom/custom-decorator-internal.data.mjs +35 -0
  79. package/{esm2020 → esm2022}/decorators/date/date-decorator-internal.data.mjs +43 -1
  80. package/esm2022/decorators/date/date-decorator.data.mjs +11 -0
  81. package/esm2022/decorators/file/file-decorator-internal.data.mjs +143 -0
  82. package/esm2022/decorators/file/file-decorator.data.mjs +64 -0
  83. package/esm2022/decorators/has-many/has-many-decorator-internal.data.mjs +42 -0
  84. package/esm2022/decorators/number/number-decorator-internal.data.mjs +76 -0
  85. package/esm2022/decorators/number/number-decorator.data.mjs +11 -0
  86. package/esm2022/decorators/object/object-decorator-internal.data.mjs +20 -0
  87. package/esm2022/decorators/object/object-decorator.data.mjs +22 -0
  88. package/esm2022/decorators/references-many/references-many-decorator-internal.data.mjs +48 -0
  89. package/esm2022/decorators/references-one/references-one-decorator-internal.data.mjs +24 -0
  90. package/esm2022/decorators/string/string-decorator-internal.data.mjs +114 -0
  91. package/esm2022/decorators/string/string-decorator.data.mjs +11 -0
  92. package/esm2022/encapsulation/uuid.utilities.mjs +15 -0
  93. package/esm2022/services/entity.service.mjs +276 -0
  94. package/esm2022/utilities/date.utilities.mjs +159 -0
  95. package/esm2022/utilities/entity.utilities.mjs +905 -0
  96. package/esm2022/utilities/file.utilities.mjs +180 -0
  97. package/{fesm2020 → fesm2022}/ngx-material-entity.mjs +1355 -484
  98. package/fesm2022/ngx-material-entity.mjs.map +1 -0
  99. package/package.json +11 -17
  100. package/utilities/date.utilities.d.ts +1 -1
  101. package/utilities/entity.utilities.d.ts +7 -3
  102. package/utilities/file.utilities.d.ts +6 -2
  103. package/esm2020/classes/base.builder.mjs +0 -42
  104. package/esm2020/classes/entity.model.mjs +0 -22
  105. package/esm2020/components/confirm-dialog/confirm-dialog-data.builder.mjs +0 -44
  106. package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +0 -57
  107. package/esm2020/components/edit-page/edit-page.component.mjs +0 -274
  108. package/esm2020/components/input/array/array-date-input/array-date-input.component.mjs +0 -26
  109. package/esm2020/components/input/array/array-date-range-input/array-date-range-input.component.mjs +0 -50
  110. package/esm2020/components/input/array/array-date-time-input/array-date-time-input.component.mjs +0 -49
  111. package/esm2020/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +0 -49
  112. package/esm2020/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +0 -70
  113. package/esm2020/components/input/array/array-table.class.mjs +0 -93
  114. package/esm2020/components/input/base-input.component.mjs +0 -64
  115. package/esm2020/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +0 -21
  116. package/esm2020/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +0 -17
  117. package/esm2020/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +0 -21
  118. package/esm2020/components/input/custom/custom.component.mjs +0 -26
  119. package/esm2020/components/input/date/date-input/date-input.component.mjs +0 -22
  120. package/esm2020/components/input/date/date-range-input/date-range-input.component.mjs +0 -71
  121. package/esm2020/components/input/date/date-time-input/date-time-input.component.mjs +0 -71
  122. package/esm2020/components/input/file/file-default-input/file-default-input.component.mjs +0 -23
  123. package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +0 -98
  124. package/esm2020/components/input/file/file-input/dragDrop.directive.mjs +0 -63
  125. package/esm2020/components/input/file/file-input/file-input.component.mjs +0 -195
  126. package/esm2020/components/input/input.component.mjs +0 -746
  127. package/esm2020/components/input/input.module.mjs +0 -169
  128. package/esm2020/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +0 -26
  129. package/esm2020/components/input/number/number-input/number-input.component.mjs +0 -16
  130. package/esm2020/components/input/number/number-slider-input/number-slider-input.component.mjs +0 -17
  131. package/esm2020/components/input/relations/references-many-input/references-many-input.component.mjs +0 -100
  132. package/esm2020/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +0 -34
  133. package/esm2020/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +0 -26
  134. package/esm2020/components/input/string/string-input/string-input.component.mjs +0 -16
  135. package/esm2020/components/input/string/string-password-input/string-password-input.component.mjs +0 -42
  136. package/esm2020/components/input/string/string-textbox-input/string-textbox-input.component.mjs +0 -17
  137. package/esm2020/components/table/create-dialog/create-dialog-data.builder.mjs +0 -32
  138. package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +0 -26
  139. package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +0 -100
  140. package/esm2020/components/table/display-column-value/base-display-column-value.component.mjs +0 -27
  141. package/esm2020/components/table/display-column-value/display-column-value.component.mjs +0 -33
  142. package/esm2020/components/table/edit-dialog/edit-data.builder.mjs +0 -76
  143. package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +0 -195
  144. package/esm2020/components/table/edit-dialog/edit-entity.builder.mjs +0 -29
  145. package/esm2020/components/table/table-data.builder.mjs +0 -205
  146. package/esm2020/components/table/table.component.mjs +0 -333
  147. package/esm2020/decorators/array/array-decorator-internal.data.mjs +0 -150
  148. package/esm2020/decorators/array/array-decorator.data.mjs +0 -7
  149. package/esm2020/decorators/base/property-decorator-internal.data.mjs +0 -58
  150. package/esm2020/decorators/base/property-decorator.data.mjs +0 -6
  151. package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +0 -33
  152. package/esm2020/decorators/boolean/boolean-decorator.data.mjs +0 -7
  153. package/esm2020/decorators/custom/custom-decorator-internal.data.mjs +0 -27
  154. package/esm2020/decorators/date/date-decorator.data.mjs +0 -7
  155. package/esm2020/decorators/file/file-decorator-internal.data.mjs +0 -97
  156. package/esm2020/decorators/file/file-decorator.data.mjs +0 -7
  157. package/esm2020/decorators/has-many/has-many-decorator-internal.data.mjs +0 -32
  158. package/esm2020/decorators/number/number-decorator-internal.data.mjs +0 -54
  159. package/esm2020/decorators/number/number-decorator.data.mjs +0 -7
  160. package/esm2020/decorators/object/object-decorator-internal.data.mjs +0 -14
  161. package/esm2020/decorators/object/object-decorator.data.mjs +0 -7
  162. package/esm2020/decorators/references-many/references-many-decorator-internal.data.mjs +0 -30
  163. package/esm2020/decorators/references-one/references-one-decorator-internal.data.mjs +0 -16
  164. package/esm2020/decorators/string/string-decorator-internal.data.mjs +0 -72
  165. package/esm2020/decorators/string/string-decorator.data.mjs +0 -7
  166. package/esm2020/services/entity.service.mjs +0 -274
  167. package/esm2020/utilities/date.utilities.mjs +0 -159
  168. package/esm2020/utilities/entity.utilities.mjs +0 -896
  169. package/esm2020/utilities/file.utilities.mjs +0 -176
  170. package/fesm2015/ngx-material-entity.mjs +0 -6300
  171. package/fesm2015/ngx-material-entity.mjs.map +0 -1
  172. package/fesm2020/ngx-material-entity.mjs.map +0 -1
  173. /package/{esm2020 → esm2022}/components/confirm-dialog/confirm-dialog-data.mjs +0 -0
  174. /package/{esm2020 → esm2022}/components/edit-page/edit-data.route.mjs +0 -0
  175. /package/{esm2020 → esm2022}/components/edit-page/page-edit-data.builder.mjs +0 -0
  176. /package/{esm2020 → esm2022}/components/get-validation-error-message.function.mjs +0 -0
  177. /package/{esm2020 → esm2022}/components/table/create-dialog/create-entity-dialog-data.mjs +0 -0
  178. /package/{esm2020 → esm2022}/components/table/default.actions.mjs +0 -0
  179. /package/{esm2020 → esm2022}/components/table/edit-dialog/edit-entity-data.mjs +0 -0
  180. /package/{esm2020 → esm2022}/components/table/table-data.mjs +0 -0
  181. /package/{esm2020 → esm2022}/decorators/array/array.decorator.mjs +0 -0
  182. /package/{esm2020 → esm2022}/decorators/base/base-property.decorator.mjs +0 -0
  183. /package/{esm2020 → esm2022}/decorators/base/decorator-types.enum.mjs +0 -0
  184. /package/{esm2020 → esm2022}/decorators/base/dropdown-value.interface.mjs +0 -0
  185. /package/{esm2020 → esm2022}/decorators/boolean/boolean.decorator.mjs +0 -0
  186. /package/{esm2020 → esm2022}/decorators/custom/custom-decorator.data.mjs +0 -0
  187. /package/{esm2020 → esm2022}/decorators/custom/custom.decorator.mjs +0 -0
  188. /package/{esm2020 → esm2022}/decorators/date/date.decorator.mjs +0 -0
  189. /package/{esm2020 → esm2022}/decorators/file/file.decorator.mjs +0 -0
  190. /package/{esm2020 → esm2022}/decorators/has-many/has-many-decorator.data.mjs +0 -0
  191. /package/{esm2020 → esm2022}/decorators/has-many/has-many.decorator.mjs +0 -0
  192. /package/{esm2020 → esm2022}/decorators/number/number.decorator.mjs +0 -0
  193. /package/{esm2020 → esm2022}/decorators/object/object.decorator.mjs +0 -0
  194. /package/{esm2020 → esm2022}/decorators/references-many/references-many-decorator.data.mjs +0 -0
  195. /package/{esm2020 → esm2022}/decorators/references-many/references-many.decorator.mjs +0 -0
  196. /package/{esm2020 → esm2022}/decorators/references-one/references-one-decorator.data.mjs +0 -0
  197. /package/{esm2020 → esm2022}/decorators/references-one/references-one.decorator.mjs +0 -0
  198. /package/{esm2020 → esm2022}/decorators/string/string.decorator.mjs +0 -0
  199. /package/{esm2020 → esm2022}/encapsulation/js-2-xml.utilities.mjs +0 -0
  200. /package/{esm2020 → esm2022}/encapsulation/jszip.utilities.mjs +0 -0
  201. /package/{esm2020 → esm2022}/encapsulation/lodash.utilities.mjs +0 -0
  202. /package/{esm2020 → esm2022}/encapsulation/reflect.utilities.mjs +0 -0
  203. /package/{esm2020 → esm2022}/functions/default-false.function.mjs +0 -0
  204. /package/{esm2020 → esm2022}/functions/default-true.function.mjs +0 -0
  205. /package/{esm2020 → esm2022}/functions/is-async-function.function.mjs +0 -0
  206. /package/{esm2020 → esm2022}/mocks/placeholder-data.png.mjs +0 -0
  207. /package/{esm2020 → esm2022}/ngx-material-entity.mjs +0 -0
  208. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  209. /package/{esm2020 → esm2022}/services/unsaved-changes.guard.mjs +0 -0
  210. /package/{esm2020 → esm2022}/utilities/selection.utilities.mjs +0 -0
@@ -0,0 +1,348 @@
1
+ import { SelectionModel } from '@angular/cdk/collections';
2
+ import { NgFor, NgIf } from '@angular/common';
3
+ import { Component, EnvironmentInjector, Input, ViewChild, inject } from '@angular/core';
4
+ import { FormsModule } from '@angular/forms';
5
+ import { MatButtonModule } from '@angular/material/button';
6
+ import { MatCheckboxModule } from '@angular/material/checkbox';
7
+ import { MatDialog, MatDialogModule } from '@angular/material/dialog';
8
+ import { MatFormFieldModule } from '@angular/material/form-field';
9
+ import { MatInputModule } from '@angular/material/input';
10
+ import { MatMenuModule } from '@angular/material/menu';
11
+ import { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';
12
+ import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
13
+ import { MatSort } from '@angular/material/sort';
14
+ import { MatTableDataSource, MatTableModule } from '@angular/material/table';
15
+ import { Router } from '@angular/router';
16
+ import { Subject, firstValueFrom, takeUntil } from 'rxjs';
17
+ import { SelectionUtilities } from '../../utilities/selection.utilities';
18
+ import { ConfirmDialogDataBuilder } from '../confirm-dialog/confirm-dialog-data.builder';
19
+ import { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';
20
+ import { CreateEntityDialogDataBuilder } from './create-dialog/create-entity-dialog-data.builder';
21
+ import { NgxMatEntityCreateDialogComponent } from './create-dialog/create-entity-dialog.component';
22
+ import { DisplayColumnValueComponent } from './display-column-value/display-column-value.component';
23
+ import { NgxMatEntityEditDialogComponent } from './edit-dialog/edit-entity-dialog.component';
24
+ import { EditEntityDataBuilder } from './edit-dialog/edit-entity.builder';
25
+ import { BaseTableActionInternal, TableDataBuilder } from './table-data.builder';
26
+ import * as i0 from "@angular/core";
27
+ import * as i1 from "@angular/material/dialog";
28
+ import * as i2 from "@angular/router";
29
+ import * as i3 from "@angular/material/input";
30
+ import * as i4 from "@angular/material/form-field";
31
+ import * as i5 from "@angular/material/checkbox";
32
+ import * as i6 from "@angular/material/table";
33
+ import * as i7 from "@angular/material/paginator";
34
+ import * as i8 from "@angular/material/button";
35
+ import * as i9 from "@angular/material/menu";
36
+ import * as i10 from "@angular/material/progress-spinner";
37
+ /**
38
+ * Generates a fully functional table for displaying, creating, updating and deleting entities
39
+ * based on the configuration passed in the @Input "tableData".
40
+ *
41
+ * It offers a lot of customization options which can be found in "TableData".
42
+ */
43
+ export class NgxMatEntityTableComponent {
44
+ dialog;
45
+ injector;
46
+ router;
47
+ /**
48
+ * The configuration for the component.
49
+ */
50
+ tableData;
51
+ data;
52
+ isLoading = true;
53
+ allowCreate;
54
+ entityService;
55
+ onDestroy = new Subject();
56
+ paginator;
57
+ sort;
58
+ filter;
59
+ displayedColumns;
60
+ dataSource = new MatTableDataSource();
61
+ selection = new SelectionModel(true, []);
62
+ SelectionUtilities = SelectionUtilities;
63
+ importAction;
64
+ constructor(dialog, injector, router) {
65
+ this.dialog = dialog;
66
+ this.injector = injector;
67
+ this.router = router;
68
+ }
69
+ /**
70
+ * Sets up all the configuration for the table and the EntityService.
71
+ */
72
+ ngOnInit() {
73
+ this.data = new TableDataBuilder(this.tableData).getResult();
74
+ this.injector.runInContext(() => {
75
+ this.allowCreate = this.data.baseData.allowCreate();
76
+ });
77
+ this.importAction = new BaseTableActionInternal({
78
+ ...this.data.baseData.importActionData,
79
+ action: () => this.startImportJson()
80
+ });
81
+ this.injector.runInContext(() => {
82
+ this.entityService = inject(this.data.baseData.EntityServiceClass);
83
+ });
84
+ const givenDisplayColumns = this.data.baseData.displayColumns.map((v) => v.displayName);
85
+ if (this.data.baseData.tableActions.filter(tA => tA.type === 'multi-select').length) {
86
+ this.displayedColumns = ['select'].concat(givenDisplayColumns);
87
+ }
88
+ else {
89
+ this.displayedColumns = givenDisplayColumns;
90
+ }
91
+ this.dataSource.sortingDataAccessor = (entity, header) => {
92
+ return this.injector.runInContext(() => {
93
+ return this.data.baseData.displayColumns.find((dp) => dp.displayName === header)?.value(entity);
94
+ });
95
+ };
96
+ this.dataSource.sort = this.sort;
97
+ this.dataSource.filterPredicate = (entity, filter) => {
98
+ const searchStr = this.data.baseData.searchString(entity);
99
+ const formattedSearchString = searchStr.toLowerCase();
100
+ const formattedFilterString = filter.toLowerCase();
101
+ return formattedSearchString.includes(formattedFilterString);
102
+ };
103
+ this.dataSource.filter = this.filter;
104
+ this.dataSource.paginator = this.paginator;
105
+ this.entityService.entitiesSubject.pipe(takeUntil(this.onDestroy)).subscribe((entities) => {
106
+ this.dataSource.data = entities;
107
+ this.selection.clear();
108
+ });
109
+ void this.entityService.read().then(() => {
110
+ this.isLoading = false;
111
+ });
112
+ }
113
+ /**
114
+ * Gets the value to display in the column.
115
+ * Runs in environment context to enable injection.
116
+ *
117
+ * @param entity - The entity to get the value from.
118
+ * @param displayColumn - The display column to get the value from.
119
+ * @returns The value of the display column.
120
+ */
121
+ getDisplayColumnValue(entity, displayColumn) {
122
+ return this.injector.runInContext(() => {
123
+ return displayColumn.value(entity);
124
+ });
125
+ }
126
+ startImportJson() {
127
+ const input = document.createElement('input');
128
+ input.type = 'file';
129
+ input.accept = 'application/json';
130
+ input.onchange = async () => {
131
+ if (input.files) {
132
+ this.importJson(input.files[0]);
133
+ }
134
+ };
135
+ input.click();
136
+ }
137
+ importJson(file) {
138
+ const dialogData = new ConfirmDialogDataBuilder(this.importAction.confirmDialogData)
139
+ .withDefault('text', this.data.baseData.importActionData.confirmDialogData.text)
140
+ .withDefault('title', this.importAction.displayName)
141
+ .getResult();
142
+ const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
143
+ data: dialogData,
144
+ autoFocus: false,
145
+ restoreFocus: false
146
+ });
147
+ dialogRef.afterClosed().subscribe(res => {
148
+ if (res == true) {
149
+ void this.entityService.import(file);
150
+ }
151
+ });
152
+ }
153
+ /**
154
+ * Edits an entity. This either calls the edit-Method provided by the user or uses a default edit-dialog.
155
+ *
156
+ * @param entity - The entity that should be updated.
157
+ * @param dCol - The display column. Is needed if a custom component was used that handles the click event differently.
158
+ * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.
159
+ */
160
+ editEntity(entity, dCol) {
161
+ if (dCol.disableClick == true) {
162
+ return;
163
+ }
164
+ if (!(this.allowUpdate(entity) || this.allowRead(entity))) {
165
+ return;
166
+ }
167
+ if (!this.data.baseData.EntityClass) {
168
+ throw new Error('No "EntityClass" specified for this table');
169
+ }
170
+ if (this.data.baseData.edit) {
171
+ this.data.baseData.edit(new this.data.baseData.EntityClass(entity));
172
+ return;
173
+ }
174
+ if (this.data.baseData.defaultEdit == 'page') {
175
+ this.editDefaultPage(new this.data.baseData.EntityClass(entity));
176
+ return;
177
+ }
178
+ void this.editDefaultDialog(new this.data.baseData.EntityClass(entity));
179
+ }
180
+ /**
181
+ * Whether updating the provided entity is allowed.
182
+ *
183
+ * @param entity - The entity that the user wants to edit.
184
+ * @returns True when the user can edit the provided entity and false otherwise.
185
+ */
186
+ allowUpdate(entity) {
187
+ return this.injector.runInContext(() => {
188
+ return this.data.baseData.allowUpdate(entity);
189
+ });
190
+ }
191
+ /**
192
+ * Whether viewing the provided entity is allowed.
193
+ *
194
+ * @param entity - The entity that the user wants to view.
195
+ * @returns True when the user can view the provided entity and false otherwise.
196
+ */
197
+ allowRead(entity) {
198
+ return this.injector.runInContext(() => {
199
+ return this.data.baseData.allowRead(entity);
200
+ });
201
+ }
202
+ editDefaultPage(entity) {
203
+ void this.router.navigate(['', this.entityService.editBaseRoute, entity.id]);
204
+ }
205
+ async editDefaultDialog(entity) {
206
+ const inputDialogData = {
207
+ entity: entity,
208
+ EntityServiceClass: this.data.baseData.EntityServiceClass,
209
+ allowUpdate: this.data.baseData.allowUpdate,
210
+ allowDelete: this.data.baseData.allowDelete,
211
+ editData: this.data.editData
212
+ };
213
+ const dialogData = new EditEntityDataBuilder(inputDialogData).getResult();
214
+ const res = await firstValueFrom(this.dialog.open(NgxMatEntityEditDialogComponent, {
215
+ data: dialogData,
216
+ minWidth: '60%',
217
+ autoFocus: false,
218
+ restoreFocus: false
219
+ }).afterClosed());
220
+ if (res === 0) {
221
+ const data = this.dataSource.data;
222
+ data[this.dataSource.data.findIndex((e) => e[this.entityService.idKey] === entity[this.entityService.idKey])] = entity;
223
+ this.dataSource.data = data;
224
+ this.selection.clear();
225
+ }
226
+ }
227
+ /**
228
+ * Creates a new Entity. This either calls the create-Method provided by the user or uses a default create-dialog.
229
+ *
230
+ * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.
231
+ */
232
+ createEntity() {
233
+ this.injector.runInContext(() => {
234
+ if (this.data.baseData.allowCreate()) {
235
+ if (!this.data.baseData.EntityClass) {
236
+ throw new Error('No "EntityClass" specified for this table');
237
+ }
238
+ if (this.data.baseData.create) {
239
+ this.data.baseData.create(new this.data.baseData.EntityClass());
240
+ }
241
+ else {
242
+ this.createDefault(new this.data.baseData.EntityClass());
243
+ }
244
+ }
245
+ });
246
+ }
247
+ createDefault(entity) {
248
+ const dialogData = new CreateEntityDialogDataBuilder({
249
+ entity: entity,
250
+ EntityServiceClass: this.data.baseData.EntityServiceClass,
251
+ createDialogData: this.data.createDialogData
252
+ }).getResult();
253
+ this.dialog.open(NgxMatEntityCreateDialogComponent, {
254
+ data: dialogData,
255
+ minWidth: '60%',
256
+ autoFocus: false,
257
+ restoreFocus: false
258
+ });
259
+ }
260
+ /**
261
+ * Runs the TableAction for all selected entries.
262
+ * Also handles confirmation with an additional dialog if configured.
263
+ *
264
+ * @param action - The TableAction to run.
265
+ */
266
+ runTableAction(action) {
267
+ const requireConfirmDialog = this.injector.runInContext(() => {
268
+ return action.requireConfirmDialog(this.selection.selected);
269
+ });
270
+ if (!requireConfirmDialog) {
271
+ this.confirmRunTableAction(action);
272
+ return;
273
+ }
274
+ const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
275
+ data: action.confirmDialogData,
276
+ autoFocus: false,
277
+ restoreFocus: false
278
+ });
279
+ dialogRef.afterClosed().subscribe(res => {
280
+ if (res == true) {
281
+ this.confirmRunTableAction(action);
282
+ }
283
+ });
284
+ }
285
+ confirmRunTableAction(action) {
286
+ void this.injector.runInContext(async () => {
287
+ await action.action(this.selection.selected);
288
+ });
289
+ }
290
+ /**
291
+ * Checks if an TableAction is disabled (e.g. Because no entries have been selected).
292
+ *
293
+ * @param action - The TableAction to check.
294
+ * @returns Whether or not the Action can be used.
295
+ */
296
+ tableActionDisabled(action) {
297
+ return this.injector.runInContext(() => {
298
+ return !action.enabled(this.selection.selected);
299
+ });
300
+ }
301
+ ngOnDestroy() {
302
+ this.onDestroy.next(undefined);
303
+ this.onDestroy.complete();
304
+ }
305
+ /**
306
+ * Applies the search input to filter the table entries.
307
+ *
308
+ * @param event - The keyup-event which contains the search-string of the user.
309
+ */
310
+ applyFilter(event) {
311
+ const filterValue = event.target.value;
312
+ this.dataSource.filter = filterValue.trim().toLowerCase();
313
+ }
314
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityTableComponent, deps: [{ token: i1.MatDialog }, { token: i0.EnvironmentInjector }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component });
315
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: NgxMatEntityTableComponent, isStandalone: true, selector: "ngx-mat-entity-table", inputs: { tableData: "tableData" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true, static: true }, { propertyName: "sort", first: true, predicate: MatSort, descendants: true, static: true }, { propertyName: "filter", first: true, predicate: ["filter"], descendants: true, static: true }], ngImport: i0, template: "<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n <mat-label>{{data.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyFilter($event)\">\n </mat-form-field>\n <div\n *ngIf=\"data.baseData.tableActions.length\"\n [class.col-lg-2]=\"allowCreate\"\n [class.col-lg-4]=\"!allowCreate\"\n [class.col-md-3]=\"allowCreate\"\n [class.col-md-6]=\"!allowCreate\"\n [class.col-sm-6]=\"allowCreate\"\n [class.col-sm-12]=\"!allowCreate\"\n >\n <button type=\"button\" class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n {{data.baseData.tableActionsLabel}}\n </button>\n </div>\n <mat-menu #menu=\"matMenu\">\n <button *ngIf=\"data.baseData.allowJsonImport\" type=\"button\" [disabled]=\"tableActionDisabled(importAction)\" (click)=\"runTableAction(importAction)\" mat-menu-item>\n {{importAction.displayName}}\n </button>\n <button type=\"button\" *ngFor=\"let action of data.baseData.tableActions\" [disabled]=\"tableActionDisabled(action)\" (click)=\"runTableAction(action)\" mat-menu-item>\n {{action.displayName}}\n </button>\n </mat-menu>\n\n <div\n *ngIf=\"allowCreate\"\n [class.col-lg-2]=\"data.baseData.tableActions.length\"\n [class.col-lg-4]=\"!data.baseData.tableActions.length\"\n [class.col-md-3]=\"data.baseData.tableActions.length\"\n [class.col-md-6]=\"!data.baseData.tableActions.length\"\n [class.col-sm-6]=\"data.baseData.tableActions.length\"\n [class.col-sm-12]=\"!data.baseData.tableActions.length\"\n >\n <button type=\"button\" class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n {{data.baseData.createButtonLabel}}\n </button>\n </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n <mat-table [dataSource]=\"dataSource\" matSort>\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"\n [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\"\n [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selection.toggle(entity) : null\"\n [checked]=\"selection.isSelected(entity)\">\n </mat-checkbox>\n </mat-cell>\n </ng-container>\n\n <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell class=\"entity\" [class.enabled]=\"!dCol.disableClick && (allowUpdate(entity) || allowRead(entity))\"\n (click)=\"editEntity(entity, dCol)\"\n *matCellDef=\"let entity\"\n >\n <ng-container *ngIf=\"dCol.Component\">\n <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n </ng-container>\n <ng-container *ngIf=\"!dCol.Component\">\n {{getDisplayColumnValue(entity, dCol)}}\n </ng-container>\n </mat-cell>\n </ng-container>\n\n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n <mat-spinner *ngIf=\"isLoading && data.baseData.displayLoadingSpinner\">\n </mat-spinner>\n\n <mat-paginator [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</div>", styles: [".mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}button{width:100%}mat-spinner{margin:10px auto}.title{text-align:center}.actions-button,.create-button{height:56px;line-height:24px;font-size:16px}.mat-column-select{flex:0 0 75px}.enabled:hover{cursor:pointer}@media (max-width: 767px){.actions-button,.create-button{margin-bottom:15px}}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i5.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i6.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i6.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i6.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i6.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i6.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i6.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i6.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i6.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i6.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i6.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i7.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i8.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i9.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i9.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i9.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i10.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: DisplayColumnValueComponent, selector: "display-column-value", inputs: ["entity", "ComponentClass"] }] });
316
+ }
317
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityTableComponent, decorators: [{
318
+ type: Component,
319
+ args: [{ selector: 'ngx-mat-entity-table', standalone: true, imports: [
320
+ NgIf,
321
+ NgFor,
322
+ MatInputModule,
323
+ FormsModule,
324
+ MatFormFieldModule,
325
+ MatCheckboxModule,
326
+ MatTableModule,
327
+ MatPaginatorModule,
328
+ MatButtonModule,
329
+ MatMenuModule,
330
+ MatDialogModule,
331
+ MatProgressSpinnerModule,
332
+ NgxMatEntityCreateDialogComponent,
333
+ NgxMatEntityEditDialogComponent,
334
+ DisplayColumnValueComponent
335
+ ], template: "<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n <mat-label>{{data.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyFilter($event)\">\n </mat-form-field>\n <div\n *ngIf=\"data.baseData.tableActions.length\"\n [class.col-lg-2]=\"allowCreate\"\n [class.col-lg-4]=\"!allowCreate\"\n [class.col-md-3]=\"allowCreate\"\n [class.col-md-6]=\"!allowCreate\"\n [class.col-sm-6]=\"allowCreate\"\n [class.col-sm-12]=\"!allowCreate\"\n >\n <button type=\"button\" class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n {{data.baseData.tableActionsLabel}}\n </button>\n </div>\n <mat-menu #menu=\"matMenu\">\n <button *ngIf=\"data.baseData.allowJsonImport\" type=\"button\" [disabled]=\"tableActionDisabled(importAction)\" (click)=\"runTableAction(importAction)\" mat-menu-item>\n {{importAction.displayName}}\n </button>\n <button type=\"button\" *ngFor=\"let action of data.baseData.tableActions\" [disabled]=\"tableActionDisabled(action)\" (click)=\"runTableAction(action)\" mat-menu-item>\n {{action.displayName}}\n </button>\n </mat-menu>\n\n <div\n *ngIf=\"allowCreate\"\n [class.col-lg-2]=\"data.baseData.tableActions.length\"\n [class.col-lg-4]=\"!data.baseData.tableActions.length\"\n [class.col-md-3]=\"data.baseData.tableActions.length\"\n [class.col-md-6]=\"!data.baseData.tableActions.length\"\n [class.col-sm-6]=\"data.baseData.tableActions.length\"\n [class.col-sm-12]=\"!data.baseData.tableActions.length\"\n >\n <button type=\"button\" class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n {{data.baseData.createButtonLabel}}\n </button>\n </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n <mat-table [dataSource]=\"dataSource\" matSort>\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"\n [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\"\n [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selection.toggle(entity) : null\"\n [checked]=\"selection.isSelected(entity)\">\n </mat-checkbox>\n </mat-cell>\n </ng-container>\n\n <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell class=\"entity\" [class.enabled]=\"!dCol.disableClick && (allowUpdate(entity) || allowRead(entity))\"\n (click)=\"editEntity(entity, dCol)\"\n *matCellDef=\"let entity\"\n >\n <ng-container *ngIf=\"dCol.Component\">\n <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n </ng-container>\n <ng-container *ngIf=\"!dCol.Component\">\n {{getDisplayColumnValue(entity, dCol)}}\n </ng-container>\n </mat-cell>\n </ng-container>\n\n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n <mat-spinner *ngIf=\"isLoading && data.baseData.displayLoadingSpinner\">\n </mat-spinner>\n\n <mat-paginator [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</div>", styles: [".mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}button{width:100%}mat-spinner{margin:10px auto}.title{text-align:center}.actions-button,.create-button{height:56px;line-height:24px;font-size:16px}.mat-column-select{flex:0 0 75px}.enabled:hover{cursor:pointer}@media (max-width: 767px){.actions-button,.create-button{margin-bottom:15px}}\n"] }]
336
+ }], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i0.EnvironmentInjector }, { type: i2.Router }]; }, propDecorators: { tableData: [{
337
+ type: Input
338
+ }], paginator: [{
339
+ type: ViewChild,
340
+ args: [MatPaginator, { static: true }]
341
+ }], sort: [{
342
+ type: ViewChild,
343
+ args: [MatSort, { static: true }]
344
+ }], filter: [{
345
+ type: ViewChild,
346
+ args: ['filter', { static: true }]
347
+ }] } });
348
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/table/table.component.ts","../../../../../projects/ngx-material-entity/src/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\nimport { NgFor, NgIf } from '@angular/common';\nimport { Component, EnvironmentInjector, Input, OnDestroy, OnInit, ViewChild, inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatSort } from '@angular/material/sort';\nimport { MatTableDataSource, MatTableModule } from '@angular/material/table';\nimport { Router } from '@angular/router';\nimport { Subject, firstValueFrom, takeUntil } from 'rxjs';\nimport { BaseEntityType, Entity } from '../../classes/entity.model';\nimport { EntityService } from '../../services/entity.service';\nimport { SelectionUtilities } from '../../utilities/selection.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { CreateEntityDialogDataBuilder, CreateEntityDialogDataInternal } from './create-dialog/create-entity-dialog-data.builder';\nimport { NgxMatEntityCreateDialogComponent } from './create-dialog/create-entity-dialog.component';\nimport { DisplayColumnValueComponent } from './display-column-value/display-column-value.component';\nimport { EditEntityData } from './edit-dialog/edit-entity-data';\nimport { NgxMatEntityEditDialogComponent } from './edit-dialog/edit-entity-dialog.component';\nimport { EditEntityDataBuilder, EditEntityDataInternal } from './edit-dialog/edit-entity.builder';\nimport { DisplayColumn, TableData } from './table-data';\nimport { BaseTableActionInternal, TableActionInternal, TableDataBuilder, TableDataInternal } from './table-data.builder';\n\n/**\n * Generates a fully functional table for displaying, creating, updating and deleting entities\n * based on the configuration passed in the @Input \"tableData\".\n *\n * It offers a lot of customization options which can be found in \"TableData\".\n */\n@Component({\n    selector: 'ngx-mat-entity-table',\n    templateUrl: './table.component.html',\n    styleUrls: ['./table.component.scss'],\n    standalone: true,\n    imports: [\n        NgIf,\n        NgFor,\n        MatInputModule,\n        FormsModule,\n        MatFormFieldModule,\n        MatCheckboxModule,\n        MatTableModule,\n        MatPaginatorModule,\n        MatButtonModule,\n        MatMenuModule,\n        MatDialogModule,\n        MatProgressSpinnerModule,\n        NgxMatEntityCreateDialogComponent,\n        NgxMatEntityEditDialogComponent,\n        DisplayColumnValueComponent\n    ]\n})\nexport class NgxMatEntityTableComponent<EntityType extends BaseEntityType<Entity>> implements OnInit, OnDestroy {\n\n    /**\n     * The configuration for the component.\n     */\n    @Input()\n    tableData!: TableData<EntityType>;\n\n    data!: TableDataInternal<EntityType>;\n\n    isLoading: boolean = true;\n    allowCreate!: boolean;\n\n    private entityService!: EntityService<EntityType>;\n    private readonly onDestroy: Subject<void> = new Subject<void>();\n    @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\n    @ViewChild(MatSort, { static: true }) sort!: MatSort;\n    @ViewChild('filter', { static: true }) filter!: string;\n    displayedColumns!: string[];\n    dataSource: MatTableDataSource<EntityType> = new MatTableDataSource();\n    selection: SelectionModel<EntityType> = new SelectionModel<EntityType>(true, []);\n\n    SelectionUtilities: typeof SelectionUtilities = SelectionUtilities;\n\n    importAction!: BaseTableActionInternal;\n\n    constructor(\n        private readonly dialog: MatDialog,\n        private readonly injector: EnvironmentInjector,\n        private readonly router: Router\n    ) {}\n\n    /**\n     * Sets up all the configuration for the table and the EntityService.\n     */\n    ngOnInit(): void {\n        this.data = new TableDataBuilder(this.tableData).getResult();\n        this.injector.runInContext(() => {\n            this.allowCreate = this.data.baseData.allowCreate();\n        });\n\n        this.importAction = new BaseTableActionInternal({\n            ...this.data.baseData.importActionData,\n            action: () => this.startImportJson()\n        });\n\n        this.injector.runInContext(() => {\n            this.entityService = inject<EntityService<EntityType>>(this.data.baseData.EntityServiceClass);\n        });\n\n        const givenDisplayColumns: string[] = this.data.baseData.displayColumns.map((v) => v.displayName);\n        if (this.data.baseData.tableActions.filter(tA => tA.type === 'multi-select').length) {\n            this.displayedColumns = ['select'].concat(givenDisplayColumns);\n        }\n        else {\n            this.displayedColumns = givenDisplayColumns;\n        }\n\n        this.dataSource.sortingDataAccessor = (entity: EntityType, header: string) => {\n            return this.injector.runInContext(() => {\n                return this.data.baseData.displayColumns.find((dp) => dp.displayName === header)?.value(entity) as string;\n            });\n        };\n        this.dataSource.sort = this.sort;\n        this.dataSource.filterPredicate = (entity: EntityType, filter: string) => {\n            const searchStr: string = this.data.baseData.searchString(entity);\n            const formattedSearchString: string = searchStr.toLowerCase();\n            const formattedFilterString: string = filter.toLowerCase();\n            return formattedSearchString.includes(formattedFilterString);\n        };\n        this.dataSource.filter = this.filter;\n        this.dataSource.paginator = this.paginator;\n\n        this.entityService.entitiesSubject.pipe(takeUntil(this.onDestroy)).subscribe((entities) => {\n            this.dataSource.data = entities;\n            this.selection.clear();\n        });\n        void this.entityService.read().then(() => {\n            this.isLoading = false;\n        });\n    }\n\n    /**\n     * Gets the value to display in the column.\n     * Runs in environment context to enable injection.\n     *\n     * @param entity - The entity to get the value from.\n     * @param displayColumn - The display column to get the value from.\n     * @returns The value of the display column.\n     */\n    getDisplayColumnValue(entity: EntityType, displayColumn: DisplayColumn<EntityType>): unknown {\n        return this.injector.runInContext(() => {\n            return displayColumn.value(entity);\n        });\n    }\n\n    private startImportJson(): void {\n        const input: HTMLInputElement = document.createElement('input');\n        input.type = 'file';\n        input.accept = 'application/json';\n        input.onchange = async () => {\n            if (input.files) {\n                this.importJson(input.files[0]);\n            }\n        };\n        input.click();\n    }\n\n    private importJson(file: File): void {\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.importAction.confirmDialogData)\n            .withDefault('text', this.data.baseData.importActionData.confirmDialogData.text)\n            .withDefault('title', this.importAction.displayName)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                void this.entityService.import(file);\n            }\n        });\n    }\n\n    /**\n     * Edits an entity. This either calls the edit-Method provided by the user or uses a default edit-dialog.\n     *\n     * @param entity - The entity that should be updated.\n     * @param dCol - The display column. Is needed if a custom component was used that handles the click event differently.\n     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    editEntity(entity: EntityType, dCol: DisplayColumn<EntityType>): void {\n        if (dCol.disableClick == true) {\n            return;\n        }\n        if (!(this.allowUpdate(entity) || this.allowRead(entity))) {\n            return;\n        }\n        if (!this.data.baseData.EntityClass) {\n            throw new Error('No \"EntityClass\" specified for this table');\n        }\n        if (this.data.baseData.edit) {\n            this.data.baseData.edit(new this.data.baseData.EntityClass(entity));\n            return;\n        }\n        if (this.data.baseData.defaultEdit == 'page') {\n            this.editDefaultPage(new this.data.baseData.EntityClass(entity));\n            return;\n        }\n        void this.editDefaultDialog(new this.data.baseData.EntityClass(entity));\n    }\n\n    /**\n     * Whether updating the provided entity is allowed.\n     *\n     * @param entity - The entity that the user wants to edit.\n     * @returns True when the user can edit the provided entity and false otherwise.\n     */\n    allowUpdate(entity: EntityType): boolean {\n        return this.injector.runInContext(() => {\n            return this.data.baseData.allowUpdate(entity);\n        });\n    }\n\n    /**\n     * Whether viewing the provided entity is allowed.\n     *\n     * @param entity - The entity that the user wants to view.\n     * @returns True when the user can view the provided entity and false otherwise.\n     */\n    allowRead(entity: EntityType): boolean {\n        return this.injector.runInContext(() => {\n            return this.data.baseData.allowRead(entity);\n        });\n    }\n\n    private editDefaultPage(entity: EntityType): void {\n        void this.router.navigate(['', this.entityService.editBaseRoute, entity.id]);\n    }\n\n    private async editDefaultDialog(entity: EntityType): Promise<void> {\n        const inputDialogData: EditEntityData<EntityType> = {\n            entity: entity,\n            EntityServiceClass: this.data.baseData.EntityServiceClass,\n            allowUpdate: this.data.baseData.allowUpdate,\n            allowDelete: this.data.baseData.allowDelete,\n            editData: this.data.editData\n        };\n        const dialogData: EditEntityDataInternal<EntityType> = new EditEntityDataBuilder(inputDialogData).getResult();\n        const res: number = await firstValueFrom(\n            this.dialog.open(NgxMatEntityEditDialogComponent, {\n                data: dialogData,\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }).afterClosed()\n        ) as number;\n        if (res === 0) {\n            const data: EntityType[] = this.dataSource.data;\n            data[this.dataSource.data.findIndex((e) => e[this.entityService.idKey] === entity[this.entityService.idKey])] = entity;\n            this.dataSource.data = data;\n            this.selection.clear();\n        }\n    }\n\n    /**\n     * Creates a new Entity. This either calls the create-Method provided by the user or uses a default create-dialog.\n     *\n     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    createEntity(): void {\n        this.injector.runInContext(() => {\n            if (this.data.baseData.allowCreate()) {\n                if (!this.data.baseData.EntityClass) {\n                    throw new Error('No \"EntityClass\" specified for this table');\n                }\n                if (this.data.baseData.create) {\n                    this.data.baseData.create(new this.data.baseData.EntityClass());\n                }\n                else {\n                    this.createDefault(new this.data.baseData.EntityClass());\n                }\n            }\n        });\n    }\n\n    private createDefault(entity: EntityType): void {\n        const dialogData: CreateEntityDialogDataInternal<EntityType> = new CreateEntityDialogDataBuilder(\n            {\n                entity: entity,\n                EntityServiceClass: this.data.baseData.EntityServiceClass,\n                createDialogData: this.data.createDialogData\n            }\n        ).getResult();\n        this.dialog.open(NgxMatEntityCreateDialogComponent, {\n            data: dialogData,\n            minWidth: '60%',\n            autoFocus: false,\n            restoreFocus: false\n        });\n    }\n\n    /**\n     * Runs the TableAction for all selected entries.\n     * Also handles confirmation with an additional dialog if configured.\n     *\n     * @param action - The TableAction to run.\n     */\n    runTableAction(action: TableActionInternal<EntityType>): void {\n        const requireConfirmDialog: boolean = this.injector.runInContext(() => {\n            return action.requireConfirmDialog(this.selection.selected);\n        });\n\n        if (!requireConfirmDialog) {\n            this.confirmRunTableAction(action);\n            return;\n        }\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: action.confirmDialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmRunTableAction(action);\n            }\n        });\n    }\n\n    private confirmRunTableAction(action: TableActionInternal<EntityType>): void {\n        void this.injector.runInContext(async () => {\n            await action.action(this.selection.selected);\n        });\n    }\n\n    /**\n     * Checks if an TableAction is disabled (e.g. Because no entries have been selected).\n     *\n     * @param action - The TableAction to check.\n     * @returns Whether or not the Action can be used.\n     */\n    tableActionDisabled(action: TableActionInternal<EntityType>): boolean {\n        return this.injector.runInContext(() => {\n            return !action.enabled(this.selection.selected);\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.onDestroy.next(undefined);\n        this.onDestroy.complete();\n    }\n\n    /**\n     * Applies the search input to filter the table entries.\n     *\n     * @param event - The keyup-event which contains the search-string of the user.\n     */\n    applyFilter(event: Event): void {\n        const filterValue: string = (event.target as HTMLInputElement).value;\n        this.dataSource.filter = filterValue.trim().toLowerCase();\n    }\n\n\n}","<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n    <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n        <mat-label>{{data.baseData.searchLabel}}</mat-label>\n        <input matInput (keyup)=\"applyFilter($event)\">\n    </mat-form-field>\n    <div\n        *ngIf=\"data.baseData.tableActions.length\"\n        [class.col-lg-2]=\"allowCreate\"\n        [class.col-lg-4]=\"!allowCreate\"\n        [class.col-md-3]=\"allowCreate\"\n        [class.col-md-6]=\"!allowCreate\"\n        [class.col-sm-6]=\"allowCreate\"\n        [class.col-sm-12]=\"!allowCreate\"\n    >\n        <button type=\"button\" class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n            {{data.baseData.tableActionsLabel}}\n        </button>\n    </div>\n    <mat-menu #menu=\"matMenu\">\n        <button *ngIf=\"data.baseData.allowJsonImport\" type=\"button\" [disabled]=\"tableActionDisabled(importAction)\" (click)=\"runTableAction(importAction)\" mat-menu-item>\n            {{importAction.displayName}}\n        </button>\n        <button type=\"button\" *ngFor=\"let action of data.baseData.tableActions\" [disabled]=\"tableActionDisabled(action)\" (click)=\"runTableAction(action)\" mat-menu-item>\n            {{action.displayName}}\n        </button>\n    </mat-menu>\n\n    <div\n        *ngIf=\"allowCreate\"\n        [class.col-lg-2]=\"data.baseData.tableActions.length\"\n        [class.col-lg-4]=\"!data.baseData.tableActions.length\"\n        [class.col-md-3]=\"data.baseData.tableActions.length\"\n        [class.col-md-6]=\"!data.baseData.tableActions.length\"\n        [class.col-sm-6]=\"data.baseData.tableActions.length\"\n        [class.col-sm-12]=\"!data.baseData.tableActions.length\"\n    >\n        <button type=\"button\" class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n            {{data.baseData.createButtonLabel}}\n        </button>\n    </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n    <mat-table [dataSource]=\"dataSource\" matSort>\n        <!-- select Column -->\n        <ng-container matColumnDef=\"select\">\n            <mat-header-cell *matHeaderCellDef>\n                <mat-checkbox (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"\n                    [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\"\n                    [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\">\n                </mat-checkbox>\n            </mat-header-cell>\n            <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n                <mat-checkbox (click)=\"$event.stopPropagation()\"\n                    (change)=\"$event ? selection.toggle(entity) : null\"\n                    [checked]=\"selection.isSelected(entity)\">\n                </mat-checkbox>\n            </mat-cell>\n        </ng-container>\n\n        <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n            <mat-header-cell *matHeaderCellDef mat-sort-header>\n                {{dCol.displayName}}\n            </mat-header-cell>\n            <mat-cell class=\"entity\" [class.enabled]=\"!dCol.disableClick && (allowUpdate(entity) || allowRead(entity))\"\n                (click)=\"editEntity(entity, dCol)\"\n                *matCellDef=\"let entity\"\n            >\n                <ng-container *ngIf=\"dCol.Component\">\n                    <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n                </ng-container>\n                <ng-container *ngIf=\"!dCol.Component\">\n                    {{getDisplayColumnValue(entity, dCol)}}\n                </ng-container>\n            </mat-cell>\n        </ng-container>\n\n        <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n        <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n    </mat-table>\n\n    <mat-spinner *ngIf=\"isLoading && data.baseData.displayLoadingSpinner\">\n    </mat-spinner>\n\n    <mat-paginator [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</div>"]}