start on result landing mobile redesign

This commit is contained in:
Alex Martzios 2023-01-24 15:32:58 +02:00
parent c58bc15a74
commit 0a519c667a
5 changed files with 676 additions and 516 deletions

View File

@ -6,13 +6,13 @@
<!-- left box - actions --> <!-- left box - actions -->
<!-- <div id="landing-left-sidebar" *ngIf="dataProviderInfo" class="uk-visible@s uk-padding-remove-horizontal"> <!-- <div id="landing-left-sidebar" *ngIf="dataProviderInfo" class="uk-visible@s uk-padding-remove-horizontal">
<div class="uk-flex uk-flex-column uk-flex-between uk-flex-center uk-sticky" <div class="uk-flex uk-flex-column uk-flex-between uk-flex-center uk-sticky"
uk-sticky="bottom: true" [attr.offset]="offset"> uk-sticky="bottom: true" [attr.offset]="offset">
<div class="uk-align-center uk-text-center uk-margin-medium-top uk-flex uk-flex-column uk-flex-between"> <div class="uk-align-center uk-text-center uk-margin-medium-top uk-flex uk-flex-column uk-flex-between">
<ng-container *ngIf="dataProviderInfo && hasMetrics"> <ng-container *ngIf="dataProviderInfo && hasMetrics">
<metrics [pageViews]="pageViews" <metrics [pageViews]="pageViews"
[id]="datasourceId" [entityType]="'datasources'" [id]="datasourceId" [entityType]="'datasources'"
[viewsFrameUrl]="viewsFrameUrl" [downloadsFrameUrl]="downloadsFrameUrl" [viewsFrameUrl]="viewsFrameUrl" [downloadsFrameUrl]="downloadsFrameUrl"
(metricsResults)="metricsResults($event)" [properties]=properties> (metricsResults)="metricsResults($event)" [properties]=properties>
</metrics> </metrics>
</ng-container> </ng-container>
</div> </div>
@ -21,8 +21,8 @@
<ul class="uk-list"> <ul class="uk-list">
<li class="uk-text-center"> <li class="uk-text-center">
<a (click)="openAddThisModal()" <a (click)="openAddThisModal()"
[title]="'Share this '+openaireEntities.DATASOURCE+' in your social networks'" [title]="'Share this '+openaireEntities.DATASOURCE+' in your social networks'"
[attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'"> [attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'">
<span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal"> <span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal">
<icon name="share" visuallyHidden="share"></icon> <icon name="share" visuallyHidden="share"></icon>
</span> </span>
@ -35,430 +35,433 @@
<!-- center box--> <!-- center box-->
<div class="uk-width-expand uk-padding-remove uk-background-default"> <div class="uk-width-expand uk-padding-remove uk-background-default">
<div *ngIf="errorMessage.length > 0 || showLoading" class="uk-container uk-flex uk-flex-center uk-height-viewport uk-position-relative"> <!-- uk-container uk-container-large -->
<div *ngIf="errorMessage.length > 0" class="uk-alert uk-alert-danger uk-width-2-3 uk-margin-xlarge-top" <div class="">
role="alert">{{errorMessage}}</div> <div *ngIf="errorMessage.length > 0 || showLoading" class="uk-container uk-flex uk-flex-center uk-height-viewport uk-position-relative">
<div *ngIf="showLoading" class="uk-position-center"> <div *ngIf="errorMessage.length > 0" class="uk-alert uk-alert-danger uk-width-2-3 uk-margin-xlarge-top"
<loading></loading> role="alert">{{errorMessage}}</div>
</div> <div *ngIf="showLoading" class="uk-position-center">
</div> <loading></loading>
<ng-template #graph_and_feedback_template>
<div class="uk-flex uk-margin-small-top uk-margin-small-bottom" [class.uk-invisible]="!dataProviderInfo">
<!-- Last Index Info-->
<div class="uk-width-2-3@m uk-width-1-2">
<icon name="graph" customClass="text-graph"></icon>
<span class="uk-margin-small-left uk-text-baseline">
<span class="uk-text-meta">Powered by </span>
<a href="https://graph.openaire.eu" target="_blank" class="text-graph">OpenAIRE Research Graph</a>
</span>
<span *ngIf="indexUpdateDate" class="uk-text-baseline uk-text-meta">
. Last update of records in OpenAIRE: {{indexUpdateDate | date: 'MMM dd, yyyy'}}
</span>
</div>
<!--Feedback-->
<div *ngIf="properties.reCaptchaSiteKey" class="uk-width-expand uk-text-right">
<span class="uk-text-meta uk-text-xsmall">See an issue?</span>
<a (click)="showFeedback = true; scroll()" class="uk-text-xsmall"> Report it here</a>
</div>
</div>
</ng-template>
<div #graph_and_feedback id="graph_and_feedback" class="uk-padding uk-padding-remove-vertical uk-blur-background uk-text-xsmall uk-visible@m"
uk-sticky="bottom: true;" [attr.offset]="graph_offset">
<ng-container *ngTemplateOutlet="graph_and_feedback_template"></ng-container>
</div>
<div class="uk-margin-top uk-margin-bottom">
<div class="uk-flex uk-flex-middle uk-flex-center">
<div class="landing-action-bar uk-box-shadow-small uk-margin-bottom">
<div class="uk-flex uk-text-xsmall" style="grid-gap: 20px;">
<!-- Actions -->
<a (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>
</div>
</div> </div>
</div> </div>
</div>
<ng-template #graph_and_feedback_template>
<div class="uk-margin-large-left uk-margin-large-right" [style]="'margin-bottom: '+graph_height+'px'"> <div class="uk-flex uk-margin-small-top uk-margin-small-bottom" [class.uk-invisible]="!dataProviderInfo">
<ng-container *ngIf="dataProviderInfo"> <!-- Last Index Info-->
<div [attr.style]="'margin-top: '+(graph_height? 'calc(40px + 20px - '+graph_height+'px)': '40px')"> <div class="uk-width-2-3@m uk-width-1-2">
<!-- schema.org--> <icon name="graph" customClass="text-graph"></icon>
<schema2jsonld [data]=dataProviderInfo <span class="uk-margin-small-left uk-text-baseline">
[URL]="canonicalUrl" <span class="uk-text-meta">Powered by </span>
type="datasource" <a href="https://graph.openaire.eu" target="_blank" class="text-graph">OpenAIRE Research Graph</a>
[otherURL]="(dataProviderInfo.provenance)?provenanceUrls:null"></schema2jsonld> </span>
<!-- Actions for mobile viewport --> <span *ngIf="indexUpdateDate" class="uk-text-baseline uk-text-meta">
<div class="uk-flex uk-flex-right uk-margin-medium-bottom uk-hidden@s"> . Last update of records in OpenAIRE: {{indexUpdateDate | date: 'MMM dd, yyyy'}}
<div> </span>
</div>
<!--Feedback-->
<div *ngIf="properties.reCaptchaSiteKey" class="uk-width-expand uk-text-right">
<span class="uk-text-meta uk-text-xsmall">See an issue?</span>
<a (click)="showFeedback = true; scroll()" class="uk-text-xsmall"> Report it here</a>
</div>
</div>
</ng-template>
<div #graph_and_feedback id="graph_and_feedback" class="uk-padding uk-padding-remove-vertical uk-blur-background uk-text-xsmall uk-visible@m"
uk-sticky="bottom: true;" [attr.offset]="graph_offset">
<ng-container *ngTemplateOutlet="graph_and_feedback_template"></ng-container>
</div>
<div class="uk-margin-top uk-margin-bottom">
<div class="uk-flex uk-flex-middle uk-flex-center">
<div class="landing-action-bar uk-box-shadow-small uk-margin-bottom">
<div class="uk-flex uk-text-xsmall" style="grid-gap: 20px;">
<!-- Actions -->
<a (click)="openAddThisModal()" <a (click)="openAddThisModal()"
[title]="'Share this '+openaireEntities.DATASOURCE+' in your social networks'" class="uk-flex uk-flex-middle uk-flex-center uk-button-link uk-text-bolder">
[attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'"> <icon flex="true" ratio="0.8" name="share" visuallyHidden="share"></icon>
<span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal"> <span class="uk-margin-xsmall-left">Share</span>
<icon name="share" visuallyHidden="share"></icon>
</span>
</a> </a>
</div> </div>
</div> </div>
</div>
<helper *ngIf="pageContents && pageContents['top'] && pageContents['top'].length > 0" </div>
[texts]="pageContents['top']"></helper>
<div class="uk-margin-large-left uk-margin-large-right" [style]="'margin-bottom: '+graph_height+'px'">
<landing-header [properties]="properties" [title]="dataProviderInfo.title.name" <ng-container *ngIf="dataProviderInfo">
[subTitle]="(dataProviderInfo.officialName <div [attr.style]="'margin-top: '+(graph_height? 'calc(40px + 20px - '+graph_height+'px)': '40px')">
&& dataProviderInfo.title.name !== dataProviderInfo.officialName)?dataProviderInfo.officialName:null" <!-- schema.org-->
[types]="dataProviderInfo.type ? [dataProviderInfo.type] : null" <schema2jsonld [data]=dataProviderInfo
[entityType]="getTypeName()" [URL]="canonicalUrl"
[compatibility]="dataProviderInfo.compatibility" [aggregationStatus]="dataProviderInfo.aggregationStatus" type="datasource"
[thematic]="dataProviderInfo.thematic" [type]="type"> [otherURL]="(dataProviderInfo.provenance)?provenanceUrls:null"></schema2jsonld>
</landing-header> <!-- Actions for mobile viewport -->
<div class="uk-flex uk-flex-right uk-margin-medium-bottom uk-hidden@s">
<!-- Labels --> <div>
<!-- To be moved inside the landing-header --> <a (click)="openAddThisModal()"
<!-- <div class="uk-margin-bottom uk-grid uk-grid-small uk-flex-middle" uk-grid> [title]="'Share this '+openaireEntities.DATASOURCE+' in your social networks'"
<ng-container *ngIf="dataProviderInfo.compatibility && [attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'">
!(dataProviderInfo.compatibility.info == 'not available' && type == 'service')"> <span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal">
<div> <icon name="share" visuallyHidden="share"></icon>
<span class="uk-label uk-text-truncate" [class.uk-label-danger]="dataProviderInfo.compatibility.info == 'not available'" title="Compatibility"> </span>
<a *ngIf="dataProviderInfo.compatibility.id" </a>
[queryParams]="{datasourceId: dataProviderInfo.compatibility.id}" routerLinkActive="router-link-active" </div>
[routerLink]="properties.searchLinkToDataProvider.split('?')[0]"> </div>
{{dataProviderInfo.compatibility.info}}
<ng-container *ngIf="dataProviderInfo.compatibility.name">{{dataProviderInfo.compatibility.name}}</ng-container> <helper *ngIf="pageContents && pageContents['top'] && pageContents['top'].length > 0"
</a> [texts]="pageContents['top']"></helper>
<span *ngIf="!dataProviderInfo.compatibility.id">
<ng-container *ngIf="dataProviderInfo.compatibility.info.toLowerCase() != 'not yet registered'">{{dataProviderInfo.compatibility.info}}</ng-container> <landing-header [properties]="properties" [title]="dataProviderInfo.title.name"
<ng-container *ngIf="dataProviderInfo.compatibility.info.toLowerCase() == 'not yet registered'"> [subTitle]="(dataProviderInfo.officialName
{{dataProviderInfo.compatibility.info}} <span *ngIf="properties.adminToolsPortalType == 'eosc'">in OpenAIRE</span> && dataProviderInfo.title.name !== dataProviderInfo.officialName)?dataProviderInfo.officialName:null"
</ng-container> [types]="dataProviderInfo.type ? [dataProviderInfo.type] : null"
</span> [entityType]="getTypeName()"
<span *ngIf="dataProviderInfo.compatibility.name && !dataProviderInfo.compatibility.id"> [compatibility]="dataProviderInfo.compatibility" [aggregationStatus]="dataProviderInfo.aggregationStatus"
{{dataProviderInfo.compatibility.name}} [thematic]="dataProviderInfo.thematic" [type]="type">
</span> </landing-header>
</span>
</div> <!-- Labels -->
</ng-container> <!-- To be moved inside the landing-header -->
<ng-container *ngIf="dataProviderInfo.aggregationStatus && dataProviderInfo.aggregationStatus.fulltexts && dataProviderInfo.aggregationStatus.fulltexts > 0"> <!-- <div class="uk-margin-bottom uk-grid uk-grid-small uk-flex-middle" uk-grid>
<div> <ng-container *ngIf="dataProviderInfo.compatibility &&
<span class="uk-label uk-text-truncate">OpenAIRE Text Mining</span> !(dataProviderInfo.compatibility.info == 'not available' && type == 'service')">
</div> <div>
</ng-container> <span class="uk-label uk-text-truncate" [class.uk-label-danger]="dataProviderInfo.compatibility.info == 'not available'" title="Compatibility">
<ng-container *ngIf="dataProviderInfo.countries && removeUnknown(dataProviderInfo.countries).length > 0"> <a *ngIf="dataProviderInfo.compatibility.id"
<ng-container *ngFor="let country of removeUnknown(dataProviderInfo.countries)"> [queryParams]="{datasourceId: dataProviderInfo.compatibility.id}" routerLinkActive="router-link-active"
<div> [routerLink]="properties.searchLinkToDataProvider.split('?')[0]">
<span class="uk-label label-country" title="Country">{{country}}</span> {{dataProviderInfo.compatibility.info}}
</div> <ng-container *ngIf="dataProviderInfo.compatibility.name">{{dataProviderInfo.compatibility.name}}</ng-container>
</ng-container> </a>
</ng-container> <span *ngIf="!dataProviderInfo.compatibility.id">
<ng-container *ngIf="dataProviderInfo.thematic"> <ng-container *ngIf="dataProviderInfo.compatibility.info.toLowerCase() != 'not yet registered'">{{dataProviderInfo.compatibility.info}}</ng-container>
<div> <ng-container *ngIf="dataProviderInfo.compatibility.info.toLowerCase() == 'not yet registered'">
<span class="uk-label uk-text-truncate">Thematic</span> {{dataProviderInfo.compatibility.info}} <span *ngIf="properties.adminToolsPortalType == 'eosc'">in OpenAIRE</span>
</div> </ng-container>
</ng-container> </span>
</div> --> <span *ngIf="dataProviderInfo.compatibility.name && !dataProviderInfo.compatibility.id">
{{dataProviderInfo.compatibility.name}}
<!-- Web Page --> </span>
<div *ngIf="dataProviderInfo.title && dataProviderInfo.title.url" </span>
class="uk-text-small uk-margin-small-top"> </div>
<span class="uk-text-meta">Web page: </span> </ng-container>
<a [href]="dataProviderInfo.title.url" target="_blank" <ng-container *ngIf="dataProviderInfo.aggregationStatus && dataProviderInfo.aggregationStatus.fulltexts && dataProviderInfo.aggregationStatus.fulltexts > 0">
class="uk-button uk-button-text uk-text-lowercase uk-text-normal custom-external"> <div>
{{dataProviderInfo.title.url}} <span class="uk-label uk-text-truncate">OpenAIRE Text Mining</span>
</a> </div>
</div> </ng-container>
<ng-container *ngIf="dataProviderInfo.countries && removeUnknown(dataProviderInfo.countries).length > 0">
<!-- Identifiers --> <ng-container *ngFor="let country of removeUnknown(dataProviderInfo.countries)">
<div *ngIf="dataProviderInfo.identifiers && dataProviderInfo.identifiers.size > 0" class="uk-margin-small-top uk-text-small"> <div>
<showIdentifiers [identifiers]="dataProviderInfo.identifiers" [showViewAll]="true"></showIdentifiers> <span class="uk-label label-country" title="Country">{{country}}</span>
</div> </div>
</div> </ng-container>
</ng-container>
<div id="main-tabs-div" class="uk-sticky uk-blur-background" <ng-container *ngIf="dataProviderInfo.thematic">
uk-sticky="bottom: true; media: @m" [attr.offset]="offset"> <div>
<div class="uk-padding uk-padding-remove-horizontal uk-padding-remove-bottom"> <span class="uk-label uk-text-truncate">Thematic</span>
<landing-header *ngIf="stickyHeader" class="uk-visible@m" </div>
[properties]="properties" [title]="dataProviderInfo.title.name" </ng-container>
[subTitle]="(dataProviderInfo.officialName </div> -->
&& dataProviderInfo.title.name !== dataProviderInfo.officialName)?dataProviderInfo.officialName:null"
[types]="dataProviderInfo.type ? [dataProviderInfo.type] : null" <!-- Web Page -->
isSticky="true"> <div *ngIf="dataProviderInfo.title && dataProviderInfo.title.url"
</landing-header> class="uk-text-small uk-margin-small-top">
<!-- <showTitle *ngIf="stickyHeader" [titleName]="dataProviderInfo.title.name" classNames="uk-margin-remove-bottom" class="uk-visible@m"></showTitle>--> <span class="uk-text-meta">Web page: </span>
<my-tabs (selectedActiveTab)="onSelectActiveTab($event)" [offsetForSticky]="offset" [(isSticky)]="stickyHeader"> <a [href]="dataProviderInfo.title.url" target="_blank"
<my-tab [tabTitle]="'Summary'" [tabId]="'summary'" [active]="true"></my-tab> class="uk-button uk-button-text uk-text-lowercase uk-text-normal custom-external">
<my-tab *ngIf="fetchProjects.searchUtils.totalResults > 0" {{dataProviderInfo.title.url}}
[tabTitle]="openaireEntities.PROJECTS" [tabNumber]="fetchProjects.searchUtils.totalResults" </a>
[tabId]="'projects'"> </div>
</my-tab>
<my-tab *ngIf="fetchDataproviders.searchUtils.totalResults > 0" <!-- Identifiers -->
[tabTitle]="openaireEntities.DATASOURCES" [tabNumber]="fetchDataproviders.searchUtils.totalResults" <div *ngIf="dataProviderInfo.identifiers && dataProviderInfo.identifiers.size > 0" class="uk-margin-small-top uk-text-small">
[tabId]="'datasources'"> <showIdentifiers [identifiers]="dataProviderInfo.identifiers" [showViewAll]="true"></showIdentifiers>
</my-tab> </div>
<my-tab *ngIf="fetchPublications.searchUtils.totalResults > 0" </div>
[tabTitle]="openaireEntities.PUBLICATIONS" [tabNumber]="fetchPublications.searchUtils.totalResults"
[tabId]="'publications'"> <div id="main-tabs-div" class="uk-sticky uk-blur-background"
</my-tab> uk-sticky="bottom: true; media: @m" [attr.offset]="offset">
<my-tab *ngIf="fetchDatasets.searchUtils.totalResults > 0" <div class="uk-padding uk-padding-remove-horizontal uk-padding-remove-bottom">
[tabTitle]="openaireEntities.DATASETS" [tabNumber]="fetchDatasets.searchUtils.totalResults" <landing-header *ngIf="stickyHeader" class="uk-visible@m"
[tabId]="'datasets'"> [properties]="properties" [title]="dataProviderInfo.title.name"
</my-tab> [subTitle]="(dataProviderInfo.officialName
<my-tab *ngIf="fetchSoftware.searchUtils.totalResults > 0" && dataProviderInfo.title.name !== dataProviderInfo.officialName)?dataProviderInfo.officialName:null"
[tabTitle]="openaireEntities.SOFTWARE" [tabNumber]="fetchSoftware.searchUtils.totalResults" [types]="dataProviderInfo.type ? [dataProviderInfo.type] : null"
[tabId]="'software'"> isSticky="true">
</my-tab> </landing-header>
<my-tab *ngIf="fetchOrps.searchUtils.totalResults > 0" <!-- <showTitle *ngIf="stickyHeader" [titleName]="dataProviderInfo.title.name" classNames="uk-margin-remove-bottom" class="uk-visible@m"></showTitle>-->
[tabTitle]="openaireEntities.OTHER" [tabNumber]="fetchOrps.searchUtils.totalResults" <my-tabs (selectedActiveTab)="onSelectActiveTab($event)" [offsetForSticky]="offset" [(isSticky)]="stickyHeader">
[tabId]="'other'"> <my-tab [tabTitle]="'Summary'" [tabId]="'summary'" [active]="true"></my-tab>
</my-tab> <my-tab *ngIf="fetchProjects.searchUtils.totalResults > 0"
<my-tab *ngIf="(fetchPublications.searchUtils.totalResults > 0 || fetchDatasets.searchUtils.totalResults > 0 [tabTitle]="openaireEntities.PROJECTS" [tabNumber]="fetchProjects.searchUtils.totalResults"
|| fetchSoftware.searchUtils.totalResults > 0 || fetchOrps.searchUtils.totalResults > 0)" [tabId]="'projects'">
[tabTitle]="'Related '+openaireEntities.DATASOURCES" [tabId]="'relatedDatasources'"> </my-tab>
</my-tab> <my-tab *ngIf="fetchDataproviders.searchUtils.totalResults > 0"
<my-tab *ngIf="(fetchPublications.searchUtils.totalResults > 0 || fetchDatasets.searchUtils.totalResults > 0 [tabTitle]="openaireEntities.DATASOURCES" [tabNumber]="fetchDataproviders.searchUtils.totalResults"
|| fetchSoftware.searchUtils.totalResults > 0 || fetchOrps.searchUtils.totalResults > 0)" [tabId]="'datasources'">
[tabTitle]="'Statistics'" customClass="statistics" [tabId]="'statistics'" [active]="false"> </my-tab>
</my-tab> <my-tab *ngIf="fetchPublications.searchUtils.totalResults > 0"
</my-tabs> [tabTitle]="openaireEntities.PUBLICATIONS" [tabNumber]="fetchPublications.searchUtils.totalResults"
</div> [tabId]="'publications'">
</div> </my-tab>
<my-tab *ngIf="fetchDatasets.searchUtils.totalResults > 0"
<div id="landing-sections" class="uk-text-small"> [tabTitle]="openaireEntities.DATASETS" [tabNumber]="fetchDatasets.searchUtils.totalResults"
<div id="summary" class="landing-section landing-section-height-auto"> [tabId]="'datasets'">
<div class="uk-card uk-card-default card-tab uk-grid uk-margin-remove-left uk-margin-medium-top uk-margin-medium-bottom"> </my-tab>
<div *ngIf="!(hasPrimaryInfo || (!aggregationStatusIsInitialized || hasAggregationStatusInfo)) && !hasSecondaryInfo" <my-tab *ngIf="fetchSoftware.searchUtils.totalResults > 0"
class="uk-width-expand uk-height-small uk-flex uk-flex-center uk-flex-middle"> [tabTitle]="openaireEntities.SOFTWARE" [tabNumber]="fetchSoftware.searchUtils.totalResults"
<div class="uk-animation-fade uk-text-meta uk-text-large"> [tabId]="'software'">
No summary information available </my-tab>
</div> <my-tab *ngIf="fetchOrps.searchUtils.totalResults > 0"
</div> [tabTitle]="openaireEntities.OTHER" [tabNumber]="fetchOrps.searchUtils.totalResults"
<div *ngIf="hasPrimaryInfo || (!aggregationStatusIsInitialized || hasAggregationStatusInfo)" [tabId]="'other'">
class="uk-width-expand uk-padding uk-inline"> </my-tab>
<!-- Description --> <my-tab *ngIf="(fetchPublications.searchUtils.totalResults > 0 || fetchDatasets.searchUtils.totalResults > 0
<div *ngIf="dataProviderInfo.description" class="uk-margin-medium-bottom"> || fetchSoftware.searchUtils.totalResults > 0 || fetchOrps.searchUtils.totalResults > 0)"
<div class="uk-text-justify"> [tabTitle]="'Related '+openaireEntities.DATASOURCES" [tabId]="'relatedDatasources'">
<div class="uk-text-meta uk-margin-small-bottom">Description</div> </my-tab>
<div class="multi-line-ellipsis lines-10"> <my-tab *ngIf="(fetchPublications.searchUtils.totalResults > 0 || fetchDatasets.searchUtils.totalResults > 0
<div #descriptionDiv class="uk-margin-small-bottom" || fetchSoftware.searchUtils.totalResults > 0 || fetchOrps.searchUtils.totalResults > 0)"
[innerHtml]="dataProviderInfo.description"></div> [tabTitle]="'Statistics'" customClass="statistics" [tabId]="'statistics'" [active]="false">
</div> </my-tab>
<div *ngIf="showViewMoreButton" class="uk-flex uk-flex-right"> </my-tabs>
<a (click)="openDescriptionModal();" class="view-more-less-link"> </div>
View more </div>
<div id="landing-sections" class="uk-text-small">
<div id="summary" class="landing-section landing-section-height-auto">
<div class="uk-card uk-card-default card-tab uk-grid uk-margin-remove-left uk-margin-medium-top uk-margin-medium-bottom">
<div *ngIf="!(hasPrimaryInfo || (!aggregationStatusIsInitialized || hasAggregationStatusInfo)) && !hasSecondaryInfo"
class="uk-width-expand uk-height-small uk-flex uk-flex-center uk-flex-middle">
<div class="uk-animation-fade uk-text-meta uk-text-large">
No summary information available
</div>
</div>
<div *ngIf="hasPrimaryInfo || (!aggregationStatusIsInitialized || hasAggregationStatusInfo)"
class="uk-width-expand uk-padding uk-inline">
<!-- Description -->
<div *ngIf="dataProviderInfo.description" class="uk-margin-medium-bottom">
<div class="uk-text-justify">
<div class="uk-text-meta uk-margin-small-bottom">Description</div>
<div class="multi-line-ellipsis lines-10">
<div #descriptionDiv class="uk-margin-small-bottom"
[innerHtml]="dataProviderInfo.description"></div>
</div>
<div *ngIf="showViewMoreButton" class="uk-flex uk-flex-right">
<a (click)="openDescriptionModal();" class="view-more-less-link">
View more
</a>
</div>
</div>
</div>
<ul *ngIf="hasJournalInfo" class="uk-list uk-margin-medium-bottom uk-margin-remove-top">
<showPublisher [journal]="dataProviderInfo.journal" [properties]="properties"></showPublisher>
</ul>
<div *ngIf="hasAggregationStatusInfo || dataProviderInfo.fundedContent"
class="uk-margin-medium-bottom uk-animation-fade uk-animation-fast">
<span *ngIf="dataProviderInfo.aggregationStatus?.fulltexts && dataProviderInfo.aggregationStatus?.fulltexts != -1"
class="uk-margin-right uk-display-inline-block">
<div class="uk-text-meta uk-margin-small-bottom">Collected full-texts</div>
{{dataProviderInfo.aggregationStatus.fulltexts | number}}
</span>
<span *ngIf="dataProviderInfo.fundedContent && dataProviderInfo.fundedContent > 0"
class="uk-display-inline-block">
<div class="uk-text-meta uk-margin-small-bottom">Results with funding information</div>
{{dataProviderInfo.fundedContent | number}}
</span>
</div>
<div *ngIf="!aggregationStatusIsInitialized || !dataProviderInfo.fundedContent"
class="uk-animation-fade uk-margin-top uk-width-1-1" role="alert">
<span class="loading-gif uk-align-center"></span>
</div>
<div *ngIf="dataProviderInfo.countries != undefined && dataProviderInfo.countries.length > 0"
class="uk-margin-medium-bottom">
<div class="uk-text-meta uk-margin-small-bottom">Countries</div>
{{dataProviderInfo.countries.join(", ")}}
</div>
<div *ngIf="dataProviderInfo.jurisdiction" class="uk-margin-medium-bottom">
<div class="uk-text-meta uk-margin-small-bottom">Jurisdiction</div>
{{dataProviderInfo.jurisdiction}}
</div>
<div *ngIf="dataProviderInfo.contentpolicy" class="uk-margin-medium-bottom">
<div class="uk-text-meta uk-margin-small-bottom">Content policy</div>
{{dataProviderInfo.contentpolicy}}
</div>
<!-- Subjects -->
<div *ngIf="dataProviderInfo.subjects && dataProviderInfo.subjects.length > 0"
class="uk-margin-medium-bottom uk-margin-bottom">
<div class="uk-height-max-medium uk-overflow-auto">
<div class="uk-text-meta uk-margin-small-bottom">Subjects </div>
<span>{{dataProviderInfo.subjects.slice(0, lessBtnSubjects ? dataProviderInfo.subjects.length : thresholdSubjects).join(", ")}}</span>
<span *ngIf="dataProviderInfo.subjects.length > thresholdSubjects && !lessBtnSubjects"> ... </span>
</div>
<div *ngIf="dataProviderInfo.subjects.length > thresholdSubjects && !lessBtnSubjects"
class="uk-width-1-1 uk-text-right">
<a (click)="viewAllSubjectsClick();" class="view-more-less-link">
View all {{dataProviderInfo.subjects.length | number}} subjects
</a> </a>
</div> </div>
</div> <div *ngIf="viewAllSubjects && lessBtnSubjects" class="uk-width-1-1 uk-text-right">
</div> <a (click)="viewAllSubjects = !viewAllSubjects; lessBtnSubjects=false;" class="view-more-less-link">View less subjects</a>
</div>
<ul *ngIf="hasJournalInfo" class="uk-list uk-margin-medium-bottom uk-margin-remove-top"> </div>
<showPublisher [journal]="dataProviderInfo.journal" [properties]="properties"></showPublisher>
</ul> </div>
<div *ngIf="hasSecondaryInfo"
<div *ngIf="hasAggregationStatusInfo || dataProviderInfo.fundedContent" [class]="'uk-inline uk-padding uk-padding-remove-horizontal ' + (hasPrimaryInfo?'uk-width-1-3@m': 'uk-width-expand')">
class="uk-margin-medium-bottom uk-animation-fade uk-animation-fast"> <div class="uk-padding uk-padding-remove-vertical uk-height-1-1">
<span *ngIf="dataProviderInfo.aggregationStatus?.fulltexts && dataProviderInfo.aggregationStatus?.fulltexts != -1" <div *ngIf="dataProviderInfo.oaiPmhURL || dataProviderInfo.provenance?.size > 0"
class="uk-margin-right uk-display-inline-block"> class="uk-margin-medium-bottom">
<div class="uk-text-meta uk-margin-small-bottom">Collected full-texts</div> <div *ngIf="dataProviderInfo.oaiPmhURL" class="uk-margin-medium-bottom">
{{dataProviderInfo.aggregationStatus.fulltexts | number}} <div class="uk-text-meta uk-margin-small-bottom">OAI-PMH</div>
</span> <a target="_blank" href="{{dataProviderInfo.oaiPmhURL}}" class="custom-external">
<span *ngIf="dataProviderInfo.fundedContent && dataProviderInfo.fundedContent > 0" {{dataProviderInfo.oaiPmhURL}}
class="uk-display-inline-block"> </a>
<div class="uk-text-meta uk-margin-small-bottom">Results with funding information</div> </div>
{{dataProviderInfo.fundedContent | number}} <div *ngIf="dataProviderInfo.provenance?.size > 0" class="uk-display-inline-block">
</span> <div class="uk-text-meta uk-margin-small-bottom">Detailed information @ </div>
</div> <span *ngFor="let provenance of getKeys(dataProviderInfo.provenance); let i=index">
<div *ngIf="!aggregationStatusIsInitialized || !dataProviderInfo.fundedContent" <a *ngIf="dataProviderInfo.provenance.get(provenance).url.length == 1" class="custom-external uk-link-text"
class="uk-animation-fade uk-margin-top uk-width-1-1" role="alert"> target="_blank" href="{{dataProviderInfo.provenance.get(provenance).url}}">
<span class="loading-gif uk-align-center"></span> {{provenance}}
</div> </a>
<ng-container *ngIf="dataProviderInfo.provenance.get(provenance).url.length > 1">
<div *ngIf="dataProviderInfo.countries != undefined && dataProviderInfo.countries.length > 0" <span class="custom-external">{{provenance}}</span>
class="uk-margin-medium-bottom"> <ng-container *ngFor="let url of dataProviderInfo.provenance.get(provenance).url; let i=index">
<div class="uk-text-meta uk-margin-small-bottom">Countries</div> [<a target="_blank" href="{{url}}">{{i}}</a>]
{{dataProviderInfo.countries.join(", ")}} </ng-container>
</div> </ng-container>
<span *ngIf="i < dataProviderInfo.provenance.size-1">, </span>
<div *ngIf="dataProviderInfo.jurisdiction" class="uk-margin-medium-bottom"> </span>
<div class="uk-text-meta uk-margin-small-bottom">Jurisdiction</div> </div>
{{dataProviderInfo.jurisdiction}} </div>
</div> <div *ngIf="dataProviderInfo.organizations && dataProviderInfo.organizations.length > 0"
class="uk-margin-medium-bottom">
<div *ngIf="dataProviderInfo.contentpolicy" class="uk-margin-medium-bottom"> <div class="uk-text-meta uk-margin-small-bottom">{{openaireEntities.ORGANIZATIONS}}</div>
<div class="uk-text-meta uk-margin-small-bottom">Content policy</div> <ng-container *ngTemplateOutlet="organizations_template; context: { threshold: lessBtnOrganizations ? dataProviderInfo.organizations.length : thresholdOrganizations }"></ng-container>
{{dataProviderInfo.contentpolicy}}
</div> <div *ngIf="dataProviderInfo.organizations.length > thresholdOrganizations && !lessBtnOrganizations"
class="uk-width-1-1 uk-text-right">
<!-- Subjects --> <a (click)="viewAllOrganizationsClick();" class="view-more-less-link">
<div *ngIf="dataProviderInfo.subjects && dataProviderInfo.subjects.length > 0" View all {{dataProviderInfo.organizations.length | number}} organizations
class="uk-margin-medium-bottom uk-margin-bottom"> </a>
<div class="uk-height-max-medium uk-overflow-auto"> </div>
<div class="uk-text-meta uk-margin-small-bottom">Subjects </div> <div *ngIf="viewAllOrganizations && lessBtnOrganizations" class="uk-width-1-1 uk-text-right">
<span>{{dataProviderInfo.subjects.slice(0, lessBtnSubjects ? dataProviderInfo.subjects.length : thresholdSubjects).join(", ")}}</span> <a (click)="viewAllOrganizations = !viewAllOrganizations; lessBtnOrganizations=false;" class="view-more-less-link">View less organizations</a>
<span *ngIf="dataProviderInfo.subjects.length > thresholdSubjects && !lessBtnSubjects"> ... </span> </div>
</div> </div>
<div *ngIf="dataProviderInfo.subjects.length > thresholdSubjects && !lessBtnSubjects" </div>
class="uk-width-1-1 uk-text-right"> </div>
<a (click)="viewAllSubjectsClick();" class="view-more-less-link"> </div>
View all {{dataProviderInfo.subjects.length | number}} subjects </div>
</a>
</div> <!-- Projects-->
<div *ngIf="viewAllSubjects && lessBtnSubjects" class="uk-width-1-1 uk-text-right"> <ng-container *ngIf="fetchProjects.searchUtils.totalResults > 0">
<a (click)="viewAllSubjects = !viewAllSubjects; lessBtnSubjects=false;" class="view-more-less-link">View less subjects</a> <div id="projects" class="landing-section uk-padding uk-padding-remove-horizontal">
</div> <search-tab [fetch]="fetchProjects" resultType="project"
</div> [params]="getParamsForSearchLink()"
[searchLinkToAdvancedPage]="properties.searchLinkToAdvancedProjects"
</div> [properties]="properties">
<div *ngIf="hasSecondaryInfo" </search-tab>
[class]="'uk-inline uk-padding uk-padding-remove-horizontal ' + (hasPrimaryInfo?'uk-width-1-3@m': 'uk-width-expand')"> </div>
<div class="uk-padding uk-padding-remove-vertical uk-height-1-1"> </ng-container>
<div *ngIf="dataProviderInfo.oaiPmhURL || dataProviderInfo.provenance?.size > 0" <!-- Datasources -->
class="uk-margin-medium-bottom"> <ng-container *ngIf="fetchDataproviders.searchUtils.totalResults > 0">
<div *ngIf="dataProviderInfo.oaiPmhURL" class="uk-margin-medium-bottom"> <div id="datasources" class="landing-section uk-padding uk-padding-remove-horizontal">
<div class="uk-text-meta uk-margin-small-bottom">OAI-PMH</div> <search-tab [fetch]="fetchDataproviders" resultType="dataprovider"
<a target="_blank" href="{{dataProviderInfo.oaiPmhURL}}" class="custom-external"> [params]="getParamsForSearchLink()"
{{dataProviderInfo.oaiPmhURL}} [searchLinkToAdvancedPage]="properties.searchLinkToAdvancedDataProviders"
</a> [properties]="properties">
</div> </search-tab>
<div *ngIf="dataProviderInfo.provenance?.size > 0" class="uk-display-inline-block"> </div>
<div class="uk-text-meta uk-margin-small-bottom">Detailed information @ </div> </ng-container>
<span *ngFor="let provenance of getKeys(dataProviderInfo.provenance); let i=index"> <!--Publications-->
<a *ngIf="dataProviderInfo.provenance.get(provenance).url.length == 1" class="custom-external uk-link-text" <ng-container *ngIf="fetchPublications.searchUtils.totalResults > 0">
target="_blank" href="{{dataProviderInfo.provenance.get(provenance).url}}"> <div id="publications" class="landing-section uk-padding uk-padding-remove-horizontal">
{{provenance}} <search-tab [fetch]="fetchPublications" resultType="publication"
</a> [params]="getParamsForSearchLink('publications')"
<ng-container *ngIf="dataProviderInfo.provenance.get(provenance).url.length > 1"> [searchLinkToAdvancedPage]="properties.searchLinkToAdvancedResults"
<span class="custom-external">{{provenance}}</span> [properties]="properties">
<ng-container *ngFor="let url of dataProviderInfo.provenance.get(provenance).url; let i=index"> </search-tab>
[<a target="_blank" href="{{url}}">{{i}}</a>] </div>
</ng-container> </ng-container>
</ng-container> <!--Research Data-->
<span *ngIf="i < dataProviderInfo.provenance.size-1">, </span> <ng-container *ngIf="fetchDatasets.searchUtils.totalResults > 0">
</span> <div id="datasets" class="landing-section uk-padding uk-padding-remove-horizontal">
</div> <search-tab [fetch]="fetchDatasets" resultType="dataset"
</div> [params]="getParamsForSearchLink('datasets')"
<div *ngIf="dataProviderInfo.organizations && dataProviderInfo.organizations.length > 0" [searchLinkToAdvancedPage]="properties.searchLinkToAdvancedResults"
class="uk-margin-medium-bottom"> [properties]="properties">
<div class="uk-text-meta uk-margin-small-bottom">{{openaireEntities.ORGANIZATIONS}}</div> </search-tab>
<ng-container *ngTemplateOutlet="organizations_template; context: { threshold: lessBtnOrganizations ? dataProviderInfo.organizations.length : thresholdOrganizations }"></ng-container> </div>
</ng-container>
<div *ngIf="dataProviderInfo.organizations.length > thresholdOrganizations && !lessBtnOrganizations" <!--Software-->
class="uk-width-1-1 uk-text-right"> <ng-container *ngIf="fetchSoftware.searchUtils.totalResults > 0">
<a (click)="viewAllOrganizationsClick();" class="view-more-less-link"> <div id="software" class="landing-section uk-padding uk-padding-remove-horizontal">
View all {{dataProviderInfo.organizations.length | number}} organizations <search-tab [fetch]="fetchSoftware" resultType="software"
</a> [params]="getParamsForSearchLink('software')"
</div> [searchLinkToAdvancedPage]="properties.searchLinkToAdvancedResults"
<div *ngIf="viewAllOrganizations && lessBtnOrganizations" class="uk-width-1-1 uk-text-right"> [properties]="properties">
<a (click)="viewAllOrganizations = !viewAllOrganizations; lessBtnOrganizations=false;" class="view-more-less-link">View less organizations</a> </search-tab>
</div> </div>
</div> </ng-container>
</div> <!--Other-->
</div> <ng-container *ngIf="fetchOrps.searchUtils.totalResults > 0">
</div> <div id="other" class="landing-section uk-padding uk-padding-remove-horizontal">
</div> <search-tab [fetch]="fetchOrps" resultType="other"
[params]="getParamsForSearchLink('other')"
<!-- Projects--> [searchLinkToAdvancedPage]="properties.searchLinkToAdvancedResults"
<ng-container *ngIf="fetchProjects.searchUtils.totalResults > 0"> [properties]="properties">
<div id="projects" class="landing-section uk-padding uk-padding-remove-horizontal"> </search-tab>
<search-tab [fetch]="fetchProjects" resultType="project" </div>
[params]="getParamsForSearchLink()" </ng-container>
[searchLinkToAdvancedPage]="properties.searchLinkToAdvancedProjects" <!--Related Datasources-->
[properties]="properties"> <ng-container *ngIf="(fetchPublications.searchUtils.totalResults > 0 || fetchDatasets.searchUtils.totalResults > 0
</search-tab> || fetchSoftware.searchUtils.totalResults > 0 || fetchOrps.searchUtils.totalResults > 0)">
</div> <div id="relatedDatasources" class="landing-section uk-padding uk-padding-remove-horizontal">
</ng-container> <relatedDatasourcesTab
<!-- Datasources --> [dataproviderId]="datasourceId"
<ng-container *ngIf="fetchDataproviders.searchUtils.totalResults > 0"> [results]="dataProviderInfo.relatedDatasources"
<div id="datasources" class="landing-section uk-padding uk-padding-remove-horizontal"> [loading]="loadingRelatedDatasources"
<search-tab [fetch]="fetchDataproviders" resultType="dataprovider" [fetchResults]="fetchAggregatorsResults"
[params]="getParamsForSearchLink()" [collectedFromName]="dataProviderInfo.title.name"
[searchLinkToAdvancedPage]="properties.searchLinkToAdvancedDataProviders" [properties]=properties
[properties]="properties"> [modal]="relatedDatasourcesModal">
</search-tab> </relatedDatasourcesTab>
</div> </div>
</ng-container> </ng-container>
<!--Publications--> <!--Statistics-->
<ng-container *ngIf="fetchPublications.searchUtils.totalResults > 0"> <ng-container *ngIf="(fetchPublications.searchUtils.totalResults > 0 || fetchDatasets.searchUtils.totalResults > 0
<div id="publications" class="landing-section uk-padding uk-padding-remove-horizontal"> || fetchSoftware.searchUtils.totalResults > 0 || fetchOrps.searchUtils.totalResults > 0)">
<search-tab [fetch]="fetchPublications" resultType="publication"
[params]="getParamsForSearchLink('publications')" <div id="statistics" class="landing-section uk-padding uk-padding-remove-horizontal">
[searchLinkToAdvancedPage]="properties.searchLinkToAdvancedResults" <div class="uk-text-meta uk-text-large uk-text-uppercase uk-margin-medium-bottom">Statistics</div>
[properties]="properties"> <errorMessages [status]="[fetchPublications.searchUtils.status, fetchDatasets.searchUtils.status,
</search-tab> fetchSoftware.searchUtils.status, fetchOrps.searchUtils.status]"
</div> [type]="'statistics'" tab_error_class=true></errorMessages>
</ng-container> <div *ngIf="statsClicked &&
<!--Research Data--> (fetchPublications.searchUtils.status == errorCodes.DONE || fetchDatasets.searchUtils.status == errorCodes.DONE
<ng-container *ngIf="fetchDatasets.searchUtils.totalResults > 0"> || fetchSoftware.searchUtils.status == errorCodes.DONE || fetchOrps.searchUtils.status == errorCodes.DONE)">
<div id="datasets" class="landing-section uk-padding uk-padding-remove-horizontal"> <statisticsTab [fetchPublications]="fetchPublications" [fetchDatasets]="fetchDatasets"
<search-tab [fetch]="fetchDatasets" resultType="dataset" [fetchSoftware]="fetchSoftware" [fetchOther]="fetchOrps"
[params]="getParamsForSearchLink('datasets')" [datasourceId]="datasourceId">
[searchLinkToAdvancedPage]="properties.searchLinkToAdvancedResults" </statisticsTab>
[properties]="properties"> </div>
</search-tab> </div>
</div> </ng-container>
</ng-container> </div>
<!--Software--> <div class="uk-text-xsmall uk-hidden@m"><ng-container *ngTemplateOutlet="graph_and_feedback_template"></ng-container></div>
<ng-container *ngIf="fetchSoftware.searchUtils.totalResults > 0"> <helper *ngIf="pageContents && pageContents['bottom'] && pageContents['bottom'].length > 0"
<div id="software" class="landing-section uk-padding uk-padding-remove-horizontal"> [texts]="pageContents['bottom']"></helper>
<search-tab [fetch]="fetchSoftware" resultType="software" </ng-container>
[params]="getParamsForSearchLink('software')" </div>
[searchLinkToAdvancedPage]="properties.searchLinkToAdvancedResults" </div>
[properties]="properties">
</search-tab>
</div>
</ng-container>
<!--Other-->
<ng-container *ngIf="fetchOrps.searchUtils.totalResults > 0">
<div id="other" class="landing-section uk-padding uk-padding-remove-horizontal">
<search-tab [fetch]="fetchOrps" resultType="other"
[params]="getParamsForSearchLink('other')"
[searchLinkToAdvancedPage]="properties.searchLinkToAdvancedResults"
[properties]="properties">
</search-tab>
</div>
</ng-container>
<!--Related Datasources-->
<ng-container *ngIf="(fetchPublications.searchUtils.totalResults > 0 || fetchDatasets.searchUtils.totalResults > 0
|| fetchSoftware.searchUtils.totalResults > 0 || fetchOrps.searchUtils.totalResults > 0)">
<div id="relatedDatasources" class="landing-section uk-padding uk-padding-remove-horizontal">
<relatedDatasourcesTab
[dataproviderId]="datasourceId"
[results]="dataProviderInfo.relatedDatasources"
[loading]="loadingRelatedDatasources"
[fetchResults]="fetchAggregatorsResults"
[collectedFromName]="dataProviderInfo.title.name"
[properties]=properties
[modal]="relatedDatasourcesModal">
</relatedDatasourcesTab>
</div>
</ng-container>
<!--Statistics-->
<ng-container *ngIf="(fetchPublications.searchUtils.totalResults > 0 || fetchDatasets.searchUtils.totalResults > 0
|| fetchSoftware.searchUtils.totalResults > 0 || fetchOrps.searchUtils.totalResults > 0)">
<div id="statistics" class="landing-section uk-padding uk-padding-remove-horizontal">
<div class="uk-text-meta uk-text-large uk-text-uppercase uk-margin-medium-bottom">Statistics</div>
<errorMessages [status]="[fetchPublications.searchUtils.status, fetchDatasets.searchUtils.status,
fetchSoftware.searchUtils.status, fetchOrps.searchUtils.status]"
[type]="'statistics'" tab_error_class=true></errorMessages>
<div *ngIf="statsClicked &&
(fetchPublications.searchUtils.status == errorCodes.DONE || fetchDatasets.searchUtils.status == errorCodes.DONE
|| fetchSoftware.searchUtils.status == errorCodes.DONE || fetchOrps.searchUtils.status == errorCodes.DONE)">
<statisticsTab [fetchPublications]="fetchPublications" [fetchDatasets]="fetchDatasets"
[fetchSoftware]="fetchSoftware" [fetchOther]="fetchOrps"
[datasourceId]="datasourceId">
</statisticsTab>
</div>
</div>
</ng-container>
</div>
<div class="uk-text-xsmall uk-hidden@m"><ng-container *ngTemplateOutlet="graph_and_feedback_template"></ng-container></div>
<helper *ngIf="pageContents && pageContents['bottom'] && pageContents['bottom'].length > 0"
[texts]="pageContents['bottom']"></helper>
</ng-container>
</div>
</div> </div>
</div> </div>
</div> </div>
@ -487,8 +490,8 @@
[attr.uk-tooltip]="organization.acronym && organization.name ? 'pos:right; delay:10' : 'cls: uk-invisible'" [attr.uk-tooltip]="organization.acronym && organization.name ? 'pos:right; delay:10' : 'cls: uk-invisible'"
[title]="organization.name"> [title]="organization.name">
<a *ngIf="organization.id" class="uk-link-text" <a *ngIf="organization.id" class="uk-link-text"
[queryParams]="{organizationId: organization.id}" routerLinkActive="router-link-active" [queryParams]="{organizationId: organization.id}" routerLinkActive="router-link-active"
[routerLink]="properties.searchLinkToOrganization.split('?')[0]"> [routerLink]="properties.searchLinkToOrganization.split('?')[0]">
{{(organization.acronym) ? organization.acronym : ''}} {{(organization.acronym) ? organization.acronym : ''}}
{{(!organization.acronym && organization.name) ? organization.name : ''}} {{(!organization.acronym && organization.name) ? organization.name : ''}}
</a> </a>

