126 lines
7.3 KiB
HTML
126 lines
7.3 KiB
HTML
<div class="uk-display-inline-block">
|
|
<advanced-search-input (searchEmitter)="search(page,size)">
|
|
<div input type="select" [(value)]="showOptions.show" placeholder="Type" hint="Select..."
|
|
[options]="showOptions.selectOptions"></div>
|
|
<div input type="text" [(value)]="keyword" placeholder="Entities to link" [hint]="'Search for ' + openaireEntities.PROJECTS + '...'"></div>
|
|
</advanced-search-input>
|
|
</div>
|
|
<div *ngIf="!showResults">
|
|
<div class="uk-text-center uk-text-large uk-text-muted uk-margin-large-top">No project results yet... <br>Start
|
|
searching for {{openaireEntities.PROJECTS.toLowerCase()}} to add them in the Basket
|
|
</div>
|
|
</div>
|
|
<div *ngIf="showResults" class="uk-margin-top">
|
|
<div *ngIf="openaireResultsStatus == errorCodes.NONE" class="uk-alert uk-alert-primary"
|
|
role="alert">No Results found
|
|
</div>
|
|
<div *ngIf="openaireResultsStatus == errorCodes.ERROR" class="uk-alert uk-alert-warning"
|
|
role="alert">An Error Occured
|
|
</div>
|
|
<div *ngIf="openaireResultsStatus == errorCodes.NOT_AVAILABLE" class="uk-alert uk-alert-danger"
|
|
role="alert">Service not available
|
|
</div>
|
|
|
|
<div class="uk-grid">
|
|
<div class="search-filters uk-width-1-1">
|
|
|
|
<!--<div *ngIf="countFilters()>0 && openaireResultsNum > 0" class="uk-grid uk-flex uk-flex-bottom">
|
|
<div class="uk-grid">
|
|
<h6 class="uk-text-bold">Filters</h6>
|
|
<a *ngIf="countFilters()>1" (click)="clearFilters()"
|
|
[class]="((openaireResultsStatus ==
|
|
errorCodes.LOADING)?'uk-disabled uk-link-muted':'')+' portal-link '">
|
|
Clear All
|
|
</a>
|
|
</div>
|
|
<div *ngIf="countFilters()>0" class="uk-grid uk-grid-small uk-text-small uk-margin-small-top " uk-grid>
|
|
<ng-container *ngFor="let filter of rangeFilters " >
|
|
<ng-container *ngIf = "filter.selectedFromAndToValues">
|
|
<span [title]="'Remove '+ filter.selectedFromAndToValues" (click) = "removeRangeFilter(filter) " >
|
|
<span class="selectedFilterLabel ">
|
|
<a [class]="((openaireResultsStatus ==
|
|
errorCodes.LOADING)?' uk-disabled':' ')+' uk-link-text '">
|
|
<span class=" clickable" aria-hidden="true">
|
|
<span class="uk-icon">
|
|
<svg width="16" height="16" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" icon="close" ratio="0.8"><path fill="none" stroke="#000" stroke-width="1.6" d="M16,16 L4,4"></path><path fill="none" stroke="#000" stroke-width="1.6" d="M16,4 L4,16"></path></svg>
|
|
</span>
|
|
</span>
|
|
<span class="uk-margin-small-left">{{filter.selectedFromAndToValues}}</span>
|
|
</a>
|
|
</span>
|
|
</span>
|
|
</ng-container>
|
|
</ng-container>
|
|
|
|
<ng-container *ngFor="let filter of filters " >
|
|
<ng-container *ngIf = "filter.countSelectedValues > 0">
|
|
<span *ngFor="let value of getSelectedValues(filter); let i = index; let end = last; "
|
|
[title]="'Remove '+value.name" (click) = "removeFilter(value, filter) " >
|
|
<!– if no grid on the div above, remove it and move class 'selectedFilterLabel' on top span –>
|
|
<span class="selectedFilterLabel ">
|
|
<a [class]="((openaireResultsStatus ==
|
|
errorCodes.LOADING)?' uk-disabled':' ')+' uk-link-text '">
|
|
<span class=" clickable" aria-hidden="true">
|
|
<span class="uk-icon">
|
|
<svg width="16" height="16" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" icon="close" ratio="0.8"><path fill="none" stroke="#000" stroke-width="1.6" d="M16,16 L4,4"></path><path fill="none" stroke="#000" stroke-width="1.6" d="M16,4 L4,16"></path></svg>
|
|
</span>
|
|
</span>
|
|
<span class="uk-margin-small-left" [innerHtml]="(value.name.length > 34)?value.name.substring(0,34)+'...':value.name"></span>
|
|
</a>
|
|
</span>
|
|
</span>
|
|
</ng-container>
|
|
</ng-container>
|
|
</div>
|
|
</div>-->
|
|
|
|
<ng-container *ngIf="openaireResultsNum > 0">
|
|
<ng-container *ngFor="let filter of rangeFilters">
|
|
|
|
<div class="uk-inline">
|
|
<button class="uk-button uk-button-default uk-button-small uk-margin-small-right uk-margin-small-bottom "
|
|
type="button"><span *ngIf="!filter.selectedFromAndToValues">{{filter.title}}</span><span *ngIf="filter.selectedFromAndToValues">{{filter.selectedFromAndToValues}}</span><span uk-icon="chevron-down"></span></button>
|
|
<div uk-dropdown="mode: click" class="uk-width-large" style="max-width:460px !important;">
|
|
<div class="uk-padding-small uk-overflow-auto uk-height-max-large uk-height-min-medium">
|
|
<range-filter [isDisabled]="openaireResultsStatus ==
|
|
errorCodes.LOADING" [filter]="filter" (onFilterChange)="dateFilterChanged(filter)"
|
|
[showQuickButtons]="false"
|
|
></range-filter>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
|
|
</ng-container>
|
|
|
|
<ng-container *ngFor="let filter of filters ">
|
|
<div class="uk-inline">
|
|
<button class="uk-button uk-button-default uk-button-small uk-margin-small-right uk-margin-small-bottom "
|
|
type="button">{{filter.title}}<span *ngIf="filter.countSelectedValues>0"> ({{filter.countSelectedValues}})</span><span uk-icon="chevron-down"></span></button>
|
|
<div uk-dropdown="mode: click" class="uk-width-large uk-overflow-auto" style="max-width:460px !important; ">
|
|
<div class="uk-padding-small uk-overflow-auto uk-height-max-large uk-height-min-medium">
|
|
<search-filter [isDisabled]="openaireResultsStatus ==
|
|
errorCodes.LOADING" [filter]="filter"
|
|
[showResultCount]=true filterValuesNum="0"
|
|
(onFilterChange)="filterChanged($event)" [actionRoute]="false"></search-filter>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</ng-container>
|
|
</ng-container>
|
|
</div>
|
|
<div class="uk-width-expand@m uk-width-1-1@s uk-first-column">
|
|
|
|
<div *ngIf="openaireResultsStatus == errorCodes.LOADING" class="uk-animation-fade uk-margin-top uk-width-1-1"
|
|
role="alert"><span class="loading-gif uk-align-center"></span></div>
|
|
<claim-results [localStoragePrefix]="localStoragePrefix" [results]=openaireResults
|
|
[selectedResults]=selectedProjects [basketLimit]="basketLimit"></claim-results>
|
|
<div *ngIf="openaireResultsNum != null && openaireResultsNum > 0 && openaireResultsStatus != errorCodes.LOADING " class="uk-flex uk-flex-center ">
|
|
<paging-no-load [currentPage]="openaireResultsPage"
|
|
[totalResults]="openaireResultsNum" [term]="keyword"
|
|
[size]="size" (pageChange)="openaireResultsPageChange($event)"></paging-no-load>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|