Merge branch 'new-theme' of code-repo.d4science.org:MaDgIK/openaire-library into new-theme

This commit is contained in:
Konstantinos Triantafyllou 2022-08-02 23:13:19 +03:00
commit 35c3728d7b
16 changed files with 105 additions and 120 deletions

View File

@ -13,6 +13,7 @@ import {ActivatedRoute} from "@angular/router";
<li [class.uk-active]="tab === 'entity'"><a routerLink="../entities">Entities</a></li> <li [class.uk-active]="tab === 'entity'"><a routerLink="../entities">Entities</a></li>
<li *ngIf="portal && type === 'community'" [class.uk-active]="tab === 'menu'"><a routerLink="../menu">Menu</a></li> <li *ngIf="portal && type === 'community'" [class.uk-active]="tab === 'menu'"><a routerLink="../menu">Menu</a></li>
<li *ngIf="isPortalAdmin && !portal" [class.uk-active]="tab === 'class'"><a routerLink="../classes">Classes</a></li> <li *ngIf="isPortalAdmin && !portal" [class.uk-active]="tab === 'class'"><a routerLink="../classes">Classes</a></li>
<li *ngIf="isPortalAdmin && portal=='connect'" [class.uk-active]="tab === 'customization'"><a routerLink="../customization">Customization</a></li>
</ul> </ul>
` `
}) })
@ -24,7 +25,7 @@ export class AdminTabsComponent implements OnInit {
@Input() @Input()
public user: User; public user: User;
@Input() @Input()
public tab: "portal" | "page" | "entity" | "menu" | "class" = 'page'; public tab: "portal" | "page" | "entity" | "menu" | "class" | "customization"= 'page';
private subscriptions: any[] = []; private subscriptions: any[] = [];
constructor(private route: ActivatedRoute, private userManagementService: UserManagementService) { constructor(private route: ActivatedRoute, private userManagementService: UserManagementService) {

View File

@ -445,7 +445,7 @@
<div class="uk-margin-medium-top uk-list uk-list-large uk-padding uk-padding-remove-vertical" [class.uk-list-divider]="!viewAll"> <div class="uk-margin-medium-top uk-list uk-list-large uk-padding uk-padding-remove-vertical" [class.uk-list-divider]="!viewAll">
<!-- EOSC Services--> <!-- EOSC Services-->
<!-- 1 link --> <!-- 1 link -->
<div *ngIf="resultLandingInfo.eoscSubjects?.length == 1 && (properties.adminToolsPortalType == 'explore' || properties.adminToolsPortalType == 'eosc') <div *ngIf="resultLandingInfo.eoscSubjects?.length == 1 && properties.adminToolsPortalType == 'eosc'
&& (!viewAll || viewAll=='egiNotebook')"> && (!viewAll || viewAll=='egiNotebook')">
<a class="uk-link-text uk-text-bold custom-external" <a class="uk-link-text uk-text-bold custom-external"
target="_blank" [href]="resultLandingInfo.eoscSubjects[0].link"> target="_blank" [href]="resultLandingInfo.eoscSubjects[0].link">
@ -455,7 +455,7 @@
</a> </a>
</div> </div>
<!-- more than 1 links --> <!-- more than 1 links -->
<div *ngIf="resultLandingInfo.eoscSubjects?.length > 1 && (properties.adminToolsPortalType == 'explore' || properties.adminToolsPortalType == 'eosc') <div *ngIf="resultLandingInfo.eoscSubjects?.length > 1 && properties.adminToolsPortalType == 'eosc'
&& (!viewAll || viewAll=='egiNotebook')"> && (!viewAll || viewAll=='egiNotebook')">
<a class="uk-link-text uk-text-bold"> <a class="uk-link-text uk-text-bold">
<img src="assets/common-assets/eosc-logo.png" <img src="assets/common-assets/eosc-logo.png"

View File

@ -18,7 +18,7 @@
<form (ngSubmit)="queryChanged()" class="uk-card uk-card-default uk-box-shadow-medium"> <form (ngSubmit)="queryChanged()" class="uk-card uk-card-default uk-box-shadow-medium">
<button type="submit" class="uk-hidden"></button> <button type="submit" class="uk-hidden"></button>
<div class="uk-card-body uk-height-medium uk-overflow-auto"> <div class="uk-card-body uk-height-medium uk-overflow-auto">
<table class="uk-table uk-table-middle uk-text-small uk-table-responsive uk-table-small uk-margin-remove"> <table class="uk-table uk-text-small uk-table-responsive uk-table-small uk-margin-remove">
<tr> <tr>
<td class="uk-text-bold uk-text-uppercase uk-width-2-5">Searching Fields</td> <td class="uk-text-bold uk-text-uppercase uk-width-2-5">Searching Fields</td>
<td class="uk-text-bold uk-text-uppercase uk-width-1-3">Terms</td> <td class="uk-text-bold uk-text-uppercase uk-width-1-3">Terms</td>

View File

@ -7,37 +7,36 @@ import { MatDatepickerInputEvent } from "@angular/material/datepicker";
@Component({ @Component({
selector: 'date-filter', selector: 'date-filter',
template: ` template: `
<div class=""> <div>
<mat-select *ngIf="dateValue && dateValue.type!='range' " name="{{'select_date_type'+filterId}}" class=" matSelection uk-input" [(ngModel)]=dateValue.type [disableOptionCentering]="true" panelClass="matSelectionPanel"> <mat-select *ngIf="dateValue && dateValue.type!='range' " name="{{'select_date_type'+filterId}}" class=" matSelection uk-input" [(ngModel)]=dateValue.type [disableOptionCentering]="true" panelClass="matSelectionPanel">
<mat-option *ngFor="let type of dateValue.types let i = index" [value]="type" (click)="typeChanged(type)">{{dateValue.typesTitle[i]}}</mat-option> <mat-option *ngFor="let type of dateValue.types let i = index" [value]="type" (click)="typeChanged(type)">{{dateValue.typesTitle[i]}}</mat-option>
</mat-select> </mat-select>
<div *ngIf="dateValue && dateValue.type=='range' "> <div *ngIf="dateValue && dateValue.type=='range' ">
<div class=" uk-grid uk-margin-remove-left" > <div class=" uk-grid uk-margin-remove-left" >
<div class="uk-padding-remove uk-width-small"> <div class="uk-padding-remove uk-margin-small-bottom uk-width-1-1">
<mat-select name="{{'select_date_type'+filterId}}" [(ngModel)]=dateValue.type [disableOptionCentering]="true" class="matSelection uk-input" panelClass="matSelectionPanel"> <mat-select name="{{'select_date_type'+filterId}}" [(ngModel)]=dateValue.type [disableOptionCentering]="true" class="matSelection uk-input" panelClass="matSelectionPanel">
<mat-option *ngFor="let type of dateValue.types let i = index" [value]="type" (click)="typeChanged(type)">{{dateValue.typesTitle[i]}}</mat-option> <mat-option *ngFor="let type of dateValue.types let i = index" [value]="type" (click)="typeChanged(type)">{{dateValue.typesTitle[i]}}</mat-option>
</mat-select> </mat-select>
</div> </div>
<div class="uk-padding-remove uk-margin-small-left" style=""> <div class="uk-padding-remove uk-margin-small-left uk-width-1-1">
<mat-form-field class="uk-width-small"> <mat-form-field class="uk-width-1-1">
<input matInput [matDatepicker]="pickerFrom" placeholder="Choose from date" <input matInput [matDatepicker]="pickerFrom" placeholder="Choose from date"
[formControl]="fromDate" (click)="pickerFrom.open()" (dateChange)="fromDateChanged($event)"> [formControl]="fromDate" (click)="pickerFrom.open()" (dateChange)="fromDateChanged($event)">
<mat-datepicker-toggle matSuffix [for]="pickerFrom"></mat-datepicker-toggle> <mat-datepicker-toggle matSuffix [for]="pickerFrom"></mat-datepicker-toggle>
<mat-datepicker #pickerFrom></mat-datepicker> <mat-datepicker #pickerFrom></mat-datepicker>
</mat-form-field> </mat-form-field>
</div> </div>
<div class="uk-padding-remove uk-margin-small-left" style=""> <div class="uk-padding-remove uk-margin-small-left uk-width-1-1">
<mat-form-field class="uk-width-small"> <mat-form-field class="uk-width-1-1">
<input matInput [matDatepicker]="pickerTo" placeholder="Choose to date" <input matInput [matDatepicker]="pickerTo" placeholder="Choose to date"
[formControl]="toDate" (click)="pickerTo.open()" (dateChange)="toDateChanged($event)"> [formControl]="toDate" (click)="pickerTo.open()" (dateChange)="toDateChanged($event)">
<mat-datepicker-toggle matSuffix [for]="pickerTo"></mat-datepicker-toggle> <mat-datepicker-toggle matSuffix [for]="pickerTo"></mat-datepicker-toggle>
<mat-datepicker #pickerTo></mat-datepicker> <mat-datepicker #pickerTo></mat-datepicker>
</mat-form-field> </mat-form-field>
</div> </div>
</div>
</div> </div>
</div> </div>
</div>
` `
}) })

View File

@ -78,7 +78,7 @@ export class EntitiesSelectionComponent {
} }
if(showPage[this.simpleView ? this.properties.searchLinkToResults : this.properties.searchLinkToAdvancedResults] if(showPage[this.simpleView ? this.properties.searchLinkToResults : this.properties.searchLinkToAdvancedResults]
&& (showEntity["publication"] || showEntity["dataset"] || showEntity["software"] || showEntity["orp"])) { && (showEntity["publication"] || showEntity["dataset"] || showEntity["software"] || showEntity["orp"])) {
this.entities.push({label: OpenaireEntities.RESULTS, value: 'result', tooltip: OpenaireEntities.PUBLICATIONS+', '+OpenaireEntities.DATASETS+', '+OpenaireEntities.SOFTWARE+', '+OpenaireEntities.OTHER}); this.entities.push({label: OpenaireEntities.RESULTS, value: 'result', tooltip: OpenaireEntities.RESULTS+' ('+OpenaireEntities.PUBLICATIONS.toLowerCase()+', '+OpenaireEntities.DATASETS.toLowerCase()+', '+OpenaireEntities.SOFTWARE.toLowerCase()+', '+OpenaireEntities.OTHER.toLowerCase()+')'});
} }
if(showPage[this.simpleView ? this.properties.searchLinkToProjects : this.properties.searchLinkToAdvancedProjects] && showEntity["project"]) { if(showPage[this.simpleView ? this.properties.searchLinkToProjects : this.properties.searchLinkToAdvancedProjects] && showEntity["project"]) {
this.entities.push({label: OpenaireEntities.PROJECTS, value: 'project'}); this.entities.push({label: OpenaireEntities.PROJECTS, value: 'project'});

View File

@ -300,9 +300,7 @@
[results]="results" [results]="results"
[status]=searchUtils.status [status]=searchUtils.status
[type]="entityType" [type]="entityType"
[showLoading]="true" [properties]=properties [showImpactFactors]="(customFilter && [showLoading]="true" [properties]=properties>
customFilter.queryFieldName == 'communityId' && (customFilter.valueId ==
'elixir-gr' || customFilter.valueId == 'inspired-ris'))">
</search-result> </search-result>
<deposit-result *ngIf="usedBy == 'deposit'" <deposit-result *ngIf="usedBy == 'deposit'"
[results]="results" [results]="results"

View File

@ -21,7 +21,6 @@ export class SearchResultComponent implements OnInit, OnChanges {
@Input() showOrganizations: boolean = true; @Input() showOrganizations: boolean = true;
@Input() custom_class: string = ""; @Input() custom_class: string = "";
@Input() properties: EnvProperties; @Input() properties: EnvProperties;
@Input() showImpactFactors: boolean = false;
@Input() showEnermaps: boolean; @Input() showEnermaps: boolean;
constructor( private http: HttpClient/*ATHENA CODE*/ constructor( private http: HttpClient/*ATHENA CODE*/
@ -67,63 +66,6 @@ export class SearchResultComponent implements OnInit, OnChanges {
} }
); );
} }
/////////////////////// ATHENA CODE ///////////////////////
// console.log(data[1]);
let dois = encodeURIComponent(this.results.map((result) => result.DOIs).join(","));
// console.log(dois);
if(dois.length > 0 && this.showImpactFactors && (this.properties.impactFactorsAPIURL && this.properties.impactFactorsAPIURL.length > 0) ) {
let url = this.properties.impactFactorsAPIURL + dois;
this.sub = this.http.get((this.properties.useCache?(this.properties.cacheUrl+(encodeURIComponent(url))):url)).subscribe((data_received:any[]) => {
let impact =[];
data_received.forEach(function (result) {
if(result.doi && result.doi.length > 0 && result.pop_class!=null && result.inf_class!=null)
impact[result.doi]=result;
});
this.previewResults.forEach(function (result) {
if(result.identifiers && result.identifiers.get("doi")) {
result.identifiers.get("doi").forEach(function (doi) {
if (impact[doi]) {
result.DOI = doi;
}
})
}
});
for (let i = 0; i < this.previewResults.length; i++) {
if (this.previewResults[i].DOI) {
this.previewResults[i].pop_inf = new Array<string>();
this.previewResults[i].pop_inf.push(impact[this.previewResults[i].DOI].pop_class, impact[this.previewResults[i].DOI].inf_class);
if(this.previewResults[i].pop_inf[0]=="A"){
// this.previewResults[i].pop_inf.push("High");
this.previewResults[i].pop_inf.push("Exceptional");
}else if(this.previewResults[i].pop_inf[0]=="B"){
// this.previewResults[i].pop_inf.push("Average");
this.previewResults[i].pop_inf.push("Substantial");
}else{
// this.previewResults[i].pop_inf.push("low");
this.previewResults[i].pop_inf.push("Average");
}
if(this.previewResults[i].pop_inf[1]=="A"){
// this.previewResults[i].pop_inf.push("Strong");
this.previewResults[i].pop_inf.push("Exceptional");
}else if(this.previewResults[i].pop_inf[1]=="B"){
// this.previewResults[i].pop_inf.push("Average");
this.previewResults[i].pop_inf.push("Substantial");
}else{
// this.previewResults[i].pop_inf.push("Weak");
this.previewResults[i].pop_inf.push("Average");
}
}
}
}, error1 => {
console.error("Failed to get Impact factors for elixir-gr")
});
// console.log(researchResults[1]);
}
/////////////////////// ATHENA CODE ///////////////////////
} }
ngOnChanges(changes: SimpleChanges): void { ngOnChanges(changes: SimpleChanges): void {

View File

@ -24,9 +24,9 @@ export class LayoutService {
return this.http.post(connectPortalUrl + "/build-css/" + (layout?"preview/":"") + pid + (suffix?("/"+ suffix):""), layout ); return this.http.post(connectPortalUrl + "/build-css/" + (layout?"preview/":"") + pid + (suffix?("/"+ suffix):""), layout );
} }
saveLayout(properties: EnvProperties, pid: string, layout: Layout): Observable<Layout> { saveLayout(properties: EnvProperties, pid: string, layout: Layout, portalType = null): Observable<Layout> {
LayoutService.removeNulls(layout); LayoutService.removeNulls(layout);
return this.http.post<Layout>(properties.adminToolsAPIURL + '/' + properties.adminToolsPortalType + '/' return this.http.post<Layout>(properties.adminToolsAPIURL + '/' + (portalType?portalType: properties.adminToolsPortalType) + '/'
+ pid + '/layout', layout, CustomOptions.getAuthOptionsWithBody()); + pid + '/layout', layout, CustomOptions.getAuthOptionsWithBody());
} }
@ -34,7 +34,9 @@ export class LayoutService {
return this.http.get<Layout>(properties.adminToolsAPIURL+"/" + properties.adminToolsPortalType + '/' return this.http.get<Layout>(properties.adminToolsAPIURL+"/" + properties.adminToolsPortalType + '/'
+ pid + '/layout'); + pid + '/layout');
} }
getLayouts(properties: EnvProperties): Observable<Layout[]> {
return this.http.get<Layout[]>(properties.adminToolsAPIURL+'/community/layouts');
}
mockLayout(): any { mockLayout(): any {
return this.http.get('./assets/customizationOptions.json') ; return this.http.get('./assets/customizationOptions.json') ;

View File

@ -199,6 +199,32 @@ export class SearchResearchResultsService {
instance = Array.isArray(resData['children']['instance']) ? resData['children']['instance'][i] : resData['children']['instance']; instance = Array.isArray(resData['children']['instance']) ? resData['children']['instance'][i] : resData['children']['instance'];
this.parsingFunctions.parseTypes(result.types, types, instance); this.parsingFunctions.parseTypes(result.types, types, instance);
} }
// Measure
result.measure = new Array<string>();
if (resData['measure'] && Array.isArray(resData['measure'])) {
for (let i = 0; i < resData['measure'].length; i++) {
if (resData['measure'][i].id == 'influence') {
result.measure[1] = resData['measure'][i].class;
if (resData['measure'][i].class == 'A') {
result.measure[3] = 'Exceptional';
} else if (resData['measure'][i].class == 'B') {
result.measure[3] = 'Substantial';
} else {
result.measure[3] = 'Average';
}
}
if (resData['measure'][i].id == 'popularity') {
result.measure[0] = resData['measure'][i].class;
if (resData['measure'][i].class == 'A') {
result.measure[2] = 'Exceptional';
} else if (resData['measure'][i].class == 'B') {
result.measure[2] = 'Substantial';
} else {
result.measure[2] = 'Average';
}
}
}
}
/////////////////////////// Athena Code /////////////////////////// /////////////////////////// Athena Code ///////////////////////////
if (resData['pid']) { if (resData['pid']) {
if (!Array.isArray(resData['pid'])) { if (!Array.isArray(resData['pid'])) {
@ -370,7 +396,6 @@ export class SearchResearchResultsService {
} }
results.push(result); results.push(result);
} }
return results; return results;
} }

