tin-spa 2.4.5 → 2.6.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/esm2020/lib/classes/Classes.mjs +5 -1
- package/esm2020/lib/classes/TinCore.mjs +28 -15
- package/esm2020/lib/components/alert/alert.component.mjs +11 -6
- package/esm2020/lib/components/email/email.component.mjs +19 -17
- package/esm2020/lib/components/form/form.component.mjs +17 -17
- package/esm2020/lib/components/label/label.component.mjs +3 -3
- package/esm2020/lib/components/list-dialog/list-dialog.component.mjs +1 -1
- package/esm2020/lib/components/option/option.component.mjs +32 -14
- package/esm2020/lib/components/page/page.component.mjs +9 -36
- package/esm2020/lib/components/search/search.component.mjs +10 -5
- package/esm2020/lib/components/select/select.component.mjs +33 -134
- package/esm2020/lib/components/select-common/select-common.component.mjs +135 -0
- package/esm2020/lib/components/select-internal/select-internal.component.mjs +47 -0
- package/esm2020/lib/components/select-lite/select-lite.component.mjs +13 -0
- package/esm2020/lib/components/steps/steps.component.mjs +33 -59
- package/esm2020/lib/components/suffix/suffix.component.mjs +71 -0
- package/esm2020/lib/components/table/detailsDialog.component.mjs +15 -11
- package/esm2020/lib/components/table/table.component.mjs +27 -62
- package/esm2020/lib/components/table-header/table-header.component.mjs +8 -6
- package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +18 -12
- package/esm2020/lib/components/table-internal/table-internal.component.mjs +31 -63
- package/esm2020/lib/components/table-lite/detailsDialog-lite.component.mjs +243 -0
- package/esm2020/lib/components/table-lite/table-lite.component.mjs +390 -0
- package/esm2020/lib/components/table-row/table-row.component.mjs +18 -4
- package/esm2020/lib/components/text/text.component.mjs +28 -36
- package/esm2020/lib/components/tiles/tiles.component.mjs +7 -2
- package/esm2020/lib/components/viewer/viewer.component.mjs +7 -3
- package/esm2020/lib/modules/admin/admin-routing.module.mjs +5 -1
- package/esm2020/lib/pages/accounts/accountDialog.component.mjs +1 -1
- package/esm2020/lib/pages/approvals/approvals.component.mjs +61 -0
- package/esm2020/lib/pages/approvals-config/approvals-config.component.mjs +89 -0
- package/esm2020/lib/pages/change-password/change-password.component.mjs +1 -1
- package/esm2020/lib/pages/create-account/create-account.component.mjs +1 -1
- package/esm2020/lib/pages/customers/customers.component.mjs +8 -8
- package/esm2020/lib/pages/departments/departments.component.mjs +1 -1
- package/esm2020/lib/pages/employees/employees.component.mjs +1 -1
- package/esm2020/lib/pages/inventory/inventory.component.mjs +1 -1
- package/esm2020/lib/pages/inventory/quantityDialog.component.mjs +1 -1
- package/esm2020/lib/pages/invitations-table/invitations-table.component.mjs +11 -10
- package/esm2020/lib/pages/login/login.component.mjs +1 -1
- package/esm2020/lib/pages/logs/logs.component.mjs +21 -22
- package/esm2020/lib/pages/membership/membership.component.mjs +15 -19
- package/esm2020/lib/pages/plans/plans.component.mjs +16 -19
- package/esm2020/lib/pages/positions/positions.component.mjs +3 -3
- package/esm2020/lib/pages/profile/profile.component.mjs +1 -1
- package/esm2020/lib/pages/recover-account/recover-account.component.mjs +1 -1
- package/esm2020/lib/pages/roles/addRoleDialog.component.mjs +2 -2
- package/esm2020/lib/pages/roles/roles.component.mjs +2 -2
- package/esm2020/lib/pages/signup/signup.component.mjs +1 -1
- package/esm2020/lib/pages/suppliers/suppliers.component.mjs +9 -9
- package/esm2020/lib/pages/tasks/tasks.component.mjs +9 -9
- package/esm2020/lib/pages/tenant-settings/tenant-settings.component.mjs +99 -71
- package/esm2020/lib/pages/tenants/tenants.component.mjs +8 -8
- package/esm2020/lib/pages/transactions/transactDialog.component.mjs +1 -1
- package/esm2020/lib/pages/transactions/transactions.component.mjs +1 -1
- package/esm2020/lib/pages/users/users.component.mjs +114 -92
- package/esm2020/lib/pages/welcome/welcome.component.mjs +8 -8
- package/esm2020/lib/select-context.directive.mjs +23 -0
- package/esm2020/lib/services/button.service.mjs +5 -6
- package/esm2020/lib/services/datalib.service.mjs +26 -15
- package/esm2020/lib/services/dialog.service.mjs +12 -1
- package/esm2020/lib/services/table-config.service.mjs +7 -3
- package/esm2020/lib/tin-spa.module.mjs +16 -9
- package/fesm2015/tin-spa.mjs +2867 -2017
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +2881 -2030
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/lib/classes/Classes.d.ts +18 -6
- package/lib/classes/TinCore.d.ts +1 -0
- package/lib/components/email/email.component.d.ts +4 -3
- package/lib/components/form/form.component.d.ts +4 -3
- package/lib/components/option/option.component.d.ts +8 -2
- package/lib/components/page/page.component.d.ts +2 -4
- package/lib/components/search/search.component.d.ts +3 -1
- package/lib/components/select/select.component.d.ts +9 -36
- package/lib/components/select-common/select-common.component.d.ts +42 -0
- package/lib/components/select-internal/select-internal.component.d.ts +17 -0
- package/lib/components/select-lite/select-lite.component.d.ts +6 -0
- package/lib/components/steps/steps.component.d.ts +9 -9
- package/lib/components/suffix/suffix.component.d.ts +23 -0
- package/lib/components/table/detailsDialog.component.d.ts +3 -2
- package/lib/components/table/table.component.d.ts +3 -2
- package/lib/components/table-header/table-header.component.d.ts +2 -1
- package/lib/components/table-internal/detailsDialog-internal.component.d.ts +3 -2
- package/lib/components/table-internal/table-internal.component.d.ts +3 -2
- package/lib/components/table-lite/detailsDialog-lite.component.d.ts +65 -0
- package/lib/components/table-lite/table-lite.component.d.ts +87 -0
- package/lib/components/table-row/table-row.component.d.ts +2 -0
- package/lib/components/text/text.component.d.ts +7 -7
- package/lib/components/tiles/tiles.component.d.ts +2 -1
- package/lib/pages/approvals/approvals.component.d.ts +11 -0
- package/lib/pages/approvals-config/approvals-config.component.d.ts +14 -0
- package/lib/pages/invitations-table/invitations-table.component.d.ts +1 -1
- package/lib/pages/logs/logs.component.d.ts +2 -6
- package/lib/pages/membership/membership.component.d.ts +2 -6
- package/lib/pages/plans/plans.component.d.ts +2 -6
- package/lib/pages/suppliers/suppliers.component.d.ts +1 -1
- package/lib/pages/tasks/tasks.component.d.ts +1 -1
- package/lib/pages/tenant-settings/tenant-settings.component.d.ts +10 -7
- package/lib/pages/tenants/tenants.component.d.ts +1 -1
- package/lib/pages/users/users.component.d.ts +8 -16
- package/lib/select-context.directive.d.ts +10 -0
- package/lib/services/button.service.d.ts +0 -1
- package/lib/services/datalib.service.d.ts +3 -1
- package/lib/services/table-config.service.d.ts +1 -1
- package/lib/tin-spa.module.d.ts +41 -34
- package/package.json +1 -1
- package/esm2020/lib/pages/invitations/invitations.component.mjs +0 -14
- package/esm2020/lib/pages/tenant-settings/inviteDialog.component.mjs +0 -60
- package/lib/pages/invitations/invitations.component.d.ts +0 -8
- package/lib/pages/tenant-settings/inviteDialog.component.d.ts +0 -28
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import { Component
|
|
2
|
-
import { MatTableDataSource } from "@angular/material/table";
|
|
1
|
+
import { Component } from "@angular/core";
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
import * as i1 from "../../services/http.service";
|
|
5
4
|
import * as i2 from "@angular/router";
|
|
@@ -7,13 +6,7 @@ import * as i3 from "../../services/auth.service";
|
|
|
7
6
|
import * as i4 from "../../services/datalib.service";
|
|
8
7
|
import * as i5 from "@angular/material/dialog";
|
|
9
8
|
import * as i6 from "../../services/message.service";
|
|
10
|
-
import * as i7 from "
|
|
11
|
-
import * as i8 from "@angular/material/table";
|
|
12
|
-
import * as i9 from "@angular/material/paginator";
|
|
13
|
-
import * as i10 from "@angular/material/button";
|
|
14
|
-
import * as i11 from "@angular/material/icon";
|
|
15
|
-
import * as i12 from "@angular/material/tooltip";
|
|
16
|
-
import * as i13 from "../../components/filter/filter.component";
|
|
9
|
+
import * as i7 from "../../components/table/table.component";
|
|
17
10
|
export class UsersComponent {
|
|
18
11
|
constructor(httpService, router, authService, dataService, dialog, messageService) {
|
|
19
12
|
this.httpService = httpService;
|
|
@@ -22,97 +15,126 @@ export class UsersComponent {
|
|
|
22
15
|
this.dataService = dataService;
|
|
23
16
|
this.dialog = dialog;
|
|
24
17
|
this.messageService = messageService;
|
|
25
|
-
this.
|
|
26
|
-
|
|
27
|
-
|
|
18
|
+
this.userBaseFormConfig = {
|
|
19
|
+
fields: [
|
|
20
|
+
{ name: 'userName', type: 'text', alias: 'Username', required: true, span: true, readonly: true },
|
|
21
|
+
{ name: 'authType', type: 'select', alias: 'Authentication Type', readonly: true, span: true, required: true, defaultFirstValue: true },
|
|
22
|
+
{
|
|
23
|
+
name: 'firstName', type: 'text', required: true,
|
|
24
|
+
readonlyCondition: x => x.authType !== 'local',
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
name: 'lastName', type: 'text', required: true,
|
|
28
|
+
readonlyCondition: x => x.authType !== 'local',
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
name: 'password', type: 'password', required: true,
|
|
32
|
+
hiddenCondition: x => x.authType !== 'local', span: true,
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
name: 'confirmPassword', type: 'password', required: true,
|
|
36
|
+
hiddenCondition: x => x.authType !== 'local', span: true
|
|
37
|
+
},
|
|
38
|
+
{ name: 'email', type: 'text', required: false, span: true },
|
|
39
|
+
{ name: 'roleID', type: 'select', alias: 'Role', required: true, span: true, defaultFirstValue: true },
|
|
40
|
+
],
|
|
41
|
+
};
|
|
42
|
+
this.createDialog = {
|
|
43
|
+
formConfig: {
|
|
44
|
+
...this.userBaseFormConfig,
|
|
45
|
+
title: 'User',
|
|
46
|
+
// fields: this.userBaseFormConfig.fields.filter(x => x.name !== 'userName' && x.name !== 'authType' && x.name !== 'email')
|
|
47
|
+
},
|
|
48
|
+
mode: 'create',
|
|
49
|
+
buttons: [
|
|
50
|
+
{ name: 'create', action: { method: 'post', url: 'User/register', successMessage: "User Created" } }
|
|
51
|
+
]
|
|
52
|
+
};
|
|
53
|
+
this.editDialog = {
|
|
54
|
+
formConfig: {
|
|
55
|
+
...this.userBaseFormConfig,
|
|
56
|
+
title: 'User',
|
|
57
|
+
fields: this.userBaseFormConfig.fields.filter(x => x.name !== 'password' && x.name !== 'confirmPassword')
|
|
58
|
+
},
|
|
59
|
+
mode: 'view',
|
|
60
|
+
buttons: [
|
|
61
|
+
{ name: 'edit', action: { method: 'post', url: 'User/edit', successMessage: "User Updated" } }
|
|
62
|
+
]
|
|
63
|
+
};
|
|
64
|
+
this.passwordDialog = {
|
|
65
|
+
formConfig: {
|
|
66
|
+
...this.userBaseFormConfig,
|
|
67
|
+
title: 'Change Password',
|
|
68
|
+
fixedTitle: true,
|
|
69
|
+
alertMessages: { messages: [
|
|
70
|
+
{ type: 'info', content: '*Please consider these requirements for your new password.' },
|
|
71
|
+
{ type: 'info', content: 'At least 8 characters.' },
|
|
72
|
+
{ type: 'info', content: 'At least 1 uppercase letter' },
|
|
73
|
+
{ type: 'info', content: 'At least 2 lowercase letters (a-z)' },
|
|
74
|
+
{ type: 'info', content: 'At least 1 digit (0-9)' },
|
|
75
|
+
{ type: 'info', content: ' At least 1 special character (~`! …)' },
|
|
76
|
+
] },
|
|
77
|
+
fields: [
|
|
78
|
+
{ name: 'newPassword', type: 'password', required: true },
|
|
79
|
+
{ name: 'confirmPassword', type: 'password', required: true }
|
|
80
|
+
]
|
|
81
|
+
},
|
|
82
|
+
mode: 'edit',
|
|
83
|
+
buttons: [
|
|
84
|
+
{ name: 'edit', action: { method: 'post', url: 'User/changepassword-admin', successMessage: 'Password Changed' } }
|
|
85
|
+
]
|
|
86
|
+
};
|
|
87
|
+
this.usersTableConfig = {
|
|
88
|
+
showFilter: true,
|
|
89
|
+
minButtons: ['fullName', 'roleName'],
|
|
90
|
+
greyOut: (value) => value.disabled == 1,
|
|
91
|
+
collapseButtons: true,
|
|
92
|
+
minColumns: ['userName', 'fullName', 'roleName', 'locked', 'dateCreated'],
|
|
93
|
+
columns: [
|
|
94
|
+
{ name: 'userName', type: 'text' },
|
|
95
|
+
{ name: 'fullName', type: 'text' },
|
|
96
|
+
{ name: 'roleName', type: 'text' },
|
|
97
|
+
{ name: 'locked', type: 'checkbox' },
|
|
98
|
+
{ name: 'createdDate', type: 'date' },
|
|
99
|
+
],
|
|
100
|
+
buttons: [
|
|
101
|
+
{ name: 'create', display: 'New User', dialog: true, detailsConfig: this.createDialog },
|
|
102
|
+
{ name: 'view', dialog: true, icon: { name: 'account_circle' }, detailsConfig: this.editDialog },
|
|
103
|
+
{
|
|
104
|
+
name: 'changePassword', display: 'Change Password', tip: 'Change Password', icon: { name: 'key' }, dialog: true, detailsConfig: this.passwordDialog,
|
|
105
|
+
visible: x => x.authType === 'local'
|
|
106
|
+
},
|
|
107
|
+
{ name: 'lock', action: { method: 'post', url: 'User/lock', successMessage: "User locked" }, color: 'red', tip: 'lock', icon: { name: 'lock' },
|
|
108
|
+
visible: (value) => value.locked == 0
|
|
109
|
+
},
|
|
110
|
+
{ name: 'unlock', action: { method: 'post', url: 'User/unlock', successMessage: "User Unlocked" }, color: 'green', tip: 'unlock', icon: { name: 'lock_open' },
|
|
111
|
+
visible: (value) => value.locked == 1
|
|
112
|
+
},
|
|
113
|
+
{ name: 'delete', action: { method: 'post', url: 'User/delete', successMessage: "User Deleted" }, color: 'red' },
|
|
114
|
+
],
|
|
115
|
+
loadAction: { url: 'User/all/x' },
|
|
116
|
+
};
|
|
28
117
|
}
|
|
29
118
|
ngOnInit() {
|
|
30
119
|
this.authService.isAuthorised(this.dataService.capUsers.name);
|
|
31
|
-
this.
|
|
120
|
+
this.loadMeta();
|
|
32
121
|
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
this.usersRaw = apiResponse.data;
|
|
36
|
-
this.users = new MatTableDataSource(apiResponse.data);
|
|
37
|
-
this.users.paginator = this.usersPaginator;
|
|
38
|
-
this.applyFilter(this._filterText);
|
|
39
|
-
}, (error) => {
|
|
40
|
-
this.isProcessing = false;
|
|
41
|
-
this.messageService.toast(this.httpService.Error(error));
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
applyFilter(filterValue) {
|
|
45
|
-
this.users.filter = filterValue.trim().toLowerCase();
|
|
46
|
-
}
|
|
47
|
-
createAccount() {
|
|
48
|
-
this.router.navigate(["home/admin/create-account"]);
|
|
49
|
-
}
|
|
50
|
-
viewProfile(user) {
|
|
51
|
-
this.dataService.tmpProfileuserName = user.userName;
|
|
52
|
-
this.router.navigate(["home/user/profile"]);
|
|
53
|
-
}
|
|
54
|
-
lock(u) {
|
|
55
|
-
let login = { userName: u.userName, password: "Abcdef@123" };
|
|
56
|
-
this.dataService.LockUser(login).subscribe((apiResponse) => {
|
|
57
|
-
if (apiResponse.success) {
|
|
58
|
-
this.messageService.toast("User Locked");
|
|
59
|
-
this.UpdateData();
|
|
60
|
-
}
|
|
61
|
-
else {
|
|
62
|
-
this.messageService.toast("Error: " + apiResponse);
|
|
63
|
-
}
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
unlock(u) {
|
|
67
|
-
let login = { userName: u.userName, password: "Abcdef@123" };
|
|
68
|
-
this.dataService.UnlockUser(login).subscribe((apiResponse) => {
|
|
69
|
-
if (apiResponse.success) {
|
|
70
|
-
this.messageService.toast("User Unlocked");
|
|
71
|
-
this.UpdateData();
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
this.messageService.toast("Error: " + apiResponse);
|
|
75
|
-
}
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
recover(u) {
|
|
79
|
-
this.dataService.SelfReset(u).subscribe((apiResponse) => {
|
|
80
|
-
if (apiResponse.message == "success") {
|
|
81
|
-
this.messageService.toast("The password has been sent on email");
|
|
82
|
-
}
|
|
83
|
-
else {
|
|
84
|
-
this.messageService.toast("Error: " + apiResponse.message);
|
|
85
|
-
}
|
|
86
|
-
});
|
|
122
|
+
inputChanged(x) {
|
|
123
|
+
console.log(x);
|
|
87
124
|
}
|
|
88
|
-
|
|
89
|
-
this.
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
if (apiResponse.message == "success") {
|
|
95
|
-
this.messageService.toast("User Deleted");
|
|
96
|
-
this.UpdateData();
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
this.messageService.toast("Error: " + apiResponse.message);
|
|
100
|
-
}
|
|
101
|
-
}, (error) => {
|
|
102
|
-
this.messageService.toast("Connection failed ");
|
|
103
|
-
this.isProcessing = false;
|
|
104
|
-
});
|
|
105
|
-
}
|
|
125
|
+
loadMeta() {
|
|
126
|
+
this.dataService.CallApi({ url: 'role/meta/x' }).subscribe((apiResponse) => {
|
|
127
|
+
console.log(apiResponse.data);
|
|
128
|
+
this.userBaseFormConfig.fields.find(x => x.name == 'roleID').options = apiResponse.data.roles;
|
|
129
|
+
this.userBaseFormConfig.fields.find(x => x.name == 'authType').options = apiResponse.data.authTypes;
|
|
130
|
+
this.createDialog.formConfig.fields.find(x => x.name == 'authType').options = apiResponse.data.authTypes.filter(x => x.value == 'local' || x.value == 'AD');
|
|
106
131
|
});
|
|
107
132
|
}
|
|
108
133
|
}
|
|
109
134
|
UsersComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: UsersComponent, deps: [{ token: i1.HttpService }, { token: i2.Router }, { token: i3.AuthService }, { token: i4.DataServiceLib }, { token: i5.MatDialog }, { token: i6.MessageService }], target: i0.ɵɵFactoryTarget.Component });
|
|
110
|
-
UsersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: UsersComponent, selector: "spa-users",
|
|
135
|
+
UsersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: UsersComponent, selector: "spa-users", ngImport: i0, template: "\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<spa-table [config]=\"usersTableConfig\" (inputChange)=\"inputChanged($event)\"></spa-table>\r\n\r\n", styles: [".mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.refreshIcon{font-size:22px!important;margin-top:-7px!important}.make-gray{background-color:#d3d3d3}\n"], dependencies: [{ kind: "component", type: i7.TableComponent, selector: "spa-table", inputs: ["hideTitle", "data", "tileData", "config", "reload"], outputs: ["dataLoad", "refreshClick", "searchClick", "createClick", "actionClick", "inputChange", "actionResponse"] }] });
|
|
111
136
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: UsersComponent, decorators: [{
|
|
112
137
|
type: Component,
|
|
113
|
-
args: [{ selector: "spa-users", template: "\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<
|
|
114
|
-
}], ctorParameters: function () { return [{ type: i1.HttpService }, { type: i2.Router }, { type: i3.AuthService }, { type: i4.DataServiceLib }, { type: i5.MatDialog }, { type: i6.MessageService }]; }
|
|
115
|
-
type: ViewChild,
|
|
116
|
-
args: ["usersPaginator"]
|
|
117
|
-
}] } });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/pages/users/users.component.ts","../../../../../../projects/tin-spa/src/lib/pages/users/users.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject, ViewChild } from \"@angular/core\";\r\nimport { MatTableDataSource } from \"@angular/material/table\";\r\nimport { MatPaginator } from \"@angular/material/paginator\";\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from \"@angular/material/dialog\";\r\nimport { DataServiceLib } from \"../../services/datalib.service\";\r\nimport { Router } from \"@angular/router\";\r\nimport { MessageService } from \"../../services/message.service\";\r\nimport { AuthService } from \"../../services/auth.service\";\r\nimport { TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { HttpService } from \"../../services/http.service\";\r\nimport { User } from \"../../classes/LibClasses\";\r\n\r\n@Component({\r\n  selector: \"spa-users\",\r\n  templateUrl: \"./users.component.html\",\r\n  styleUrls: [\"./users.component.css\"],\r\n})\r\nexport class UsersComponent implements OnInit {\r\n  constructor(private httpService: HttpService, public router: Router, private authService: AuthService, private dataService: DataServiceLib, public dialog: MatDialog, private messageService: MessageService) { }\r\n\r\n  ngOnInit() {\r\n    this.authService.isAuthorised(this.dataService.capUsers.name);\r\n    this.UpdateData();\r\n  }\r\n\r\n  isProcessing: boolean = false;\r\n  @ViewChild(\"usersPaginator\") usersPaginator: MatPaginator;\r\n\r\n  _filterText = \"\";\r\n\r\n  users;\r\n  usersRaw;\r\n  displayedColumns: string[] = [\"userName\", \"fullName\", \"roleName\", \"locked\", \"dateCreated\", \"Action\"];\r\n\r\n  public UpdateData() {\r\n    this.dataService.GetUser().subscribe(\r\n      (apiResponse) => {\r\n\r\n        this.usersRaw = apiResponse.data;\r\n        this.users = new MatTableDataSource(apiResponse.data);\r\n        this.users.paginator = this.usersPaginator;\r\n        this.applyFilter(this._filterText);\r\n\r\n      },\r\n      (error) => {\r\n        this.isProcessing = false;\r\n        this.messageService.toast(this.httpService.Error(error));\r\n      }\r\n    );\r\n  }\r\n\r\n  applyFilter(filterValue: string) {\r\n    this.users.filter = filterValue.trim().toLowerCase();\r\n  }\r\n\r\n  createAccount() {\r\n    this.router.navigate([\"home/admin/create-account\"]);\r\n  }\r\n\r\n  viewProfile(user: User) {\r\n\r\n    this.dataService.tmpProfileuserName = user.userName;\r\n    this.router.navigate([\"home/user/profile\"]);\r\n\r\n  }\r\n\r\n  lock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.LockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Locked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  unlock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.UnlockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Unlocked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  recover(u: User) {\r\n    this.dataService.SelfReset(u).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.message == \"success\") {\r\n        this.messageService.toast(\"The password has been sent on email\");\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  deleteUser(user: User) {\r\n\r\n\r\n\r\n    this.messageService.confirm(`Delete ${user.userName} ?`).subscribe((result) => {\r\n\r\n      if (result == \"yes\") {\r\n\r\n        this.isProcessing = true;\r\n        this.dataService.DeleteUser(user).subscribe(\r\n          (apiResponse: ApiResponse) => {\r\n            this.isProcessing = false;\r\n\r\n            if (apiResponse.message == \"success\") {\r\n              this.messageService.toast(\"User Deleted\");\r\n\r\n              this.UpdateData();\r\n\r\n            } else {\r\n              this.messageService.toast(\"Error: \" + apiResponse.message);\r\n            }\r\n          },\r\n          (error) => {\r\n            this.messageService.toast(\"Connection failed \");\r\n            this.isProcessing = false;\r\n          }\r\n        );\r\n\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n\r\n  //----------------------------------------\r\n\r\n  // config: TableConfig = {\r\n  //   showFilter: true,\r\n  //   newText: \"Create Account\",\r\n  //   minColumns: ['firstName', 'lastName', 'roleID'],\r\n\r\n  //   columns: [\r\n  //     { name: 'userName', type: 'text', icon: { name: 'person', color: 'green', tip: 'name desc' } },\r\n  //     { name: 'firstName', type: 'text',},\r\n  //     { name: 'lastName', type: 'text' },\r\n  //     { name: 'roleID', type: 'text' },\r\n  //     { name: 'locked', type: 'checkbox' },\r\n  //     { name: 'createdDate', type: 'date' },\r\n  //   ],\r\n\r\n  //   buttons: [\r\n  //     { name:'create', display:'Create Account', dialog: true },\r\n  //     { name: 'view', dialog: true, icon: { name: 'account_circle'} },\r\n  //     { name: 'custom1', action: { method: 'post', url: 'User/lock', successMessage: \"User locked\" }, color:'red', tip:'lock', icon: { name: 'lock'}, visible: (value) => value.locked == 0},\r\n  //     { name: 'custom2', action: { method: 'post', url: 'User/unlock', successMessage: \"User Unlocked\" }, color: 'green', tip: 'unlock', icon: { name: 'lock_open' }, visible: (value) => value.locked == 1 },\r\n  //     { name: 'delete' },\r\n  //   ],\r\n\r\n  //   loadAction: { url: 'User/all/x' }\r\n\r\n  // }\r\n\r\n}\r\n\r\n\r\n\r\n","\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<div class=\"container-fluid\" style=\"font-size: 14px;\">\r\n\r\n  <div class=\"row justify-content-between\" style=\"padding-bottom: 10px\">\r\n    <div class=\"col-2\">\r\n      <button id=\"btnCreateAccount\" mat-raised-button color=\"primary\" (click)=\"createAccount()\">Create User</button>\r\n    </div>\r\n\r\n    <div class=\"d-flex justify-content-end\">\r\n      <spa-filter [data]=\"users\" (refreshClick)=\"UpdateData()\"></spa-filter>\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p *ngIf=\"!users\"><em>Loading...</em></p>\r\n\r\n\r\n  <div class=\"mat-elevation-z8\" *ngIf=\"users\">\r\n\r\n    <table id=\"tblTable\" mat-table [dataSource]=\"users\">\r\n\r\n      <ng-container matColumnDef=\"userName\">\r\n        <th mat-header-cell *matHeaderCellDef> UserName </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.userName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"locked\">\r\n        <th mat-header-cell *matHeaderCellDef> Locked </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.locked}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"fullName\">\r\n        <th mat-header-cell *matHeaderCellDef> Name </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.firstName}} {{user.lastName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"roleName\">\r\n        <th mat-header-cell *matHeaderCellDef> Role </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.role.roleName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"disabled\">\r\n        <th mat-header-cell *matHeaderCellDef> Disabled </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.disabled}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateCreated\">\r\n        <th mat-header-cell *matHeaderCellDef> Created </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.createdDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateUpdated\">\r\n        <th mat-header-cell *matHeaderCellDef> Updated </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.updatedDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n\r\n      <ng-container matColumnDef=\"Action\">\r\n        <th mat-header-cell *matHeaderCellDef> Action </th>\r\n        <td mat-cell *matCellDef=\"let user\" style=\"width: 250px;\">\r\n\r\n          <button mat-mini-fab color=\"primary\" (click)=\"viewProfile(user)\" style=\"margin-right:30px\" matTooltip=\"View Profile\" matTooltipPosition=\"above\"> <mat-icon>account_circle</mat-icon></button>\r\n\r\n          <button *ngIf=\"user.locked=='0'\" mat-mini-fab color=\"warn\" (click)=\"lock(user)\" style=\"margin-right:10px\" matTooltip=\"Lock\" matTooltipPosition=\"above\"> <mat-icon>lock</mat-icon></button>\r\n          <button *ngIf=\"user.locked=='1'\" mat-mini-fab  (click)=\"unlock(user)\" style=\"margin-right:10px; background-color: green;\" matTooltip=\"Unlock\" matTooltipPosition=\"above\"> <mat-icon >lock_open</mat-icon></button>\r\n\r\n          <!-- <button *ngIf=\"user.disabled=='0'\" mat-mini-fab color=\"warn\" (click)=\"disable(user)\" style=\"margin-right:10px\" matTooltip=\"Disable\" matTooltipPosition=\"above\"> <mat-icon>block</mat-icon></button>\r\n          <button *ngIf=\"user.disabled=='1'\" mat-mini-fab (click)=\"enable(user)\" style=\"margin-right:10px; background-color: green\" matTooltip=\"Enable\" matTooltipPosition=\"above\"> <mat-icon>done</mat-icon></button> -->\r\n\r\n          <button mat-mini-fab color=\"warn\" (click)=\"deleteUser(user)\" style=\"margin-right:10px\" matTooltip=\"Delete\" matTooltipPosition=\"above\"> <mat-icon>delete</mat-icon></button>\r\n          <!-- <button mat-mini-fab color=\"primary\" (click)=\"recover(user)\" style=\"margin-right:10px\" matTooltip=\"Reset Password\" matTooltipPosition=\"above\"> <mat-icon>vpn_key</mat-icon></button> -->\r\n\r\n\r\n\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': row.disabled =='1'}\"></tr>\r\n\r\n    </table>\r\n\r\n  </div>\r\n\r\n  <mat-paginator #usersPaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n</div>\r\n\r\n<!-- ------------------ -->\r\n\r\n<!-- <div class=\"container mt-5\" style=\" font-size: 14px;\">\r\n<spa-table  [data]=\"usersRaw\" [config]=\"config\" (refreshClick)=\"UpdateData()\" (viewClick)=\"viewProfile($event)\" (createClick)=\"createAccount()\" (deleteClick)=\"deleteUser($event)\"></spa-table>\r\n</div> -->\r\n\r\n"]}
|
|
138
|
+
args: [{ selector: "spa-users", template: "\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<spa-table [config]=\"usersTableConfig\" (inputChange)=\"inputChanged($event)\"></spa-table>\r\n\r\n", styles: [".mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.refreshIcon{font-size:22px!important;margin-top:-7px!important}.make-gray{background-color:#d3d3d3}\n"] }]
|
|
139
|
+
}], ctorParameters: function () { return [{ type: i1.HttpService }, { type: i2.Router }, { type: i3.AuthService }, { type: i4.DataServiceLib }, { type: i5.MatDialog }, { type: i6.MessageService }]; } });
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/pages/users/users.component.ts","../../../../../../projects/tin-spa/src/lib/pages/users/users.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject, ViewChild } from \"@angular/core\";\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from \"@angular/material/dialog\";\r\nimport { DataServiceLib } from \"../../services/datalib.service\";\r\nimport { Router } from \"@angular/router\";\r\nimport { MessageService } from \"../../services/message.service\";\r\nimport { AuthService } from \"../../services/auth.service\";\r\nimport { TableConfig, ApiResponse, FormConfig, Button, DetailsDialogConfig } from '../../classes/Classes';\r\nimport { HttpService } from \"../../services/http.service\";\r\nimport { User } from \"../../classes/LibClasses\";\r\n\r\n@Component({\r\n  selector: \"spa-users\",\r\n  templateUrl: \"./users.component.html\",\r\n  styleUrls: [\"./users.component.css\"],\r\n})\r\n\r\nexport class UsersComponent implements OnInit {\r\n  constructor(private httpService: HttpService, public router: Router, private authService: AuthService, private dataService: DataServiceLib, public dialog: MatDialog, private messageService: MessageService) { }\r\n\r\n  ngOnInit() {\r\n    this.authService.isAuthorised(this.dataService.capUsers.name);\r\n    this.loadMeta()\r\n  }\r\n\r\n\r\n  inputChanged(x) {\r\n    console.log(x);\r\n\r\n  }\r\n\r\n  loadMeta(){\r\n    this.dataService.CallApi({ url: 'role/meta/x' }).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      console.log(apiResponse.data);\r\n      this.userBaseFormConfig.fields.find(x => x.name == 'roleID').options = apiResponse.data.roles;\r\n      this.userBaseFormConfig.fields.find(x => x.name == 'authType').options = apiResponse.data.authTypes;\r\n      this.createDialog.formConfig.fields.find(x => x.name == 'authType').options = apiResponse.data.authTypes.filter(x => x.value == 'local' || x.value == 'AD');\r\n    })\r\n  }\r\n\r\n\r\n  userBaseFormConfig: FormConfig = {\r\n    fields: [\r\n      { name: 'userName', type: 'text', alias: 'Username', required: true, span : true, readonly : true },\r\n      { name: 'authType', type: 'select', alias: 'Authentication Type', readonly: true, span: true, required: true, defaultFirstValue: true },\r\n      {\r\n        name: 'firstName', type: 'text', required: true,\r\n        readonlyCondition: x => x.authType !== 'local',\r\n      },\r\n      {\r\n        name: 'lastName', type: 'text', required: true,\r\n        readonlyCondition: x => x.authType !== 'local',\r\n      },\r\n      {\r\n        name: 'password', type: 'password', required: true,\r\n        hiddenCondition: x => x.authType !== 'local', span: true,\r\n      },\r\n      {\r\n        name: 'confirmPassword', type: 'password', required: true,\r\n        hiddenCondition: x => x.authType !== 'local', span: true\r\n      },\r\n      { name: 'email', type: 'text', required: false, span: true },\r\n      { name: 'roleID', type: 'select', alias: 'Role', required: true,  span: true, defaultFirstValue: true },\r\n    ],\r\n  };\r\n\r\n\r\n  createDialog: DetailsDialogConfig = {\r\n    formConfig: {\r\n      ...this.userBaseFormConfig,\r\n      title: 'User',\r\n      // fields: this.userBaseFormConfig.fields.filter(x => x.name !== 'userName' && x.name !== 'authType' && x.name !== 'email')\r\n    },\r\n    mode: 'create',\r\n    buttons: [\r\n      { name: 'create', action: { method: 'post', url: 'User/register', successMessage: \"User Created\" }}\r\n    ]\r\n  }\r\n\r\n  editDialog : DetailsDialogConfig = {\r\n    formConfig: {\r\n      ...this.userBaseFormConfig,\r\n      title : 'User',\r\n      fields : this.userBaseFormConfig.fields.filter(x => x.name !== 'password' && x.name !== 'confirmPassword')\r\n    },\r\n    mode: 'view',\r\n    buttons: [\r\n      { name: 'edit', action: { method: 'post', url: 'User/edit', successMessage: \"User Updated\" } }\r\n    ]\r\n  }\r\n\r\n  passwordDialog: DetailsDialogConfig = {\r\n    formConfig: {\r\n      ...this.userBaseFormConfig,\r\n      title : 'Change Password',\r\n      fixedTitle: true,\r\n      alertMessages: { messages: [\r\n        { type: 'info', content: '*Please consider these requirements for your new password.' },\r\n        { type: 'info', content: 'At least 8 characters.' },\r\n        { type: 'info', content: 'At least 1 uppercase letter' },\r\n        { type: 'info', content: 'At least 2 lowercase letters (a-z)' },\r\n        { type: 'info', content: 'At least 1 digit (0-9)' },\r\n        { type: 'info', content: ' At least 1 special character (~`! …)' },\r\n      ]},\r\n      fields: [\r\n        { name: 'newPassword', type: 'password', required: true },\r\n        { name: 'confirmPassword', type: 'password',  required: true }\r\n      ]\r\n    },\r\n    mode: 'edit',\r\n    buttons: [\r\n      { name: 'edit', action: { method: 'post', url: 'User/changepassword-admin', successMessage: 'Password Changed' }    }\r\n    ]\r\n  }\r\n\r\n  usersTableConfig : TableConfig = {\r\n    showFilter: true,\r\n    minButtons: ['fullName','roleName'],\r\n    greyOut : (value) => value.disabled == 1,\r\n    collapseButtons: true,\r\n    minColumns: ['userName', 'fullName', 'roleName', 'locked', 'dateCreated'],\r\n    columns: [\r\n      { name: 'userName', type: 'text'},\r\n      { name: 'fullName', type: 'text' },\r\n      { name: 'roleName', type: 'text' },\r\n      { name: 'locked', type: 'checkbox' },\r\n      { name: 'createdDate', type: 'date' },\r\n    ],\r\n    buttons: [\r\n      { name: 'create', display: 'New User', dialog: true, detailsConfig : this.createDialog  },\r\n      { name: 'view', dialog: true, icon: { name: 'account_circle' }, detailsConfig: this.editDialog },\r\n      {\r\n        name: 'changePassword', display: 'Change Password', tip : 'Change Password', icon: { name: 'key' }, dialog: true, detailsConfig: this.passwordDialog,\r\n        visible: x => x.authType === 'local'\r\n      },\r\n      { name: 'lock', action: { method: 'post', url: 'User/lock', successMessage: \"User locked\" }, color: 'red', tip: 'lock', icon: { name: 'lock' },\r\n        visible: (value) => value.locked == 0\r\n      },\r\n      { name: 'unlock', action: { method: 'post', url: 'User/unlock', successMessage: \"User Unlocked\" }, color: 'green', tip: 'unlock', icon: { name: 'lock_open' },\r\n        visible: (value) => value.locked == 1\r\n      },\r\n      { name: 'delete', action: { method: 'post', url: 'User/delete', successMessage: \"User Deleted\" }, color: 'red' },\r\n    ],\r\n    loadAction: { url: 'User/all/x' },\r\n  }\r\n\r\n\r\n}\r\n","\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<spa-table [config]=\"usersTableConfig\" (inputChange)=\"inputChanged($event)\"></spa-table>\r\n\r\n"]}
|
|
@@ -26,10 +26,10 @@ export class WelcomeComponent {
|
|
|
26
26
|
{ name: 'owner', type: 'text', },
|
|
27
27
|
],
|
|
28
28
|
buttons: [
|
|
29
|
-
{ name: 'accept', icon: { 'name': 'done', }, color: 'green', action: { url: '
|
|
30
|
-
{ name: 'decline', icon: { 'name': 'close', }, color: 'red', action: { url: '
|
|
29
|
+
{ name: 'accept', icon: { 'name': 'done', }, color: 'green', action: { url: 'members/dto?action=accept', method: 'post', }, confirm: { message: 'Accept ?' }, disabled: (x) => x.accepted },
|
|
30
|
+
{ name: 'decline', icon: { 'name': 'close', }, color: 'red', action: { url: 'members/dto?action=remove', method: 'post', }, confirm: { message: 'Decline ?' }, disabled: (x) => x.accepted },
|
|
31
31
|
],
|
|
32
|
-
loadAction: { url: '
|
|
32
|
+
loadAction: { url: 'tenants/invitations/x' },
|
|
33
33
|
};
|
|
34
34
|
}
|
|
35
35
|
ngOnInit() {
|
|
@@ -37,14 +37,14 @@ export class WelcomeComponent {
|
|
|
37
37
|
this.authService.loggedUserFullName.subscribe(x => this.username = x);
|
|
38
38
|
}
|
|
39
39
|
loadMeta() {
|
|
40
|
-
this.dataService.CallApi({ url: '
|
|
40
|
+
this.dataService.CallApi({ url: 'tenants/welcome_meta/x' }).subscribe((api) => {
|
|
41
41
|
this.invitations = api.data.invitations;
|
|
42
42
|
this.own = api.data.own;
|
|
43
43
|
this.myTenant = api.data.tenant;
|
|
44
44
|
});
|
|
45
45
|
}
|
|
46
46
|
renameTenant() {
|
|
47
|
-
this.dataService.CallApi({ url: '
|
|
47
|
+
this.dataService.CallApi({ url: 'tenants/dto?action=rename', method: 'post' }, this.myTenant).subscribe((apiResponse) => {
|
|
48
48
|
if (apiResponse.success) {
|
|
49
49
|
this.authService.updateTenantName(this.myTenant.name);
|
|
50
50
|
}
|
|
@@ -69,7 +69,7 @@ export class WelcomeComponent {
|
|
|
69
69
|
this.setWelcome();
|
|
70
70
|
}
|
|
71
71
|
setWelcome() {
|
|
72
|
-
this.dataService.CallApi({ url: '
|
|
72
|
+
this.dataService.CallApi({ url: 'tenants/set_welcome/x' }).subscribe((api) => {
|
|
73
73
|
this.home();
|
|
74
74
|
});
|
|
75
75
|
}
|
|
@@ -78,9 +78,9 @@ export class WelcomeComponent {
|
|
|
78
78
|
}
|
|
79
79
|
}
|
|
80
80
|
WelcomeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: WelcomeComponent, deps: [{ token: i1.DataServiceLib }, { token: i2.AuthService }], target: i0.ɵɵFactoryTarget.Component });
|
|
81
|
-
WelcomeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: WelcomeComponent, selector: "spa-welcome", ngImport: i0, template: "<label class=\"title\">Welcome, {{username}}</label>\n\n\n\n<!-- terms -->\n<div class=\"mt-3\" *ngIf=\"step=='terms'\">\n\n <label class=\"subtitle text-muted mb-2\" >We care about our users and are dedicated to protecting your data and privacy -\n thats why we want to be clear about what data we collect and how we use it to improve your experience.</label>\n\n <br>\n <spa-check display=\"I agree to the Terms and Privacy Policy\" [(value)]=\"agree\"></spa-check>\n</div>\n\n<!-- owner -->\n<div class=\"mt-3\" *ngIf=\"step=='name' && own\">\n\n <label class=\"subtitle text-muted\" style=\" margin-bottom: 20px;\">The follow steps will guide you to customise your application.</label>\n\n <div style=\"max-width: 400px;\">\n <spa-text display=\"Organisation Name\" [(value)]=\"myTenant.name\" ></spa-text>\n </div>\n\n <label class=\"text-muted\" style=\" font-size: 12px;\">You can change the Organisation's name to your team or company name.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">The name can be changed later.</label>\n\n</div>\n\n<!-- guest -->\n<div *ngIf=\"step=='hi' && !own\">\n <label class=\"subtitle text-muted\">You are now signed in to {{myTenant.name}}.</label>\n</div>\n\n\n<!-- invitations -->\n<div class=\"mt-3\" *ngIf=\"step=='invitations' && own\">\n\n <label class=\"subtitle text-muted\">You have been requested to join the following organisations. If you accept, you have the option to switch to that org now or stay in you org.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">You will be able to switch later.</label>\n <spa-invitations-table></spa-invitations-table>\n\n</div>\n\n\n<!-- Actions -->\n<div class=\"mt-3\">\n <button mat-stroked-button color=\"primary\" [disabled]=\"!agree\" (click)=\"next()\">Next <mat-icon>arrow_right_alt</mat-icon></button>\n</div>\n", styles: [".title{margin-top:1em;font-size:28px;font-weight:300}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.TextComponent, selector: "spa-text", inputs: ["readonly", "hint", "display", "placeholder", "value", "format", "type", "rows", "width", "copyContent", "options", "optionValue", "required", "min", "max", "regex", "suffix", "infoMessage"], outputs: ["valueChange", "leave", "enterPress"
|
|
81
|
+
WelcomeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: WelcomeComponent, selector: "spa-welcome", ngImport: i0, template: "<label class=\"title\">Welcome, {{username}}</label>\n\n\n\n<!-- terms -->\n<div class=\"mt-3\" *ngIf=\"step=='terms'\">\n\n <label class=\"subtitle text-muted mb-2\" >We care about our users and are dedicated to protecting your data and privacy -\n thats why we want to be clear about what data we collect and how we use it to improve your experience.</label>\n\n <br>\n <spa-check display=\"I agree to the Terms and Privacy Policy\" [(value)]=\"agree\"></spa-check>\n</div>\n\n<!-- owner -->\n<div class=\"mt-3\" *ngIf=\"step=='name' && own\">\n\n <label class=\"subtitle text-muted\" style=\" margin-bottom: 20px;\">The follow steps will guide you to customise your application.</label>\n\n <div style=\"max-width: 400px;\">\n <spa-text display=\"Organisation Name\" [(value)]=\"myTenant.name\" ></spa-text>\n </div>\n\n <label class=\"text-muted\" style=\" font-size: 12px;\">You can change the Organisation's name to your team or company name.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">The name can be changed later.</label>\n\n</div>\n\n<!-- guest -->\n<div *ngIf=\"step=='hi' && !own\">\n <label class=\"subtitle text-muted\">You are now signed in to {{myTenant.name}}.</label>\n</div>\n\n\n<!-- invitations -->\n<div class=\"mt-3\" *ngIf=\"step=='invitations' && own\">\n\n <label class=\"subtitle text-muted\">You have been requested to join the following organisations. If you accept, you have the option to switch to that org now or stay in you org.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">You will be able to switch later.</label>\n <spa-invitations-table></spa-invitations-table>\n\n</div>\n\n\n<!-- Actions -->\n<div class=\"mt-3\">\n <button mat-stroked-button color=\"primary\" [disabled]=\"!agree\" (click)=\"next()\">Next <mat-icon>arrow_right_alt</mat-icon></button>\n</div>\n", styles: [".title{margin-top:1em;font-size:28px;font-weight:300}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.TextComponent, selector: "spa-text", inputs: ["readonly", "hint", "display", "placeholder", "value", "format", "type", "rows", "width", "copyContent", "clearContent", "options", "optionValue", "required", "min", "max", "regex", "suffix", "infoMessage"], outputs: ["valueChange", "leave", "enterPress"] }, { kind: "component", type: i7.CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value", "infoMessage"], outputs: ["valueChange", "click", "check", "uncheck", "infoClick"] }, { kind: "component", type: i8.InvitationsTableComponent, selector: "spa-invitations-table" }] });
|
|
82
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: WelcomeComponent, decorators: [{
|
|
83
83
|
type: Component,
|
|
84
84
|
args: [{ selector: 'spa-welcome', template: "<label class=\"title\">Welcome, {{username}}</label>\n\n\n\n<!-- terms -->\n<div class=\"mt-3\" *ngIf=\"step=='terms'\">\n\n <label class=\"subtitle text-muted mb-2\" >We care about our users and are dedicated to protecting your data and privacy -\n thats why we want to be clear about what data we collect and how we use it to improve your experience.</label>\n\n <br>\n <spa-check display=\"I agree to the Terms and Privacy Policy\" [(value)]=\"agree\"></spa-check>\n</div>\n\n<!-- owner -->\n<div class=\"mt-3\" *ngIf=\"step=='name' && own\">\n\n <label class=\"subtitle text-muted\" style=\" margin-bottom: 20px;\">The follow steps will guide you to customise your application.</label>\n\n <div style=\"max-width: 400px;\">\n <spa-text display=\"Organisation Name\" [(value)]=\"myTenant.name\" ></spa-text>\n </div>\n\n <label class=\"text-muted\" style=\" font-size: 12px;\">You can change the Organisation's name to your team or company name.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">The name can be changed later.</label>\n\n</div>\n\n<!-- guest -->\n<div *ngIf=\"step=='hi' && !own\">\n <label class=\"subtitle text-muted\">You are now signed in to {{myTenant.name}}.</label>\n</div>\n\n\n<!-- invitations -->\n<div class=\"mt-3\" *ngIf=\"step=='invitations' && own\">\n\n <label class=\"subtitle text-muted\">You have been requested to join the following organisations. If you accept, you have the option to switch to that org now or stay in you org.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">You will be able to switch later.</label>\n <spa-invitations-table></spa-invitations-table>\n\n</div>\n\n\n<!-- Actions -->\n<div class=\"mt-3\">\n <button mat-stroked-button color=\"primary\" [disabled]=\"!agree\" (click)=\"next()\">Next <mat-icon>arrow_right_alt</mat-icon></button>\n</div>\n", styles: [".title{margin-top:1em;font-size:28px;font-weight:300}\n"] }]
|
|
85
85
|
}], ctorParameters: function () { return [{ type: i1.DataServiceLib }, { type: i2.AuthService }]; } });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"welcome.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/pages/welcome/welcome.component.ts","../../../../../../projects/tin-spa/src/lib/pages/welcome/welcome.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\n\r\n@Component({\r\n  selector: 'spa-welcome',\r\n  templateUrl: './welcome.component.html',\r\n  styleUrls: ['./welcome.component.css']\r\n})\r\nexport class WelcomeComponent implements OnInit {\r\n\r\n  constructor(public dataService : DataServiceLib, public authService: AuthService) { }\r\n\r\n  ngOnInit(): void {\r\n    this.loadMeta();\r\n\r\n    this.authService.loggedUserFullName.subscribe(x => this.username = x)\r\n  }\r\n\r\n  username;\r\n\r\n  step = \"terms\"\r\n  agree = false\r\n  own = true;\r\n  invitations = false;\r\n\r\n  myTenant\r\n\r\n  loadMeta(){\r\n    this.dataService.CallApi({ url:'tenant/welcome_meta/x'}).subscribe((api) => {\r\n      this.invitations = api.data.invitations;\r\n      this.own = api.data.own;\r\n      this.myTenant = api.data.tenant;\r\n    })\r\n  }\r\n\r\n  renameTenant() {\r\n\r\n    this.dataService.CallApi({ url: 'tenant/tenants?action=rename', method: 'post' }, this.myTenant).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.authService.updateTenantName(this.myTenant.name)\r\n      }\r\n    });\r\n  }\r\n\r\n  next(){\r\n\r\n    if (this.step == 'terms' && this.own){\r\n      this.step = \"name\"\r\n      return;\r\n    }\r\n    else if (this.step == \"terms\" && !this.own) {\r\n      this.step = \"hi\"\r\n      return;\r\n    }\r\n    else if (this.step == \"name\" && this.own){\r\n\r\n      this.renameTenant();\r\n      if (this.invitations == true){\r\n        this.step = \"invitations\"\r\n        return;\r\n      }\r\n\r\n\r\n    }\r\n\r\n\r\n    this.setWelcome();\r\n  }\r\n\r\n  setWelcome() {\r\n    this.dataService.CallApi({ url: 'tenant/set_welcome/x' }).subscribe((api) => {\r\n      this.home();\r\n    })\r\n  }\r\n\r\n  home(){\r\n    this.dataService.Navigate('home');\r\n  }\r\n\r\n\r\n  invTableConfig: TableConfig = {\r\n\r\n    greyOut: (value) => value.accepted == false,\r\n    elevation: 'low',\r\n    minColumns: ['tenantName'],\r\n    minButtons: ['accept', 'decline'],\r\n\r\n    columns: [\r\n      { name: 'tenantName', alias: 'Organisation', type: 'text' },\r\n      { name: 'owner', type: 'text', },\r\n    ],\r\n\r\n    buttons: [\r\n      { name: 'accept', icon: { 'name': 'done', }, color: 'green', action: { url: 'tenant/members?action=accept', method: 'post', }, confirm: { message: 'Accept ?' }, disabled: (x) => x.accepted },\r\n      { name: 'decline', icon: { 'name': 'close', }, color: 'red', action: { url: 'tenant/members?action=remove', method: 'post', }, confirm: { message: 'Decline ?' }, disabled: (x) => x.accepted },\r\n    ],\r\n\r\n    loadAction: { url: 'tenant/invitations/x' },\r\n\r\n  }\r\n\r\n}\r\n","<label class=\"title\">Welcome,  {{username}}</label>\n\n\n\n<!-- terms -->\n<div class=\"mt-3\" *ngIf=\"step=='terms'\">\n\n  <label class=\"subtitle text-muted mb-2\" >We care about our users and are dedicated to protecting your data and privacy -\n    thats why we want to be clear about what data we collect and how we use it to improve your experience.</label>\n\n  <br>\n  <spa-check display=\"I agree to the Terms and Privacy Policy\" [(value)]=\"agree\"></spa-check>\n</div>\n\n<!-- owner -->\n<div class=\"mt-3\" *ngIf=\"step=='name' && own\">\n\n  <label class=\"subtitle text-muted\" style=\" margin-bottom: 20px;\">The follow steps will guide you to customise your application.</label>\n\n  <div style=\"max-width: 400px;\">\n   <spa-text display=\"Organisation Name\" [(value)]=\"myTenant.name\" ></spa-text>\n  </div>\n\n  <label class=\"text-muted\" style=\" font-size: 12px;\">You can change the Organisation's name to your team or company name.</label><br>\n  <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">The name can be changed later.</label>\n\n</div>\n\n<!-- guest -->\n<div *ngIf=\"step=='hi' && !own\">\n  <label class=\"subtitle text-muted\">You are now signed in to {{myTenant.name}}.</label>\n</div>\n\n\n<!-- invitations -->\n<div class=\"mt-3\" *ngIf=\"step=='invitations' && own\">\n\n  <label class=\"subtitle text-muted\">You have been requested to join the following organisations. If you accept, you have the option to switch to that org now or stay in you org.</label><br>\n  <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">You will be able to switch later.</label>\n  <spa-invitations-table></spa-invitations-table>\n\n</div>\n\n\n<!-- Actions -->\n<div class=\"mt-3\">\n  <button  mat-stroked-button color=\"primary\" [disabled]=\"!agree\" (click)=\"next()\">Next <mat-icon>arrow_right_alt</mat-icon></button>\n</div>\n"]}
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"welcome.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/pages/welcome/welcome.component.ts","../../../../../../projects/tin-spa/src/lib/pages/welcome/welcome.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\n\r\n@Component({\r\n  selector: 'spa-welcome',\r\n  templateUrl: './welcome.component.html',\r\n  styleUrls: ['./welcome.component.css']\r\n})\r\nexport class WelcomeComponent implements OnInit {\r\n\r\n  constructor(public dataService : DataServiceLib, public authService: AuthService) { }\r\n\r\n  ngOnInit(): void {\r\n    this.loadMeta();\r\n\r\n    this.authService.loggedUserFullName.subscribe(x => this.username = x)\r\n  }\r\n\r\n  username;\r\n\r\n  step = \"terms\"\r\n  agree = false\r\n  own = true;\r\n  invitations = false;\r\n\r\n  myTenant\r\n\r\n  loadMeta(){\r\n    this.dataService.CallApi({ url:'tenants/welcome_meta/x'}).subscribe((api) => {\r\n      this.invitations = api.data.invitations;\r\n      this.own = api.data.own;\r\n      this.myTenant = api.data.tenant;\r\n    })\r\n  }\r\n\r\n  renameTenant() {\r\n\r\n    this.dataService.CallApi({ url: 'tenants/dto?action=rename', method: 'post' }, this.myTenant).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.authService.updateTenantName(this.myTenant.name)\r\n      }\r\n    });\r\n  }\r\n\r\n  next(){\r\n\r\n    if (this.step == 'terms' && this.own){\r\n      this.step = \"name\"\r\n      return;\r\n    }\r\n    else if (this.step == \"terms\" && !this.own) {\r\n      this.step = \"hi\"\r\n      return;\r\n    }\r\n    else if (this.step == \"name\" && this.own){\r\n\r\n      this.renameTenant();\r\n      if (this.invitations == true){\r\n        this.step = \"invitations\"\r\n        return;\r\n      }\r\n\r\n\r\n    }\r\n\r\n\r\n    this.setWelcome();\r\n  }\r\n\r\n  setWelcome() {\r\n    this.dataService.CallApi({ url: 'tenants/set_welcome/x' }).subscribe((api) => {\r\n      this.home();\r\n    })\r\n  }\r\n\r\n  home(){\r\n    this.dataService.Navigate('home');\r\n  }\r\n\r\n\r\n  invTableConfig: TableConfig = {\r\n\r\n    greyOut: (value) => value.accepted == false,\r\n    elevation: 'low',\r\n    minColumns: ['tenantName'],\r\n    minButtons: ['accept', 'decline'],\r\n\r\n    columns: [\r\n      { name: 'tenantName', alias: 'Organisation', type: 'text' },\r\n      { name: 'owner', type: 'text', },\r\n    ],\r\n\r\n    buttons: [\r\n      { name: 'accept', icon: { 'name': 'done', }, color: 'green', action: { url: 'members/dto?action=accept', method: 'post', }, confirm: { message: 'Accept ?' }, disabled: (x) => x.accepted },\r\n      { name: 'decline', icon: { 'name': 'close', }, color: 'red', action: { url: 'members/dto?action=remove', method: 'post', }, confirm: { message: 'Decline ?' }, disabled: (x) => x.accepted },\r\n    ],\r\n\r\n    loadAction: { url: 'tenants/invitations/x' },\r\n\r\n  }\r\n\r\n}\r\n","<label class=\"title\">Welcome,  {{username}}</label>\n\n\n\n<!-- terms -->\n<div class=\"mt-3\" *ngIf=\"step=='terms'\">\n\n  <label class=\"subtitle text-muted mb-2\" >We care about our users and are dedicated to protecting your data and privacy -\n    thats why we want to be clear about what data we collect and how we use it to improve your experience.</label>\n\n  <br>\n  <spa-check display=\"I agree to the Terms and Privacy Policy\" [(value)]=\"agree\"></spa-check>\n</div>\n\n<!-- owner -->\n<div class=\"mt-3\" *ngIf=\"step=='name' && own\">\n\n  <label class=\"subtitle text-muted\" style=\" margin-bottom: 20px;\">The follow steps will guide you to customise your application.</label>\n\n  <div style=\"max-width: 400px;\">\n   <spa-text display=\"Organisation Name\" [(value)]=\"myTenant.name\" ></spa-text>\n  </div>\n\n  <label class=\"text-muted\" style=\" font-size: 12px;\">You can change the Organisation's name to your team or company name.</label><br>\n  <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">The name can be changed later.</label>\n\n</div>\n\n<!-- guest -->\n<div *ngIf=\"step=='hi' && !own\">\n  <label class=\"subtitle text-muted\">You are now signed in to {{myTenant.name}}.</label>\n</div>\n\n\n<!-- invitations -->\n<div class=\"mt-3\" *ngIf=\"step=='invitations' && own\">\n\n  <label class=\"subtitle text-muted\">You have been requested to join the following organisations. If you accept, you have the option to switch to that org now or stay in you org.</label><br>\n  <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">You will be able to switch later.</label>\n  <spa-invitations-table></spa-invitations-table>\n\n</div>\n\n\n<!-- Actions -->\n<div class=\"mt-3\">\n  <button  mat-stroked-button color=\"primary\" [disabled]=\"!agree\" (click)=\"next()\">Next <mat-icon>arrow_right_alt</mat-icon></button>\n</div>\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class SelectContextDirective {
|
|
4
|
+
constructor(templateRef, viewContainer) {
|
|
5
|
+
this.templateRef = templateRef;
|
|
6
|
+
this.viewContainer = viewContainer;
|
|
7
|
+
}
|
|
8
|
+
set selectContext(context) {
|
|
9
|
+
this.viewContainer.clear();
|
|
10
|
+
this.viewContainer.createEmbeddedView(this.templateRef, context);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
SelectContextDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectContextDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
14
|
+
SelectContextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: SelectContextDirective, selector: "[selectContext]", inputs: { selectContext: "selectContext" }, ngImport: i0 });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectContextDirective, decorators: [{
|
|
16
|
+
type: Directive,
|
|
17
|
+
args: [{
|
|
18
|
+
selector: '[selectContext]'
|
|
19
|
+
}]
|
|
20
|
+
}], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; }, propDecorators: { selectContext: [{
|
|
21
|
+
type: Input
|
|
22
|
+
}] } });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWNvbnRleHQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL3NlbGVjdC1jb250ZXh0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBaUMsTUFBTSxlQUFlLENBQUM7O0FBS2hGLE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsWUFDVSxXQUE2QixFQUM3QixhQUErQjtRQUQvQixnQkFBVyxHQUFYLFdBQVcsQ0FBa0I7UUFDN0Isa0JBQWEsR0FBYixhQUFhLENBQWtCO0lBQ3JDLENBQUM7SUFFTCxJQUFhLGFBQWEsQ0FBQyxPQUFZO1FBQ3JDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDM0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ25FLENBQUM7O21IQVRVLHNCQUFzQjt1R0FBdEIsc0JBQXNCOzJGQUF0QixzQkFBc0I7a0JBSGxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtpQkFDNUI7aUlBT2MsYUFBYTtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQsIFRlbXBsYXRlUmVmLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1tzZWxlY3RDb250ZXh0XSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFNlbGVjdENvbnRleHREaXJlY3RpdmUge1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcclxuICAgIHByaXZhdGUgdmlld0NvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZlxyXG4gICkgeyB9XHJcblxyXG4gIEBJbnB1dCgpIHNldCBzZWxlY3RDb250ZXh0KGNvbnRleHQ6IGFueSkge1xyXG4gICAgdGhpcy52aWV3Q29udGFpbmVyLmNsZWFyKCk7XHJcbiAgICB0aGlzLnZpZXdDb250YWluZXIuY3JlYXRlRW1iZWRkZWRWaWV3KHRoaXMudGVtcGxhdGVSZWYsIGNvbnRleHQpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -14,7 +14,7 @@ export class ButtonService {
|
|
|
14
14
|
};
|
|
15
15
|
}
|
|
16
16
|
getButtonColor(button, row) {
|
|
17
|
-
if (this.
|
|
17
|
+
if (this.testDisabled(button, row))
|
|
18
18
|
return 'lightgray';
|
|
19
19
|
if (button?.color)
|
|
20
20
|
return button.color;
|
|
@@ -26,13 +26,10 @@ export class ButtonService {
|
|
|
26
26
|
};
|
|
27
27
|
return colorMap[button.name] || '#4050B5';
|
|
28
28
|
}
|
|
29
|
-
isButtonDisabled(button, row) {
|
|
30
|
-
return button?.disabled ? button.disabled(row) : false;
|
|
31
|
-
}
|
|
32
29
|
isButtonVisible(button, row, isLoadComplete) {
|
|
33
30
|
if (!isLoadComplete)
|
|
34
31
|
return false;
|
|
35
|
-
return button
|
|
32
|
+
return this.testVisible(button, row);
|
|
36
33
|
}
|
|
37
34
|
getTitleAction(mode, buttons) {
|
|
38
35
|
const modeMap = {
|
|
@@ -52,6 +49,8 @@ export class ButtonService {
|
|
|
52
49
|
return this.getDefaultIcon(button.name, config.flatButtons);
|
|
53
50
|
}
|
|
54
51
|
testDisabled(button, row) {
|
|
52
|
+
if ((button.name == 'edit' || button.name == "delete") && row.pendingApproval)
|
|
53
|
+
return true;
|
|
55
54
|
return button.disabled ? button.disabled(row) : false;
|
|
56
55
|
}
|
|
57
56
|
testVisible(button, row) {
|
|
@@ -99,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
99
98
|
providedIn: 'root'
|
|
100
99
|
}]
|
|
101
100
|
}] });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.service.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/services/button.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { Button, TableConfig } from '../classes/Classes';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ButtonService {\r\n  getButton(buttons: Button[], name: string): Button | null {\r\n    return buttons?.find(x => x.name === name) || null;\r\n  }\r\n\r\n  getButtonProperties(button: Button, row: any, config: TableConfig): {\r\n    color: string,\r\n    icon: string,\r\n    disabled: boolean,\r\n    visible: boolean,\r\n    tip: string\r\n  } {\r\n    return {\r\n      color: this.getButtonColor(button, row),\r\n      icon: this.getIcon(button, config),\r\n      disabled: this.testDisabled(button, row),\r\n      visible: this.testVisible(button, row),\r\n      tip: button.tip || button.name\r\n    };\r\n  }\r\n\r\n  getButtonColor(button: Button, row: any): string {\r\n    if (this.testDisabled(button, row)) return 'lightgray';\r\n\r\n    if (button?.color) return button.color;\r\n    if (button.icon?.color) return button.icon.color;\r\n\r\n    const colorMap = {\r\n      'delete': '#F44336',\r\n      'create': 'green'\r\n    };\r\n\r\n    return colorMap[button.name] || '#4050B5';\r\n  }\r\n\r\n\r\n\r\n  isButtonVisible(button: Button, row: any, isLoadComplete: boolean): boolean {\r\n    if (!isLoadComplete) return false;\r\n    return this.testVisible(button,row);\r\n  }\r\n\r\n  getTitleAction(mode: string, buttons: Button[]): string {\r\n    const modeMap = {\r\n      'view': 'View',\r\n      'edit': buttons.find(b => b.name === 'edit')?.display || 'Edit',\r\n      'create': buttons.find(b => b.name === 'create')?.display || 'Create'\r\n    };\r\n    return modeMap[mode] || '';\r\n  }\r\n\r\n  isTabVisible(tableConfig: TableConfig): boolean {\r\n    return tableConfig.hideTabCondition ? !tableConfig.hideTabCondition(tableConfig.parentData) : true;\r\n  }\r\n\r\n  getIcon(button: Button, config: TableConfig): string {\r\n    if (button.icon) {\r\n      return button.icon.name;\r\n    }\r\n    return this.getDefaultIcon(button.name, config.flatButtons);\r\n  }\r\n\r\n  testDisabled(button: Button, row: any): boolean {\r\n    if ((button.name == 'edit' || button.name == \"delete\") && row.pendingApproval) return true;\r\n    return button.disabled ? button.disabled(row) : false;\r\n  }\r\n\r\n  testVisible(button: Button, row: any): boolean {\r\n    return button.visible ? button.visible(row) : true;\r\n  }\r\n\r\n  private getDefaultColor(buttonName: string): string {\r\n    switch (buttonName) {\r\n      case 'delete': return '#F44336';\r\n      case 'create': return 'green';\r\n      default: return '#4050B5';\r\n    }\r\n  }\r\n\r\n  private getDefaultIcon(buttonName: string, flatButtons: boolean): string {\r\n    switch (buttonName) {\r\n      case 'view':\r\n        return flatButtons ? 'open_in_new' : 'pageview';\r\n      case 'edit': return 'edit';\r\n      case 'delete': return 'delete';\r\n      case 'create': return 'add';\r\n      default: return 'more_horiz';\r\n    }\r\n  }\r\n\r\n  getCreateButton(buttons: Button[]): Button | undefined {\r\n    return buttons?.find(button => button?.name === 'create');\r\n  }\r\n\r\n  getDisplayedButtons(buttons: Button[], isSmallScreen: boolean, minButtons?: string[]): Button[] {\r\n    const nonCreateButtons = buttons?.filter(x => x.name !== 'create' && !x.inHeader);\r\n\r\n    if (isSmallScreen) {\r\n      if (minButtons) {\r\n        return nonCreateButtons.filter(x => minButtons.includes(x.name));\r\n      }\r\n      return nonCreateButtons.slice(0, 1);\r\n    }\r\n\r\n    return nonCreateButtons;\r\n  }\r\n\r\n  getActionsWidth(buttons: Button[]): string {\r\n    return `${buttons.length * 40 + 20}px`;\r\n  }\r\n}\r\n"]}
|