tin-spa 2.2.2 → 2.3.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 (106) hide show
  1. package/esm2020/lib/components/accounts/accountDialog.component.mjs +2 -2
  2. package/esm2020/lib/components/accounts/accounts.component.mjs +2 -2
  3. package/esm2020/lib/components/attach/attach.component.mjs +1 -20
  4. package/esm2020/lib/components/change-password/change-password.component.mjs +2 -2
  5. package/esm2020/lib/components/create-account/create-account.component.mjs +2 -2
  6. package/esm2020/lib/components/customers/customers.component.mjs +2 -2
  7. package/esm2020/lib/components/departments/departments.component.mjs +6 -26
  8. package/esm2020/lib/components/employees/employees.component.mjs +10 -53
  9. package/esm2020/lib/components/form/form.component.mjs +2 -2
  10. package/esm2020/lib/components/inventory/inventory.component.mjs +2 -2
  11. package/esm2020/lib/components/inventory/quantityDialog.component.mjs +2 -2
  12. package/esm2020/lib/components/invitations-table/invitations-table.component.mjs +2 -2
  13. package/esm2020/lib/components/list-dialog/list-dialog.component.mjs +2 -2
  14. package/esm2020/lib/components/login/login.component.mjs +2 -2
  15. package/esm2020/lib/components/logs/logs.component.mjs +2 -2
  16. package/esm2020/lib/components/membership/membership.component.mjs +2 -2
  17. package/esm2020/lib/components/nav-menu/nav-menu.component.mjs +2 -2
  18. package/esm2020/lib/components/plans/plans.component.mjs +2 -2
  19. package/esm2020/lib/components/positions/positions.component.mjs +13 -6
  20. package/esm2020/lib/components/profile/profile.component.mjs +2 -2
  21. package/esm2020/lib/components/recover-account/recover-account.component.mjs +2 -2
  22. package/esm2020/lib/components/roles/addRoleDialog.component.mjs +2 -2
  23. package/esm2020/lib/components/roles/roles.component.mjs +2 -2
  24. package/esm2020/lib/components/settings/settings.component.mjs +2 -2
  25. package/esm2020/lib/components/signup/signup.component.mjs +2 -2
  26. package/esm2020/lib/components/suppliers/suppliers.component.mjs +2 -2
  27. package/esm2020/lib/components/table/detailsDialog.component.mjs +74 -142
  28. package/esm2020/lib/components/table/table.component.mjs +151 -333
  29. package/esm2020/lib/components/table-action/table-action.component.mjs +46 -0
  30. package/esm2020/lib/components/table-header/table-header.component.mjs +52 -0
  31. package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +78 -139
  32. package/esm2020/lib/components/table-internal/table-internal.component.mjs +153 -334
  33. package/esm2020/lib/components/table-row/table-row.component.mjs +58 -0
  34. package/esm2020/lib/components/tasks/tasks.component.mjs +2 -2
  35. package/esm2020/lib/components/tenant-settings/inviteDialog.component.mjs +2 -2
  36. package/esm2020/lib/components/tenant-settings/tenant-settings.component.mjs +2 -2
  37. package/esm2020/lib/components/tenants/tenants.component.mjs +2 -2
  38. package/esm2020/lib/components/tiles/tiles.component.mjs +2 -2
  39. package/esm2020/lib/components/transactions/transactDialog.component.mjs +2 -2
  40. package/esm2020/lib/components/transactions/transactions.component.mjs +2 -2
  41. package/esm2020/lib/components/users/users.component.mjs +2 -2
  42. package/esm2020/lib/components/viewer/viewer.component.mjs +2 -2
  43. package/esm2020/lib/components/welcome/welcome.component.mjs +2 -2
  44. package/esm2020/lib/services/button.service.mjs +100 -0
  45. package/esm2020/lib/services/condition.service.mjs +32 -0
  46. package/esm2020/lib/services/datalib.service.mjs +381 -0
  47. package/esm2020/lib/services/dialog.service.mjs +38 -0
  48. package/esm2020/lib/services/table-config.service.mjs +26 -0
  49. package/esm2020/lib/tin-spa.module.mjs +6 -3
  50. package/esm2020/public-api.mjs +3 -2
  51. package/fesm2015/tin-spa.mjs +938 -1061
  52. package/fesm2015/tin-spa.mjs.map +1 -1
  53. package/fesm2020/tin-spa.mjs +947 -1058
  54. package/fesm2020/tin-spa.mjs.map +1 -1
  55. package/lib/components/accounts/accountDialog.component.d.ts +1 -1
  56. package/lib/components/accounts/accounts.component.d.ts +1 -1
  57. package/lib/components/attach/attach.component.d.ts +0 -19
  58. package/lib/components/change-password/change-password.component.d.ts +1 -1
  59. package/lib/components/create-account/create-account.component.d.ts +1 -1
  60. package/lib/components/customers/customers.component.d.ts +1 -1
  61. package/lib/components/departments/departments.component.d.ts +2 -5
  62. package/lib/components/employees/employees.component.d.ts +3 -14
  63. package/lib/components/form/form.component.d.ts +1 -1
  64. package/lib/components/inventory/inventory.component.d.ts +1 -1
  65. package/lib/components/inventory/quantityDialog.component.d.ts +1 -1
  66. package/lib/components/invitations-table/invitations-table.component.d.ts +1 -1
  67. package/lib/components/list-dialog/list-dialog.component.d.ts +1 -1
  68. package/lib/components/login/login.component.d.ts +1 -1
  69. package/lib/components/logs/logs.component.d.ts +1 -1
  70. package/lib/components/membership/membership.component.d.ts +1 -1
  71. package/lib/components/nav-menu/nav-menu.component.d.ts +1 -1
  72. package/lib/components/plans/plans.component.d.ts +1 -1
  73. package/lib/components/positions/positions.component.d.ts +5 -1
  74. package/lib/components/profile/profile.component.d.ts +1 -1
  75. package/lib/components/recover-account/recover-account.component.d.ts +1 -1
  76. package/lib/components/roles/addRoleDialog.component.d.ts +1 -1
  77. package/lib/components/roles/roles.component.d.ts +1 -1
  78. package/lib/components/settings/settings.component.d.ts +1 -1
  79. package/lib/components/signup/signup.component.d.ts +1 -1
  80. package/lib/components/suppliers/suppliers.component.d.ts +1 -1
  81. package/lib/components/table/detailsDialog.component.d.ts +11 -4
  82. package/lib/components/table/table.component.d.ts +28 -15
  83. package/lib/components/table-action/table-action.component.d.ts +22 -0
  84. package/lib/components/table-header/table-header.component.d.ts +22 -0
  85. package/lib/components/table-internal/detailsDialog-internal.component.d.ts +16 -6
  86. package/lib/components/table-internal/table-internal.component.d.ts +28 -15
  87. package/lib/components/table-row/table-row.component.d.ts +28 -0
  88. package/lib/components/tasks/tasks.component.d.ts +1 -1
  89. package/lib/components/tenant-settings/inviteDialog.component.d.ts +1 -1
  90. package/lib/components/tenant-settings/tenant-settings.component.d.ts +1 -1
  91. package/lib/components/tenants/tenants.component.d.ts +1 -1
  92. package/lib/components/tiles/tiles.component.d.ts +1 -1
  93. package/lib/components/transactions/transactDialog.component.d.ts +1 -1
  94. package/lib/components/transactions/transactions.component.d.ts +1 -1
  95. package/lib/components/users/users.component.d.ts +1 -1
  96. package/lib/components/viewer/viewer.component.d.ts +1 -1
  97. package/lib/components/welcome/welcome.component.d.ts +1 -1
  98. package/lib/services/button.service.d.ts +27 -0
  99. package/lib/services/condition.service.d.ts +10 -0
  100. package/lib/services/{data.service.d.ts → datalib.service.d.ts} +15 -1
  101. package/lib/services/dialog.service.d.ts +18 -0
  102. package/lib/services/table-config.service.d.ts +8 -0
  103. package/lib/tin-spa.module.d.ts +8 -5
  104. package/package.json +1 -1
  105. package/public-api.d.ts +2 -1
  106. package/esm2020/lib/services/data.service.mjs +0 -236
@@ -5,33 +5,39 @@ import { DetailsDialog } from './detailsDialog.component';
5
5
  import { DetailsDialogProcessor } from '../../classes/TinCore';
6
6
  import { Subject } from 'rxjs';
7
7
  import * as i0 from "@angular/core";
8
- import * as i1 from "../../services/data.service";
8
+ import * as i1 from "../../services/datalib.service";
9
9
  import * as i2 from "../../services/message.service";
10
10
  import * as i3 from "@angular/cdk/layout";
11
11
  import * as i4 from "@angular/material/dialog";
