argos/dmp-frontend/src/app/core/services/description/description.service.ts

157 lines
7.0 KiB
TypeScript
Raw Normal View History

2024-01-04 17:09:09 +01:00
import { HttpClient, HttpHeaders, HttpParamsOptions, HttpResponse } from '@angular/common/http';
2023-11-27 17:22:13 +01:00
import { Injectable } from '@angular/core';
import { IsActive } from '@app/core/common/enum/is-active.enum';
2024-03-19 16:21:50 +01:00
import { Description, DescriptionPersist, DescriptionSectionPermissionResolver, DescriptionStatusPersist, PublicDescription } from '@app/core/model/description/description';
2023-11-29 14:26:40 +01:00
import { DescriptionLookup } from '@app/core/query/description.lookup';
2023-11-27 17:22:13 +01:00
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';
2024-03-13 18:24:01 +01:00
import { Observable, of, throwError } from 'rxjs';
2023-11-27 17:22:13 +01:00
import { catchError, map } from 'rxjs/operators';
import { nameof } from 'ts-simple-nameof';
import { ConfigurationService } from '../configuration/configuration.service';
import { BaseHttpV2Service } from '../http/base-http-v2.service';
import { FileFormat } from '@app/core/model/file/file-format.model';
2024-01-04 17:09:09 +01:00
import { BaseHttpParams } from '@common/http/base-http-params';
import { InterceptorType } from '@common/http/interceptors/interceptor-type';
2024-03-13 18:24:01 +01:00
import { DescriptionValidationResult } from '@app/ui/dmp/dmp-finalize-dialog/dmp-finalize-dialog.component';
2023-11-27 17:22:13 +01:00
@Injectable()
2023-11-29 14:26:40 +01:00
export class DescriptionService {
2023-11-27 17:22:13 +01:00
2023-11-29 14:26:40 +01:00
private headers = new HttpHeaders();
constructor(private http: BaseHttpV2Service, private httpClient: HttpClient, private configurationService: ConfigurationService, private filterService: FilterService) {
2023-11-27 17:22:13 +01:00
}
2023-11-29 14:26:40 +01:00
private get apiBase(): string { return `${this.configurationService.server}description`; }
2023-11-27 17:22:13 +01:00
2023-11-29 14:26:40 +01:00
query(q: DescriptionLookup): Observable<QueryResult<Description>> {
2023-11-27 17:22:13 +01:00
const url = `${this.apiBase}/query`;
2023-11-29 14:26:40 +01:00
return this.http.post<QueryResult<Description>>(url, q).pipe(catchError((error: any) => throwError(error)));
}
2024-03-19 16:21:50 +01:00
getDescriptionSectionPermissions(q: DescriptionSectionPermissionResolver): Observable<Map<Guid, string[]>> {
const url = `${this.apiBase}/get-description-section-permissions`;
return this.http.post<Map<Guid, string[]>>(url, q).pipe(catchError((error: any) => throwError(error)));
}
2023-11-29 14:26:40 +01:00
publicQuery(q: DescriptionLookup): Observable<QueryResult<PublicDescription>> {
const url = `${this.apiBase}/public/query`;
2024-03-11 14:20:09 +01:00
const params = new BaseHttpParams();
params.interceptorContext = {
excludedInterceptors: [InterceptorType.AuthToken]
};
return this.http.post<QueryResult<PublicDescription>>(url, q, {params: params}).pipe(catchError((error: any) => throwError(error)));
2023-11-27 17:22:13 +01:00
}
2023-11-29 14:26:40 +01:00
getSingle(id: Guid, reqFields: string[] = []): Observable<Description> {
2023-11-27 17:22:13 +01:00
const url = `${this.apiBase}/${id}`;
2024-01-04 17:09:09 +01:00
const options: HttpParamsOptions = { fromObject: { f: reqFields } };
let params: BaseHttpParams = new BaseHttpParams(options);
2023-11-27 17:22:13 +01:00
return this.http
2024-01-04 17:09:09 +01:00
.get<Description>(url, { params: params }).pipe(
2023-11-27 17:22:13 +01:00
catchError((error: any) => throwError(error)));
}
2024-03-11 08:47:03 +01:00
getPublicSingle(id: Guid, reqFields: string[] = []): Observable<PublicDescription> {
2023-11-29 14:26:40 +01:00
const url = `${this.apiBase}/public/${id}`;
2024-03-11 14:20:09 +01:00
const options: HttpParamsOptions = { fromObject: { f: reqFields } };
let params: BaseHttpParams = new BaseHttpParams(options);
params.interceptorContext = {
excludedInterceptors: [InterceptorType.AuthToken]
};
2023-11-28 18:10:04 +01:00
return this.http
2024-03-11 14:20:09 +01:00
.get<PublicDescription>(url, { params: params }).pipe(
2023-11-28 18:10:04 +01:00
catchError((error: any) => throwError(error)));
}
2023-11-29 14:26:40 +01:00
persist(item: DescriptionPersist): Observable<Description> {
2023-11-27 17:22:13 +01:00
const url = `${this.apiBase}/persist`;
return this.http
2023-11-29 14:26:40 +01:00
.post<Description>(url, item).pipe(
2023-11-27 17:22:13 +01:00
catchError((error: any) => throwError(error)));
}
2023-12-06 22:10:01 +01:00
persistStatus(item: DescriptionStatusPersist, reqFields: string[] = []): Observable<Description> {
const url = `${this.apiBase}/persist-status`;
return this.http
.post<Description>(url, item).pipe(
catchError((error: any) => throwError(error)));
}
2023-11-29 14:26:40 +01:00
delete(id: Guid): Observable<Description> {
2023-11-27 17:22:13 +01:00
const url = `${this.apiBase}/${id}`;
return this.http
2023-11-29 14:26:40 +01:00
.delete<Description>(url).pipe(
2023-11-27 17:22:13 +01:00
catchError((error: any) => throwError(error)));
}
2024-03-15 08:39:36 +01:00
validate(descriptionIds: Guid[]): Observable<DescriptionValidationResult[]> {
const url = `${this.apiBase}/validate`;
const options = {params: { descriptionIds: descriptionIds} };
return this.http
.get<DescriptionValidationResult[]>(url, options).pipe(
catchError((error: any) => throwError(error)));
2024-03-13 18:24:01 +01:00
}
// public downloadPDF(id: string): Observable<HttpResponse<Blob>> {
// return this.httpClient.get(`${this.apiBase}/${id}/export/Pdf`, { responseType: 'blob', observe: 'response', headers: this.headers });
// }
public download(id: string, format: string): Observable<HttpResponse<Blob>> {
//let headerDocx: HttpHeaders = this.headers.set('Content-Type', 'application/msword')
return this.httpClient.get(`${this.apiBase}/${id}/export/${format}`, { responseType: 'blob', observe: 'response', headers: this.headers });
2023-12-18 11:55:19 +01:00
}
2023-11-27 17:22:13 +01:00
//
// 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])),
2023-11-29 14:26:40 +01:00
displayFn: (item: Description) => item.label,
titleFn: (item: Description) => item.label,
valueAssign: (item: Description) => item.id,
2023-11-27 17:22:13 +01:00
};
// 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)),
2023-11-29 14:26:40 +01:00
displayFn: (item: Description) => item.label,
titleFn: (item: Description) => item.label,
valueAssign: (item: Description) => item.id,
2023-11-27 17:22:13 +01:00
};
2023-12-28 16:18:49 +01:00
public buildAutocompleteLookup(like?: string, excludedIds?: Guid[], ids?: Guid[]): DescriptionLookup {
2023-11-29 14:26:40 +01:00
const lookup: DescriptionLookup = new DescriptionLookup();
2023-11-27 17:22:13 +01:00
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];
lookup.project = {
fields: [
2023-11-29 14:26:40 +01:00
nameof<Description>(x => x.id),
nameof<Description>(x => x.label)
2023-11-27 17:22:13 +01:00
]
};
2023-11-29 14:26:40 +01:00
lookup.order = { items: [nameof<Description>(x => x.label)] };
2023-11-27 17:22:13 +01:00
if (like) { lookup.like = this.filterService.transformLike(like); }
return lookup;
}
2023-11-29 14:26:40 +01:00
}