mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 01:54:15 +00:00
195 lines
7.0 KiB
TypeScript
195 lines
7.0 KiB
TypeScript
import { Injectable } from '@angular/core';
|
|
import { ItemDataService } from './item-data.service';
|
|
import { UpdateDataService } from './update-data.service';
|
|
import { Item } from '../shared/item.model';
|
|
import { RestRequestMethod } from './rest-request-method';
|
|
import { RemoteData } from './remote-data';
|
|
import { Observable } from 'rxjs/internal/Observable';
|
|
import { DSOChangeAnalyzer } from './dso-change-analyzer.service';
|
|
import { RequestService } from './request.service';
|
|
import { RemoteDataBuildService } from '../cache/builders/remote-data-build.service';
|
|
import { Store } from '@ngrx/store';
|
|
import { CoreState } from '../core.reducers';
|
|
import { ObjectCacheService } from '../cache/object-cache.service';
|
|
import { HALEndpointService } from '../shared/hal-endpoint.service';
|
|
import { NotificationsService } from '../../shared/notifications/notifications.service';
|
|
import { HttpClient } from '@angular/common/http';
|
|
import { BrowseService } from '../browse/browse.service';
|
|
import { CollectionDataService } from './collection-data.service';
|
|
import { switchMap, map } from 'rxjs/operators';
|
|
import { BundleDataService } from './bundle-data.service';
|
|
import { FollowLinkConfig } from '../../shared/utils/follow-link-config.model';
|
|
import { RestResponse } from '../cache/response.models';
|
|
|
|
/* tslint:disable:max-classes-per-file */
|
|
/**
|
|
* A custom implementation of the ItemDataService, but for collection item templates
|
|
* Makes sure to change the endpoint before sending out CRUD requests for the item template
|
|
*/
|
|
class DataServiceImpl extends ItemDataService {
|
|
protected collectionLinkPath = 'itemtemplate';
|
|
protected linkPath = 'itemtemplates';
|
|
|
|
/**
|
|
* Endpoint dynamically changing depending on what request we're sending
|
|
*/
|
|
private endpoint$: Observable<string>;
|
|
|
|
/**
|
|
* Is the current endpoint based on a collection?
|
|
*/
|
|
private collectionEndpoint = false;
|
|
|
|
constructor(
|
|
protected requestService: RequestService,
|
|
protected rdbService: RemoteDataBuildService,
|
|
protected store: Store<CoreState>,
|
|
protected bs: BrowseService,
|
|
protected objectCache: ObjectCacheService,
|
|
protected halService: HALEndpointService,
|
|
protected notificationsService: NotificationsService,
|
|
protected http: HttpClient,
|
|
protected comparator: DSOChangeAnalyzer<Item>,
|
|
protected bundleService: BundleDataService,
|
|
protected collectionService: CollectionDataService) {
|
|
super(requestService, rdbService, store, bs, objectCache, halService, notificationsService, http, comparator, bundleService);
|
|
}
|
|
|
|
/**
|
|
* Set the endpoint to be based on a collection
|
|
* @param collectionID The ID of the collection to base the endpoint on
|
|
*/
|
|
private setCollectionEndpoint(collectionID: string) {
|
|
this.collectionEndpoint = true;
|
|
this.endpoint$ = this.collectionService.getIDHrefObs(collectionID).pipe(
|
|
switchMap((href: string) => this.halService.getEndpoint(this.collectionLinkPath, href))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Set the endpoint to the regular linkPath
|
|
*/
|
|
private setRegularEndpoint() {
|
|
this.collectionEndpoint = false;
|
|
this.endpoint$ = this.halService.getEndpoint(this.linkPath);
|
|
}
|
|
|
|
/**
|
|
* Get the base endpoint for all requests
|
|
* Uses the current collectionID to assemble a request endpoint for the collection's item template
|
|
*/
|
|
protected getEndpoint(): Observable<string> {
|
|
return this.endpoint$;
|
|
}
|
|
|
|
/**
|
|
* If the current endpoint is based on a collection, simply return the collection's template endpoint, otherwise
|
|
* create a regular template endpoint
|
|
* @param resourceID
|
|
*/
|
|
getIDHrefObs(resourceID: string): Observable<string> {
|
|
if (this.collectionEndpoint) {
|
|
return this.getEndpoint();
|
|
} else {
|
|
return super.getIDHrefObs(resourceID);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Set the collection ID and send a find by ID request
|
|
* @param collectionID
|
|
* @param linksToFollow List of {@link FollowLinkConfig} that indicate which {@link HALLink}s should be automatically resolved
|
|
*/
|
|
findByCollectionID(collectionID: string, ...linksToFollow: Array<FollowLinkConfig<Item>>): Observable<RemoteData<Item>> {
|
|
this.setCollectionEndpoint(collectionID);
|
|
return super.findById(collectionID, ...linksToFollow);
|
|
}
|
|
|
|
/**
|
|
* Set the collection ID and send a create request
|
|
* @param item
|
|
* @param collectionID
|
|
*/
|
|
createTemplate(item: Item, collectionID: string): Observable<RemoteData<Item>> {
|
|
this.setCollectionEndpoint(collectionID);
|
|
return super.create(item);
|
|
}
|
|
|
|
/**
|
|
* Set the collection ID and send a delete request
|
|
* @param item
|
|
* @param collectionID
|
|
*/
|
|
deleteByCollectionID(item: Item, collectionID: string): Observable<boolean> {
|
|
this.setRegularEndpoint();
|
|
return super.delete(item.uuid).pipe(map((response: RestResponse) => response.isSuccessful));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* A service responsible for fetching/sending data from/to the REST API on a collection's itemtemplates endpoint
|
|
*/
|
|
@Injectable()
|
|
export class ItemTemplateDataService implements UpdateDataService<Item> {
|
|
/**
|
|
* The data service responsible for all CRUD actions on the item
|
|
*/
|
|
private dataService: DataServiceImpl;
|
|
|
|
constructor(
|
|
protected requestService: RequestService,
|
|
protected rdbService: RemoteDataBuildService,
|
|
protected store: Store<CoreState>,
|
|
protected bs: BrowseService,
|
|
protected objectCache: ObjectCacheService,
|
|
protected halService: HALEndpointService,
|
|
protected notificationsService: NotificationsService,
|
|
protected http: HttpClient,
|
|
protected comparator: DSOChangeAnalyzer<Item>,
|
|
protected bundleService: BundleDataService,
|
|
protected collectionService: CollectionDataService) {
|
|
this.dataService = new DataServiceImpl(requestService, rdbService, store, bs, objectCache, halService, notificationsService, http, comparator, bundleService, collectionService);
|
|
}
|
|
|
|
/**
|
|
* Commit current object changes to the server
|
|
*/
|
|
commitUpdates(method?: RestRequestMethod) {
|
|
this.dataService.commitUpdates(method);
|
|
}
|
|
|
|
/**
|
|
* Add a new patch to the object cache
|
|
*/
|
|
update(object: Item): Observable<RemoteData<Item>> {
|
|
return this.dataService.update(object);
|
|
}
|
|
|
|
/**
|
|
* Find an item template by collection ID
|
|
* @param collectionID
|
|
* @param linksToFollow List of {@link FollowLinkConfig} that indicate which {@link HALLink}s should be automatically resolved
|
|
*/
|
|
findByCollectionID(collectionID: string, ...linksToFollow: Array<FollowLinkConfig<Item>>): Observable<RemoteData<Item>> {
|
|
return this.dataService.findByCollectionID(collectionID, ...linksToFollow);
|
|
}
|
|
|
|
/**
|
|
* Create a new item template for a collection by ID
|
|
* @param item
|
|
* @param collectionID
|
|
*/
|
|
create(item: Item, collectionID: string): Observable<RemoteData<Item>> {
|
|
return this.dataService.createTemplate(item, collectionID);
|
|
}
|
|
|
|
/**
|
|
* Delete a template item by collection ID
|
|
* @param item
|
|
* @param collectionID
|
|
*/
|
|
deleteByCollectionID(item: Item, collectionID: string): Observable<boolean> {
|
|
return this.dataService.deleteByCollectionID(item, collectionID);
|
|
}
|
|
}
|