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