118 lines
6.9 KiB
HTML
118 lines
6.9 KiB
HTML
<div class="uk-width-xlarge@l uk-width-large" [ngClass]="centerAlign ? 'uk-align-center':''">
|
|
<advanced-search-input (searchEmitter)="search(page,size)">
|
|
<div input type="select" [(value)]="showOptions.show" placeholder="Type" hint="Select..."
|
|
[options]="showOptions.selectOptions" class="uk-width-2-5"></div>
|
|
<div class="uk-width-expand" input type="text" [(value)]="keyword" [searchable]="true" placeholder="Entities to link"
|
|
[hint]="'Search for ' + openaireEntities.PROJECTS + '...'" tooltip="true"></div>
|
|
</advanced-search-input>
|
|
</div>
|
|
<div *ngIf="!showResults">
|
|
<div class="uk-text-center uk-text-large uk-text-meta uk-margin-large-top">No {{openaireEntities.PROJECT.toLowerCase()}} 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 class="uk-grid" 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">-->
|
|
<div class="uk-grid uk-grid-small" uk-grid>
|
|
<ng-container *ngFor="let filter of rangeFilters">
|
|
<div>
|
|
<dropdown-filter [name]="filter.selectedFromAndToValues?filter.selectedFromAndToValues:filter.title"
|
|
dropdownMinWidth="450">
|
|
<div class="uk-padding-small">
|
|
<range-filter [isDisabled]="openaireResultsStatus == errorCodes.LOADING"
|
|
[filter]="filter" (onFilterChange)="dateFilterChanged(filter)"
|
|
[showQuickButtons]="false"
|
|
></range-filter>
|
|
</div>
|
|
</dropdown-filter>
|
|
</div>
|
|
</ng-container>
|
|
<ng-container *ngFor="let filter of filters ">
|
|
<div>
|
|
<dropdown-filter [count]="filter.countSelectedValues" [name]="filter.title"
|
|
dropdownMinWidth="450">
|
|
<div class="uk-padding-small">
|
|
<search-filter [isDisabled]="openaireResultsStatus == errorCodes.LOADING"
|
|
[filter]="filter" [filterValuesNum]="0" [showResultCount]=true
|
|
(onFilterChange)="filterChanged($event)" [actionRoute]="false"></search-filter>
|
|
</div>
|
|
</dropdown-filter>
|
|
</div>
|
|
</ng-container>
|
|
</div>
|
|
<!-- </ng-container>-->
|
|
</div>
|
|
<div class="uk-width-expand@m uk-width-1-1@s uk-first-column">
|
|
<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 *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>
|