2018-11-21 16:24:14 +01:00
|
|
|
import {Component, Input, Output, EventEmitter} from '@angular/core';
|
2022-06-06 11:22:01 +02:00
|
|
|
import {Option} from "../../sharedComponents/input/input.component";
|
2023-09-20 13:13:34 +02:00
|
|
|
import {properties} from "../../../../environments/environment";
|
2018-11-21 16:24:14 +01:00
|
|
|
|
|
|
|
@Component({
|
2022-06-06 11:22:01 +02:00
|
|
|
selector: 'search-sorting',
|
|
|
|
template: `
|
|
|
|
<div *ngIf="options" class="uk-width-small">
|
|
|
|
<div input
|
|
|
|
type="select" placeholder="Sort by" inputClass="flat x-small"
|
|
|
|
[options]="options" [(value)]="sortBy" [disabled]="isDisabled"
|
|
|
|
(valueChange)="sortByChanged()"></div>
|
|
|
|
</div>
|
|
|
|
`
|
2018-11-21 16:24:14 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
export class SearchSortingComponent {
|
2022-06-06 11:22:01 +02:00
|
|
|
@Input() isDisabled: boolean = false;
|
|
|
|
@Input() sortBy: string = '';
|
|
|
|
@Input() entityType: string = '';
|
|
|
|
@Output() sortByChange = new EventEmitter();
|
|
|
|
public options: Option[];
|
2023-09-20 13:13:34 +02:00
|
|
|
private generalOptions = properties.environment != "production" ?
|
|
|
|
[
|
|
|
|
{value: '', label: 'Relevance'},
|
|
|
|
{value: 'resultdateofacceptance,descending', label: 'Date (most recent)'},
|
|
|
|
{value: 'resultdateofacceptance,ascending', label: 'Date (least recent)'},
|
|
|
|
{value: 'citation_count,descending', label: 'Citation Count'},
|
|
|
|
{value: 'popularity,descending', label: 'Popularity'},
|
|
|
|
{value: 'influence,descending', label: 'Influence'},
|
|
|
|
{value: 'impulse,descending', label: 'Impulse'}
|
|
|
|
] :
|
|
|
|
[
|
|
|
|
{value: '', label: 'Relevance'},
|
|
|
|
{value: 'resultdateofacceptance,descending', label: 'Date (most recent)'},
|
|
|
|
{value: 'resultdateofacceptance,ascending', label: 'Date (least recent)'}
|
|
|
|
];
|
2022-06-06 11:22:01 +02:00
|
|
|
private communityOptions = [
|
|
|
|
{value: '', label: 'Title'},
|
|
|
|
{value: 'creationdate,descending', label: 'Creation Date (most recent)'},
|
|
|
|
{value: 'creationdate,ascending', label: 'Creation Date (least recent)'},
|
|
|
|
];
|
|
|
|
private stakeholderOptions = [
|
|
|
|
{value: '', label: 'Name'},
|
|
|
|
{value: 'creationdate,descending', label: 'Creation Date (most recent)'},
|
|
|
|
{value: 'creationdate,ascending', label: 'Creation Date (least recent)'},
|
|
|
|
];
|
|
|
|
|
|
|
|
constructor() {
|
|
|
|
}
|
|
|
|
|
|
|
|
ngOnInit() {
|
|
|
|
if (this.entityType === 'community') {
|
|
|
|
this.options = this.communityOptions;
|
|
|
|
} else if (this.entityType === 'stakeholder') {
|
|
|
|
this.options = this.stakeholderOptions;
|
|
|
|
} else {
|
|
|
|
this.options = this.generalOptions;
|
2018-11-21 16:24:14 +01:00
|
|
|
}
|
2022-06-06 11:22:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
sortByChanged() {
|
|
|
|
this.sortByChange.emit(this.sortBy);
|
|
|
|
}
|
2018-11-21 16:24:14 +01:00
|
|
|
}
|