View File

@ -59,7 +59,7 @@ declare var UIkit;
<label>{{placeholderInfo.label}} <sup *ngIf="required">*</sup></label> <label>{{placeholderInfo.label}} <sup *ngIf="required">*</sup></label>
</div> </div>
<div class="uk-flex" [class.uk-flex-middle]="type !== 'textarea'" <div class="uk-flex" [class.uk-flex-middle]="type !== 'textarea'"
[attr.uk-tooltip]="(tooltip && formControl.value && !focused && type !== 'chips' && type !== 'textarea')?('title: ' + getLabel(formControl.value) + '; delay: 500; pos: bottom-left'):null"> [attr.uk-tooltip]="(tooltip && formControl.value && !focused && type !== 'chips' && type !== 'textarea')?('title: ' + getTooltip(formControl.value) + '; delay: 500; pos: bottom-left'):null">
<ng-template [ngIf]="type === 'text' || type === 'URL' || type === 'logoURL'"> <ng-template [ngIf]="type === 'text' || type === 'URL' || type === 'logoURL'">
<input #input class="input" [attr.placeholder]="placeholderInfo?.static?placeholderInfo.label:hint" <input #input class="input" [attr.placeholder]="placeholderInfo?.static?placeholderInfo.label:hint"
[formControl]="formAsControl" [class.uk-text-truncate]="!focused"> [formControl]="formAsControl" [class.uk-text-truncate]="!focused">
@ -498,6 +498,11 @@ export class InputComponent implements OnInit, OnDestroy, AfterViewInit, OnChang
return (option) ? option.label : (value); return (option) ? option.label : (value);
} }
getTooltip(value: any): string {
let option = this.optionsArray.find(option => HelperFunctions.equals(option.value, value));
return (option) ? (option.tooltip ? option.tooltip : option.label) : (value);
}
focus(value: boolean, event = null) { focus(value: boolean, event = null) {
if (this.focused) { if (this.focused) {
this.formControl.markAsTouched(); this.formControl.markAsTouched();

View File

@ -6,6 +6,7 @@ export class SearchResult {
relcanId: string; relcanId: string;
DOIs: string[]=[]; DOIs: string[]=[];
identifiers: Map<string, string[]>; identifiers: Map<string, string[]>;
measure: Array<string>;
//publications & datasets & orp & software & projects & dataproviders: //publications & datasets & orp & software & projects & dataproviders:
description: string; description: string;

View File

@ -309,29 +309,29 @@
</div> </div>
</div> </div>
<!--&& loggedIn (card footer)--> <!--&& loggedIn (card footer)-->
<div *ngIf="(result.pop_inf && result.DOI) || <div *ngIf="result.measure?.length ||
((properties.adminToolsPortalType == 'explore' || properties.adminToolsPortalType == 'community') && ((properties.adminToolsPortalType == 'explore' || properties.adminToolsPortalType == 'community') &&
((showOrcid && result.identifiers && result.identifiers.size > 0 && isResultType) || result.orcidCreationDates?.length > 0))" ((showOrcid && result.identifiers && result.identifiers.size > 0 && isResultType) || result.orcidCreationDates?.length > 0))"
class="uk-text-small" class="uk-text-small"
[ngClass]="{'uk-card-footer': isCard}"> [ngClass]="{'uk-card-footer': isCard}">
<!-- Impact Factors--> <!-- Impact Factors-->
<span class="uk-flex uk-flex-top uk-flex-wrap" style="grid-gap: 10px;"> <span class="uk-flex uk-flex-top uk-flex-wrap" style="grid-gap: 10px;">
<ng-container *ngIf="result.pop_inf && result.DOI"> <ng-container *ngIf="result.measure?.length">
<!--Popularity --> <!--Popularity -->
<a title="Popularity" class="popularity-{{result.pop_inf[0]}} uk-margin-right uk-flex uk-flex-middle uk-width-auto@s uk-width-1-1"> <a title="Popularity" class="popularity-{{result.measure[0]}} uk-margin-right uk-flex uk-flex-middle uk-width-auto@s uk-width-1-1">
<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
class="a" class="a"
d="M10.382.67a14.44,14.44,0,0,1,.5,3.225A2.331,2.331,0,0,1,8.589,6.4,2.445,2.445,0,0,1,6.15,3.895l.02-.242A9.25,9.25,0,0,0,4,9.625a5.375,5.375,0,0,0,10.749,0A11.5,11.5,0,0,0,10.382.67ZM9.18,12.985a2.134,2.134,0,0,1-2.163-2.11A2.1,2.1,0,0,1,8.9,8.779a5.181,5.181,0,0,0,3.1-1.733,9.374,9.374,0,0,1,.4,2.714A3.226,3.226,0,0,1,9.18,12.985Z" d="M10.382.67a14.44,14.44,0,0,1,.5,3.225A2.331,2.331,0,0,1,8.589,6.4,2.445,2.445,0,0,1,6.15,3.895l.02-.242A9.25,9.25,0,0,0,4,9.625a5.375,5.375,0,0,0,10.749,0A11.5,11.5,0,0,0,10.382.67ZM9.18,12.985a2.134,2.134,0,0,1-2.163-2.11A2.1,2.1,0,0,1,8.9,8.779a5.181,5.181,0,0,0,3.1-1.733,9.374,9.374,0,0,1,.4,2.714A3.226,3.226,0,0,1,9.18,12.985Z"
transform="translate(-4 -0.67)"/> transform="translate(-4 -0.67)"/>
</svg> </svg>
<span class="uk-margin-small-left"> <span class="uk-margin-small-left">
{{" " + result.pop_inf[2] + " popularity" }} {{" " + result.measure[2] + " popularity" }}
</span> </span>
</a> </a>
<div class="default-dropdown uk-margin-remove-top uk-padding-small" <div class="default-dropdown uk-margin-remove-top uk-padding-small"
uk-dropdown="pos: bottom-left; mode:click" style="min-width: 70px !important;"> uk-dropdown="pos: bottom-left; mode:click" style="min-width: 70px !important;">
<span class="uk-flex uk-flex-middle"> <span class="uk-flex uk-flex-middle">
<span class="popularity-{{result.pop_inf[0]}}"> <span class="popularity-{{result.measure[0]}}">
<svg xmlns="http://www.w3.org/2000/svg" width="20.234" height="26.974" <svg xmlns="http://www.w3.org/2000/svg" width="20.234" height="26.974"
viewBox="0 0 20.234 26.974"><defs> </defs><path class="a" viewBox="0 0 20.234 26.974"><defs> </defs><path class="a"
d="M16.014.67a27.181,27.181,0,0,1,.936,6.07c0,2.605-1.707,4.717-4.312,4.717A4.6,4.6,0,0,1,8.047,6.74l.038-.455A17.411,17.411,0,0,0,4,17.527a10.117,10.117,0,0,0,20.234,0A21.643,21.643,0,0,0,16.014.67ZM13.75,23.85A4.016,4.016,0,0,1,9.678,19.88c0-2.049,1.328-3.49,3.554-3.946a9.753,9.753,0,0,0,5.843-3.263,17.645,17.645,0,0,1,.746,5.109,6.072,6.072,0,0,1-6.07,6.07Z" d="M16.014.67a27.181,27.181,0,0,1,.936,6.07c0,2.605-1.707,4.717-4.312,4.717A4.6,4.6,0,0,1,8.047,6.74l.038-.455A17.411,17.411,0,0,0,4,17.527a10.117,10.117,0,0,0,20.234,0A21.643,21.643,0,0,0,16.014.67ZM13.75,23.85A4.016,4.016,0,0,1,9.678,19.88c0-2.049,1.328-3.49,3.554-3.946a9.753,9.753,0,0,0,5.843-3.263,17.645,17.645,0,0,1,.746,5.109,6.072,6.072,0,0,1-6.07,6.07Z"
@ -339,23 +339,23 @@
</svg> </svg>
</span> </span>
<span class="uk-margin-small-left"> <span class="uk-margin-small-left">
{{" " + result.pop_inf[2] + " popularity" }} {{" " + result.measure[2] + " popularity" }}
</span> </span>
<span class="uk-margin-small-left"> <span class="uk-margin-small-left">
{{" " + (result.pop_inf[0] == 'A' ? 'In top 0.01%' : '') + (result.pop_inf[0] == 'B' ? 'In top 1%' : '') + (result.pop_inf[0] == 'C' ? 'In bottom 99%' : '')}} {{" " + (result.measure[0] == 'A' ? 'In top 0.01%' : '') + (result.measure[0] == 'B' ? 'In top 1%' : '') + (result.measure[0] == 'C' ? 'In bottom 99%' : '')}}
</span> </span>
</span> </span>
<div class="uk-text-meta uk-margin"> <div class="uk-text-meta uk-margin">
Popularity: Citation-based measure reflecting the current impact. Popularity: Citation-based measure reflecting the current impact.
</div> </div>
<div> <div>
<a title="Link to Bip!Finder" class="uk-float-right" target="_blank" href="https://bip.imis.athena-innovation.gr/site/details?id={{result.DOI}}"> <a title="Link to Bip!Finder" class="uk-float-right" target="_blank" href="https://bip.imis.athena-innovation.gr/site/details?id={{result.id}}">
View more details View more details
</a> </a>
</div> </div>
</div> </div>
<!--Influence --> <!--Influence -->
<a title="Influence" class="influence-{{result.pop_inf[1]}} uk-margin-right uk-flex uk-flex-middle uk-width-auto@s uk-width-1-1"> <a title="Influence" class="influence-{{result.measure[1]}} uk-margin-right uk-flex uk-flex-middle uk-width-auto@s uk-width-1-1">
<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"
@ -363,13 +363,13 @@
transform="translate(-2 -1)"/> transform="translate(-2 -1)"/>
</svg> </svg>
<span class="uk-margin-small-left"> <span class="uk-margin-small-left">
{{" " + result.pop_inf[3] + " influence" }} {{" " + result.measure[3] + " influence" }}
</span> </span>
</a> </a>
<div class="default-dropdown uk-margin-remove-top uk-padding-small" <div class="default-dropdown uk-margin-remove-top uk-padding-small"
uk-dropdown="pos: bottom-left; mode:click" style="min-width: 70px !important;"> uk-dropdown="pos: bottom-left; mode:click" style="min-width: 70px !important;">
<span class="uk-flex uk-flex-middle"> <span class="uk-flex uk-flex-middle">
<span class="influence-{{result.pop_inf[1]}}"> <span class="influence-{{result.measure[1]}}">
<svg xmlns="http://www.w3.org/2000/svg" width="24.299" height="26.857" viewBox="0 0 24.299 26.857"><defs><style>.a { <svg xmlns="http://www.w3.org/2000/svg" width="24.299" height="26.857" viewBox="0 0 24.299 26.857"><defs><style>.a {
fill: #464646; fill: #464646;
}</style></defs><path class="a" }</style></defs><path class="a"
@ -378,17 +378,17 @@
</svg> </svg>
</span> </span>
<span class=" uk-margin-small-left"> <span class=" uk-margin-small-left">
{{result.pop_inf[3] + " influence" }} {{result.measure[3] + " influence" }}
</span> </span>
<span class="uk-margin-small-left"> <span class="uk-margin-small-left">
{{" " + (result.pop_inf[1] == 'A' ? 'In top 0.01%' : '') + (result.pop_inf[1] == 'B' ? 'In top 1%' : '') + (result.pop_inf[1] == 'C' ? 'In bottom 99%' : '')}} {{" " + (result.measure[1] == 'A' ? 'In top 0.01%' : '') + (result.measure[1] == 'B' ? 'In top 1%' : '') + (result.measure[1] == 'C' ? 'In bottom 99%' : '')}}
</span> </span>
</span> </span>
<div class="uk-text-meta uk-margin"> <div class="uk-text-meta uk-margin">
Influence: Citation-based measure reflecting the total impact. Influence: Citation-based measure reflecting the total impact.
</div> </div>
<div> <div>
<a title="Link to Bip!Finder" class=" uk-float-right" target="_blank" href="https://bip.imis.athena-innovation.gr/site/details?id={{result.DOI}}"> <a title="Link to Bip!Finder" class=" uk-float-right" target="_blank" href="https://bip.imis.athena-innovation.gr/site/details?id={{result.id}}">
View more details View more details
</a> </a>
</div> </div>

View File

@ -0,0 +1,10 @@
// Impact Factors
.popularity-A svg .a, .influence-A svg .a {
fill:#d51717;
}
.popularity-B svg .a, .influence-B svg .a {
fill: #e1920a;
}
.popularity-C svg .a, .influence-C svg .a {
fill: #444;
}

View File

@ -10,7 +10,8 @@ import {OpenaireEntities} from "../properties/searchFields";
@Component({ @Component({
selector: 'result-preview', selector: 'result-preview',
templateUrl: 'result-preview.component.html' templateUrl: 'result-preview.component.html',
styleUrls: ['result-preview.component.less']
}) })
export class ResultPreviewComponent implements OnInit, OnChanges { export class ResultPreviewComponent implements OnInit, OnChanges {
@Input() result: ResultPreview; @Input() result: ResultPreview;

View File

@ -81,7 +81,8 @@ export class ResultPreview {
//Impact factor //Impact factor
DOI:string; DOI:string;
pop_inf; measure: Array<string>;
//publications & datasets & orp & software & organizations: //publications & datasets & orp & software & organizations:
projects: Project[]; projects: Project[];
@ -194,6 +195,7 @@ export class ResultPreview {
// } // }
resultPreview.identifiers = result.identifiers; resultPreview.identifiers = result.identifiers;
resultPreview.enermapsId = result.enermapsId; resultPreview.enermapsId = result.enermapsId;
resultPreview.measure = result.measure;
return resultPreview; return resultPreview;
} }

View File

@ -39,7 +39,7 @@ import {StringUtils} from "../../string-utils.class";
<search-result [properties]="properties" <search-result [properties]="properties"
[results]="results" [results]="results"
[status]="fetch.searchUtils.status" [status]="fetch.searchUtils.status"
[type]="resultType" [showImpactFactors]="showImpactFactors" [showEnermaps]="showEnermaps"> [type]="resultType" [showEnermaps]="showEnermaps">
</search-result> </search-result>
<!-- <div *ngIf="searchLinkToAdvancedPage && fetch.results?.length > 0" class="uk-text-right">--> <!-- <div *ngIf="searchLinkToAdvancedPage && fetch.results?.length > 0" class="uk-text-right">-->
@ -59,7 +59,6 @@ export class SearchTabComponent {
@Input() public searchNumber: number = 5; @Input() public searchNumber: number = 5;
@Input() public searchLinkToAdvancedPage: string; @Input() public searchLinkToAdvancedPage: string;
@Input() properties: EnvProperties; @Input() properties: EnvProperties;
@Input() showImpactFactors;
@Input() customTitle; @Input() customTitle;
@Input() showEnermaps: boolean; @Input() showEnermaps: boolean;
@Input() currentPage: number = null; @Input() currentPage: number = null;