openaire-library/claims/claim-utils/service/contexts.service.ts

141 lines
5.2 KiB
TypeScript

import {throwError as observableThrowError, Observable} from 'rxjs';
import {Injectable} from '@angular/core';
import {Jsonp, URLSearchParams, RequestOptions, Headers} from '@angular/http';
import {Http, Response} from '@angular/http';
import { HttpClient } from '@angular/common/http';
import {Claim} from '../claim';
import {AutoCompleteValue} from '../../../searchPages/searchUtils/searchHelperClasses.class';
import {catchError, map} from "rxjs/operators";
import { COOKIE } from '../../../login/utils/helper.class';
@Injectable()
export class ContextsService {
constructor(private http: HttpClient ) {
}
public getCommunities( apiUrl:string):any {
let url = apiUrl + 's/';
let key = url;
//console.info('ContextsService: request communities '+url);
return this.http.get(url)
//.map(res => <any> res.json())
.pipe(map(res => this.parseCommunities(res, true) ))
// .do(request => console.info("Get claims: offset = "))
.pipe(catchError(this.handleError));
}
public getPublicCommunities( apiUrl:string):any {
let url = apiUrl + 's/';
let key = url;
//console.info('ContextsService: request communities '+url);
return this.http.get(url)
.pipe(map(res => this.parseCommunities(res, true) ));
}
parseCommunities(data, getall){
var communities = [];
for(var i = 0; i< data.length; i++){
if(data[i].type && (data[i].type == "ri" || data[i].type == "community")){
if(getall || data[i].status!='hidden') {
communities.push(data[i]);
}
}
}
return communities;
}
public getCategories(communityId :string, apiUrl:string):any {
//console.info('ContextsService: request categories for community with id '+communityId);
let url= apiUrl + '/' + communityId ;
let key = url;
return this.http.get(url)
//.map(request => <any> request.json())
// .do(request => console.info("Get claims: offset = " ))
.pipe(catchError(this.handleError));
}
public getConcepts(categoryId :string, keyword: string, parsing:boolean, apiUrl:string):any {
//console.info('ContextsService: request concept for category with id '+categoryId + ' and keyword '+ keyword);
let url= apiUrl + '/category/' + categoryId;
let key = url+"_parsing="+parsing;
return this.http.get(url )
//.map(request => <any> request.json())
.pipe(catchError(this.handleError))
.pipe(map(res => (parsing)?this.parse(res):res));
// .do(res => console.info("Result is "+ res.length ));
}
public getSubConcepts(subConceptID :string, keyword: string, parsing:boolean, apiUrl:string):any {
//console.info('ContextsService: request sub concept for concept with id '+subConceptID + ' and keyword '+ keyword);
let url= apiUrl + '/category/concept/' + subConceptID;
let key = url+"_parsing="+parsing;
return this.http.get(url )
//.map(request => <any> request.json())
.pipe(catchError(this.handleError))
.pipe(map(res => (parsing)?this.parseSubConcepts(res):res));
// .do(res => console.info("Result is "+ res.length ));
}
parse (data: any):any {
var array =[]
if(!Array.isArray(data) && data.id && data.label){
var value ={id:"",label:"",hasSubConcept:""};
value.id = data.id;
value.label = data.label;
value.hasSubConcept = data.hasSubConcept;
array.push(value);
}
for(var i = 0; i < data.length; i++){
var value={id:"",label:"",hasSubConcept:""};
value.id = data[i].id;
value.label = data[i].label;
value.hasSubConcept = data[i].hasSubConcept;
array.push(value);
}
return array;
}
parseSubConcepts (data: any):any {
var array = []
if(data.length >0 && data[0].concepts){
var concepts = data[0].concepts;
for(var i = 0; i < concepts.length; i++){
var value ={id:"",label:"",hasSubConcept:""};
value.id = concepts[i].id;
value.label = concepts[i].label;
value.hasSubConcept = concepts[i].hasSubConcept;
if(concepts[i].concepts){
var subconcepts = concepts[i].concepts;
for(var x = 0; x < subconcepts.length; x++){
var value ={id:"",label:"",hasSubConcept:""};
value.id = subconcepts[x].id;
value.label = subconcepts[x].label;
value.hasSubConcept = subconcepts[x].hasSubConcept;
array.push(value);
}
}
array.push(value);
}
}
return array;
}
private handleError (error: Response) {
// in a real world app, we may send the error to some remote logging infrastructure
// instead of just logging it to the console
console.log(error);
return observableThrowError(error || 'Server error');
}
private getAuthOptions():RequestOptions{
let headers = new Headers();
headers.append('X-XSRF-TOKEN', COOKIE.getCookie(COOKIE.cookieName_id));
let options = new RequestOptions({ headers: headers, withCredentials:true });
return options;
}
}