From 8e3931558634ec98e9f7c916235eb51c413d8feb Mon Sep 17 00:00:00 2001 From: Dominik Bruhn Date: Tue, 16 Apr 2024 23:41:15 +0200 Subject: [PATCH] Enhancement: Hide columns in document list if user does not have permissions (#6415) --------- Co-authored-by: Dominik Bruhn Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com> --- src-ui/messages.xlf | 60 ++++++------- .../document-list.component.html | 84 +++++++++++-------- .../document-list.component.spec.ts | 23 +++-- .../document-list/document-list.component.ts | 4 +- 4 files changed, 96 insertions(+), 75 deletions(-) diff --git a/src-ui/messages.xlf b/src-ui/messages.xlf index 0855a0dcf..7461baf9c 100644 --- a/src-ui/messages.xlf +++ b/src-ui/messages.xlf @@ -608,7 +608,7 @@ src/app/components/admin/users-groups/users-groups.component.html - 94 + 92 src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.html @@ -943,7 +943,7 @@ src/app/components/document-list/document-list.component.html - 173 + 175 src/app/services/rest/document.service.ts @@ -1241,7 +1241,7 @@ src/app/components/admin/users-groups/users-groups.component.html - 59 + 58 src/app/components/common/edit-dialog/correspondent-edit-dialog/correspondent-edit-dialog.component.html @@ -1377,7 +1377,7 @@ src/app/components/admin/users-groups/users-groups.component.html - 62 + 61 src/app/components/common/edit-dialog/workflow-edit-dialog/workflow-edit-dialog.component.html @@ -1436,7 +1436,7 @@ src/app/components/admin/users-groups/users-groups.component.html - 77 + 76 src/app/components/common/edit-dialog/mail-rule-edit-dialog/mail-rule-edit-dialog.component.ts @@ -1674,7 +1674,7 @@ src/app/components/document-list/document-list.component.html - 195 + 201 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -1900,7 +1900,7 @@ src/app/components/admin/users-groups/users-groups.component.html - 74 + 73 src/app/components/common/input/permissions/permissions-form/permissions-form.component.html @@ -1978,7 +1978,7 @@ No groups defined src/app/components/admin/users-groups/users-groups.component.html - 85 + 84 @@ -2251,7 +2251,7 @@ src/app/components/document-list/document-list.component.ts - 97 + 103 src/app/components/manage/management-list/management-list.component.html @@ -4811,7 +4811,7 @@ src/app/components/document-list/document-list.component.html - 158 + 160 src/app/components/document-list/filter-editor/filter-editor.component.ts @@ -4838,7 +4838,7 @@ src/app/components/document-list/document-list.component.html - 150 + 151 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -5163,7 +5163,7 @@ src/app/components/document-list/document-list.component.html - 181 + 184 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -5186,7 +5186,7 @@ src/app/components/document-list/document-list.component.html - 188 + 193 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -5858,7 +5858,7 @@ src/app/components/document-list/document-list.component.html - 218 + 225 @@ -5869,7 +5869,7 @@ src/app/components/document-list/document-list.component.html - 224 + 232 @@ -5894,7 +5894,7 @@ src/app/components/document-list/document-list.component.html - 243 + 252 @@ -5905,7 +5905,7 @@ src/app/components/document-list/document-list.component.html - 248 + 259 @@ -6098,28 +6098,28 @@ Sort by correspondent src/app/components/document-list/document-list.component.html - 146 + 147 Sort by title src/app/components/document-list/document-list.component.html - 153 + 155 Sort by owner src/app/components/document-list/document-list.component.html - 161 + 163 Owner src/app/components/document-list/document-list.component.html - 165 + 167 src/app/services/rest/document.service.ts @@ -6130,42 +6130,42 @@ Sort by notes src/app/components/document-list/document-list.component.html - 169 + 171 Sort by document type src/app/components/document-list/document-list.component.html - 177 + 180 Sort by storage path src/app/components/document-list/document-list.component.html - 184 + 189 Sort by created date src/app/components/document-list/document-list.component.html - 191 + 197 Sort by added date src/app/components/document-list/document-list.component.html - 198 + 204 Added src/app/components/document-list/document-list.component.html - 202 + 208 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -6180,21 +6180,21 @@ Edit document src/app/components/document-list/document-list.component.html - 222 + 230 View "" saved successfully. src/app/components/document-list/document-list.component.ts - 207 + 213 View "" created successfully. src/app/components/document-list/document-list.component.ts - 248 + 254 diff --git a/src-ui/src/app/components/document-list/document-list.component.html b/src-ui/src/app/components/document-list/document-list.component.html index 1cfa4fff9..3cce1496b 100644 --- a/src-ui/src/app/components/document-list/document-list.component.html +++ b/src-ui/src/app/components/document-list/document-list.component.html @@ -141,13 +141,15 @@ [currentSortReverse]="list.sortReverse" (sort)="onSort($event)" i18n>ASN - Correspondent + @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.Correspondent)) { + Correspondent + } Notes } - Document type - Storage path + @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.DocumentType)) { + Document type + } + @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.StoragePath)) { + Storage path + } {{d.archive_serial_number}} - - @if (d.correspondent) { - {{(d.correspondent$ | async)?.name}} - } - + @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.Correspondent)) { + + @if (d.correspondent) { + {{(d.correspondent$ | async)?.name}} + } + + } {{d.title | documentTitle}} @for (t of d.tags$ | async; track t) { @@ -238,16 +246,20 @@ } } - - @if (d.document_type) { - {{(d.document_type$ | async)?.name}} - } - - - @if (d.storage_path) { - {{(d.storage_path$ | async)?.name}} - } - + @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.DocumentType)) { + + @if (d.document_type) { + {{(d.document_type$ | async)?.name}} + } + + } + @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.StoragePath)) { + + @if (d.storage_path) { + {{(d.storage_path$ | async)?.name}} + } + + } {{d.created_date | customDate}} diff --git a/src-ui/src/app/components/document-list/document-list.component.spec.ts b/src-ui/src/app/components/document-list/document-list.component.spec.ts index bf21616e8..77dc03f84 100644 --- a/src-ui/src/app/components/document-list/document-list.component.spec.ts +++ b/src-ui/src/app/components/document-list/document-list.component.spec.ts @@ -64,6 +64,8 @@ import { SettingsService } from 'src/app/services/settings.service' import { SETTINGS_KEYS } from 'src/app/data/ui-settings' import { IsNumberPipe } from 'src/app/pipes/is-number.pipe' import { NgxBootstrapIconsModule, allIcons } from 'ngx-bootstrap-icons' +import { PermissionsService } from 'src/app/services/permissions.service' +import { NgSelectModule } from '@ng-select/ng-select' const docs: Document[] = [ { @@ -101,6 +103,7 @@ describe('DocumentListComponent', () => { let toastService: ToastService let modalService: NgbModal let settingsService: SettingsService + let permissionService: PermissionsService beforeEach(async () => { TestBed.configureTestingModule({ @@ -148,6 +151,7 @@ describe('DocumentListComponent', () => { NgbPopoverModule, NgbTooltipModule, NgxBootstrapIconsModule.pick(allIcons), + NgSelectModule, ], }).compileComponents() @@ -160,6 +164,7 @@ describe('DocumentListComponent', () => { toastService = TestBed.inject(ToastService) modalService = TestBed.inject(NgbModal) settingsService = TestBed.inject(SettingsService) + permissionService = TestBed.inject(PermissionsService) fixture = TestBed.createComponent(DocumentListComponent) component = fixture.componentInstance }) @@ -548,18 +553,13 @@ describe('DocumentListComponent', () => { expect(routerSpy).toHaveBeenCalledWith(['documents', 99]) }) - it('should support checking if notes enabled to hide column', () => { + it('should hide columns if no perms or notes disabled', () => { + jest.spyOn(permissionService, 'currentUserCan').mockReturnValue(true) jest.spyOn(documentListService, 'documents', 'get').mockReturnValue(docs) - fixture.detectChanges() expect(documentListService.sortField).toEqual('created') - const detailsDisplayModeButton = fixture.debugElement.query( - By.css('input[type="radio"]') - ) - detailsDisplayModeButton.nativeElement.checked = true - detailsDisplayModeButton.triggerEventHandler('change') + component.displayMode = 'details' fixture.detectChanges() - expect(component.displayMode).toEqual('details') expect( fixture.debugElement.queryAll(By.directive(SortableDirective)) @@ -572,6 +572,13 @@ describe('DocumentListComponent', () => { expect( fixture.debugElement.queryAll(By.directive(SortableDirective)) ).toHaveLength(8) + + // insufficient perms + jest.spyOn(permissionService, 'currentUserCan').mockReturnValue(false) + fixture.detectChanges() + expect( + fixture.debugElement.queryAll(By.directive(SortableDirective)) + ).toHaveLength(5) }) it('should support toggle on document objects', () => { diff --git a/src-ui/src/app/components/document-list/document-list.component.ts b/src-ui/src/app/components/document-list/document-list.component.ts index 537e24601..7d27f4e3e 100644 --- a/src-ui/src/app/components/document-list/document-list.component.ts +++ b/src-ui/src/app/components/document-list/document-list.component.ts @@ -29,6 +29,7 @@ import { DOCUMENT_SORT_FIELDS, DOCUMENT_SORT_FIELDS_FULLTEXT, } from 'src/app/services/rest/document.service' +import { PermissionsService } from 'src/app/services/permissions.service' import { SavedViewService } from 'src/app/services/rest/saved-view.service' import { SettingsService } from 'src/app/services/settings.service' import { ToastService } from 'src/app/services/toast.service' @@ -54,7 +55,8 @@ export class DocumentListComponent private modalService: NgbModal, private consumerStatusService: ConsumerStatusService, public openDocumentsService: OpenDocumentsService, - private settingsService: SettingsService + private settingsService: SettingsService, + public permissionService: PermissionsService ) { super() }