mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 18:14:17 +00:00
taskid 66074 Keep virtual metadata on relationship delete - fix lint issues
This commit is contained in:
@@ -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
|
||||||
|
@@ -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)),
|
||||||
|
@@ -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);
|
||||||
}
|
}
|
||||||
|
@@ -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) {
|
||||||
|
@@ -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(),
|
||||||
|
@@ -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
|
||||||
|
@@ -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]),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -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)),
|
||||||
|
Reference in New Issue
Block a user