12
- import * as i5 from "@angular/common";
13
- import * as i6 from "@angular/material/table";
14
- import * as i7 from "@angular/material/paginator";
15
- import * as i8 from "@angular/material/button";
16
- import * as i9 from "@angular/material/icon";
17
- import * as i10 from "@angular/material/chips";
18
- import * as i11 from "@angular/material/tooltip";
19
- import * as i12 from "../check/check.component";
20
- import * as i13 from "../select/select.component";
21
- import * as i14 from "../filter/filter.component";
22
- import * as i15 from "../tiles/tiles.component";
23
- import * as i16 from "../search/search.component";
24
- import * as i17 from "../../pipes/camelToWords.pipe";
12
+ import * as i5 from "../../services/button.service";
13
+ import * as i6 from "../../services/dialog.service";
14
+ import * as i7 from "../../services/table-config.service";
15
+ import * as i8 from "../../services/condition.service";
16
+ import * as i9 from "@angular/common";
17
+ import * as i10 from "@angular/material/table";
18
+ import * as i11 from "@angular/material/paginator";
19
+ import * as i12 from "../search/search.component";
20
+ import * as i13 from "../table-header/table-header.component";
21
+ import * as i14 from "../table-row/table-row.component";
22
+ import * as i15 from "../table-action/table-action.component";
23
+ import * as i16 from "../../pipes/camelToWords.pipe";
25
24
  export class TableComponent {
26
- constructor(dataService, messageService, breakpointObserver, dialog) {
25
+ constructor(dataService, messageService, breakpointObserver, dialog, buttonService, dialogService, tableConfigService, conditionService) {
27
26
  this.dataService = dataService;
28
27
  this.messageService = messageService;
29
28
  this.breakpointObserver = breakpointObserver;
30
29
  this.dialog = dialog;
30
+ this.buttonService = buttonService;
31
+ this.dialogService = dialogService;
32
+ this.tableConfigService = tableConfigService;
33
+ this.conditionService = conditionService;
31
34
  this.elevation = "mat-elevation-z5";
32
35
  this.actionsWidth = "50px";
33
36
  this.showFilterButton = true;
34
37
  this.tileReload = new Subject();
38
+ this.smallScreen = false;
39
+ this.displayedColumns = [];
40
+ this.displayedButtons = [];
35
41
  this.hideTitle = false;
36
42
  this.data = [];
37
43
  this.dataLoad = new EventEmitter();
@@ -40,69 +46,73 @@ export class TableComponent {
40
46
  this.createClick = new EventEmitter();
41
47
  this.actionClick = new EventEmitter();
42
48
  this.inputChange = new EventEmitter();
43
- this.smallScreen = false;
44
- // columns: Column[] = [];
45
- this.displayedColumns = [];
46
- // @Input() optionValue = "";
47
- // @Input() optionDisplay = "";
48
- this.displayedButtons = [];
49
49
  // detect screen size changes
50
50
  this.breakpointObserver.observe(["(max-width: 600px)"]).subscribe((result) => {
51
- if (result.matches) {
52
- this.smallScreen = true;
53
- this.setColumns();
54
- }
55
- else {
56
- this.smallScreen = false;
57
- this.setColumns();
58
- }
51
+ this.smallScreen = result.matches;
52
+ this.updateTableConfiguration();
59
53
  });
60
54
  }
61
55
  ngOnInit() {
62
- if (this.config.elevation) {
63
- if (this.config.elevation == "none") {
64
- this.elevation = "";
65
- }
66
- else if (this.config.elevation == "low") {
67
- this.elevation = "mat-elevation-z1";
68
- }
69
- else if (this.config.elevation == "medium") {
70
- this.elevation = "mat-elevation-z5";
71
- }
72
- else if (this.config.elevation == "high") {
73
- this.elevation = "mat-elevation-z9";
74
- }
56
+ this.initializeComponent();
57
+ }
58
+ ngOnChanges() {
59
+ if (!this.config.loadAction) {
60
+ this.dataSource = this.data;
61
+ this.tableDataSource = new MatTableDataSource(this.dataSource);
75
62
  }
76
- this.setColumns();
77
- this.createButton = this.getButton('create');
63
+ setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 1000);
64
+ }
65
+ initializeComponent() {
66
+ this.updateTableConfiguration();
67
+ this.setupDataLoading();
68
+ this.formDefaults();
69
+ }
70
+ updateTableConfiguration() {
71
+ this.elevation = this.getElevationClass(this.config?.elevation);
72
+ this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);
73
+ this.displayedButtons = this.buttonService.getDisplayedButtons(this.config?.buttons, this.smallScreen, this.config?.minButtons);
74
+ this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);
75
+ this.createButton = this.buttonService.getCreateButton(this.config?.buttons);
76
+ this.showFilterButton = !this.config?.searchConfig;
77
+ if (this.displayedButtons?.length > 0 && !this.displayedColumns.includes('action')) {
78
+ this.displayedColumns.push('action');
79
+ }
80
+ }
81
+ setupDataLoading() {
78
82
  if (this.config.loadAction) {
79
83
  this.loadData(this.config.loadAction, "");
80
84
  }
81
- this.formDefaults();
82
- if (this.config.searchConfig) {
83
- this.showFilterButton = false;
84
- }
85
- if (this.reload != null) {
85
+ if (this.reload) {
86
86
  this.reload.subscribe(v => {
87
- if (v == true) {
88
- if (this.config?.loadAction) {
89
- this.loadData(this.config?.loadAction, "");
90
- }
87
+ if (v && this.config?.loadAction) {
88
+ this.loadData(this.config.loadAction, "");
91
89
  }
92
90
  });
93
91
  }
94
92
  }
95
- ngOnChanges() {
96
- if (!this.config.loadAction) {
97
- // console.log("Table data Changed")
98
- // this.dataSource = this.data;
99
- this.tableDataSource = new MatTableDataSource(this.dataSource);
93
+ loadData(action, data) {
94
+ console.log("loading");
95
+ if (action) {
96
+ this.dataService.CallApi(action, data).subscribe((apiResponse) => {
97
+ if (this.config.logResponse) {
98
+ console.log(apiResponse);
99
+ }
100
+ this.dataSource = apiResponse.data;
101
+ this.tableDataSource = new MatTableDataSource(apiResponse.data);
102
+ this.tableDataSource.paginator = this.tablePaginator;
103
+ if (apiResponse.success) {
104
+ this.tableDataSource = new MatTableDataSource(apiResponse.data);
105
+ this.tableDataSource.paginator = this.tablePaginator;
106
+ this.dataLoaded(apiResponse.data);
107
+ }
108
+ else {
109
+ this.messageService.toast("Error: " + apiResponse.message);
110
+ }
111
+ });
100
112
  }
101
- setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 1000);
102
113
  }
103
114
  inputChanged(event) {
104
115
  this.inputChange.emit({ field: event.field, value: event.value });
105
- // console.log("Changed " + JSON.stringify(event))
106
116
  }
107
117
  formDefaults() {
108
118
  if (!this.config.formConfig) {
@@ -116,46 +126,11 @@ export class TableComponent {
116
126
  }
117
127
  }
118
128
  setColumns() {
119
- //columns
120
- if (!this.config?.columns) {
121
- return;
122
- }
123
- if (this.smallScreen) {
124
- let cols = [];
125
- if (this.config.minColumns) {
126
- cols = this.config.minColumns.filter(col => this.config.columns.some(x => x.name === col));
127
- }
128
- if (cols.length > 0) {
129
- this.displayedColumns = cols;
130
- }
131
- else {
132
- this.displayedColumns = this.config.columns.map(({ name }) => name);
133
- }
134
- }
135
- else {
136
- this.displayedColumns = this.config.columns.map(({ name }) => name);
137
- }
138
- //buttons
139
- if (!this.config?.buttons) {
140
- return;
141
- }
142
- let buttonsCount = this.config.buttons.filter(x => x.name != 'create').length ?? 0;
143
- if (buttonsCount > 0) {
144
- if (!this.displayedColumns.find(x => x == 'action') && this.config.buttons) {
145
- this.displayedColumns.push("action");
146
- }
147
- if (this.smallScreen) {
148
- if (this.config.minButtons) {
149
- this.displayedButtons = this.config.buttons.filter(x => this.config.minButtons.includes(x.name));
150
- }
151
- else {
152
- this.displayedButtons = this.config.buttons.filter(x => x.name != 'create').slice(0, 1);
153
- }
154
- }
155
- else {
156
- this.displayedButtons = this.config.buttons.filter(x => x.name != 'create');
157
- }
158
- this.actionsWidth = `${this.displayedButtons.length * 40 + 20}px`;
129
+ this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);
130
+ this.displayedButtons = this.buttonService.getDisplayedButtons(this.config.buttons, this.smallScreen, this.config.minButtons);
131
+ this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);
132
+ if (this.displayedButtons.length > 0 && !this.displayedColumns.includes('action')) {
133
+ this.displayedColumns.push('action');
159
134
  }
160
135
  }
161
136
  setButtons() {
@@ -169,132 +144,45 @@ export class TableComponent {
169
144
  }
170
145
  }
171
146
  getButton(name) {
172
- if (!this.config.buttons) {
173
- console.log("No buttons found");
174
- return null;
175
- }
176
- return this.config.buttons.find(x => x.name == name);
147
+ return this.buttonService.getButton(this.config.buttons, name);
177
148
  }
178
149
  getIcon(buttonName) {
179
- let b = this.getButton(buttonName);
180
- if (b.icon) {
181
- return b.icon.name;
182
- }
183
- let i = 'open_in_new';
184
- switch (buttonName) {
185
- case 'view':
186
- i = this.config.flatButtons ? 'open_in_new' : 'pageview';
187
- break;
188
- case 'edit':
189
- i = 'edit';
190
- break;
191
- case 'delete':
192
- i = 'delete';
193
- break;
194
- default:
195
- break;
196
- }
197
- return i;
150
+ const button = this.getButton(buttonName);
151
+ return this.buttonService.getIcon(button, this.config);
198
152
  }
199
153
  getButtonColor(button, row) {
200
- if (button.disabled) {
201
- if (button.disabled(row)) {
202
- return 'lightgray';
203
- }
204
- }
205
- if (button.color) {
206
- return button.color;
207
- }
208
- if (button.name == 'delete') {
209
- return '#F44336';
210
- }
211
- if (button.name == 'create') {
212
- return 'green';
213
- }
214
- return ' #4050B5';
154
+ return this.buttonService.getButtonColor(button, row);
215
155
  }
216
156
  getOptions(column) {
217
157
  let x = this.config.columns.find(opt => opt.name === column);
218
158
  return x;
219
159
  }
220
- getColor(v, options) {
221
- let defaultColor = 'lightgrey';
222
- if (!options)
223
- return defaultColor;
224
- let c = options.find(x => x.value == v);
225
- if (c) {
226
- return c.color;
227
- }
228
- else {
229
- return defaultColor;
230
- }
160
+ getColor(value, options) {
161
+ return this.conditionService.getColor(value, options);
231
162
  }
232
- testIconCondition(value, icon) {
233
- if (icon.condition) {
234
- return icon.condition(value);
235
- }
236
- else {
237
- return true;
238
- }
163
+ testIconCondition(row, icon) {
164
+ return this.conditionService.testIconCondition(icon, row);
239
165
  }
240
- testColorCondition(value, color) {
241
- if (!color)
242
- return false;
243
- if (color.condition) {
244
- return color.condition(value);
245
- }
246
- else {
247
- return true;
248
- }
166
+ testColorCondition(row, color) {
167
+ return this.conditionService.testColorCondition(color, row);
249
168
  }
250
169
  showBanner(message) {
251
- if (!message)
252
- return;
253
- if (message == '')
254
- return;
255
- this.messageService.info(message);
170
+ if (message && message !== '') {
171
+ this.messageService.info(message);
172
+ }
256
173
  }
257
174
  testDisabled(row, buttonName) {
258
- let button = this.getButton(buttonName);
259
- if (button.disabled) {
260
- return button.disabled(row);
261
- }
262
- return false;
175
+ const button = this.getButton(buttonName);
176
+ return this.buttonService.testDisabled(button, row);
263
177
  }
264
178
  testVisible(row, buttonName) {
265
- let button = this.getButton(buttonName);
266
- if (button.visible) {
267
- return button.visible(row);
268
- }
269
- return true;
270
- }
271
- //Actions
272
- loadData(action, data) {
273
- console.log("loading");
274
- if (action) {
275
- this.dataService.CallApi(action, data).subscribe((apiResponse) => {
276
- if (this.config.logResponse) {
277
- console.log(apiResponse);
278
- }
279
- this.dataSource = apiResponse.data;
280
- this.tableDataSource = new MatTableDataSource(apiResponse.data);
281
- this.tableDataSource.paginator = this.tablePaginator;
282
- if (apiResponse.success) {
283
- this.tableDataSource = new MatTableDataSource(apiResponse.data);
284
- this.tableDataSource.paginator = this.tablePaginator;
285
- this.dataLoaded(apiResponse.data);
286
- }
287
- else {
288
- this.messageService.toast("Error: " + apiResponse.message);
289
- }
290
- });
291
- }
179
+ const button = this.getButton(buttonName);
180
+ return this.buttonService.testVisible(button, row);
292
181
  }
293
182
  //Events
294
183
  searchClicked(x) {
295
184
  console.log("Search");
296
185
  this.searchClick.emit(x);
297
- // console.log(x)
298
186
  if (this.config.searchConfig.searchAction) {
299
187
  this.config.searchConfig.searchAction.method == 'post';
300
188
  this.loadData(this.config.searchConfig.searchAction, x);
@@ -311,73 +199,37 @@ export class TableComponent {
311
199
  }
312
200
  }
313
201
  dataLoaded(x) {
314
- this.dataLoad.emit(x);
315
202
  console.log("dataloaded");
203
+ this.dataLoad.emit(x);
316
204
  if (this.config.tileConfig?.loadAction) {
317
205
  this.tileReload.next(true);
318
206
  }
319
207
  }
320
208
  actionClicked(name, row) {
321
- if (name == 'view') {
209
+ if (name === 'view') {
322
210
  this.viewModel(row);
323
211
  }
324
- else if (name == 'edit') {
212
+ else if (name === 'edit') {
325
213
  this.editModel(row);
326
214
  }
327
- else if (name == 'delete') {
215
+ else if (name === 'delete') {
328
216
  this.deleteModel(row);
329
217
  }
330
218
  else {
331
219
  this.customModel(name, row);
332
220
  }
333
221
  }
222
+ //Dialog events
334
223
  columnClicked(column, row) {
335
224
  if (column.detailsConfig) {
336
- let conf = DetailsDialogProcessor.processDetailsConfig(column.detailsConfig, row);
337
- const dialogRef = this.dialog.open(DetailsDialog, {
338
- width: "900px",
339
- data: conf
340
- });
341
- dialogRef.afterClosed().subscribe((result) => {
342
- if (result.message == "success") {
343
- this.actionClickedEmit(column.name, row);
344
- this.refreshClicked();
345
- }
346
- });
225
+ this.openDetailsDialog(column.name, row, column);
347
226
  }
348
227
  else {
349
228
  this.actionClickedEmit(column.name, row);
350
229
  }
351
230
  }
352
231
  customModel(name, row) {
353
- let button = this.getButton(name);
354
- if (button) {
355
- if (!button.dialog) {
356
- this.doAction(button.name, row);
357
- this.actionClickedEmit(name, row);
358
- }
359
- else {
360
- if (button.detailsConfig) {
361
- let conf = DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);
362
- const dialogRef = this.dialog.open(DetailsDialog, {
363
- width: "900px",
364
- data: conf
365
- });
366
- dialogRef.afterClosed().subscribe((result) => {
367
- if (result.message == "success") {
368
- this.actionClickedEmit(button.name, row);
369
- this.refreshClicked();
370
- }
371
- });
372
- }
373
- else {
374
- this.actionClickedEmit(button.name, row);
375
- }
376
- }
377
- }
378
- else {
379
- this.actionClickedEmit(name, row);
380
- }
232
+ this.openDetailsDialog(name, row);
381
233
  }
382
234
  actionClickedEmit(name, row) {
383
235
  console.log("Action clicked");
@@ -385,82 +237,24 @@ export class TableComponent {
385
237
  }
386
238
  viewModel(row) {
387
239
  console.log("view Clicked");
388
- let button = this.getButton('view');
389
- if (!button)
390
- return;
391
- if (!button.dialog) {
392
- this.actionClickedEmit(button.name, row);
393
- return;
394
- }
395
- if (!this.config.formConfig) {
396
- this.messageService.toast("Please configure form");
397
- return;
398
- }
399
- let conf = {
400
- formConfig: this.config.formConfig,
401
- buttons: this.config.buttons,
402
- details: row,
403
- };
404
- if (button.detailsConfig) {
405
- conf = DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);
406
- }
407
- conf.formConfig.mode = "view";
408
- const dialogRef = this.dialog.open(DetailsDialog, {
409
- width: "900px",
410
- data: conf
411
- });
412
- dialogRef.afterClosed().subscribe((result) => {
413
- if (result.message) {
414
- this.refreshClicked();
415
- }
416
- });
240
+ this.openDetailsDialog('view', row);
417
241
  }
418
242
  newModel() {
419
- let button = this.getButton('create');
420
- if (!button)
421
- return;
422
- if (!button.dialog) {
423
- this.actionClickedEmit(button.name, null);
424
- return;
425
- }
426
- if (!this.config.formConfig) {
427
- this.messageService.toast("Please configure form");
428
- return;
429
- }
430
- this.config.formConfig.mode = "create";
431
- let conf = {
432
- formConfig: this.config.formConfig,
433
- buttons: this.config.buttons,
434
- };
435
- if (button.detailsConfig) {
436
- conf = button.detailsConfig;
437
- }
438
- conf.formConfig.mode = "create";
439
- conf.heroField = this.config?.heroField;
440
- conf.heroValue = this.config?.heroValue;
441
- const dialogRef = this.dialog.open(DetailsDialog, {
442
- width: "900px",
443
- data: conf,
444
- });
445
- dialogRef.afterClosed().subscribe((result) => {
446
- if (result.message == "success") {
447
- this.actionClickedEmit('create', result.data);
448
- this.refreshClicked();
449
- }
450
- else if (result.message == "emit") {
451
- this.actionClickedEmit('create', result.data);
452
- }
453
- });
243
+ this.openDetailsDialog('create', null);
454
244
  }
455
245
  editModel(row) {
456
- let button = this.getButton('edit');
246
+ this.openDetailsDialog('edit', row);
247
+ }
248
+ openDetailsDialog(buttonName, row, column) {
249
+ const button = column ? { name: column.name, dialog: true, detailsConfig: column.detailsConfig } : this.getButton(buttonName);
457
250
  if (!button)
458
251
  return;
459
252
  if (!button.dialog) {
253
+ this.doAction(button.name, row);
460
254
  this.actionClickedEmit(button.name, row);
461
255
  return;
462
256
  }
463
- if (!this.config.formConfig) {
257
+ if (!this.config.formConfig && !button.detailsConfig) {
464
258
  this.messageService.toast("Please configure form");
465
259
  return;
466
260
  }
@@ -470,24 +264,28 @@ export class TableComponent {
470
264
  details: row,
471
265
  };
472
266
  if (button.detailsConfig) {
473
- conf = DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);
267
+ conf = buttonName === 'create'
268
+ ? button.detailsConfig
269
+ : DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);
270
+ }
271
+ conf.formConfig.mode = buttonName === 'create' ? 'create' : (buttonName === 'edit' ? 'edit' : 'view');
272
+ if (buttonName === 'create') {
273
+ conf.heroField = this.config?.heroField;
274
+ conf.heroValue = this.config?.heroValue;
275
+ }
276
+ const dialogResult = this.dialogService.openDetailsDialog(conf, DetailsDialog);
277
+ if (buttonName === 'edit') {
278
+ dialogResult.inputChange.subscribe((x) => {
279
+ this.inputChanged(x);
280
+ });
474
281
  }
475
- conf.formConfig.mode = "edit";
476
- const dialogRef = this.dialog.open(DetailsDialog, {
477
- width: "900px",
478
- data: conf
479
- });
480
- dialogRef.componentInstance.inputChange.subscribe((x) => {
481
- this.inputChanged(x);
482
- });
483
- dialogRef.afterClosed().subscribe((result) => {
484
- console.log(result);
485
- if (result.message == "success") {
486
- this.actionClickedEmit('edit', result.data);
282
+ dialogResult.afterClosed.subscribe((result) => {
283
+ if (result.message === 'success') {
284
+ this.actionClickedEmit(button.name, result.data);
487
285
  this.refreshClicked();
488
286
  }
489
- else if (result.message == "emit") {
490
- this.actionClickedEmit('edit', result.data);
287
+ else if (result.message === 'emit') {
288
+ this.actionClickedEmit(button.name, result.data);
491
289
  }
492
290
  });
493
291
  }
@@ -502,6 +300,7 @@ export class TableComponent {
502
300
  }
503
301
  });
504
302
  }
303
+ //Actions
505
304
  doAction(buttonName, row) {
506
305
  let b = this.getButton(buttonName);
507
306
  if (!b)
@@ -537,13 +336,32 @@ export class TableComponent {
537
336
  this.messageService.toast("Error: " + error);
538
337
  });
539
338
  }
339
+ //Misc
340
+ getElevationClass(elevation) {
341
+ console.log(elevation);
342
+ if (elevation == "none") {
343
+ return "";
344
+ }
345
+ else if (elevation == "low") {
346
+ return "mat-elevation-z1";
347
+ }
348
+ else if (elevation == "medium") {
349
+ return "mat-elevation-z5";
350
+ }
351
+ else if (elevation == "high") {
352
+ return "mat-elevation-z9";
353
+ }
354
+ else {
355
+ return "mat-elevation-z5";
356
+ }
357
+ }
540
358
  }
541
- TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, deps: [{ token: i1.DataServiceLib }, { token: i2.MessageService }, { token: i3.BreakpointObserver }, { token: i4.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
542
- TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableComponent, selector: "spa-table", inputs: { hideTitle: "hideTitle", data: "data", config: "config", reload: "reload" }, outputs: { dataLoad: "dataLoad", refreshClick: "refreshClick", searchClick: "searchClick", createClick: "createClick", actionClick: "actionClick", inputChange: "inputChange" }, viewQueries: [{ propertyName: "tablePaginator", first: true, predicate: ["tablePaginator"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n<spa-search *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\n\n<div class=\"top\">\n\n <div class=\"tin-row\" >\n <button *ngIf=\"createButton && !config.flatButtons\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}</button>\n <button *ngIf=\"createButton && config.flatButtons\" id=\"btnNew\" mat-stroked-button style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}</button>\n </div>\n\n <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\n <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n </div>\n\n <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\n <spa-filter [showText]=\"!smallScreen || (smallScreen && dataSource?.length > 10)\" [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" [flatButtons]=\"config.flatButtons\" (refreshClick)=\"refreshClicked()\"></spa-filter>\n </div>\n\n</div>\n\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\n <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n</div>\n\n<div *ngIf=\"config.title && !hideTitle\" class=\"title\">\n <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\n</div>\n\n<div>\n\n <p *ngIf=\"!config\"><em>Configure Table</em></p>\n <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\n\n\n\n <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\n\n\n <table mat-table [dataSource]=\"tableDataSource\" [ngClass]=\"elevation\">\n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\n <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\n <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\n\n <ng-container [ngSwitch]=\"column.type\">\n\n <ng-container *ngSwitchCase=\"'checkbox'\">\n <spa-check [value]=\"row[column.name]\" [readonly]=\"true\"></spa-check>\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'select'\">\n <spa-select [options]=\"column.options\" [optionDisplay]=\"column.optionDisplay\" [optionValue]=\"column.optionValue\" [(value)]=\"row[column.name]\" width=\"90%\" ></spa-select>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'chip'\">\n <mat-chip-list>\n <mat-chip (click)=\"columnClicked(column, row)\" [ngStyle]=\"{'background-color': testColorCondition(row, column.color) ? column.color.name : getColor(row[column.name], column?.options)}\" style=\"font-size: 12px;\"> {{row[column.name]}} </mat-chip>\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </mat-chip-list>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'icon'\">\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'date'\">\n {{row[column.name] | date : 'dd/MM/yyyy'}}\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'datetime'\">\n {{row[column.name] | date : 'dd/MM/yyyy HH:mm'}}\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <!-- <ng-container *ngSwitchCase=\"'spinner'\">\n <mat-spinner [diameter]=\"20\">\n\n </mat-spinner>\n </ng-container> -->\n\n <ng-container *ngSwitchCase=\"'money'\">\n\n <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name] | currency:'':''}}</label>\n\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'button'\">\n\n <button mat-button [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\" (click)=\"actionClicked(column.name, row)\">{{row[column.name]}}</button>\n\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name]}}</label>\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"action\">\n <th mat-header-cell *matHeaderCellDef> Action </th>\n <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\n <div class=\"action-buttons-container\">\n\n <ng-container *ngFor=\"let button of displayedButtons\">\n\n <ng-container *ngIf=\"button.name != 'create' && testVisible(row,button.name)\">\n\n <button *ngIf=\"!config.flatButtons\" mat-mini-fab [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n [ngStyle]=\"{'background-color':getButtonColor(button, row)}\"\n [disabled]=\"testDisabled(row,button.name)\" (click)=\"actionClicked(button.name, row)\">\n <mat-icon>{{getIcon(button.name)}}</mat-icon>\n </button>\n\n <button *ngIf=\"config.flatButtons\" mat-icon-button [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n [disabled]=\"testDisabled(row,button.name)\" (click)=\"actionClicked(button.name, row)\">\n <mat-icon [ngStyle]=\"{'color':getButtonColor(button, row)}\">{{getIcon(button.name)}}</mat-icon>\n </button>\n\n </ng-container>\n\n <ng-container *ngIf=\"button.name != 'create' && !testVisible(row,button.name) && !config.collapseButtons\">\n <label style=\"margin-right: 35px;\"></label>\n </ng-container>\n\n </ng-container>\n </div>\n\n\n\n\n\n </td>\n </ng-container>\n\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\n </table>\n\n </div>\n\n <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\n\n</div>\n\n<div class=\"tin-center\">\n <p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\n</div>\n\n\n\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;margin-top:10px}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.mat-icon-button{width:32px;height:32px}.mat-icon-button mat-icon{font-size:20px;margin-top:-7px}.col-icon{margin-left:10px}.title{margin-top:10px;font-size:larger;font-weight:300}.make-gray{background-color:#e5e5e5}.right-padding{padding-right:10px}.action-buttons-container{display:flex;justify-content:flex-end;align-items:center}.refreshIcon{font-size:22px!important;margin-top:-7px!important}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i5.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { 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: "component", type: i7.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i10.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i10.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i11.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i12.CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value"], outputs: ["valueChange", "click", "check", "uncheck"] }, { kind: "component", type: i13.SelectComponent, selector: "spa-select", inputs: ["width", "readonly", "required", "defaultFirstValue", "readonlyMode", "hint", "placeholder", "multiple", "display", "value", "options", "masterOptions", "optionValue", "optionDisplay", "optionDisplayExtra", "nullable"], outputs: ["valueChange"] }, { kind: "component", type: i14.FilterComponent, selector: "spa-filter", inputs: ["flatButtons", "showText", "showButton", "data"], outputs: ["refreshClick"] }, { kind: "component", type: i15.TilesComponent, selector: "spa-tiles", inputs: ["config", "data", "reload"], outputs: ["tileClick"] }, { kind: "component", type: i16.SearchComponent, selector: "spa-search", inputs: ["config"], outputs: ["searchClick"] }, { kind: "pipe", type: i5.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i5.DatePipe, name: "date" }, { kind: "pipe", type: i17.CamelToWordsPipe, name: "camelToWords" }] });
359
+ TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, deps: [{ token: i1.DataServiceLib }, { token: i2.MessageService }, { token: i3.BreakpointObserver }, { token: i4.MatDialog }, { token: i5.ButtonService }, { token: i6.DialogService }, { token: i7.TableConfigService }, { token: i8.ConditionService }], target: i0.ɵɵFactoryTarget.Component });
360
+ TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableComponent, selector: "spa-table", inputs: { hideTitle: "hideTitle", data: "data", config: "config", reload: "reload" }, outputs: { dataLoad: "dataLoad", refreshClick: "refreshClick", searchClick: "searchClick", createClick: "createClick", actionClick: "actionClick", inputChange: "inputChange" }, viewQueries: [{ propertyName: "tablePaginator", first: true, predicate: ["tablePaginator"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\r\n<!-- Search -->\r\n<spa-search\r\n *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n [config]=\"config\" [hideTitle]=\"false\" [tableDataSource]=\"tableDataSource\" [createButton]=\"createButton\" [tileConfig]=\"config.tileConfig\" [smallScreen]=\"smallScreen\"\r\n [tileReload]=\"tileReload\" [showFilterButton]=\"showFilterButton\" (createClick)=\"newModel()\" (refreshClick)=\"refreshClicked()\">\r\n</app-table-header>\r\n\r\n\r\n<!-- Table -->\r\n<div>\r\n\r\n <p *ngIf=\"!config\"><em>Configure Table</em></p>\r\n <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\r\n\r\n <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\r\n\r\n <table mat-table [dataSource]=\"tableDataSource\" [ngClass]=\"elevation\">\r\n\r\n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\r\n <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\r\n <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\r\n\r\n <!-- Rows -->\r\n <app-table-row [column]=\"column\" [row]=\"row\" [config]=\"config\"\r\n (actionClick)=\"actionClicked(column.name, row)\" (columnClick)=\"columnClicked(column, row)\" (showBannerEvent)=\"showBanner($event)\">\r\n </app-table-row>\r\n\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"action\">\r\n <th mat-header-cell *matHeaderCellDef> Action </th>\r\n <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\r\n <div class=\"action-buttons-container\">\r\n\r\n <!-- Actions -->\r\n <app-table-action\r\n [displayedButtons]=\"displayedButtons\" [config]=\"config\" [row]=\"row\" (actionClick)=\"actionClicked($event.name, $event.row)\">\r\n </app-table-action>\r\n\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\r\n </table>\r\n\r\n </div>\r\n\r\n <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n\r\n</div>\r\n\r\n<div class=\"tin-center\">\r\n <p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\r\n</div>\r\n\r\n\r\n\r\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;margin-top:10px}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.mat-icon-button{width:32px;height:32px}.mat-icon-button mat-icon{font-size:20px;margin-top:-7px}.col-icon{margin-left:10px}.title{margin-top:10px;font-size:larger;font-weight:300}.make-gray{background-color:#e5e5e5}.right-padding{padding-right:10px}.action-buttons-container{display:flex;justify-content:flex-end;align-items:center}.refreshIcon{font-size:22px!important;margin-top:-7px!important}.dialog-container{display:flex;flex-direction:column;height:100%}.dialog-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.dialog-scroll-content{flex:1;overflow-y:auto}mat-dialog-actions{flex-shrink:0}\n"], dependencies: [{ kind: "directive", type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i9.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i10.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i10.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i10.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i10.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i10.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i10.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i10.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i10.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i10.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i10.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i11.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i12.SearchComponent, selector: "spa-search", inputs: ["config"], outputs: ["searchClick"] }, { kind: "component", type: i13.TableHeaderComponent, selector: "app-table-header", inputs: ["config", "hideTitle", "tableDataSource", "createButton", "tileConfig", "smallScreen", "tileReload", "showFilterButton"], outputs: ["createClick", "refreshClick", "tileClick"] }, { kind: "component", type: i14.TableRowComponent, selector: "app-table-row", inputs: ["column", "row", "config"], outputs: ["actionClick", "columnClick", "showBannerEvent"] }, { kind: "component", type: i15.TableActionComponent, selector: "app-table-action", inputs: ["displayedButtons", "config", "row"], outputs: ["actionClick"] }, { kind: "pipe", type: i16.CamelToWordsPipe, name: "camelToWords" }] });
543
361
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, decorators: [{
544
362
  type: Component,
545
- args: [{ selector: 'spa-table', template: "\n<spa-search *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\n\n<div class=\"top\">\n\n <div class=\"tin-row\" >\n <button *ngIf=\"createButton && !config.flatButtons\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}</button>\n <button *ngIf=\"createButton && config.flatButtons\" id=\"btnNew\" mat-stroked-button style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}</button>\n </div>\n\n <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\n <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n </div>\n\n <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\n <spa-filter [showText]=\"!smallScreen || (smallScreen && dataSource?.length > 10)\" [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" [flatButtons]=\"config.flatButtons\" (refreshClick)=\"refreshClicked()\"></spa-filter>\n </div>\n\n</div>\n\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\n <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n</div>\n\n<div *ngIf=\"config.title && !hideTitle\" class=\"title\">\n <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\n</div>\n\n<div>\n\n <p *ngIf=\"!config\"><em>Configure Table</em></p>\n <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\n\n\n\n <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\n\n\n <table mat-table [dataSource]=\"tableDataSource\" [ngClass]=\"elevation\">\n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\n <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\n <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\n\n <ng-container [ngSwitch]=\"column.type\">\n\n <ng-container *ngSwitchCase=\"'checkbox'\">\n <spa-check [value]=\"row[column.name]\" [readonly]=\"true\"></spa-check>\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'select'\">\n <spa-select [options]=\"column.options\" [optionDisplay]=\"column.optionDisplay\" [optionValue]=\"column.optionValue\" [(value)]=\"row[column.name]\" width=\"90%\" ></spa-select>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'chip'\">\n <mat-chip-list>\n <mat-chip (click)=\"columnClicked(column, row)\" [ngStyle]=\"{'background-color': testColorCondition(row, column.color) ? column.color.name : getColor(row[column.name], column?.options)}\" style=\"font-size: 12px;\"> {{row[column.name]}} </mat-chip>\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </mat-chip-list>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'icon'\">\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'date'\">\n {{row[column.name] | date : 'dd/MM/yyyy'}}\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'datetime'\">\n {{row[column.name] | date : 'dd/MM/yyyy HH:mm'}}\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <!-- <ng-container *ngSwitchCase=\"'spinner'\">\n <mat-spinner [diameter]=\"20\">\n\n </mat-spinner>\n </ng-container> -->\n\n <ng-container *ngSwitchCase=\"'money'\">\n\n <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name] | currency:'':''}}</label>\n\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'button'\">\n\n <button mat-button [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\" (click)=\"actionClicked(column.name, row)\">{{row[column.name]}}</button>\n\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name]}}</label>\n <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n <ng-container *ngFor=\"let icon of column.icons\">\n <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"action\">\n <th mat-header-cell *matHeaderCellDef> Action </th>\n <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\n <div class=\"action-buttons-container\">\n\n <ng-container *ngFor=\"let button of displayedButtons\">\n\n <ng-container *ngIf=\"button.name != 'create' && testVisible(row,button.name)\">\n\n <button *ngIf=\"!config.flatButtons\" mat-mini-fab [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n [ngStyle]=\"{'background-color':getButtonColor(button, row)}\"\n [disabled]=\"testDisabled(row,button.name)\" (click)=\"actionClicked(button.name, row)\">\n <mat-icon>{{getIcon(button.name)}}</mat-icon>\n </button>\n\n <button *ngIf=\"config.flatButtons\" mat-icon-button [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n [disabled]=\"testDisabled(row,button.name)\" (click)=\"actionClicked(button.name, row)\">\n <mat-icon [ngStyle]=\"{'color':getButtonColor(button, row)}\">{{getIcon(button.name)}}</mat-icon>\n </button>\n\n </ng-container>\n\n <ng-container *ngIf=\"button.name != 'create' && !testVisible(row,button.name) && !config.collapseButtons\">\n <label style=\"margin-right: 35px;\"></label>\n </ng-container>\n\n </ng-container>\n </div>\n\n\n\n\n\n </td>\n </ng-container>\n\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\n </table>\n\n </div>\n\n <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\n\n</div>\n\n<div class=\"tin-center\">\n <p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\n</div>\n\n\n\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;margin-top:10px}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.mat-icon-button{width:32px;height:32px}.mat-icon-button mat-icon{font-size:20px;margin-top:-7px}.col-icon{margin-left:10px}.title{margin-top:10px;font-size:larger;font-weight:300}.make-gray{background-color:#e5e5e5}.right-padding{padding-right:10px}.action-buttons-container{display:flex;justify-content:flex-end;align-items:center}.refreshIcon{font-size:22px!important;margin-top:-7px!important}\n"] }]
546
- }], ctorParameters: function () { return [{ type: i1.DataServiceLib }, { type: i2.MessageService }, { type: i3.BreakpointObserver }, { type: i4.MatDialog }]; }, propDecorators: { tablePaginator: [{
363
+ args: [{ selector: 'spa-table', template: "\r\n<!-- Search -->\r\n<spa-search\r\n *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n [config]=\"config\" [hideTitle]=\"false\" [tableDataSource]=\"tableDataSource\" [createButton]=\"createButton\" [tileConfig]=\"config.tileConfig\" [smallScreen]=\"smallScreen\"\r\n [tileReload]=\"tileReload\" [showFilterButton]=\"showFilterButton\" (createClick)=\"newModel()\" (refreshClick)=\"refreshClicked()\">\r\n</app-table-header>\r\n\r\n\r\n<!-- Table -->\r\n<div>\r\n\r\n <p *ngIf=\"!config\"><em>Configure Table</em></p>\r\n <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\r\n\r\n <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\r\n\r\n <table mat-table [dataSource]=\"tableDataSource\" [ngClass]=\"elevation\">\r\n\r\n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\r\n <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\r\n <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\r\n\r\n <!-- Rows -->\r\n <app-table-row [column]=\"column\" [row]=\"row\" [config]=\"config\"\r\n (actionClick)=\"actionClicked(column.name, row)\" (columnClick)=\"columnClicked(column, row)\" (showBannerEvent)=\"showBanner($event)\">\r\n </app-table-row>\r\n\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"action\">\r\n <th mat-header-cell *matHeaderCellDef> Action </th>\r\n <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\r\n <div class=\"action-buttons-container\">\r\n\r\n <!-- Actions -->\r\n <app-table-action\r\n [displayedButtons]=\"displayedButtons\" [config]=\"config\" [row]=\"row\" (actionClick)=\"actionClicked($event.name, $event.row)\">\r\n </app-table-action>\r\n\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\r\n </table>\r\n\r\n </div>\r\n\r\n <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n\r\n</div>\r\n\r\n<div class=\"tin-center\">\r\n <p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\r\n</div>\r\n\r\n\r\n\r\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;margin-top:10px}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.mat-icon-button{width:32px;height:32px}.mat-icon-button mat-icon{font-size:20px;margin-top:-7px}.col-icon{margin-left:10px}.title{margin-top:10px;font-size:larger;font-weight:300}.make-gray{background-color:#e5e5e5}.right-padding{padding-right:10px}.action-buttons-container{display:flex;justify-content:flex-end;align-items:center}.refreshIcon{font-size:22px!important;margin-top:-7px!important}.dialog-container{display:flex;flex-direction:column;height:100%}.dialog-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.dialog-scroll-content{flex:1;overflow-y:auto}mat-dialog-actions{flex-shrink:0}\n"] }]
364
+ }], ctorParameters: function () { return [{ type: i1.DataServiceLib }, { type: i2.MessageService }, { type: i3.BreakpointObserver }, { type: i4.MatDialog }, { type: i5.ButtonService }, { type: i6.DialogService }, { type: i7.TableConfigService }, { type: i8.ConditionService }]; }, propDecorators: { tablePaginator: [{
547
365
  type: ViewChild,
548
366
  args: ['tablePaginator']
549
367
  }], hideTitle: [{
@@ -567,4 +385,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
567
385
  }], inputChange: [{
568
386
  type: Output
569
387
  }] } });
570
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table/table.component.ts","../../../../../../projects/tin-spa/src/lib/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { DatePipe, CurrencyPipe } from '@angular/common';\r\nimport { Action, Button, Color, Column, DetailsDialogConfig, FormConfig, Icon, TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { DetailsDialog } from './detailsDialog.component';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.css']\r\n})\r\nexport class TableComponent implements OnInit {\r\n\r\n  constructor(private dataService: DataServiceLib, private messageService: MessageService, private breakpointObserver: BreakpointObserver, public dialog: MatDialog)\r\n  {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([ \"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n\r\n      if (result.matches) {\r\n        this.smallScreen = true\r\n        this.setColumns()\r\n      } else {\r\n        this.smallScreen = false\r\n        this.setColumns()\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n\r\n  ngOnInit() {\r\n\r\n    if (this.config.elevation){\r\n      if (this.config.elevation == \"none\"){\r\n        this.elevation = \"\"\r\n      }\r\n      else if (this.config.elevation == \"low\") {\r\n        this.elevation = \"mat-elevation-z1\"\r\n      }\r\n      else if (this.config.elevation == \"medium\") {\r\n        this.elevation = \"mat-elevation-z5\"\r\n      }\r\n      else if (this.config.elevation == \"high\") {\r\n        this.elevation = \"mat-elevation-z9\"\r\n      }\r\n    }\r\n\r\n    this.setColumns()\r\n\r\n    this.createButton = this.getButton('create')\r\n\r\n\r\n\r\n    if (this.config.loadAction){\r\n      this.loadData(this.config.loadAction, \"\");\r\n    }\r\n\r\n    this.formDefaults();\r\n\r\n    if (this.config.searchConfig){\r\n      this.showFilterButton = false;\r\n    }\r\n\r\n    if (this.reload != null){\r\n      this.reload.subscribe(v => {\r\n\r\n        if (v == true) {\r\n          if (this.config?.loadAction) {\r\n            this.loadData(this.config?.loadAction, \"\");\r\n          }\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n\r\n  elevation = \"mat-elevation-z5\";\r\n  actionsWidth = \"50px\";\r\n\r\n  showFilterButton = true;\r\n  tileReload : Subject<boolean> = new Subject();\r\n\r\n\r\n  ngOnChanges() {\r\n\r\n    if (!this.config.loadAction){\r\n      // console.log(\"Table data Changed\")\r\n      // this.dataSource = this.data;\r\n\r\n      this.tableDataSource = new MatTableDataSource<any>(this.dataSource);\r\n\r\n    }\r\n\r\n    setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 1000)\r\n\r\n  }\r\n\r\n\r\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\r\n\r\n  @Input() hideTitle = false;\r\n  @Input() data: any =[];\r\n  @Input() config: TableConfig;\r\n  @Input() reload: Subject<boolean>;\r\n  @Output() dataLoad = new EventEmitter();\r\n  @Output() refreshClick = new EventEmitter();\r\n  @Output() searchClick = new EventEmitter();\r\n  @Output() createClick = new EventEmitter();\r\n  @Output() actionClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n    // console.log(\"Changed \" + JSON.stringify(event))\r\n  }\r\n\r\n  smallScreen = false\r\n\r\n  createButton: Button;\r\n\r\n\r\n  //Table\r\n  tableDataSource;\r\n  dataSource: any[];\r\n  // columns: Column[] = [];\r\n  displayedColumns = []\r\n  // @Input() optionValue = \"\";\r\n  // @Input() optionDisplay = \"\";\r\n  displayedButtons = []\r\n\r\n  formDefaults() {\r\n\r\n    if (!this.config.formConfig) {\r\n      let config = new FormConfig\r\n\r\n      config.fields = []\r\n\r\n      this.config.columns.forEach(column => {\r\n\r\n        let field = { name: column.name, type: column.type }\r\n        config.fields.push(field)\r\n\r\n      });\r\n\r\n      this.config.formConfig = config;\r\n    }\r\n  }\r\n\r\n  setColumns() {\r\n\r\n    //columns\r\n    if (!this.config?.columns) {\r\n      return\r\n    }\r\n\r\n    if (this.smallScreen) {\r\n\r\n      let cols = [];\r\n\r\n      if (this.config.minColumns){\r\n        cols = this.config.minColumns.filter(col =>\r\n          this.config.columns.some(x => x.name === col)\r\n        )\r\n      }\r\n\r\n\r\n      if (cols.length > 0){\r\n        this.displayedColumns = cols;\r\n      }else{\r\n        this.displayedColumns = this.config.columns.map(({ name }) => name)\r\n      }\r\n\r\n    } else {\r\n      this.displayedColumns = this.config.columns.map(({ name }) => name)\r\n    }\r\n\r\n\r\n    //buttons\r\n    if (!this.config?.buttons) {\r\n      return\r\n    }\r\n\r\n    let buttonsCount = this.config.buttons.filter(x => x.name != 'create').length ?? 0\r\n    if (buttonsCount > 0) {\r\n\r\n      if (!this.displayedColumns.find(x => x == 'action') && this.config.buttons) {\r\n        this.displayedColumns.push(\"action\")\r\n      }\r\n\r\n\r\n\r\n      if (this.smallScreen) {\r\n\r\n        if (this.config.minButtons){\r\n          this.displayedButtons = this.config.buttons.filter(x => this.config.minButtons.includes(x.name))\r\n        }else{\r\n          this.displayedButtons = this.config.buttons.filter(x => x.name != 'create').slice(0, 1);\r\n        }\r\n      } else {\r\n        this.displayedButtons = this.config.buttons.filter(x => x.name != 'create');\r\n      }\r\n\r\n      this.actionsWidth = `${this.displayedButtons.length * 40 +20}px`\r\n\r\n\r\n    }\r\n\r\n  }\r\n\r\n  setButtons(){\r\n\r\n    if (!this.config.buttons) return\r\n\r\n    if (!this.smallScreen){\r\n      this.displayedButtons = this.config.buttons;\r\n\r\n    }else{\r\n      this.displayedButtons = this.config.buttons;\r\n\r\n    }\r\n\r\n  }\r\n\r\n\r\n  getButton(name: string) {\r\n    if (!this.config.buttons) {\r\n      console.log(\"No buttons found\")\r\n      return null\r\n    }\r\n    return this.config.buttons.find(x => x.name == name)\r\n  }\r\n\r\n  getIcon(buttonName: string){\r\n\r\n    let b = this.getButton(buttonName);\r\n    if (b.icon){\r\n      return b.icon.name\r\n    }\r\n\r\n    let i = 'open_in_new'\r\n\r\n    switch (buttonName) {\r\n\r\n      case 'view':\r\n\r\n        i = this.config.flatButtons ? 'open_in_new' : 'pageview';\r\n\r\n        break;\r\n      case 'edit':\r\n        i = 'edit'\r\n        break;\r\n      case 'delete':\r\n        i = 'delete'\r\n        break;\r\n\r\n      default:\r\n        break;\r\n    }\r\n\r\n    return i;\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n\r\n    if (button.disabled){\r\n      if (button.disabled(row)){\r\n        return 'lightgray'\r\n      }\r\n    }\r\n\r\n    if (button.color){\r\n      return button.color;\r\n    }\r\n\r\n    if (button.name == 'delete'){\r\n      return '#F44336'\r\n    }\r\n\r\n    if (button.name == 'create') {\r\n      return 'green'\r\n    }\r\n\r\n    return' #4050B5'\r\n  }\r\n\r\n\r\n  getOptions(column){\r\n    let x = this.config.columns.find(opt => opt.name === column);\r\n    return  x\r\n  }\r\n\r\n  getColor(v, options) {\r\n\r\n    let defaultColor = 'lightgrey'\r\n\r\n    if (!options) return defaultColor\r\n\r\n    let c = options.find(x => x.value == v)\r\n\r\n    if (c) {\r\n      return c.color\r\n    } else {\r\n      return defaultColor\r\n    }\r\n\r\n\r\n  }\r\n\r\n\r\n  testIconCondition(value: any, icon : Icon): boolean {\r\n\r\n    if (icon.condition) {\r\n      return icon.condition(value);\r\n\r\n    }else{\r\n      return true;\r\n    }\r\n  }\r\n\r\n  testColorCondition(value: any, color: Color): boolean {\r\n\r\n    if (!color) return false;\r\n\r\n    if (color.condition) {\r\n      return color.condition(value);\r\n\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  showBanner(message){\r\n\r\n    if (!message) return;\r\n    if (message == '') return;\r\n    this.messageService.info(message);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean{\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.disabled){\r\n\r\n      return button.disabled(row);\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.visible) {\r\n\r\n      return button.visible(row);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n\r\n  //Actions\r\n\r\n\r\n\r\n  loadData(action: Action, data: any) {\r\n    console.log(\"loading\")\r\n\r\n    if (action) {\r\n\r\n\r\n\r\n\r\n      this.dataService.CallApi(action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (this.config.logResponse){\r\n          console.log(apiResponse)\r\n        }\r\n\r\n        this.dataSource = apiResponse.data\r\n\r\n        this.tableDataSource = new MatTableDataSource<any>(apiResponse.data);\r\n        this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n        if (apiResponse.success) {\r\n          this.tableDataSource = new MatTableDataSource(apiResponse.data);\r\n          this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n          this.dataLoaded(apiResponse.data);\r\n\r\n\r\n        } else {\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n\r\n  //Events\r\n  searchClicked(x){\r\n    console.log(\"Search\")\r\n    this.searchClick.emit(x);\r\n\r\n    // console.log(x)\r\n\r\n    if (this.config.searchConfig.searchAction){\r\n      this.config.searchConfig.searchAction.method == 'post'\r\n      this.loadData(this.config.searchConfig.searchAction, x);\r\n    }\r\n  }\r\n\r\n  refreshClicked() {\r\n    console.log(\"Refresh\")\r\n    this.refreshClick.emit();\r\n\r\n\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction,\"\");\r\n    }else{\r\n      this.dataLoad.emit();\r\n    }\r\n  }\r\n\r\n  dataLoaded(x) {\r\n\r\n    this.dataLoad.emit(x)\r\n\r\n    console.log(\"dataloaded\")\r\n\r\n    if (this.config.tileConfig?.loadAction) {\r\n      this.tileReload.next(true);\r\n    }\r\n  }\r\n\r\n\r\n\r\n  actionClicked(name, row) {\r\n\r\n    if (name == 'view') {\r\n      this.viewModel(row)\r\n    }\r\n    else if (name == 'edit') {\r\n      this.editModel(row);\r\n    }\r\n    else if (name == 'delete') {\r\n      this.deleteModel(row);\r\n    }else{\r\n      this.customModel(name,row);\r\n    }\r\n\r\n  }\r\n\r\n\r\n\r\n\r\n  columnClicked(column : Column, row){\r\n\r\n    if (column.detailsConfig){\r\n\r\n      let conf = DetailsDialogProcessor.processDetailsConfig(column.detailsConfig, row)\r\n\r\n\r\n      const dialogRef = this.dialog.open(DetailsDialog, {\r\n        width: \"900px\",\r\n        data: conf\r\n      });\r\n\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n\r\n        if (result.message == \"success\") {\r\n          this.actionClickedEmit(column.name, row)\r\n          this.refreshClicked();\r\n        }\r\n\r\n      });\r\n    }\r\n    else{\r\n      this.actionClickedEmit(column.name, row)\r\n    }\r\n  }\r\n\r\n  customModel(name, row) {\r\n\r\n    let button = this.getButton(name);\r\n    if (button) {\r\n\r\n      if (!button.dialog){\r\n        this.doAction(button.name, row)\r\n        this.actionClickedEmit(name, row);\r\n      }\r\n      else{\r\n\r\n        if (button.detailsConfig) {\r\n\r\n          let conf = DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row)\r\n\r\n          const dialogRef = this.dialog.open(DetailsDialog, {\r\n            width: \"900px\",\r\n            data: conf\r\n          });\r\n\r\n          dialogRef.afterClosed().subscribe((result) => {\r\n\r\n            if (result.message == \"success\") {\r\n              this.actionClickedEmit(button.name, row)\r\n              this.refreshClicked();\r\n            }\r\n\r\n          });\r\n        }\r\n        else {\r\n          this.actionClickedEmit(button.name, row)\r\n        }\r\n      }\r\n\r\n    }else{\r\n      this.actionClickedEmit(name, row);\r\n    }\r\n\r\n\r\n\r\n  }\r\n\r\n\r\n  actionClickedEmit(name, row) {\r\n    console.log(\"Action clicked\")\r\n    this.actionClick.emit({name:name,data : row});\r\n  }\r\n\r\n\r\n\r\n\r\n  viewModel(row) {\r\n\r\n    console.log(\"view Clicked\")\r\n\r\n    let button = this.getButton('view');\r\n\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n\r\n    let conf: DetailsDialogConfig = {\r\n      formConfig: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details: row,\r\n    }\r\n\r\n    if (button.detailsConfig) {\r\n      conf = DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row)\r\n    }\r\n\r\n    conf.formConfig.mode = \"view\";\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialog, {\r\n      width: \"900px\",\r\n      data: conf\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result.message) {\r\n        this.refreshClicked();\r\n      }\r\n    });\r\n\r\n\r\n\r\n  }\r\n\r\n  newModel() {\r\n\r\n    let button = this.getButton('create');\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, null);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n    this.config.formConfig.mode = \"create\";\r\n    let conf : DetailsDialogConfig = {\r\n      formConfig : this.config.formConfig,\r\n      buttons : this.config.buttons,\r\n    }\r\n\r\n    if (button.detailsConfig) {\r\n      conf = button.detailsConfig;\r\n    }\r\n\r\n    conf.formConfig.mode = \"create\";\r\n    conf.heroField = this.config?.heroField;\r\n    conf.heroValue = this.config?.heroValue;\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialog, {\r\n      width: \"900px\",\r\n      data: conf,\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result.message == \"success\") {\r\n        this.actionClickedEmit('create',result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message == \"emit\") {\r\n        this.actionClickedEmit('create',result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n\r\n  editModel(row) {\r\n\r\n    let button = this.getButton('edit');\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n    let conf: DetailsDialogConfig = {\r\n      formConfig: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details : row,\r\n    }\r\n\r\n    if (button.detailsConfig) {\r\n      conf = DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row)\r\n    }\r\n\r\n    conf.formConfig.mode = \"edit\";\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialog, {\r\n      width: \"900px\",\r\n      data: conf\r\n    });\r\n\r\n\r\n    dialogRef.componentInstance.inputChange.subscribe((x) => {\r\n      this.inputChanged(x)\r\n    });\r\n\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      console.log(result)\r\n      if (result.message == \"success\") {\r\n        this.actionClickedEmit('edit',result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message == \"emit\") {\r\n        this.actionClickedEmit('edit',result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n  deleteModel(row) {\r\n\r\n    let button = this.getButton('delete');\r\n    if (!button) return;\r\n\r\n\r\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.actionClickedEmit('delete', row)\r\n        this.doAction(button.name,row);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n\r\n  doAction(buttonName: string, row) {\r\n\r\n    let b = this.getButton(buttonName)\r\n\r\n    if (!b) return;\r\n\r\n    if (!b.action) return;\r\n\r\n    if (b.confirm){\r\n      this.messageService.confirm(`${b.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.execAction(b,row)\r\n        }\r\n      });\r\n    }else{\r\n      this.execAction(b, row)\r\n    }\r\n\r\n  }\r\n\r\n\r\n  execAction(b: Button, row){\r\n    this.dataService.CallApi(b.action, row).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        if (b.action.successMessage) {\r\n          this.messageService.toast(b.action.successMessage);\r\n        } else {\r\n\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.refreshClicked();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    },\r\n      (error) => {\r\n        this.messageService.toast(\"Error: \" + error);\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n}\r\n","\n<spa-search *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\n\n<div class=\"top\">\n\n  <div class=\"tin-row\" >\n    <button *ngIf=\"createButton && !config.flatButtons\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}</button>\n    <button *ngIf=\"createButton && config.flatButtons\" id=\"btnNew\" mat-stroked-button style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}</button>\n  </div>\n\n  <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\n    <spa-tiles  [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n  </div>\n\n  <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\n    <spa-filter [showText]=\"!smallScreen || (smallScreen && dataSource?.length > 10)\" [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" [flatButtons]=\"config.flatButtons\" (refreshClick)=\"refreshClicked()\"></spa-filter>\n  </div>\n\n</div>\n\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\n  <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n</div>\n\n<div *ngIf=\"config.title && !hideTitle\" class=\"title\">\n  <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\n</div>\n\n<div>\n\n  <p *ngIf=\"!config\"><em>Configure Table</em></p>\n  <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\n\n\n\n  <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\n\n\n    <table mat-table [dataSource]=\"tableDataSource\"  [ngClass]=\"elevation\">\n      <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\n        <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\n        <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\n\n          <ng-container [ngSwitch]=\"column.type\">\n\n            <ng-container *ngSwitchCase=\"'checkbox'\">\n              <spa-check [value]=\"row[column.name]\" [readonly]=\"true\"></spa-check>\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'select'\">\n              <spa-select [options]=\"column.options\" [optionDisplay]=\"column.optionDisplay\" [optionValue]=\"column.optionValue\" [(value)]=\"row[column.name]\" width=\"90%\" ></spa-select>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'chip'\">\n              <mat-chip-list>\n                <mat-chip (click)=\"columnClicked(column, row)\" [ngStyle]=\"{'background-color': testColorCondition(row, column.color) ? column.color.name : getColor(row[column.name], column?.options)}\" style=\"font-size: 12px;\"> {{row[column.name]}} </mat-chip>\n                  <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n                  <ng-container *ngFor=\"let icon of column.icons\">\n                    <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n                  </ng-container>\n              </mat-chip-list>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'icon'\">\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'date'\">\n              {{row[column.name] | date : 'dd/MM/yyyy'}}\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'datetime'\">\n              {{row[column.name] | date : 'dd/MM/yyyy HH:mm'}}\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <!-- <ng-container *ngSwitchCase=\"'spinner'\">\n                <mat-spinner [diameter]=\"20\">\n\n                </mat-spinner>\n            </ng-container> -->\n\n            <ng-container *ngSwitchCase=\"'money'\">\n\n              <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name] | currency:'':''}}</label>\n\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'button'\">\n\n              <button mat-button [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\" (click)=\"actionClicked(column.name, row)\">{{row[column.name]}}</button>\n\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchDefault>\n              <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name]}}</label>\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n\n            </ng-container>\n\n          </ng-container>\n\n\n        </td>\n      </ng-container>\n\n      <ng-container matColumnDef=\"action\">\n        <th mat-header-cell *matHeaderCellDef> Action </th>\n        <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\n          <div class=\"action-buttons-container\">\n\n            <ng-container *ngFor=\"let button of displayedButtons\">\n\n              <ng-container *ngIf=\"button.name != 'create' && testVisible(row,button.name)\">\n\n                <button *ngIf=\"!config.flatButtons\" mat-mini-fab [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n                  [ngStyle]=\"{'background-color':getButtonColor(button, row)}\"\n                  [disabled]=\"testDisabled(row,button.name)\" (click)=\"actionClicked(button.name, row)\">\n                  <mat-icon>{{getIcon(button.name)}}</mat-icon>\n                </button>\n\n                <button *ngIf=\"config.flatButtons\" mat-icon-button [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n                  [disabled]=\"testDisabled(row,button.name)\" (click)=\"actionClicked(button.name, row)\">\n                  <mat-icon [ngStyle]=\"{'color':getButtonColor(button, row)}\">{{getIcon(button.name)}}</mat-icon>\n                </button>\n\n              </ng-container>\n\n              <ng-container *ngIf=\"button.name != 'create' && !testVisible(row,button.name) && !config.collapseButtons\">\n                <label style=\"margin-right: 35px;\"></label>\n              </ng-container>\n\n            </ng-container>\n          </div>\n\n\n\n\n\n        </td>\n      </ng-container>\n\n\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\n    </table>\n\n  </div>\n\n  <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\n\n</div>\n\n<div class=\"tin-center\">\n  <p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\n</div>\n\n\n\n"]}
388
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table/table.component.ts","../../../../../../projects/tin-spa/src/lib/components/table/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE7D,OAAO,EAAsD,UAAU,EAAkC,MAAM,uBAAuB,CAAC;AAIvI,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAG1D,OAAO,EAAQ,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;;;;;;;AAW/B,MAAM,OAAO,cAAc;IAEzB,YAAoB,WAA2B,EAAU,cAA8B,EAAU,kBAAsC,EAAS,MAAiB,EACvJ,aAA4B,EAAU,aAA4B,EAAU,kBAAsC,EAAU,gBAAkC;QADpJ,gBAAW,GAAX,WAAW,CAAgB;QAAU,mBAAc,GAAd,cAAc,CAAgB;QAAU,uBAAkB,GAAlB,kBAAkB,CAAoB;QAAS,WAAM,GAAN,MAAM,CAAW;QACvJ,kBAAa,GAAb,aAAa,CAAe;QAAU,kBAAa,GAAb,aAAa,CAAe;QAAU,uBAAkB,GAAlB,kBAAkB,CAAoB;QAAU,qBAAgB,GAAhB,gBAAgB,CAAkB;QAwBxK,cAAS,GAAG,kBAAkB,CAAC;QAC/B,iBAAY,GAAG,MAAM,CAAC;QACtB,qBAAgB,GAAG,IAAI,CAAC;QACxB,eAAU,GAAqB,IAAI,OAAO,EAAE,CAAC;QAE7C,gBAAW,GAAG,KAAK,CAAA;QAMnB,qBAAgB,GAAG,EAAE,CAAA;QACrB,qBAAgB,GAAG,EAAE,CAAA;QAIZ,cAAS,GAAG,KAAK,CAAC;QAClB,SAAI,GAAQ,EAAE,CAAC;QAGd,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAC9B,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAClC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QA/CzC,6BAA6B;QAC7B,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAuB,EAAE,EAAE;YAC5F,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC;YAClC,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QAET,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC;YAC5B,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAM,IAAI,CAAC,UAAU,CAAC,CAAC;SACrE;QAED,UAAU,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;IACnF,CAAC;IA8BO,mBAAmB;QACzB,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAEO,wBAAwB;QAC9B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAChE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1F,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAChI,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACnF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC7E,IAAI,CAAC,gBAAgB,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,YAAY,CAAC;QAEnD,IAAI,IAAI,CAAC,gBAAgB,EAAE,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YAClF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtC;IACH,CAAC;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;SAC3C;QAED,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;gBACxB,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE;oBAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;iBAC3C;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,QAAQ,CAAC,MAAc,EAAE,IAAS;QAChC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;QAEtB,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,WAAwB,EAAE,EAAE;gBAE5E,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;oBAC3B,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;iBACzB;gBAED,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,IAAI,CAAA;gBAElC,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAM,WAAW,CAAC,IAAI,CAAC,CAAC;gBACrE,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC;gBAErD,IAAI,WAAW,CAAC,OAAO,EAAE;oBACvB,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;oBAChE,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC;oBAErD,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;iBAEnC;qBAAM;oBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;iBAC5D;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAGD,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAA;IACnE,CAAC;IAED,YAAY;QAEV,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,MAAM,GAAG,IAAI,UAAU,CAAA;YAE3B,MAAM,CAAC,MAAM,GAAG,EAAE,CAAA;YAElB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAEnC,IAAI,KAAK,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAA;gBACpD,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAE3B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC;SACjC;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1F,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC9H,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAEnF,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YACjF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtC;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;YAAE,OAAM;QAChC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;SAC7C;aAAI;YACH,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;SAC7C;IACH,CAAC;IAED,SAAS,CAAC,IAAY;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACjE,CAAC;IAED,OAAO,CAAC,UAAkB;QACxB,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACzD,CAAC;IAED,cAAc,CAAC,MAAc,EAAE,GAAG;QAChC,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACxD,CAAC;IAED,UAAU,CAAC,MAAM;QACf,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;QAC7D,OAAQ,CAAC,CAAA;IACX,CAAC;IAED,QAAQ,CAAC,KAAU,EAAE,OAAc;QACjC,OAAO,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACxD,CAAC;IAED,iBAAiB,CAAC,GAAQ,EAAE,IAAU;QACpC,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IAC5D,CAAC;IAED,kBAAkB,CAAC,GAAQ,EAAE,KAAY;QACvC,OAAO,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC9D,CAAC;IAED,UAAU,CAAC,OAAe;QACxB,IAAI,OAAO,IAAI,OAAO,KAAK,EAAE,EAAE;YAC7B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACnC;IACH,CAAC;IAED,YAAY,CAAC,GAAG,EAAE,UAAkB;QAClC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACtD,CAAC;IAED,WAAW,CAAC,GAAG,EAAE,UAAkB;QACjC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACrD,CAAC;IAID,QAAQ;IACR,aAAa,CAAC,CAAC;QACb,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAEzB,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,EAAC;YACxC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,IAAI,MAAM,CAAA;YACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;SACzD;IACH,CAAC;IAED,cAAc;QACZ,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;QACtB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAEzB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAC,EAAE,CAAC,CAAC;SAC1C;aAAI;YACH,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;SACtB;IACH,CAAC;IAED,UAAU,CAAC,CAAC;QACV,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAA;QACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAErB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,UAAU,EAAE;YACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC5B;IACH,CAAC;IAED,aAAa,CAAC,IAAY,EAAE,GAAQ;QAClC,IAAI,IAAI,KAAK,MAAM,EAAE;YACnB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SACrB;aAAM,IAAI,IAAI,KAAK,MAAM,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SACrB;aAAM,IAAI,IAAI,KAAK,QAAQ,EAAE;YAC5B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;SACvB;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SAC7B;IACH,CAAC;IAGD,eAAe;IACf,aAAa,CAAC,MAAe,EAAE,GAAG;QAChC,IAAI,MAAM,CAAC,aAAa,EAAE;YACxB,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;SAClD;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SAC1C;IACH,CAAC;IAED,WAAW,CAAC,IAAI,EAAE,GAAG;QACnB,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IACpC,CAAC;IAGD,iBAAiB,CAAC,IAAI,EAAE,GAAG;QACzB,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAA;QAC7B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,IAAI,EAAC,IAAI,EAAC,IAAI,EAAG,GAAG,EAAC,CAAC,CAAC;IAChD,CAAC;IAED,SAAS,CAAC,GAAG;QACX,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC5B,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACtC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,SAAS,CAAC,GAAG;QACX,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACtC,CAAC;IAEO,iBAAiB,CAAC,UAAkB,EAAE,GAAe,EAAE,MAAe;QAC5E,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC9H,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAClB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;YAC/B,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YACzC,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE;YACpD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;YACnD,OAAO;SACR;QAED,IAAI,IAAI,GAAwB;YAC9B,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU;YAClC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;YAC5B,OAAO,EAAE,GAAG;SACb,CAAC;QAEF,IAAI,MAAM,CAAC,aAAa,EAAE;YACxB,IAAI,GAAG,UAAU,KAAK,QAAQ;gBAC5B,CAAC,CAAC,MAAM,CAAC,aAAa;gBACtB,CAAC,CAAC,sBAAsB,CAAC,oBAAoB,CAAC,MAAM,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;SAC5E;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAEtG,IAAI,UAAU,KAAK,QAAQ,EAAE;YAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC;YACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC;SACzC;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC;QAE/E,IAAI,UAAU,KAAK,MAAM,EAAE;YACzB,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;gBACvC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;SACJ;QAED,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC5C,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS,EAAE;gBAChC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;gBACjD,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;iBAAM,IAAI,MAAM,CAAC,OAAO,KAAK,MAAM,EAAE;gBACpC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;aAClD;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,GAAG;QAEb,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3D,IAAI,MAAM,IAAI,KAAK,EAAE;gBACnB,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAA;gBACrC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAC,GAAG,CAAC,CAAC;aAChC;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAGD,SAAS;IACT,QAAQ,CAAC,UAAkB,EAAE,GAAG;QAE9B,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;QAElC,IAAI,CAAC,CAAC;YAAE,OAAO;QACf,IAAI,CAAC,CAAC,CAAC,MAAM;YAAE,OAAO;QAEtB,IAAI,CAAC,CAAC,OAAO,EAAC;YACZ,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;gBACvE,IAAI,MAAM,IAAI,KAAK,EAAE;oBACnB,IAAI,CAAC,UAAU,CAAC,CAAC,EAAC,GAAG,CAAC,CAAA;iBACvB;YACH,CAAC,CAAC,CAAC;SACJ;aAAI;YACH,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;SACxB;IAEH,CAAC;IAED,UAAU,CAAC,CAAS,EAAE,GAAG;QACvB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;YAEhE,IAAI,WAAW,CAAC,OAAO,EAAE;gBACvB,IAAI,CAAC,CAAC,MAAM,CAAC,cAAc,EAAE;oBAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;iBACpD;qBAAM;oBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;iBACtC;gBAED,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;iBAAM;gBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;aAC5D;QACH,CAAC,EACC,CAAC,KAAK,EAAE,EAAE;YACR,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC;QAC/C,CAAC,CACF,CAAC;IACJ,CAAC;IAGD,MAAM;IACE,iBAAiB,CAAC,SAAiB;QAEzC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;QACtB,IAAI,SAAS,IAAI,MAAM,EAAC;YACtB,OAAO,EAAE,CAAA;SACV;aACI,IAAI,SAAS,IAAI,KAAK,EAAC;YAC1B,OAAO,kBAAkB,CAAA;SAC1B;aACI,IAAI,SAAS,IAAI,QAAQ,EAAC;YAC7B,OAAO,kBAAkB,CAAA;SAC1B;aACI,IAAI,SAAS,IAAI,MAAM,EAAC;YAC3B,OAAO,kBAAkB,CAAA;SAC1B;aACG;YACF,OAAO,kBAAkB,CAAA;SAC1B;IAEH,CAAC;;2GA1ZU,cAAc;+FAAd,cAAc,+bCtB3B,spFAkEA;2FD5Ca,cAAc;kBAL1B,SAAS;+BACE,WAAW;mTA6CQ,cAAc;sBAA1C,SAAS;uBAAC,gBAAgB;gBAElB,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACI,QAAQ;sBAAjB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { DatePipe, CurrencyPipe } from '@angular/common';\r\nimport { Action, Button, Color, Column, DetailsDialogConfig, FormConfig, Icon, TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { DetailsDialog } from './detailsDialog.component';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { Subject } from 'rxjs';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { TableConfigService } from '../../services/table-config.service';\r\nimport { ConditionService } from '../../services/condition.service';\r\n\r\n@Component({\r\n  selector: 'spa-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.css']\r\n})\r\nexport class TableComponent implements OnInit {\r\n\r\n  constructor(private dataService: DataServiceLib, private messageService: MessageService, private breakpointObserver: BreakpointObserver, public dialog: MatDialog,\r\n    private buttonService: ButtonService, private dialogService: DialogService, private tableConfigService: TableConfigService, private conditionService: ConditionService )\r\n  {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n      this.smallScreen = result.matches;\r\n      this.updateTableConfiguration();\r\n    });\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.initializeComponent();\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (!this.config.loadAction) {\r\n      this.dataSource = this.data;\r\n      this.tableDataSource = new MatTableDataSource<any>(this.dataSource);\r\n    }\r\n\r\n    setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 1000)\r\n  }\r\n\r\n\r\n  elevation = \"mat-elevation-z5\";\r\n  actionsWidth = \"50px\";\r\n  showFilterButton = true;\r\n  tileReload: Subject<boolean> = new Subject();\r\n\r\n  smallScreen = false\r\n  createButton: Button;\r\n\r\n  //Table\r\n  tableDataSource;\r\n  dataSource: any[];\r\n  displayedColumns = []\r\n  displayedButtons = []\r\n\r\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\r\n\r\n  @Input() hideTitle = false;\r\n  @Input() data: any = [];\r\n  @Input() config: TableConfig;\r\n  @Input() reload: Subject<boolean>;\r\n  @Output() dataLoad = new EventEmitter();\r\n  @Output() refreshClick = new EventEmitter();\r\n  @Output() searchClick = new EventEmitter();\r\n  @Output() createClick = new EventEmitter();\r\n  @Output() actionClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  private initializeComponent() {\r\n    this.updateTableConfiguration();\r\n    this.setupDataLoading();\r\n    this.formDefaults();\r\n  }\r\n\r\n  private updateTableConfiguration() {\r\n    this.elevation = this.getElevationClass(this.config?.elevation);\r\n    this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);\r\n    this.displayedButtons = this.buttonService.getDisplayedButtons(this.config?.buttons, this.smallScreen, this.config?.minButtons);\r\n    this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);\r\n    this.createButton = this.buttonService.getCreateButton(this.config?.buttons);\r\n    this.showFilterButton = !this.config?.searchConfig;\r\n\r\n    if (this.displayedButtons?.length > 0 && !this.displayedColumns.includes('action')) {\r\n      this.displayedColumns.push('action');\r\n    }\r\n  }\r\n\r\n  private setupDataLoading() {\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction, \"\");\r\n    }\r\n\r\n    if (this.reload) {\r\n      this.reload.subscribe(v => {\r\n        if (v && this.config?.loadAction) {\r\n          this.loadData(this.config.loadAction, \"\");\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  loadData(action: Action, data: any) {\r\n    console.log(\"loading\")\r\n\r\n    if (action) {\r\n      this.dataService.CallApi(action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (this.config.logResponse) {\r\n          console.log(apiResponse)\r\n        }\r\n\r\n        this.dataSource = apiResponse.data\r\n\r\n        this.tableDataSource = new MatTableDataSource<any>(apiResponse.data);\r\n        this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n        if (apiResponse.success) {\r\n          this.tableDataSource = new MatTableDataSource(apiResponse.data);\r\n          this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n          this.dataLoaded(apiResponse.data);\r\n\r\n        } else {\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n  }\r\n\r\n  formDefaults() {\r\n\r\n    if (!this.config.formConfig) {\r\n      let config = new FormConfig\r\n\r\n      config.fields = []\r\n\r\n      this.config.columns.forEach(column => {\r\n\r\n        let field = { name: column.name, type: column.type }\r\n        config.fields.push(field)\r\n\r\n      });\r\n\r\n      this.config.formConfig = config;\r\n    }\r\n  }\r\n\r\n  setColumns() {\r\n    this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);\r\n    this.displayedButtons = this.buttonService.getDisplayedButtons(this.config.buttons, this.smallScreen, this.config.minButtons);\r\n    this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);\r\n\r\n    if (this.displayedButtons.length > 0 && !this.displayedColumns.includes('action')) {\r\n      this.displayedColumns.push('action');\r\n    }\r\n  }\r\n\r\n  setButtons(){\r\n    if (!this.config.buttons) return\r\n    if (!this.smallScreen){\r\n      this.displayedButtons = this.config.buttons;\r\n    }else{\r\n      this.displayedButtons = this.config.buttons;\r\n    }\r\n  }\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.config.buttons, name);\r\n  }\r\n\r\n  getIcon(buttonName: string) {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.getIcon(button, this.config);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getOptions(column){\r\n    let x = this.config.columns.find(opt => opt.name === column);\r\n    return  x\r\n  }\r\n\r\n  getColor(value: any, options: any[]): string {\r\n    return this.conditionService.getColor(value, options);\r\n  }\r\n\r\n  testIconCondition(row: any, icon: Icon): boolean {\r\n    return this.conditionService.testIconCondition(icon, row);\r\n  }\r\n\r\n  testColorCondition(row: any, color: Color): boolean {\r\n    return this.conditionService.testColorCondition(color, row);\r\n  }\r\n\r\n  showBanner(message: string) {\r\n    if (message && message !== '') {\r\n      this.messageService.info(message);\r\n    }\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.testDisabled(button, row);\r\n  }\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.testVisible(button, row);\r\n  }\r\n\r\n\r\n\r\n  //Events\r\n  searchClicked(x){\r\n    console.log(\"Search\")\r\n    this.searchClick.emit(x);\r\n\r\n    if (this.config.searchConfig.searchAction){\r\n      this.config.searchConfig.searchAction.method == 'post'\r\n      this.loadData(this.config.searchConfig.searchAction, x);\r\n    }\r\n  }\r\n\r\n  refreshClicked() {\r\n    console.log(\"Refresh\")\r\n    this.refreshClick.emit();\r\n\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction,\"\");\r\n    }else{\r\n      this.dataLoad.emit();\r\n    }\r\n  }\r\n\r\n  dataLoaded(x) {\r\n    console.log(\"dataloaded\")\r\n    this.dataLoad.emit(x)\r\n\r\n    if (this.config.tileConfig?.loadAction) {\r\n      this.tileReload.next(true);\r\n    }\r\n  }\r\n\r\n  actionClicked(name: string, row: any) {\r\n    if (name === 'view') {\r\n      this.viewModel(row);\r\n    } else if (name === 'edit') {\r\n      this.editModel(row);\r\n    } else if (name === 'delete') {\r\n      this.deleteModel(row);\r\n    } else {\r\n      this.customModel(name, row);\r\n    }\r\n  }\r\n\r\n\r\n  //Dialog events\r\n  columnClicked(column : Column, row){\r\n    if (column.detailsConfig) {\r\n      this.openDetailsDialog(column.name, row, column);\r\n    } else {\r\n      this.actionClickedEmit(column.name, row);\r\n    }\r\n  }\r\n\r\n  customModel(name, row) {\r\n    this.openDetailsDialog(name, row);\r\n  }\r\n\r\n\r\n  actionClickedEmit(name, row) {\r\n    console.log(\"Action clicked\")\r\n    this.actionClick.emit({name:name,data : row});\r\n  }\r\n\r\n  viewModel(row) {\r\n    console.log(\"view Clicked\");\r\n    this.openDetailsDialog('view', row);\r\n  }\r\n\r\n  newModel() {\r\n    this.openDetailsDialog('create', null);\r\n  }\r\n\r\n  editModel(row) {\r\n    this.openDetailsDialog('edit', row);\r\n  }\r\n\r\n  private openDetailsDialog(buttonName: string, row: any | null, column?: Column): void {\r\n    const button = column ? { name: column.name, dialog: true, detailsConfig: column.detailsConfig } : this.getButton(buttonName);\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.doAction(button.name, row)\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig && !button.detailsConfig) {\r\n      this.messageService.toast(\"Please configure form\");\r\n      return;\r\n    }\r\n\r\n    let conf: DetailsDialogConfig = {\r\n      formConfig: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details: row,\r\n    };\r\n\r\n    if (button.detailsConfig) {\r\n      conf = buttonName === 'create'\r\n        ? button.detailsConfig\r\n        : DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);\r\n    }\r\n\r\n    conf.formConfig.mode = buttonName === 'create' ? 'create' : (buttonName === 'edit' ? 'edit' : 'view');\r\n\r\n    if (buttonName === 'create') {\r\n      conf.heroField = this.config?.heroField;\r\n      conf.heroValue = this.config?.heroValue;\r\n    }\r\n\r\n    const dialogResult = this.dialogService.openDetailsDialog(conf, DetailsDialog);\r\n\r\n    if (buttonName === 'edit') {\r\n      dialogResult.inputChange.subscribe((x) => {\r\n        this.inputChanged(x);\r\n      });\r\n    }\r\n\r\n    dialogResult.afterClosed.subscribe((result) => {\r\n      if (result.message === 'success') {\r\n        this.actionClickedEmit(button.name, result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message === 'emit') {\r\n        this.actionClickedEmit(button.name, result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n  deleteModel(row) {\r\n\r\n    let button = this.getButton('delete');\r\n    if (!button) return;\r\n\r\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.actionClickedEmit('delete', row)\r\n        this.doAction(button.name,row);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n\r\n  //Actions\r\n  doAction(buttonName: string, row) {\r\n\r\n    let b = this.getButton(buttonName)\r\n\r\n    if (!b) return;\r\n    if (!b.action) return;\r\n\r\n    if (b.confirm){\r\n      this.messageService.confirm(`${b.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.execAction(b,row)\r\n        }\r\n      });\r\n    }else{\r\n      this.execAction(b, row)\r\n    }\r\n\r\n  }\r\n\r\n  execAction(b: Button, row){\r\n    this.dataService.CallApi(b.action, row).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        if (b.action.successMessage) {\r\n          this.messageService.toast(b.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.refreshClicked();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    },\r\n      (error) => {\r\n        this.messageService.toast(\"Error: \" + error);\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n  //Misc\r\n  private getElevationClass(elevation: string): string {\r\n\r\n    console.log(elevation)\r\n    if (elevation == \"none\"){\r\n      return \"\"\r\n    }\r\n    else if (elevation == \"low\"){\r\n      return \"mat-elevation-z1\"\r\n    }\r\n    else if (elevation == \"medium\"){\r\n      return \"mat-elevation-z5\"\r\n    }\r\n    else if (elevation == \"high\"){\r\n      return \"mat-elevation-z9\"\r\n    }\r\n    else{\r\n      return \"mat-elevation-z5\"\r\n    }\r\n\r\n  }\r\n\r\n}\r\n","\r\n<!-- Search -->\r\n<spa-search\r\n  *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n  [config]=\"config\" [hideTitle]=\"false\" [tableDataSource]=\"tableDataSource\" [createButton]=\"createButton\" [tileConfig]=\"config.tileConfig\" [smallScreen]=\"smallScreen\"\r\n  [tileReload]=\"tileReload\" [showFilterButton]=\"showFilterButton\" (createClick)=\"newModel()\" (refreshClick)=\"refreshClicked()\">\r\n</app-table-header>\r\n\r\n\r\n<!-- Table -->\r\n<div>\r\n\r\n  <p *ngIf=\"!config\"><em>Configure Table</em></p>\r\n  <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\r\n\r\n  <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\r\n\r\n    <table mat-table [dataSource]=\"tableDataSource\"  [ngClass]=\"elevation\">\r\n\r\n      <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\r\n        <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\r\n        <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\r\n\r\n          <!-- Rows -->\r\n          <app-table-row [column]=\"column\" [row]=\"row\" [config]=\"config\"\r\n            (actionClick)=\"actionClicked(column.name, row)\" (columnClick)=\"columnClicked(column, row)\" (showBannerEvent)=\"showBanner($event)\">\r\n          </app-table-row>\r\n\r\n        </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"action\">\r\n        <th mat-header-cell *matHeaderCellDef> Action </th>\r\n        <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\r\n          <div class=\"action-buttons-container\">\r\n\r\n            <!-- Actions -->\r\n            <app-table-action\r\n              [displayedButtons]=\"displayedButtons\" [config]=\"config\" [row]=\"row\" (actionClick)=\"actionClicked($event.name, $event.row)\">\r\n            </app-table-action>\r\n\r\n          </div>\r\n        </td>\r\n      </ng-container>\r\n\r\n\r\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\r\n    </table>\r\n\r\n  </div>\r\n\r\n  <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n\r\n</div>\r\n\r\n<div class=\"tin-center\">\r\n  <p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\r\n</div>\r\n\r\n\r\n\r\n"]}