View File

@ -6,29 +6,46 @@ import {StringUtils} from "../../utils/string-utils.class";
@Component({ @Component({
selector: 'fos', selector: 'fos',
template: ` template: `
<div class="uk-text-xsmall" style="color: #EEB204">Beta</div> <div class="uk-visible@m">
<div [class]="'uk-flex uk-flex-between uk-flex-middle uk-margin-'+(viewAll?'':'small-')+'bottom'"> <div class="uk-text-xsmall" style="color: #EEB204">Beta</div>
<span *ngIf="viewAll" class="clickable uk-h6 uk-flex uk-flex-middle uk-margin-small-right uk-margin-remove-bottom" (click)="viewLessClick()"> <div [class]="'uk-flex uk-flex-between uk-flex-middle uk-margin-'+(viewAll?'':'small-')+'bottom'">
<icon class="uk-margin-small-right" name="arrow_back" flex="true" ratio="1.2"></icon> <span *ngIf="viewAll" class="clickable uk-h6 uk-flex uk-flex-middle uk-margin-small-right uk-margin-remove-bottom" (click)="viewLessClick()">
<span class="uk-text-nowrap">{{title}}</span> <icon class="uk-margin-small-right" name="arrow_back" flex="true" ratio="1.2"></icon>
</span> <span class="uk-text-nowrap">{{title}}</span>
<span *ngIf="!viewAll" class="uk-text-emphasis uk-text-bolder uk-text-nowrap uk-margin-small-right">{{title}}</span> </span>
<!-- <a *ngIf="viewAll && lessBtn" (click)="viewAll = !viewAll; lessBtn=false;">View less</a>--> <span *ngIf="!viewAll" class="uk-text-emphasis uk-text-bolder uk-text-nowrap uk-margin-small-right">{{title}}</span>
<a *ngIf="subjects && subjects.length > threshold && !viewAll" <!-- <a *ngIf="viewAll && lessBtn" (click)="viewAll = !viewAll; lessBtn=false;">View less</a> -->
(click)="viewAllClick();" class="view-more-less-link uk-text-truncate" uk-tooltip="View all & feedback"> <a *ngIf="subjects && subjects.length > threshold && !viewAll"
<span class="">View all & suggest</span> (click)="viewAllClick();" class="view-more-less-link uk-text-truncate" uk-tooltip="View all & feedback">
</a> <span class="">View all & suggest</span>
<a *ngIf="(subjects && subjects.length <= threshold || viewAll)" class="uk-link uk-text-truncate" </a>
(click)="feedbackClick();">Feedback</a> <a *ngIf="(subjects && subjects.length <= threshold || viewAll)" class="uk-link uk-text-truncate"
</div> (click)="feedbackClick();">Feedback</a>
<div class="uk-margin-small-top"> </div>
<div *ngFor="let subject of subjects.slice(0, viewAll?subjects.length:threshold); let i=index" class="uk-text-truncate"> <div class="uk-margin-small-top">
<a [routerLink]="properties.searchLinkToResults" <div *ngFor="let subject of subjects.slice(0, viewAll?subjects.length:threshold); let i=index" class="uk-text-truncate">
[queryParams]="{'fos': urlEncodeAndQuote(subject)}"> <a [routerLink]="properties.searchLinkToResults"
{{subject}} [queryParams]="{'fos': urlEncodeAndQuote(subject)}">
</a> {{subject}}
</div> </a>
</div> </div>
</div>
</div>
<div class="uk-hidden@m">
<div class="uk-grid uk-grid-small uk-grid-divider" uk-grid>
<div class="uk-width-1-4 uk-text-meta">
Fields of Science (FOS)
</div>
<div class="uk-width-expand">
<div *ngFor="let subject of subjects.slice(0, viewAll?subjects.length:threshold); let i=index" class="uk-text-truncate">
<a [routerLink]="properties.searchLinkToResults"
[queryParams]="{'fos': urlEncodeAndQuote(subject)}">
{{subject}}
</a>
</div>
</div>
</div>
</div>
` `
}) })
@ -38,7 +55,7 @@ export class FosComponent {
@Output() viewAllClicked = new EventEmitter(); @Output() viewAllClicked = new EventEmitter();
@Output() feedbackClicked = new EventEmitter(); @Output() feedbackClicked = new EventEmitter();
public lessBtn: boolean = false; public lessBtn: boolean = false;
public threshold: number = 2; public threshold: number = 3; // was 2
public routerHelper: RouterHelper = new RouterHelper(); public routerHelper: RouterHelper = new RouterHelper();
public properties = properties; public properties = properties;
public title: string = "Fields of Science"; public title: string = "Fields of Science";

View File

@ -14,7 +14,7 @@ import {OpenaireEntities} from "src/app/openaireLibrary/utils/properties/searchF
<span class="uk-text-meta uk-text-small" [innerHTML]="subTitle"></span> <span class="uk-text-meta uk-text-small" [innerHTML]="subTitle"></span>
</div> </div>
</div> </div>
<div class="uk-margin-bottom uk-text-xsmall uk-text-emphasis uk-flex uk-flex-middle"> <div class="uk-margin-bottom 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 uk-text-success"> <span class="uk-margin-xsmall-right uk-text-success">
@ -42,8 +42,8 @@ import {OpenaireEntities} from "src/app/openaireLibrary/utils/properties/searchF
<icon *ngIf="entityType.toLowerCase() == 'organization'" name="corporate_fare" type="outlined" [flex]="true" ratio="0.8"></icon> <icon *ngIf="entityType.toLowerCase() == 'organization'" name="corporate_fare" type="outlined" [flex]="true" ratio="0.8"></icon>
</span> </span>
<span *ngIf="entityType" class="uk-text-capitalize uk-text-bolder" style="text-decoration: underline;"> <span *ngIf="entityType" class="uk-text-capitalize uk-text-bolder" style="text-decoration: underline;">
{{entityType}} {{entityType}}
</span> </span>
<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>

View File

@ -6,34 +6,52 @@ import {StringUtils} from "../../utils/string-utils.class";
@Component({ @Component({
selector: 'sdg', selector: 'sdg',
template: ` template: `
<div class="uk-text-xsmall" style="color: #EEB204">Beta</div> <div class="uk-visible@m">
<div [class]="'uk-flex uk-flex-between uk-flex-middle uk-margin-'+(viewAll?'':'small-')+'bottom'"> <div class="uk-text-xsmall" style="color: #EEB204">Beta</div>
<span *ngIf="viewAll" class="clickable uk-h6 uk-flex uk-flex-middle uk-margin-small-right uk-margin-remove-bottom" <div [class]="'uk-flex uk-flex-between uk-flex-middle uk-margin-'+(viewAll?'':'small-')+'bottom'">
(click)="viewLessClick()"> <span *ngIf="viewAll" class="clickable uk-h6 uk-flex uk-flex-middle uk-margin-small-right uk-margin-remove-bottom"
<icon class="uk-margin-small-right" name="arrow_back" flex="true" ratio="1.2"></icon> (click)="viewLessClick()">
<span uk-tooltip="Sustainable Development Goals">{{title}}</span> <icon class="uk-margin-small-right" name="arrow_back" flex="true" ratio="1.2"></icon>
</span> <span uk-tooltip="Sustainable Development Goals">{{title}}</span>
<span *ngIf="!viewAll" class="uk-text-emphasis uk-text-bolder uk-text-nowrap uk-margin-small-right" uk-tooltip="Sustainable Development Goals">{{title}}</span> </span>
<!-- <a *ngIf="viewAll && lessBtn" (click)="viewAll = !viewAll; lessBtn=false;">View less</a>--> <span *ngIf="!viewAll" class="uk-text-emphasis uk-text-bolder uk-text-nowrap uk-margin-small-right" uk-tooltip="Sustainable Development Goals">{{title}}</span>
<a *ngIf="subjects && subjects.length > threshold && !viewAll" <!-- <a *ngIf="viewAll && lessBtn" (click)="viewAll = !viewAll; lessBtn=false;">View less</a> -->
(click)="viewAllClick();" class="view-more-less-link uk-text-truncate" uk-tooltip="View all & feedback"> <a *ngIf="subjects && subjects.length > threshold && !viewAll"
View all & suggest</a> (click)="viewAllClick();" class="view-more-less-link uk-text-truncate" uk-tooltip="View all & feedback">
<a *ngIf="(subjects && subjects.length <= threshold || viewAll)" class="uk-link uk-text-truncate" View all & suggest</a>
(click)="feedbackClick();">Feedback</a> <a *ngIf="(subjects && subjects.length <= threshold || viewAll)" class="uk-link uk-text-truncate"
</div> (click)="feedbackClick();">Feedback</a>
</div>
<div class="uk-margin-small-bottom uk-flex"> <div class="uk-margin-small-bottom uk-flex">
<img src="assets/common-assets/common/The_Global_Goals_Icon_Color.svg" <img src="assets/common-assets/common/The_Global_Goals_Icon_Color.svg"
loading="lazy" alt="sdg_colors" style="width:27px; height:27px"> loading="lazy" alt="sdg_colors" style="width:27px; height:27px">
<div class="uk-margin-small-left"> <div class="uk-margin-small-left">
<div *ngFor="let subject of subjects.slice(0, viewAll?subjects.length:threshold); let i=index" class="uk-text-truncate"> <div *ngFor="let subject of subjects.slice(0, viewAll?subjects.length:threshold); let i=index" class="uk-text-truncate">
<a [routerLink]=" properties.searchLinkToResults" <a [routerLink]=" properties.searchLinkToResults"
[queryParams]="{'sdg': urlEncodeAndQuote(subject)}"> [queryParams]="{'sdg': urlEncodeAndQuote(subject)}">
{{subject}} {{subject}}
</a> </a>
</div> </div>
</div> </div>
</div> </div>
</div>
<div class="uk-hidden@m">
<div class="uk-flex uk-flex-middle uk-flex-wrap">
<img src="assets/common-assets/common/The_Global_Goals_Icon_Color.svg"
loading="lazy" alt="sdg_colors" style="width:18px; height:18px">
<span class="uk-margin-xsmall-left uk-margin-xsmall-right uk-text-meta">SDGs:</span>
<div *ngFor="let subject of subjects.slice(0, viewAll?subjects.length:threshold); let i=index" class="uk-text-truncate">
<a [routerLink]=" properties.searchLinkToResults"
[queryParams]="{'sdg': urlEncodeAndQuote(subject)}">
{{subject}}
</a>
<span>, &nbsp;</span>
</div>
<!-- <div>
{{subjects.slice(0, viewAll?subjects.length:threshold).join(", ")}}
</div> -->
</div>
</div>
` `
}) })

View File

@ -1,4 +1,5 @@
<div id="tm-main" class="landing uk-section uk-padding-remove tm-middle"> <!-- Desktop view -->
<div id="tm-main" class="uk-visible@m landing uk-section uk-padding-remove tm-middle">
<div class="tm-main"> <div class="tm-main">
<div class="publication"> <div class="publication">
<div *ngIf="!showFeedback" class="uk-grid uk-margin-remove-left" uk-grid> <div *ngIf="!showFeedback" class="uk-grid uk-margin-remove-left" uk-grid>
@ -6,14 +7,14 @@
<!-- left box/sidebar - actions --> <!-- left box/sidebar - actions -->
<!-- <div id="landing-left-sidebar" *ngIf="resultLandingInfo" class="uk-visible@s uk-padding-remove-horizontal"> <!-- <div id="landing-left-sidebar" *ngIf="resultLandingInfo" class="uk-visible@s uk-padding-remove-horizontal">
<div class="uk-flex uk-flex-column uk-flex-between uk-flex-center uk-sticky" <div class="uk-flex uk-flex-column uk-flex-between uk-flex-center uk-sticky"
uk-sticky="bottom: true" [attr.offset]="offset"> uk-sticky="bottom: true" [attr.offset]="offset">
<div class="uk-align-center uk-text-center uk-margin-medium-top uk-flex uk-flex-column uk-flex-between"> <div class="uk-align-center uk-text-center uk-margin-medium-top uk-flex uk-flex-column uk-flex-between">
<ng-container *ngIf="resultLandingInfo && (hasAltMetrics || hasMetrics)"> <ng-container *ngIf="resultLandingInfo && (hasAltMetrics || hasMetrics)">
<metrics *ngIf="hasMetrics" class="uk-margin-bottom" <metrics *ngIf="hasMetrics" class="uk-margin-bottom"
[pageViews]="pageViews" [pageViews]="pageViews"
[id]="id" [entityType]="'results'" [entity]="title" [id]="id" [entityType]="'results'" [entity]="title"
[viewsFrameUrl]="viewsFrameUrl" [downloadsFrameUrl]="downloadsFrameUrl" [viewsFrameUrl]="viewsFrameUrl" [downloadsFrameUrl]="downloadsFrameUrl"
(metricsResults)="metricsResults($event)" [properties]=properties> (metricsResults)="metricsResults($event)" [properties]=properties>
</metrics> </metrics>
<altmetrics *ngIf="hasAltMetrics" id="{{resultLandingInfo.identifiers?.get('doi')[0]}}" type="doi"></altmetrics> <altmetrics *ngIf="hasAltMetrics" id="{{resultLandingInfo.identifiers?.get('doi')[0]}}" type="doi"></altmetrics>
</ng-container> </ng-container>
@ -23,8 +24,8 @@
<ul class="uk-list"> <ul class="uk-list">
<li class="uk-text-center"> <li class="uk-text-center">
<a (click)="openAddThisModal()" <a (click)="openAddThisModal()"
[title]="'Share this '+getTypeName() + ' in your social networks'" [title]="'Share this '+getTypeName() + ' in your social networks'"
[attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'"> [attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'">
<span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal"> <span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal">
<icon name="share" visuallyHidden="share"></icon> <icon name="share" visuallyHidden="share"></icon>
</span> </span>
@ -34,7 +35,7 @@
[title]="'<span class=\'uk-flex uk-flex-middle\'>Link this '+getTypeName()+' to ...<span class=\'material-icons uk-margin-small-left\'>east</span></span>'" [title]="'<span class=\'uk-flex uk-flex-middle\'>Link this '+getTypeName()+' to ...<span class=\'material-icons uk-margin-small-left\'>east</span></span>'"
[attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'"> [attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'">
<a [queryParams]="routerHelper.createQueryParams(['id','type','linkTo'],[id,type,'project'])" <a [queryParams]="routerHelper.createQueryParams(['id','type','linkTo'],[id,type,'project'])"
routerLinkActive="router-link-active" routerLink="/participate/direct-claim"> routerLinkActive="router-link-active" routerLink="/participate/direct-claim">
<span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal"> <span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal">
<icon name="link" visuallyHidden="link"></icon> <icon name="link" visuallyHidden="link"></icon>
</span> </span>
@ -42,8 +43,8 @@
</li> </li>
<li class="uk-text-center"> <li class="uk-text-center">
<a (click)="openCiteModal()" <a (click)="openCiteModal()"
[title]="'Cite this '+getTypeName()" [title]="'Cite this '+getTypeName()"
[attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'"> [attr.uk-tooltip]="'pos: right; cls: uk-active uk-text-small uk-padding-small'">
<span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal"> <span class="uk-icon-button uk-icon landing-action-button landing-action-button-portal">
<icon name="quotes" visuallyHidden="cite"></icon> <icon name="quotes" visuallyHidden="cite"></icon>
</span> </span>
@ -70,7 +71,7 @@
<div class="uk-width-expand uk-padding-remove uk-background-default"> <div class="uk-width-expand uk-padding-remove uk-background-default">
<div *ngIf="errorMessage.length > 0 || showLoading" class="uk-container uk-flex uk-flex-center uk-height-viewport uk-position-relative"> <div *ngIf="errorMessage.length > 0 || showLoading" class="uk-container uk-flex uk-flex-center uk-height-viewport uk-position-relative">
<div *ngIf="errorMessage.length > 0" class="uk-alert uk-alert-danger uk-width-2-3 uk-margin-xlarge-top" <div *ngIf="errorMessage.length > 0" class="uk-alert uk-alert-danger uk-width-2-3 uk-margin-xlarge-top"
role="alert">{{errorMessage}}</div> role="alert">{{errorMessage}}</div>
<div *ngIf="showLoading" class="uk-position-center"> <div *ngIf="showLoading" class="uk-position-center">
<loading></loading> <loading></loading>
</div> </div>
@ -98,7 +99,7 @@
</ng-template> </ng-template>
<div #graph_and_feedback id="graph_and_feedback" class="uk-padding uk-padding-remove-vertical uk-blur-background uk-text-xsmall uk-visible@m" <div #graph_and_feedback id="graph_and_feedback" class="uk-padding uk-padding-remove-vertical uk-blur-background uk-text-xsmall uk-visible@m"
uk-sticky="bottom: true;" [attr.offset]="graph_offset"> uk-sticky="bottom: true;" [attr.offset]="graph_offset">
<ng-container *ngTemplateOutlet="graph_and_feedback_template"></ng-container> <ng-container *ngTemplateOutlet="graph_and_feedback_template"></ng-container>
</div> </div>
@ -160,7 +161,7 @@
<!-- schema.org--> <!-- schema.org-->
<schema2jsonld *ngIf="resultLandingInfo.record" [data]=resultLandingInfo.record <schema2jsonld *ngIf="resultLandingInfo.record" [data]=resultLandingInfo.record
[URL]="canonicalUrl" [URL]="canonicalUrl"
[searchActionRoute]="properties.searchLinkToResults"></schema2jsonld> [searchActionRoute]="properties.searchLinkToResults"></schema2jsonld>
<!-- Actions for mobile viewport --> <!-- Actions for mobile viewport -->
<div class="uk-flex uk-flex-right uk-margin-medium-bottom uk-hidden@s"> <div class="uk-flex uk-flex-right uk-margin-medium-bottom uk-hidden@s">
@ -256,13 +257,13 @@
<!--Published Date, Journal and Publisher--> <!--Published Date, Journal and Publisher-->
<!-- Moved inside landing-header component --> <!-- Moved inside landing-header component -->
<!-- <div showPublisher [publisher]="resultLandingInfo.publisher" <!-- <div showPublisher [publisher]="resultLandingInfo.publisher"
[publishDate]="resultLandingInfo.dateofacceptance" [publishDate]="resultLandingInfo.dateofacceptance"
[journal]="resultLandingInfo.journal" [properties]="properties" class="uk-margin-small-top"></div> --> [journal]="resultLandingInfo.journal" [properties]="properties" class="uk-margin-small-top"></div> -->
</div> </div>
</div> </div>
<div id="main-tabs-div" class="uk-sticky uk-blur-background" <div id="main-tabs-div" class="uk-sticky uk-blur-background"
uk-sticky="bottom: true; media: @m" [attr.offset]="offset"> uk-sticky="bottom: true; media: @m" [attr.offset]="offset">
<div class="uk-padding uk-padding-remove-horizontal uk-padding-remove-bottom"> <div class="uk-padding uk-padding-remove-horizontal uk-padding-remove-bottom">
<landing-header *ngIf="stickyHeader" class="uk-visible@m" <landing-header *ngIf="stickyHeader" class="uk-visible@m"
[properties]="properties" [title]="resultLandingInfo.title" [properties]="properties" [title]="resultLandingInfo.title"
@ -273,7 +274,7 @@
[date]="resultLandingInfo.dateofacceptance" [embargoEndDate]="resultLandingInfo.embargoEndDate" [date]="resultLandingInfo.dateofacceptance" [embargoEndDate]="resultLandingInfo.embargoEndDate"
isSticky="true"> isSticky="true">
</landing-header> </landing-header>
<!-- <showTitle *ngIf="stickyHeader" [titleName]="resultLandingInfo.title" classNames="uk-margin-remove-bottom" class="uk-visible@m"></showTitle>--> <!-- <showTitle *ngIf="stickyHeader" [titleName]="resultLandingInfo.title" classNames="uk-margin-remove-bottom" class="uk-visible@m"></showTitle>-->
<my-tabs (selectedActiveTab)="onSelectActiveTab($event)" [offsetForSticky]="offset" [(isSticky)]="stickyHeader"> <my-tabs (selectedActiveTab)="onSelectActiveTab($event)" [offsetForSticky]="offset" [(isSticky)]="stickyHeader">
<my-tab tabTitle="Summary" [tabId]="'summary'" [active]="true"></my-tab> <my-tab tabTitle="Summary" [tabId]="'summary'" [active]="true"></my-tab>
<my-tab *ngIf="resultLandingInfo.references && resultLandingInfo.references.length > 0" <my-tab *ngIf="resultLandingInfo.references && resultLandingInfo.references.length > 0"
@ -340,11 +341,11 @@
</div> </div>
<!-- Related Organizations--> <!-- Related Organizations-->
<div *ngIf="resultLandingInfo.organizations && resultLandingInfo.organizations.length > 0" <div *ngIf="resultLandingInfo.organizations && resultLandingInfo.organizations.length > 0"
class="uk-margin-medium-bottom uk-width-2-3@m"> class="uk-margin-medium-bottom uk-width-2-3@m">
<div class="uk-text-meta uk-margin-small-bottom">Related {{openaireEntities.ORGANIZATIONS}}</div> <div class="uk-text-meta uk-margin-small-bottom">Related {{openaireEntities.ORGANIZATIONS}}</div>
<ng-container *ngTemplateOutlet="organizations_template; context: { threshold: lessBtnOrganizations ? resultLandingInfo.organizations.length : thresholdOrganizations }"></ng-container> <ng-container *ngTemplateOutlet="organizations_template; context: { threshold: lessBtnOrganizations ? resultLandingInfo.organizations.length : thresholdOrganizations }"></ng-container>
<div *ngIf="resultLandingInfo.organizations.length > thresholdOrganizations && !lessBtnOrganizations" <div *ngIf="resultLandingInfo.organizations.length > thresholdOrganizations && !lessBtnOrganizations"
class="uk-text-center"> class="uk-text-center">
<a (click)="viewAllOrganizationsClick();" class="view-more-less-link"> <a (click)="viewAllOrganizationsClick();" class="view-more-less-link">
View all View all
</a> </a>
@ -371,8 +372,8 @@
[<a *ngIf="id.type !== 'openaire'" href="{{getReferenceUrl(id)}}" [<a *ngIf="id.type !== 'openaire'" href="{{getReferenceUrl(id)}}"
target="_blank">{{getReferenceIdName(id)}}</a> target="_blank">{{getReferenceIdName(id)}}</a>
<a *ngIf="id.type === 'openaire'" [routerLink]="properties.searchLinkToResult.split('?')[0]" <a *ngIf="id.type === 'openaire'" [routerLink]="properties.searchLinkToResult.split('?')[0]"
[queryParams]="{id: id.value}" [queryParams]="{id: id.value}"
target="_blank">OpenAIRE</a>] target="_blank">OpenAIRE</a>]
</span> </span>
</ng-container> </ng-container>
</p> </p>
@ -401,12 +402,12 @@
*ngFor="let keyIn of keysToArray(resultLandingInfo.bioentities.get(key)).slice((bioentitiesPage-1)*2*pageSize, bioentitiesPage*2*pageSize)"> *ngFor="let keyIn of keysToArray(resultLandingInfo.bioentities.get(key)).slice((bioentitiesPage-1)*2*pageSize, bioentitiesPage*2*pageSize)">
<div> <div>
<div [title]="key" *ngIf="keyIn && !resultLandingInfo.bioentities.get(key).get(keyIn)" <div [title]="key" *ngIf="keyIn && !resultLandingInfo.bioentities.get(key).get(keyIn)"
class="uk-card uk-card-default uk-card-body"> class="uk-card uk-card-default uk-card-body">
{{keyIn}} {{keyIn}}
</div> </div>
<a [href]="resultLandingInfo.bioentities.get(key).get(keyIn)" target="_blank" <a [href]="resultLandingInfo.bioentities.get(key).get(keyIn)" target="_blank"
[title]="key" *ngIf="keyIn && resultLandingInfo.bioentities.get(key).get(keyIn)" [title]="key" *ngIf="keyIn && resultLandingInfo.bioentities.get(key).get(keyIn)"
class="uk-card uk-card-default uk-card-hover uk-card-body custom-external"> class="uk-card uk-card-default uk-card-hover uk-card-body custom-external">
{{keyIn}} {{keyIn}}
</a> </a>
</div> </div>
@ -442,7 +443,7 @@
<ng-container *ngFor="let word of detail[1].split(' ')"> <ng-container *ngFor="let word of detail[1].split(' ')">
<ng-container *ngIf="!word.startsWith('http://') && !word.startsWith('https://')">{{word}} </ng-container> <ng-container *ngIf="!word.startsWith('http://') && !word.startsWith('https://')">{{word}} </ng-container>
<a *ngIf="word.startsWith('http://') || word.startsWith('https://')" <a *ngIf="word.startsWith('http://') || word.startsWith('https://')"
target="_blank" [href]="word">{{word}} </a> target="_blank" [href]="word">{{word}} </a>
</ng-container> </ng-container>
</span> </span>
</li> </li>
@ -670,7 +671,6 @@
</ng-container> </ng-container>
</div> </div>
<div class="uk-text-xsmall uk-hidden@m"><ng-container *ngTemplateOutlet="graph_and_feedback_template"></ng-container></div> <div class="uk-text-xsmall uk-hidden@m"><ng-container *ngTemplateOutlet="graph_and_feedback_template"></ng-container></div>
<helper *ngIf="pageContents && pageContents['bottom'] && pageContents['bottom'].length > 0" <helper *ngIf="pageContents && pageContents['bottom'] && pageContents['bottom'].length > 0"
[texts]="pageContents['bottom']"></helper> [texts]="pageContents['bottom']"></helper>
</ng-container> </ng-container>
@ -681,7 +681,7 @@
<!-- right box/ sidebar--> <!-- right box/ sidebar-->
<ng-container *ngIf="resultLandingInfo && hasRightSidebarInfo"> <ng-container *ngIf="resultLandingInfo && hasRightSidebarInfo">
<div id="landing-right-sidebar" *ngIf="!rightSidebarOffcanvasClicked" class="uk-width-1-3 uk-width-1-4@l uk-padding-remove uk-text-small uk-visible@m" <div id="landing-right-sidebar" *ngIf="!rightSidebarOffcanvasClicked" class="uk-width-1-3 uk-width-1-4@l uk-padding-remove uk-text-small uk-visible@m"
[class.uk-animation-right]="viewAll"> [class.uk-animation-right]="viewAll">
<div class="uk-sticky" uk-sticky="bottom: true" [attr.offset]="offset"> <div class="uk-sticky" uk-sticky="bottom: true" [attr.offset]="offset">
<div class="uk-overflow-auto uk-height-1-1"> <div class="uk-overflow-auto uk-height-1-1">
<ng-container *ngTemplateOutlet="right_column"></ng-container> <ng-container *ngTemplateOutlet="right_column"></ng-container>
@ -694,8 +694,8 @@
<!-- right box/ sidebar--> <!-- right box/ sidebar-->
<ng-container *ngIf="!showFeedback && resultLandingInfo && hasRightSidebarInfo"> <ng-container *ngIf="!showFeedback && resultLandingInfo && hasRightSidebarInfo">
<div id="landing-right-sidebar-switcher" uk-toggle href="#right-column-offcanvas" <div id="landing-right-sidebar-switcher" uk-toggle href="#right-column-offcanvas"
class="uk-offcanvas-switcher uk-flex uk-flex-center uk-flex-middle uk-hidden@m" class="uk-offcanvas-switcher uk-flex uk-flex-center uk-flex-middle uk-hidden@m"
(click)="rightSidebarOffcanvasClicked = true;"> (click)="rightSidebarOffcanvasClicked = true;">
<icon name="more" ratio="1.5" customClass="uk-text-primary" flex="true" visuallyHidden="sidebar"></icon> <icon name="more" ratio="1.5" customClass="uk-text-primary" flex="true" visuallyHidden="sidebar"></icon>
</div> </div>
<div id="right-column-offcanvas" class="uk-offcanvas" uk-offcanvas="flip: true; overlay: true;"> <div id="right-column-offcanvas" class="uk-offcanvas" uk-offcanvas="flip: true; overlay: true;">
@ -749,14 +749,14 @@
<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-->
<div *ngIf="resultLandingInfo.eoscSubjects?.length > 0 && properties.adminToolsPortalType == 'eosc' <div *ngIf="resultLandingInfo.eoscSubjects?.length > 0 && properties.adminToolsPortalType == 'eosc'
&& (!viewAll || viewAll=='egiNotebook')"> && (!viewAll || viewAll=='egiNotebook')">
<div class="uk-flex uk-flex-between uk-flex-middle uk-margin-small-bottom"> <div class="uk-flex uk-flex-between uk-flex-middle uk-margin-small-bottom">
<span class="uk-text-light-grey uk-text-nowrap uk-margin-small-right">Compatible EOSC Services</span> <span class="uk-text-light-grey uk-text-nowrap uk-margin-small-right">Compatible EOSC Services</span>
</div> </div>
<div class="uk-margin-small-bottom uk-flex"> <div class="uk-margin-small-bottom uk-flex">
<img src="assets/common-assets/eosc-logo.png" <img src="assets/common-assets/eosc-logo.png"
loading="lazy" alt="eosc_logo" style="width:27px; height:27px"> loading="lazy" alt="eosc_logo" style="width:27px; height:27px">
<div class="uk-margin-small-left uk-flex uk-flex-column uk-flex-center"> <div class="uk-margin-small-left uk-flex uk-flex-column uk-flex-center">
<div *ngFor="let subject of resultLandingInfo.eoscSubjects; let i=index" class="uk-text-truncate"> <div *ngFor="let subject of resultLandingInfo.eoscSubjects; let i=index" class="uk-text-truncate">
<a [href]="subject.link" target="_blank" class="custom-external">{{subject.value}}</a> <a [href]="subject.link" target="_blank" class="custom-external">{{subject.value}}</a>
@ -793,9 +793,131 @@
[properties]="properties" [entityType]="getTypeName()" [fields]="feedbackFields" [properties]="properties" [entityType]="getTypeName()" [fields]="feedbackFields"
[(showForm)]="showFeedback" [preSelectedField]="feedbackPreSelectedField"></feedback> [(showForm)]="showFeedback" [preSelectedField]="feedbackPreSelectedField"></feedback>
</div> </div>
<!-- Mobile view -->
<div class="uk-hidden@m uk-position-relative landing">
<div class="uk-container uk-section">
<div *ngIf="resultLandingInfo.hostedBy_collectedFrom && resultLandingInfo.hostedBy_collectedFrom.length > 0"
class="uk-margin-small-bottom uk-flex uk-flex-middle">
<icon [name]="resultLandingInfo.hostedBy_collectedFrom[0].accessRightIcon" flex="true" ratio="1"></icon>
<span class="uk-margin-xsmall-left uk-text-small uk-text-uppercase uk-text-bolder">{{resultLandingInfo.hostedBy_collectedFrom[0].accessRight}}</span>
</div>
<landing-header [properties]="properties" [title]="resultLandingInfo.title"
[subTitle]="resultLandingInfo.subtitle"
[authors]="resultLandingInfo.authors"
[underCuration]="resultLandingInfo.underCurationMessage"
[entityType]="getTypeName()" [types]="resultLandingInfo.types"
[date]="resultLandingInfo.dateofacceptance" [embargoEndDate]="resultLandingInfo.embargoEndDate"
[publisher]="resultLandingInfo.publisher" [journal]="resultLandingInfo.journal"
[languages]="resultLandingInfo.languages" [programmingLanguages]="resultLandingInfo.programmingLanguages">
</landing-header>
<div class="uk-text-small">
<!-- Identifiers -->
<div *ngIf="resultLandingInfo.identifiers && resultLandingInfo.identifiers.size > 0" class="uk-margin-small-top">
<showIdentifiers [identifiers]="resultLandingInfo.identifiers" [showViewAll]="true"></showIdentifiers>
</div>
<!-- SDGs -->
<div *ngIf="resultLandingInfo.sdg && resultLandingInfo.sdg.length > 0 && (!viewAll || viewAll=='sdg')" class="uk-margin-small-top">
<sdg [subjects]="resultLandingInfo.sdg" (viewAllClicked)="viewAll=$event" (feedbackClicked)="feedbackClicked('Sustainable Development Goals (SDGs)')"></sdg>
</div>
<!-- FOS -->
<div *ngIf="resultLandingInfo.fos && resultLandingInfo.fos.length > 0 && (!viewAll || viewAll=='fos')" class="uk-margin-small-top">
<fos [subjects]="resultLandingInfo.fos" (viewAllClicked)="viewAll=$event" (feedbackClicked)="feedbackClicked('Fields of Science and Technology (FOS)')"></fos>
</div>
</div>
<div class="uk-section uk-margin-top uk-text-large uk-text-empashis uk-text-bold">
<hr>
<ng-container>
<div class="uk-flex uk-flex-middle uk-flex-between">
<span>Summary</span>
<icon name="chevron_right" ratio="1.5" [flex]="true"></icon>
</div>
<hr>
</ng-container>
<ng-container *ngIf="resultLandingInfo.references && resultLandingInfo.references.length > 0">
<div class="uk-flex uk-flex-middle uk-flex-between">
<span>References</span>
<icon name="chevron_right" ratio="1.5" [flex]="true"></icon>
</div>
<hr>
</ng-container>
<ng-container *ngIf="resultLandingInfo.relatedResults?.length > 0">
<div class="uk-flex uk-flex-middle uk-flex-between">
<span>Related Research</span>
<icon name="chevron_right" ratio="1.5" [flex]="true"></icon>
</div>
<hr>
</ng-container>
<ng-container *ngIf="resultLandingInfo.bioentities && bioentitiesNum> 0">
<div class="uk-flex uk-flex-middle uk-flex-between">
<span>External Databases</span>
<icon name="chevron_right" ratio="1.5" [flex]="true"></icon>
</div>
<hr>
</ng-container>
<ng-container *ngIf="enermapsId && properties.enermapsURL">
<div class="uk-flex uk-flex-middle uk-flex-between">
<span>Enermaps Tool</span>
<icon name="chevron_right" ratio="1.5" [flex]="true"></icon>
</div>
<hr>
</ng-container>
<ng-container *ngIf="resultLandingInfo.eoscSubjects?.length > 0 && properties.adminToolsPortalType == 'eosc'
&& (!viewAll || viewAll=='egiNotebook')">
<div class="uk-flex uk-flex-middle uk-flex-between">
<span>Compatible EOSC Services</span>
<icon name="chevron_right" ratio="1.5" [flex]="true"></icon>
</div>
</ng-container>
<ng-container *ngIf="resultLandingInfo.fundedByProjects && resultLandingInfo.fundedByProjects.length > 0 && (!viewAll || viewAll=='fundedBy')">
<div class="uk-flex uk-flex-middle uk-flex-between">
<span>Funded by</span>
<icon name="chevron_right" ratio="1.5" [flex]="true"></icon>
</div>
<hr>
</ng-container>
<ng-container *ngIf="resultLandingInfo.contexts && resultLandingInfo.contexts.length > 0 && !noCommunities && (!viewAll || viewAll=='relatedTo')">
<div class="uk-flex uk-flex-middle uk-flex-between">
<span>Related to Research Communities</span>
<icon name="chevron_right" ratio="1.5" [flex]="true"></icon>
</div>
<hr>
</ng-container>
</div>
</div>
<div class="landing-action-bar-mobile uk-background-default">
<div class="uk-container uk-flex uk-flex-middle uk-flex-between uk-text-xsmall uk-text-meta">
<div>
<a class="uk-flex uk-flex-column uk-flex-middle uk-flex-center uk-link-reset">
<icon *ngIf="getTypeName().toLowerCase() == 'publication'" name="description" type="outlined" [flex]="true" ratio="2"></icon>
<icon *ngIf="getTypeName().toLowerCase() == 'research data'" name="database" type="outlined" [flex]="true" ratio="2"></icon>
<icon *ngIf="getTypeName().toLowerCase() == 'research software'" name="integration_instructions" type="outlined" [flex]="true" ratio="2"></icon>
<icon *ngIf="getTypeName().toLowerCase() == 'other research product'" name="apps" type="outlined" [flex]="true" ratio="2"></icon>
<icon *ngIf="getTypeName().toLowerCase() == 'project'" name="assignment_turned_in" type="outlined" [flex]="true" ratio="2"></icon>
<icon *ngIf="getTypeName().toLowerCase() == 'data source'" name="note_add" type="outlined" [flex]="true" ratio="2"></icon>
<icon *ngIf="getTypeName().toLowerCase() == 'organization'" name="corporate_fare" type="outlined" [flex]="true" ratio="2"></icon>
<span>{{getTypeName()}}</span>
</a>
</div>
<div *ngIf="resultLandingInfo && (resultLandingInfo.measure || hasAltMetrics)">
<a class="uk-flex uk-flex-column uk-flex-middle uk-flex-center uk-link-reset">
<icon name="bar_chart" type="outlined" [flex]="true" ratio="2"></icon>
<span>Metrics</span>
</a>
</div>
<div>
<a class="uk-flex uk-flex-column uk-flex-middle uk-flex-center uk-link-reset">
<icon name="pending" type="outlined" [flex]="true" ratio="2"></icon>
<span>Actions</span>
</a>
</div>
</div>
</div>
</div>
<!-- Other versions --> <!-- Other versions -->
<modal-alert *ngIf="resultLandingInfo && resultLandingInfo.deletedByInferenceIds" <modal-alert *ngIf="resultLandingInfo && resultLandingInfo.deletedByInferenceIds"
#AlertModalDeletedByInference large="true"> #AlertModalDeletedByInference large="true">
<deletedByInference *ngIf="type == 'publication' && deleteByInferenceOpened" <deletedByInference *ngIf="type == 'publication' && deleteByInferenceOpened"
[id]="resultLandingInfo.record['result']['header']['dri:objIdentifier']" [id]="resultLandingInfo.record['result']['header']['dri:objIdentifier']"
[ids]="resultLandingInfo.deletedByInferenceIds" [ids]="resultLandingInfo.deletedByInferenceIds"
@ -823,7 +945,7 @@
</modal-alert> </modal-alert>
<modal-alert *ngIf="resultLandingInfo" <modal-alert *ngIf="resultLandingInfo"
#addThisModal classBody="uk-flex uk-flex-center uk-flex-middle"> #addThisModal classBody="uk-flex uk-flex-center uk-flex-middle">
<addThis></addThis> <addThis></addThis>
</modal-alert> </modal-alert>
@ -854,9 +976,9 @@
class="uk-margin-bottom"> class="uk-margin-bottom">
<h6 *ngIf="header">{{header}}</h6> <h6 *ngIf="header">{{header}}</h6>
<div *ngIf="relatedClassFilters?.length > 1" class="uk-margin-medium-bottom" <div *ngIf="relatedClassFilters?.length > 1" class="uk-margin-medium-bottom"
input type="select" placeholder="Filter by relation" inputClass="flat x-small" input type="select" placeholder="Filter by relation" inputClass="flat x-small"
[options]="relatedClassFilters" [(value)]="relatedClassSelected" [options]="relatedClassFilters" [(value)]="relatedClassSelected"
(valueChange)="relatedClassChanged()"></div> (valueChange)="relatedClassChanged()"></div>
<results-and-pages <results-and-pages
[type]="openaireEntities.RESULTS" [type]="openaireEntities.RESULTS"