mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-13 13:03:04 +00:00
95 lines
3.4 KiB
TypeScript
95 lines
3.4 KiB
TypeScript
import { Component } from '@angular/core';
|
|
import { ActivatedRoute, Router } from '@angular/router';
|
|
import { TranslateService } from '@ngx-translate/core';
|
|
|
|
import { AbstractSimpleItemActionComponent } from '../simple-item-action/abstract-simple-item-action.component';
|
|
import { RemoteData } from '../../../core/data/remote-data';
|
|
import { Item } from '../../../core/shared/item.model';
|
|
import { NotificationsService } from '../../../shared/notifications/notifications.service';
|
|
import { ItemDataService } from '../../../core/data/item-data.service';
|
|
import { getFirstCompletedRemoteData, getFirstSucceededRemoteData } from '../../../core/shared/operators';
|
|
import { first, map } from 'rxjs/operators';
|
|
import { hasValue } from '../../../shared/empty.util';
|
|
import { Observable } from 'rxjs';
|
|
import { getItemPageRoute } from '../../item-page-routing-paths';
|
|
import { IdentifierDataService } from '../../../core/data/identifier-data.service';
|
|
import { Identifier } from '../../../shared/object-list/identifier-data/identifier.model';
|
|
|
|
@Component({
|
|
selector: 'ds-item-register-doi',
|
|
templateUrl: './item-register-doi-component.html'
|
|
})
|
|
/**
|
|
* Component responsible for rendering the Item Registe DOI page
|
|
*/
|
|
export class ItemRegisterDoiComponent extends AbstractSimpleItemActionComponent {
|
|
|
|
protected messageKey = 'registerdoi';
|
|
doiToUpdateMessage = 'item.edit.' + this.messageKey + '.to-update';
|
|
identifiers$: Observable<Identifier[]>;
|
|
processing = false;
|
|
|
|
constructor(protected route: ActivatedRoute,
|
|
protected router: Router,
|
|
protected notificationsService: NotificationsService,
|
|
protected itemDataService: ItemDataService,
|
|
protected translateService: TranslateService,
|
|
protected identifierDataService: IdentifierDataService) {
|
|
super(route, router, notificationsService, itemDataService, translateService);
|
|
}
|
|
|
|
/**
|
|
* Initialise component
|
|
*/
|
|
ngOnInit(): void {
|
|
this.itemRD$ = this.route.data.pipe(
|
|
map((data) => data.dso),
|
|
getFirstSucceededRemoteData()
|
|
)as Observable<RemoteData<Item>>;
|
|
|
|
this.itemRD$.pipe(first()).subscribe((rd) => {
|
|
this.item = rd.payload;
|
|
this.itemPageRoute = getItemPageRoute(this.item);
|
|
this.identifiers$ = this.identifierDataService.getIdentifierDataFor(this.item).pipe(
|
|
map((identifierRD) => {
|
|
if (identifierRD.statusCode !== 401 && hasValue(identifierRD.payload)) {
|
|
return identifierRD.payload.identifiers;
|
|
} else {
|
|
return null;
|
|
}
|
|
}),
|
|
);
|
|
}
|
|
);
|
|
|
|
this.confirmMessage = 'item.edit.' + this.messageKey + '.confirm';
|
|
this.cancelMessage = 'item.edit.' + this.messageKey + '.cancel';
|
|
this.headerMessage = 'item.edit.' + this.messageKey + '.header';
|
|
this.descriptionMessage = 'item.edit.' + this.messageKey + '.description';
|
|
|
|
|
|
}
|
|
|
|
/**
|
|
* Perform the register DOI action to the item
|
|
*/
|
|
performAction() {
|
|
this.registerDoi();
|
|
}
|
|
|
|
/**
|
|
* Request that a pending, minted or null DOI be queued for registration
|
|
*/
|
|
registerDoi() {
|
|
this.processing = true;
|
|
this.itemDataService.registerDOI(this.item.id).pipe(getFirstCompletedRemoteData()).subscribe(
|
|
(response: RemoteData<Item>) => {
|
|
this.processing = false;
|
|
//this.router.navigateByUrl(getItemEditRoute(this.item));
|
|
this.processRestResponse(response);
|
|
}
|
|
);
|
|
}
|
|
|
|
}
|