import {Injectable} from '@angular/core'; import {Http, Response} from '@angular/http'; import {Observable} from 'rxjs/Observable'; import {OrpInfo} from '../../utils/entities/orpInfo'; import 'rxjs/add/observable/of'; import 'rxjs/add/operator/do'; import 'rxjs/add/operator/share'; import{EnvProperties} from '../../utils/properties/env-properties'; import { ParsingFunctions } from '../landing-utils/parsingFunctions.class'; @Injectable() export class OrpService { constructor(private http: Http ) { this.parsingFunctions = new ParsingFunctions(); } public parsingFunctions: ParsingFunctions; orpInfo: OrpInfo; getOrpInfo (id: string, properties:EnvProperties):any { let url = properties.searchAPIURLLAst+'other/'+id+"?format=json"; let key = url; return this.http.get((properties.useCache)? (properties.cacheUrl+encodeURIComponent(url)): url) .map(res => res.json()) .map(res => [res['result']['header']['dri:status'], res['result']['metadata']['oaf:entity'],res]) .map(res => [res[1]['oaf:result'], //0 res[1]['oaf:result']['title'], //1 res[1]['oaf:result']['rels']['rel'], //2 res[1]['oaf:result']['children'], //3 res[1]['oaf:result']['pid'], //4 res[1]['oaf:result']['subject'], //5 res[1]['oaf:result']['bestaccessright'], //6 res[1]['oaf:result']['collectedfrom'], //7 res[1]['oaf:result']['context'], //8 res[0], //9 res[1]['oaf:result']['creator'], //10 res[1]['oaf:result']['language'], //11 res[1]['oaf:result']['country'], //12 res[2], //13 (res[1]['extraInfo']!= undefined && res[1]['extraInfo']['citations']!= undefined)? res[1]['extraInfo']['citations']['citation']:null //14 ]).map(res => this.parseOrpInfo(res)); } 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 Observable.throw(error || 'Server error'); } parseOrpInfo (data: any):any { this.orpInfo = new OrpInfo(); this.orpInfo.record = data[13]; if(data[0] != null) { var date:string = (data[0].dateofacceptance)+""; // transform to string in case it is an integer this.orpInfo.date = (date && (date).indexOf('-') !== -1)?date.split('-')[0]:date; this.orpInfo.dateofacceptance = data[0].dateofacceptance; this.orpInfo.publisher = data[0].publisher; if(!Array.isArray(data[0].description)) { this.orpInfo.description = data[0].description; } else { this.orpInfo.description = data[0].description[0]; } this.orpInfo.embargoEndDate = data[0].embargoenddate; } if(data[0]['bestaccessright'] && data[0]['bestaccessright'].hasOwnProperty("classid")) { this.orpInfo.accessMode = data[0]['bestaccessright'].classid; } if(data[1] != null) { if(Array.isArray(data[1])) { this.orpInfo.title = data[1][0].content; } else { this.orpInfo.title = data[1].content; } } if(data[2] != null) { let relation; let length = data[2].length!=undefined ? data[2].length : 1; for(let i=0; i(); this.orpInfo.types = new Array(); let types = new Set(); let counter = 0; let instance; let length = data[3]['instance'].length!=undefined ? data[3]['instance'].length : 1; for(let i=0; i, Map] = this.parsingFunctions.parseAllSubjects(data[5]); this.orpInfo.subjects = subjectResults[0]; this.orpInfo.otherSubjects = subjectResults[1]; this.orpInfo.classifiedSubjects = subjectResults[2]; } this.orpInfo.hostedBy_collectedFrom = this.parsingFunctions.addPublisherToHostedBy_collectedFrom( this.orpInfo.hostedBy_collectedFrom, this.orpInfo.publisher, null, this.orpInfo.identifiers/*, this.orpInfo.title*/); if(data[8] != null) { this.orpInfo.contexts = this.parsingFunctions.parseContexts(data[8]); } if(data[9] != null && data[9] == "under curation") { this.orpInfo.underCurationMessage = true; } else { this.orpInfo.underCurationMessage = false; } if(data[10] != null) { if(this.orpInfo.authors == undefined) { this.orpInfo.authors = new Array(); } let authors = data[10]; let length = Array.isArray(authors) ? authors.length : 1; for(let i=0; i