[Trunk | Library]:
1. error-interceptor.service.ts: Add "properties.orcidAPIURL" in UNAUTHORIZED_WHITELIST. 2. resultLanding.component.html: If result has identifiers and user is logged in, call <orcid-work>. 3. resultLanding.module.ts: Import OrcidModule. 4. searchResult.component.ts: If user is logged in, call "orcidService.getPutCodes()" and set orcidPutCodes of previewResults. 5. searchResults.module.ts: Add "OrcidService" in providers. 6. searchResearchResults.service.ts: In method "parseResults()", call "this.parsingFunctions.parseIdentifiers(resData['pid'])" to set identifiers. 7. customOptions.class.ts: Change method return type: "public static registryOptions(): any" --> public static registryOptions(): {}". (caused problem in return type of services (e.g. HttpEvent<string> instead of string). 8. searchResult.ts: Add field "identifiers: Map<string, string[]>". 9. env-properties.ts: Add field "orcidAPIURL". 10. result-preview.component.html: a. If result has identifiers and user is logged in, call <orcid-work>. b. In bottom line with impact factors and orcid, add class "result-preview-bottom" (set color to #747474 (like muted text) when not on hover). 11. result-preview.component.ts: Add field "loggedIn" and check on init if user is logged in (via Session). 12. result-preview.module.ts: Import OrcidModule. 13. result-preview.ts: Add field "orcidPutCodes" | In method "searchResultConvert()", set resultPreview.identifiers with all identifiers (not only dois). git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@60231 d315682c-612b-4755-9ff5-7f18f6832af3
This commit is contained in:
parent
948831e201
commit
eb4a1f13f6
|
@ -11,7 +11,7 @@ import {isArray} from "util";
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class ErrorInterceptorService implements HttpInterceptor {
|
export class ErrorInterceptorService implements HttpInterceptor {
|
||||||
|
|
||||||
private static UNAUTHORIZED_WHITELIST = [properties.userInfoUrl];
|
private static UNAUTHORIZED_WHITELIST = [properties.userInfoUrl, properties.orcidAPIURL];
|
||||||
|
|
||||||
constructor(private router: Router) {
|
constructor(private router: Router) {
|
||||||
}
|
}
|
||||||
|
|
|
@ -100,6 +100,12 @@
|
||||||
<span class="uk-margin-small-left">Cite this {{getTypeName()}}</span>
|
<span class="uk-margin-small-left">Cite this {{getTypeName()}}</span>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
|
<!-- ORCID -->
|
||||||
|
<li *ngIf="properties.environment == 'development' &&
|
||||||
|
loggedIn && resultLandingInfo && resultLandingInfo.identifiers && resultLandingInfo.identifiers.size > 0">
|
||||||
|
<orcid-work [resultId]="id" [resultLandingInfo]="resultLandingInfo" [pids]="pidsArrayString" [pageType]="'landing'">
|
||||||
|
</orcid-work>
|
||||||
|
</li>
|
||||||
<li *ngIf="properties.b2noteAPIURL">
|
<li *ngIf="properties.b2noteAPIURL">
|
||||||
<a *ngIf="isLoggedIn && pid" class="uk-link-text uk-text-bold uk-text-uppercase" (click)="annotation.toggleAnnotation($event)">
|
<a *ngIf="isLoggedIn && pid" class="uk-link-text uk-text-bold uk-text-uppercase" (click)="annotation.toggleAnnotation($event)">
|
||||||
<span class="uk-icon-button uk-button-primary uk-icon">
|
<span class="uk-icon-button uk-button-primary uk-icon">
|
||||||
|
|
|
@ -28,13 +28,16 @@ import {ResultPreviewModule} from "../../utils/result-preview/result-preview.mod
|
||||||
import {FeedbackModule} from "../feedback/feedback.module";
|
import {FeedbackModule} from "../feedback/feedback.module";
|
||||||
import {TabsModule} from "../../utils/tabs/tabs.module";
|
import {TabsModule} from "../../utils/tabs/tabs.module";
|
||||||
import {LoadingModule} from "../../utils/loading/loading.module";
|
import {LoadingModule} from "../../utils/loading/loading.module";
|
||||||
|
import {OrcidModule} from "../../orcid/orcid.module";
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [
|
imports: [
|
||||||
CommonModule, FormsModule, LandingModule, SharedModule, RouterModule,
|
CommonModule, FormsModule, LandingModule, SharedModule, RouterModule,
|
||||||
CiteThisModule, PagingModule, IFrameModule,
|
CiteThisModule, PagingModule, IFrameModule,
|
||||||
MetricsModule, AltMetricsModule, Schema2jsonldModule, SEOServiceModule,
|
MetricsModule, AltMetricsModule, Schema2jsonldModule, SEOServiceModule,
|
||||||
DeletedByInferenceModule, ShowAuthorsModule, HelperModule, ResultLandingUtilsModule, AlertModalModule, AnnotationModule, LandingHeaderModule, NoLoadPaging, ResultPreviewModule, FeedbackModule, TabsModule, LoadingModule
|
DeletedByInferenceModule, ShowAuthorsModule, HelperModule, ResultLandingUtilsModule, AlertModalModule,
|
||||||
|
AnnotationModule, LandingHeaderModule, NoLoadPaging, ResultPreviewModule, FeedbackModule, TabsModule, LoadingModule,
|
||||||
|
OrcidModule
|
||||||
],
|
],
|
||||||
declarations: [
|
declarations: [
|
||||||
ResultLandingComponent
|
ResultLandingComponent
|
||||||
|
|
|
@ -3,6 +3,8 @@ import {SearchResult} from '../../utils/entities/searchResult';
|
||||||
import {EnvProperties} from '../../utils/properties/env-properties';
|
import {EnvProperties} from '../../utils/properties/env-properties';
|
||||||
import {ResultPreview} from "../../utils/result-preview/result-preview";
|
import {ResultPreview} from "../../utils/result-preview/result-preview";
|
||||||
import {HttpClient} from "@angular/common/http";
|
import {HttpClient} from "@angular/common/http";
|
||||||
|
import {OrcidService} from "../../orcid/orcid.service";
|
||||||
|
import {Session} from "../../login/utils/helper.class";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'search-result',
|
selector: 'search-result',
|
||||||
|
@ -20,7 +22,8 @@ export class SearchResultComponent implements OnInit, OnChanges {
|
||||||
@Input() properties: EnvProperties;
|
@Input() properties: EnvProperties;
|
||||||
@Input() showImpactFactors: boolean = false;
|
@Input() showImpactFactors: boolean = false;
|
||||||
|
|
||||||
constructor( private http: HttpClient/*ATHENA CODE*/) {
|
constructor( private http: HttpClient/*ATHENA CODE*/
|
||||||
|
, private orcidService: OrcidService) {
|
||||||
}
|
}
|
||||||
|
|
||||||
ngOnInit() {}
|
ngOnInit() {}
|
||||||
|
@ -35,6 +38,31 @@ export class SearchResultComponent implements OnInit, OnChanges {
|
||||||
for(let result of this.results){
|
for(let result of this.results){
|
||||||
this.previewResults.push(this.getResultPreview(result));
|
this.previewResults.push(this.getResultPreview(result));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(this.properties.environment == 'development' && Session.isLoggedIn() && this.results && this.results.length > 0) {
|
||||||
|
this.orcidService.getPutCodes(this.previewResults.map(
|
||||||
|
previewResult => {
|
||||||
|
if(previewResult.identifiers) {
|
||||||
|
let pidsArray: string[] = [];
|
||||||
|
for(let key of Array.from(previewResult.identifiers.keys())) {
|
||||||
|
pidsArray = pidsArray.concat(previewResult.identifiers.get(key));
|
||||||
|
}
|
||||||
|
return pidsArray;//.join();
|
||||||
|
}
|
||||||
|
})).subscribe(
|
||||||
|
putCodes => {
|
||||||
|
for (let i = 0; i < this.previewResults.length; i++) {
|
||||||
|
if(this.previewResults[i].identifiers) {
|
||||||
|
this.previewResults[i].orcidPutCodes = putCodes[i];
|
||||||
|
console.debug(i, this.previewResults[i].orcidPutCodes);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, error => {
|
||||||
|
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
/////////////////////// ATHENA CODE ///////////////////////
|
/////////////////////// ATHENA CODE ///////////////////////
|
||||||
// console.log(data[1]);
|
// console.log(data[1]);
|
||||||
let dois = encodeURIComponent(this.results.map((result) => result.DOIs).join(","));
|
let dois = encodeURIComponent(this.results.map((result) => result.DOIs).join(","));
|
||||||
|
|
|
@ -9,6 +9,7 @@ import {ApprovedByCommunityModule} from '../../connect/approvedByCommunity/appro
|
||||||
import {ShowAuthorsModule} from "../../utils/authors/showAuthors.module";
|
import {ShowAuthorsModule} from "../../utils/authors/showAuthors.module";
|
||||||
import {HighlightModule} from "./highlight/highlight.module";
|
import {HighlightModule} from "./highlight/highlight.module";
|
||||||
import {ResultPreviewModule} from "../../utils/result-preview/result-preview.module";
|
import {ResultPreviewModule} from "../../utils/result-preview/result-preview.module";
|
||||||
|
import {OrcidService} from "../../orcid/orcid.service";
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [
|
imports: [
|
||||||
|
@ -21,6 +22,7 @@ import {ResultPreviewModule} from "../../utils/result-preview/result-preview.mod
|
||||||
SearchResultComponent
|
SearchResultComponent
|
||||||
],
|
],
|
||||||
providers:[
|
providers:[
|
||||||
|
OrcidService
|
||||||
],
|
],
|
||||||
exports: [
|
exports: [
|
||||||
SearchResultComponent
|
SearchResultComponent
|
||||||
|
|
|
@ -4,7 +4,7 @@ import {HttpHeaders} from "@angular/common/http";
|
||||||
|
|
||||||
export class CustomOptions {
|
export class CustomOptions {
|
||||||
|
|
||||||
public static registryOptions(): any {
|
public static registryOptions(): {} {
|
||||||
return {
|
return {
|
||||||
headers: new HttpHeaders({
|
headers: new HttpHeaders({
|
||||||
'Content-Type': 'application/json',
|
'Content-Type': 'application/json',
|
||||||
|
|
|
@ -4,6 +4,7 @@ export class SearchResult {
|
||||||
title: ResultTitle;
|
title: ResultTitle;
|
||||||
id: string;
|
id: string;
|
||||||
DOIs: string[]=[];
|
DOIs: string[]=[];
|
||||||
|
identifiers: Map<string, string[]>;
|
||||||
|
|
||||||
//publications & datasets & orp & software & projects & dataproviders:
|
//publications & datasets & orp & software & projects & dataproviders:
|
||||||
description: string;
|
description: string;
|
||||||
|
@ -30,6 +31,7 @@ export class SearchResult {
|
||||||
//projects:
|
//projects:
|
||||||
acronym: string;
|
acronym: string;
|
||||||
code: string;
|
code: string;
|
||||||
|
// callIdentifier?: string; // currently not parsed
|
||||||
funderShortname: string;
|
funderShortname: string;
|
||||||
budget?: string;
|
budget?: string;
|
||||||
contribution?: string;
|
contribution?: string;
|
||||||
|
|
|
@ -30,6 +30,7 @@ export interface EnvProperties {
|
||||||
searchDataciteAPIURL?: string;
|
searchDataciteAPIURL?: string;
|
||||||
searchOrcidURL?: string;
|
searchOrcidURL?: string;
|
||||||
orcidURL?: string;
|
orcidURL?: string;
|
||||||
|
orcidAPIURL?: string;
|
||||||
doiURL?: string;
|
doiURL?: string;
|
||||||
pmcURL?: string;
|
pmcURL?: string;
|
||||||
pmidURL?: string;
|
pmidURL?: string;
|
||||||
|
|
|
@ -262,9 +262,11 @@
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div *ngIf="(result.pop_inf && result.DOI) || (loggedIn && result.identifiers && result.identifiers.size > 0)"
|
||||||
|
class="result-preview-bottom">
|
||||||
<!-- Impact Factors-->
|
<!-- Impact Factors-->
|
||||||
<span *ngIf="result.pop_inf && result.DOI" class="uk-flex uk-flex-middle">
|
<span class="uk-flex uk-flex-middle">
|
||||||
|
<ng-container *ngIf="result.pop_inf && result.DOI">
|
||||||
<!--Popularity -->
|
<!--Popularity -->
|
||||||
<a title="Popularity" class="popularity-{{result.pop_inf[0]}} uk-margin-right uk-flex uk-flex-middle">
|
<a title="Popularity" class="popularity-{{result.pop_inf[0]}} uk-margin-right uk-flex uk-flex-middle">
|
||||||
<svg xmlns="http://www.w3.org/2000/svg" width="10.749" height="14.33" viewBox="0 0 10.749 14.33"><defs><!--<style>.a{fill:#d51717;}</style>--></defs><path
|
<svg xmlns="http://www.w3.org/2000/svg" width="10.749" height="14.33" viewBox="0 0 10.749 14.33"><defs><!--<style>.a{fill:#d51717;}</style>--></defs><path
|
||||||
|
@ -299,7 +301,7 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!--Influence -->
|
<!--Influence -->
|
||||||
<a title="Influence" class="influence-{{result.pop_inf[1]}} uk-flex uk-flex-middle">
|
<a title="Influence" class="influence-{{result.pop_inf[1]}} uk-margin-right uk-flex uk-flex-middle">
|
||||||
<svg xmlns="http://www.w3.org/2000/svg" width="12.667" height="14" viewBox="0 0 12.667 14">
|
<svg xmlns="http://www.w3.org/2000/svg" width="12.667" height="14" viewBox="0 0 12.667 14">
|
||||||
<defs><!--<style>.a{fill:#e1920a;}</style>--></defs>
|
<defs><!--<style>.a{fill:#e1920a;}</style>--></defs>
|
||||||
<path class="a"
|
<path class="a"
|
||||||
|
@ -334,5 +336,12 @@
|
||||||
"https://bip.imis.athena-innovation.gr/site/details?id={{result.DOI}}">View more details</a>
|
"https://bip.imis.athena-innovation.gr/site/details?id={{result.DOI}}">View more details</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</ng-container>
|
||||||
|
<span *ngIf="properties.environment == 'development' && loggedIn && result.identifiers && result.identifiers.size > 0"
|
||||||
|
class="uk-margin-right uk-flex uk-flex-middle uk-flex-right uk-width-expand">
|
||||||
|
<orcid-work [resultId]="result.id" [type]="result.resultType" [pageType]="'search'"
|
||||||
|
[putCodes]="result.orcidPutCodes" [givenPutCode]="true">
|
||||||
|
</orcid-work>
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -4,6 +4,7 @@ import {EnvProperties} from "../properties/env-properties";
|
||||||
import {RouterHelper} from "../routerHelper.class";
|
import {RouterHelper} from "../routerHelper.class";
|
||||||
import {AlertModal} from "../modal/alert";
|
import {AlertModal} from "../modal/alert";
|
||||||
import {properties} from "../../../../environments/environment";
|
import {properties} from "../../../../environments/environment";
|
||||||
|
import {Session} from "../../login/utils/helper.class";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'result-preview',
|
selector: 'result-preview',
|
||||||
|
@ -22,8 +23,12 @@ export class ResultPreviewComponent implements OnInit{
|
||||||
public type: string;
|
public type: string;
|
||||||
public beforeTitle: string[] = [];
|
public beforeTitle: string[] = [];
|
||||||
public dataProviderUrl = properties.searchLinkToDataProvider.split('?')[0];
|
public dataProviderUrl = properties.searchLinkToDataProvider.split('?')[0];
|
||||||
|
public loggedIn: boolean = false;
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
|
if (Session.isLoggedIn()) {
|
||||||
|
this.loggedIn = true;
|
||||||
|
}
|
||||||
if (this.result.resultType === "publication") {
|
if (this.result.resultType === "publication") {
|
||||||
this.urlParam = "articleId";
|
this.urlParam = "articleId";
|
||||||
this.url = properties.searchLinkToPublication.split('?')[0];
|
this.url = properties.searchLinkToPublication.split('?')[0];
|
||||||
|
|
|
@ -4,9 +4,10 @@ import {ResultPreviewComponent} from "./result-preview.component";
|
||||||
import {RouterModule} from "@angular/router";
|
import {RouterModule} from "@angular/router";
|
||||||
import {ShowAuthorsModule} from "../authors/showAuthors.module";
|
import {ShowAuthorsModule} from "../authors/showAuthors.module";
|
||||||
import {ResultLandingUtilsModule} from "../../landingPages/landing-utils/resultLandingUtils.module";
|
import {ResultLandingUtilsModule} from "../../landingPages/landing-utils/resultLandingUtils.module";
|
||||||
|
import {OrcidModule} from "../../orcid/orcid.module";
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [CommonModule, RouterModule, ShowAuthorsModule, ResultLandingUtilsModule],
|
imports: [CommonModule, RouterModule, ShowAuthorsModule, ResultLandingUtilsModule, OrcidModule],
|
||||||
declarations: [ResultPreviewComponent],
|
declarations: [ResultPreviewComponent],
|
||||||
exports: [ResultPreviewComponent]
|
exports: [ResultPreviewComponent]
|
||||||
})
|
})
|
||||||
|
|
|
@ -90,6 +90,7 @@ export class ResultPreview {
|
||||||
languages: string[];
|
languages: string[];
|
||||||
identifiers: Map<string, string[]>; //key is the classname
|
identifiers: Map<string, string[]>; //key is the classname
|
||||||
hostedBy_collectedFrom: HostedByCollectedFrom[];
|
hostedBy_collectedFrom: HostedByCollectedFrom[];
|
||||||
|
orcidPutCodes: string[];
|
||||||
|
|
||||||
//datasets & orp & software:
|
//datasets & orp & software:
|
||||||
publisher: string;
|
publisher: string;
|
||||||
|
@ -178,10 +179,11 @@ export class ResultPreview {
|
||||||
resultPreview.subjects = result.subjects;
|
resultPreview.subjects = result.subjects;
|
||||||
resultPreview.resultType = type;
|
resultPreview.resultType = type;
|
||||||
//impact factor;
|
//impact factor;
|
||||||
if(result.DOIs && result.DOIs.length > 0) {
|
// if(result.DOIs && result.DOIs.length > 0) {
|
||||||
resultPreview.identifiers = new Map();
|
// resultPreview.identifiers = new Map();
|
||||||
resultPreview.identifiers.set("doi", result.DOIs);
|
// resultPreview.identifiers.set("doi", result.DOIs);
|
||||||
}
|
// }
|
||||||
|
resultPreview.identifiers = result.identifiers;
|
||||||
return resultPreview;
|
return resultPreview;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue