nuxeo-development-framework 2.0.9 → 3.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/nuxeo-development-framework.umd.js +8683 -454
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/activities-log/activities-log/activities-log.component.js +84 -0
- package/esm2015/lib/components/activities-log/activities-log/activities-log.service.js +35 -0
- package/esm2015/lib/components/activities-log/activities-log.module.js +30 -0
- package/esm2015/lib/components/attachment-item/attachment-item/attachment-item.component.js +54 -0
- package/esm2015/lib/components/attachment-item/attachment-item.module.js +44 -0
- package/esm2015/lib/components/attachment-modal/attachment-modal.module.js +40 -0
- package/esm2015/lib/components/attachment-modal/attachments/attachments.component.js +157 -0
- package/esm2015/lib/components/confirmation-dialog/confirmation-dialog/confirmation-dialog.component.js +30 -0
- package/esm2015/lib/components/confirmation-dialog/confirmation-dialog.module.js +30 -0
- package/esm2015/lib/components/display-suitable-icon/display-suitable-icon/display-suitable-icon.component.js +44 -0
- package/esm2015/lib/components/display-suitable-icon/display-suitable-icon/icon.service.js +140 -0
- package/esm2015/lib/components/display-suitable-icon/display-suitable-icon.module.js +24 -0
- package/esm2015/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.js +177 -0
- package/esm2015/lib/components/dynamic-fields-renderer/dynamic-fields-renderer.module.js +43 -0
- package/esm2015/lib/components/dynamic-tabs/dynamic-tabs/dynamic-tabs.component.js +39 -0
- package/esm2015/lib/components/dynamic-tabs/dynamic-tabs.module.js +34 -0
- package/esm2015/lib/components/file-manger/components/add-to-collection/add-to-collection.component.js +132 -0
- package/esm2015/lib/components/file-manger/components/clipboard/clipboard.component.js +264 -0
- package/esm2015/lib/components/file-manger/components/copy/copy.component.js +119 -0
- package/esm2015/lib/components/file-manger/components/create-directory/create-directory.component.js +91 -0
- package/esm2015/lib/components/file-manger/components/create-modal/create-modal.component.js +455 -0
- package/esm2015/lib/components/file-manger/components/creation-type/creation-type.component.js +26 -0
- package/esm2015/lib/components/file-manger/components/delete/delete.component.js +77 -0
- package/esm2015/lib/components/file-manger/components/folder-modal/folder-modal.component.js +114 -0
- package/esm2015/lib/components/file-manger/components/loan-request/loan-request.component.js +80 -0
- package/esm2015/lib/components/file-manger/components/move/move.component.js +108 -0
- package/esm2015/lib/components/file-manger/components/publish-dialog/publish-dialog.component.js +111 -0
- package/esm2015/lib/components/file-manger/components/rename/rename.component.js +86 -0
- package/esm2015/lib/components/file-manger/components/scan-modal/scan-modal.component.js +314 -0
- package/esm2015/lib/components/file-manger/components/share-dialog/share-dialog.component.js +294 -0
- package/esm2015/lib/components/file-manger/components/sidepanel/sidepanel.component.js +257 -0
- package/esm2015/lib/components/file-manger/components/template-modal/template-modal.component.js +64 -0
- package/esm2015/lib/components/file-manger/components/transfer-doc/transfer-doc.component.js +71 -0
- package/esm2015/lib/components/file-manger/components/update-modal/update-modal.component.js +358 -0
- package/esm2015/lib/components/file-manger/file-manager.abstract.js +1031 -0
- package/esm2015/lib/components/file-manger/file-manger.module.js +295 -0
- package/esm2015/lib/components/mutiple-dynamic-form-viewer/multiple-dynamic-form-viewer/multiple-dynamic-form-viewer.component.js +51 -0
- package/esm2015/lib/components/mutiple-dynamic-form-viewer/mutiple-dynamic-form-viewer.module.js +30 -0
- package/esm2015/lib/components/permissions/add-permissions-dialog/add-permissions-dialog.component.js +177 -0
- package/esm2015/lib/components/permissions/permission.service.js +118 -0
- package/esm2015/lib/components/permissions/permissions/permissions.component.js +232 -0
- package/esm2015/lib/components/permissions/permissions-template/permissions-template.component.js +117 -0
- package/esm2015/lib/components/permissions/permissions.module.js +71 -0
- package/esm2015/lib/components/select-users-by-department/select-users-by-department.module.js +47 -0
- package/esm2015/lib/components/select-users-by-department/select-users-by-departments/department-management.service.js +27 -0
- package/esm2015/lib/components/select-users-by-department/select-users-by-departments/select-users-by-departments.component.js +116 -0
- package/esm2015/lib/components/user/user/user.component.js +29 -0
- package/esm2015/lib/components/user/user.module.js +30 -0
- package/esm2015/lib/directive/directive.module.js +9 -4
- package/esm2015/lib/directive/drag-and-drop/drag-and-drop.directive.js +46 -0
- package/esm2015/lib/shared/libraryShared.module.js +1 -4
- package/esm2015/lib/shared-services/dialog-mangment.service.js +61 -0
- package/esm2015/lib/shared-services/dynamic-form.service.js +241 -0
- package/esm2015/lib/shared-services/file-manager.adapter.js +74 -0
- package/esm2015/lib/shared-services/file-manager.service.js +793 -0
- package/esm2015/lib/shared-services/global-pdftron.service.js +46 -0
- package/esm2015/lib/shared-services/mainfolder.service.js +160 -0
- package/esm2015/lib/shared-services/publishing-document.service.js +202 -0
- package/esm2015/lib/shared-services/recently-viewed.service.js +57 -0
- package/esm2015/lib/shared-services/shared-docs.service.js +135 -0
- package/esm2015/lib/shared-services/shared-services.module.js +20 -0
- package/esm2015/lib/shared-services/upload-file.service.js +29 -0
- package/esm2015/lib/shared-services/upload-managment.service.js +151 -0
- package/esm2015/lib/shared-services/user.service.js +54 -0
- package/esm2015/public-api.js +65 -1
- package/fesm2015/nuxeo-development-framework.js +7969 -154
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/activities-log/activities-log/activities-log.component.d.ts +23 -0
- package/lib/components/activities-log/activities-log/activities-log.service.d.ts +9 -0
- package/lib/components/activities-log/activities-log.module.d.ts +10 -0
- package/lib/components/attachment-item/attachment-item/attachment-item.component.d.ts +21 -0
- package/lib/components/attachment-item/attachment-item.module.d.ts +13 -0
- package/lib/components/attachment-modal/attachment-modal.module.d.ts +12 -0
- package/lib/components/attachment-modal/attachments/attachments.component.d.ts +50 -0
- package/lib/components/confirmation-dialog/confirmation-dialog/confirmation-dialog.component.d.ts +12 -0
- package/lib/components/confirmation-dialog/confirmation-dialog.module.d.ts +10 -0
- package/lib/components/display-suitable-icon/display-suitable-icon/display-suitable-icon.component.d.ts +17 -0
- package/lib/components/display-suitable-icon/display-suitable-icon/icon.service.d.ts +8 -0
- package/lib/components/display-suitable-icon/display-suitable-icon.module.d.ts +8 -0
- package/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.d.ts +137 -0
- package/lib/components/dynamic-fields-renderer/dynamic-fields-renderer.module.d.ts +12 -0
- package/lib/components/dynamic-tabs/dynamic-tabs/dynamic-tabs.component.d.ts +13 -0
- package/lib/components/dynamic-tabs/dynamic-tabs.module.d.ts +11 -0
- package/lib/components/file-manger/components/add-to-collection/add-to-collection.component.d.ts +31 -0
- package/lib/components/file-manger/components/clipboard/clipboard.component.d.ts +41 -0
- package/lib/components/file-manger/components/copy/copy.component.d.ts +32 -0
- package/lib/components/file-manger/components/create-directory/create-directory.component.d.ts +24 -0
- package/lib/components/file-manger/components/create-modal/create-modal.component.d.ts +108 -0
- package/lib/components/file-manger/components/creation-type/creation-type.component.d.ts +11 -0
- package/lib/components/file-manger/components/delete/delete.component.d.ts +30 -0
- package/lib/components/file-manger/components/folder-modal/folder-modal.component.d.ts +56 -0
- package/lib/components/file-manger/components/loan-request/loan-request.component.d.ts +23 -0
- package/lib/components/file-manger/components/move/move.component.d.ts +32 -0
- package/lib/components/file-manger/components/publish-dialog/publish-dialog.component.d.ts +32 -0
- package/lib/components/file-manger/components/rename/rename.component.d.ts +25 -0
- package/lib/components/file-manger/components/scan-modal/scan-modal.component.d.ts +95 -0
- package/lib/components/file-manger/components/share-dialog/share-dialog.component.d.ts +58 -0
- package/lib/components/file-manger/components/sidepanel/sidepanel.component.d.ts +62 -0
- package/lib/components/file-manger/components/template-modal/template-modal.component.d.ts +34 -0
- package/lib/components/file-manger/components/transfer-doc/transfer-doc.component.d.ts +24 -0
- package/lib/components/file-manger/components/update-modal/update-modal.component.d.ts +194 -0
- package/lib/components/file-manger/file-manager.abstract.d.ts +173 -0
- package/lib/components/file-manger/file-manger.module.d.ts +59 -0
- package/lib/components/mutiple-dynamic-form-viewer/multiple-dynamic-form-viewer/multiple-dynamic-form-viewer.component.d.ts +17 -0
- package/lib/components/mutiple-dynamic-form-viewer/mutiple-dynamic-form-viewer.module.d.ts +10 -0
- package/lib/components/permissions/add-permissions-dialog/add-permissions-dialog.component.d.ts +44 -0
- package/lib/components/permissions/permission.service.d.ts +21 -0
- package/lib/components/permissions/permissions/permissions.component.d.ts +48 -0
- package/lib/components/permissions/permissions-template/permissions-template.component.d.ts +22 -0
- package/lib/components/permissions/permissions.module.d.ts +21 -0
- package/lib/components/select-users-by-department/select-users-by-department.module.d.ts +13 -0
- package/lib/components/select-users-by-department/select-users-by-departments/department-management.service.d.ts +10 -0
- package/lib/components/select-users-by-department/select-users-by-departments/select-users-by-departments.component.d.ts +33 -0
- package/lib/components/user/user/user.component.d.ts +12 -0
- package/lib/components/user/user.module.d.ts +10 -0
- package/lib/directive/directive.module.d.ts +3 -2
- package/lib/directive/drag-and-drop/drag-and-drop.directive.d.ts +11 -0
- package/lib/shared/libraryShared.module.d.ts +1 -1
- package/lib/shared-services/dialog-mangment.service.d.ts +15 -0
- package/lib/shared-services/dynamic-form.service.d.ts +24 -0
- package/lib/shared-services/file-manager.adapter.d.ts +48 -0
- package/lib/shared-services/file-manager.service.d.ts +94 -0
- package/lib/shared-services/global-pdftron.service.d.ts +10 -0
- package/lib/shared-services/mainfolder.service.d.ts +32 -0
- package/lib/shared-services/publishing-document.service.d.ts +25 -0
- package/lib/shared-services/recently-viewed.service.d.ts +17 -0
- package/lib/shared-services/shared-docs.service.d.ts +21 -0
- package/lib/shared-services/shared-services.module.d.ts +7 -0
- package/lib/shared-services/upload-file.service.d.ts +10 -0
- package/lib/shared-services/upload-managment.service.d.ts +72 -0
- package/lib/shared-services/user.service.d.ts +12 -0
- package/package.json +7 -6
- package/public-api.d.ts +62 -0
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { MatDialogConfig } from '@angular/material/dialog';
|
|
3
|
+
import { AddPermissionsDialogComponent } from '../add-permissions-dialog/add-permissions-dialog.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../permission.service";
|
|
6
|
+
import * as i2 from "@angular/material/dialog";
|
|
7
|
+
import * as i3 from "../../custom-toastr/services/custom-toastr.service";
|
|
8
|
+
import * as i4 from "../../../Core/services/translation/translation.service";
|
|
9
|
+
import * as i5 from "../../../Core/services/nuxeo/nuxeo.service";
|
|
10
|
+
import * as i6 from "../../../shared-services/user.service";
|
|
11
|
+
import * as i7 from "../../../directive/permissions/evaluators.service";
|
|
12
|
+
import * as i8 from "@angular/material/divider";
|
|
13
|
+
import * as i9 from "../permissions-template/permissions-template.component";
|
|
14
|
+
import * as i10 from "@angular/material/progress-bar";
|
|
15
|
+
import * as i11 from "@angular/material/progress-spinner";
|
|
16
|
+
import * as i12 from "@angular/common";
|
|
17
|
+
import * as i13 from "@ngx-translate/core";
|
|
18
|
+
export class PermissionsComponent {
|
|
19
|
+
constructor(permissionService, addPermissionsDialog, tosterService, translateService, nuxeoService, userServ, evaluatorService) {
|
|
20
|
+
this.permissionService = permissionService;
|
|
21
|
+
this.addPermissionsDialog = addPermissionsDialog;
|
|
22
|
+
this.tosterService = tosterService;
|
|
23
|
+
this.translateService = translateService;
|
|
24
|
+
this.nuxeoService = nuxeoService;
|
|
25
|
+
this.userServ = userServ;
|
|
26
|
+
this.evaluatorService = evaluatorService;
|
|
27
|
+
this.sourcePage = '';
|
|
28
|
+
this.subscriptions$ = [];
|
|
29
|
+
this.localPermissions = [];
|
|
30
|
+
this.inheritedPermissions = [];
|
|
31
|
+
this.departmentPermissions = [];
|
|
32
|
+
this.sharePermissions = [];
|
|
33
|
+
this.workflowPermissions = [];
|
|
34
|
+
this.status = null; //to know inherited Permissions if block or not
|
|
35
|
+
this.allowAdd_Block_DeletePermission = false;
|
|
36
|
+
this.blockOrUnblock = false;
|
|
37
|
+
this.loading = false;
|
|
38
|
+
this.allDepartmentUsers = [];
|
|
39
|
+
}
|
|
40
|
+
ngOnInit() {
|
|
41
|
+
this.subscriptions$.concat([
|
|
42
|
+
this.permissionService.createAndAddAnother.subscribe(res => {
|
|
43
|
+
this.getPermissions();
|
|
44
|
+
})
|
|
45
|
+
]);
|
|
46
|
+
this.loading = true;
|
|
47
|
+
this.checkIfUserCanDoActionsOnPermissions();
|
|
48
|
+
this.getPermissions();
|
|
49
|
+
(this.inheritedPermissions.length > 0) ? this.status = 'unblock' : this.status = 'block';
|
|
50
|
+
}
|
|
51
|
+
addPermissionLabel(arr, permissionArr) {
|
|
52
|
+
arr.forEach(element => {
|
|
53
|
+
if (!this.isItemContainAdministratorGroup(element)) {
|
|
54
|
+
element.permissionLabel = this.translateService.instant(`rights.${element.permission}`);
|
|
55
|
+
permissionArr.push(element);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
isItemContainAdministratorGroup(element) {
|
|
60
|
+
let isAdministrator = false;
|
|
61
|
+
if (element.granted === false) {
|
|
62
|
+
isAdministrator = true;
|
|
63
|
+
}
|
|
64
|
+
else if (element.username && element.username['entity-type'] === 'group' && element.username.groupname === 'administrators') {
|
|
65
|
+
isAdministrator = true;
|
|
66
|
+
}
|
|
67
|
+
else if (element.username.userGroups) {
|
|
68
|
+
element.username.userGroups.map(group => {
|
|
69
|
+
if (group.name === 'administrators') {
|
|
70
|
+
isAdministrator = true;
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
return isAdministrator;
|
|
75
|
+
}
|
|
76
|
+
getPermissions() {
|
|
77
|
+
this.subscriptions$.concat([this.permissionService.getPermissionsForDocument(this.documentId).subscribe(res => {
|
|
78
|
+
this.permissionsType = res.contextParameters.acls;
|
|
79
|
+
this.userVisiblePermissions = res.contextParameters.userVisiblePermissions;
|
|
80
|
+
for (let p of this.permissionsType) {
|
|
81
|
+
if (p.name == 'local') {
|
|
82
|
+
this.localPermissions = [];
|
|
83
|
+
this.addPermissionLabel(p.aces, this.localPermissions);
|
|
84
|
+
this.localPermissions = this.localPermissions.map(element => {
|
|
85
|
+
if (element.creator.properties.username != this.nuxeoService.nuxeoClient.user.properties.username) {
|
|
86
|
+
element['currentUserIsPermissionOwner'] = false;
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
element['currentUserIsPermissionOwner'] = true;
|
|
90
|
+
}
|
|
91
|
+
return element;
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
else if (p.name == 'inherited') {
|
|
95
|
+
this.inheritedPermissions = [];
|
|
96
|
+
this.addPermissionLabel(p.aces, this.inheritedPermissions);
|
|
97
|
+
}
|
|
98
|
+
else if (p.name.includes('deptSpace')) {
|
|
99
|
+
this.departmentPermissions = [];
|
|
100
|
+
this.addPermissionLabel(p.aces, this.departmentPermissions);
|
|
101
|
+
}
|
|
102
|
+
else if (p.name.includes('share')) {
|
|
103
|
+
this.sharePermissions = [];
|
|
104
|
+
this.addPermissionLabel(p.aces, this.sharePermissions);
|
|
105
|
+
}
|
|
106
|
+
else if (p.name.includes('routing')) {
|
|
107
|
+
this.workflowPermissions = [];
|
|
108
|
+
this.addPermissionLabel(p.aces, this.workflowPermissions);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
(this.inheritedPermissions.length == 0) ? this.status = 'block' : this.status = 'unblock';
|
|
112
|
+
this.loading = false;
|
|
113
|
+
}, err => this.loading = false)]);
|
|
114
|
+
}
|
|
115
|
+
blockPermissionInheritance() {
|
|
116
|
+
this.blockOrUnblock = true;
|
|
117
|
+
this.subscriptions$.concat([this.permissionService.blockPermissionInheritance(this.documentId).subscribe(res => {
|
|
118
|
+
if (res) {
|
|
119
|
+
this.getPermissions();
|
|
120
|
+
this.tosterService.show('success', 'TOASTER.SUCCESS', "TOASTER.PERMISSION_BLOCK_SUCCESS");
|
|
121
|
+
this.blockOrUnblock = false;
|
|
122
|
+
this.status = "unblock";
|
|
123
|
+
this.inheritedPermissions = [];
|
|
124
|
+
}
|
|
125
|
+
}, err => {
|
|
126
|
+
this.blockOrUnblock = false;
|
|
127
|
+
this.tosterService.show('error', 'TOASTER.ERROR', 'TOASTER.PERMISSION_BLOCK_FAIL');
|
|
128
|
+
})]);
|
|
129
|
+
}
|
|
130
|
+
unblockPermissionInheritance() {
|
|
131
|
+
this.blockOrUnblock = true;
|
|
132
|
+
this.subscriptions$.concat([this.permissionService.unblockPermissionInheritance(this.documentId).subscribe(res => {
|
|
133
|
+
if (res) {
|
|
134
|
+
this.getPermissions();
|
|
135
|
+
this.tosterService.show('success', 'TOASTER.SUCCESS', "TOASTER.PERMISSION_UNBLOCK_SUCCESS");
|
|
136
|
+
this.status = "block";
|
|
137
|
+
this.blockOrUnblock = false;
|
|
138
|
+
}
|
|
139
|
+
}, err => {
|
|
140
|
+
this.blockOrUnblock = false;
|
|
141
|
+
this.tosterService.show('error', 'TOASTER.ERROR', 'TOASTER.PERMISSION_UNBLOCK_FAIL');
|
|
142
|
+
})]);
|
|
143
|
+
}
|
|
144
|
+
addNewLocalPermissions() {
|
|
145
|
+
this.permissionService.departmentUsers = [...this.allDepartmentUsers];
|
|
146
|
+
this.localPermissions.forEach(perm => {
|
|
147
|
+
this.permissionService.departmentUsers.forEach((user, index) => {
|
|
148
|
+
if (perm.username.properties.username === user.properties.username
|
|
149
|
+
&& perm.creator.properties.username === this.nuxeoService.nuxeoClient.user.properties.username) {
|
|
150
|
+
this.permissionService.departmentUsers.splice(index, 1);
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
});
|
|
154
|
+
const dialogConfig = new MatDialogConfig();
|
|
155
|
+
dialogConfig.disableClose = false;
|
|
156
|
+
dialogConfig.autoFocus = true;
|
|
157
|
+
dialogConfig.data = {
|
|
158
|
+
id: this.documentId,
|
|
159
|
+
rights: this.userVisiblePermissions
|
|
160
|
+
};
|
|
161
|
+
dialogConfig.width = '35%';
|
|
162
|
+
dialogConfig.height = '70%';
|
|
163
|
+
// befor opening modal we diable clickout side effect to prevent details side menu from closing when clicking in the modal
|
|
164
|
+
this.permissionService.disableClickOutSide = true;
|
|
165
|
+
let dialofRef = this.addPermissionsDialog.open(AddPermissionsDialogComponent, dialogConfig);
|
|
166
|
+
dialofRef.afterClosed().subscribe(res => {
|
|
167
|
+
// return click outside effect to work to close side menu when clicking out side it
|
|
168
|
+
this.permissionService.disableClickOutSide = false;
|
|
169
|
+
if (res) {
|
|
170
|
+
this.getPermissions();
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
checkIfUserCanDoActionsOnPermissions() {
|
|
175
|
+
this.evaluatorService.evaluateRule('isManagePermissionEnabled').then(isEnabled => {
|
|
176
|
+
if (isEnabled) {
|
|
177
|
+
let userInControllerGroup = false;
|
|
178
|
+
this.nuxeoService.nuxeoClient.user.userGroups.forEach(group => {
|
|
179
|
+
if (group.name === 'dms_document_controller') {
|
|
180
|
+
userInControllerGroup = true;
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
if (userInControllerGroup) {
|
|
184
|
+
let depCode = this.userServ.getUserDepartmentFromPath(this.document.path);
|
|
185
|
+
this.permissionService.getDepMembers(depCode).subscribe(res => {
|
|
186
|
+
this.permissionService.departmentUsers = res.users.map(e => {
|
|
187
|
+
e['displayLabel'] = e.properties.firstName + ' ' + e.properties.lastName;
|
|
188
|
+
return e;
|
|
189
|
+
});
|
|
190
|
+
this.allDepartmentUsers = [...this.permissionService.departmentUsers];
|
|
191
|
+
res.users.forEach(user => {
|
|
192
|
+
if (user.properties.username === this.nuxeoService.nuxeoClient.user.properties.username
|
|
193
|
+
&& this.document.type === 'DmsFolder') {
|
|
194
|
+
this.allowAdd_Block_DeletePermission = true;
|
|
195
|
+
}
|
|
196
|
+
});
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
this.allowAdd_Block_DeletePermission = false;
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
else {
|
|
204
|
+
this.allowAdd_Block_DeletePermission = false;
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
ngOnDestroy() {
|
|
209
|
+
// return click outside effect to work to close side menu when clicking out side it
|
|
210
|
+
this.permissionService.disableClickOutSide = false;
|
|
211
|
+
this.subscriptions$.forEach(e => e.unsubscribe());
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
PermissionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PermissionsComponent, deps: [{ token: i1.PermissionService }, { token: i2.MatDialog }, { token: i3.CustomToastrService }, { token: i4.TranslationService }, { token: i5.NuxeoService }, { token: i6.UserService }, { token: i7.EvaluatorsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
215
|
+
PermissionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: PermissionsComponent, selector: "app-permissions", inputs: { documentId: "documentId", document: "document", allowAddAndBlock: "allowAddAndBlock", sourcePage: "sourcePage" }, ngImport: i0, template: "<div class=\"h-auto mt-3 px-0 pb-4\" *ngIf=\"!loading; else loader\">\r\n <!--LocalPermission List Items-->\r\n <div *ngIf=\"sourcePage != 'myFiles'\">\r\n <div class=\"flex flex-row justify-between\">\r\n <span class=\"font-bold text-gray-500 text-base\">{{\r\n \"permission.local\" | translate\r\n }}</span>\r\n <span *ngIf=\"allowAdd_Block_DeletePermission && !inheritedPermissions.length\">\r\n <button\r\n *ngIf=\"allowAddAndBlock\"\r\n class=\"hover:text-blue-700 text-blue-500 mb-1 text-base\"\r\n (click)=\"addNewLocalPermissions()\"\r\n [disabled]=\"!permissionsType\"\r\n >\r\n {{ \"permission.new\" | translate }}\r\n </button>\r\n </span>\r\n </div>\r\n <mat-divider class=\"mat-divider\"></mat-divider>\r\n <app-permissions-template\r\n [documentId]=\"documentId\"\r\n [userVisiblePermissions]=\"userVisiblePermissions\"\r\n (getPermissions)=\"getPermissions()\"\r\n [allowDeleteAndEdit]=\"allowAdd_Block_DeletePermission\"\r\n [permissionsArray]=\"localPermissions\"\r\n *ngIf=\"localPermissions.length > 0; else nolocalPermissions\"\r\n >\r\n </app-permissions-template>\r\n </div>\r\n <ng-template #nolocalPermissions>\r\n <div class=\"single-permssion p-3 text-center\">\r\n {{ \"permission.noLocal\" | translate }}\r\n </div>\r\n </ng-template>\r\n <!--InheritedPermission List Items-->\r\n <div>\r\n <div class=\"flex flex-row justify-between mt-3\">\r\n <span class=\"font-bold text-gray-500 text-base\">{{\r\n \"permission.inherited\" | translate\r\n }}</span>\r\n <span *ngIf=\"allowAdd_Block_DeletePermission\">\r\n <button\r\n class=\"hover:text-blue-700 text-blue-500 mb-1 text-base\"\r\n *ngIf=\"status != null && allowAddAndBlock\"\r\n >\r\n <span\r\n *ngIf=\"status == 'block'; else unblock\"\r\n (click)=\"unblockPermissionInheritance()\"\r\n >\r\n {{ \"permission.unblock\" | translate }}\r\n </span>\r\n <ng-template #unblock>\r\n <span (click)=\"blockPermissionInheritance()\">\r\n {{ \"permission.block\" | translate }}\r\n </span>\r\n </ng-template>\r\n </button>\r\n </span>\r\n </div>\r\n <mat-divider class=\"mat-divider\" *ngIf=\"!blockOrUnblock\"></mat-divider>\r\n <mat-progress-bar mode=\"indeterminate\" *ngIf=\"blockOrUnblock\"></mat-progress-bar>\r\n <app-permissions-template\r\n *ngIf=\"inheritedPermissions.length > 0; else noinheritedPermissions\"\r\n [documentId]=\"documentId\"\r\n [userVisiblePermissions]=\"userVisiblePermissions\"\r\n [permissionsArray]=\"inheritedPermissions\"\r\n (getPermissions)=\"getPermissions()\"\r\n >\r\n </app-permissions-template>\r\n </div>\r\n <ng-template #noinheritedPermissions>\r\n <div class=\"single-permssion p-3 text-center\">\r\n {{\"permission.noInherited\" | translate }}</div>\r\n </ng-template>\r\n <!--departmentPermissions List Items-->\r\n <div *ngIf=\"departmentPermissions.length > 0\">\r\n <div class=\"flex flex-row justify-between\">\r\n <span class=\"font-bold text-gray-500 text-base\">{{\r\n \"permission.departmentPermissions\" | translate\r\n }}</span>\r\n </div>\r\n <mat-divider class=\"mat-divider\"></mat-divider>\r\n <app-permissions-template\r\n [documentId]=\"documentId\"\r\n [userVisiblePermissions]=\"userVisiblePermissions\"\r\n (getPermissions)=\"getPermissions()\"\r\n [permissionsArray]=\"departmentPermissions\"\r\n >\r\n </app-permissions-template>\r\n </div>\r\n <!--sharePermissions List Items-->\r\n <div *ngIf=\"sharePermissions.length > 0\">\r\n <div class=\"flex flex-row justify-between\">\r\n <span class=\"font-bold text-gray-500 text-base\">{{\r\n \"permission.sharePermissions\" | translate\r\n }}</span>\r\n </div>\r\n <mat-divider class=\"mat-divider\"></mat-divider>\r\n <app-permissions-template\r\n [documentId]=\"documentId\"\r\n [userVisiblePermissions]=\"userVisiblePermissions\"\r\n (getPermissions)=\"getPermissions()\"\r\n [permissionsArray]=\"sharePermissions\"\r\n >\r\n </app-permissions-template>\r\n </div>\r\n <!--workflowPermissions List Items-->\r\n <div *ngIf=\"workflowPermissions.length > 0\">\r\n <div class=\"flex flex-row justify-between\">\r\n <span class=\"font-bold text-gray-500 text-base\">{{\r\n \"permission.workflowPermissions\" | translate\r\n }}</span>\r\n </div>\r\n <mat-divider class=\"mat-divider\"></mat-divider>\r\n <app-permissions-template\r\n [documentId]=\"documentId\"\r\n [userVisiblePermissions]=\"userVisiblePermissions\"\r\n (getPermissions)=\"getPermissions()\"\r\n [permissionsArray]=\"workflowPermissions\"\r\n >\r\n </app-permissions-template>\r\n </div>\r\n</div>\r\n\r\n<ng-template #loader>\r\n <div class=\"flex items-center justify-center w-full h-full\">\r\n <mat-spinner [value]=\"90\" [strokeWidth]=\"6\" overlay=\"true\" [diameter]=\"75\"></mat-spinner>\r\n </div>\r\n</ng-template>\r\n", styles: [""], components: [{ type: i8.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { type: i9.PermissionsTemplateComponent, selector: "app-permissions-template", inputs: ["allowDeleteAndEdit", "documentId", "userVisiblePermissions", "permissionsArray"], outputs: ["getPermissions"] }, { type: i10.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "mode", "value", "bufferValue"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { type: i11.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i13.TranslatePipe } });
|
|
216
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PermissionsComponent, decorators: [{
|
|
217
|
+
type: Component,
|
|
218
|
+
args: [{
|
|
219
|
+
selector: 'app-permissions',
|
|
220
|
+
templateUrl: './permissions.component.html',
|
|
221
|
+
styleUrls: ['./permissions.component.scss']
|
|
222
|
+
}]
|
|
223
|
+
}], ctorParameters: function () { return [{ type: i1.PermissionService }, { type: i2.MatDialog }, { type: i3.CustomToastrService }, { type: i4.TranslationService }, { type: i5.NuxeoService }, { type: i6.UserService }, { type: i7.EvaluatorsService }]; }, propDecorators: { documentId: [{
|
|
224
|
+
type: Input
|
|
225
|
+
}], document: [{
|
|
226
|
+
type: Input
|
|
227
|
+
}], allowAddAndBlock: [{
|
|
228
|
+
type: Input
|
|
229
|
+
}], sourcePage: [{
|
|
230
|
+
type: Input
|
|
231
|
+
}] } });
|
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permissions.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/permissions/permissions/permissions.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/permissions/permissions/permissions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { MatDialog, MatDialogConfig } from '@angular/material/dialog';\r\nimport { Subscription } from 'rxjs';\r\nimport { PermissionService } from '../permission.service';\r\nimport { UserService } from '../../../shared-services/user.service';\r\nimport { AddPermissionsDialogComponent } from '../add-permissions-dialog/add-permissions-dialog.component';\r\nimport { EvaluatorsService } from '../../../directive/permissions/evaluators.service';\r\nimport { CustomToastrService } from '../../custom-toastr/services/custom-toastr.service';\r\nimport { TranslationService } from '../../../Core/services/translation/translation.service';\r\nimport { NuxeoService } from '../../../Core/services/nuxeo/nuxeo.service';\r\n\r\n@Component({\r\n  selector: 'app-permissions',\r\n  templateUrl: './permissions.component.html',\r\n  styleUrls: ['./permissions.component.scss']\r\n})\r\nexport class PermissionsComponent implements OnInit, OnDestroy {\r\n  permissionsType: any;\r\n  @Input()\r\n  documentId;\r\n  @Input()\r\n  document;\r\n  @Input()\r\n  allowAddAndBlock\r\n  @Input()\r\n  sourcePage = ''\r\n  subscriptions$: Subscription[] = [];\r\n  userVisiblePermissions: any;\r\n  localPermissions = [];\r\n  inheritedPermissions = [];\r\n  departmentPermissions = [];\r\n  sharePermissions = [];\r\n  workflowPermissions = [];\r\n  status=null;//to know inherited Permissions if block or not\r\n  allowAdd_Block_DeletePermission =false;\r\n  blockOrUnblock = false;\r\n  loading = false;\r\n  allDepartmentUsers = [];\r\n  constructor(private permissionService: PermissionService,\r\n    private addPermissionsDialog: MatDialog,\r\n    private tosterService: CustomToastrService,\r\n    private translateService: TranslationService,\r\n    private nuxeoService: NuxeoService,\r\n    private userServ: UserService,\r\n    private evaluatorService : EvaluatorsService) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.subscriptions$.concat([\r\n      this.permissionService.createAndAddAnother.subscribe(res => {\r\n        this.getPermissions();\r\n      })\r\n    ]);\r\n    this.loading = true;\r\n    this.checkIfUserCanDoActionsOnPermissions();\r\n    this.getPermissions();\r\n    (this.inheritedPermissions.length > 0) ? this.status = 'unblock' : this.status = 'block';\r\n  }\r\n\r\n  addPermissionLabel(arr,permissionArr) {\r\n    arr.forEach(element => {\r\n      if(!this.isItemContainAdministratorGroup(element)){\r\n        element.permissionLabel = this.translateService.instant(`rights.${element.permission}`)\r\n        permissionArr.push(element)\r\n      }\r\n    });\r\n  }\r\n\r\n  isItemContainAdministratorGroup(element){\r\n    let isAdministrator = false;\r\n    if(element.granted === false){\r\n      isAdministrator = true;\r\n    }else if (element.username && element.username['entity-type'] === 'group' && element.username.groupname === 'administrators'){\r\n      isAdministrator = true;\r\n    } else if(element.username.userGroups){\r\n        element.username.userGroups.map(group => {\r\n          if(group.name === 'administrators'){\r\n            isAdministrator = true;\r\n          }\r\n        })\r\n    }\r\n    return isAdministrator;\r\n  }\r\n\r\n  getPermissions() {\r\n    this.subscriptions$.concat([this.permissionService.getPermissionsForDocument(this.documentId).subscribe(res => {\r\n      this.permissionsType = res.contextParameters.acls;\r\n      this.userVisiblePermissions = res.contextParameters.userVisiblePermissions;\r\n      for (let p of this.permissionsType) {\r\n        if (p.name == 'local') {\r\n          this.localPermissions = [];\r\n          this.addPermissionLabel(p.aces,this.localPermissions);\r\n          this.localPermissions = this.localPermissions.map(element => {\r\n            if(element.creator.properties.username != this.nuxeoService.nuxeoClient.user.properties.username) {\r\n              element['currentUserIsPermissionOwner'] = false;\r\n            } else {\r\n              element['currentUserIsPermissionOwner'] = true;\r\n            }\r\n            return element;\r\n          });\r\n        }\r\n        else if (p.name == 'inherited') {\r\n          this.inheritedPermissions = [];\r\n          this.addPermissionLabel(p.aces,this.inheritedPermissions)\r\n        }\r\n        else if (p.name.includes('deptSpace')) {\r\n          this.departmentPermissions = [];\r\n          this.addPermissionLabel(p.aces,this.departmentPermissions)\r\n        }\r\n        else if (p.name.includes('share')) {\r\n          this.sharePermissions = [];\r\n          this.addPermissionLabel(p.aces,this.sharePermissions)\r\n        }\r\n        else if (p.name.includes('routing')) {\r\n          this.workflowPermissions = [];\r\n          this.addPermissionLabel(p.aces,this.workflowPermissions)\r\n        }    \r\n      }\r\n      (this.inheritedPermissions.length == 0) ? this.status = 'block' : this.status = 'unblock';  \r\n      this.loading = false;\r\n    },err => this.loading = false\r\n    )]);\r\n    \r\n  }\r\n\r\n  blockPermissionInheritance() {\r\n    this.blockOrUnblock = true;\r\n    this.subscriptions$.concat([this.permissionService.blockPermissionInheritance(this.documentId).subscribe(res => {\r\n      if (res) {\r\n        this.getPermissions();\r\n        this.tosterService.show('success', 'TOASTER.SUCCESS', \"TOASTER.PERMISSION_BLOCK_SUCCESS\");\r\n        this.blockOrUnblock = false;\r\n        this.status = \"unblock\";\r\n        this.inheritedPermissions = [];\r\n      }\r\n    }, err => {\r\n      this.blockOrUnblock = false;\r\n      this.tosterService.show('error', 'TOASTER.ERROR', 'TOASTER.PERMISSION_BLOCK_FAIL');\r\n    }\r\n    )])\r\n  }\r\n\r\n  unblockPermissionInheritance() {\r\n    this.blockOrUnblock = true;\r\n    this.subscriptions$.concat([this.permissionService.unblockPermissionInheritance(this.documentId).subscribe(res => {\r\n      if (res) {   \r\n        this.getPermissions();\r\n        this.tosterService.show('success', 'TOASTER.SUCCESS', \"TOASTER.PERMISSION_UNBLOCK_SUCCESS\");\r\n        this.status = \"block\";\r\n        this.blockOrUnblock = false;\r\n      }\r\n    }, err => {\r\n      this.blockOrUnblock = false;\r\n      this.tosterService.show('error', 'TOASTER.ERROR', 'TOASTER.PERMISSION_UNBLOCK_FAIL');\r\n    })])\r\n  }\r\n\r\n  addNewLocalPermissions() {\r\n    this.permissionService.departmentUsers = [...this.allDepartmentUsers];\r\n    this.localPermissions.forEach(perm => {\r\n      this.permissionService.departmentUsers.forEach((user, index) => {\r\n        if (perm.username.properties.username === user.properties.username\r\n          && perm.creator.properties.username === this.nuxeoService.nuxeoClient.user.properties.username) {\r\n          this.permissionService.departmentUsers.splice(index, 1)\r\n        }\r\n      });\r\n    });\r\n    const dialogConfig = new MatDialogConfig();\r\n    dialogConfig.disableClose = false;\r\n    dialogConfig.autoFocus = true;\r\n    dialogConfig.data = {\r\n      id: this.documentId,\r\n      rights: this.userVisiblePermissions\r\n    };\r\n    dialogConfig.width = '35%';\r\n    dialogConfig.height = '70%';\r\n    // befor opening modal we diable clickout side effect to prevent details side menu from closing when clicking in the modal\r\n    this.permissionService.disableClickOutSide = true;\r\n    let dialofRef = this.addPermissionsDialog.open(\r\n      AddPermissionsDialogComponent, \r\n      dialogConfig);\r\n    dialofRef.afterClosed().subscribe(res => {\r\n      // return click outside effect to work to close side menu when clicking out side it\r\n      this.permissionService.disableClickOutSide = false;\r\n      if(res) {\r\n        this.getPermissions()\r\n      }\r\n    })\r\n  }\r\n  checkIfUserCanDoActionsOnPermissions() {\r\n    this.evaluatorService.evaluateRule('isManagePermissionEnabled').then(isEnabled => {\r\n      if (isEnabled) {\r\n        let userInControllerGroup = false;\r\n        this.nuxeoService.nuxeoClient.user.userGroups.forEach(group => {\r\n          if (group.name === 'dms_document_controller') {\r\n            userInControllerGroup = true;\r\n          }\r\n        });\r\n        if (userInControllerGroup) {\r\n          let depCode = this.userServ.getUserDepartmentFromPath(this.document.path);\r\n          this.permissionService.getDepMembers(depCode).subscribe(res => {\r\n            this.permissionService.departmentUsers = res.users.map(e => {\r\n              e['displayLabel'] = e.properties.firstName + ' ' + e.properties.lastName;\r\n              return e;\r\n            });\r\n            this.allDepartmentUsers = [...this.permissionService.departmentUsers];\r\n            res.users.forEach(user => {\r\n              if (user.properties.username === this.nuxeoService.nuxeoClient.user.properties.username\r\n                && this.document.type === 'DmsFolder') {\r\n                this.allowAdd_Block_DeletePermission = true;\r\n              }\r\n            });\r\n          })\r\n        } else {\r\n          this.allowAdd_Block_DeletePermission = false;\r\n        }\r\n      } else {\r\n        this.allowAdd_Block_DeletePermission = false;\r\n      }\r\n    });\r\n  }\r\n  ngOnDestroy() {\r\n    // return click outside effect to work to close side menu when clicking out side it\r\n    this.permissionService.disableClickOutSide = false;\r\n    this.subscriptions$.forEach(e => e.unsubscribe())\r\n  }\r\n}\r\n","<div class=\"h-auto mt-3 px-0 pb-4\" *ngIf=\"!loading; else loader\">\r\n    <!--LocalPermission List Items-->\r\n    <div *ngIf=\"sourcePage != 'myFiles'\">\r\n        <div class=\"flex flex-row justify-between\">\r\n            <span class=\"font-bold text-gray-500 text-base\">{{\r\n                \"permission.local\" | translate\r\n            }}</span>\r\n            <span *ngIf=\"allowAdd_Block_DeletePermission && !inheritedPermissions.length\">\r\n                <button\r\n                    *ngIf=\"allowAddAndBlock\"\r\n                    class=\"hover:text-blue-700 text-blue-500 mb-1 text-base\"\r\n                    (click)=\"addNewLocalPermissions()\"\r\n                    [disabled]=\"!permissionsType\"\r\n                >\r\n                    {{ \"permission.new\" | translate }}\r\n                </button>\r\n            </span>\r\n        </div>\r\n        <mat-divider class=\"mat-divider\"></mat-divider>\r\n        <app-permissions-template\r\n            [documentId]=\"documentId\"\r\n            [userVisiblePermissions]=\"userVisiblePermissions\"\r\n            (getPermissions)=\"getPermissions()\"\r\n            [allowDeleteAndEdit]=\"allowAdd_Block_DeletePermission\"\r\n            [permissionsArray]=\"localPermissions\"\r\n            *ngIf=\"localPermissions.length > 0; else nolocalPermissions\"\r\n        >\r\n        </app-permissions-template>\r\n    </div>\r\n    <ng-template #nolocalPermissions>\r\n        <div class=\"single-permssion p-3 text-center\">\r\n            {{ \"permission.noLocal\" | translate }}\r\n        </div>\r\n    </ng-template>\r\n    <!--InheritedPermission List Items-->\r\n    <div>\r\n        <div class=\"flex flex-row justify-between mt-3\">\r\n            <span class=\"font-bold text-gray-500 text-base\">{{\r\n                \"permission.inherited\" | translate\r\n            }}</span>\r\n            <span *ngIf=\"allowAdd_Block_DeletePermission\">\r\n                <button\r\n                    class=\"hover:text-blue-700 text-blue-500 mb-1 text-base\"\r\n                    *ngIf=\"status != null && allowAddAndBlock\"\r\n                >\r\n                    <span\r\n                        *ngIf=\"status == 'block'; else unblock\"\r\n                        (click)=\"unblockPermissionInheritance()\"\r\n                    >\r\n                        {{ \"permission.unblock\" | translate }}\r\n                    </span>\r\n                    <ng-template #unblock>\r\n                        <span (click)=\"blockPermissionInheritance()\">\r\n                            {{ \"permission.block\" | translate }}\r\n                        </span>\r\n                    </ng-template>\r\n                </button>\r\n            </span>\r\n        </div>\r\n        <mat-divider class=\"mat-divider\" *ngIf=\"!blockOrUnblock\"></mat-divider>\r\n        <mat-progress-bar mode=\"indeterminate\" *ngIf=\"blockOrUnblock\"></mat-progress-bar>\r\n        <app-permissions-template\r\n            *ngIf=\"inheritedPermissions.length > 0; else noinheritedPermissions\"\r\n            [documentId]=\"documentId\"\r\n            [userVisiblePermissions]=\"userVisiblePermissions\"\r\n            [permissionsArray]=\"inheritedPermissions\"\r\n            (getPermissions)=\"getPermissions()\"\r\n        >\r\n        </app-permissions-template>\r\n    </div>\r\n    <ng-template #noinheritedPermissions>\r\n        <div class=\"single-permssion p-3 text-center\">\r\n            {{\"permission.noInherited\" | translate }}</div>\r\n    </ng-template>\r\n    <!--departmentPermissions List Items-->\r\n    <div *ngIf=\"departmentPermissions.length > 0\">\r\n        <div class=\"flex flex-row justify-between\">\r\n            <span class=\"font-bold text-gray-500 text-base\">{{\r\n                \"permission.departmentPermissions\" | translate\r\n            }}</span>\r\n        </div>\r\n        <mat-divider class=\"mat-divider\"></mat-divider>\r\n        <app-permissions-template\r\n            [documentId]=\"documentId\"\r\n            [userVisiblePermissions]=\"userVisiblePermissions\"\r\n            (getPermissions)=\"getPermissions()\"\r\n            [permissionsArray]=\"departmentPermissions\"\r\n        >\r\n        </app-permissions-template>\r\n    </div>\r\n    <!--sharePermissions List Items-->\r\n    <div *ngIf=\"sharePermissions.length > 0\">\r\n        <div class=\"flex flex-row justify-between\">\r\n            <span class=\"font-bold text-gray-500 text-base\">{{\r\n                \"permission.sharePermissions\" | translate\r\n            }}</span>\r\n        </div>\r\n        <mat-divider class=\"mat-divider\"></mat-divider>\r\n        <app-permissions-template\r\n            [documentId]=\"documentId\"\r\n            [userVisiblePermissions]=\"userVisiblePermissions\"\r\n            (getPermissions)=\"getPermissions()\"\r\n            [permissionsArray]=\"sharePermissions\"\r\n        >\r\n        </app-permissions-template>\r\n    </div>\r\n    <!--workflowPermissions List Items-->\r\n    <div *ngIf=\"workflowPermissions.length > 0\">\r\n        <div class=\"flex flex-row justify-between\">\r\n            <span class=\"font-bold text-gray-500 text-base\">{{\r\n                \"permission.workflowPermissions\" | translate\r\n            }}</span>\r\n        </div>\r\n        <mat-divider class=\"mat-divider\"></mat-divider>\r\n        <app-permissions-template\r\n            [documentId]=\"documentId\"\r\n            [userVisiblePermissions]=\"userVisiblePermissions\"\r\n            (getPermissions)=\"getPermissions()\"\r\n            [permissionsArray]=\"workflowPermissions\"\r\n        >\r\n        </app-permissions-template>\r\n    </div>\r\n</div>\r\n\r\n<ng-template #loader>\r\n    <div class=\"flex items-center justify-center w-full h-full\">\r\n        <mat-spinner [value]=\"90\" [strokeWidth]=\"6\" overlay=\"true\" [diameter]=\"75\"></mat-spinner>\r\n    </div>\r\n</ng-template>\r\n"]}
|
package/esm2015/lib/components/permissions/permissions-template/permissions-template.component.js
ADDED
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { Component, Input, EventEmitter, Output } from '@angular/core';
|
|
2
|
+
import { MatDialogConfig } from '@angular/material/dialog';
|
|
3
|
+
import { AddPermissionsDialogComponent } from '../add-permissions-dialog/add-permissions-dialog.component';
|
|
4
|
+
import { ConfirmationDialogComponent } from '../../confirmation-dialog/confirmation-dialog/confirmation-dialog.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../permission.service";
|
|
7
|
+
import * as i2 from "../../custom-toastr/services/custom-toastr.service";
|
|
8
|
+
import * as i3 from "@angular/material/dialog";
|
|
9
|
+
import * as i4 from "@angular/material/icon";
|
|
10
|
+
import * as i5 from "@angular/common";
|
|
11
|
+
import * as i6 from "@ngx-translate/core";
|
|
12
|
+
export class PermissionsTemplateComponent {
|
|
13
|
+
constructor(permissionService, tosterService, dialog) {
|
|
14
|
+
this.permissionService = permissionService;
|
|
15
|
+
this.tosterService = tosterService;
|
|
16
|
+
this.dialog = dialog;
|
|
17
|
+
this.allowDeleteAndEdit = false;
|
|
18
|
+
this.permissionsArray = [];
|
|
19
|
+
this.getPermissions = new EventEmitter();
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() {
|
|
22
|
+
}
|
|
23
|
+
deletePermission(permission) {
|
|
24
|
+
this.permissionService.deleteLocalPermissions(this.documentId, permission).subscribe(res => {
|
|
25
|
+
this.getPermissions.emit();
|
|
26
|
+
this.tosterService.show('success', 'TOASTER.SUCCESS', "TOASTER.PERMISSION_REMOVE_SUCCESS");
|
|
27
|
+
}, err => {
|
|
28
|
+
this.tosterService.show('error', 'TOASTER.ERROR', 'TOASTER.PERMISSION_REMOVE_FAIL');
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
editPermission(permission, username, userVisiblePermissions, begin, end) {
|
|
32
|
+
const dialogConfig = new MatDialogConfig();
|
|
33
|
+
dialogConfig.disableClose = false;
|
|
34
|
+
dialogConfig.autoFocus = true;
|
|
35
|
+
dialogConfig.data = {
|
|
36
|
+
id: this.documentId,
|
|
37
|
+
rights: this.userVisiblePermissions,
|
|
38
|
+
state: "update",
|
|
39
|
+
aclId: permission,
|
|
40
|
+
username: username,
|
|
41
|
+
editableRight: userVisiblePermissions,
|
|
42
|
+
editableBegin: begin,
|
|
43
|
+
editableEnd: end,
|
|
44
|
+
};
|
|
45
|
+
dialogConfig.width = '35%';
|
|
46
|
+
dialogConfig.height = '70%';
|
|
47
|
+
// befor opening modal we diable clickout side effect to prevent details side menu from closing when clicking in the modal
|
|
48
|
+
this.permissionService.disableClickOutSide = true;
|
|
49
|
+
let addDialogRef = this.dialog.open(AddPermissionsDialogComponent, dialogConfig);
|
|
50
|
+
addDialogRef.afterClosed().subscribe(res => {
|
|
51
|
+
// return click outside effect to work to close side menu when clicking out side it
|
|
52
|
+
this.permissionService.disableClickOutSide = false;
|
|
53
|
+
this.getPermissions.emit();
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
openDialog(permission) {
|
|
57
|
+
// befor opening modal we diable clickout side effect to prevent details side menu from closing when clicking in the modal
|
|
58
|
+
this.permissionService.disableClickOutSide = true;
|
|
59
|
+
let dialogRef = this.dialog.open(ConfirmationDialogComponent, {
|
|
60
|
+
width: '510px',
|
|
61
|
+
data: {
|
|
62
|
+
title: 'confirmDialog.confirm',
|
|
63
|
+
message: 'confirmDialog.Rem_Per',
|
|
64
|
+
confirmButton: `BUTTONS.Remove`,
|
|
65
|
+
cancelButton: "BUTTONS.Cancel"
|
|
66
|
+
},
|
|
67
|
+
disableClose: true,
|
|
68
|
+
});
|
|
69
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
70
|
+
// return click outside effect to work to close side menu when clicking out side it
|
|
71
|
+
this.permissionService.disableClickOutSide = false;
|
|
72
|
+
if (result) {
|
|
73
|
+
this.deletePermission(permission);
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
// const dialogRef = this.fuseConfirmationService.open(
|
|
77
|
+
// {
|
|
78
|
+
// dismissible: true,
|
|
79
|
+
// title: this.translateService.instant("confirmDialog.confirm"),
|
|
80
|
+
// message: this.translateService.instant("confirmDialog.Rem_Per"),
|
|
81
|
+
// actions: {
|
|
82
|
+
// confirm: {
|
|
83
|
+
// show: true,
|
|
84
|
+
// label: this.translateService.instant("BUTTONS.Remove"),
|
|
85
|
+
// color: "warn"
|
|
86
|
+
// },
|
|
87
|
+
// cancel: {
|
|
88
|
+
// show: true,
|
|
89
|
+
// label: this.translateService.instant("BUTTONS.Cancel"),
|
|
90
|
+
// }
|
|
91
|
+
// }
|
|
92
|
+
// }
|
|
93
|
+
// );
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
PermissionsTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PermissionsTemplateComponent, deps: [{ token: i1.PermissionService }, { token: i2.CustomToastrService }, { token: i3.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
97
|
+
PermissionsTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: PermissionsTemplateComponent, selector: "app-permissions-template", inputs: { allowDeleteAndEdit: "allowDeleteAndEdit", documentId: "documentId", userVisiblePermissions: "userVisiblePermissions", permissionsArray: "permissionsArray" }, outputs: { getPermissions: "getPermissions" }, ngImport: i0, template: "<div class=\"flex flex-col\">\r\n <div *ngFor=\"let p of permissionsArray\">\r\n <!-- Info -->\r\n <div class=\"flex single-permssion\" *ngIf=\"(p.granted && p.username['entity-type']== 'user') || (p.granted && (p.username['entity-type']== 'group' && (p.username.id != 'administrators' && p.username.id != 'members')))\">\r\n <mat-icon>lock</mat-icon>\r\n <div class=\"flex flex-auto justify-between ml-3\">\r\n <!-- Info -->\r\n <div>\r\n <div class=\"font-bold text-base text-gray-900 w-64\">\r\n <span *ngIf=\"p.username['entity-type'] == 'user'; else group\">\r\n {{p.username.fullName}}\r\n </span>\r\n <ng-template #group>\r\n {{p.username.grouplabel}}\r\n </ng-template>\r\n - {{p.permissionLabel}}</div>\r\n <div class=\"mt-0.5 text-secondary\">\r\n <div class=\"flex flex-row gap-x-14\">\r\n <div class=\"flex flex-col\">\r\n <div *ngIf=\"p.begin != null;else permanent\">\r\n {{p.begin | date:'dd/MM/yyyy'}}\r\n <span *ngIf=\"p.end != null\">- {{ p.end | date:'dd/MM/yyyy' }}</span>\r\n </div>\r\n <ng-template #permanent>\r\n <h1>{{\"permission.permanent\" | translate }}</h1>\r\n </ng-template>\r\n <div class=\"text-secondary\" *ngIf=\"p.creator != null\">{{\"permission.granted\" | translate }} {{p.creator['fullName']}}</div>\r\n </div>\r\n <!-- Actions -->\r\n <div class=\"flex\" *ngIf=\"allowDeleteAndEdit && p.currentUserIsPermissionOwner \r\n && p.permission != 'Everything'\">\r\n <button mat-icon-button\r\n (click)=\"editPermission(p.id,p.username,p.permission,p.begin,p.end)\">\r\n <mat-icon [svgIcon]=\"'heroicons_outline:pencil-alt'\"></mat-icon>\r\n </button>\r\n \r\n <button mat-icon-button (click)=\"openDialog(p.id)\">\r\n <mat-icon [svgIcon]=\"'heroicons_outline:trash'\"></mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".single-permssion{box-shadow:0 0 12.5px #0000001a;border-radius:8px;padding:15px;margin:10px;font-size:12px}\n"], components: [{ type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "date": i5.DatePipe, "translate": i6.TranslatePipe } });
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PermissionsTemplateComponent, decorators: [{
|
|
99
|
+
type: Component,
|
|
100
|
+
args: [{
|
|
101
|
+
selector: 'app-permissions-template',
|
|
102
|
+
templateUrl: './permissions-template.component.html',
|
|
103
|
+
styleUrls: ['./permissions-template.component.scss']
|
|
104
|
+
}]
|
|
105
|
+
}], ctorParameters: function () { return [{ type: i1.PermissionService }, { type: i2.CustomToastrService }, { type: i3.MatDialog }]; }, propDecorators: { allowDeleteAndEdit: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], documentId: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], userVisiblePermissions: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], permissionsArray: [{
|
|
112
|
+
type: Input,
|
|
113
|
+
args: ['permissionsArray']
|
|
114
|
+
}], getPermissions: [{
|
|
115
|
+
type: Output
|
|
116
|
+
}] } });
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permissions-template.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/permissions/permissions-template/permissions-template.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/permissions/permissions-template/permissions-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, EventEmitter, Output } from '@angular/core';\r\nimport { MatDialog, MatDialogConfig } from '@angular/material/dialog';\r\nimport { PermissionService } from '../permission.service';\r\nimport { AddPermissionsDialogComponent } from '../add-permissions-dialog/add-permissions-dialog.component';\r\nimport { CustomToastrService } from '../../custom-toastr/services/custom-toastr.service';\r\nimport { ConfirmationDialogComponent } from '../../confirmation-dialog/confirmation-dialog/confirmation-dialog.component';\r\n\r\n@Component({\r\n  selector: 'app-permissions-template',\r\n  templateUrl: './permissions-template.component.html',\r\n  styleUrls: ['./permissions-template.component.scss']\r\n})\r\nexport class PermissionsTemplateComponent implements OnInit {\r\n\r\n  @Input() allowDeleteAndEdit = false;\r\n  @Input() documentId;\r\n  @Input() userVisiblePermissions;\r\n  @Input('permissionsArray') permissionsArray = [];\r\n  @Output() getPermissions = new EventEmitter();\r\n  constructor(private permissionService: PermissionService,\r\n    private tosterService: CustomToastrService,\r\n    private dialog: MatDialog) { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  deletePermission(permission) {\r\n  this.permissionService.deleteLocalPermissions(this.documentId, permission).subscribe(\r\n    res => {\r\n      this.getPermissions.emit();\r\n      this.tosterService.show('success', 'TOASTER.SUCCESS', \"TOASTER.PERMISSION_REMOVE_SUCCESS\")\r\n    }, err => {\r\n      this.tosterService.show('error', 'TOASTER.ERROR', 'TOASTER.PERMISSION_REMOVE_FAIL');\r\n    })\r\n  }\r\n\r\n  editPermission(permission, username, userVisiblePermissions, begin, end) {\r\n    const dialogConfig = new MatDialogConfig();\r\n    dialogConfig.disableClose = false;\r\n    dialogConfig.autoFocus = true;\r\n    dialogConfig.data = {\r\n      id: this.documentId,\r\n      rights: this.userVisiblePermissions,\r\n      state: \"update\",\r\n      aclId: permission,\r\n      username: username,\r\n      editableRight: userVisiblePermissions,\r\n      editableBegin: begin,\r\n      editableEnd: end,\r\n    };\r\n    dialogConfig.width = '35%';\r\n    dialogConfig.height = '70%';\r\n    // befor opening modal we diable clickout side effect to prevent details side menu from closing when clicking in the modal\r\n    this.permissionService.disableClickOutSide = true;\r\n    let addDialogRef = this.dialog.open(AddPermissionsDialogComponent, dialogConfig);\r\n    addDialogRef.afterClosed().subscribe(res => {\r\n      // return click outside effect to work to close side menu when clicking out side it\r\n      this.permissionService.disableClickOutSide = false;\r\n      this.getPermissions.emit()\r\n    })\r\n  }\r\n\r\n  openDialog(permission) {\r\n    // befor opening modal we diable clickout side effect to prevent details side menu from closing when clicking in the modal\r\n    this.permissionService.disableClickOutSide = true;\r\n    let dialogRef = this.dialog.open(ConfirmationDialogComponent, {\r\n      width: '510px',\r\n      data: {\r\n          title: 'confirmDialog.confirm',\r\n          message: 'confirmDialog.Rem_Per',\r\n          confirmButton : `BUTTONS.Remove`,\r\n          cancelButton : \"BUTTONS.Cancel\"\r\n      },\r\n      disableClose: true,\r\n  });\r\n  dialogRef.afterClosed().subscribe((result) => {\r\n    // return click outside effect to work to close side menu when clicking out side it\r\n    this.permissionService.disableClickOutSide = false;\r\n    if (result) {\r\n      this.deletePermission(permission)\r\n    }\r\n  });\r\n    // const dialogRef = this.fuseConfirmationService.open(\r\n    //   {\r\n    //     dismissible: true,\r\n    //     title: this.translateService.instant(\"confirmDialog.confirm\"),\r\n    //     message: this.translateService.instant(\"confirmDialog.Rem_Per\"),\r\n    //     actions: {\r\n    //       confirm: {\r\n    //         show: true,\r\n    //         label: this.translateService.instant(\"BUTTONS.Remove\"),\r\n    //         color: \"warn\"\r\n    //       },\r\n    //       cancel: {\r\n    //         show: true,\r\n    //         label: this.translateService.instant(\"BUTTONS.Cancel\"),\r\n    //       }\r\n    //     }\r\n    //   }\r\n    // );\r\n\r\n  }\r\n\r\n}\r\n","<div class=\"flex flex-col\">\r\n    <div *ngFor=\"let p of permissionsArray\">\r\n        <!-- Info -->\r\n        <div class=\"flex single-permssion\" *ngIf=\"(p.granted && p.username['entity-type']== 'user') || (p.granted && (p.username['entity-type']== 'group' && (p.username.id != 'administrators' && p.username.id != 'members')))\">\r\n            <mat-icon>lock</mat-icon>\r\n            <div class=\"flex flex-auto justify-between ml-3\">\r\n                <!-- Info -->\r\n                <div>\r\n                    <div class=\"font-bold text-base text-gray-900 w-64\">\r\n                        <span *ngIf=\"p.username['entity-type'] == 'user'; else group\">\r\n                            {{p.username.fullName}}\r\n                        </span>\r\n                        <ng-template #group>\r\n                            {{p.username.grouplabel}}\r\n                        </ng-template>\r\n                        - {{p.permissionLabel}}</div>\r\n                    <div class=\"mt-0.5 text-secondary\">\r\n                        <div class=\"flex flex-row gap-x-14\">\r\n                            <div class=\"flex flex-col\">\r\n                                <div *ngIf=\"p.begin != null;else permanent\">\r\n                                    {{p.begin | date:'dd/MM/yyyy'}}\r\n                                    <span *ngIf=\"p.end != null\">- {{ p.end | date:'dd/MM/yyyy' }}</span>\r\n                                </div>\r\n                                <ng-template #permanent>\r\n                                    <h1>{{\"permission.permanent\" | translate }}</h1>\r\n                                </ng-template>\r\n                                <div class=\"text-secondary\" *ngIf=\"p.creator != null\">{{\"permission.granted\" | translate }} {{p.creator['fullName']}}</div>\r\n                            </div>\r\n                            <!-- Actions -->\r\n                            <div class=\"flex\" *ngIf=\"allowDeleteAndEdit && p.currentUserIsPermissionOwner \r\n                            && p.permission != 'Everything'\">\r\n                                <button mat-icon-button\r\n                                    (click)=\"editPermission(p.id,p.username,p.permission,p.begin,p.end)\">\r\n                                    <mat-icon [svgIcon]=\"'heroicons_outline:pencil-alt'\"></mat-icon>\r\n                                </button>\r\n                                \r\n                                <button mat-icon-button (click)=\"openDialog(p.id)\">\r\n                                    <mat-icon [svgIcon]=\"'heroicons_outline:trash'\"></mat-icon>\r\n                                </button>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { PermissionsComponent } from './permissions/permissions.component';
|
|
4
|
+
import { AddPermissionsDialogComponent } from './add-permissions-dialog/add-permissions-dialog.component';
|
|
5
|
+
import { PermissionsTemplateComponent } from './permissions-template/permissions-template.component';
|
|
6
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
7
|
+
import { MatDividerModule } from '@angular/material/divider';
|
|
8
|
+
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
9
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
10
|
+
import { SharedServicesModule } from '../../shared-services/shared-services.module';
|
|
11
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
12
|
+
import { PipesModule } from '../../pipes/pipes.module';
|
|
13
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
14
|
+
import { DirectiveModule } from '../../directive/directive.module';
|
|
15
|
+
import { NgSelectModule } from '@ng-select/ng-select';
|
|
16
|
+
import { AvatarModule } from '../avatar/avatar.module';
|
|
17
|
+
import * as i0 from "@angular/core";
|
|
18
|
+
export class PermissionsModule {
|
|
19
|
+
}
|
|
20
|
+
PermissionsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PermissionsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
21
|
+
PermissionsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PermissionsModule, declarations: [PermissionsComponent, AddPermissionsDialogComponent, PermissionsTemplateComponent], imports: [CommonModule,
|
|
22
|
+
TranslateModule,
|
|
23
|
+
MatDividerModule,
|
|
24
|
+
MatProgressBarModule,
|
|
25
|
+
MatProgressSpinnerModule,
|
|
26
|
+
SharedServicesModule,
|
|
27
|
+
MatIconModule,
|
|
28
|
+
PipesModule,
|
|
29
|
+
FormsModule,
|
|
30
|
+
ReactiveFormsModule,
|
|
31
|
+
DirectiveModule,
|
|
32
|
+
NgSelectModule,
|
|
33
|
+
AvatarModule], exports: [PermissionsComponent, AddPermissionsDialogComponent, PermissionsTemplateComponent] });
|
|
34
|
+
PermissionsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PermissionsModule, imports: [[
|
|
35
|
+
CommonModule,
|
|
36
|
+
TranslateModule,
|
|
37
|
+
MatDividerModule,
|
|
38
|
+
MatProgressBarModule,
|
|
39
|
+
MatProgressSpinnerModule,
|
|
40
|
+
SharedServicesModule,
|
|
41
|
+
MatIconModule,
|
|
42
|
+
PipesModule,
|
|
43
|
+
FormsModule,
|
|
44
|
+
ReactiveFormsModule,
|
|
45
|
+
DirectiveModule,
|
|
46
|
+
NgSelectModule,
|
|
47
|
+
AvatarModule
|
|
48
|
+
]] });
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: PermissionsModule, decorators: [{
|
|
50
|
+
type: NgModule,
|
|
51
|
+
args: [{
|
|
52
|
+
declarations: [PermissionsComponent, AddPermissionsDialogComponent, PermissionsTemplateComponent],
|
|
53
|
+
imports: [
|
|
54
|
+
CommonModule,
|
|
55
|
+
TranslateModule,
|
|
56
|
+
MatDividerModule,
|
|
57
|
+
MatProgressBarModule,
|
|
58
|
+
MatProgressSpinnerModule,
|
|
59
|
+
SharedServicesModule,
|
|
60
|
+
MatIconModule,
|
|
61
|
+
PipesModule,
|
|
62
|
+
FormsModule,
|
|
63
|
+
ReactiveFormsModule,
|
|
64
|
+
DirectiveModule,
|
|
65
|
+
NgSelectModule,
|
|
66
|
+
AvatarModule
|
|
67
|
+
],
|
|
68
|
+
exports: [PermissionsComponent, AddPermissionsDialogComponent, PermissionsTemplateComponent],
|
|
69
|
+
}]
|
|
70
|
+
}] });
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVybWlzc2lvbnMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9wZXJtaXNzaW9ucy9wZXJtaXNzaW9ucy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDM0UsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sMkRBQTJELENBQUM7QUFDMUcsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDckcsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3RFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQXVCdkQsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQWxCYixvQkFBb0IsRUFBRSw2QkFBNkIsRUFBQyw0QkFBNEIsYUFFN0YsWUFBWTtRQUNaLGVBQWU7UUFDZixnQkFBZ0I7UUFDaEIsb0JBQW9CO1FBQ3BCLHdCQUF3QjtRQUN4QixvQkFBb0I7UUFDcEIsYUFBYTtRQUNiLFdBQVc7UUFDWCxXQUFXO1FBQ1gsbUJBQW1CO1FBQ25CLGVBQWU7UUFDZixjQUFjO1FBQ2QsWUFBWSxhQUVILG9CQUFvQixFQUFFLDZCQUE2QixFQUFDLDRCQUE0QjsrR0FFaEYsaUJBQWlCLFlBakJuQjtZQUNQLFlBQVk7WUFDWixlQUFlO1lBQ2YsZ0JBQWdCO1lBQ2hCLG9CQUFvQjtZQUNwQix3QkFBd0I7WUFDeEIsb0JBQW9CO1lBQ3BCLGFBQWE7WUFDYixXQUFXO1lBQ1gsV0FBVztZQUNYLG1CQUFtQjtZQUNuQixlQUFlO1lBQ2YsY0FBYztZQUNkLFlBQVk7U0FDYjsyRkFHVSxpQkFBaUI7a0JBbkI3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLG9CQUFvQixFQUFFLDZCQUE2QixFQUFDLDRCQUE0QixDQUFDO29CQUNoRyxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGdCQUFnQjt3QkFDaEIsb0JBQW9CO3dCQUNwQix3QkFBd0I7d0JBQ3hCLG9CQUFvQjt3QkFDcEIsYUFBYTt3QkFDYixXQUFXO3dCQUNYLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixlQUFlO3dCQUNmLGNBQWM7d0JBQ2QsWUFBWTtxQkFDYjtvQkFDRCxPQUFPLEVBQUcsQ0FBQyxvQkFBb0IsRUFBRSw2QkFBNkIsRUFBQyw0QkFBNEIsQ0FBQztpQkFDN0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBQZXJtaXNzaW9uc0NvbXBvbmVudCB9IGZyb20gJy4vcGVybWlzc2lvbnMvcGVybWlzc2lvbnMuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQWRkUGVybWlzc2lvbnNEaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2FkZC1wZXJtaXNzaW9ucy1kaWFsb2cvYWRkLXBlcm1pc3Npb25zLWRpYWxvZy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBQZXJtaXNzaW9uc1RlbXBsYXRlQ29tcG9uZW50IH0gZnJvbSAnLi9wZXJtaXNzaW9ucy10ZW1wbGF0ZS9wZXJtaXNzaW9ucy10ZW1wbGF0ZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcclxuaW1wb3J0IHsgTWF0RGl2aWRlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpdmlkZXInO1xyXG5pbXBvcnQgeyBNYXRQcm9ncmVzc0Jhck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLWJhcic7XHJcbmltcG9ydCB7IE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXInO1xyXG5pbXBvcnQgeyBTaGFyZWRTZXJ2aWNlc01vZHVsZSB9IGZyb20gJy4uLy4uL3NoYXJlZC1zZXJ2aWNlcy9zaGFyZWQtc2VydmljZXMubW9kdWxlJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBQaXBlc01vZHVsZSB9IGZyb20gJy4uLy4uL3BpcGVzL3BpcGVzLm1vZHVsZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBEaXJlY3RpdmVNb2R1bGUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmUvZGlyZWN0aXZlLm1vZHVsZSc7XHJcbmltcG9ydCB7IE5nU2VsZWN0TW9kdWxlIH0gZnJvbSAnQG5nLXNlbGVjdC9uZy1zZWxlY3QnO1xyXG5pbXBvcnQgeyBBdmF0YXJNb2R1bGUgfSBmcm9tICcuLi9hdmF0YXIvYXZhdGFyLm1vZHVsZSc7XHJcblxyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbUGVybWlzc2lvbnNDb21wb25lbnQsIEFkZFBlcm1pc3Npb25zRGlhbG9nQ29tcG9uZW50LFBlcm1pc3Npb25zVGVtcGxhdGVDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcclxuICAgIE1hdERpdmlkZXJNb2R1bGUsXHJcbiAgICBNYXRQcm9ncmVzc0Jhck1vZHVsZSxcclxuICAgIE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZSxcclxuICAgIFNoYXJlZFNlcnZpY2VzTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIFBpcGVzTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgRGlyZWN0aXZlTW9kdWxlLFxyXG4gICAgTmdTZWxlY3RNb2R1bGUsXHJcbiAgICBBdmF0YXJNb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHMgOiBbUGVybWlzc2lvbnNDb21wb25lbnQgLEFkZFBlcm1pc3Npb25zRGlhbG9nQ29tcG9uZW50LFBlcm1pc3Npb25zVGVtcGxhdGVDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUGVybWlzc2lvbnNNb2R1bGUgeyB9XHJcbiJdfQ==
|
package/esm2015/lib/components/select-users-by-department/select-users-by-department.module.js
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { DynamicFormModule } from '../dynamic-form/dynamic-form.module';
|
|
5
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
6
|
+
import { NgSelectModule } from '@ng-select/ng-select';
|
|
7
|
+
import { AvatarModule } from '../avatar/avatar.module';
|
|
8
|
+
import { SelectUsersByDepartmentsComponent } from './select-users-by-departments/select-users-by-departments.component';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class SelectUsersByDepartmentModule {
|
|
11
|
+
}
|
|
12
|
+
SelectUsersByDepartmentModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: SelectUsersByDepartmentModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
SelectUsersByDepartmentModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: SelectUsersByDepartmentModule, declarations: [SelectUsersByDepartmentsComponent], imports: [CommonModule,
|
|
14
|
+
FormsModule,
|
|
15
|
+
ReactiveFormsModule,
|
|
16
|
+
DynamicFormModule,
|
|
17
|
+
TranslateModule,
|
|
18
|
+
NgSelectModule,
|
|
19
|
+
AvatarModule], exports: [SelectUsersByDepartmentsComponent] });
|
|
20
|
+
SelectUsersByDepartmentModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: SelectUsersByDepartmentModule, imports: [[
|
|
21
|
+
CommonModule,
|
|
22
|
+
FormsModule,
|
|
23
|
+
ReactiveFormsModule,
|
|
24
|
+
DynamicFormModule,
|
|
25
|
+
TranslateModule,
|
|
26
|
+
NgSelectModule,
|
|
27
|
+
AvatarModule
|
|
28
|
+
]] });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: SelectUsersByDepartmentModule, decorators: [{
|
|
30
|
+
type: NgModule,
|
|
31
|
+
args: [{
|
|
32
|
+
declarations: [SelectUsersByDepartmentsComponent],
|
|
33
|
+
imports: [
|
|
34
|
+
CommonModule,
|
|
35
|
+
FormsModule,
|
|
36
|
+
ReactiveFormsModule,
|
|
37
|
+
DynamicFormModule,
|
|
38
|
+
TranslateModule,
|
|
39
|
+
NgSelectModule,
|
|
40
|
+
AvatarModule
|
|
41
|
+
],
|
|
42
|
+
exports: [
|
|
43
|
+
SelectUsersByDepartmentsComponent
|
|
44
|
+
]
|
|
45
|
+
}]
|
|
46
|
+
}] });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LXVzZXJzLWJ5LWRlcGFydG1lbnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3QtdXNlcnMtYnktZGVwYXJ0bWVudC9zZWxlY3QtdXNlcnMtYnktZGVwYXJ0bWVudC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLHFFQUFxRSxDQUFDOztBQW1CeEgsTUFBTSxPQUFPLDZCQUE2Qjs7MEhBQTdCLDZCQUE2QjsySEFBN0IsNkJBQTZCLGlCQWR6QixpQ0FBaUMsYUFFOUMsWUFBWTtRQUNaLFdBQVc7UUFDWCxtQkFBbUI7UUFDbkIsaUJBQWlCO1FBQ2pCLGVBQWU7UUFDZixjQUFjO1FBQ2QsWUFBWSxhQUdaLGlDQUFpQzsySEFHeEIsNkJBQTZCLFlBYi9CO1lBQ1AsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsaUJBQWlCO1lBQ2pCLGVBQWU7WUFDZixjQUFjO1lBQ2QsWUFBWTtTQUNiOzJGQUtVLDZCQUE2QjtrQkFmekMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztvQkFDakQsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGlCQUFpQjt3QkFDakIsZUFBZTt3QkFDZixjQUFjO3dCQUNkLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFDO3dCQUNOLGlDQUFpQztxQkFDbEM7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgRHluYW1pY0Zvcm1Nb2R1bGUgfSBmcm9tICcuLi9keW5hbWljLWZvcm0vZHluYW1pYy1mb3JtLm1vZHVsZSc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5pbXBvcnQgeyBOZ1NlbGVjdE1vZHVsZSB9IGZyb20gJ0BuZy1zZWxlY3Qvbmctc2VsZWN0JztcclxuaW1wb3J0IHsgQXZhdGFyTW9kdWxlIH0gZnJvbSAnLi4vYXZhdGFyL2F2YXRhci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTZWxlY3RVc2Vyc0J5RGVwYXJ0bWVudHNDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC11c2Vycy1ieS1kZXBhcnRtZW50cy9zZWxlY3QtdXNlcnMtYnktZGVwYXJ0bWVudHMuY29tcG9uZW50JztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtTZWxlY3RVc2Vyc0J5RGVwYXJ0bWVudHNDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIER5bmFtaWNGb3JtTW9kdWxlLFxyXG4gICAgVHJhbnNsYXRlTW9kdWxlLFxyXG4gICAgTmdTZWxlY3RNb2R1bGUsXHJcbiAgICBBdmF0YXJNb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHM6W1xyXG4gICAgU2VsZWN0VXNlcnNCeURlcGFydG1lbnRzQ29tcG9uZW50XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2VsZWN0VXNlcnNCeURlcGFydG1lbnRNb2R1bGUgeyB9XHJcbiJdfQ==
|