From 60ca20e2d98578c830571c395fd747a63531af11 Mon Sep 17 00:00:00 2001 From: Dan Briem Date: Thu, 1 Apr 2021 09:38:41 -0400 Subject: [PATCH] LP#1920815 Item edit link displayed for all users The Angular catalog item table doesn't check UPDATE_COPY perm before displaying an edit link. The back-end checks, so this is a display issue only. This commit grabs a list of org Ids where the user has UPDATE_COPY perm and checks the copy circ lib or cn owning lib is in the list before displaying the edit link. To test: 1. Search for a record with items you don't have perm to edit 2. Note the edit link shows on every item 3. Apply patch 4. Repeat steps 1-2 5. Note edit link displays if you have perm to edit Signed-off-by: Dan Briem Signed-off-by: Michele Morgan Signed-off-by: Galen Charlton --- .../src/app/staff/catalog/record/copies.component.html | 16 +++++++++------- .../eg2/src/app/staff/catalog/record/copies.component.ts | 16 +++++++++++++++- 2 files changed, 24 insertions(+), 8 deletions(-) diff --git a/Open-ILS/src/eg2/src/app/staff/catalog/record/copies.component.html b/Open-ILS/src/eg2/src/app/staff/catalog/record/copies.component.html index 55c4e655c9..94795fe84d 100644 --- a/Open-ILS/src/eg2/src/app/staff/catalog/record/copies.component.html +++ b/Open-ILS/src/eg2/src/app/staff/catalog/record/copies.component.html @@ -4,14 +4,16 @@ {{copy.call_number_suffix_label}} - +
{{copy.barcode}}
- View - | - Edit + View + + | + Edit +
@@ -58,7 +60,7 @@ + [cellTemplate]="barcodeTemplate" [cellContext]="copyContext"> diff --git a/Open-ILS/src/eg2/src/app/staff/catalog/record/copies.component.ts b/Open-ILS/src/eg2/src/app/staff/catalog/record/copies.component.ts index 3ad8322686..bb535918fe 100644 --- a/Open-ILS/src/eg2/src/app/staff/catalog/record/copies.component.ts +++ b/Open-ILS/src/eg2/src/app/staff/catalog/record/copies.component.ts @@ -9,6 +9,7 @@ import {GridDataSource, GridColumn, GridCellTextGenerator} from '@eg/share/grid/ import {GridComponent} from '@eg/share/grid/grid.component'; import {BroadcastService} from '@eg/share/util/broadcast.service'; import {CourseService} from '@eg/staff/share/course.service'; +import {PermService} from '@eg/core/perm.service'; @Component({ selector: 'eg-catalog-copies', @@ -19,6 +20,7 @@ export class CopiesComponent implements OnInit { recId: number; initDone = false; usingCourseModule = false; + editableCopyLibs: number[] = []; gridDataSource: GridDataSource; copyContext: any; // grid context @ViewChild('copyGrid', { static: true }) copyGrid: GridComponent; @@ -41,7 +43,8 @@ export class CopiesComponent implements OnInit { private net: NetService, private org: OrgService, private staffCat: StaffCatalogService, - private broadcaster: BroadcastService + private broadcaster: BroadcastService, + private perm: PermService ) { this.gridDataSource = new GridDataSource(); } @@ -52,12 +55,23 @@ export class CopiesComponent implements OnInit { this.usingCourseModule = res; }); + this.perm.hasWorkPermAt(['UPDATE_COPY'], true) + .then(result => { + this.editableCopyLibs = result.UPDATE_COPY as number[]; + }); + this.gridDataSource.getRows = (pager: Pager, sort: any[]) => { // sorting not currently supported return this.fetchCopies(pager); }; this.copyContext = { + editable: (copy: any) => { + return this.editableCopyLibs.some(lib => { + return copy.circ_lib === lib + || copy.call_number_owning_lib === lib; + }); + }, holdable: (copy: any) => { return copy.holdable === 't' && copy.location_holdable === 't' -- 2.11.0