2019-01-18 18:03:45 +01:00
|
|
|
import { HttpClient, HttpHeaders, HttpResponse } from '@angular/common/http';
|
|
|
|
import { Injectable } from '@angular/core';
|
2023-12-01 18:18:41 +01:00
|
|
|
import { DmpUserRole } from '@app/core/common/enum/dmp-user-role';
|
2023-11-29 14:26:40 +01:00
|
|
|
import { IsActive } from '@app/core/common/enum/is-active.enum';
|
|
|
|
import { UserInfoListingModel } from '@app/core/model/user/user-info-listing';
|
|
|
|
import { VersionListingModel } from '@app/core/model/version/version-listing.model';
|
|
|
|
import { DmpLookup } from '@app/core/query/dmp.lookup';
|
|
|
|
import { MultipleAutoCompleteConfiguration } from '@app/library/auto-complete/multiple/multiple-auto-complete-configuration';
|
|
|
|
import { SingleAutoCompleteConfiguration } from '@app/library/auto-complete/single/single-auto-complete-configuration';
|
|
|
|
import { QueryResult } from '@common/model/query-result';
|
|
|
|
import { FilterService } from '@common/modules/text-filter/filter-service';
|
|
|
|
import { Guid } from '@common/types/guid';
|
|
|
|
import { Observable, throwError } from 'rxjs';
|
|
|
|
import { catchError, map } from 'rxjs/operators';
|
|
|
|
import { nameof } from 'ts-simple-nameof';
|
2019-12-11 15:51:03 +01:00
|
|
|
import { BaseHttpParams } from '../../../../common/http/base-http-params';
|
|
|
|
import { InterceptorType } from '../../../../common/http/interceptors/interceptor-type';
|
2019-08-01 09:54:40 +02:00
|
|
|
import { DynamicFieldGrantCriteria } from '../../../models/dynamic-field-grant/DynamicFieldGrantCriteria';
|
2019-01-18 18:03:45 +01:00
|
|
|
import { DataTableData } from '../../model/data-table/data-table-data';
|
|
|
|
import { DataTableRequest } from '../../model/data-table/data-table-request';
|
2019-09-23 10:17:03 +02:00
|
|
|
import { DatasetListingModel } from '../../model/dataset/dataset-listing';
|
2019-01-18 18:03:45 +01:00
|
|
|
import { DatasetProfileModel } from '../../model/dataset/dataset-profile';
|
2019-09-23 10:17:03 +02:00
|
|
|
import { DatasetsToBeFinalized } from '../../model/dataset/datasets-toBeFinalized';
|
2023-12-06 22:10:01 +01:00
|
|
|
import { CloneDmpPersist, Dmp, DmpModel, DmpPersist, DmpUser, DmpUserPersist, DmpUserRemovePersist, NewVersionDmpPersist } from '../../model/dmp/dmp';
|
2019-01-18 18:03:45 +01:00
|
|
|
import { DmpListingModel } from '../../model/dmp/dmp-listing';
|
2019-09-23 10:17:03 +02:00
|
|
|
import { DmpOverviewModel } from '../../model/dmp/dmp-overview';
|
2019-01-18 18:03:45 +01:00
|
|
|
import { DatasetProfileCriteria } from '../../query/dataset-profile/dataset-profile-criteria';
|
|
|
|
import { DmpCriteria } from '../../query/dmp/dmp-criteria';
|
2019-09-23 10:17:03 +02:00
|
|
|
import { ExploreDmpCriteriaModel } from '../../query/explore-dmp/explore-dmp-criteria';
|
2019-01-18 18:03:45 +01:00
|
|
|
import { RequestItem } from '../../query/request-item';
|
2023-12-01 18:18:41 +01:00
|
|
|
import { AuthService } from '../auth/auth.service';
|
2020-03-26 17:44:12 +01:00
|
|
|
import { ConfigurationService } from '../configuration/configuration.service';
|
2023-11-29 14:26:40 +01:00
|
|
|
import { BaseHttpV2Service } from '../http/base-http-v2.service';
|
|
|
|
import { BaseHttpService } from '../http/base-http.service';
|
2023-12-01 18:18:41 +01:00
|
|
|
import { DmpStatus } from '@app/core/common/enum/dmp-status';
|
2023-12-04 18:37:52 +01:00
|
|
|
import { DmpDescriptionTemplateLookup } from '@app/core/query/dmp-description-template.lookup';
|
2023-11-29 14:26:40 +01:00
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class DmpServiceNew {
|
|
|
|
|
|
|
|
private headers = new HttpHeaders();
|
|
|
|
|
2023-12-01 18:18:41 +01:00
|
|
|
constructor(
|
|
|
|
private http: BaseHttpV2Service,
|
|
|
|
private httpClient: HttpClient,
|
|
|
|
private configurationService: ConfigurationService,
|
|
|
|
private filterService: FilterService,
|
|
|
|
private authService: AuthService
|
|
|
|
) {
|
2023-11-29 14:26:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private get apiBase(): string { return `${this.configurationService.server}dmp`; }
|
|
|
|
|
|
|
|
query(q: DmpLookup): Observable<QueryResult<Dmp>> {
|
|
|
|
const url = `${this.apiBase}/query`;
|
|
|
|
return this.http.post<QueryResult<Dmp>>(url, q).pipe(catchError((error: any) => throwError(error)));
|
|
|
|
}
|
|
|
|
|
|
|
|
getSingle(id: Guid, reqFields: string[] = []): Observable<Dmp> {
|
|
|
|
const url = `${this.apiBase}/${id}`;
|
|
|
|
const options = { params: { f: reqFields } };
|
|
|
|
|
|
|
|
return this.http
|
|
|
|
.get<Dmp>(url, options).pipe(
|
|
|
|
catchError((error: any) => throwError(error)));
|
|
|
|
}
|
|
|
|
|
2023-12-04 16:56:12 +01:00
|
|
|
getPublicSingle(id: Guid, reqFields: string[] = []): Observable<Dmp> { //TODO: add this to backend.
|
|
|
|
const url = `${this.apiBase}/public/${id}`;
|
|
|
|
const options = { params: { f: reqFields } };
|
|
|
|
|
|
|
|
return this.http
|
|
|
|
.get<Dmp>(url, options).pipe(
|
|
|
|
catchError((error: any) => throwError(error)));
|
|
|
|
}
|
|
|
|
|
2023-11-29 14:26:40 +01:00
|
|
|
persist(item: DmpPersist): Observable<Dmp> {
|
|
|
|
const url = `${this.apiBase}/persist`;
|
|
|
|
|
|
|
|
return this.http
|
|
|
|
.post<Dmp>(url, item).pipe(
|
|
|
|
catchError((error: any) => throwError(error)));
|
|
|
|
}
|
|
|
|
|
|
|
|
delete(id: Guid): Observable<Dmp> {
|
|
|
|
const url = `${this.apiBase}/${id}`;
|
|
|
|
|
|
|
|
return this.http
|
|
|
|
.delete<Dmp>(url).pipe(
|
|
|
|
catchError((error: any) => throwError(error)));
|
|
|
|
}
|
|
|
|
|
|
|
|
clone(item: CloneDmpPersist, reqFields: string[] = []): Observable<Dmp> {
|
|
|
|
const url = `${this.apiBase}/clone`;
|
|
|
|
const options = { params: { f: reqFields } };
|
|
|
|
|
|
|
|
return this.http
|
|
|
|
.post<Dmp>(url, item).pipe(
|
|
|
|
catchError((error: any) => throwError(error)));
|
|
|
|
}
|
|
|
|
|
|
|
|
newVersion(item: NewVersionDmpPersist, reqFields: string[] = []): Observable<Dmp> {
|
|
|
|
const url = `${this.apiBase}/new-version`;
|
|
|
|
const options = { params: { f: reqFields } };
|
|
|
|
|
|
|
|
return this.http
|
|
|
|
.get<Dmp>(url, options).pipe(
|
|
|
|
catchError((error: any) => throwError(error)));
|
|
|
|
}
|
|
|
|
|
|
|
|
assignUsers(id: Guid, items: DmpUserPersist[], reqFields: string[] = []): Observable<DmpUser> {
|
|
|
|
const url = `${this.apiBase}/${id}/assign-users`;
|
|
|
|
const options = { params: { f: reqFields } };
|
|
|
|
|
|
|
|
return this.http
|
|
|
|
.post<DmpUser>(url, items).pipe(
|
|
|
|
catchError((error: any) => throwError(error)));
|
2023-12-06 22:10:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
removeUser(item: DmpUserRemovePersist, reqFields: string[] = []): Observable<Dmp> {
|
|
|
|
const url = `${this.apiBase}/remove-user`;
|
|
|
|
|
|
|
|
return this.http
|
|
|
|
.post<Dmp>(url, item).pipe(
|
|
|
|
catchError((error: any) => throwError(error)));
|
2023-11-29 14:26:40 +01:00
|
|
|
}
|
|
|
|
|
2023-12-18 11:55:19 +01:00
|
|
|
public downloadDocx(id: string): Observable<HttpResponse<Blob>> {
|
|
|
|
let headerDoc: HttpHeaders = this.headers.set('Content-Type', 'application/msword')
|
|
|
|
return this.httpClient.get(`${this.apiBase}/${id}/export/Word`, { responseType: 'blob', observe: 'response', headers: headerDoc });
|
|
|
|
}
|
|
|
|
|
|
|
|
public downloadPDF(id: string): Observable<HttpResponse<Blob>> {
|
|
|
|
let headerPdf: HttpHeaders = this.headers.set('Content-Type', 'application/pdf')
|
|
|
|
return this.httpClient.get(`${this.apiBase}/${id}/export/Pdf`, { responseType: 'blob', observe: 'response', headers: headerPdf });
|
|
|
|
}
|
|
|
|
|
|
|
|
// public downloadJson(id: string): Observable<HttpResponse<Blob>> {
|
|
|
|
// return this.httpClient.get(this.actionUrl + 'rda/' + id, { responseType: 'blob', observe: 'response' });
|
|
|
|
// }
|
|
|
|
|
2023-11-29 14:26:40 +01:00
|
|
|
downloadXML(id: Guid): Observable<HttpResponse<Blob>> {
|
|
|
|
const url = `${this.apiBase}/xml/export/${id}`;
|
|
|
|
let headerXml: HttpHeaders = this.headers.set('Content-Type', 'application/xml');
|
|
|
|
const params = new BaseHttpParams();
|
|
|
|
params.interceptorContext = {
|
|
|
|
excludedInterceptors: [InterceptorType.JSONContentType]
|
|
|
|
};
|
|
|
|
return this.httpClient.get(url, { params: params, responseType: 'blob', observe: 'response', headers: headerXml });
|
|
|
|
}
|
|
|
|
|
|
|
|
uploadFile(file: FileList, labelSent: string, reqFields: string[] = []): Observable<DataTableData<Dmp>> {
|
|
|
|
const url = `${this.apiBase}/xml/import`;
|
|
|
|
const params = new BaseHttpParams();
|
|
|
|
params.interceptorContext = {
|
|
|
|
excludedInterceptors: [InterceptorType.JSONContentType]
|
|
|
|
};
|
|
|
|
const formData = new FormData();
|
|
|
|
formData.append('file', file[0], labelSent);
|
|
|
|
return this.http.post(url, formData, { params: params });
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Autocomplete Commons
|
|
|
|
//
|
|
|
|
// tslint:disable-next-line: member-ordering
|
|
|
|
singleAutocompleteConfiguration: SingleAutoCompleteConfiguration = {
|
|
|
|
initialItems: (data?: any) => this.query(this.buildAutocompleteLookup()).pipe(map(x => x.items)),
|
|
|
|
filterFn: (searchQuery: string, data?: any) => this.query(this.buildAutocompleteLookup(searchQuery)).pipe(map(x => x.items)),
|
|
|
|
getSelectedItem: (selectedItem: any) => this.query(this.buildAutocompleteLookup(null, null, [selectedItem])).pipe(map(x => x.items[0])),
|
|
|
|
displayFn: (item: Dmp) => item.label,
|
|
|
|
titleFn: (item: Dmp) => item.label,
|
|
|
|
valueAssign: (item: Dmp) => item.id,
|
|
|
|
};
|
|
|
|
|
|
|
|
// tslint:disable-next-line: member-ordering
|
|
|
|
multipleAutocompleteConfiguration: MultipleAutoCompleteConfiguration = {
|
|
|
|
initialItems: (excludedItems: any[], data?: any) => this.query(this.buildAutocompleteLookup(null, excludedItems ? excludedItems : null)).pipe(map(x => x.items)),
|
|
|
|
filterFn: (searchQuery: string, excludedItems: any[]) => this.query(this.buildAutocompleteLookup(searchQuery, excludedItems)).pipe(map(x => x.items)),
|
|
|
|
getSelectedItems: (selectedItems: any[]) => this.query(this.buildAutocompleteLookup(null, null, selectedItems)).pipe(map(x => x.items)),
|
|
|
|
displayFn: (item: Dmp) => item.label,
|
|
|
|
titleFn: (item: Dmp) => item.label,
|
|
|
|
valueAssign: (item: Dmp) => item.id,
|
|
|
|
};
|
|
|
|
|
2023-12-04 18:37:52 +01:00
|
|
|
public buildAutocompleteLookup(like?: string, excludedIds?: Guid[], ids?: Guid[], statuses?: DmpStatus[], dmpDescriptionTemplateSubQuery?: DmpDescriptionTemplateLookup): DmpLookup {
|
2023-11-29 14:26:40 +01:00
|
|
|
const lookup: DmpLookup = new DmpLookup();
|
|
|
|
lookup.page = { size: 100, offset: 0 };
|
|
|
|
if (excludedIds && excludedIds.length > 0) { lookup.excludedIds = excludedIds; }
|
|
|
|
if (ids && ids.length > 0) { lookup.ids = ids; }
|
|
|
|
lookup.isActive = [IsActive.Active];
|
2023-12-01 18:18:41 +01:00
|
|
|
lookup.statuses = statuses;
|
2023-11-29 14:26:40 +01:00
|
|
|
lookup.project = {
|
|
|
|
fields: [
|
|
|
|
nameof<Dmp>(x => x.id),
|
|
|
|
nameof<Dmp>(x => x.label)
|
|
|
|
]
|
|
|
|
};
|
2023-12-04 18:37:52 +01:00
|
|
|
if (dmpDescriptionTemplateSubQuery != null) lookup.dmpDescriptionTemplateSubQuery = dmpDescriptionTemplateSubQuery;
|
2023-11-29 14:26:40 +01:00
|
|
|
lookup.order = { items: [nameof<Dmp>(x => x.label)] };
|
|
|
|
if (like) { lookup.like = this.filterService.transformLike(like); }
|
|
|
|
return lookup;
|
|
|
|
}
|
2023-12-01 18:18:41 +01:00
|
|
|
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// UI Helpers
|
|
|
|
//
|
|
|
|
//
|
|
|
|
|
|
|
|
getCurrentUserRolesInDmp(dmpUsers: DmpUser[]): DmpUserRole[] {
|
|
|
|
const principalId: Guid = this.authService.userId();
|
|
|
|
let dmpUserRoles: DmpUserRole[] = null;
|
|
|
|
if (principalId) {
|
|
|
|
dmpUserRoles = dmpUsers.filter(element => element?.user?.id === principalId).map(x => x.role);
|
|
|
|
}
|
|
|
|
return dmpUserRoles;
|
|
|
|
}
|
|
|
|
|
|
|
|
isDmpOwner(dmpUsers: DmpUser[]): Boolean {
|
|
|
|
return this.getCurrentUserRolesInDmp(dmpUsers).includes(DmpUserRole.Owner);
|
|
|
|
}
|
2023-11-29 14:26:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// Pre refactor TODO: delete
|
|
|
|
//
|
|
|
|
//
|
2019-01-18 18:03:45 +01:00
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class DmpService {
|
|
|
|
|
|
|
|
private actionUrl: string;
|
2019-02-06 11:46:14 +01:00
|
|
|
private headers = new HttpHeaders();
|
2019-01-18 18:03:45 +01:00
|
|
|
|
2020-03-26 17:44:12 +01:00
|
|
|
constructor(private http: BaseHttpService, private httpClient: HttpClient, private configurationService: ConfigurationService) {
|
|
|
|
this.actionUrl = configurationService.server + 'dmps/';
|
2019-02-06 11:46:14 +01:00
|
|
|
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
2019-01-31 14:56:53 +01:00
|
|
|
getPaged(dataTableRequest: DataTableRequest<DmpCriteria>, fieldsGroup?: string): Observable<DataTableData<DmpListingModel>> {
|
|
|
|
if (fieldsGroup) {
|
|
|
|
return this.http.post<DataTableData<DmpListingModel>>(this.actionUrl + 'paged?fieldsGroup=' + fieldsGroup, dataTableRequest, { headers: this.headers });
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return this.http.post<DataTableData<DmpListingModel>>(this.actionUrl + 'paged?fieldsGroup=' + fieldsGroup, dataTableRequest, { headers: this.headers });
|
|
|
|
}
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
getSingle(id: String): Observable<DmpModel> {
|
2019-01-29 12:05:36 +01:00
|
|
|
return this.http.get<DmpModel>(this.actionUrl + id, { headers: this.headers }); //'getSingle/' +
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
2022-03-15 16:58:01 +01:00
|
|
|
getSingleNoDatasets(id: String): Observable<DmpModel> {
|
|
|
|
return this.http.get<DmpModel>(this.actionUrl + 'plain/' + id, { headers: this.headers }); //'getSingle/' +
|
|
|
|
}
|
|
|
|
|
2019-04-26 16:05:15 +02:00
|
|
|
getSinglePublic(id: String): Observable<DmpModel> {
|
|
|
|
return this.http.get<DmpModel>(this.actionUrl + 'public/' + id, { headers: this.headers });
|
|
|
|
}
|
|
|
|
|
2019-06-11 10:25:32 +02:00
|
|
|
getOverviewSingle(id: string): Observable<DmpOverviewModel> {
|
2019-05-21 15:42:28 +02:00
|
|
|
return this.http.get<DmpOverviewModel>(this.actionUrl + 'overview/' + id, { headers: this.headers });
|
2019-05-17 17:21:56 +02:00
|
|
|
}
|
|
|
|
|
2019-06-11 10:25:32 +02:00
|
|
|
getOverviewSinglePublic(id: string): Observable<DmpOverviewModel> {
|
|
|
|
return this.http.get<DmpOverviewModel>(this.actionUrl + 'publicOverview/' + id, { headers: this.headers })
|
|
|
|
}
|
|
|
|
|
2020-10-12 11:45:32 +02:00
|
|
|
getAllVersions(id: string, isPublic: boolean): Observable<VersionListingModel[]> {
|
|
|
|
return this.http.get<VersionListingModel[]>(this.actionUrl + 'versions/' + id + '?public=' + isPublic, { headers: this.headers })
|
2020-07-09 13:28:55 +02:00
|
|
|
}
|
|
|
|
|
2019-01-18 18:03:45 +01:00
|
|
|
unlock(id: String): Observable<DmpModel> {
|
|
|
|
return this.http.get<DmpModel>(this.actionUrl + id + '/unlock', { headers: this.headers });
|
|
|
|
}
|
2019-03-05 12:59:34 +01:00
|
|
|
|
2020-10-02 09:15:02 +02:00
|
|
|
createDmp(dataManagementPlanModel: DmpModel): Observable<DmpModel> {
|
|
|
|
return this.http.post<DmpModel>(this.actionUrl, dataManagementPlanModel, { headers: this.headers });
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
2020-07-27 12:09:30 +02:00
|
|
|
createDmpWithDatasets(dataManagementPlanModel: DmpModel): Observable<String> {
|
|
|
|
return this.http.post<String>(this.actionUrl + 'full', dataManagementPlanModel, { headers: this.headers });
|
|
|
|
}
|
|
|
|
|
2019-01-18 18:03:45 +01:00
|
|
|
inactivate(id: String): Observable<DmpModel> {
|
|
|
|
return this.http.delete<DmpModel>(this.actionUrl + 'inactivate/' + id, { headers: this.headers });
|
|
|
|
}
|
|
|
|
|
2023-10-20 17:01:09 +02:00
|
|
|
searchDmpBlueprints(dataSetProfileRequest: RequestItem<DatasetProfileCriteria>): Observable<DatasetProfileModel[]> {
|
2019-01-18 18:03:45 +01:00
|
|
|
return this.http.post<DatasetProfileModel[]>(this.actionUrl + 'datasetprofiles/get', dataSetProfileRequest, { headers: this.headers });
|
|
|
|
}
|
|
|
|
|
2020-09-03 17:49:45 +02:00
|
|
|
newVersion(dataManagementPlanModel: DmpModel, id: String): Observable<String> {
|
|
|
|
return this.http.post<String>(this.actionUrl + 'new/' + id, dataManagementPlanModel, { headers: this.headers });
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
2020-09-03 11:52:35 +02:00
|
|
|
clone(dataManagementPlanModel: DmpModel, id: String): Observable<String> {
|
|
|
|
return this.http.post<String>(this.actionUrl + 'clone/' + id, dataManagementPlanModel, { headers: this.headers });
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
delete(id: String): Observable<DmpModel> {
|
2019-01-29 12:05:36 +01:00
|
|
|
return this.http.delete<DmpModel>(this.actionUrl + id, { headers: this.headers }); // + 'delete/'
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
2019-07-01 11:35:09 +02:00
|
|
|
publish(id: String): Observable<DmpModel> {
|
|
|
|
return this.http.get<DmpModel>(this.actionUrl + 'makepublic/' + id, { headers: this.headers });
|
|
|
|
}
|
|
|
|
|
|
|
|
finalize(datasetsToBeFinalized: DatasetsToBeFinalized, id: String): Observable<DmpModel> {
|
|
|
|
return this.http.post<DmpModel>(this.actionUrl + 'finalize/' + id, datasetsToBeFinalized, { headers: this.headers });
|
|
|
|
}
|
|
|
|
|
2020-07-27 12:09:30 +02:00
|
|
|
unfinalize(id: String): Observable<DmpModel> {
|
2020-05-26 13:31:47 +02:00
|
|
|
return this.http.post<DmpModel>(this.actionUrl + 'unfinalize/' + id, { headers: this.headers });
|
|
|
|
}
|
|
|
|
|
2020-07-07 11:22:45 +02:00
|
|
|
updateUsers(id: string, users: UserInfoListingModel[]): Observable<DmpModel> {
|
2020-07-27 12:09:30 +02:00
|
|
|
return this.http.post<DmpModel>(`${this.actionUrl}updateusers/${id}`, users, { headers: this.headers });
|
2020-07-07 11:22:45 +02:00
|
|
|
}
|
|
|
|
|
2019-08-01 09:54:40 +02:00
|
|
|
getDynamicField(requestItem: RequestItem<DynamicFieldGrantCriteria>): any {
|
2019-01-18 18:03:45 +01:00
|
|
|
return this.http.post<any>(this.actionUrl + 'dynamic', requestItem, { headers: this.headers });
|
|
|
|
}
|
|
|
|
|
|
|
|
public downloadXML(id: string): Observable<HttpResponse<Blob>> {
|
2019-02-06 11:46:14 +01:00
|
|
|
let headerXml: HttpHeaders = this.headers.set('Content-Type', 'application/xml')
|
|
|
|
return this.httpClient.get(this.actionUrl + id, { responseType: 'blob', observe: 'response', headers: headerXml }); //+ "/getXml/"
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public downloadDocx(id: string): Observable<HttpResponse<Blob>> {
|
2019-02-06 11:46:14 +01:00
|
|
|
let headerDoc: HttpHeaders = this.headers.set('Content-Type', 'application/msword')
|
|
|
|
return this.httpClient.get(this.actionUrl + id, { responseType: 'blob', observe: 'response', headers: headerDoc });
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public downloadPDF(id: string): Observable<HttpResponse<Blob>> {
|
2019-02-06 11:46:14 +01:00
|
|
|
let headerPdf: HttpHeaders = this.headers.set('Content-Type', 'application/pdf')
|
|
|
|
return this.httpClient.get(this.actionUrl + 'getPDF/' + id, { responseType: 'blob', observe: 'response', headers: headerPdf });
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
2019-03-05 12:59:34 +01:00
|
|
|
|
2019-06-04 16:04:04 +02:00
|
|
|
public downloadJson(id: string): Observable<HttpResponse<Blob>> {
|
|
|
|
return this.httpClient.get(this.actionUrl + 'rda/' + id, { responseType: 'blob', observe: 'response' });
|
|
|
|
}
|
|
|
|
|
2023-10-20 17:01:09 +02:00
|
|
|
public uploadXml(fileList: FileList, dmpTitle: string, dmpBlueprints: any[]): Observable<any> {
|
2019-03-05 12:59:34 +01:00
|
|
|
const formData: FormData = new FormData();
|
|
|
|
if (fileList instanceof FileList) {
|
|
|
|
for (let i = 0; i < fileList.length; i++) {
|
|
|
|
formData.append('file', fileList[i], dmpTitle);
|
|
|
|
}
|
2020-09-28 13:31:42 +02:00
|
|
|
} else if (Array.isArray(fileList)) {
|
2020-10-02 09:35:09 +02:00
|
|
|
formData.append('file', fileList[0], dmpTitle);
|
2019-03-05 12:59:34 +01:00
|
|
|
} else {
|
2020-09-28 13:59:50 +02:00
|
|
|
formData.append('file', fileList, dmpTitle);
|
2019-03-05 12:59:34 +01:00
|
|
|
}
|
2023-10-20 17:01:09 +02:00
|
|
|
for (let j = 0; j < dmpBlueprints.length; j++) {
|
|
|
|
formData.append('profiles', dmpBlueprints[j].id);
|
2020-05-29 12:39:18 +02:00
|
|
|
}
|
2019-03-05 12:59:34 +01:00
|
|
|
const params = new BaseHttpParams();
|
|
|
|
params.interceptorContext = {
|
|
|
|
excludedInterceptors: [InterceptorType.JSONContentType]
|
|
|
|
};
|
|
|
|
return this.http.post(this.actionUrl + 'upload', formData, { params: params });
|
|
|
|
}
|
2019-04-26 16:05:15 +02:00
|
|
|
|
2019-06-11 10:25:32 +02:00
|
|
|
getPublicPaged(dataTableRequest: DataTableRequest<ExploreDmpCriteriaModel>, fieldsGroup?: string): Observable<DataTableData<DmpListingModel>> {
|
|
|
|
return this.http.post<DataTableData<DmpListingModel>>(this.actionUrl + 'public/paged?fieldsGroup=' + fieldsGroup, dataTableRequest, { headers: this.headers });
|
2019-04-26 16:05:15 +02:00
|
|
|
}
|
2019-06-12 11:13:50 +02:00
|
|
|
|
|
|
|
getDatasetProfilesUsedPaged(dataTableRequest: DataTableRequest<DatasetProfileCriteria>) {
|
|
|
|
return this.http.post<DataTableData<DatasetListingModel>>(this.actionUrl + 'datasetProfilesUsedByDmps/paged', dataTableRequest);
|
|
|
|
}
|
2020-04-01 17:16:06 +02:00
|
|
|
|
|
|
|
generateIndex() {
|
|
|
|
return this.http.post(this.actionUrl + 'index', {});
|
|
|
|
}
|
|
|
|
|
|
|
|
clearIndex() {
|
|
|
|
return this.http.delete(this.actionUrl + 'index');
|
|
|
|
}
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|