2018-11-21 16:24:14 +01:00
|
|
|
import {Component, Input, Output, EventEmitter} from '@angular/core';
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
selector: 'search-sorting',
|
2020-03-13 17:11:36 +01:00
|
|
|
template: `
|
|
|
|
<div>
|
2022-04-05 14:26:26 +02:00
|
|
|
<!-- TODO: Disabled functionality -->
|
|
|
|
<div input *ngIf="(entityType != 'community' && entityType != 'stakeholder' )"
|
|
|
|
type="select" placeholder="Sort by:"
|
|
|
|
[options]="optionsA" [(value)]="sortBy"
|
|
|
|
(valueChange)="sortByChanged()"></div>
|
|
|
|
|
|
|
|
<div input *ngIf="(entityType == 'community' || entityType == 'stakeholder')"
|
|
|
|
type="select" placeholder="Sort by:"
|
|
|
|
[options]="optionsB" [(value)]="sortBy"
|
|
|
|
(valueChange)="sortByChanged()"></div>
|
2020-03-13 17:11:36 +01:00
|
|
|
</div>
|
2018-11-21 16:24:14 +01:00
|
|
|
`
|
|
|
|
})
|
|
|
|
|
|
|
|
export class SearchSortingComponent {
|
2020-07-14 15:13:44 +02:00
|
|
|
@Input() isDisabled: boolean = false;
|
2019-04-05 19:21:23 +02:00
|
|
|
@Input() sortBy: string = '';
|
|
|
|
@Input() entityType: string = '';
|
2018-11-21 16:24:14 +01:00
|
|
|
@Output() sortByChange = new EventEmitter();
|
2022-04-05 14:26:26 +02:00
|
|
|
public optionsA = [
|
|
|
|
{value: '', label: 'Relevance'},
|
|
|
|
{value: 'resultdateofacceptance,descending', label: 'Date (most recent)'},
|
|
|
|
{value: 'resultdateofacceptance,ascending', label: 'Date (least recent)'},
|
|
|
|
];
|
|
|
|
public optionsB = [
|
|
|
|
{value: '', label: 'Title'},
|
|
|
|
{value: 'creationdate,descending', label: 'Creation Date (most recent)'},
|
|
|
|
{value: 'creationdate,ascending', label: 'Creation Date (least recent)'},
|
|
|
|
];
|
2018-11-21 16:24:14 +01:00
|
|
|
|
|
|
|
|
2019-04-05 19:21:23 +02:00
|
|
|
constructor () {}
|
2018-11-21 16:24:14 +01:00
|
|
|
|
|
|
|
ngOnInit() {}
|
|
|
|
|
|
|
|
|
|
|
|
sortByChanged() {
|
[Trunk | Library]:
1. searchUtils.class.ts: In SearchUtilsClass added field "refineStatus:number = 1;" for refine queries.
2. searchResultsPerPage.component.ts & searchSorting.component.ts: [Bug fix] In EventEmitter (value change), emit raw value, not object with field "value".
3. searchDataProviders.component.ts & searchOrganizations.component.ts & searchProjects.component.ts & searchResearchResults.component.ts:
a. Add subscriptions in array to unsubscribe in ngOnDestroy.
b. Get properties from environment (no service needed).
c. Separate queries for refine and results.
d. Do not call refine query when page, results per page, sortBy change (there is still a bug here).
e. For refine query, added field "disableRefineForms" default set to false - passed in <new-search-page>.
4. newSearchPage.component.html:
a. Disable forms when "disableForms" or "disableRefineForms" is true.
b. Do not show filters, until results query returns, but show results while refine is loading.
c. Deleted old, unused code.
5. newSearchPage.component.ts:
a. Added fields "@Input() disableRefineForms: boolean = false;", "@Input() sortedByChanged: string = "";", "@Input() resultsPerPageChanged: number;"
b. When results per page or sortBy change, do not upadate immediately searchUtils values - do not query for refine when these change (there is still a bug here).
git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@59155 d315682c-612b-4755-9ff5-7f18f6832af3
2020-07-21 15:48:55 +02:00
|
|
|
this.sortByChange.emit(this.sortBy);
|
2018-11-21 16:24:14 +01:00
|
|
|
}
|
|
|
|
}
|