From b1f4a90a582f54cb0bd106e77c9cdf6c6c8c283f Mon Sep 17 00:00:00 2001
From: Samuel <samuel@atmire.com>
Date: Tue, 26 Nov 2019 17:31:47 +0100
Subject: [PATCH] taskid 66074 Keep virtual metadata on relationship delete -
 fix lint issues

---
 .../edit-item-page/edit-item-page.module.ts   |  2 +-
 .../edit-relationship-list.component.ts       |  4 ++--
 .../edit-relationship.component.ts            | 21 +++++++++----------
 .../item-relationships.component.ts           |  4 ++--
 .../virtual-metadata.component.ts             | 16 +++++++-------
 .../object-updates/object-updates.reducer.ts  |  2 +-
 .../object-updates/object-updates.service.ts  | 10 ++++-----
 src/app/core/data/relationship.service.ts     |  2 +-
 8 files changed, 30 insertions(+), 31 deletions(-)

diff --git a/src/app/+item-page/edit-item-page/edit-item-page.module.ts b/src/app/+item-page/edit-item-page/edit-item-page.module.ts
index 6d86e7f35c..5eda9aef10 100644
--- a/src/app/+item-page/edit-item-page/edit-item-page.module.ts
+++ b/src/app/+item-page/edit-item-page/edit-item-page.module.ts
@@ -21,7 +21,7 @@ import { ItemRelationshipsComponent } from './item-relationships/item-relationsh
 import { EditRelationshipComponent } from './item-relationships/edit-relationship/edit-relationship.component';
 import { EditRelationshipListComponent } from './item-relationships/edit-relationship-list/edit-relationship-list.component';
 import { ItemMoveComponent } from './item-move/item-move.component';
