2020-01-28 15:09:32 +01:00
|
|
|
import {Injectable} from "@angular/core";
|
|
|
|
import {HttpClient} from "@angular/common/http";
|
|
|
|
import {Observable} from "rxjs";
|
2020-04-07 19:09:31 +02:00
|
|
|
import {EnvProperties} from "../../utils/properties/env-properties";
|
|
|
|
import {map} from "rxjs/operators";
|
|
|
|
import {response} from "express";
|
|
|
|
import {el} from "@angular/platform-browser/testing/src/browser_util";
|
|
|
|
|
|
|
|
export interface Annotation {
|
|
|
|
text: string;
|
|
|
|
type: 'semantic' | 'keyword' | 'comment';
|
|
|
|
urls?: string[];
|
2020-05-29 11:50:49 +02:00
|
|
|
urlSize?: number;
|
2020-04-07 19:09:31 +02:00
|
|
|
}
|
2020-01-28 15:09:32 +01:00
|
|
|
|
|
|
|
@Injectable({
|
|
|
|
providedIn: "root"
|
|
|
|
})
|
|
|
|
export class AnnotationService {
|
|
|
|
|
|
|
|
|
|
|
|
constructor(private http: HttpClient) {
|
|
|
|
}
|
|
|
|
|
2020-04-07 19:09:31 +02:00
|
|
|
getAllAnnotations(properties: EnvProperties, source: string): Observable<Annotation[]> {
|
|
|
|
let url = properties.b2noteAPIURL + 'annotations?type[]=semantic&type[]=keyword&type[]=comment&format=json-ld&download=false&target-source=' + encodeURIComponent(source);
|
|
|
|
return this.http.get<Annotation[]>(url).pipe(map((response: any[]) => {
|
|
|
|
return this.parseAnnotations(response);
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
private parseAnnotations(response: any[]): Annotation[] {
|
|
|
|
let annotations: Annotation[] = [];
|
|
|
|
if(response && response.length > 0) {
|
|
|
|
response.forEach(value => {
|
|
|
|
let body = value.body;
|
|
|
|
if(body.type === 'TextualBody') {
|
|
|
|
if(body.purpose === 'tagging') {
|
|
|
|
annotations.push({
|
|
|
|
text: body.value,
|
|
|
|
type: "keyword"
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
annotations.push({
|
|
|
|
text: body.value,
|
|
|
|
type: "comment"
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
let items = body.items;
|
|
|
|
let urls: string[] = [];
|
|
|
|
let text: string = null;
|
|
|
|
items.forEach(item => {
|
|
|
|
if(item.type === 'SpecificResource') {
|
|
|
|
urls.push(item.source);
|
|
|
|
} else if(item.type === 'TextualBody') {
|
|
|
|
text = item.value;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
annotations.push({
|
|
|
|
text: text,
|
|
|
|
type: "semantic",
|
|
|
|
urls: urls
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return annotations.sort((a, b) => {
|
|
|
|
if(a.type === b.type) {
|
|
|
|
return 0;
|
|
|
|
} else if (a.type === 'semantic') {
|
|
|
|
return -1;
|
|
|
|
} else if(b.type === 'semantic') {
|
|
|
|
return 1;
|
|
|
|
} else if(a.type === 'keyword') {
|
|
|
|
return -1;
|
|
|
|
} else if(b.type === 'keyword') {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
2020-01-28 15:09:32 +01:00
|
|
|
}
|
2020-05-29 11:50:49 +02:00
|
|
|
}
|