tin-spa 2.0.0 → 2.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/{esm2015/lib/classes/Classes.js → esm2020/lib/classes/Classes.mjs} +15 -55
- package/esm2020/lib/classes/TinCore.mjs +148 -0
- package/esm2020/lib/components/activity/activity.component.mjs +24 -0
- package/esm2020/lib/components/attach/attach.component.mjs +105 -0
- package/esm2020/lib/components/change-password/change-password.component.mjs +92 -0
- package/esm2020/lib/components/check/check.component.mjs +56 -0
- package/esm2020/lib/components/chips/chips.component.mjs +58 -0
- package/esm2020/lib/components/create-account/create-account.component.mjs +72 -0
- package/esm2020/lib/components/date/date.component.mjs +64 -0
- package/esm2020/lib/components/datetime/datetime.component.mjs +39 -0
- package/esm2020/lib/components/filter/filter.component.mjs +46 -0
- package/esm2020/lib/components/form/form.component.mjs +63 -0
- package/esm2020/lib/components/label/label.component.mjs +25 -0
- package/esm2020/lib/components/loader/loader.component.mjs +24 -0
- package/esm2020/lib/components/login/login.component.mjs +113 -0
- package/esm2020/lib/components/logs/logs.component.mjs +37 -0
- package/esm2020/lib/components/message/messageDialog.component.mjs +32 -0
- package/esm2020/lib/components/money/currency-input-mask.directive.mjs +185 -0
- package/esm2020/lib/components/money/currency-input-mask.module.mjs +28 -0
- package/esm2020/lib/components/money/money.component.mjs +64 -0
- package/esm2020/lib/components/nav-menu/nav-menu.component.mjs +49 -0
- package/esm2020/lib/components/number/number.component.mjs +86 -0
- package/esm2020/lib/components/option/option.component.mjs +59 -0
- package/esm2020/lib/components/profile/profile.component.mjs +93 -0
- package/esm2020/lib/components/recover-account/recover-account.component.mjs +46 -0
- package/esm2020/lib/components/roles/addRoleDialog.component.mjs +61 -0
- package/esm2020/lib/components/roles/roles.component.mjs +91 -0
- package/esm2020/lib/components/select/select.component.mjs +71 -0
- package/esm2020/lib/components/settings/settings.component.mjs +63 -0
- package/esm2020/lib/components/signup/signup.component.mjs +50 -0
- package/esm2020/lib/components/steps/steps.component.mjs +90 -0
- package/esm2020/lib/components/table/detailsDialog.component.mjs +149 -0
- package/esm2020/lib/components/table/table.component.mjs +341 -0
- package/esm2020/lib/components/text/text.component.mjs +166 -0
- package/esm2020/lib/components/tiles/tiles.component.mjs +41 -0
- package/esm2020/lib/components/tin-spa.component.mjs +19 -0
- package/esm2020/lib/components/users/users.component.mjs +119 -0
- package/esm2020/lib/modules/admin/admin-routing.module.mjs +29 -0
- package/esm2020/lib/modules/admin/admin.module.mjs +26 -0
- package/esm2020/lib/modules/index/index-routing.module.mjs +27 -0
- package/esm2020/lib/modules/index/index.module.mjs +26 -0
- package/esm2020/lib/modules/spa-admin.module.mjs +73 -0
- package/esm2020/lib/modules/spa-index.module.mjs +52 -0
- package/esm2020/lib/modules/spa-mat.module.mjs +67 -0
- package/esm2020/lib/modules/spa-user.module.mjs +49 -0
- package/esm2020/lib/modules/user/user-routing.module.mjs +23 -0
- package/esm2020/lib/modules/user/user.module.mjs +26 -0
- package/esm2020/lib/pipes/camelToWords.pipe.mjs +23 -0
- package/esm2020/lib/services/auth.service.mjs +142 -0
- package/esm2020/lib/services/data.service.mjs +125 -0
- package/esm2020/lib/services/export.service.mjs +16 -0
- package/esm2020/lib/services/http.service.mjs +79 -0
- package/esm2020/lib/services/loader-interceptor.service.mjs +77 -0
- package/esm2020/lib/services/loader.service.mjs +17 -0
- package/esm2020/lib/services/log.service.mjs +77 -0
- package/esm2020/lib/services/message.service.mjs +52 -0
- package/esm2020/lib/services/storage.service.mjs +34 -0
- package/esm2020/lib/services/tin-spa.service.mjs +14 -0
- package/esm2020/lib/tin-spa.module.mjs +114 -0
- package/esm2020/public-api.mjs +62 -0
- package/esm2020/tin-spa.mjs +5 -0
- package/fesm2015/tin-spa.mjs +3846 -0
- package/fesm2015/tin-spa.mjs.map +1 -0
- package/fesm2020/tin-spa.mjs +3829 -0
- package/fesm2020/tin-spa.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/classes/Classes.d.ts +58 -63
- package/lib/classes/TinCore.d.ts +1 -0
- package/lib/components/activity/activity.component.d.ts +3 -0
- package/lib/components/attach/attach.component.d.ts +4 -1
- package/lib/components/change-password/change-password.component.d.ts +3 -0
- package/lib/components/check/check.component.d.ts +3 -0
- package/lib/components/chips/chips.component.d.ts +3 -0
- package/lib/components/create-account/create-account.component.d.ts +3 -0
- package/lib/components/date/date.component.d.ts +14 -6
- package/lib/components/datetime/datetime.component.d.ts +3 -0
- package/lib/components/filter/filter.component.d.ts +4 -0
- package/lib/components/form/form.component.d.ts +16 -0
- package/lib/components/label/label.component.d.ts +3 -0
- package/lib/components/loader/loader.component.d.ts +3 -0
- package/lib/components/login/login.component.d.ts +6 -0
- package/lib/components/logs/logs.component.d.ts +3 -0
- package/lib/components/message/messageDialog.component.d.ts +3 -0
- package/lib/components/money/currency-input-mask.directive.d.ts +41 -0
- package/lib/components/money/currency-input-mask.module.d.ts +9 -0
- package/lib/components/money/money.component.d.ts +9 -1
- package/lib/components/nav-menu/nav-menu.component.d.ts +3 -0
- package/lib/components/number/number.component.d.ts +29 -0
- package/lib/components/option/option.component.d.ts +3 -0
- package/lib/components/profile/profile.component.d.ts +6 -2
- package/lib/components/recover-account/recover-account.component.d.ts +3 -0
- package/lib/components/roles/addRoleDialog.component.d.ts +3 -0
- package/lib/components/roles/roles.component.d.ts +3 -0
- package/lib/components/select/select.component.d.ts +5 -1
- package/lib/components/settings/settings.component.d.ts +3 -0
- package/lib/components/signup/signup.component.d.ts +3 -0
- package/lib/components/steps/steps.component.d.ts +3 -0
- package/lib/components/table/detailsDialog.component.d.ts +28 -0
- package/lib/components/table/table.component.d.ts +57 -17
- package/lib/components/text/text.component.d.ts +13 -9
- package/lib/components/tiles/tiles.component.d.ts +3 -0
- package/lib/components/tin-spa.component.d.ts +4 -4
- package/lib/components/users/users.component.d.ts +4 -0
- package/lib/modules/admin/admin-routing.module.d.ts +7 -0
- package/lib/modules/admin/admin.module.d.ts +9 -0
- package/lib/modules/index/index-routing.module.d.ts +7 -0
- package/lib/modules/index/index.module.d.ts +9 -0
- package/lib/modules/spa-admin.module.d.ts +13 -0
- package/lib/modules/spa-index.module.d.ts +10 -0
- package/lib/modules/spa-mat.module.d.ts +31 -0
- package/lib/modules/spa-user.module.d.ts +9 -0
- package/lib/modules/user/user-routing.module.d.ts +7 -0
- package/lib/modules/user/user.module.d.ts +9 -0
- package/lib/pipes/camelToWords.pipe.d.ts +7 -0
- package/lib/services/auth.service.d.ts +3 -0
- package/lib/services/data.service.d.ts +5 -1
- package/lib/services/export.service.d.ts +3 -4
- package/lib/services/http.service.d.ts +3 -0
- package/lib/services/loader-interceptor.service.d.ts +3 -0
- package/lib/services/loader.service.d.ts +3 -0
- package/lib/services/log.service.d.ts +3 -0
- package/lib/services/message.service.d.ts +3 -0
- package/lib/services/storage.service.d.ts +3 -0
- package/lib/services/tin-spa.service.d.ts +3 -0
- package/lib/tin-spa.module.d.ts +30 -0
- package/package.json +24 -23
- package/public-api.d.ts +7 -2
- package/bundles/tin-spa.umd.js +0 -3672
- package/bundles/tin-spa.umd.js.map +0 -1
- package/bundles/tin-spa.umd.min.js +0 -16
- package/bundles/tin-spa.umd.min.js.map +0 -1
- package/esm2015/lib/classes/TinCore.js +0 -139
- package/esm2015/lib/components/activity/activity.component.js +0 -26
- package/esm2015/lib/components/attach/attach.component.js +0 -107
- package/esm2015/lib/components/change-password/change-password.component.js +0 -102
- package/esm2015/lib/components/check/check.component.js +0 -63
- package/esm2015/lib/components/chips/chips.component.js +0 -66
- package/esm2015/lib/components/create-account/create-account.component.js +0 -78
- package/esm2015/lib/components/date/date.component.js +0 -45
- package/esm2015/lib/components/datetime/datetime.component.js +0 -44
- package/esm2015/lib/components/filter/filter.component.js +0 -40
- package/esm2015/lib/components/label/label.component.js +0 -29
- package/esm2015/lib/components/loader/loader.component.js +0 -29
- package/esm2015/lib/components/login/login.component.js +0 -114
- package/esm2015/lib/components/logs/logs.component.js +0 -39
- package/esm2015/lib/components/message/messageDialog.component.js +0 -31
- package/esm2015/lib/components/money/money.component.js +0 -52
- package/esm2015/lib/components/nav-menu/nav-menu.component.js +0 -51
- package/esm2015/lib/components/option/option.component.js +0 -63
- package/esm2015/lib/components/profile/profile.component.js +0 -98
- package/esm2015/lib/components/recover-account/recover-account.component.js +0 -53
- package/esm2015/lib/components/roles/addRoleDialog.component.js +0 -61
- package/esm2015/lib/components/roles/roles.component.js +0 -94
- package/esm2015/lib/components/select/select.component.js +0 -77
- package/esm2015/lib/components/settings/settings.component.js +0 -63
- package/esm2015/lib/components/signup/signup.component.js +0 -57
- package/esm2015/lib/components/steps/steps.component.js +0 -93
- package/esm2015/lib/components/table/table.component.js +0 -107
- package/esm2015/lib/components/text/text.component.js +0 -165
- package/esm2015/lib/components/tiles/tiles.component.js +0 -41
- package/esm2015/lib/components/timeout/timeout.component.js +0 -90
- package/esm2015/lib/components/tin-spa.component.js +0 -19
- package/esm2015/lib/components/users/users.component.js +0 -120
- package/esm2015/lib/dnd.directive.js +0 -51
- package/esm2015/lib/modules/spa-admin.module.js +0 -50
- package/esm2015/lib/modules/spa-index.module.js +0 -35
- package/esm2015/lib/modules/spa-mat.module.js +0 -53
- package/esm2015/lib/modules/spa-user.module.js +0 -33
- package/esm2015/lib/services/auth.service.js +0 -155
- package/esm2015/lib/services/data.service.js +0 -115
- package/esm2015/lib/services/export.service.js +0 -29
- package/esm2015/lib/services/http.service.js +0 -84
- package/esm2015/lib/services/loader-interceptor.service.js +0 -83
- package/esm2015/lib/services/loader.service.js +0 -17
- package/esm2015/lib/services/log.service.js +0 -76
- package/esm2015/lib/services/message.service.js +0 -58
- package/esm2015/lib/services/storage.service.js +0 -42
- package/esm2015/lib/services/tin-spa.service.js +0 -14
- package/esm2015/lib/tin-spa.module.js +0 -91
- package/esm2015/public-api.js +0 -56
- package/esm2015/tin-spa.js +0 -8
- package/esm5/lib/classes/Classes.js +0 -313
- package/esm5/lib/classes/TinCore.js +0 -166
- package/esm5/lib/components/activity/activity.component.js +0 -27
- package/esm5/lib/components/attach/attach.component.js +0 -119
- package/esm5/lib/components/change-password/change-password.component.js +0 -104
- package/esm5/lib/components/check/check.component.js +0 -64
- package/esm5/lib/components/chips/chips.component.js +0 -68
- package/esm5/lib/components/create-account/create-account.component.js +0 -80
- package/esm5/lib/components/date/date.component.js +0 -46
- package/esm5/lib/components/datetime/datetime.component.js +0 -45
- package/esm5/lib/components/filter/filter.component.js +0 -41
- package/esm5/lib/components/label/label.component.js +0 -30
- package/esm5/lib/components/loader/loader.component.js +0 -31
- package/esm5/lib/components/login/login.component.js +0 -117
- package/esm5/lib/components/logs/logs.component.js +0 -41
- package/esm5/lib/components/message/messageDialog.component.js +0 -32
- package/esm5/lib/components/money/money.component.js +0 -53
- package/esm5/lib/components/nav-menu/nav-menu.component.js +0 -53
- package/esm5/lib/components/option/option.component.js +0 -64
- package/esm5/lib/components/profile/profile.component.js +0 -102
- package/esm5/lib/components/recover-account/recover-account.component.js +0 -55
- package/esm5/lib/components/roles/addRoleDialog.component.js +0 -63
- package/esm5/lib/components/roles/roles.component.js +0 -100
- package/esm5/lib/components/select/select.component.js +0 -79
- package/esm5/lib/components/settings/settings.component.js +0 -66
- package/esm5/lib/components/signup/signup.component.js +0 -59
- package/esm5/lib/components/steps/steps.component.js +0 -105
- package/esm5/lib/components/table/table.component.js +0 -109
- package/esm5/lib/components/text/text.component.js +0 -168
- package/esm5/lib/components/tiles/tiles.component.js +0 -42
- package/esm5/lib/components/timeout/timeout.component.js +0 -92
- package/esm5/lib/components/tin-spa.component.js +0 -17
- package/esm5/lib/components/users/users.component.js +0 -126
- package/esm5/lib/dnd.directive.js +0 -52
- package/esm5/lib/modules/spa-admin.module.js +0 -53
- package/esm5/lib/modules/spa-index.module.js +0 -38
- package/esm5/lib/modules/spa-mat.module.js +0 -56
- package/esm5/lib/modules/spa-user.module.js +0 -36
- package/esm5/lib/services/auth.service.js +0 -157
- package/esm5/lib/services/data.service.js +0 -116
- package/esm5/lib/services/export.service.js +0 -30
- package/esm5/lib/services/http.service.js +0 -85
- package/esm5/lib/services/loader-interceptor.service.js +0 -85
- package/esm5/lib/services/loader.service.js +0 -18
- package/esm5/lib/services/log.service.js +0 -112
- package/esm5/lib/services/message.service.js +0 -59
- package/esm5/lib/services/storage.service.js +0 -74
- package/esm5/lib/services/tin-spa.service.js +0 -16
- package/esm5/lib/tin-spa.module.js +0 -94
- package/esm5/public-api.js +0 -56
- package/esm5/tin-spa.js +0 -8
- package/fesm2015/tin-spa.js +0 -3184
- package/fesm2015/tin-spa.js.map +0 -1
- package/fesm5/tin-spa.js +0 -3422
- package/fesm5/tin-spa.js.map +0 -1
- package/lib/components/timeout/timeout.component.d.ts +0 -21
- package/lib/dnd.directive.d.ts +0 -8
- package/tin-spa.d.ts +0 -7
- package/tin-spa.metadata.json +0 -1
|
@@ -0,0 +1,341 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { MatTableDataSource } from '@angular/material/table';
|
|
3
|
+
import { FormConfig } from '../../classes/Classes';
|
|
4
|
+
import { detailsDialog } from './detailsDialog.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/data.service";
|
|
7
|
+
import * as i2 from "../../services/message.service";
|
|
8
|
+
import * as i3 from "@angular/cdk/layout";
|
|
9
|
+
import * as i4 from "@angular/material/dialog";
|
|
10
|
+
import * as i5 from "@angular/common";
|
|
11
|
+
import * as i6 from "@angular/material/table";
|
|
12
|
+
import * as i7 from "@angular/material/paginator";
|
|
13
|
+
import * as i8 from "@angular/material/button";
|
|
14
|
+
import * as i9 from "@angular/material/icon";
|
|
15
|
+
import * as i10 from "@angular/material/tooltip";
|
|
16
|
+
import * as i11 from "../check/check.component";
|
|
17
|
+
import * as i12 from "../filter/filter.component";
|
|
18
|
+
import * as i13 from "../../pipes/camelToWords.pipe";
|
|
19
|
+
export class TableComponent {
|
|
20
|
+
constructor(dataService, messageService, breakpointObserver, dialog) {
|
|
21
|
+
this.dataService = dataService;
|
|
22
|
+
this.messageService = messageService;
|
|
23
|
+
this.breakpointObserver = breakpointObserver;
|
|
24
|
+
this.dialog = dialog;
|
|
25
|
+
this.actionsWidth = "50px";
|
|
26
|
+
this.data = [];
|
|
27
|
+
this.refreshClick = new EventEmitter();
|
|
28
|
+
this.createClick = new EventEmitter();
|
|
29
|
+
this.viewClick = new EventEmitter();
|
|
30
|
+
this.editClick = new EventEmitter();
|
|
31
|
+
this.deleteClick = new EventEmitter();
|
|
32
|
+
this.custom1Click = new EventEmitter();
|
|
33
|
+
this.custom2Click = new EventEmitter();
|
|
34
|
+
this.custom3Click = new EventEmitter();
|
|
35
|
+
this.smallScreen = false;
|
|
36
|
+
this.options = [];
|
|
37
|
+
this.displayedColumns = [];
|
|
38
|
+
// detect screen size changes
|
|
39
|
+
this.breakpointObserver.observe(["(max-width: 600px)"]).subscribe((result) => {
|
|
40
|
+
if (result.matches) {
|
|
41
|
+
this.smallScreen = true;
|
|
42
|
+
this.setColumns();
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.smallScreen = false;
|
|
46
|
+
this.setColumns();
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
ngOnInit() {
|
|
51
|
+
this.options = this.config.columns;
|
|
52
|
+
this.setColumns();
|
|
53
|
+
this.createButton = this.getButton('create');
|
|
54
|
+
this.viewButton = this.getButton('view');
|
|
55
|
+
this.editButton = this.getButton('edit');
|
|
56
|
+
this.deleteButton = this.getButton('delete');
|
|
57
|
+
this.custom1Button = this.getButton('custom1');
|
|
58
|
+
this.custom2Button = this.getButton('custom2');
|
|
59
|
+
this.custom3Button = this.getButton('custom3');
|
|
60
|
+
if (this.config.loadAction) {
|
|
61
|
+
this.loadData();
|
|
62
|
+
}
|
|
63
|
+
this.formDefaults();
|
|
64
|
+
}
|
|
65
|
+
ngOnChanges() {
|
|
66
|
+
if (!this.config.loadAction) {
|
|
67
|
+
console.log("Table data Changed");
|
|
68
|
+
this.dataSource = this.data;
|
|
69
|
+
this.tableDataSource = new MatTableDataSource(this.dataSource);
|
|
70
|
+
setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 5);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
getButton(name) {
|
|
74
|
+
if (!this.config.buttons)
|
|
75
|
+
return null;
|
|
76
|
+
return this.config.buttons.find(x => x.name == name);
|
|
77
|
+
}
|
|
78
|
+
getIcon(buttonName) {
|
|
79
|
+
let b = this.getButton(buttonName);
|
|
80
|
+
if (b.icon) {
|
|
81
|
+
return b.icon.name;
|
|
82
|
+
}
|
|
83
|
+
let i = 'pageview';
|
|
84
|
+
switch (buttonName) {
|
|
85
|
+
case 'view':
|
|
86
|
+
i = 'pageview';
|
|
87
|
+
break;
|
|
88
|
+
case 'edit':
|
|
89
|
+
i = 'edit';
|
|
90
|
+
break;
|
|
91
|
+
case 'delete':
|
|
92
|
+
i = 'delete';
|
|
93
|
+
break;
|
|
94
|
+
default:
|
|
95
|
+
break;
|
|
96
|
+
}
|
|
97
|
+
return i;
|
|
98
|
+
}
|
|
99
|
+
setColumns() {
|
|
100
|
+
if (!this.config?.columns) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
if (this.smallScreen) {
|
|
104
|
+
this.displayedColumns = this.config.minColumns;
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
this.displayedColumns = this.config.columns.map(({ name }) => name);
|
|
108
|
+
}
|
|
109
|
+
let buttonsCount = this.config.buttons.filter(x => x.name != 'create').length ?? 0;
|
|
110
|
+
if (buttonsCount > 0) {
|
|
111
|
+
if (!this.displayedColumns.find(x => x == 'action') && this.config.buttons) {
|
|
112
|
+
this.displayedColumns.push("action");
|
|
113
|
+
}
|
|
114
|
+
this.actionsWidth = `${buttonsCount * 40 + 20}px`;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
getOptions(column) {
|
|
118
|
+
let x = this.options.find(opt => opt.name === column);
|
|
119
|
+
return x;
|
|
120
|
+
}
|
|
121
|
+
testIconCondition(column, row) {
|
|
122
|
+
const option = this.getOptions(column);
|
|
123
|
+
if (option && option.icon && !option.icon.condition) {
|
|
124
|
+
return true;
|
|
125
|
+
}
|
|
126
|
+
if (option && option.icon && option.icon.condition) {
|
|
127
|
+
return option.icon.condition(row[column]);
|
|
128
|
+
}
|
|
129
|
+
return false;
|
|
130
|
+
}
|
|
131
|
+
testDisabled(row, buttonName) {
|
|
132
|
+
let button = this.getButton(buttonName);
|
|
133
|
+
if (button.disabled) {
|
|
134
|
+
return button.disabled(row);
|
|
135
|
+
}
|
|
136
|
+
return false;
|
|
137
|
+
}
|
|
138
|
+
testVisible(row, buttonName) {
|
|
139
|
+
let button = this.getButton(buttonName);
|
|
140
|
+
if (button.visible) {
|
|
141
|
+
return button.visible(row);
|
|
142
|
+
}
|
|
143
|
+
return true;
|
|
144
|
+
}
|
|
145
|
+
//Actions
|
|
146
|
+
refreshClicked() {
|
|
147
|
+
console.log("Refresh");
|
|
148
|
+
this.refreshClick.emit();
|
|
149
|
+
if (this.config.loadAction) {
|
|
150
|
+
this.loadData();
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
view(x) {
|
|
154
|
+
console.log("View");
|
|
155
|
+
this.viewClick.emit(x);
|
|
156
|
+
// this.doAction('view', x);
|
|
157
|
+
}
|
|
158
|
+
create(x) {
|
|
159
|
+
console.log("Create");
|
|
160
|
+
this.createClick.emit(x);
|
|
161
|
+
this.doAction('create', x);
|
|
162
|
+
}
|
|
163
|
+
edit(x) {
|
|
164
|
+
console.log("Edit");
|
|
165
|
+
this.editClick.emit(x);
|
|
166
|
+
this.doAction('edit', x);
|
|
167
|
+
}
|
|
168
|
+
delete(x) {
|
|
169
|
+
console.log("Delete");
|
|
170
|
+
this.deleteClick.emit(x);
|
|
171
|
+
this.doAction('delete', x);
|
|
172
|
+
}
|
|
173
|
+
custom1(x) {
|
|
174
|
+
console.log("Custom 1");
|
|
175
|
+
this.custom1Click.emit(x);
|
|
176
|
+
this.doAction('custom1', x);
|
|
177
|
+
}
|
|
178
|
+
custom2(x) {
|
|
179
|
+
console.log("Custom 2");
|
|
180
|
+
this.custom2Click.emit(x);
|
|
181
|
+
this.doAction('custom2', x);
|
|
182
|
+
}
|
|
183
|
+
custom3(x) {
|
|
184
|
+
console.log("Custom 3");
|
|
185
|
+
this.custom3Click.emit(x);
|
|
186
|
+
this.doAction('custom3', x);
|
|
187
|
+
}
|
|
188
|
+
viewModel(row) {
|
|
189
|
+
let button = this.getButton('view');
|
|
190
|
+
if (button && !button.dialog) {
|
|
191
|
+
this.view(row);
|
|
192
|
+
return;
|
|
193
|
+
}
|
|
194
|
+
if (!this.config.formConfig) {
|
|
195
|
+
this.messageService.toast("Please configure form");
|
|
196
|
+
return;
|
|
197
|
+
}
|
|
198
|
+
const dialogRef = this.dialog.open(detailsDialog, {
|
|
199
|
+
width: "900px",
|
|
200
|
+
data: { mode: "view", config: this.config, details: row, smallScreen: this.smallScreen },
|
|
201
|
+
});
|
|
202
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
203
|
+
if (result.message) {
|
|
204
|
+
this.refreshClicked();
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
newModel() {
|
|
209
|
+
let button = this.getButton('create');
|
|
210
|
+
if (button && !button.dialog) {
|
|
211
|
+
this.create('');
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
if (!this.config.formConfig) {
|
|
215
|
+
this.messageService.toast("Please configure form");
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
const dialogRef = this.dialog.open(detailsDialog, {
|
|
219
|
+
width: "900px",
|
|
220
|
+
data: { mode: "create", config: this.config, smallScreen: this.smallScreen }
|
|
221
|
+
});
|
|
222
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
223
|
+
if (result.message) {
|
|
224
|
+
this.create(result.data);
|
|
225
|
+
this.refreshClicked();
|
|
226
|
+
}
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
editModel(row) {
|
|
230
|
+
let button = this.getButton('edit');
|
|
231
|
+
if (button && !button.dialog) {
|
|
232
|
+
this.edit(row);
|
|
233
|
+
return;
|
|
234
|
+
}
|
|
235
|
+
if (!this.config.formConfig) {
|
|
236
|
+
this.messageService.toast("Please configure form");
|
|
237
|
+
return;
|
|
238
|
+
}
|
|
239
|
+
const dialogRef = this.dialog.open(detailsDialog, {
|
|
240
|
+
width: "900px",
|
|
241
|
+
data: { mode: "edit", config: this.config, details: row, smallScreen: this.smallScreen },
|
|
242
|
+
});
|
|
243
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
244
|
+
if (result.message) {
|
|
245
|
+
this.edit(result.data);
|
|
246
|
+
this.refreshClicked();
|
|
247
|
+
}
|
|
248
|
+
});
|
|
249
|
+
}
|
|
250
|
+
deleteModel(row) {
|
|
251
|
+
let button = this.getButton('delete');
|
|
252
|
+
if (button && !button.dialog) {
|
|
253
|
+
this.delete(row);
|
|
254
|
+
return;
|
|
255
|
+
}
|
|
256
|
+
this.messageService.confirm(`DELETE ?`).subscribe((result) => {
|
|
257
|
+
if (result == "yes") {
|
|
258
|
+
this.delete(row);
|
|
259
|
+
this.refreshClicked();
|
|
260
|
+
}
|
|
261
|
+
});
|
|
262
|
+
}
|
|
263
|
+
doAction(buttonName, row) {
|
|
264
|
+
let b = this.getButton(buttonName);
|
|
265
|
+
if (!b)
|
|
266
|
+
return;
|
|
267
|
+
if (b.action && buttonName != 'delete')
|
|
268
|
+
return;
|
|
269
|
+
this.dataService.CallApi(b.action, row).subscribe((apiResponse) => {
|
|
270
|
+
if (apiResponse.success) {
|
|
271
|
+
if (b.action.successMessage) {
|
|
272
|
+
this.messageService.toast(b.action.successMessage);
|
|
273
|
+
}
|
|
274
|
+
else {
|
|
275
|
+
this.messageService.toast("Updated");
|
|
276
|
+
}
|
|
277
|
+
this.refreshClicked();
|
|
278
|
+
}
|
|
279
|
+
else {
|
|
280
|
+
this.messageService.toast("Error: " + apiResponse);
|
|
281
|
+
}
|
|
282
|
+
});
|
|
283
|
+
}
|
|
284
|
+
loadData() {
|
|
285
|
+
console.log("loading");
|
|
286
|
+
if (this.config.loadAction) {
|
|
287
|
+
this.dataService.CallApi(this.config.loadAction, "").subscribe((apiResponse) => {
|
|
288
|
+
this.dataSource = apiResponse.data;
|
|
289
|
+
this.tableDataSource = new MatTableDataSource(apiResponse.data);
|
|
290
|
+
this.tableDataSource.paginator = this.tablePaginator;
|
|
291
|
+
// if (apiResponse.success){
|
|
292
|
+
// this.tableDataSource = new MatTableDataSource(apiResponse.data);
|
|
293
|
+
// this.tableDataSource.paginator = this.tablePaginator;
|
|
294
|
+
// }else{
|
|
295
|
+
// this.messageService.toast("Error: " + JSON.stringify(apiResponse));
|
|
296
|
+
// }
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
formDefaults() {
|
|
301
|
+
if (!this.config.formConfig) {
|
|
302
|
+
let config = new FormConfig;
|
|
303
|
+
config.fields = [];
|
|
304
|
+
this.config.columns.forEach(column => {
|
|
305
|
+
let field = { name: column.name, type: column.type };
|
|
306
|
+
config.fields.push(field);
|
|
307
|
+
});
|
|
308
|
+
this.config.formConfig = config;
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, deps: [{ token: i1.DataServiceLib }, { token: i2.MessageService }, { token: i3.BreakpointObserver }, { token: i4.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
313
|
+
TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableComponent, selector: "spa-table", inputs: { data: "data", config: "config" }, outputs: { refreshClick: "refreshClick", createClick: "createClick", viewClick: "viewClick", editClick: "editClick", deleteClick: "deleteClick", custom1Click: "custom1Click", custom2Click: "custom2Click", custom3Click: "custom3Click" }, viewQueries: [{ propertyName: "tablePaginator", first: true, predicate: ["tablePaginator"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n<div class=\"top\">\n\n <div >\n <!-- <button *ngIf=\"config.newText\" id=\"btnNew\" mat-raised-button color=\"primary\" (click)=\"newModel()\">{{config.newText}}</button> -->\n <button *ngIf=\"createButton\" id=\"btnNew\" mat-raised-button color=\"primary\" (click)=\"newModel()\">{{createButton.display}}</button>\n </div>\n\n <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\n <spa-filter [data]=\"tableDataSource\" (refreshClick)=\"refreshClicked()\"></spa-filter>\n </div>\n\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\">\n\n\n <table mat-table [dataSource]=\"tableDataSource\" class=\"mat-elevation-z8\">\n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\n <th mat-header-cell *matHeaderCellDef>{{ column.name | camelToWords }}</th>\n <td mat-cell *matCellDef=\"let row;\" >\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 </ng-container>\n\n <ng-container *ngSwitchCase=\"'date'\">\n {{row[column.name] | date : 'dd/MM/yyyy'}}\n <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'money'\">\n {{row[column.name] | currency:'':''}}\n <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <label>{{row[column.name]}}</label>\n <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\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:smallScreen ? '50px' : actionsWidth}\">\n\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"viewButton.tip ?? 'view' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':viewButton.color}\" [disabled]=\"testDisabled(row,'view')\" *ngIf=\"viewButton && testVisible(row,'view')\" (click)=\"viewModel(row)\">\n <mat-icon>{{getIcon('view')}}</mat-icon>\n </button>\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom1Button.tip ?? 'custom1' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom1Button.color}\" [disabled]=\"testDisabled(row,'custom1')\" *ngIf=\"!smallScreen && custom1Button && testVisible(row,'custom1')\" (click)=\"custom1(row)\">\n <mat-icon>{{getIcon('custom1')}}</mat-icon>\n </button>\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom2Button.tip ?? 'custom2' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom2Button.color}\" [disabled]=\"testDisabled(row,'custom2')\" *ngIf=\"!smallScreen && custom2Button && testVisible(row,'custom2')\" (click)=\"custom2(row)\">\n <mat-icon>{{getIcon('custom2')}}</mat-icon>\n </button>\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom3Button.tip ?? 'custom3' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom3Button.color}\" [disabled]=\"testDisabled(row,'custom3')\" *ngIf=\"!smallScreen && custom3Button && testVisible(row,'custom3')\" (click)=\"custom3(row)\">\n <mat-icon>{{getIcon('custom3')}}</mat-icon>\n </button>\n\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"editButton.tip ?? 'edit' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':editButton.color}\" [disabled]=\"testDisabled(row,'edit')\" *ngIf=\"!smallScreen && editButton && testVisible(row,'edit')\" (click)=\"editModel(row)\">\n <mat-icon>{{getIcon('edit')}}</mat-icon>\n </button>\n\n <button mat-mini-fab color=\"warn\" [matTooltip]=\"deleteButton.tip ?? 'delete' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':deleteButton.color}\" [disabled]=\"testDisabled(row,'delete')\" *ngIf=\"!smallScreen && deleteButton && testVisible(row,'delete')\" (click)=\"deleteModel(row)\">\n <mat-icon>{{getIcon('delete')}}</mat-icon>\n </button>\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;\"></tr>\n </table>\n\n </div>\n\n <mat-paginator #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\n\n</div>\n\n<p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\n\n\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}\n"], dependencies: [{ 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: "directive", type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i11.CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value"], outputs: ["valueChange", "click", "check", "uncheck"] }, { kind: "component", type: i12.FilterComponent, selector: "spa-filter", inputs: ["data"], outputs: ["refreshClick"] }, { kind: "pipe", type: i5.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i5.DatePipe, name: "date" }, { kind: "pipe", type: i13.CamelToWordsPipe, name: "camelToWords" }] });
|
|
314
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, decorators: [{
|
|
315
|
+
type: Component,
|
|
316
|
+
args: [{ selector: 'spa-table', template: "\n<div class=\"top\">\n\n <div >\n <!-- <button *ngIf=\"config.newText\" id=\"btnNew\" mat-raised-button color=\"primary\" (click)=\"newModel()\">{{config.newText}}</button> -->\n <button *ngIf=\"createButton\" id=\"btnNew\" mat-raised-button color=\"primary\" (click)=\"newModel()\">{{createButton.display}}</button>\n </div>\n\n <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\n <spa-filter [data]=\"tableDataSource\" (refreshClick)=\"refreshClicked()\"></spa-filter>\n </div>\n\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\">\n\n\n <table mat-table [dataSource]=\"tableDataSource\" class=\"mat-elevation-z8\">\n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\n <th mat-header-cell *matHeaderCellDef>{{ column.name | camelToWords }}</th>\n <td mat-cell *matCellDef=\"let row;\" >\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 </ng-container>\n\n <ng-container *ngSwitchCase=\"'date'\">\n {{row[column.name] | date : 'dd/MM/yyyy'}}\n <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'money'\">\n {{row[column.name] | currency:'':''}}\n <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <label>{{row[column.name]}}</label>\n <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\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:smallScreen ? '50px' : actionsWidth}\">\n\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"viewButton.tip ?? 'view' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':viewButton.color}\" [disabled]=\"testDisabled(row,'view')\" *ngIf=\"viewButton && testVisible(row,'view')\" (click)=\"viewModel(row)\">\n <mat-icon>{{getIcon('view')}}</mat-icon>\n </button>\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom1Button.tip ?? 'custom1' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom1Button.color}\" [disabled]=\"testDisabled(row,'custom1')\" *ngIf=\"!smallScreen && custom1Button && testVisible(row,'custom1')\" (click)=\"custom1(row)\">\n <mat-icon>{{getIcon('custom1')}}</mat-icon>\n </button>\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom2Button.tip ?? 'custom2' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom2Button.color}\" [disabled]=\"testDisabled(row,'custom2')\" *ngIf=\"!smallScreen && custom2Button && testVisible(row,'custom2')\" (click)=\"custom2(row)\">\n <mat-icon>{{getIcon('custom2')}}</mat-icon>\n </button>\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom3Button.tip ?? 'custom3' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom3Button.color}\" [disabled]=\"testDisabled(row,'custom3')\" *ngIf=\"!smallScreen && custom3Button && testVisible(row,'custom3')\" (click)=\"custom3(row)\">\n <mat-icon>{{getIcon('custom3')}}</mat-icon>\n </button>\n\n\n <button mat-mini-fab color=\"primary\" [matTooltip]=\"editButton.tip ?? 'edit' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':editButton.color}\" [disabled]=\"testDisabled(row,'edit')\" *ngIf=\"!smallScreen && editButton && testVisible(row,'edit')\" (click)=\"editModel(row)\">\n <mat-icon>{{getIcon('edit')}}</mat-icon>\n </button>\n\n <button mat-mini-fab color=\"warn\" [matTooltip]=\"deleteButton.tip ?? 'delete' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':deleteButton.color}\" [disabled]=\"testDisabled(row,'delete')\" *ngIf=\"!smallScreen && deleteButton && testVisible(row,'delete')\" (click)=\"deleteModel(row)\">\n <mat-icon>{{getIcon('delete')}}</mat-icon>\n </button>\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;\"></tr>\n </table>\n\n </div>\n\n <mat-paginator #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\n\n</div>\n\n<p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\n\n\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}\n"] }]
|
|
317
|
+
}], ctorParameters: function () { return [{ type: i1.DataServiceLib }, { type: i2.MessageService }, { type: i3.BreakpointObserver }, { type: i4.MatDialog }]; }, propDecorators: { tablePaginator: [{
|
|
318
|
+
type: ViewChild,
|
|
319
|
+
args: ['tablePaginator']
|
|
320
|
+
}], data: [{
|
|
321
|
+
type: Input
|
|
322
|
+
}], config: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], refreshClick: [{
|
|
325
|
+
type: Output
|
|
326
|
+
}], createClick: [{
|
|
327
|
+
type: Output
|
|
328
|
+
}], viewClick: [{
|
|
329
|
+
type: Output
|
|
330
|
+
}], editClick: [{
|
|
331
|
+
type: Output
|
|
332
|
+
}], deleteClick: [{
|
|
333
|
+
type: Output
|
|
334
|
+
}], custom1Click: [{
|
|
335
|
+
type: Output
|
|
336
|
+
}], custom2Click: [{
|
|
337
|
+
type: Output
|
|
338
|
+
}], custom3Click: [{
|
|
339
|
+
type: Output
|
|
340
|
+
}] } });
|
|
341
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table/table.component.ts","../../../../../../projects/tin-spa/src/lib/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { DatePipe, CurrencyPipe } from '@angular/common';\nimport { Button, Column, FormConfig, TableConfig } from '../../classes/Classes';\nimport { MatPaginator } from '@angular/material/paginator';\nimport { MessageService } from '../../services/message.service';\nimport { MatDialog } from '@angular/material/dialog';\nimport { detailsDialog } from './detailsDialog.component';\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\nimport { DataServiceLib } from '../../services/data.service';\nimport { ApiResponse } from '../../classes/TinCore';\n\n@Component({\n  selector: 'spa-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.css']\n})\nexport class TableComponent implements OnInit {\n\n  constructor(private dataService: DataServiceLib, private messageService: MessageService, private breakpointObserver: BreakpointObserver, public dialog: MatDialog)\n  {\n    // detect screen size changes\n    this.breakpointObserver.observe([ \"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\n\n      if (result.matches) {\n        this.smallScreen = true\n        this.setColumns()\n      } else {\n        this.smallScreen = false\n        this.setColumns()\n      }\n\n    });\n  }\n\n\n  ngOnInit() {\n\n    this.options = this.config.columns;\n\n    this.setColumns()\n\n    this.createButton = this.getButton('create')\n    this.viewButton = this.getButton('view')\n    this.editButton = this.getButton('edit')\n    this.deleteButton = this.getButton('delete')\n    this.custom1Button = this.getButton('custom1')\n    this.custom2Button = this.getButton('custom2')\n    this.custom3Button = this.getButton('custom3')\n\n\n    if (this.config.loadAction){\n      this.loadData();\n    }\n\n    this.formDefaults();\n\n\n\n  }\n\n\n  actionsWidth = \"50px\";\n\n\n\n  ngOnChanges() {\n\n    if (!this.config.loadAction){\n      console.log(\"Table data Changed\")\n      this.dataSource = this.data;\n\n      this.tableDataSource = new MatTableDataSource<any>(this.dataSource);\n      setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 5)\n    }\n\n  }\n\n\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\n\n\n  @Input() data: any =[];\n  @Input() config: TableConfig;\n\n  @Output() refreshClick = new EventEmitter();\n  @Output() createClick = new EventEmitter();\n  @Output() viewClick = new EventEmitter();\n  @Output() editClick = new EventEmitter();\n  @Output() deleteClick = new EventEmitter();\n  @Output() custom1Click = new EventEmitter();\n  @Output() custom2Click = new EventEmitter();\n  @Output() custom3Click = new EventEmitter();\n\n  smallScreen = false\n\n  createButton: Button;\n  viewButton\n  editButton\n  deleteButton\n  custom1Button\n  custom2Button\n  custom3Button\n\n  //Table\n  tableDataSource;\n  dataSource: any[];\n  options: Column[] = [];\n  displayedColumns = []\n\n\n  getButton(name: string) {\n    if (!this.config.buttons) return null\n    return this.config.buttons.find(x => x.name == name)\n  }\n\n  getIcon(buttonName: string){\n\n    let b = this.getButton(buttonName);\n    if (b.icon){\n      return b.icon.name\n    }\n\n    let i = 'pageview'\n\n    switch (buttonName) {\n\n      case 'view':\n        i = 'pageview'\n        break;\n      case 'edit':\n        i = 'edit'\n        break;\n      case 'delete':\n        i = 'delete'\n        break;\n\n      default:\n        break;\n    }\n\n    return i;\n  }\n\n  setColumns (){\n\n    if (!this.config?.columns){\n      return\n    }\n\n    if (this.smallScreen) {\n      this.displayedColumns = this.config.minColumns\n    } else {\n      this.displayedColumns = this.config.columns.map(({ name }) => name)\n    }\n\n\n    let buttonsCount = this.config.buttons.filter(x => x.name != 'create').length ?? 0\n    if (buttonsCount > 0){\n\n      if (!this.displayedColumns.find(x => x == 'action') && this.config.buttons) {\n        this.displayedColumns.push(\"action\")\n      }\n\n      this.actionsWidth = `${buttonsCount * 40 + 20}px`\n\n    }\n\n  }\n\n  getOptions(column){\n    let x = this.options.find(opt => opt.name === column);\n    return  x\n  }\n\n\n  testIconCondition(column: string, row: any): boolean {\n\n    const option = this.getOptions(column);\n\n    if (option && option.icon && !option.icon.condition){\n      return true;\n    }\n\n    if (option && option.icon && option.icon.condition) {\n      return option.icon.condition(row[column]);\n    }\n\n    return false;\n  }\n\n  testDisabled(row, buttonName: string): boolean{\n\n    let button = this.getButton(buttonName)\n\n    if (button.disabled){\n\n      return button.disabled(row);\n    }\n\n    return false;\n  }\n\n  testVisible(row, buttonName: string): boolean {\n\n    let button = this.getButton(buttonName)\n\n    if (button.visible) {\n\n      return button.visible(row);\n    }\n\n    return true;\n  }\n\n\n  //Actions\n\n  refreshClicked() {\n    console.log(\"Refresh\")\n    this.refreshClick.emit();\n\n    if (this.config.loadAction) {\n      this.loadData();\n    }\n  }\n\n  view(x) {\n    console.log(\"View\")\n    this.viewClick.emit(x);\n    // this.doAction('view', x);\n  }\n\n  create(x) {\n    console.log(\"Create\")\n    this.createClick.emit(x);\n    this.doAction('create', x);\n  }\n\n  edit(x) {\n    console.log(\"Edit\")\n    this.editClick.emit(x);\n    this.doAction('edit', x);\n  }\n\n  delete(x) {\n    console.log(\"Delete\")\n    this.deleteClick.emit(x);\n    this.doAction('delete', x);\n  }\n\n  custom1(x) {\n    console.log(\"Custom 1\")\n    this.custom1Click.emit(x);\n    this.doAction('custom1', x);\n  }\n\n  custom2(x) {\n    console.log(\"Custom 2\")\n    this.custom2Click.emit(x);\n    this.doAction('custom2', x);\n  }\n\n  custom3(x) {\n    console.log(\"Custom 3\")\n    this.custom3Click.emit(x);\n    this.doAction('custom3', x);\n  }\n\n\n  viewModel(row) {\n\n    let button = this.getButton('view');\n    if (button && !button.dialog) {\n      this.view(row);\n      return;\n    }\n\n    if (!this.config.formConfig) {\n      this.messageService.toast(\"Please configure form\")\n      return;\n    }\n\n    const dialogRef = this.dialog.open(detailsDialog, {\n      width: \"900px\",\n      data: { mode: \"view\", config: this.config, details: row, smallScreen: this.smallScreen },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result.message) {\n        this.refreshClicked();\n      }\n    });\n\n  }\n\n  newModel() {\n\n    let button = this.getButton('create');\n    if (button && !button.dialog){\n      this.create('');\n      return;\n    }\n\n    if (!this.config.formConfig){\n      this.messageService.toast(\"Please configure form\")\n      return;\n    }\n\n    const dialogRef = this.dialog.open(detailsDialog, {\n      width: \"900px\",\n      data: { mode: \"create\", config: this.config, smallScreen: this.smallScreen }\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result.message) {\n        this.create(result.data);\n        this.refreshClicked();\n      }\n    });\n  }\n\n\n\n  editModel(row) {\n\n    let button = this.getButton('edit');\n    if (button && !button.dialog) {\n      this.edit(row);\n      return;\n    }\n\n    if (!this.config.formConfig) {\n      this.messageService.toast(\"Please configure form\")\n      return;\n    }\n\n    const dialogRef = this.dialog.open(detailsDialog, {\n      width: \"900px\",\n      data: { mode: \"edit\", config: this.config, details: row, smallScreen: this.smallScreen },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result.message) {\n        this.edit(result.data);\n        this.refreshClicked();\n      }\n    });\n  }\n\n  deleteModel(row) {\n\n    let button = this.getButton('delete');\n    if (button && !button.dialog) {\n      this.delete(row);\n      return;\n    }\n\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\n        if (result == \"yes\") {\n          this.delete(row)\n          this.refreshClicked();\n        }\n      });\n  }\n\n  doAction(buttonName,row){\n\n\n    let b = this.getButton(buttonName)\n\n    if (!b) return;\n\n    if (b.action && buttonName != 'delete') return;\n\n\n\n    this.dataService.CallApi(b.action, row).subscribe((apiResponse) => {\n\n      if (apiResponse.success) {\n        if (b.action.successMessage){\n          this.messageService.toast(b.action.successMessage);\n        }else{\n          this.messageService.toast(\"Updated\");\n        }\n\n        this.refreshClicked();\n      } else {\n        this.messageService.toast(\"Error: \" + apiResponse);\n      }\n    });\n\n  }\n\n  loadData(){\n    console.log(\"loading\")\n\n    if (this.config.loadAction){\n\n      this.dataService.CallApi(this.config.loadAction, \"\").subscribe((apiResponse: ApiResponse) => {\n\n        this.dataSource = apiResponse.data\n\n        this.tableDataSource = new MatTableDataSource<any>(apiResponse.data);\n        this.tableDataSource.paginator = this.tablePaginator;\n\n        // if (apiResponse.success){\n        //   this.tableDataSource = new MatTableDataSource(apiResponse.data);\n        //   this.tableDataSource.paginator = this.tablePaginator;\n        // }else{\n        //   this.messageService.toast(\"Error: \" + JSON.stringify(apiResponse));\n        // }\n\n      });\n    }\n\n  }\n\n  formDefaults(){\n\n    if (!this.config.formConfig){\n      let config = new FormConfig\n\n      config.fields = []\n\n      this.config.columns.forEach(column => {\n\n        let field = {name: column.name, type: column.type}\n        config.fields.push(field)\n\n      });\n\n      this.config.formConfig = config;\n    }\n  }\n\n}\n","\n<div class=\"top\">\n\n  <div >\n    <!-- <button *ngIf=\"config.newText\" id=\"btnNew\" mat-raised-button color=\"primary\" (click)=\"newModel()\">{{config.newText}}</button> -->\n    <button *ngIf=\"createButton\" id=\"btnNew\" mat-raised-button color=\"primary\" (click)=\"newModel()\">{{createButton.display}}</button>\n  </div>\n\n  <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\n    <spa-filter [data]=\"tableDataSource\" (refreshClick)=\"refreshClicked()\"></spa-filter>\n  </div>\n\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\">\n\n\n    <table mat-table [dataSource]=\"tableDataSource\" class=\"mat-elevation-z8\">\n      <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\n        <th mat-header-cell *matHeaderCellDef>{{ column.name | camelToWords }}</th>\n        <td mat-cell *matCellDef=\"let row;\" >\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            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'date'\">\n              {{row[column.name] | date : 'dd/MM/yyyy'}}\n              <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'money'\">\n              {{row[column.name] | currency:'':''}}\n              <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n            </ng-container>\n\n            <ng-container *ngSwitchDefault>\n              <label>{{row[column.name]}}</label>\n              <mat-icon *ngIf=\"column.icon && testIconCondition(column.name, row)\" [matTooltip]=\"column.icon?.tip\" matTooltipPosition=\"above\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\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:smallScreen ? '50px' : actionsWidth}\">\n\n\n          <button mat-mini-fab color=\"primary\" [matTooltip]=\"viewButton.tip ?? 'view' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':viewButton.color}\" [disabled]=\"testDisabled(row,'view')\" *ngIf=\"viewButton && testVisible(row,'view')\" (click)=\"viewModel(row)\">\n            <mat-icon>{{getIcon('view')}}</mat-icon>\n          </button>\n\n          <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom1Button.tip ?? 'custom1' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom1Button.color}\" [disabled]=\"testDisabled(row,'custom1')\" *ngIf=\"!smallScreen && custom1Button && testVisible(row,'custom1')\" (click)=\"custom1(row)\">\n            <mat-icon>{{getIcon('custom1')}}</mat-icon>\n          </button>\n\n          <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom2Button.tip ?? 'custom2' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom2Button.color}\" [disabled]=\"testDisabled(row,'custom2')\" *ngIf=\"!smallScreen && custom2Button && testVisible(row,'custom2')\" (click)=\"custom2(row)\">\n            <mat-icon>{{getIcon('custom2')}}</mat-icon>\n          </button>\n\n          <button mat-mini-fab color=\"primary\" [matTooltip]=\"custom3Button.tip ?? 'custom3' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':custom3Button.color}\" [disabled]=\"testDisabled(row,'custom3')\" *ngIf=\"!smallScreen && custom3Button && testVisible(row,'custom3')\" (click)=\"custom3(row)\">\n            <mat-icon>{{getIcon('custom3')}}</mat-icon>\n          </button>\n\n\n          <button mat-mini-fab color=\"primary\" [matTooltip]=\"editButton.tip ?? 'edit' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':editButton.color}\" [disabled]=\"testDisabled(row,'edit')\" *ngIf=\"!smallScreen && editButton && testVisible(row,'edit')\" (click)=\"editModel(row)\">\n            <mat-icon>{{getIcon('edit')}}</mat-icon>\n          </button>\n\n          <button mat-mini-fab color=\"warn\" [matTooltip]=\"deleteButton.tip ?? 'delete' \" matTooltipPosition=\"above\" style=\"margin-right:5px\" [ngStyle]=\"{'background-color':deleteButton.color}\" [disabled]=\"testDisabled(row,'delete')\" *ngIf=\"!smallScreen && deleteButton && testVisible(row,'delete')\" (click)=\"deleteModel(row)\">\n            <mat-icon>{{getIcon('delete')}}</mat-icon>\n          </button>\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;\"></tr>\n    </table>\n\n  </div>\n\n  <mat-paginator #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\n\n</div>\n\n<p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\n\n\n"]}
|