[Library|Trunk]
Search: -Entities Selection: add check if route is enabled -Delay in result types checkboxes to 2 s -Use breadcrumb component -add connect background -remove space between names in showAuthors component -Filters: -message about top 100 always visible -rename to view all -change css for search input -show 100 if results > 95 -view less under the 2nd list -Search bar: -select contains all avaliable entities not only search results - Landing pages: -correct issue with pmid in landing -correct issue with date in cite this -Hide Addthis: value in properties git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@58552 d315682c-612b-4755-9ff5-7f18f6832af3
This commit is contained in:
parent
221f37f360
commit
7f1862dbab
|
@ -3,7 +3,7 @@ import {HttpParams} from '@angular/common/http';
|
||||||
export class ConnectHelper {
|
export class ConnectHelper {
|
||||||
|
|
||||||
public static getCommunityFromDomain(domain: string): string{
|
public static getCommunityFromDomain(domain: string): string{
|
||||||
// domain = "beta.egi.openaire.eu"; //for testing
|
domain = "beta.ee.openaire.eu"; //for testing
|
||||||
if (domain.indexOf('openaire.eu') === -1) {
|
if (domain.indexOf('openaire.eu') === -1) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,18 +69,28 @@ import {Meta, Title} from "@angular/platform-browser";
|
||||||
<div></div>
|
<div></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-width-1-2@m uk-width-1-1@s">
|
<div class="uk-width-1-2@m uk-width-1-1@s">
|
||||||
<p class="uk-margin-auto-top uk-margin-remove-bottom uk-h5">
|
<!--<p class="uk-margin-auto-top uk-margin-remove-bottom uk-h5">
|
||||||
Start by <span class="uk-text-bold">searching</span> repositories and journals
|
Start by <span class="uk-text-bold">searching</span> repositories and journals
|
||||||
</p>
|
</p>-->
|
||||||
<div class="uk-margin">
|
<div class="uk-padding uk-padding-remove-vertical">
|
||||||
<form class="uk-search uk-search-default uk-width-xlarge@l uk-width-medium@m uk-width-auto">
|
<form class=" uk-grid uk-margin">
|
||||||
<!-- <span uk-search-icon class="uk-icon"></span>-->
|
<!-- <span uk-search-icon class="uk-icon"></span>-->
|
||||||
<button routerLinkActive="uk-link"
|
<!-- <button routerLinkActive="uk-link"-->
|
||||||
routerLink="{{depositRoute}}" [queryParams]="{keyword: keyword}" class="uk-search-icon uk-icon" uk-search-icon>
|
<!-- routerLink="{{depositRoute}}" [queryParams]="{keyword: keyword}" class="uk-search-icon uk-icon" uk-search-icon>-->
|
||||||
</button>
|
<!-- </button>-->
|
||||||
<input class="uk-search-input uk-input"
|
<input class="uk-search-input uk-input uk-width-expand uk-margin-small-right"
|
||||||
type="search" [(ngModel)]="keyword" name="keyword"
|
type="search" [(ngModel)]="keyword" name="keyword"
|
||||||
placeholder="{{searchPlaceHolder}}">
|
placeholder="{{searchPlaceHolder}}">
|
||||||
|
<div class="uk-padding-remove-left">
|
||||||
|
<button routerLinkActive="uk-link" routerLink="{{depositRoute}}" [queryParams]="{keyword: keyword}" class="uk-button"> Search
|
||||||
|
</button>
|
||||||
|
<div class="uk-padding-small">
|
||||||
|
<a [queryParams]="properties.environment!='development'?{}:routerHelper.createQueryParam('communityId',communityId)" routerLinkActive="router-link-active" [routerLink]="depositRoute"
|
||||||
|
type="submit" class=" ">
|
||||||
|
<span><span>Browse all </span><!--<span uk-icon="arrow-right"></span>--></span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-width-1-6 uk-text-right">
|
<div class="uk-width-1-6 uk-text-right">
|
||||||
|
@ -100,9 +110,20 @@ import {Meta, Title} from "@angular/platform-browser";
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
<a [queryParams]="properties.environment!='development'?{}:routerHelper.createQueryParam('communityId',communityId)" routerLinkActive="router-link-active" [routerLink]="depositRoute"
|
<!--<a [queryParams]="properties.environment!='development'?{}:routerHelper.createQueryParam('communityId',communityId)" routerLinkActive="router-link-active" [routerLink]="depositRoute"
|
||||||
type="submit" class="uk-button uk-button-large portal-button uk-padding uk-padding-remove-vertical">
|
type="submit" class="uk-button uk-button-large portal-button uk-padding uk-padding-remove-vertical">
|
||||||
<span><span>Browse all </span><span uk-icon="arrow-right"></span></span>
|
<span><span>Browse all </span><span uk-icon="arrow-right"></span></span>
|
||||||
|
</a>-->
|
||||||
|
<a *ngIf="zenodoInformation.shareInZenodoUrl" type="submit"
|
||||||
|
[queryParams]="properties.environment!='development'?{}:routerHelper.createQueryParam('communityId',communityId)"
|
||||||
|
routerLinkActive="router-link-active" [routerLink]="zenodoInformation.shareInZenodoUrl"
|
||||||
|
class="uk-button portal-button uk-padding uk-padding-remove-vertical uk-margin-medium-top uk-margin-bottom">
|
||||||
|
<span><span> Use related zenodo communities</span><span uk-icon="arrow-right"></span></span>
|
||||||
|
</a>
|
||||||
|
<a *ngIf="!zenodoInformation.shareInZenodoUrl" target="_blank" href="{{zenodoInformation.url}}" type="submit"
|
||||||
|
[class]="'uk-button uk-padding uk-padding-remove-vertical uk-margin-medium-top uk-margin-bottom' +
|
||||||
|
((communityId && communityId != 'openaire') ? ' portal-button' : ' uk-button-primary')">
|
||||||
|
<span><span>Deposit in Zenodo</span><span uk-icon="arrow-right"></span></span>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -84,7 +84,7 @@ export class CiteThisComponent {
|
||||||
}
|
}
|
||||||
if(this.result.dateofacceptance != undefined){
|
if(this.result.dateofacceptance != undefined){
|
||||||
citationData.issued = {};
|
citationData.issued = {};
|
||||||
var date:string = (this.result.dateofacceptance)+""; // transform to string in case it is an integer
|
var date:string = (this.result.dateofacceptance.getFullYear())+""; // transform to string in case it is an integer
|
||||||
var dateArray:string[] = (date && (date).indexOf('-') !== -1)?[date.split('-')[0]]:[date];
|
var dateArray:string[] = (date && (date).indexOf('-') !== -1)?[date.split('-')[0]]:[date];
|
||||||
if(dateArray.length < 3){
|
if(dateArray.length < 3){
|
||||||
// dateArray.push[1];
|
// dateArray.push[1];
|
||||||
|
|
|
@ -454,7 +454,7 @@ export class ParsingFunctions {
|
||||||
let identifiers = new Map<string, string[]>();
|
let identifiers = new Map<string, string[]>();
|
||||||
|
|
||||||
if (pid.hasOwnProperty("classname") && pid['classname'] != "") {
|
if (pid.hasOwnProperty("classname") && pid['classname'] != "") {
|
||||||
if (pid.classname == "doi" || pid.classname == "pmc" || pid.classname == "handle" || pid == "pmid") {
|
if (pid.classname == "doi" || pid.classname == "pmc" || pid.classname == "handle" || pid.classname == "pmid") {
|
||||||
if (!identifiers.has(pid.classname)) {
|
if (!identifiers.has(pid.classname)) {
|
||||||
identifiers.set(pid.classname, new Array<string>());
|
identifiers.set(pid.classname, new Array<string>());
|
||||||
}
|
}
|
||||||
|
@ -463,7 +463,7 @@ export class ParsingFunctions {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (let i = 0; i < pid.length; i++) {
|
for (let i = 0; i < pid.length; i++) {
|
||||||
if (pid[i].classname == "doi" || pid[i].classname == "pmc" || pid[i].classname == "handle" || pid == "pmid") {
|
if (pid[i].classname == "doi" || pid[i].classname == "pmc" || pid[i].classname == "handle" || pid[i].classname == "pmid") {
|
||||||
if (!identifiers.has(pid[i].classname)) {
|
if (!identifiers.has(pid[i].classname)) {
|
||||||
identifiers.set(pid[i].classname, new Array<string>());
|
identifiers.set(pid[i].classname, new Array<string>());
|
||||||
}
|
}
|
||||||
|
|
|
@ -498,7 +498,7 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Share -->
|
<!-- Share -->
|
||||||
<div [class.uk-hidden]="!addThis" class="uk-margin-top">
|
<div *ngIf="properties.showAddThis" [class.uk-hidden]="!addThis" class="uk-margin-top">
|
||||||
<div class="sideInfoTitle uk-margin-small-bottom">Share - Bookmark</div>
|
<div class="sideInfoTitle uk-margin-small-bottom">Share - Bookmark</div>
|
||||||
<addThis (event)="hideAddThis($event)"></addThis>
|
<addThis (event)="hideAddThis($event)"></addThis>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -101,19 +101,23 @@ export class EntitiesSelectionComponent {
|
||||||
if (this.properties) {
|
if (this.properties) {
|
||||||
// console.log(this.customFilter)
|
// console.log(this.customFilter)
|
||||||
this.config.getCommunityInformation(this.properties, (this.customFilter && this.customFilter.queryFieldName == "communityId") ? this.customFilter.valueId : this.properties.adminToolsCommunity).subscribe(data => {
|
this.config.getCommunityInformation(this.properties, (this.customFilter && this.customFilter.queryFieldName == "communityId") ? this.customFilter.valueId : this.properties.adminToolsCommunity).subscribe(data => {
|
||||||
var showEntity = {};
|
let showEntity = {};
|
||||||
for (var i = 0; i < data['entities'].length; i++) {
|
let showPage = {};
|
||||||
|
for (let i = 0; i < data['entities'].length; i++) {
|
||||||
|
|
||||||
showEntity["" + data['entities'][i]["pid"] + ""] = data['entities'][i]["isEnabled"];
|
showEntity["" + data['entities'][i]["pid"] + ""] = data['entities'][i]["isEnabled"];
|
||||||
}
|
}
|
||||||
this.showResearchOutcomes = showEntity["publication"] || showEntity["dataset"] || showEntity["software"] || showEntity["orp"];
|
for (let i = 0; i < data['pages'].length; i++) {
|
||||||
this.showPublications = showEntity["publication"];
|
showPage["" + data['pages'][i]["route"] + ""] = data['pages'][i]["isEnabled"];
|
||||||
this.showDatasets = showEntity["dataset"];
|
}
|
||||||
this.showSoftware = showEntity["software"];
|
this.showResearchOutcomes = showPage[this.properties.searchLinkToResults] && (showEntity["publication"] || showEntity["dataset"] || showEntity["software"] || showEntity["orp"]);
|
||||||
this.showOther = showEntity["orp"];
|
this.showPublications = showPage[this.properties.searchLinkToResults] && showEntity["publication"];
|
||||||
this.showProjects = showEntity["project"];
|
this.showDatasets = showPage[this.properties.searchLinkToResults] && showEntity["dataset"];
|
||||||
this.showOrganizations = showEntity["organization"];
|
this.showSoftware = showPage[this.properties.searchLinkToResults] && showEntity["software"];
|
||||||
this.showDataProviders = showEntity["datasource"];
|
this.showOther = showPage[this.properties.searchLinkToResults] && showEntity["orp"];
|
||||||
|
this.showProjects = showPage[this.properties.searchLinkToProjects] && showEntity["project"];
|
||||||
|
this.showOrganizations = showPage[this.properties.searchLinkToOrganizations] && showEntity["organization"];
|
||||||
|
this.showDataProviders = showPage[this.properties.searchLinkToDataProviders] && showEntity["datasource"];
|
||||||
|
|
||||||
if (this.customFilter && this.customFilter.queryFieldName == "communityId") {
|
if (this.customFilter && this.customFilter.queryFieldName == "communityId") {
|
||||||
this.showOrganizations = false;
|
this.showOrganizations = false;
|
||||||
|
|
|
@ -107,11 +107,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<div id="tm-main" class=" tm-middle">
|
<div id="tm-main" class=" tm-middle communityBackground">
|
||||||
<div uk-grid>
|
<div uk-grid>
|
||||||
<div class="tm-main uk-width-1-1@s uk-width-1-1@m uk-width-1-1@l uk-row-first ">
|
<div class="tm-main uk-width-1-1@s uk-width-1-1@m uk-width-1-1@l uk-row-first ">
|
||||||
<!-- TODO add breadcrumb here-->
|
<breadcrumbs *ngIf="showBreadcrumb" addClass="uk-margin-large-left uk-margin-remove-bottom uk-margin-small-top" [breadcrumbs]="breadcrumbs"></breadcrumbs>
|
||||||
<div *ngIf="showBreadcrumb" class=" uk-margin-large-left">Home > Search</div>
|
|
||||||
<div class="uk-container uk-container-large">
|
<div class="uk-container uk-container-large">
|
||||||
<div>
|
<div>
|
||||||
|
|
||||||
|
@ -359,7 +358,8 @@
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-width-expand@m uk-with-1-1@s">
|
<div class="uk-width-expand@m uk-with-1-1@s">
|
||||||
<div *ngIf="openaireLink"> <a class="uk-margin-top uk-button uk-button-text"
|
<div *ngIf="openaireLink && (searchUtils.totalResults > 0 || !loadPaging )"> <a
|
||||||
|
class="uk-margin-top uk-button uk-button-text"
|
||||||
[href]="openaireLink+this.routerHelper.createQueryParamsString(this.parameterNames, this.parameterValues)"
|
[href]="openaireLink+this.routerHelper.createQueryParamsString(this.parameterNames, this.parameterValues)"
|
||||||
target="_blank" >Results in OpenAIRE</a></div>
|
target="_blank" >Results in OpenAIRE</a></div>
|
||||||
<div class="uk-align-center uk-margin-remove-bottom">
|
<div class="uk-align-center uk-margin-remove-bottom">
|
||||||
|
|
|
@ -18,6 +18,7 @@ import {SearchFields} from "../../utils/properties/searchFields";
|
||||||
import {RefineResultsUtils} from "../../services/servicesUtils/refineResults.class";
|
import {RefineResultsUtils} from "../../services/servicesUtils/refineResults.class";
|
||||||
import {RangeFilter} from "../../utils/rangeFilter/rangeFilterHelperClasses.class";
|
import {RangeFilter} from "../../utils/rangeFilter/rangeFilterHelperClasses.class";
|
||||||
import {ZenodoInformationClass} from "../../deposit/utils/zenodoInformation.class";
|
import {ZenodoInformationClass} from "../../deposit/utils/zenodoInformation.class";
|
||||||
|
import {Breadcrumb} from "../../utils/breadcrumbs/breadcrumbs.component";
|
||||||
|
|
||||||
declare var UIkit: any;
|
declare var UIkit: any;
|
||||||
|
|
||||||
|
@ -92,7 +93,7 @@ export class NewSearchPageComponent {
|
||||||
public divContents = null;
|
public divContents = null;
|
||||||
public routerHelper: RouterHelper = new RouterHelper();
|
public routerHelper: RouterHelper = new RouterHelper();
|
||||||
public errorCodes: ErrorCodes = new ErrorCodes();
|
public errorCodes: ErrorCodes = new ErrorCodes();
|
||||||
|
breadcrumbs:Breadcrumb[] = [];
|
||||||
url = null;
|
url = null;
|
||||||
|
|
||||||
@Input() entitiesSelection:boolean = true;
|
@Input() entitiesSelection:boolean = true;
|
||||||
|
@ -133,6 +134,12 @@ export class NewSearchPageComponent {
|
||||||
|
|
||||||
this.searchUtils.baseUrl = "/" + this.searchUtils.baseUrl;
|
this.searchUtils.baseUrl = "/" + this.searchUtils.baseUrl;
|
||||||
this.seoService.createLinkForCanonicalURL(this.properties.baseLink + this.router.url, false);
|
this.seoService.createLinkForCanonicalURL(this.properties.baseLink + this.router.url, false);
|
||||||
|
this.breadcrumbs.push({name: 'home', route: '/'});
|
||||||
|
if(this.simpleView) {
|
||||||
|
this.breadcrumbs.push( {name: "Search", route: this.simpleSearchLink});
|
||||||
|
}else if(!this.simpleView && this.advancedSearchLink) {
|
||||||
|
this.breadcrumbs.push({name: "Advanced Search", route: this.advancedSearchLink});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,7 @@ import {SearchResultsModule} from "./searchResults.module";
|
||||||
import {SearchResultsInDepositModule} from "../../deposit/searchResultsInDeposit.module";
|
import {SearchResultsInDepositModule} from "../../deposit/searchResultsInDeposit.module";
|
||||||
import {AdvancedSearchFormModule} from "./advancedSearchForm.module";
|
import {AdvancedSearchFormModule} from "./advancedSearchForm.module";
|
||||||
import {QuickSelectionsModule} from "./quick-selections.module";
|
import {QuickSelectionsModule} from "./quick-selections.module";
|
||||||
|
import {BreadcrumbsModule} from "../../utils/breadcrumbs/breadcrumbs.module";
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [
|
imports: [
|
||||||
|
@ -33,7 +34,7 @@ import {QuickSelectionsModule} from "./quick-selections.module";
|
||||||
SearchPagingModule, SearchResultsPerPageModule, SearchSortingModule, SearchDownloadModule, ModalModule,
|
SearchPagingModule, SearchResultsPerPageModule, SearchSortingModule, SearchDownloadModule, ModalModule,
|
||||||
SearchFilterModule, RangeFilterModule,
|
SearchFilterModule, RangeFilterModule,
|
||||||
PiwikServiceModule, HelperModule, Schema2jsonldModule, SEOServiceModule, SearchResultsModule,
|
PiwikServiceModule, HelperModule, Schema2jsonldModule, SEOServiceModule, SearchResultsModule,
|
||||||
SearchResultsInDepositModule, AdvancedSearchFormModule, QuickSelectionsModule
|
SearchResultsInDepositModule, AdvancedSearchFormModule, QuickSelectionsModule, BreadcrumbsModule
|
||||||
],
|
],
|
||||||
declarations: [
|
declarations: [
|
||||||
NewSearchPageComponent
|
NewSearchPageComponent
|
||||||
|
|
|
@ -123,7 +123,7 @@ export class QuickSelectionsComponent implements OnChanges {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
this.resultTypesObs = this.clicks.pipe(
|
this.resultTypesObs = this.clicks.pipe(
|
||||||
debounceTime(1000)
|
debounceTime(2000)
|
||||||
).subscribe(e =>{this.actuallyChanged()} );
|
).subscribe(e =>{this.actuallyChanged()} );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,19 +56,24 @@
|
||||||
<a
|
<a
|
||||||
[class]="((isDisabled)?'uk-disabled uk-link-muted ':' portal-link ') + ' uk-margin-small-top'"
|
[class]="((isDisabled)?'uk-disabled uk-link-muted ':' portal-link ') + ' uk-margin-small-top'"
|
||||||
[attr.uk-toggle]="'target: #toggle-'+filter.filterId" (click)="toggle()">
|
[attr.uk-toggle]="'target: #toggle-'+filter.filterId" (click)="toggle()">
|
||||||
<span *ngIf="!isOpen">+ View more</span>
|
<span *ngIf="!isOpen">+ View all</span>
|
||||||
<span *ngIf="isOpen">- View less</span>
|
<!-- <span *ngIf="isOpen">- View less</span>-->
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<div hidden [id]="'toggle-'+filter.filterId" class="uk-text-small uk-margin-small-bottom">
|
<div hidden [id]="'toggle-'+filter.filterId" class="uk-text-small uk-margin-small-bottom">
|
||||||
<div class="">
|
<div class="">
|
||||||
<span *ngIf="filter.values.length >= 99">* only the Top 100 values are shown</span>
|
<span class="uk-text-meta uk-margin-small-left">Top 100 values are
|
||||||
<input class="uk-input uk-margin-small-bottom uk-width-1-1 " name="filter-keyword" placeholder="Search for {{filter.title}}" type="text" [(ngModel)]="keyword">
|
shown in the filters</span>
|
||||||
|
<div class="uk-grid uk-margin-small-left uk-flex uk-flex-bottom">
|
||||||
|
<input class="uk-input uk-margin-small-top uk-form-small uk-width-2-3@m uk-width-3-5@s text-input-box "
|
||||||
|
name="filter-keyword"
|
||||||
|
placeholder="Search..." type="text" [(ngModel)]="keyword">
|
||||||
|
|
||||||
<span *ngIf = "showResultCount === true" class="uk-flex-inline uk-flex-middle uk-width-5-6@m uk-width-1-1@s uk-align-right uk-margin-small-bottom">
|
<span *ngIf = "showResultCount === true"
|
||||||
|
class="uk-width-1-3@m uk-width-2-5@s uk-padding-small uk-padding-remove-vertical uk-padding-remove-right">
|
||||||
<span class="uk-width-1-4 uk-text-muted"> Sort by:</span>
|
<span class="uk-width-1-4 uk-text-muted"> Sort by:</span>
|
||||||
<select [(ngModel)]="sortBy"
|
<select [(ngModel)]="sortBy"
|
||||||
class=" uk-width-expand uk-select uk-hidden@m"
|
class=" uk-width-expand uk-select uk-hidden@m uk-form-small"
|
||||||
id="form-horizontal-select" name="select_order">
|
id="form-horizontal-select" name="select_order">
|
||||||
<option value="num">Results number</option>
|
<option value="num">Results number</option>
|
||||||
<option value="name">Name</option>
|
<option value="name">Name</option>
|
||||||
|
@ -82,6 +87,7 @@
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="uk-modal-body uk-overflow-auto uk-height-max-small uk-padding-remove
|
<div class="uk-modal-body uk-overflow-auto uk-height-max-small uk-padding-remove
|
||||||
uk-margin-small-left uk-margin-small-right uk-margin-small-top uk-width-1-1">
|
uk-margin-small-left uk-margin-small-right uk-margin-small-top uk-width-1-1">
|
||||||
|
@ -129,10 +135,10 @@
|
||||||
</ng-container>
|
</ng-container>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- <a [class]="(isDisabled)?'uk-disabled uk-link-muted ':' portal-link '"-->
|
<a [class]="(isDisabled)?'uk-disabled uk-link-muted ':' portal-link '"
|
||||||
<!-- [attr.uk-toggle]="'target: #toggle-'+filter.filterId" (click)="toggle()">-->
|
[attr.uk-toggle]="'target: #toggle-'+filter.filterId" (click)="toggle()">
|
||||||
<!-- <span *ngIf="isOpen">- View less</span>-->
|
<span *ngIf="isOpen">- View less</span>
|
||||||
<!-- </a>-->
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -32,7 +32,7 @@ export class SearchFilterComponent {
|
||||||
ngOnInit() {}
|
ngOnInit() {}
|
||||||
|
|
||||||
public _formatTitle(title,length){
|
public _formatTitle(title,length){
|
||||||
return (((title+" ("+length+")").length >this._maxCharacters)?(title.substring(0,(this._maxCharacters - (" ("+length+")").length - ('...').length))+"..."):title+" ("+length+")")
|
return (((title+" ("+length+")").length >this._maxCharacters)?(title.substring(0,(this._maxCharacters - (" ("+length+")").length - ('...').length))+"..."):title+" ("+(length>95?"100":length)+")")
|
||||||
}
|
}
|
||||||
public _formatName(value){
|
public _formatName(value){
|
||||||
//let maxLineLength = 24;
|
//let maxLineLength = 24;
|
||||||
|
|
|
@ -55,7 +55,8 @@
|
||||||
</div>
|
</div>
|
||||||
</ng-template>
|
</ng-template>
|
||||||
|
|
||||||
<div class="image-front-topbar uk-section-default uk-position-relative" uk-scrollspy="{"target":"[uk-scrollspy-class]","cls":"uk-animation-fade","delay":false}" tm-header-transparent="light">
|
<div *ngIf="!includeOnlyResultsAndFilter" class="image-front-topbar uk-section-default uk-position-relative"
|
||||||
|
uk-scrollspy="{"target":"[uk-scrollspy-class]","cls":"uk-animation-fade","delay":false}" tm-header-transparent="light">
|
||||||
<div style=" min-height: 350px;" [class]="' uk-background-norepeat uk-background-cover uk-background-bottom-center uk-section uk-padding-remove-bottom uk-flex uk-flex-middle uk-background-fixed '+searchFormClass">
|
<div style=" min-height: 350px;" [class]="' uk-background-norepeat uk-background-cover uk-background-bottom-center uk-section uk-padding-remove-bottom uk-flex uk-flex-middle uk-background-fixed '+searchFormClass">
|
||||||
<div class="uk-position-cover" style="/*background-color: rgba(255, 255, 255, 0.37);*/"></div>
|
<div class="uk-position-cover" style="/*background-color: rgba(255, 255, 255, 0.37);*/"></div>
|
||||||
<div class="uk-container">
|
<div class="uk-container">
|
||||||
|
@ -106,10 +107,10 @@
|
||||||
</div>
|
</div>
|
||||||
<schema2jsonld *ngIf="url" [URL]="url" type="search" [name]=pageTitle [searchAction]=false></schema2jsonld>
|
<schema2jsonld *ngIf="url" [URL]="url" type="search" [name]=pageTitle [searchAction]=false></schema2jsonld>
|
||||||
|
|
||||||
<div id="tm-main" class=" uk-section uk-padding-remove-top tm-middle" >
|
<div id="tm-main" class=" uk-section uk-padding-remove-top tm-middle communityBackground" >
|
||||||
<div uk-grid>
|
<div uk-grid>
|
||||||
<div class="tm-main uk-width-1-1@s uk-width-1-1@m uk-width-1-1@l uk-row-first ">
|
<div class="tm-main uk-width-1-1@s uk-width-1-1@m uk-width-1-1@l uk-row-first ">
|
||||||
|
<breadcrumbs *ngIf="showBreadcrumb" addClass="uk-margin-large-left uk-margin-remove-bottom uk-margin-small-top" [breadcrumbs]="breadcrumbs"></breadcrumbs>
|
||||||
<div class="uk-container uk-container-large">
|
<div class="uk-container uk-container-large">
|
||||||
<helper *ngIf="pageContents && pageContents['top'] && pageContents['top'].length > 0" [texts]="pageContents['top']"></helper>
|
<helper *ngIf="pageContents && pageContents['top'] && pageContents['top'].length > 0" [texts]="pageContents['top']"></helper>
|
||||||
<div class="uk-width-2-3@m uk-width-2-3@l uk-width-1-1@s">
|
<div class="uk-width-2-3@m uk-width-2-3@l uk-width-1-1@s">
|
||||||
|
@ -141,13 +142,14 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="uk-grid uk-width-1-1 uk-margin-top">
|
<div class="uk-grid uk-width-1-1 uk-margin-top">
|
||||||
<div *ngIf="filters.length > 0" class="uk-width-1-4@m search-filters uk-visible@m ">
|
<div *ngIf="filters.length > 0" class="uk-width-1-5@m search-filters uk-visible@m ">
|
||||||
<ng-container *ngTemplateOutlet="filters_column; context: {}" class=""></ng-container>
|
<ng-container *ngTemplateOutlet="filters_column; context: {}" class=""></ng-container>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="uk-width-expand@m uk-width-1-1@s uk-first-column custom-dataTable-content" >
|
<div class="uk-width-expand@m uk-width-1-1@s uk-first-column custom-dataTable-content" >
|
||||||
<div *ngIf="openaireLink"> <a class=" uk-button uk-button-text" [href]=openaireLink target="_blank"
|
<div *ngIf="openaireLink && (searchUtils.totalResults > 0 || !disableForms )">
|
||||||
>Results in OpenAIRE</a></div>
|
<a class="uk-button uk-button-text" [href]=openaireLink target="_blank">Results in OpenAIRE</a>
|
||||||
|
</div>
|
||||||
<div *ngIf="searchUtils.totalResults > 0" class="uk-align-center uk-margin-remove-bottom ">
|
<div *ngIf="searchUtils.totalResults > 0" class="uk-align-center uk-margin-remove-bottom ">
|
||||||
<div class="uk-grid">
|
<div class="uk-grid">
|
||||||
<div class="uk-width-expand@m uk-grid uk-grid-medium uk-margin-small-bottom">
|
<div class="uk-width-expand@m uk-grid uk-grid-medium uk-margin-small-bottom">
|
||||||
|
|
|
@ -18,6 +18,7 @@ import {ErrorCodes} from '../../utils/properties/errorCode
|
||||||
import {PiwikService} from '../../utils/piwik/piwik.service';
|
import {PiwikService} from '../../utils/piwik/piwik.service';
|
||||||
import { SEOService } from '../../sharedComponents/SEO/SEO.service';
|
import { SEOService } from '../../sharedComponents/SEO/SEO.service';
|
||||||
import {HelperService} from "../../utils/helper/helper.service";
|
import {HelperService} from "../../utils/helper/helper.service";
|
||||||
|
import {Breadcrumb} from "../../utils/breadcrumbs/breadcrumbs.component";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'search-page-table',
|
selector: 'search-page-table',
|
||||||
|
@ -77,6 +78,10 @@ export class SearchPageTableViewComponent implements OnInit, AfterViewInit {
|
||||||
public pageContents = null;
|
public pageContents = null;
|
||||||
@Input() customFilter: SearchCustomFilter = null;
|
@Input() customFilter: SearchCustomFilter = null;
|
||||||
@Input() enableEntitySelection: boolean = false;
|
@Input() enableEntitySelection: boolean = false;
|
||||||
|
@Input() includeOnlyResultsAndFilter:boolean = false;
|
||||||
|
@Input() showBreadcrumb:boolean = false;
|
||||||
|
breadcrumbs:Breadcrumb[] = [];
|
||||||
|
|
||||||
constructor (private route: ActivatedRoute,
|
constructor (private route: ActivatedRoute,
|
||||||
private router: Router,
|
private router: Router,
|
||||||
private location: Location,
|
private location: Location,
|
||||||
|
@ -110,6 +115,7 @@ export class SearchPageTableViewComponent implements OnInit, AfterViewInit {
|
||||||
var description = "Openaire, search, repositories, open access, type, content provider, funder, project, " + this.type + "," +this.pageTitle;
|
var description = "Openaire, search, repositories, open access, type, content provider, funder, project, " + this.type + "," +this.pageTitle;
|
||||||
this.updateDescription(description);
|
this.updateDescription(description);
|
||||||
this.seoService.createLinkForCanonicalURL(this.properties.baseLink+this.router.url,false);
|
this.seoService.createLinkForCanonicalURL(this.properties.baseLink+this.router.url,false);
|
||||||
|
this.breadcrumbs.push({name: 'home', route: '/'}, {name: this.pageTitle, route: this.router.url});
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@ import { SEOServiceModule } from '../../sharedComponents/SEO/SEOService.module';
|
||||||
import { SearchDataproviderMapModule } from './searchDataproviderMap.module';
|
import { SearchDataproviderMapModule } from './searchDataproviderMap.module';
|
||||||
import {AdvancedSearchFormModule} from "./advancedSearchForm.module";
|
import {AdvancedSearchFormModule} from "./advancedSearchForm.module";
|
||||||
import {EntitiesSelectionModule} from "./entitiesSelection.module";
|
import {EntitiesSelectionModule} from "./entitiesSelection.module";
|
||||||
|
import {BreadcrumbsModule} from "../../utils/breadcrumbs/breadcrumbs.module";
|
||||||
|
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
|
@ -33,7 +34,7 @@ import {EntitiesSelectionModule} from "./entitiesSelection.module";
|
||||||
CommonModule, FormsModule, RouterModule, SearchFormModule, SearchResultsModule, LoadingModalModule,
|
CommonModule, FormsModule, RouterModule, SearchFormModule, SearchResultsModule, LoadingModalModule,
|
||||||
ReportsServiceModule, SearchPagingModule, SearchDownloadModule, ModalModule, PagingModule,
|
ReportsServiceModule, SearchPagingModule, SearchDownloadModule, ModalModule, PagingModule,
|
||||||
DataTablesModule, SearchFilterModule, PiwikServiceModule, HelperModule, ErrorMessagesModule,
|
DataTablesModule, SearchFilterModule, PiwikServiceModule, HelperModule, ErrorMessagesModule,
|
||||||
Schema2jsonldModule, SEOServiceModule, SearchResultsPerPageModule, SearchDataproviderMapModule, AdvancedSearchFormModule, EntitiesSelectionModule
|
Schema2jsonldModule, SEOServiceModule, SearchResultsPerPageModule, SearchDataproviderMapModule, AdvancedSearchFormModule, EntitiesSelectionModule, BreadcrumbsModule
|
||||||
],
|
],
|
||||||
declarations: [
|
declarations: [
|
||||||
SearchPageTableViewComponent
|
SearchPageTableViewComponent
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
<div *ngIf="enableSearch && isEnabled([searchRoute], showPage)"
|
<div *ngIf="enableSearch && isEnabled([searchRoute], showPage)"
|
||||||
class=" uk-width-large ">
|
class=" uk-width-large ">
|
||||||
<search-bar [searchPlaceHolder]="searchPlaceHolder"
|
<search-bar [searchPlaceHolder]="searchPlaceHolder"
|
||||||
[searchRoute]="searchRoute" [properties]="properties"></search-bar>
|
[searchRoute]="searchRoute" [properties]="properties" [communityId]="communityId"></search-bar>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-navbar-center">
|
<div class="uk-navbar-center">
|
||||||
|
@ -152,7 +152,7 @@
|
||||||
<div *ngIf="enableSearch && isEnabled([searchRoute], showPage)"
|
<div *ngIf="enableSearch && isEnabled([searchRoute], showPage)"
|
||||||
class=" uk-margin-left uk-width-xlarge ">
|
class=" uk-margin-left uk-width-xlarge ">
|
||||||
<search-bar [searchPlaceHolder]="searchPlaceHolder"
|
<search-bar [searchPlaceHolder]="searchPlaceHolder"
|
||||||
[searchRoute]="searchRoute" [properties]="properties"></search-bar>
|
[searchRoute]="searchRoute" [properties]="properties" [communityId]="communityId"></search-bar>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-navbar-left uk-visible@m uk-hidden@l ">
|
<div class="uk-navbar-left uk-visible@m uk-hidden@l ">
|
||||||
|
@ -172,7 +172,7 @@
|
||||||
<div *ngIf="enableSearch && isEnabled([searchRoute], showPage)"
|
<div *ngIf="enableSearch && isEnabled([searchRoute], showPage)"
|
||||||
class="uk-width-large ">
|
class="uk-width-large ">
|
||||||
<search-bar [searchPlaceHolder]="searchPlaceHolder"
|
<search-bar [searchPlaceHolder]="searchPlaceHolder"
|
||||||
[searchRoute]="searchRoute" [properties]="properties"></search-bar>
|
[searchRoute]="searchRoute" [properties]="properties" [communityId]="communityId" ></search-bar>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
[properties]="properties"
|
[properties]="properties"
|
||||||
(selectionChange)=" entityChanged($event)"
|
(selectionChange)=" entityChanged($event)"
|
||||||
[customFilter]="customFilter"
|
[customFilter]="customFilter"
|
||||||
[onlyresults]="true" matPanelClass="navbarMatSelectPanelClass"
|
[onlyresults]="false" matPanelClass="navbarMatSelectPanelClass"
|
||||||
[onChangeNavigate]="false" ></entities-selection>
|
[onChangeNavigate]="false" ></entities-selection>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
@ -29,4 +29,6 @@
|
||||||
<button (click)="keywordChanged()" type="submit"
|
<button (click)="keywordChanged()" type="submit"
|
||||||
class="uk-icon-button uk-icon portal-button uk-padding-remove-left uk-margin-small-left uk-margin-small-top"><svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" data-svg="search"><circle fill="none" stroke="#000" stroke-width="1.1" cx="9" cy="9" r="7"></circle><path fill="none" stroke="#000" stroke-width="1.1" d="M14,14 L18,18 L14,14 Z"></path></svg>
|
class="uk-icon-button uk-icon portal-button uk-padding-remove-left uk-margin-small-left uk-margin-small-top"><svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" data-svg="search"><circle fill="none" stroke="#000" stroke-width="1.1" cx="9" cy="9" r="7"></circle><path fill="none" stroke="#000" stroke-width="1.1" d="M14,14 L18,18 L14,14 Z"></path></svg>
|
||||||
</button>
|
</button>
|
||||||
|
<a *ngIf="advancedSearchLink" class="portal-link uk-margin-top uk-padding-remove-left uk-margin-small-left"
|
||||||
|
routerLinkActive="router-link-active" [routerLink]="advancedSearchLink"> Advanced search</a>
|
||||||
</form>
|
</form>
|
||||||
|
|
|
@ -6,11 +6,6 @@ import {SearchCustomFilter} from "../../searchPages/searchUtils/searchUtils.clas
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'search-bar',
|
selector: 'search-bar',
|
||||||
templateUrl: 'searchBar.component.html',
|
templateUrl: 'searchBar.component.html',
|
||||||
styles:[`
|
|
||||||
.mat-select-panel-wrap {
|
|
||||||
z-index: 2001
|
|
||||||
}
|
|
||||||
`]
|
|
||||||
|
|
||||||
})
|
})
|
||||||
export class SearchBarComponent {
|
export class SearchBarComponent {
|
||||||
|
@ -22,8 +17,11 @@ export class SearchBarComponent {
|
||||||
keyword: string = "";
|
keyword: string = "";
|
||||||
entityType = "all";
|
entityType = "all";
|
||||||
enableSearchbar:boolean = true;
|
enableSearchbar:boolean = true;
|
||||||
@Input() customFilter: SearchCustomFilter = null;
|
customFilter: SearchCustomFilter = null;
|
||||||
|
@Input() communityId;
|
||||||
|
@Input() onlyresults:boolean=false;
|
||||||
parameters = {};
|
parameters = {};
|
||||||
|
advancedSearchLink = null;
|
||||||
constructor(private router: Router,
|
constructor(private router: Router,
|
||||||
private route: ActivatedRoute ) {
|
private route: ActivatedRoute ) {
|
||||||
}
|
}
|
||||||
|
@ -31,60 +29,53 @@ export class SearchBarComponent {
|
||||||
ngOnInit() {
|
ngOnInit() {
|
||||||
|
|
||||||
// this.activeRouteEnabled = false;
|
// this.activeRouteEnabled = false;
|
||||||
|
if(this.communityId){
|
||||||
|
this.customFilter = new SearchCustomFilter("Community", "communityId", this.communityId, "");
|
||||||
|
}
|
||||||
this.route.queryParams.subscribe(params => {
|
this.route.queryParams.subscribe(params => {
|
||||||
this.parameters = Object.assign({}, params);
|
this.parameters = Object.assign({}, params);
|
||||||
this.entityType = "all";
|
this.entityType = "all";
|
||||||
|
if(this.onlyresults) {
|
||||||
if (params["type"] && params["type"].length > 0) {
|
if (params["type"] && params["type"].length > 0) {
|
||||||
let types= params["type"].split(",");
|
let types = params["type"].split(",");
|
||||||
if(types.length == 1){
|
if (types.length == 1) {
|
||||||
if(types.indexOf("publications")!=-1 ){
|
if (types.indexOf("publications") != -1) {
|
||||||
this.entityType = "publications";
|
this.entityType = "publications";
|
||||||
}else if(types.indexOf("datasets")!=-1 ){
|
} else if (types.indexOf("datasets") != -1) {
|
||||||
this.entityType = "datasets";
|
this.entityType = "datasets";
|
||||||
}else if(types.indexOf("software")!=-1 ){
|
} else if (types.indexOf("software") != -1) {
|
||||||
this.entityType = "software";
|
this.entityType = "software";
|
||||||
}else if(types.indexOf("other")!=-1 ){
|
} else if (types.indexOf("other") != -1) {
|
||||||
this.entityType = "other";
|
this.entityType = "other";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(this.getCurrentRoute() == "/search/advanced/research-outcomes" ){
|
}else{
|
||||||
|
let currentRoute= this.getCurrentRoute();
|
||||||
|
if(currentRoute== this.properties.searchLinkToProjects){
|
||||||
|
this.entityType = "project";
|
||||||
|
}else if(currentRoute== this.properties.searchLinkToDataProviders){
|
||||||
|
this.entityType = "dataprovider";
|
||||||
|
}else if(currentRoute== this.properties.searchLinkToOrganizations){
|
||||||
|
this.entityType = "organization";
|
||||||
|
}else{
|
||||||
|
this.entityType = "result";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(this.getCurrentRoute() == this.properties.searchLinkToAdvancedResults){
|
||||||
this.enableSearchbar = false;
|
this.enableSearchbar = false;
|
||||||
}else{
|
}else{
|
||||||
this.enableSearchbar = true;
|
this.enableSearchbar = true;
|
||||||
}
|
}
|
||||||
// this.initialize();
|
if(this.entityType == "result"){
|
||||||
|
this.advancedSearchLink = this.properties.searchLinkToAdvancedResults;
|
||||||
|
}else{
|
||||||
|
this.advancedSearchLink = null;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
ngOnDestroy() {
|
|
||||||
this.sub.unsubscribe();
|
|
||||||
}
|
|
||||||
|
|
||||||
initialize() {
|
|
||||||
this.activeRouteEnabled = false;
|
|
||||||
this.isAuthorized = Session.isClaimsCurator(this.user) || Session.isPortalAdministrator(this.user);
|
|
||||||
/!*if (this.properties.adminToolsAPIURL && this.communityId) {
|
|
||||||
this.config.getCommunityInformation(this.properties, this.communityId).subscribe(data => {
|
|
||||||
for (var i = 0; i < data['entities'].length; i++) {
|
|
||||||
|
|
||||||
this.showEntity["" + data['entities'][i]["pid"] + ""] = data['entities'][i]["isEnabled"];
|
|
||||||
}
|
|
||||||
for (var i = 0; i < data['pages'].length; i++) {
|
|
||||||
this.showPage[data['pages'][i]["route"]] = data['pages'][i]["isEnabled"];
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
},
|
|
||||||
error => {
|
|
||||||
this.handleError("Error getting community information (e.g. pages,entities) for community with id: " + this.communityId, error);
|
|
||||||
});
|
|
||||||
}*!/
|
|
||||||
|
|
||||||
}*/
|
|
||||||
|
|
||||||
isEnabled(required, enabled) {
|
isEnabled(required, enabled) {
|
||||||
if (!required) {
|
if (!required) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -96,27 +87,25 @@ export class SearchBarComponent {
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private handleError(message: string, error) {
|
|
||||||
console.error("NavigationBar (component): " + message, error);
|
|
||||||
}
|
|
||||||
|
|
||||||
getCurrentRoute() {
|
getCurrentRoute() {
|
||||||
return this.router.url.split('?')[0];
|
return this.router.url.split('?')[0];
|
||||||
}
|
}
|
||||||
entityChanged($event){
|
entityChanged($event){
|
||||||
this.entityType = $event.entity;
|
this.entityType = $event.entity;
|
||||||
this.searchRoute = $event.simpleUrl;
|
this.searchRoute = $event.simpleUrl;
|
||||||
|
if(!this.onlyresults && this.entityType == "result") {
|
||||||
// this.selectedEntityAdvancedUrl = $event.advancedUrl;
|
this.parameters["qf"] = true;
|
||||||
// check if it is search or not
|
}
|
||||||
//no search page
|
if(this.entityType == "result"){
|
||||||
|
this.advancedSearchLink = this.properties.searchLinkToAdvancedResults;
|
||||||
|
}else{
|
||||||
|
this.advancedSearchLink = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
keywordChanged(){
|
keywordChanged(){
|
||||||
// this.parameters = {};
|
if(!this.onlyresults) {
|
||||||
|
this.parameters = {};
|
||||||
|
}
|
||||||
if ( this.keyword.length > 0) {
|
if ( this.keyword.length > 0) {
|
||||||
this.parameters["fv0"] = this.keyword;
|
this.parameters["fv0"] = this.keyword;
|
||||||
this.parameters["f0"] = "q";
|
this.parameters["f0"] = "q";
|
||||||
|
@ -124,7 +113,7 @@ export class SearchBarComponent {
|
||||||
delete this.parameters['fv0'];
|
delete this.parameters['fv0'];
|
||||||
delete this.parameters['f0'];
|
delete this.parameters['f0'];
|
||||||
}
|
}
|
||||||
if(this.entityType != "all"){
|
if(this.onlyresults && this.entityType != "all"){
|
||||||
this.parameters["type"] = this.entityType;
|
this.parameters["type"] = this.entityType;
|
||||||
}else{
|
}else{
|
||||||
delete this.parameters['type'];
|
delete this.parameters['type'];
|
||||||
|
@ -133,7 +122,6 @@ export class SearchBarComponent {
|
||||||
if(!this.parameters["qf"]) {
|
if(!this.parameters["qf"]) {
|
||||||
this.parameters["qf"] = true;
|
this.parameters["qf"] = true;
|
||||||
}
|
}
|
||||||
console.log(this.parameters);
|
|
||||||
this.router.navigate([this.searchRoute], {queryParams: this.parameters} );
|
this.router.navigate([this.searchRoute], {queryParams: this.parameters} );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,12 +14,12 @@ import {AlertModal} from "../modal/alert";
|
||||||
<span *ngFor="let author of authors.slice(0,numberOfAuthors) let i=index">
|
<span *ngFor="let author of authors.slice(0,numberOfAuthors) let i=index">
|
||||||
<span *ngIf="!author.orcid || (properties.environment == 'production') || !testBrowser"
|
<span *ngIf="!author.orcid || (properties.environment == 'production') || !testBrowser"
|
||||||
[class.uk-text-small]="small">
|
[class.uk-text-small]="small">
|
||||||
{{author.fullName}}
|
{{author.fullName + "; "}}
|
||||||
</span>
|
</span>
|
||||||
<a *ngIf="author.orcid && (properties.environment != 'production') && testBrowser">
|
<a *ngIf="author.orcid && (properties.environment != 'production') && testBrowser">
|
||||||
<img src="assets/common-assets/common/ORCIDiD_icon16x16.png" alt="">{{" "}}
|
<img src="assets/common-assets/common/ORCIDiD_icon16x16.png" alt="">{{" "}}
|
||||||
<span [class.uk-text-small]="small">
|
<span [class.uk-text-small]="small">
|
||||||
{{author.fullName}}
|
{{author.fullName + "; "}}
|
||||||
</span>
|
</span>
|
||||||
</a>
|
</a>
|
||||||
<div *ngIf="author.orcid && (properties.environment != 'production')"
|
<div *ngIf="author.orcid && (properties.environment != 'production')"
|
||||||
|
@ -57,7 +57,6 @@ import {AlertModal} from "../modal/alert";
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<span>;{{" "}}</span>
|
|
||||||
</span>
|
</span>
|
||||||
<span *ngIf="numberOfAuthors == authorsLimit && authors.length > authorsLimit"> ... </span>
|
<span *ngIf="numberOfAuthors == authorsLimit && authors.length > authorsLimit"> ... </span>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -8,7 +8,7 @@ export interface Breadcrumb {
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'breadcrumbs',
|
selector: 'breadcrumbs',
|
||||||
template: `
|
template: `
|
||||||
<ul class="uk-breadcrumb" [class.uk-light]="light">
|
<ul [class]="'uk-breadcrumb '+addClass" [class.uk-light]="light">
|
||||||
<li *ngFor="let breadcrumb of breadcrumbs">
|
<li *ngFor="let breadcrumb of breadcrumbs">
|
||||||
<a class="uk-text-capitalize" *ngIf="breadcrumb.route" [routerLink]="breadcrumb.route">{{breadcrumb.name}}</a>
|
<a class="uk-text-capitalize" *ngIf="breadcrumb.route" [routerLink]="breadcrumb.route">{{breadcrumb.name}}</a>
|
||||||
<span class="uk-text-capitalize" *ngIf="!breadcrumb.route">{{breadcrumb.name}}</span>
|
<span class="uk-text-capitalize" *ngIf="!breadcrumb.route">{{breadcrumb.name}}</span>
|
||||||
|
@ -19,4 +19,5 @@ export class BreadcrumbsComponent {
|
||||||
|
|
||||||
@Input() public light: boolean = false;
|
@Input() public light: boolean = false;
|
||||||
@Input() public breadcrumbs: Breadcrumb[] = [];
|
@Input() public breadcrumbs: Breadcrumb[] = [];
|
||||||
|
@Input() public addClass;
|
||||||
}
|
}
|
|
@ -4,6 +4,7 @@ export class EnvProperties {
|
||||||
domain: string;
|
domain: string;
|
||||||
enablePiwikTrack: boolean;
|
enablePiwikTrack: boolean;
|
||||||
useCache: boolean;
|
useCache: boolean;
|
||||||
|
showAddThis: boolean;
|
||||||
showContent: boolean;
|
showContent: boolean;
|
||||||
|
|
||||||
metricsAPIURL;
|
metricsAPIURL;
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<span class="uk-width-expand uk-flex-right">
|
<span class="uk-width-expand uk-flex-right">
|
||||||
<a *ngIf="result.websiteURL && promoteWebsiteURL" href="{{result.websiteURL}}" target="_blank" type="submit"
|
<a *ngIf="result.websiteURL && promoteWebsiteURL" href="{{result.websiteURL}}" target="_blank" type="submit"
|
||||||
class="uk-float-right uk-button portal-button uk-padding uk-padding-remove-vertical uk-margin-small-left">
|
class="uk-float-right uk-button portal-button uk-padding uk-padding-remove-vertical uk-margin-small-left">
|
||||||
<span><span>Go to website</span><span uk-icon="arrow-right"></span></span>
|
<span><span>Visit repository to deposit</span><span uk-icon="arrow-right"></span></span>
|
||||||
</a>
|
</a>
|
||||||
</span>
|
</span>
|
||||||
<div class="uk-text-small">
|
<div class="uk-text-small">
|
||||||
|
@ -267,7 +267,7 @@
|
||||||
</div>
|
</div>
|
||||||
<!-- Description -->
|
<!-- Description -->
|
||||||
<div *ngIf="result.description" class="uk-margin-small-bottom multi-line-ellipsis lines-3">
|
<div *ngIf="result.description" class="uk-margin-small-bottom multi-line-ellipsis lines-3">
|
||||||
<p class="uk-text-small">
|
<p class="uk-text-small uk-text-muted">
|
||||||
{{result.description}}
|
{{result.description}}
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in New Issue