taskid 66074 Keep virtual metadata on relationship delete - fix lint issues

This commit is contained in:
Samuel
2019-11-26 17:31:47 +01:00
parent ae476baa62
commit b1f4a90a58
8 changed files with 30 additions and 31 deletions

View File

@@ -21,7 +21,7 @@ import { ItemRelationshipsComponent } from './item-relationships/item-relationsh
import { EditRelationshipComponent } from './item-relationships/edit-relationship/edit-relationship.component'; import { EditRelationshipComponent } from './item-relationships/edit-relationship/edit-relationship.component';
import { EditRelationshipListComponent } from './item-relationships/edit-relationship-list/edit-relationship-list.component'; import { EditRelationshipListComponent } from './item-relationships/edit-relationship-list/edit-relationship-list.component';
import { ItemMoveComponent } from './item-move/item-move.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 * Module that contains all components related to the Edit Item page administrator functionality

View File

@@ -6,7 +6,7 @@ import { RelationshipService } from '../../../../core/data/relationship.service'
import { Item } from '../../../../core/shared/item.model'; import { Item } from '../../../../core/shared/item.model';
import { map, switchMap} from 'rxjs/operators'; import { map, switchMap} from 'rxjs/operators';
import { hasValue } from '../../../../shared/empty.util'; 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({ @Component({
selector: 'ds-edit-relationship-list', selector: 'ds-edit-relationship-list',
@@ -66,7 +66,7 @@ export class EditRelationshipListComponent implements OnInit, OnChanges {
*/ */
public getUpdatesByLabel(label: string): Observable<FieldUpdates> { public getUpdatesByLabel(label: string): Observable<FieldUpdates> {
return this.relationshipService.getItemRelationshipsByLabel(this.item, label).pipe( 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}) Object.assign(new Relationship(), relationship, {uuid: relationship.id})
)), )),
switchMap((initialFields) => this.objectUpdatesService.getFieldUpdatesExclusive(this.url, initialFields)), switchMap((initialFields) => this.objectUpdatesService.getFieldUpdatesExclusive(this.url, initialFields)),

View File

@@ -9,7 +9,7 @@ import {Item} from '../../../../core/shared/item.model';
import {getRemoteDataPayload, getSucceededRemoteData} from '../../../../core/shared/operators'; import {getRemoteDataPayload, getSucceededRemoteData} from '../../../../core/shared/operators';
import {ViewMode} from '../../../../core/shared/view-mode.model'; import {ViewMode} from '../../../../core/shared/view-mode.model';
import {hasValue, isNotEmpty} from '../../../../shared/empty.util'; import {hasValue, isNotEmpty} from '../../../../shared/empty.util';
import {NgbModal, NgbModalRef} from "@ng-bootstrap/ng-bootstrap"; import {NgbModal, NgbModalRef} from '@ng-bootstrap/ng-bootstrap';
@Component({ @Component({
// tslint:disable-next-line:component-selector // tslint:disable-next-line:component-selector
@@ -53,6 +53,11 @@ export class EditRelationshipComponent implements OnChanges {
*/ */
viewMode = ViewMode.ListElement; viewMode = ViewMode.ListElement;
/**
* Reference to NgbModal
*/
public modalRef: NgbModalRef;
constructor( constructor(
private objectUpdatesService: ObjectUpdatesService, private objectUpdatesService: ObjectUpdatesService,
private modalService: NgbModal, private modalService: NgbModal,
@@ -93,17 +98,16 @@ export class EditRelationshipComponent implements OnChanges {
this.rightItem$, this.rightItem$,
).pipe( ).pipe(
map((items: Item[]) => map((items: Item[]) =>
items.map(item => this.objectUpdatesService items.map((item) => this.objectUpdatesService
.isSelectedVirtualMetadataItem(this.url, this.relationship.id, item.uuid)) .isSelectedVirtualMetadataItem(this.url, this.relationship.id, item.uuid))
), ),
switchMap((selection$: Observable<boolean>[]) => observableCombineLatest(selection$)), switchMap((selection$) => observableCombineLatest(selection$)),
map((selection: boolean[]) => { map((selection: boolean[]) => {
return Object.assign({}, return Object.assign({},
this.fieldUpdate.field, this.fieldUpdate.field,
{ {
uuid: this.relationship.id, keepLeftVirtualMetadata: selection[0] === true,
keepLeftVirtualMetadata: selection[0] == true, keepRightVirtualMetadata: selection[1] === true,
keepRightVirtualMetadata: selection[1] == true,
} }
) as DeleteRelationship ) as DeleteRelationship
}), }),
@@ -113,11 +117,6 @@ export class EditRelationshipComponent implements OnChanges {
); );
} }
/**
* Reference to NgbModal
*/
public modalRef: NgbModalRef;
openVirtualMetadataModal(content: any) { openVirtualMetadataModal(content: any) {
this.modalRef = this.modalService.open(content); this.modalRef = this.modalService.open(content);
} }

View File

@@ -110,7 +110,7 @@ export class ItemRelationshipsComponent extends AbstractItemUpdateComponent impl
public submit(): void { public submit(): void {
// Get all the relationships that should be removed // Get all the relationships that should be removed
const removedRelationshipIDs$ = this.relationshipService.getItemRelationshipsArray(this.item).pipe( 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}) Object.assign(new Relationship(), relationship, {uuid: relationship.id})
)), )),
switchMap((relationships: Relationship[]) => { switchMap((relationships: Relationship[]) => {
@@ -124,7 +124,7 @@ export class ItemRelationshipsComponent extends AbstractItemUpdateComponent impl
take(1), take(1),
switchMap((deleteRelationships: DeleteRelationship[]) => switchMap((deleteRelationships: DeleteRelationship[]) =>
observableZip(...deleteRelationships.map((deleteRelationship) => { observableZip(...deleteRelationships.map((deleteRelationship) => {
let copyVirtualMetadata : string; let copyVirtualMetadata: string;
if (deleteRelationship.keepLeftVirtualMetadata && deleteRelationship.keepRightVirtualMetadata) { if (deleteRelationship.keepLeftVirtualMetadata && deleteRelationship.keepRightVirtualMetadata) {
copyVirtualMetadata = 'all'; copyVirtualMetadata = 'all';
} else if (deleteRelationship.keepLeftVirtualMetadata) { } else if (deleteRelationship.keepLeftVirtualMetadata) {

View File

@@ -1,11 +1,11 @@
import {Component, EventEmitter, Input, OnChanges, Output} from '@angular/core'; import {Component, EventEmitter, Input, OnChanges, Output} from '@angular/core';
import {ActivatedRoute} from '@angular/router'; import {ActivatedRoute} from '@angular/router';
import {Observable} from 'rxjs'; import {Observable} from 'rxjs';
import {Item} from "../../../core/shared/item.model"; import {Item} from '../../../core/shared/item.model';
import {Relationship} from "../../../core/shared/item-relationships/relationship.model"; import {Relationship} from '../../../core/shared/item-relationships/relationship.model';
import {MetadataValue} from "../../../core/shared/metadata.models"; import {MetadataValue} from '../../../core/shared/metadata.models';
import {getRemoteDataPayload, getSucceededRemoteData} from "../../../core/shared/operators"; import {getRemoteDataPayload, getSucceededRemoteData} from '../../../core/shared/operators';
import {ObjectUpdatesService} from "../../../core/data/object-updates/object-updates.service"; import {ObjectUpdatesService} from '../../../core/data/object-updates/object-updates.service';
@Component({ @Component({
selector: 'ds-virtual-metadata', selector: 'ds-virtual-metadata',
@@ -26,15 +26,15 @@ export class VirtualMetadataComponent implements OnChanges {
@Output() close = new EventEmitter(); @Output() close = new EventEmitter();
@Output() save = new EventEmitter(); @Output() save = new EventEmitter();
leftItem$: Observable<Item>;
rightItem$: Observable<Item>;
constructor( constructor(
protected route: ActivatedRoute, protected route: ActivatedRoute,
protected objectUpdatesService: ObjectUpdatesService, protected objectUpdatesService: ObjectUpdatesService,
) { ) {
} }
leftItem$: Observable<Item>;
rightItem$: Observable<Item>;
ngOnChanges(): void { ngOnChanges(): void {
this.leftItem$ = this.relationship.leftItem.pipe( this.leftItem$ = this.relationship.leftItem.pipe(
getSucceededRemoteData(), getSucceededRemoteData(),

View File

@@ -13,7 +13,7 @@ import {
SelectVirtualMetadataAction, SelectVirtualMetadataAction,
} from './object-updates.actions'; } from './object-updates.actions';
import { hasNoValue, hasValue } from '../../../shared/empty.util'; 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 * Path where discarded objects are saved

View File

@@ -26,10 +26,10 @@ import {
import {distinctUntilChanged, filter, map} from 'rxjs/operators'; import {distinctUntilChanged, filter, map} from 'rxjs/operators';
import {hasNoValue, hasValue, isEmpty, isNotEmpty} from '../../../shared/empty.util'; import {hasNoValue, hasValue, isEmpty, isNotEmpty} from '../../../shared/empty.util';
import {INotification} from '../../../shared/notifications/models/notification.model'; import {INotification} from '../../../shared/notifications/models/notification.model';
import {Item} from "../../shared/item.model"; import {Item} from '../../shared/item.model';
import {Relationship} from "../../shared/item-relationships/relationship.model"; import {Relationship} from '../../shared/item-relationships/relationship.model';
import {MetadataValue} from "../../shared/metadata.models"; import {MetadataValue} from '../../shared/metadata.models';
import {VirtualMetadata} from "../../../+item-page/edit-item-page/virtual-metadata/virtual-metadata.component"; import {VirtualMetadata} from '../../../+item-page/edit-item-page/virtual-metadata/virtual-metadata.component';
function objectUpdatesStateSelector(): MemoizedSelector<CoreState, ObjectUpdatesState> { function objectUpdatesStateSelector(): MemoizedSelector<CoreState, ObjectUpdatesState> {
return createSelector(coreSelector, (state: CoreState) => state['cache/object-updates']); return createSelector(coreSelector, (state: CoreState) => state['cache/object-updates']);
@@ -226,7 +226,7 @@ export class ObjectUpdatesService {
return this.store return this.store
.pipe( .pipe(
select(virtualMetadataSourceSelector(url, relationship)), select(virtualMetadataSourceSelector(url, relationship)),
map(virtualMetadataSource => virtualMetadataSource && virtualMetadataSource[item]), map((virtualMetadataSource) => virtualMetadataSource && virtualMetadataSource[item]),
); );
} }

View File

@@ -88,7 +88,7 @@ export class RelationshipService extends DataService<Relationship> {
isNotEmptyOperator(), isNotEmptyOperator(),
distinctUntilChanged(), distinctUntilChanged(),
map((endpointURL: string) => map((endpointURL: string) =>
new DeleteRequest(this.requestService.generateRequestId(), endpointURL + "?copyVirtualMetadata=" + copyVirtualMetadata) new DeleteRequest(this.requestService.generateRequestId(), endpointURL + '?copyVirtualMetadata=' + copyVirtualMetadata)
), ),
configureRequest(this.requestService), configureRequest(this.requestService),
switchMap((restRequest: RestRequest) => this.requestService.getByUUID(restRequest.uuid)), switchMap((restRequest: RestRequest) => this.requestService.getByUUID(restRequest.uuid)),