2019-03-18 16:02:46 +01:00
|
|
|
import {Injectable} from '@angular/core';
|
2019-10-08 12:56:04 +02:00
|
|
|
import {HttpClient, HttpErrorResponse} from '@angular/common/http';
|
2019-10-08 15:37:11 +02:00
|
|
|
import {Observable, throwError} from 'rxjs';
|
2019-03-18 16:02:46 +01:00
|
|
|
import {CustomOptions} from './servicesUtils/customOptions.class';
|
2021-04-06 16:10:46 +02:00
|
|
|
import {CustomizationOptions, Layout} from '../connect/community/CustomizationOptions';
|
[Trunk | Library]:
1. community.service.ts: Mark unused method "isSubscribedToCommunity()" as "deprecated" (This service calls community API - made in Italy, not uoa-admin-tools - made in Greece).
2. connectSubscriber.guard.ts: Call "isSubscribedToCommunity()" method from "subscribe.service.ts" (not "community.service.ts").
3. curator.service.ts: getCurators(properties: EnvProperties, url: string) --> getCurators(properties: EnvProperties, emails: string): Build path for request in service.
4. email.service.ts: Build request path in service
a. sendEmail(url: string, email: Email) --> sendEmail(properties: EnvProperties, email: Email)
b. contact(url: string, email: Email, recaptcha: string = null) --> contact(properties: EnvProperties, email: Email, recaptcha: string = null)
c. Create method "notifyForNewManagers(properties: EnvProperties, communityId: string, email: Email)" (sendEmail was used for everything).
5. subscribe.service.ts:
a. subscribeToCommunity(pid: string, email: string, url: string) --> subscribeToCommunity(properties: EnvProperties, pid: string, email: string)
b. unSubscribeToCommunity(pid: string, email: string, url: string) --> unSubscribeToCommunity(properties: EnvProperties, pid: string, email: string)
6. layout.service.ts: getLayout(communityId: string, url: string) --> getLayout(properties: EnvProperties, communityId: string): Build path for request in service.
7. feedback.component.ts: In method "contact" from "emailService", build request path in service.
git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@58420 d315682c-612b-4755-9ff5-7f18f6832af3
2020-04-07 16:57:26 +02:00
|
|
|
import {EnvProperties} from "../utils/properties/env-properties";
|
2019-03-18 16:02:46 +01:00
|
|
|
|
|
|
|
@Injectable()
|
2022-08-08 12:01:53 +02:00
|
|
|
export class CustomizationService {
|
2019-06-03 15:20:36 +02:00
|
|
|
constructor(private http: HttpClient) {
|
2019-03-18 16:02:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static removeNulls(obj) {
|
|
|
|
const isArray = obj instanceof Array;
|
|
|
|
for (let k in obj) {
|
|
|
|
if (obj[k] === null || obj[k] === '') {
|
2022-09-23 13:49:59 +02:00
|
|
|
isArray ? obj.splice(Number.parseInt(k), 1) : delete obj[k];
|
2019-03-18 16:02:46 +01:00
|
|
|
} else if (typeof obj[k] === 'object') {
|
2022-08-08 12:01:53 +02:00
|
|
|
CustomizationService.removeNulls(obj[k]);
|
2019-03-18 16:02:46 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-08-01 11:18:47 +02:00
|
|
|
createCSS( pid: string, connectPortalUrl:string, suffix = null, layout = null): Observable<any> {
|
|
|
|
return this.http.post(connectPortalUrl + "/build-css/" + (layout?"preview/":"") + pid + (suffix?("/"+ suffix):""), layout );
|
2022-07-22 17:35:51 +02:00
|
|
|
}
|
2019-03-18 16:02:46 +01:00
|
|
|
|
2022-08-01 16:32:25 +02:00
|
|
|
saveLayout(properties: EnvProperties, pid: string, layout: Layout, portalType = null): Observable<Layout> {
|
2022-08-08 12:01:53 +02:00
|
|
|
CustomizationService.removeNulls(layout);
|
2022-08-01 16:32:25 +02:00
|
|
|
return this.http.post<Layout>(properties.adminToolsAPIURL + '/' + (portalType?portalType: properties.adminToolsPortalType) + '/'
|
2020-04-08 13:25:41 +02:00
|
|
|
+ pid + '/layout', layout, CustomOptions.getAuthOptionsWithBody());
|
2019-03-18 16:02:46 +01:00
|
|
|
}
|
2022-08-08 12:01:53 +02:00
|
|
|
deleteLayout(properties: EnvProperties, pid: string, portalType = null): Observable<Layout> {
|
|
|
|
return this.http.delete<Layout>(properties.adminToolsAPIURL + '/' + (portalType?portalType: properties.adminToolsPortalType) + '/'
|
|
|
|
+ pid + '/layout', CustomOptions.getAuthOptionsWithBody());
|
|
|
|
}
|
2021-04-06 16:10:46 +02:00
|
|
|
getLayout(properties: EnvProperties, pid: string): Observable<Layout> {
|
|
|
|
return this.http.get<Layout>(properties.adminToolsAPIURL+"/" + properties.adminToolsPortalType + '/'
|
2020-09-24 13:18:24 +02:00
|
|
|
+ pid + '/layout');
|
2019-03-18 16:02:46 +01:00
|
|
|
}
|
2022-08-01 16:32:25 +02:00
|
|
|
getLayouts(properties: EnvProperties): Observable<Layout[]> {
|
|
|
|
return this.http.get<Layout[]>(properties.adminToolsAPIURL+'/community/layouts');
|
|
|
|
}
|
2019-10-08 12:56:04 +02:00
|
|
|
mockLayout(): any {
|
|
|
|
return this.http.get('./assets/customizationOptions.json') ;
|
2019-07-22 16:15:23 +02:00
|
|
|
|
|
|
|
}
|
2019-03-18 16:02:46 +01:00
|
|
|
|
2019-06-03 15:20:36 +02:00
|
|
|
private handleError(error: HttpErrorResponse) {
|
2019-03-18 16:02:46 +01:00
|
|
|
// in a real world app, we may send the error to some remote logging infrastructure
|
|
|
|
// instead of just logging it to the console
|
|
|
|
console.error(error);
|
2019-06-03 15:20:36 +02:00
|
|
|
return throwError(error.error || 'Server error');
|
2019-03-18 16:02:46 +01:00
|
|
|
}
|
|
|
|
}
|