-import {VirtualMetadataComponent} from "./virtual-metadata/virtual-metadata.component";
+import {VirtualMetadataComponent} from './virtual-metadata/virtual-metadata.component';
 
 /**
  * Module that contains all components related to the Edit Item page administrator functionality
diff --git a/src/app/+item-page/edit-item-page/item-relationships/edit-relationship-list/edit-relationship-list.component.ts b/src/app/+item-page/edit-item-page/item-relationships/edit-relationship-list/edit-relationship-list.component.ts
index e7d1a14200..7645b2b4b7 100644
--- a/src/app/+item-page/edit-item-page/item-relationships/edit-relationship-list/edit-relationship-list.component.ts
+++ b/src/app/+item-page/edit-item-page/item-relationships/edit-relationship-list/edit-relationship-list.component.ts
@@ -6,7 +6,7 @@ import { RelationshipService } from '../../../../core/data/relationship.service'
 import { Item } from '../../../../core/shared/item.model';
 import { map, switchMap} from 'rxjs/operators';
 import { hasValue } from '../../../../shared/empty.util';
-import {Relationship} from "../../../../core/shared/item-relationships/relationship.model";
+import {Relationship} from '../../../../core/shared/item-relationships/relationship.model';
 
 @Component({
   selector: 'ds-edit-relationship-list',
@@ -66,7 +66,7 @@ export class EditRelationshipListComponent implements OnInit, OnChanges {
    */
   public getUpdatesByLabel(label: string): Observable<FieldUpdates> {
     return this.relationshipService.getItemRelationshipsByLabel(this.item, label).pipe(
-      map(relationsRD => relationsRD.payload.page.map(relationship =>
+      map((relationsRD) => relationsRD.payload.page.map((relationship) =>
         Object.assign(new Relationship(), relationship, {uuid: relationship.id})
       )),
       switchMap((initialFields) => this.objectUpdatesService.getFieldUpdatesExclusive(this.url, initialFields)),
diff --git a/src/app/+item-page/edit-item-page/item-relationships/edit-relationship/edit-relationship.component.ts b/src/app/+item-page/edit-item-page/item-relationships/edit-relationship/edit-relationship.component.ts
index 7c1780da58..220582a5fd 100644
--- a/src/app/+item-page/edit-item-page/item-relationships/edit-relationship/edit-relationship.component.ts
+++ b/src/app/+item-page/edit-item-page/item-relationships/edit-relationship/edit-relationship.component.ts
@@ -9,7 +9,7 @@ import {Item} from '../../../../core/shared/item.model';
 import {getRemoteDataPayload, getSucceededRemoteData} from '../../../../core/shared/operators';
 import {ViewMode} from '../../../../core/shared/view-mode.model';
 import {hasValue, isNotEmpty} from '../../../../shared/empty.util';
-import {NgbModal, NgbModalRef} from "@ng-bootstrap/ng-bootstrap";
+import {NgbModal, NgbModalRef} from '@ng-bootstrap/ng-bootstrap';
 
 @Component({
   // tslint:disable-next-line:component-selector
@@ -53,6 +53,11 @@ export class EditRelationshipComponent implements OnChanges {
    */
   viewMode = ViewMode.ListElement;
 
+  /**
+   * Reference to NgbModal
+   */
+  public modalRef: NgbModalRef;
+
   constructor(
     private objectUpdatesService: ObjectUpdatesService,
     private modalService: NgbModal,
@@ -93,17 +98,16 @@ export class EditRelationshipComponent implements OnChanges {
       this.rightItem$,
     ).pipe(
       map((items: Item[]) =>
-        items.map(item => this.objectUpdatesService
+        items.map((item) => this.objectUpdatesService
           .isSelectedVirtualMetadataItem(this.url, this.relationship.id, item.uuid))
       ),
-      switchMap((selection$: Observable<boolean>[]) => observableCombineLatest(selection$)),
+      switchMap((selection$) => observableCombineLatest(selection$)),
       map((selection: boolean[]) => {
         return Object.assign({},
           this.fieldUpdate.field,
           {
-            uuid: this.relationship.id,
-            keepLeftVirtualMetadata: selection[0] == true,
-            keepRightVirtualMetadata: selection[1] == true,
+            keepLeftVirtualMetadata: selection[0] === true,
+            keepRightVirtualMetadata: selection[1] === true,
           }
         ) as DeleteRelationship
       }),
@@ -113,11 +117,6 @@ export class EditRelationshipComponent implements OnChanges {
     );
   }
 
-  /**
-   * Reference to NgbModal
-   */
-  public modalRef: NgbModalRef;
-
   openVirtualMetadataModal(content: any) {
     this.modalRef = this.modalService.open(content);
   }
diff --git a/src/app/+item-page/edit-item-page/item-relationships/item-relationships.component.ts b/src/app/+item-page/edit-item-page/item-relationships/item-relationships.component.ts
index 92b138e962..fadba3b981 100644
--- a/src/app/+item-page/edit-item-page/item-relationships/item-relationships.component.ts
+++ b/src/app/+item-page/edit-item-page/item-relationships/item-relationships.component.ts
@@ -110,7 +110,7 @@ export class ItemRelationshipsComponent extends AbstractItemUpdateComponent impl
   public submit(): void {
     // Get all the relationships that should be removed
     const removedRelationshipIDs$ = this.relationshipService.getItemRelationshipsArray(this.item).pipe(
-      map((relationships: Relationship[]) => relationships.map(relationship =>
+      map((relationships: Relationship[]) => relationships.map((relationship) =>
         Object.assign(new Relationship(), relationship, {uuid: relationship.id})
       )),
       switchMap((relationships: Relationship[]) => {
@@ -124,7 +124,7 @@ export class ItemRelationshipsComponent extends AbstractItemUpdateComponent impl
       take(1),
       switchMap((deleteRelationships: DeleteRelationship[]) =>
         observableZip(...deleteRelationships.map((deleteRelationship) => {
-            let copyVirtualMetadata : string;
+            let copyVirtualMetadata: string;
             if (deleteRelationship.keepLeftVirtualMetadata && deleteRelationship.keepRightVirtualMetadata) {
               copyVirtualMetadata = 'all';
             } else if (deleteRelationship.keepLeftVirtualMetadata) {
diff --git a/src/app/+item-page/edit-item-page/virtual-metadata/virtual-metadata.component.ts b/src/app/+item-page/edit-item-page/virtual-metadata/virtual-metadata.component.ts
index c3379750a2..170c3aec0c 100644
--- a/src/app/+item-page/edit-item-page/virtual-metadata/virtual-metadata.component.ts
+++ b/src/app/+item-page/edit-item-page/virtual-metadata/virtual-metadata.component.ts
@@ -1,11 +1,11 @@
 import {Component, EventEmitter, Input, OnChanges, Output} from '@angular/core';
 import {ActivatedRoute} from '@angular/router';
 import {Observable} from 'rxjs';
-import {Item} from "../../../core/shared/item.model";
-import {Relationship} from "../../../core/shared/item-relationships/relationship.model";
-import {MetadataValue} from "../../../core/shared/metadata.models";
-import {getRemoteDataPayload, getSucceededRemoteData} from "../../../core/shared/operators";
-import {ObjectUpdatesService} from "../../../core/data/object-updates/object-updates.service";
+import {Item} from '../../../core/shared/item.model';
+import {Relationship} from '../../../core/shared/item-relationships/relationship.model';
+import {MetadataValue} from '../../../core/shared/metadata.models';
+import {getRemoteDataPayload, getSucceededRemoteData} from '../../../core/shared/operators';
+import {ObjectUpdatesService} from '../../../core/data/object-updates/object-updates.service';
 
 @Component({
   selector: 'ds-virtual-metadata',
@@ -26,15 +26,15 @@ export class VirtualMetadataComponent implements OnChanges {
   @Output() close = new EventEmitter();
   @Output() save = new EventEmitter();
 
+  leftItem$: Observable<Item>;
+  rightItem$: Observable<Item>;
+
   constructor(
     protected route: ActivatedRoute,
     protected objectUpdatesService: ObjectUpdatesService,
   ) {
   }
 
-  leftItem$: Observable<Item>;
-  rightItem$: Observable<Item>;
-
   ngOnChanges(): void {
     this.leftItem$ = this.relationship.leftItem.pipe(
       getSucceededRemoteData(),
diff --git a/src/app/core/data/object-updates/object-updates.reducer.ts b/src/app/core/data/object-updates/object-updates.reducer.ts
index 41d1704797..daf7555692 100644
--- a/src/app/core/data/object-updates/object-updates.reducer.ts
+++ b/src/app/core/data/object-updates/object-updates.reducer.ts
@@ -13,7 +13,7 @@ import {
   SelectVirtualMetadataAction,
 } from './object-updates.actions';
 import { hasNoValue, hasValue } from '../../../shared/empty.util';
-import {Relationship} from "../../shared/item-relationships/relationship.model";
+import {Relationship} from '../../shared/item-relationships/relationship.model';
 
 /**
  * Path where discarded objects are saved
diff --git a/src/app/core/data/object-updates/object-updates.service.ts b/src/app/core/data/object-updates/object-updates.service.ts
index 0e8b1c8d07..5063a8a005 100644
--- a/src/app/core/data/object-updates/object-updates.service.ts
+++ b/src/app/core/data/object-updates/object-updates.service.ts
@@ -26,10 +26,10 @@ import {
 import {distinctUntilChanged, filter, map} from 'rxjs/operators';
 import {hasNoValue, hasValue, isEmpty, isNotEmpty} from '../../../shared/empty.util';
 import {INotification} from '../../../shared/notifications/models/notification.model';
-import {Item} from "../../shared/item.model";
-import {Relationship} from "../../shared/item-relationships/relationship.model";
-import {MetadataValue} from "../../shared/metadata.models";
-import {VirtualMetadata} from "../../../+item-page/edit-item-page/virtual-metadata/virtual-metadata.component";
+import {Item} from '../../shared/item.model';
+import {Relationship} from '../../shared/item-relationships/relationship.model';
+import {MetadataValue} from '../../shared/metadata.models';
+import {VirtualMetadata} from '../../../+item-page/edit-item-page/virtual-metadata/virtual-metadata.component';
 
 function objectUpdatesStateSelector(): MemoizedSelector<CoreState, ObjectUpdatesState> {
   return createSelector(coreSelector, (state: CoreState) => state['cache/object-updates']);
@@ -226,7 +226,7 @@ export class ObjectUpdatesService {
     return this.store
       .pipe(
         select(virtualMetadataSourceSelector(url, relationship)),
-        map(virtualMetadataSource => virtualMetadataSource && virtualMetadataSource[item]),
+        map((virtualMetadataSource) => virtualMetadataSource && virtualMetadataSource[item]),
     );
   }
 
diff --git a/src/app/core/data/relationship.service.ts b/src/app/core/data/relationship.service.ts
index a4a24e8aaa..895cb46ed1 100644
--- a/src/app/core/data/relationship.service.ts
+++ b/src/app/core/data/relationship.service.ts
@@ -88,7 +88,7 @@ export class RelationshipService extends DataService<Relationship> {
       isNotEmptyOperator(),
       distinctUntilChanged(),
       map((endpointURL: string) =>
-        new DeleteRequest(this.requestService.generateRequestId(), endpointURL + "?copyVirtualMetadata=" + copyVirtualMetadata)
+        new DeleteRequest(this.requestService.generateRequestId(), endpointURL + '?copyVirtualMetadata=' + copyVirtualMetadata)
       ),
       configureRequest(this.requestService),
       switchMap((restRequest: RestRequest) => this.requestService.getByUUID(restRequest.uuid)),
-- 
GitLab