Merging explore-redesign branch into develop for Explore July release #7

Merged
konstantina.galouni merged 112 commits from explore-redesign into develop 2023-07-05 11:11:53 +02:00
13 changed files with 453 additions and 379 deletions
Showing only changes of commit 9715de74d2 - Show all commits

View File

@ -11,21 +11,18 @@ declare var UIkit;
<ng-container *ngIf="availableOn && availableOn.length > 0"> <ng-container *ngIf="availableOn && availableOn.length > 0">
<div class="uk-flex uk-flex-middle"> <div class="uk-flex uk-flex-middle">
<ng-container *ngIf="availableOn[0].downloadUrl"> <ng-container *ngIf="availableOn[0].downloadUrl">
<span *ngIf="source" class="uk-margin-xsmall-right">Source: </span> <span [class]="'uk-margin-xsmall-right ' + (availableOn[0].accessRightIcon == 'open_access' ? 'open-access' : 'closed-access')"
<span
[class]="'uk-margin-xsmall-right ' + (availableOn[0].accessRightIcon == 'open_access' ? 'open-access' : 'closed-access')"
uk-tooltip [title]="availableOn[0].accessRight ? availableOn[0].accessRight : 'Not available'"> uk-tooltip [title]="availableOn[0].accessRight ? availableOn[0].accessRight : 'Not available'">
<icon [name]="availableOn[0].accessRightIcon" [flex]="true" [ratio]="0.8"></icon> <icon [name]="availableOn[0].accessRightIcon" [flex]="true" [ratio]="0.8"></icon>
</span> </span>
<a [href]="availableOn[0].downloadUrl" target="_blank" <a uk-tooltip="Source" target="_blank"
class="uk-flex uk-flex-middle uk-flex-center uk-button-link uk-text-bolder custom-external"> class="uk-flex uk-flex-middle uk-flex-center uk-button-link uk-text-bolder">
<span>{{sliceString(availableOn[0].downloadNames.join("; "), 20)}}</span> <span>{{sliceString(availableOn[0].downloadNames.join("; "), 20)}}</span>
<span>
<icon [flex]="true" [name]="'expand_' + (isOpen?'less':'more')"></icon>
</span>
</a> </a>
</ng-container> <div #dropElement uk-drop="mode: click; pos: bottom-left;"
<a class="uk-flex uk-flex-middle uk-flex-center uk-button-link uk-text-bolder">
<icon [flex]="true" [name]="'expand_' + (isOpen?'less':'more')"></icon>
</a>
<div #dropElement uk-drop="mode: click; pos: bottom-left;"
class="download-drop uk-card uk-card-default uk-padding-small uk-padding-remove-horizontal uk-text-small"> class="download-drop uk-card uk-card-default uk-padding-small uk-padding-remove-horizontal uk-text-small">
<div *ngFor="let instance of availableOn let i=index" class="download-drop-item uk-flex uk-flex-top"> <div *ngFor="let instance of availableOn let i=index" class="download-drop-item uk-flex uk-flex-top">
<span <span
@ -67,6 +64,7 @@ declare var UIkit;
</div> </div>
</div> </div>
</div> </div>
</ng-container>
</div> </div>
</ng-container> </ng-container>
` `
@ -74,7 +72,6 @@ declare var UIkit;
export class AvailableOnComponent { export class AvailableOnComponent {
@Input() availableOn: HostedByCollectedFrom[]; @Input() availableOn: HostedByCollectedFrom[];
@Input() source: boolean = true;
/** @deprecated */ /** @deprecated */
@Output() viewAllClicked = new EventEmitter(); @Output() viewAllClicked = new EventEmitter();
@ViewChild("dropElement") dropElement: ElementRef; @ViewChild("dropElement") dropElement: ElementRef;

View File

@ -257,7 +257,7 @@ export class CiteThisComponent implements OnInit, OnDestroy {
/** /**
* Based on this and citeproc library https://citation.js.org/api/tutorial-plugins.html * Based on this and citeproc library https://citation.js.org/api/tutorial-plugins.html
* if the template doesn;t exist add the CSL xml and the library will produce the citation * if the template doesn't exist add the CSL xml and the library will produce the citation
* @param template * @param template
*/ */

View File

@ -2,13 +2,15 @@ import {Component, Input} from "@angular/core";
import {EnvProperties} from "../../utils/properties/env-properties"; import {EnvProperties} from "../../utils/properties/env-properties";
import {properties} from "../../../../environments/environment"; import {properties} from "../../../../environments/environment";
import {OpenaireEntities} from "../../utils/properties/searchFields"; import {OpenaireEntities} from "../../utils/properties/searchFields";
import {Project} from "../../utils/result-preview/result-preview";
@Component({ @Component({
selector: 'entity-metadata', selector: 'entity-metadata',
template: ` template: `
<div class="uk-text-xsmall uk-text-emphasis uk-flex uk-flex-middle uk-flex-wrap"> <div class="uk-text-xsmall uk-text-emphasis uk-flex uk-flex-middle uk-flex-wrap">
<!-- oa --> <!-- oa -->
<ng-container *ngIf="(openAccessMandatePublications != undefined && openAccessMandatePublications) || (openAccessMandateDatasets != undefined && openAccessMandateDatasets)"> <ng-container
*ngIf="(openAccessMandatePublications != undefined && openAccessMandatePublications) || (openAccessMandateDatasets != undefined && openAccessMandateDatasets)">
<span class="uk-margin-xsmall-right open-access"> <span class="uk-margin-xsmall-right open-access">
<icon name="open_access" [flex]="true" [ratio]="0.8"></icon> <icon name="open_access" [flex]="true" [ratio]="0.8"></icon>
</span> </span>
@ -28,28 +30,28 @@ import {OpenaireEntities} from "../../utils/properties/searchFields";
</ng-container> </ng-container>
<!-- types --> <!-- types -->
<span *ngIf="entityType" class="uk-margin-xsmall-right"> <span *ngIf="entityType" class="uk-margin-xsmall-right">
<icon *ngIf="entityType.toLowerCase() == 'publication'" name="description" type="outlined" <icon *ngIf="entityType.toLowerCase() == 'publication'" name="description" type="outlined"
[flex]="true" [ratio]="0.8"></icon> [flex]="true" [ratio]="0.8"></icon>
<icon *ngIf="entityType.toLowerCase() == 'research data'" name="database" type="outlined" <icon *ngIf="entityType.toLowerCase() == 'research data'" name="database" type="outlined"
[flex]="true" [ratio]="0.8"></icon> [flex]="true" [ratio]="0.8"></icon>
<icon *ngIf="entityType.toLowerCase() == 'research software'" name="integration_instructions" <icon *ngIf="entityType.toLowerCase() == 'research software'" name="integration_instructions"
type="outlined" [flex]="true" [ratio]="0.8"></icon> type="outlined" [flex]="true" [ratio]="0.8"></icon>
<icon *ngIf="entityType.toLowerCase() == 'other research product'" name="apps" type="outlined" <icon *ngIf="entityType.toLowerCase() == 'other research product'" name="apps" type="outlined"
[flex]="true" [ratio]="0.8"></icon> [flex]="true" [ratio]="0.8"></icon>
<icon *ngIf="entityType.toLowerCase() == 'project'" name="assignment_turned_in" type="outlined" <icon *ngIf="entityType.toLowerCase() == 'project'" name="assignment_turned_in" type="outlined"
[flex]="true" [ratio]="0.8"></icon> [flex]="true" [ratio]="0.8"></icon>
<icon *ngIf="entityType.toLowerCase() == 'data source'" name="note_add" type="outlined" <icon *ngIf="entityType.toLowerCase() == 'data source'" name="note_add" type="outlined"
[flex]="true" [ratio]="0.8"></icon> [flex]="true" [ratio]="0.8"></icon>
<icon *ngIf="entityType.toLowerCase() == 'organization'" name="corporate_fare" type="outlined" <icon *ngIf="entityType.toLowerCase() == 'organization'" name="corporate_fare" type="outlined"
[flex]="true" [ratio]="0.8"></icon> [flex]="true" [ratio]="0.8"></icon>
</span> </span>
<u *ngIf="entityType" class="uk-text-capitalize uk-text-bolder">{{entityType}}</u> <u *ngIf="entityType" class="uk-text-capitalize uk-text-bolder">{{entityType}}</u>
<span *ngIf="entityType && types && removeUnknown(types, true).length > 0"> <span *ngIf="entityType && types && removeUnknown(types, true).length > 0">
<icon name="keyboard_double_arrow_right" [flex]="true" [ratio]="0.8"></icon> <icon name="keyboard_double_arrow_right" [flex]="true" [ratio]="0.8"></icon>
</span> </span>
<span *ngIf="types && removeUnknown(types, true).length > 0" class="uk-text-italic"> <span *ngIf="types && removeUnknown(types, true).length > 0" class="uk-text-italic">
{{removeUnknown(types, true).join(' , ')}} {{removeUnknown(types, true).join(' , ')}}
</span> </span>
<!-- years --> <!-- years -->
<ng-container *ngIf="year"> <ng-container *ngIf="year">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span> <span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
@ -65,7 +67,7 @@ import {OpenaireEntities} from "../../utils/properties/searchFields";
</ng-container> </ng-container>
<ng-container *ngIf="startYear && endYear"> <ng-container *ngIf="startYear && endYear">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span> <span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
<ng-container *ngIf="startDate"> <ng-container>
<span>{{startYear}} - {{endYear}}</span> <span>{{startYear}} - {{endYear}}</span>
</ng-container> </ng-container>
</ng-container> </ng-container>
@ -92,7 +94,7 @@ import {OpenaireEntities} from "../../utils/properties/searchFields";
<span class="uk-margin-xsmall-left">{{currentDate >= endDate ? '(Ended)' : '(Ending)'}}</span> <span class="uk-margin-xsmall-left">{{currentDate >= endDate ? '(Ended)' : '(Ending)'}}</span>
</ng-container> </ng-container>
</ng-container> </ng-container>
<ng-container *ngIf="status && status != ''"> <ng-container *ngIf="status">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span> <span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
<span>{{status}}</span> <span>{{status}}</span>
</ng-container> </ng-container>
@ -105,10 +107,10 @@ import {OpenaireEntities} from "../../utils/properties/searchFields";
<span>Embargo end date: {{embargoEndDate | date: 'dd MMM yyyy'}}</span> <span>Embargo end date: {{embargoEndDate | date: 'dd MMM yyyy'}}</span>
</ng-container> </ng-container>
<span *ngIf="underCuration"> <span *ngIf="underCuration">
. <span title="{{buildCurationTooltip()}}" <span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
uk-tooltip="pos:bottom-right; delay:10;" <span title="{{buildCurationTooltip()}}"uk-tooltip="pos:bottom-right; delay:10;"
class="uk-text-primary">Under curation</span> class="uk-text-primary">Under curation</span>
</span> </span>
<!-- countries --> <!-- countries -->
<ng-container *ngIf="countries && removeUnknown(countries).length > 0"> <ng-container *ngIf="countries && removeUnknown(countries).length > 0">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span> <span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
@ -130,29 +132,62 @@ import {OpenaireEntities} from "../../utils/properties/searchFields";
<span>{{programmingLanguage}}</span> <span>{{programmingLanguage}}</span>
</ng-container> </ng-container>
</ng-container> </ng-container>
<!-- Projects -->
<ng-container *ngIf="projects && projects.length > 0">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
<span uk-tooltip="Projects">
<span *ngFor="let project of projects.slice(0,10) let i=index">
<span>
{{project.funderShortname ? project.funderShortname : project.funderName}}
</span>
<span *ngIf="project.acronym || project.title">
| {{ project.acronym ? project.acronym : (project.title.length > 25 ?
project.title.substring(0, 25) + '...' : project.title)}}
</span>
<span *ngIf="project.code"> ({{project.code}})</span>
<span *ngIf="i < projects.length-1">,</span>
</span>
<span *ngIf="projects.length > 10">...</span>
</span>
</ng-container>
<!-- Subjects -->
<ng-container *ngIf="subjects && subjects.length > 0">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
<span uk-tooltip="Subjects">
<span *ngFor="let subject of subjects.slice(0,10) let i = index">
<span>{{subject}}</span>
<span>{{(i < (subjects.slice(0, 10).length - 1)) ? ", " : ""}}</span>
<span>{{(i == subjects.slice(0, 10).length - 1 && subjects.length > 10) ? "..." : ""}}</span>
</span>
</span>
</ng-container>
<!-- published info --> <!-- published info -->
<showPublisher [publisher]="publisher" [journal]="journal" [properties]="properties"></showPublisher> <showPublisher [publisher]="publisher" [journal]="journal" [properties]="properties"></showPublisher>
<!-- data provider labels --> <!-- data provider labels -->
<ng-container *ngIf="compatibility && !(compatibility.info == 'not available' && type == 'service')"> <ng-container *ngIf="compatibility && !(compatibility.info == 'not available' && type == 'service')">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span> <span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
<span title="Compatibility"> <span uk-tooltip title="Compatibility">
<a *ngIf="compatibility.id" <a *ngIf="compatibility.id"
[queryParams]="{datasourceId: compatibility.id}" routerLinkActive="router-link-active" [queryParams]="{datasourceId: compatibility.id}" routerLinkActive="router-link-active"
[routerLink]="properties.searchLinkToDataProvider.split('?')[0]"> [routerLink]="properties.searchLinkToDataProvider.split('?')[0]">
{{compatibility.info}} {{compatibility.info}}
<ng-container *ngIf="compatibility.name">{{compatibility.name}}</ng-container> <ng-container *ngIf="compatibility.name">{{compatibility.name}}</ng-container>
</a> </a>
<span *ngIf="!compatibility.id && compatibility.info"> <span *ngIf="!compatibility.id && compatibility.info">
<ng-container <ng-container
*ngIf="compatibility.info.toLowerCase() != 'not yet registered'">{{compatibility.info}}</ng-container> *ngIf="compatibility.info.toLowerCase() != 'not yet registered'">{{compatibility.info}}</ng-container>
<ng-container *ngIf="compatibility.info.toLowerCase() == 'not yet registered'"> <ng-container *ngIf="compatibility.info.toLowerCase() == 'not yet registered'">
{{compatibility.info}} <span *ngIf="properties.adminToolsPortalType == 'eosc'">in OpenAIRE</span> {{compatibility.info}} <span *ngIf="properties.adminToolsPortalType == 'eosc'">in OpenAIRE</span>
</ng-container> </ng-container>
</span> </span>
<span *ngIf="compatibility.name && !compatibility.id"> <span *ngIf="compatibility.name && !compatibility.id">
{{compatibility.name}} {{compatibility.name}}
</span> </span>
</span> </span>
</ng-container>
<ng-container *ngIf="compatibilityString">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right bullet"></span>
<span uk-tooltip title="Compatibility">{{compatibilityString}}</span>
</ng-container> </ng-container>
<ng-container <ng-container
*ngIf="aggregationStatus && aggregationStatus.fulltexts && aggregationStatus.fulltexts > 0"> *ngIf="aggregationStatus && aggregationStatus.fulltexts && aggregationStatus.fulltexts > 0">
@ -172,7 +207,7 @@ import {OpenaireEntities} from "../../utils/properties/searchFields";
<span>{{relationName}}</span> <span>{{relationName}}</span>
</ng-container> </ng-container>
</div> </div>
` `
}) })
export class EntityMetadataComponent { export class EntityMetadataComponent {
@Input() entityType: string; @Input() entityType: string;
@ -194,12 +229,15 @@ export class EntityMetadataComponent {
@Input() countries; @Input() countries;
@Input() languages; @Input() languages;
@Input() programmingLanguages; @Input() programmingLanguages;
@Input() compatibilityString: string;
@Input() compatibility; // data provider landing @Input() compatibility; // data provider landing
@Input() aggregationStatus; // data provider landing @Input() aggregationStatus; // data provider landing
@Input() thematic: boolean; // data provider landing @Input() thematic: boolean; // data provider landing
@Input() type; // data provider landing @Input() type; // data provider landing
@Input() provenanceAction: string; // search result @Input() provenanceAction: string; // search result
@Input() relationName: string; // search result @Input() relationName: string; // search result
@Input() projects: Project[];
@Input() subjects: string[];
properties: EnvProperties = properties; properties: EnvProperties = properties;
public openaireEntities = OpenaireEntities; public openaireEntities = OpenaireEntities;

View File

@ -948,7 +948,7 @@ export class ResultLandingComponent {
// this.sdgSelectionModal.open(); // this.sdgSelectionModal.open();
// } // }
private openFosSelectionModal() { /*private openFosSelectionModal() {
this.fosSelectionModal.cancelButton = false; this.fosSelectionModal.cancelButton = false;
this.fosSelectionModal.alertTitle = "Please select FOS that are the most relevant for this publication."; this.fosSelectionModal.alertTitle = "Please select FOS that are the most relevant for this publication.";
this.fosSelectionModal.open(); this.fosSelectionModal.open();
@ -956,5 +956,5 @@ export class ResultLandingComponent {
public sdgModalOutput() { public sdgModalOutput() {
this.sdgFosSuggest.sdgModalOutput(); this.sdgFosSuggest.sdgModalOutput();
} }*/
} }

View File

@ -82,7 +82,7 @@
[id]="'autocomplete-'+i"> [id]="'autocomplete-'+i">
</entities-autocomplete> </entities-autocomplete>
</td> </td>
<td *ngIf="selectedField.type == 'boolean'" class="input-group"> <td *ngIf="selectedField.type == 'boolean'" class="input-group">
<span class="input-group-addon"> <span class="input-group-addon">
<input type="radio" [(ngModel)]="selectedField.value" [name]=selectedField.param <input type="radio" [(ngModel)]="selectedField.value" [name]=selectedField.param
@ -163,19 +163,22 @@
</div> </div>
<div class="uk-flex uk-flex-center uk-child-width-1-1"> <div class="uk-flex uk-flex-center uk-child-width-1-1">
<ng-container *ngIf="entitiesSelection"> <ng-container *ngIf="entitiesSelection">
<advanced-search-input [class.uk-hidden]="disableSelect" [dark]="dark" [disabled]="isDisabled" (searchEmitter)="simpleKeywordChanged()"> <advanced-search-input [class.uk-hidden]="disableSelect" [dark]="dark" [iconPosition]="isMobile?'left':'right'" [disabled]="isDisabled" (searchEmitter)="simpleKeywordChanged()">
<entities-selection [simpleView]="true" [currentEntity]="entityType" <entities-selection [simpleView]="true" [currentEntity]="entityType"
(selectionChange)="simpleEntityChanged($event)" (disableSelectEmitter)="disableSelectChange($event)" (selectionChange)="simpleEntityChanged($event)" (disableSelectEmitter)="disableSelectChange($event)"
[onChangeNavigate]="true" [customFilter]="customFilter" class="uk-width-2-5"></entities-selection> [onChangeNavigate]="true" [customFilter]="customFilter" class="uk-width-2-5"></entities-selection>
<div class="uk-width-expand" input placeholder="Scholary works" [searchable]="true" [hint]="formPlaceholderText" <div class="uk-width-expand" input placeholder="Scholary works" [searchable]="true" [hint]="formPlaceholderText"
[(value)]="selectedFields[0].value" tooltip="true"></div> [(value)]="selectedFields[0].value" tooltip="true"></div>
<a *ngIf="isMobile" href="#mobile-filters" filters-toggle (click)="filtersClicked.emit(true)" uk-toggle>
<icon name="filters"></icon>
</a>
</advanced-search-input> </advanced-search-input>
<div *ngIf="selectedFields[0] && disableSelect" search-input [disabled]="isDisabled" [(value)]="selectedFields[0].value" <div *ngIf="selectedFields[0] && disableSelect" search-input [disabled]="isDisabled" [(value)]="selectedFields[0].value"
[placeholder]="formPlaceholderText" (searchEmitter)="simpleKeywordChanged()" [iconPosition]="isMobile?'left':'right'"> [placeholder]="formPlaceholderText" (searchEmitter)="simpleKeywordChanged()" [iconPosition]="isMobile?'left':'right'">
<a *ngIf="isMobile" href="#mobile-filters" filters-toggle (click)="filtersClicked.emit(true)" uk-toggle> <a *ngIf="isMobile" href="#mobile-filters" filters-toggle (click)="filtersClicked.emit(true)" uk-toggle>
<icon name="filters"></icon> <icon name="filters"></icon>
</a> </a>
</div> </div>
</ng-container> </ng-container>
<div *ngIf="selectedFields[0] && !entitiesSelection" search-input [disabled]="isDisabled" [(value)]="selectedFields[0].value" <div *ngIf="selectedFields[0] && !entitiesSelection" search-input [disabled]="isDisabled" [(value)]="selectedFields[0].value"
[placeholder]="formPlaceholderText" (searchEmitter)="simpleKeywordChanged()" [iconPosition]="isMobile?'left':'right'"> [placeholder]="formPlaceholderText" (searchEmitter)="simpleKeywordChanged()" [iconPosition]="isMobile?'left':'right'">

View File

@ -1,6 +1,6 @@
<ul class="uk-list uk-list-large uk-margin" [class.uk-list-xlarge]="!isMobile" [ngClass]="custom_class"> <ul class="uk-list uk-margin" [ngClass]="custom_class">
<errorMessages [status]="[status]" [type]="'results'"></errorMessages> <errorMessages [status]="[status]" [type]="'results'"></errorMessages>
<li *ngFor="let result of previewResults" [class.uk-border-bottom]="!isMobile"> <li *ngFor="let result of previewResults">
<result-preview [properties]="properties" [showOrganizations]="showOrganizations" <result-preview [properties]="properties" [showOrganizations]="showOrganizations"
[showSubjects]="showSubjects" [result]="result" [showEnermaps]="showEnermaps" [showSubjects]="showSubjects" [result]="result" [showEnermaps]="showEnermaps"
[isCard]="isMobile" [isMobile]="isMobile"> [isCard]="isMobile" [isMobile]="isMobile">

View File

@ -22,7 +22,10 @@ import {EntitiesSelectionComponent} from "../../searchPages/searchUtils/entities
<ng-content></ng-content> <ng-content></ng-content>
</div> </div>
</div> </div>
<div class="uk-width-auto"> <div class="uk-width-auto filters-toggle">
<ng-content select="[filters-toggle]"></ng-content>
</div>
<div class="uk-width-auto" [class.uk-flex-first]="iconPosition === 'left'">
<div class="search-icon" [class.disabled]="disabled" (click)="searchEmitter.emit()"> <div class="search-icon" [class.disabled]="disabled" (click)="searchEmitter.emit()">
<icon name="search" [flex]="true" ratio="1.3"></icon> <icon name="search" [flex]="true" ratio="1.3"></icon>
</div> </div>
@ -34,6 +37,7 @@ import {EntitiesSelectionComponent} from "../../searchPages/searchUtils/entities
export class AdvancedSearchInputComponent implements AfterContentInit, OnDestroy { export class AdvancedSearchInputComponent implements AfterContentInit, OnDestroy {
@ContentChildren(InputComponent) inputs: QueryList<InputComponent>; @ContentChildren(InputComponent) inputs: QueryList<InputComponent>;
@ContentChildren(EntitiesSelectionComponent) entities: QueryList<EntitiesSelectionComponent>; @ContentChildren(EntitiesSelectionComponent) entities: QueryList<EntitiesSelectionComponent>;
@Input() iconPosition: 'left' | 'right' = 'right';
@Input() disabled: boolean = false; @Input() disabled: boolean = false;
@Input() searchInputClass: string = 'inner'; @Input() searchInputClass: string = 'inner';
@Input() dark: boolean; @Input() dark: boolean;

View File

@ -75,17 +75,17 @@ import {properties} from "../../../../environments/environment";
<ng-container *ngFor="let author of authors.slice(0, viewAll?authors.length:authorsLimit) let i=index"> <ng-container *ngFor="let author of authors.slice(0, viewAll?authors.length:authorsLimit) let i=index">
<ng-container *ngTemplateOutlet="author_template; context: { author: author, i:i}"></ng-container> <ng-container *ngTemplateOutlet="author_template; context: { author: author, i:i}"></ng-container>
</ng-container> </ng-container>
<span *ngIf="!showAll && authors && authors.length > authorsLimit" class="uk-text-meta"> <span *ngIf="!showAll && authors && authors.length > authorsLimit" class="uk-text-meta">
+{{authors.length-authorsLimit | number}} more +{{authors.length-authorsLimit | number}} more
</span> </span>
<span *ngIf="showAll && authors && authors.length > authorsLimit && !viewAll"> <span *ngIf="showAll && authors && authors.length > authorsLimit && !viewAll">
<a (click)="viewAllClick();"> <a (click)="viewAllClick();">
+{{authors.length-authorsLimit | number}} Authors +{{authors.length-authorsLimit | number}} Authors
</a> </a>
</span> </span>
</div> <div *ngIf="viewAll && lessBtn" class="uk-text-small">
<div *ngIf="viewAll && lessBtn" class="uk-width-1-1 uk-text-right uk-text-small"> <a (click)="viewAll = !viewAll; lessBtn=false;">View less</a>
<a (click)="viewAll = !viewAll; lessBtn=false;" class="view-more-less-link">View less authors</a> </div>
</div> </div>
<modal-alert #authorsModal> <modal-alert #authorsModal>

View File

@ -0,0 +1,80 @@
import {Component, Input, ViewChild} from "@angular/core";
import {StringUtils} from "../string-utils.class";
import {RouterHelper} from "../routerHelper.class";
import {properties} from "../../../../environments/environment";
@Component({
selector: 'entity-actions',
template: `
<div class="uk-grid uk-grid-small uk-child-width-auto" uk-grid>
<a *ngIf="linking"
[queryParams]="routerHelper.createQueryParams(['id','type','linkTo'], [id,type,linkTo])"
routerLinkActive="router-link-active" routerLink="/participate/direct-claim"
[title]="'Link this '+getTypeName()+' to ...'"
[attr.uk-tooltip]="'pos: bottom; cls: uk-active uk-text-small uk-padding-small'"
class="uk-flex uk-flex-middle uk-flex-center uk-button-link uk-text-bolder">
<icon [flex]="true" [ratio]="0.7" name="link_to" visuallyHidden="link"></icon>
<span class="uk-margin-xsmall-left">Link to</span>
</a>
<a *ngIf="share" (click)="openAddThisModal()"
class="uk-flex uk-flex-middle uk-flex-center uk-button-link uk-text-bolder">
<icon [flex]="true" [ratio]="0.8" name="share" visuallyHidden="share"></icon>
<span class="uk-margin-xsmall-left">Share</span>
</a>
<a *ngIf="cite" (click)="openCiteModal()"
class="uk-flex uk-flex-middle uk-flex-center uk-button-link uk-text-bolder">
<icon [flex]="true" [ratio]="0.7" name="cite" visuallyHidden="cite"></icon>
<span class="uk-margin-xsmall-left">Cite</span>
</a>
<ng-content></ng-content>
</div>
<modal-alert *ngIf="cite" #citeModal>
<citeThis *ngIf="citeThisClicked" [result]="result" [id]="id"
[type]="getTypeName().toLowerCase()" [piwikSiteId]="piwikSiteId"></citeThis>
</modal-alert>
<modal-alert *ngIf="share" #addThisModal classBody="uk-flex uk-flex-center uk-flex-middle">
<addThis [url]="url"></addThis>
</modal-alert>
`
})
export class EntityActionsComponent {
@Input() result: any;
@Input() type: string;
@Input() id: string;
@Input() linking: boolean = false;
@Input() share: boolean = false;
@Input() cite: boolean = false;
@Input() url: string;
public piwikSiteId = properties.piwikSiteId;
public citeThisClicked: boolean;
public routerHelper: RouterHelper = new RouterHelper();
@ViewChild('citeModal') citeModal;
@ViewChild('addThisModal') addThisModal;
constructor() {
}
get linkTo():string {
return this.type === 'project'?'result':'project';
}
public getTypeName(): string {
return StringUtils.getEntityName(this.type, false);
}
public openCiteModal() {
this.citeThisClicked = true;
this.citeModal.cancelButton = false;
this.citeModal.okButton = false;
this.citeModal.alertTitle = "Cite this " + this.getTypeName();
this.citeModal.open();
}
public openAddThisModal() {
console.log(this.url);
this.addThisModal.cancelButton = false;
this.addThisModal.okButton = false;
this.addThisModal.alertTitle = "Share this " + this.getTypeName() + " in your social networks";
this.addThisModal.open();
}
}

View File

@ -0,0 +1,17 @@
import {NgModule} from "@angular/core";
import {CommonModule} from "@angular/common";
import {EntityActionsComponent} from "./entity-actions.component";
import {RouterLinkWithHref} from "@angular/router";
import {IconsModule} from "../icons/icons.module";
import {AlertModalModule} from "../modal/alertModal.module";
import {CiteThisModule} from "../../landingPages/landing-utils/citeThis/citeThis.module";
import {LandingModule} from "../../landingPages/landing-utils/landing.module";
@NgModule({
imports: [CommonModule, RouterLinkWithHref, IconsModule, AlertModalModule, CiteThisModule, LandingModule],
declarations: [EntityActionsComponent],
exports: [EntityActionsComponent]
})
export class EntityActionsModule {
}

View File

@ -1,329 +1,262 @@
<div *ngIf="result" [ngClass]="{'uk-card uk-card-default': isCard}"> <div *ngIf="result" class="uk-card" [class.uk-card-default]="isMobile">
<div [ngClass]="{'uk-card-body': isCard}"> <div class="uk-padding-small">
<div class="uk-grid uk-flex uk-flex-middle"> <div>
<div *ngIf="properties.enermapsURL && showEnermaps && result.enermapsId" <div class="uk-grid uk-flex uk-flex-middle">
class=" uk-inline uk-width-auto uk-text-center uk-visible-toggle"> <div *ngIf="properties.enermapsURL && showEnermaps && result.enermapsId"
<img class="uk-width-medium" [src]="properties.enermapsURL +'/images/datasets/' + result.enermapsId + '.png'" class=" uk-inline uk-width-auto uk-text-center uk-visible-toggle">
alt="Enermaps tool preview" loading="lazy"> <img class="uk-width-medium" [src]="properties.enermapsURL +'/images/datasets/' + result.enermapsId + '.png'"
<div alt="Enermaps tool preview" loading="lazy">
class="uk-overlay uk-margin-medium-left uk-overlay-default uk-position-bottom uk-hidden-hover uk-padding-small"> <div
<p>Visit <a class="uk-overlay uk-margin-medium-left uk-overlay-default uk-position-bottom uk-hidden-hover uk-padding-small">
class="custom-external uk-margin-right uk-margin-small-top" <p>Visit <a
[href]="properties.enermapsURL + '/?shared_id=' + result.enermapsId" target="_blank"> class="custom-external uk-margin-right uk-margin-small-top"
Enermaps tool [href]="properties.enermapsURL + '/?shared_id=' + result.enermapsId" target="_blank">
</a></p> Enermaps tool
</div> </a></p>
</div> </div>
<div class="uk-width-expand"> </div>
<!-- 1st section (title, metadata) --> <div class="uk-width-expand">
<div class="uk-margin-small-bottom"> <!-- 1st section (title, metadata) -->
<!-- Title --> <div class="uk-margin-small-bottom">
<div> <!-- Title -->
<h2 class="uk-margin-remove uk-text-break uk-inline-block uk-h6"> <div>
<a *ngIf="!externalUrl && result.id" (click)="onClick()" [queryParams]="createParam()" <h2 class="uk-margin-remove uk-text-break uk-inline-block uk-h6">
[routerLink]="url" class="uk-link uk-text-decoration-none uk-width-expand"> <a *ngIf="!externalUrl && result.id" (click)="onClick()" [queryParams]="createParam()"
<div *ngIf="(result.title) || result.acronym"> [routerLink]="url" class="uk-link uk-text-decoration-none uk-width-expand">
<div *ngIf="(result.title) || result.acronym">
<span *ngIf="result.acronym"> <span *ngIf="result.acronym">
{{result.acronym}} {{result.acronym}}
</span> </span>
<span *ngIf="result.acronym && (result.title)"> (</span> <span *ngIf="result.acronym && (result.title)"> (</span>
<span *ngIf="result.title" [innerHTML]="result.title"></span> <span *ngIf="result.title" [innerHTML]="result.title"></span>
<span *ngIf="result.acronym && result.title">)</span> <span *ngIf="result.acronym && result.title">)</span>
</div> </div>
<div *ngIf="!result.title && !result.acronym"> <div *ngIf="!result.title && !result.acronym">
[no title available] [no title available]
</div> </div>
</a> </a>
<a *ngIf="externalUrl && result.id" (click)="onClick()" <a *ngIf="externalUrl && result.id" (click)="onClick()"
target="_blank" [href]="externalUrl+result.id" target="_blank" [href]="externalUrl+result.id"
class="custom-external uk-link uk-text-decoration-none uk-width-expand"> class="custom-external uk-link uk-text-decoration-none uk-width-expand">
<span *ngIf="(result.title) || result.acronym"> <span *ngIf="(result.title) || result.acronym">
<span *ngIf="result.acronym"> <span *ngIf="result.acronym">
{{result.acronym}} {{result.acronym}}
</span> </span>
<span *ngIf="result.acronym && (result.title)"> (</span> <span *ngIf="result.acronym && (result.title)"> (</span>
<span *ngIf="result.title" [innerHTML]="result.title"></span> <span *ngIf="result.title" [innerHTML]="result.title"></span>
<span *ngIf="result.acronym && result.title">)</span> <span *ngIf="result.acronym && result.title">)</span>
</span> </span>
<span *ngIf="!result.title && !result.acronym"> <span *ngIf="!result.title && !result.acronym">
[no title available] [no title available]
</span> </span>
</a> </a>
<div *ngIf="!result.id" class="uk-width-expand"> <div *ngIf="!result.id" class="uk-width-expand">
<div *ngIf="(result.title) || result.acronym"> <div *ngIf="(result.title) || result.acronym">
<span *ngIf="result.acronym"> <span *ngIf="result.acronym">
{{result.acronym}} {{result.acronym}}
</span> </span>
<span *ngIf="result.acronym && (result.title)"> (</span> <span *ngIf="result.acronym && (result.title)"> (</span>
<span *ngIf="result.title" [innerHTML]="result.title"></span> <span *ngIf="result.title" [innerHTML]="result.title"></span>
<span *ngIf="result.acronym && result.title">)</span> <span *ngIf="result.acronym && result.title">)</span>
</div> </div>
<div *ngIf="!result.title && !result.acronym"> <div *ngIf="!result.title && !result.acronym">
[no title available] [no title available]
</div> </div>
</div> </div>
</h2> </h2>
</div> </div>
<!-- Metadata --> <!-- Metadata -->
<div class="uk-margin-xsmall-top"> <div class="uk-margin-xsmall-top">
<entity-metadata [entityType]="type" [types]="result.types" [startYear]="result.startYear?.toString()" [endYear]="result.endYear?.toString()" <entity-metadata [entityType]="type" [types]="result.types" [startYear]="result.startYear?.toString()"
[year]="result.year?.toString()" [openAccessMandatePublications]="result.openAccessMandatePublications" [endYear]="result.endYear?.toString()"
[openAccessMandateDatasets]="result.openAccessMandateDatasets" [date]="" [embargoEndDate]="result.embargoEndDate" [year]="result.year?.toString()"
[publisher]="result.publisher" [countries]="result.countries" [openAccessMandatePublications]="result.openAccessMandatePublications"
[languages]="result.languages" [programmingLanguages]="result.programmingLanguages" [openAccessMandateDatasets]="result.openAccessMandateDatasets" [date]=""
[compatibility]="result.compatibility" [type]="type" [embargoEndDate]="result.embargoEndDate"
></entity-metadata> [publisher]="result.publisher" [countries]="result.countries"
</div> [languages]="result.languages" [programmingLanguages]="result.programmingLanguages"
</div> [compatibilityString]="result.compatibility" [type]="type" [projects]="result.projects"
<!-- 2nd section (labels only) --> [subjects]="result.subjects"
<!--<div class="uk-margin-bottom"> ></entity-metadata>
&lt;!&ndash; Labels &ndash;&gt; </div>
<div> </div>
<span <!-- 2nd section (funders, budget, authors, PIDs, publisher etc.) -->
*ngIf="result.accessMode && result.accessMode.toLowerCase() !== 'not available'" <div class="uk-text-small uk-margin-small-bottom uk-visible@m">
class="uk-label uk-text-truncate " [ngClass]="'uk-label-' + accessClass(result.accessMode)" <!-- Funder -->
title="Access Mode"> <div *ngIf="result.funderShortname || result.code" class="uk-margin-xsmall-bottom">
{{result.accessMode}}
</span>{{' '}}
<span
*ngIf="result.openAccessMandatePublications && (!result.openAccessMandateDatasets)"
class="uk-label uk-label-success uk-text-truncate"
title="Open Access mandate for {{openaireEntities.PUBLICATIONS}}">
Open Access mandate for {{openaireEntities.PUBLICATIONS}}
</span>{{' '}}
<span
*ngIf="result.openAccessMandateDatasets != undefined && result.openAccessMandateDatasets && (result.openAccessMandatePublications == undefined || !result.openAccessMandatePublications)"
class="uk-label uk-label-success uk-text-truncate "
title="Open Access mandate for {{openaireEntities.DATASETS}}">
Open Access mandate for {{openaireEntities.DATASETS}}
</span>{{' '}}
<span
*ngIf="result.openAccessMandatePublications != undefined && result.openAccessMandatePublications && result.openAccessMandateDatasets != undefined && result.openAccessMandateDatasets"
class="uk-label uk-label-success uk-text-truncate"
title="Open Access mandate for {{openaireEntities.PUBLICATIONS}} and {{openaireEntities.DATASETS}}">
Open Access mandate for {{openaireEntities.PUBLICATIONS}} and {{openaireEntities.DATASETS}}
</span>{{' '}}
<span *ngIf="result.languages && result.languages.length > 0">
<span
*ngFor="let language of result.languages"
class="uk-label" title="Language">
{{language}}
</span>{{' '}}
</span>
<span *ngIf="result.programmingLanguages && result.programmingLanguages.length > 0">
<span
*ngFor="let programmingLanguage of result.programmingLanguages"
class="uk-label" title="Programming Language">
{{programmingLanguage}}
</span>{{" "}}
</span>
&lt;!&ndash; <span &ndash;&gt;
&lt;!&ndash; *ngIf="result.sc39" class="uk-label" title="Special Clause 39">&ndash;&gt;
&lt;!&ndash; Special Clause 39&ndash;&gt;
&lt;!&ndash; </span>{{' '}}&ndash;&gt;
<span
*ngIf="result.compatibility && result.compatibility != '' && result.compatibility.toLowerCase() != 'not yet registered'"
class="uk-label" title="Compatibility">
{{result.compatibility}}
</span>{{' '}}
<span
*ngIf="result.compatibility != undefined && result.compatibility != '' && result.compatibility.toLowerCase() == 'not yet registered'
&& result.resultType != 'service'"
class="uk-label" [class.uk-label-danger]="deposit" title="OpenAIRE Compatibility">
{{result.compatibility}} <span *ngIf="properties.adminToolsPortalType == 'eosc'">in OpenAIRE</span>
</span>{{' '}}
</div>
</div>-->
<!-- 3rd section (funders, budget, authors, PIDs, publisher etc.) -->
<div class="uk-text-small uk-margin-small-bottom">
<!-- Funder -->
<div *ngIf="result.funderShortname || result.code" class="uk-margin-xsmall-bottom">
<span *ngIf="result.funderShortname"> <span *ngIf="result.funderShortname">
<span class="uk-text-meta">Funder: </span> <span class="uk-text-meta">Funder: </span>
{{result.funderShortname}} {{result.funderShortname}}
</span> </span>
<span *ngIf="result.code" [class.uk-margin-left]="result.funderShortname"> <span *ngIf="result.code" [class.uk-margin-left]="result.funderShortname">
<span class="uk-text-meta">{{openaireEntities.PROJECT}} Code: </span> <span class="uk-text-meta">{{openaireEntities.PROJECT}} Code: </span>
{{result.code}} {{result.code}}
</span> </span>
<!-- Currently not parsed --> <!-- Currently not parsed -->
<!-- <span *ngIf="result.callIdentifier" [class.uk-margin-left]="(result.funderShortname || result.code)">--> <!-- <span *ngIf="result.callIdentifier" [class.uk-margin-left]="(result.funderShortname || result.code)">-->
<!-- <span class="uk-text-muted">Call for proposal: </span>--> <!-- <span class="uk-text-muted">Call for proposal: </span>-->
<!-- {{result.callIdentifier}}--> <!-- {{result.callIdentifier}}-->
<!-- </span>--> <!-- </span>-->
</div> </div>
<!-- Funder Budget --> <!-- Funder Budget -->
<div *ngIf="result.budget || result.contribution" class="uk-margin-xsmall-bottom"> <div *ngIf="result.budget || result.contribution" class="uk-margin-xsmall-bottom">
<span *ngIf="result.budget"> <span *ngIf="result.budget">
<span class="uk-text-meta">Overall Budget: </span> <span class="uk-text-meta">Overall Budget: </span>
{{result.budget | number}} {{result.budget | number}}
<span *ngIf="result.currency">{{result.currency}}</span> <span *ngIf="result.currency">{{result.currency}}</span>
</span> </span>
<span *ngIf="result.contribution" [class.uk-margin-left]="result.budget"> <span *ngIf="result.contribution" [class.uk-margin-left]="result.budget">
<span class="uk-text-meta">Funder Contribution: </span> <span class="uk-text-meta">Funder Contribution: </span>
{{result.contribution | number}} {{result.contribution | number}}
<span *ngIf="result.currency">{{result.currency}}</span> <span *ngIf="result.currency">{{result.currency}}</span>
</span> </span>
</div> </div>
<!-- Authors --> <!-- Authors -->
<div *ngIf="result.authors" class="uk-flex uk-margin-xsmall-bottom"> <div *ngIf="result.authors" class="uk-margin-xsmall-bottom">
<showAuthors [authors]="result.authors" [authorsLimit]=10 [modal]="modal" <showAuthors [authors]="result.authors" [authorsLimit]=4 [modal]="modal"
[showAll]=false></showAuthors> [showAll]=true></showAuthors>
</div> </div>
<!-- Identifiers --> <!-- Identifiers -->
<div *ngIf="result.identifiers && result.identifiers.size > 0" class="uk-margin-xsmall-bottom"> <div *ngIf="result.identifiers && result.identifiers.size > 0" class="uk-margin-xsmall-bottom">
<showIdentifiers [identifiers]="result.identifiers"></showIdentifiers> <showIdentifiers [identifiers]="result.identifiers"></showIdentifiers>
</div> </div>
<!-- Projects --> <!-- Organizations -->
<div *ngIf="result.projects && result.projects.length > 0" class="uk-margin-xsmall-bottom"> <div *ngIf="showOrganizations && result.organizations && result.organizations.length > 0"
<span class="uk-text-meta"> Project: </span> class="uk-margin-xsmall-bottom">
<span *ngFor="let project of result.projects.slice(0,10) let i=index"> <span class="uk-text-meta">Partners: </span>
<span> <span *ngFor="let organization of result.organizations.slice(0,10) let i=index">
{{project.funderShortname ? project.funderShortname : project.funderName}} <span>{{organization.name}}</span>
</span> <span *ngIf="(i < result.organizations.length-1) && (i < 9)">, </span>
<span *ngIf="project.acronym || project.title"> </span>
| {{ project.acronym ? project.acronym : (project.title.length > 25 ? <span *ngIf="result.organizations.length > 10">...</span>
project.title.substring(0, 25) + '...' : project.title)}} </div>
</span> <!-- Website URL -->
<span *ngIf="project.code"> ({{project.code}})</span> <div *ngIf="result.websiteURL && result.websiteURL != '' && !promoteWebsiteURL"
<span *ngIf="i < result.projects.length-1">,</span> class="uk-margin-xsmall-bottom">
</span> <span class="uk-text-meta">Website URL: </span>
<span *ngIf="result.projects.length > 10">...</span> <span>
</div> <a href="{{result.websiteURL}}" target="_blank" class="custom-external">
<!-- Organizations --> {{result.websiteURL}}
<div *ngIf="showOrganizations && result.organizations && result.organizations.length > 0" </a>
class="uk-margin-xsmall-bottom"> </span>
<span class="uk-text-meta">Partners: </span> </div>
<span *ngFor="let organization of result.organizations.slice(0,10) let i=index"> <!-- OAI-PMH URL-->
<span>{{organization.name}}</span> <div *ngIf="result.OAIPMHURL && result.OAIPMHURL != ''" class="uk-margin-xsmall-bottom">
<span *ngIf="(i < result.organizations.length-1) && (i < 9)">, </span> <span class="uk-text-meta">OAI-PMH URL: </span>
</span> <span>
<span *ngIf="result.organizations.length > 10">...</span> <a href="{{result.OAIPMHURL}}" target="_blank" class="custom-external">
</div> {{result.OAIPMHURL}}
<!-- Website URL --> </a>
<div *ngIf="result.websiteURL && result.websiteURL != '' && !promoteWebsiteURL" </span>
class="uk-margin-xsmall-bottom"> </div>
<span class="uk-text-meta">Website URL: </span> </div>
<span> <!-- 3rd section (description) -->
<a href="{{result.websiteURL}}" target="_blank" class="custom-external"> <div class="uk-text-small uk-visible@m">
{{result.websiteURL}} <!-- Description -->
</a> <div *ngIf="result.description" class="multi-line-ellipsis lines-2">
</span> <p class="uk-margin-remove" [innerHTML]="result.description"></p>
</div> </div>
<!-- OAI-PMH URL--> </div>
<div *ngIf="result.OAIPMHURL && result.OAIPMHURL != ''" class="uk-margin-xsmall-bottom"> <!-- 5th section(deposit only) -->
<span class="uk-text-meta">OAI-PMH URL: </span> <div>
<span> <span *ngIf="result.websiteURL && promoteWebsiteURL" class="uk-flex uk-flex-right uk-margin-small-top">
<a href="{{result.OAIPMHURL}}" target="_blank" class="custom-external"> <a href="{{result.websiteURL}}" target="_blank" type="submit"
{{result.OAIPMHURL}} class="uk-float-right uk-margin-small-left uk-display-inline-block uk-text-uppercase uk-button uk-button-text">
</a> <span class="uk-flex uk-flex-middle">
</span> <icon name="file_upload" type="outlined" [flex]="true" class="uk-margin-small-right"></icon>
</div> <span>Go to repository</span>
<!-- Subjects --> </span>
<div *ngIf="showSubjects && result.subjects && result.subjects.length > 0" </a>
class="uk-margin-xsmall-bottom"> </span>
<span class="uk-text-meta">Subject: </span> </div>
<span *ngFor="let subject of result.subjects.slice(0,10) let i = index"> </div>
<span>{{subject}}</span> </div>
<span>{{(i < (result.subjects.slice(0, 10).length - 1)) ? ", " : ""}}</span> <div *ngIf="result.hostedBy_collectedFrom || hasActions || result.measure?.bip.length || result.measure?.counts.length"
<span>{{(i == result.subjects.slice(0, 10).length - 1 && result.subjects.length > 10) ? "..." : ""}}</span> class="uk-text-small uk-margin-top" [class.uk-border-bottom]="!isMobile"
</span> [class.uk-visible@m]="!result.measure?.bip.length && result.measure?.counts.length">
</div> <div
</div> class="uk-grid uk-grid-small uk-flex-between uk-text-xsmall uk-flex-middle uk-grid-divider uk-margin-xsmall-bottom"
<!-- 4th section (description) --> uk-grid>
<div class="uk-text-small"> <div *ngIf="result.hostedBy_collectedFrom?.length" class="uk-width-auto uk-visible@m">
<!-- Description --> <availableOn [availableOn]="result.hostedBy_collectedFrom"></availableOn>
<div *ngIf="result.description" class="multi-line-ellipsis lines-3"> </div>
<p class="uk-text-meta" [innerHTML]="result.description"></p> <div *ngIf="hasActions" class="uk-width-expand uk-visible@m">
</div> <entity-actions [cite]="cite" [share]="share" [linking]="linking" [type]="result.resultType"
</div> [result]="result" [id]="result.objId"
<!-- 5th section(deposit only) --> [url]="properties.domain + properties.baseLink + url + '?' + urlParam + '=' + result.id">
<div>
<span class="uk-flex uk-flex-right uk-margin-small-top">
<a *ngIf="result.websiteURL && promoteWebsiteURL" href="{{result.websiteURL}}" target="_blank" type="submit"
class="uk-float-right uk-margin-small-left uk-display-inline-block uk-text-uppercase uk-button uk-button-text">
<span class="uk-flex uk-flex-middle">
<icon name="file_upload" type="outlined" [flex]="true" class="uk-margin-small-right"></icon>
<span>Go to repository</span>
</span>
</a>
</span>
</div>
</div>
</div>
</div>
<!--&& loggedIn (card footer)-->
<div *ngIf="result.hostedBy_collectedFrom || result.measure?.bip.length || result.measure?.counts.length"
class="uk-text-small" [class.uk-visible@m]="!result.measure?.bip.length && result.measure?.counts.length" [ngClass]="{'uk-card-footer': isCard}">
<div class="uk-grid uk-grid-small uk-flex-between uk-flex-middle uk-grid-divider uk-margin-xsmall-bottom" uk-grid>
<div *ngIf="result.hostedBy_collectedFrom" class="uk-width-auto uk-visible@m">
<availableOn [availableOn]="result.hostedBy_collectedFrom" [source]="false"></availableOn>
</div>
<div *ngIf="hasActions" class="uk-width-expand uk-visible@m">
<span class="uk-grid uk-grid-small uk-child-width-auto uk-text-xsmall" uk-grid>
<span *ngIf="orcid"> <span *ngIf="orcid">
<orcid-work *ngIf="showOrcid && result.identifiers && result.identifiers.size > 0" <orcid-work *ngIf="showOrcid && result.identifiers && result.identifiers.size > 0"
[resultId]="result.relcanId" [resultTitle]="result.title" [resultId]="result.relcanId" [resultTitle]="result.title"
[type]="result.resultType" [pageType]="'search'" [type]="result.resultType" [pageType]="'search'"
[putCodes]="result.orcidPutCodes" [givenPutCode]="true" [identifiers]="result.identifiers"> [putCodes]="result.orcidPutCodes" [givenPutCode]="true" [identifiers]="result.identifiers">
</orcid-work> </orcid-work>
</span> </span>
<span *ngIf="orcid" class="uk-width-expand uk-text-right"> <span *ngIf="orcid" class="uk-width-expand uk-text-right">
<span *ngIf="result.orcidCreationDates?.length > 0" class="uk-display-inline-block"> <span *ngIf="result.orcidCreationDates?.length > 0" class="uk-display-inline-block">
<span class="uk-text-meta"> <span class="uk-text-meta">
Added in ORCID: Added in ORCID:
</span> </span>
<span *ngFor="let date of result.orcidCreationDates; let i=index"> <span *ngFor="let date of result.orcidCreationDates; let i=index">
{{date | date: 'dd MMM yyyy'}} {{date | date: 'dd MMM yyyy'}}
<span *ngIf="i < (result.orcidCreationDates.length - 1)"> <span *ngIf="i < (result.orcidCreationDates.length - 1)">
& &
</span> </span>
</span> </span>
</span> </span>
</span> </span>
</span> </entity-actions>
</div> </div>
<div *ngIf="result.measure?.bip.length || result.measure?.counts.length" <div *ngIf="result.measure?.bip.length || result.measure?.counts.length"
class="uk-text-xsmall uk-width-auto metrics uk-flex uk-flex-middle uk-flex-right uk-text-meta"> class="uk-text-xsmall uk-width-auto metrics uk-flex uk-flex-middle uk-flex-right uk-text-meta">
<ng-container *ngIf="result.measure?.bip.length"> <ng-container *ngIf="result.measure?.bip.length">
<a class="uk-flex uk-flex-middle uk-link-reset"> <a class="uk-flex uk-flex-middle uk-link-reset">
<icon customClass="bip-icon-hover" [flex]="true" [ratio]="0.7" [name]="result.measure.bip[0].icon"></icon> <icon customClass="bip-icon-hover" [flex]="true" [ratio]="0.7"
<span class="uk-margin-xsmall-left">{{result.measure.bip[0].value}}</span> [name]="result.measure.bip[0].icon"></icon>
</a> <span class="uk-margin-xsmall-left">{{result.measure.bip[0].value}}</span>
<div uk-drop="pos: top-left" class="uk-card uk-card-default uk-border uk-box-no-shadow uk-padding-small"> </a>
<table> <div uk-drop="pos: top-right" class="uk-card uk-card-default uk-border uk-box-no-shadow uk-padding-small">
<tr *ngFor="let metric of result.measure.bip"> <table>
<td class="bip-icon"><icon [flex]="true" [ratio]="0.7" [name]="metric.icon"></icon></td> <tr *ngFor="let metric of result.measure.bip">
<td class="uk-text-capitalize">{{metric.name}}</td> <td class="bip-icon">
<td class="uk-text-bolder">{{metric.value}}</td> <icon [flex]="true" [ratio]="0.7" [name]="metric.icon"></icon>
</tr> </td>
</table> <td class="uk-text-capitalize">{{metric.name}}</td>
<div class="uk-margin-top uk-flex uk-flex-middle uk-flex-center"> <td class="uk-text-bolder">{{metric.value}}</td>
<img class="uk-margin-xsmall-right" width="15" src="assets/common-assets/bip-minimal.svg" loading="lazy" alt="BIP!"> </tr>
<span class="uk-text-uppercase">Powered by <span class="uk-text-bolder">BIP!</span></span> </table>
</div> <div class="uk-margin-top uk-flex uk-flex-middle uk-flex-center">
</div> <img class="uk-margin-xsmall-right" width="15" src="assets/common-assets/bip-minimal.svg"
</ng-container> loading="lazy" alt="BIP!">
<ng-container *ngIf="result.measure?.counts.length"> <span class="uk-text-uppercase">Powered by <span class="uk-text-bolder">BIP!</span></span>
<a class="uk-flex uk-flex-middle uk-margin-small-left uk-link-reset"> </div>
<icon class="text-usage-counts-hover" [flex]="true" [ratio]="0.8" [name]="result.measure.counts[0].icon"></icon> </div>
<span class="uk-margin-xsmall-left">{{result.measure.counts[0].value}}</span> </ng-container>
</a> <ng-container *ngIf="result.measure?.counts.length">
<div uk-drop="pos: top-left" class="uk-card uk-card-default uk-border uk-box-no-shadow uk-padding-small"> <a class="uk-flex uk-flex-middle uk-margin-small-left uk-link-reset">
<table> <icon class="text-usage-counts-hover" [flex]="true" [ratio]="0.8"
<tr *ngFor="let metric of result.measure.counts"> [name]="result.measure.counts[0].icon"></icon>
<td class="text-usage-counts"><icon [flex]="true" [ratio]="0.7" [name]="metric.icon"></icon></td> <span class="uk-margin-xsmall-left">{{result.measure.counts[0].value}}</span>
<td class="uk-text-capitalize">{{metric.name}}</td> </a>
<td class="uk-text-bolder">{{metric.value}}</td> <div uk-drop="pos: top-right" class="uk-card uk-card-default uk-border uk-box-no-shadow uk-padding-small">
</tr> <table>
</table> <tr *ngFor="let metric of result.measure.counts">
<div class="uk-margin-top uk-flex uk-flex-middle uk-flex-center"> <td class="text-usage-counts">
<span class="uk-text-uppercase">Powered by </span> <icon [flex]="true" [ratio]="0.7" [name]="metric.icon"></icon>
<img class="uk-margin-xsmall-left" width="15" src="assets/common-assets/logo-small-usage-counts.png" loading="lazy" alt="BIP!"> </td>
</div> <td class="uk-text-capitalize">{{metric.name}}</td>
</div> <td class="uk-text-bolder">{{metric.value}}</td>
</ng-container> </tr>
</div> </table>
</div> <div class="uk-margin-top uk-flex uk-flex-middle uk-flex-center">
</div> <span class="uk-text-uppercase">Powered by </span>
<img class="uk-margin-xsmall-left" width="15" src="assets/common-assets/logo-small-usage-counts.png"
loading="lazy" alt="BIP!">
</div>
</div>
</ng-container>
</div>
</div>
</div>
</div>
</div>
</div> </div>

View File

@ -22,20 +22,21 @@ export class ResultPreviewComponent implements OnInit, OnChanges {
@Input() modal: AlertModal = null; @Input() modal: AlertModal = null;
@Input() promoteWebsiteURL: boolean = false; @Input() promoteWebsiteURL: boolean = false;
@Input() hasLink: boolean = true; @Input() hasLink: boolean = true;
/**
* @deprecated
* */
@Input() isCard: boolean = false; @Input() isCard: boolean = false;
@Input() isMobile: boolean = false; @Input() isMobile: boolean = false;
public routerHelper: RouterHelper = new RouterHelper(); public routerHelper: RouterHelper = new RouterHelper();
public urlParam: string; public urlParam: string;
public url: string; public url: string;
@Input() externalUrl: string; @Input() externalUrl: string;
public dataProviderUrl = properties.searchLinkToDataProvider.split('?')[0];
@Input() showOrcid: boolean = true; @Input() showOrcid: boolean = true;
@Input() showEnermaps: boolean = false; @Input() showEnermaps: boolean = false;
@Input() deposit: boolean = false; @Input() deposit: boolean = false;
@Input() provenanceActionVocabulary = null; @Input() provenanceActionVocabulary = null;
@Input() relationsVocabulary = null; @Input() relationsVocabulary = null;
/* Metadata */ /* Metadata */
public type: string; public type: string;
public types: string[]; public types: string[];
@ -46,7 +47,7 @@ export class ResultPreviewComponent implements OnInit, OnChanges {
public share: boolean = false; public share: boolean = false;
public cite: boolean = false; public cite: boolean = false;
public orcid: boolean = false; public orcid: boolean = false;
ngOnInit(): void { ngOnInit(): void {
if (this.hasLink) { if (this.hasLink) {
if (this.result.resultType === "publication") { if (this.result.resultType === "publication") {
@ -109,7 +110,7 @@ export class ResultPreviewComponent implements OnInit, OnChanges {
this.orcid = (this.properties.adminToolsPortalType == 'explore' || this.properties.adminToolsPortalType == 'community' || this.properties.adminToolsPortalType == 'aggregator') && this.orcid = (this.properties.adminToolsPortalType == 'explore' || this.properties.adminToolsPortalType == 'community' || this.properties.adminToolsPortalType == 'aggregator') &&
this.showOrcid && this.result.identifiers && this.result.identifiers.size > 0; this.showOrcid && this.result.identifiers && this.result.identifiers.size > 0;
} }
ngOnChanges(changes: SimpleChanges) { ngOnChanges(changes: SimpleChanges) {
if (changes.result && this.hasLink) { if (changes.result && this.hasLink) {
this.checkPID(); this.checkPID();
@ -151,7 +152,7 @@ export class ResultPreviewComponent implements OnInit, OnChanges {
get hasActions() { get hasActions() {
return this.linking || this.share || this.cite || this.orcid; return this.linking || this.share || this.cite || this.orcid;
} }
public getTypeName(type: string): string { public getTypeName(type: string): string {
return StringUtils.getEntityName(type, false); return StringUtils.getEntityName(type, false);
} }
@ -188,7 +189,7 @@ export class ResultPreviewComponent implements OnInit, OnChanges {
return this.routerHelper.createQueryParam(this.urlParam, this.result.id) return this.routerHelper.createQueryParam(this.urlParam, this.result.id)
} }
public get isResultType() { public get isResultType() {
return this.result.resultType == "publication" || this.result.resultType == "dataset" || return this.result.resultType == "publication" || this.result.resultType == "dataset" ||
this.result.resultType == "software" || this.result.resultType == "other" || this.result.resultType == "result"; this.result.resultType == "software" || this.result.resultType == "other" || this.result.resultType == "result";

View File

@ -8,9 +8,10 @@ import {OrcidModule} from "../../orcid/orcid.module";
import {IconsModule} from "../icons/icons.module"; import {IconsModule} from "../icons/icons.module";
import {IconsService} from "../icons/icons.service"; import {IconsService} from "../icons/icons.service";
import {cite, fire, graph, landmark, link, link_to, quotes, rocket, versions} from "../icons/icons"; import {cite, fire, graph, landmark, link, link_to, quotes, rocket, versions} from "../icons/icons";
import {EntityActionsModule} from "../entity-actions/entity-actions.module";
@NgModule({ @NgModule({
imports: [CommonModule, RouterModule, ShowAuthorsModule, ResultLandingUtilsModule, OrcidModule, IconsModule], imports: [CommonModule, RouterModule, ShowAuthorsModule, ResultLandingUtilsModule, OrcidModule, IconsModule, EntityActionsModule],
declarations: [ResultPreviewComponent], declarations: [ResultPreviewComponent],
exports: [ResultPreviewComponent] exports: [ResultPreviewComponent]
}) })