tin-spa 2.2.3 → 2.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/accounts/accountDialog.component.mjs +2 -2
- package/esm2020/lib/components/accounts/accounts.component.mjs +2 -2
- package/esm2020/lib/components/attach/attach.component.mjs +1 -20
- package/esm2020/lib/components/change-password/change-password.component.mjs +2 -2
- package/esm2020/lib/components/create-account/create-account.component.mjs +2 -2
- package/esm2020/lib/components/customers/customers.component.mjs +2 -2
- package/esm2020/lib/components/date/date.component.mjs +23 -16
- package/esm2020/lib/components/departments/departments.component.mjs +6 -26
- package/esm2020/lib/components/employees/employees.component.mjs +10 -53
- package/esm2020/lib/components/form/form.component.mjs +2 -2
- package/esm2020/lib/components/inventory/inventory.component.mjs +2 -2
- package/esm2020/lib/components/inventory/quantityDialog.component.mjs +2 -2
- package/esm2020/lib/components/invitations-table/invitations-table.component.mjs +2 -2
- package/esm2020/lib/components/list-dialog/list-dialog.component.mjs +2 -2
- package/esm2020/lib/components/login/login.component.mjs +2 -2
- package/esm2020/lib/components/logs/logs.component.mjs +2 -2
- package/esm2020/lib/components/membership/membership.component.mjs +2 -2
- package/esm2020/lib/components/nav-menu/nav-menu.component.mjs +2 -2
- package/esm2020/lib/components/plans/plans.component.mjs +2 -2
- package/esm2020/lib/components/positions/positions.component.mjs +13 -6
- package/esm2020/lib/components/profile/profile.component.mjs +2 -2
- package/esm2020/lib/components/recover-account/recover-account.component.mjs +2 -2
- package/esm2020/lib/components/roles/addRoleDialog.component.mjs +2 -2
- package/esm2020/lib/components/roles/roles.component.mjs +2 -2
- package/esm2020/lib/components/settings/settings.component.mjs +2 -2
- package/esm2020/lib/components/signup/signup.component.mjs +2 -2
- package/esm2020/lib/components/suppliers/suppliers.component.mjs +2 -2
- package/esm2020/lib/components/table/detailsDialog.component.mjs +72 -142
- package/esm2020/lib/components/table/table.component.mjs +151 -333
- package/esm2020/lib/components/table-action/table-action.component.mjs +46 -0
- package/esm2020/lib/components/table-header/table-header.component.mjs +52 -0
- package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +78 -139
- package/esm2020/lib/components/table-internal/table-internal.component.mjs +153 -334
- package/esm2020/lib/components/table-row/table-row.component.mjs +58 -0
- package/esm2020/lib/components/tasks/tasks.component.mjs +2 -2
- package/esm2020/lib/components/tenant-settings/inviteDialog.component.mjs +2 -2
- package/esm2020/lib/components/tenant-settings/tenant-settings.component.mjs +2 -2
- package/esm2020/lib/components/tenants/tenants.component.mjs +2 -2
- package/esm2020/lib/components/tiles/tiles.component.mjs +2 -2
- package/esm2020/lib/components/transactions/transactDialog.component.mjs +2 -2
- package/esm2020/lib/components/transactions/transactions.component.mjs +2 -2
- package/esm2020/lib/components/users/users.component.mjs +2 -2
- package/esm2020/lib/components/viewer/viewer.component.mjs +2 -2
- package/esm2020/lib/components/welcome/welcome.component.mjs +2 -2
- package/esm2020/lib/services/button.service.mjs +100 -0
- package/esm2020/lib/services/condition.service.mjs +32 -0
- package/esm2020/lib/services/datalib.service.mjs +387 -0
- package/esm2020/lib/services/dialog.service.mjs +38 -0
- package/esm2020/lib/services/table-config.service.mjs +26 -0
- package/esm2020/lib/tin-spa.module.mjs +6 -3
- package/esm2020/public-api.mjs +3 -2
- package/fesm2015/tin-spa.mjs +963 -1075
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +970 -1070
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/lib/components/accounts/accountDialog.component.d.ts +1 -1
- package/lib/components/accounts/accounts.component.d.ts +1 -1
- package/lib/components/attach/attach.component.d.ts +0 -19
- package/lib/components/change-password/change-password.component.d.ts +1 -1
- package/lib/components/create-account/create-account.component.d.ts +1 -1
- package/lib/components/customers/customers.component.d.ts +1 -1
- package/lib/components/date/date.component.d.ts +10 -9
- package/lib/components/departments/departments.component.d.ts +2 -5
- package/lib/components/employees/employees.component.d.ts +3 -14
- package/lib/components/form/form.component.d.ts +1 -1
- package/lib/components/inventory/inventory.component.d.ts +1 -1
- package/lib/components/inventory/quantityDialog.component.d.ts +1 -1
- package/lib/components/invitations-table/invitations-table.component.d.ts +1 -1
- package/lib/components/list-dialog/list-dialog.component.d.ts +1 -1
- package/lib/components/login/login.component.d.ts +1 -1
- package/lib/components/logs/logs.component.d.ts +1 -1
- package/lib/components/membership/membership.component.d.ts +1 -1
- package/lib/components/nav-menu/nav-menu.component.d.ts +1 -1
- package/lib/components/plans/plans.component.d.ts +1 -1
- package/lib/components/positions/positions.component.d.ts +5 -1
- package/lib/components/profile/profile.component.d.ts +1 -1
- package/lib/components/recover-account/recover-account.component.d.ts +1 -1
- package/lib/components/roles/addRoleDialog.component.d.ts +1 -1
- package/lib/components/roles/roles.component.d.ts +1 -1
- package/lib/components/settings/settings.component.d.ts +1 -1
- package/lib/components/signup/signup.component.d.ts +1 -1
- package/lib/components/suppliers/suppliers.component.d.ts +1 -1
- package/lib/components/table/detailsDialog.component.d.ts +11 -4
- package/lib/components/table/table.component.d.ts +28 -15
- package/lib/components/table-action/table-action.component.d.ts +22 -0
- package/lib/components/table-header/table-header.component.d.ts +22 -0
- package/lib/components/table-internal/detailsDialog-internal.component.d.ts +16 -6
- package/lib/components/table-internal/table-internal.component.d.ts +28 -15
- package/lib/components/table-row/table-row.component.d.ts +28 -0
- package/lib/components/tasks/tasks.component.d.ts +1 -1
- package/lib/components/tenant-settings/inviteDialog.component.d.ts +1 -1
- package/lib/components/tenant-settings/tenant-settings.component.d.ts +1 -1
- package/lib/components/tenants/tenants.component.d.ts +1 -1
- package/lib/components/tiles/tiles.component.d.ts +1 -1
- package/lib/components/transactions/transactDialog.component.d.ts +1 -1
- package/lib/components/transactions/transactions.component.d.ts +1 -1
- package/lib/components/users/users.component.d.ts +1 -1
- package/lib/components/viewer/viewer.component.d.ts +1 -1
- package/lib/components/welcome/welcome.component.d.ts +1 -1
- package/lib/services/button.service.d.ts +27 -0
- package/lib/services/condition.service.d.ts +10 -0
- package/lib/services/{data.service.d.ts → datalib.service.d.ts} +15 -1
- package/lib/services/dialog.service.d.ts +18 -0
- package/lib/services/table-config.service.d.ts +8 -0
- package/lib/tin-spa.module.d.ts +8 -5
- package/package.json +1 -1
- package/public-api.d.ts +2 -1
- package/esm2020/lib/services/data.service.mjs +0 -236
|
@@ -5,33 +5,41 @@ import { DetailsDialogInternal } from './detailsDialog-internal.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/
|
|
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 "
|
|
13
|
-
import * as i6 from "
|
|
14
|
-
import * as i7 from "
|
|
15
|
-
import * as i8 from "
|
|
16
|
-
import * as i9 from "@angular/
|
|
17
|
-
import * as i10 from "@angular/material/
|
|
18
|
-
import * as i11 from "@angular/material/
|
|
19
|
-
import * as i12 from "
|
|
20
|
-
import * as i13 from "../
|
|
21
|
-
import * as i14 from "../
|
|
22
|
-
import * as i15 from "../
|
|
23
|
-
import * as i16 from "../
|
|
24
|
-
import * as i17 from "
|
|
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 "@angular/material/button";
|
|
20
|
+
import * as i13 from "../filter/filter.component";
|
|
21
|
+
import * as i14 from "../tiles/tiles.component";
|
|
22
|
+
import * as i15 from "../search/search.component";
|
|
23
|
+
import * as i16 from "../table-row/table-row.component";
|
|
24
|
+
import * as i17 from "../table-action/table-action.component";
|
|
25
|
+
import * as i18 from "../../pipes/camelToWords.pipe";
|
|
25
26
|
export class TableInternalComponent {
|
|
26
|
-
constructor(dataService, messageService, breakpointObserver, dialog) {
|
|
27
|
+
constructor(dataService, messageService, breakpointObserver, dialog, buttonService, dialogService, tableConfigService, conditionService) {
|
|
27
28
|
this.dataService = dataService;
|
|
28
29
|
this.messageService = messageService;
|
|
29
30
|
this.breakpointObserver = breakpointObserver;
|
|
30
31
|
this.dialog = dialog;
|
|
32
|
+
this.buttonService = buttonService;
|
|
33
|
+
this.dialogService = dialogService;
|
|
34
|
+
this.tableConfigService = tableConfigService;
|
|
35
|
+
this.conditionService = conditionService;
|
|
31
36
|
this.elevation = "mat-elevation-z5";
|
|
32
37
|
this.actionsWidth = "50px";
|
|
33
38
|
this.showFilterButton = true;
|
|
34
39
|
this.tileReload = new Subject();
|
|
40
|
+
this.smallScreen = false;
|
|
41
|
+
this.displayedColumns = [];
|
|
42
|
+
this.displayedButtons = [];
|
|
35
43
|
this.hideTitle = false;
|
|
36
44
|
this.data = [];
|
|
37
45
|
this.dataLoad = new EventEmitter();
|
|
@@ -40,69 +48,73 @@ export class TableInternalComponent {
|
|
|
40
48
|
this.createClick = new EventEmitter();
|
|
41
49
|
this.actionClick = new EventEmitter();
|
|
42
50
|
this.inputChange = new EventEmitter();
|
|
43
|
-
this.smallScreen = false;
|
|
44
|
-
// columns: Column[] = [];
|
|
45
|
-
this.displayedColumns = [];
|
|
46
|
-
// @Input() optionValue = "";
|
|
47
|
-
// @Input() optionDisplay = "";
|
|
48
|
-
this.displayedButtons = [];
|
|
49
51
|
// detect screen size changes
|
|
50
52
|
this.breakpointObserver.observe(["(max-width: 600px)"]).subscribe((result) => {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
this.setColumns();
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
this.smallScreen = false;
|
|
57
|
-
this.setColumns();
|
|
58
|
-
}
|
|
53
|
+
this.smallScreen = result.matches;
|
|
54
|
+
this.updateTableConfiguration();
|
|
59
55
|
});
|
|
60
56
|
}
|
|
61
57
|
ngOnInit() {
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
58
|
+
this.initializeComponent();
|
|
59
|
+
}
|
|
60
|
+
ngOnChanges() {
|
|
61
|
+
if (!this.config.loadAction) {
|
|
62
|
+
this.dataSource = this.data;
|
|
63
|
+
this.tableDataSource = new MatTableDataSource(this.dataSource);
|
|
64
|
+
}
|
|
65
|
+
setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 1000);
|
|
66
|
+
}
|
|
67
|
+
initializeComponent() {
|
|
68
|
+
this.updateTableConfiguration();
|
|
69
|
+
this.setupDataLoading();
|
|
70
|
+
this.formDefaults();
|
|
71
|
+
}
|
|
72
|
+
updateTableConfiguration() {
|
|
73
|
+
this.elevation = this.getElevationClass(this.config?.elevation);
|
|
74
|
+
this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);
|
|
75
|
+
this.displayedButtons = this.buttonService.getDisplayedButtons(this.config?.buttons, this.smallScreen, this.config?.minButtons);
|
|
76
|
+
this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);
|
|
77
|
+
this.createButton = this.buttonService.getCreateButton(this.config?.buttons);
|
|
78
|
+
this.showFilterButton = !this.config?.searchConfig;
|
|
79
|
+
if (this.displayedButtons?.length > 0 && !this.displayedColumns.includes('action')) {
|
|
80
|
+
this.displayedColumns.push('action');
|
|
75
81
|
}
|
|
76
|
-
|
|
77
|
-
|
|
82
|
+
}
|
|
83
|
+
setupDataLoading() {
|
|
78
84
|
if (this.config.loadAction) {
|
|
79
85
|
this.loadData(this.config.loadAction, "");
|
|
80
86
|
}
|
|
81
|
-
this.
|
|
82
|
-
if (this.config.searchConfig) {
|
|
83
|
-
this.showFilterButton = false;
|
|
84
|
-
}
|
|
85
|
-
if (this.reload != null) {
|
|
87
|
+
if (this.reload) {
|
|
86
88
|
this.reload.subscribe(v => {
|
|
87
|
-
if (v
|
|
88
|
-
|
|
89
|
-
this.loadData(this.config?.loadAction, "");
|
|
90
|
-
}
|
|
89
|
+
if (v && this.config?.loadAction) {
|
|
90
|
+
this.loadData(this.config.loadAction, "");
|
|
91
91
|
}
|
|
92
92
|
});
|
|
93
93
|
}
|
|
94
94
|
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
this.
|
|
99
|
-
|
|
95
|
+
loadData(action, data) {
|
|
96
|
+
console.log("loading");
|
|
97
|
+
if (action) {
|
|
98
|
+
this.dataService.CallApi(action, data).subscribe((apiResponse) => {
|
|
99
|
+
if (this.config.logResponse) {
|
|
100
|
+
console.log(apiResponse);
|
|
101
|
+
}
|
|
102
|
+
this.dataSource = apiResponse.data;
|
|
103
|
+
this.tableDataSource = new MatTableDataSource(apiResponse.data);
|
|
104
|
+
this.tableDataSource.paginator = this.tablePaginator;
|
|
105
|
+
if (apiResponse.success) {
|
|
106
|
+
this.tableDataSource = new MatTableDataSource(apiResponse.data);
|
|
107
|
+
this.tableDataSource.paginator = this.tablePaginator;
|
|
108
|
+
this.dataLoaded(apiResponse.data);
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
this.messageService.toast("Error: " + apiResponse.message);
|
|
112
|
+
}
|
|
113
|
+
});
|
|
100
114
|
}
|
|
101
|
-
setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 1000);
|
|
102
115
|
}
|
|
103
116
|
inputChanged(event) {
|
|
104
117
|
this.inputChange.emit({ field: event.field, value: event.value });
|
|
105
|
-
// console.log("Changed " + JSON.stringify(event))
|
|
106
118
|
}
|
|
107
119
|
formDefaults() {
|
|
108
120
|
if (!this.config.formConfig) {
|
|
@@ -116,46 +128,11 @@ export class TableInternalComponent {
|
|
|
116
128
|
}
|
|
117
129
|
}
|
|
118
130
|
setColumns() {
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
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`;
|
|
131
|
+
this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);
|
|
132
|
+
this.displayedButtons = this.buttonService.getDisplayedButtons(this.config.buttons, this.smallScreen, this.config.minButtons);
|
|
133
|
+
this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);
|
|
134
|
+
if (this.displayedButtons.length > 0 && !this.displayedColumns.includes('action')) {
|
|
135
|
+
this.displayedColumns.push('action');
|
|
159
136
|
}
|
|
160
137
|
}
|
|
161
138
|
setButtons() {
|
|
@@ -169,132 +146,45 @@ export class TableInternalComponent {
|
|
|
169
146
|
}
|
|
170
147
|
}
|
|
171
148
|
getButton(name) {
|
|
172
|
-
|
|
173
|
-
console.log("No buttons found");
|
|
174
|
-
return null;
|
|
175
|
-
}
|
|
176
|
-
return this.config.buttons.find(x => x.name == name);
|
|
149
|
+
return this.buttonService.getButton(this.config.buttons, name);
|
|
177
150
|
}
|
|
178
151
|
getIcon(buttonName) {
|
|
179
|
-
|
|
180
|
-
|
|
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;
|
|
152
|
+
const button = this.getButton(buttonName);
|
|
153
|
+
return this.buttonService.getIcon(button, this.config);
|
|
198
154
|
}
|
|
199
155
|
getButtonColor(button, row) {
|
|
200
|
-
|
|
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';
|
|
156
|
+
return this.buttonService.getButtonColor(button, row);
|
|
215
157
|
}
|
|
216
158
|
getOptions(column) {
|
|
217
159
|
let x = this.config.columns.find(opt => opt.name === column);
|
|
218
160
|
return x;
|
|
219
161
|
}
|
|
220
|
-
getColor(
|
|
221
|
-
|
|
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
|
-
}
|
|
162
|
+
getColor(value, options) {
|
|
163
|
+
return this.conditionService.getColor(value, options);
|
|
231
164
|
}
|
|
232
|
-
testIconCondition(
|
|
233
|
-
|
|
234
|
-
return icon.condition(value);
|
|
235
|
-
}
|
|
236
|
-
else {
|
|
237
|
-
return true;
|
|
238
|
-
}
|
|
165
|
+
testIconCondition(row, icon) {
|
|
166
|
+
return this.conditionService.testIconCondition(icon, row);
|
|
239
167
|
}
|
|
240
|
-
testColorCondition(
|
|
241
|
-
|
|
242
|
-
return false;
|
|
243
|
-
if (color.condition) {
|
|
244
|
-
return color.condition(value);
|
|
245
|
-
}
|
|
246
|
-
else {
|
|
247
|
-
return true;
|
|
248
|
-
}
|
|
168
|
+
testColorCondition(row, color) {
|
|
169
|
+
return this.conditionService.testColorCondition(color, row);
|
|
249
170
|
}
|
|
250
171
|
showBanner(message) {
|
|
251
|
-
if (
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
return;
|
|
255
|
-
this.messageService.info(message);
|
|
172
|
+
if (message && message !== '') {
|
|
173
|
+
this.messageService.info(message);
|
|
174
|
+
}
|
|
256
175
|
}
|
|
257
176
|
testDisabled(row, buttonName) {
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
return button.disabled(row);
|
|
261
|
-
}
|
|
262
|
-
return false;
|
|
177
|
+
const button = this.getButton(buttonName);
|
|
178
|
+
return this.buttonService.testDisabled(button, row);
|
|
263
179
|
}
|
|
264
180
|
testVisible(row, buttonName) {
|
|
265
|
-
|
|
266
|
-
|
|
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
|
-
}
|
|
181
|
+
const button = this.getButton(buttonName);
|
|
182
|
+
return this.buttonService.testVisible(button, row);
|
|
292
183
|
}
|
|
293
184
|
//Events
|
|
294
185
|
searchClicked(x) {
|
|
295
186
|
console.log("Search");
|
|
296
187
|
this.searchClick.emit(x);
|
|
297
|
-
// console.log(x)
|
|
298
188
|
if (this.config.searchConfig.searchAction) {
|
|
299
189
|
this.config.searchConfig.searchAction.method == 'post';
|
|
300
190
|
this.loadData(this.config.searchConfig.searchAction, x);
|
|
@@ -311,73 +201,37 @@ export class TableInternalComponent {
|
|
|
311
201
|
}
|
|
312
202
|
}
|
|
313
203
|
dataLoaded(x) {
|
|
314
|
-
this.dataLoad.emit(x);
|
|
315
204
|
console.log("dataloaded");
|
|
205
|
+
this.dataLoad.emit(x);
|
|
316
206
|
if (this.config.tileConfig?.loadAction) {
|
|
317
207
|
this.tileReload.next(true);
|
|
318
208
|
}
|
|
319
209
|
}
|
|
320
210
|
actionClicked(name, row) {
|
|
321
|
-
if (name
|
|
211
|
+
if (name === 'view') {
|
|
322
212
|
this.viewModel(row);
|
|
323
213
|
}
|
|
324
|
-
else if (name
|
|
214
|
+
else if (name === 'edit') {
|
|
325
215
|
this.editModel(row);
|
|
326
216
|
}
|
|
327
|
-
else if (name
|
|
217
|
+
else if (name === 'delete') {
|
|
328
218
|
this.deleteModel(row);
|
|
329
219
|
}
|
|
330
220
|
else {
|
|
331
221
|
this.customModel(name, row);
|
|
332
222
|
}
|
|
333
223
|
}
|
|
224
|
+
//Dialog events
|
|
334
225
|
columnClicked(column, row) {
|
|
335
226
|
if (column.detailsConfig) {
|
|
336
|
-
|
|
337
|
-
const dialogRef = this.dialog.open(DetailsDialogInternal, {
|
|
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
|
-
});
|
|
227
|
+
this.openDetailsDialog(column.name, row, column);
|
|
347
228
|
}
|
|
348
229
|
else {
|
|
349
230
|
this.actionClickedEmit(column.name, row);
|
|
350
231
|
}
|
|
351
232
|
}
|
|
352
233
|
customModel(name, row) {
|
|
353
|
-
|
|
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(DetailsDialogInternal, {
|
|
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
|
-
}
|
|
234
|
+
this.openDetailsDialog(name, row);
|
|
381
235
|
}
|
|
382
236
|
actionClickedEmit(name, row) {
|
|
383
237
|
console.log("Action clicked");
|
|
@@ -385,110 +239,55 @@ export class TableInternalComponent {
|
|
|
385
239
|
}
|
|
386
240
|
viewModel(row) {
|
|
387
241
|
console.log("view Clicked");
|
|
388
|
-
|
|
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(DetailsDialogInternal, {
|
|
409
|
-
width: "900px",
|
|
410
|
-
data: conf
|
|
411
|
-
});
|
|
412
|
-
dialogRef.afterClosed().subscribe((result) => {
|
|
413
|
-
if (result.message) {
|
|
414
|
-
this.refreshClicked();
|
|
415
|
-
}
|
|
416
|
-
});
|
|
242
|
+
this.openDetailsDialog('view', row);
|
|
417
243
|
}
|
|
418
244
|
newModel() {
|
|
419
|
-
|
|
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(DetailsDialogInternal, {
|
|
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
|
-
});
|
|
245
|
+
this.openDetailsDialog('create', null);
|
|
454
246
|
}
|
|
455
247
|
editModel(row) {
|
|
456
|
-
|
|
248
|
+
this.openDetailsDialog('edit', row);
|
|
249
|
+
}
|
|
250
|
+
openDetailsDialog(buttonName, row, column) {
|
|
251
|
+
const button = column ? { name: column.name, dialog: true, detailsConfig: column.detailsConfig } : this.getButton(buttonName);
|
|
457
252
|
if (!button)
|
|
458
253
|
return;
|
|
459
254
|
if (!button.dialog) {
|
|
255
|
+
this.doAction(button.name, row);
|
|
460
256
|
this.actionClickedEmit(button.name, row);
|
|
461
257
|
return;
|
|
462
258
|
}
|
|
463
|
-
if (!this.config.formConfig) {
|
|
259
|
+
if (!this.config.formConfig && !button.detailsConfig) {
|
|
464
260
|
this.messageService.toast("Please configure form");
|
|
465
261
|
return;
|
|
466
262
|
}
|
|
467
|
-
this.config.formConfig.mode = "edit";
|
|
468
263
|
let conf = {
|
|
469
264
|
formConfig: this.config.formConfig,
|
|
470
265
|
buttons: this.config.buttons,
|
|
471
266
|
details: row,
|
|
472
267
|
};
|
|
473
268
|
if (button.detailsConfig) {
|
|
474
|
-
conf =
|
|
269
|
+
conf = buttonName === 'create'
|
|
270
|
+
? button.detailsConfig
|
|
271
|
+
: DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);
|
|
272
|
+
}
|
|
273
|
+
conf.formConfig.mode = buttonName === 'create' ? 'create' : (buttonName === 'edit' ? 'edit' : 'view');
|
|
274
|
+
if (buttonName === 'create') {
|
|
275
|
+
conf.heroField = this.config?.heroField;
|
|
276
|
+
conf.heroValue = this.config?.heroValue;
|
|
277
|
+
}
|
|
278
|
+
const dialogResult = this.dialogService.openDetailsDialog(conf, DetailsDialogInternal); // Unique to internal
|
|
279
|
+
if (buttonName === 'edit') {
|
|
280
|
+
dialogResult.inputChange.subscribe((x) => {
|
|
281
|
+
this.inputChanged(x);
|
|
282
|
+
});
|
|
475
283
|
}
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
data: conf
|
|
480
|
-
});
|
|
481
|
-
dialogRef.componentInstance.inputChange.subscribe((x) => {
|
|
482
|
-
this.inputChanged(x);
|
|
483
|
-
});
|
|
484
|
-
dialogRef.afterClosed().subscribe((result) => {
|
|
485
|
-
console.log(result);
|
|
486
|
-
if (result.message == "success") {
|
|
487
|
-
this.actionClickedEmit('edit', result.data);
|
|
284
|
+
dialogResult.afterClosed.subscribe((result) => {
|
|
285
|
+
if (result.message === 'success') {
|
|
286
|
+
this.actionClickedEmit(button.name, result.data);
|
|
488
287
|
this.refreshClicked();
|
|
489
288
|
}
|
|
490
|
-
else if (result.message
|
|
491
|
-
this.actionClickedEmit(
|
|
289
|
+
else if (result.message === 'emit') {
|
|
290
|
+
this.actionClickedEmit(button.name, result.data);
|
|
492
291
|
}
|
|
493
292
|
});
|
|
494
293
|
}
|
|
@@ -503,6 +302,7 @@ export class TableInternalComponent {
|
|
|
503
302
|
}
|
|
504
303
|
});
|
|
505
304
|
}
|
|
305
|
+
//Actions
|
|
506
306
|
doAction(buttonName, row) {
|
|
507
307
|
let b = this.getButton(buttonName);
|
|
508
308
|
if (!b)
|
|
@@ -538,13 +338,32 @@ export class TableInternalComponent {
|
|
|
538
338
|
this.messageService.toast("Error: " + error);
|
|
539
339
|
});
|
|
540
340
|
}
|
|
341
|
+
//Misc
|
|
342
|
+
getElevationClass(elevation) {
|
|
343
|
+
console.log(elevation);
|
|
344
|
+
if (elevation == "none") {
|
|
345
|
+
return "";
|
|
346
|
+
}
|
|
347
|
+
else if (elevation == "low") {
|
|
348
|
+
return "mat-elevation-z1";
|
|
349
|
+
}
|
|
350
|
+
else if (elevation == "medium") {
|
|
351
|
+
return "mat-elevation-z5";
|
|
352
|
+
}
|
|
353
|
+
else if (elevation == "high") {
|
|
354
|
+
return "mat-elevation-z9";
|
|
355
|
+
}
|
|
356
|
+
else {
|
|
357
|
+
return "mat-elevation-z5";
|
|
358
|
+
}
|
|
359
|
+
}
|
|
541
360
|
}
|
|
542
|
-
TableInternalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableInternalComponent, deps: [{ token: i1.DataServiceLib }, { token: i2.MessageService }, { token: i3.BreakpointObserver }, { token: i4.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
543
|
-
TableInternalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableInternalComponent, selector: "spa-table-internal", 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 <!-- Unique to internal -->\n <div class=\"tin-row\">\n <button *ngIf=\"createButton && !config.flatButtons && testVisible(config.parentData,createButton.name)\"\n [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}\n </button>\n <button *ngIf=\"createButton && config.flatButtons && testVisible(config.parentData,createButton.name)\"\n [ngStyle]=\"{'color': getButtonColor(createButton, config.parentData)}\"\n [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-stroked-button style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}\n </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\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)\">\n <label style=\"margin-right: 35px;\"></label>\n </ng-container>\n\n </ng-container>\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", 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}\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" }] });
|
|
361
|
+
TableInternalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableInternalComponent, 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 });
|
|
362
|
+
TableInternalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableInternalComponent, selector: "spa-table-internal", 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 *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\r\n\r\n\r\n<!-- Header -->\r\n<div class=\"top\">\r\n\r\n <!-- Unique to internal -->\r\n <div class=\"tin-row\">\r\n <button *ngIf=\"createButton && !config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}\r\n </button>\r\n <button *ngIf=\"createButton && config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n [ngStyle]=\"{'color': getButtonColor(createButton, config.parentData)}\"\r\n [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-stroked-button style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}\r\n </button>\r\n </div>\r\n\r\n <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\r\n <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n </div>\r\n\r\n <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\r\n <spa-filter [showText]=\"!smallScreen || (smallScreen && dataSource?.length > 10)\" [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" [flatButtons]=\"config.flatButtons\" (refreshClick)=\"refreshClicked()\"></spa-filter>\r\n </div>\r\n\r\n</div>\r\n\r\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\r\n <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n</div>\r\n\r\n<div *ngIf=\"config.title && !hideTitle\" class=\"title\">\r\n <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\r\n</div>\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\" (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 [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", 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}.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.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: i13.FilterComponent, selector: "spa-filter", inputs: ["flatButtons", "showText", "showButton", "data"], outputs: ["refreshClick"] }, { kind: "component", type: i14.TilesComponent, selector: "spa-tiles", inputs: ["config", "data", "reload"], outputs: ["tileClick"] }, { kind: "component", type: i15.SearchComponent, selector: "spa-search", inputs: ["config"], outputs: ["searchClick"] }, { kind: "component", type: i16.TableRowComponent, selector: "app-table-row", inputs: ["column", "row", "config"], outputs: ["actionClick", "columnClick", "showBannerEvent"] }, { kind: "component", type: i17.TableActionComponent, selector: "app-table-action", inputs: ["displayedButtons", "config", "row"], outputs: ["actionClick"] }, { kind: "pipe", type: i18.CamelToWordsPipe, name: "camelToWords" }] });
|
|
544
363
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableInternalComponent, decorators: [{
|
|
545
364
|
type: Component,
|
|
546
|
-
args: [{ selector: 'spa-table-internal', 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 <!-- Unique to internal -->\n <div class=\"tin-row\">\n <button *ngIf=\"createButton && !config.flatButtons && testVisible(config.parentData,createButton.name)\"\n [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}\n </button>\n <button *ngIf=\"createButton && config.flatButtons && testVisible(config.parentData,createButton.name)\"\n [ngStyle]=\"{'color': getButtonColor(createButton, config.parentData)}\"\n [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-stroked-button style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}\n </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\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)\">\n <label style=\"margin-right: 35px;\"></label>\n </ng-container>\n\n </ng-container>\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", 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}\n"] }]
|
|
547
|
-
}], ctorParameters: function () { return [{ type: i1.DataServiceLib }, { type: i2.MessageService }, { type: i3.BreakpointObserver }, { type: i4.MatDialog }]; }, propDecorators: { tablePaginator: [{
|
|
365
|
+
args: [{ selector: 'spa-table-internal', template: "\r\n<!-- Search -->\r\n<spa-search *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\r\n\r\n\r\n<!-- Header -->\r\n<div class=\"top\">\r\n\r\n <!-- Unique to internal -->\r\n <div class=\"tin-row\">\r\n <button *ngIf=\"createButton && !config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}\r\n </button>\r\n <button *ngIf=\"createButton && config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n [ngStyle]=\"{'color': getButtonColor(createButton, config.parentData)}\"\r\n [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-stroked-button style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}\r\n </button>\r\n </div>\r\n\r\n <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\r\n <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n </div>\r\n\r\n <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\r\n <spa-filter [showText]=\"!smallScreen || (smallScreen && dataSource?.length > 10)\" [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" [flatButtons]=\"config.flatButtons\" (refreshClick)=\"refreshClicked()\"></spa-filter>\r\n </div>\r\n\r\n</div>\r\n\r\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\r\n <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n</div>\r\n\r\n<div *ngIf=\"config.title && !hideTitle\" class=\"title\">\r\n <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\r\n</div>\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\" (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 [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", 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}.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"] }]
|
|
366
|
+
}], 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: [{
|
|
548
367
|
type: ViewChild,
|
|
549
368
|
args: ['tablePaginator']
|
|
550
369
|
}], hideTitle: [{
|
|
@@ -568,4 +387,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
568
387
|
}], inputChange: [{
|
|
569
388
|
type: Output
|
|
570
389
|
}] } });
|
|
571
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.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 { DetailsDialogInternal } from './detailsDialog-internal.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-internal',\r\n  templateUrl: './table-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class TableInternalComponent 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  }\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\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  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      const dialogRef = this.dialog.open(DetailsDialogInternal, {\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(DetailsDialogInternal, {\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\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(DetailsDialogInternal, {\r\n      width: \"900px\",\r\n      data: conf\r\n    });\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\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\r\n    conf.formConfig.mode = \"create\";\r\n    conf.heroField = this.config?.heroField;\r\n    conf.heroValue = this.config?.heroValue;\r\n\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialogInternal, {\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    this.config.formConfig.mode = \"edit\";\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(DetailsDialogInternal, {\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  <!-- Unique to internal -->\n  <div class=\"tin-row\">\n    <button *ngIf=\"createButton && !config.flatButtons && testVisible(config.parentData,createButton.name)\"\n      [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}\n    </button>\n    <button *ngIf=\"createButton && config.flatButtons && testVisible(config.parentData,createButton.name)\"\n      [ngStyle]=\"{'color': getButtonColor(createButton, config.parentData)}\"\n      [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-stroked-button  style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}\n    </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\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)\">\n              <label style=\"margin-right: 35px;\"></label>\n            </ng-container>\n\n          </ng-container>\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"]}
|
|
390
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.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 { DetailsDialogInternal } from './detailsDialog-internal.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-internal',\r\n  templateUrl: './table-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class TableInternalComponent 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    // 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\r\n\r\n    const dialogResult = this.dialogService.openDetailsDialog(conf, DetailsDialogInternal); // Unique to internal\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\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","\r\n<!-- Search -->\r\n<spa-search *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\r\n\r\n\r\n<!-- Header -->\r\n<div class=\"top\">\r\n\r\n  <!-- Unique to internal -->\r\n  <div class=\"tin-row\">\r\n    <button *ngIf=\"createButton && !config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n      [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}\r\n    </button>\r\n    <button *ngIf=\"createButton && config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n      [ngStyle]=\"{'color': getButtonColor(createButton, config.parentData)}\"\r\n      [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-stroked-button  style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}\r\n    </button>\r\n  </div>\r\n\r\n  <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\r\n    <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n  </div>\r\n\r\n  <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\r\n    <spa-filter [showText]=\"!smallScreen || (smallScreen && dataSource?.length > 10)\" [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" [flatButtons]=\"config.flatButtons\" (refreshClick)=\"refreshClicked()\"></spa-filter>\r\n  </div>\r\n\r\n</div>\r\n\r\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\r\n  <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n</div>\r\n\r\n<div *ngIf=\"config.title && !hideTitle\" class=\"title\">\r\n  <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\r\n</div>\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\" (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 [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"]}
|