129 lines
5.3 KiB
TypeScript
129 lines
5.3 KiB
TypeScript
import {ChangeDetectorRef, Component, ViewChild} from "@angular/core";
|
|
import {
|
|
MonitorIndicatorStakeholderBaseComponent
|
|
} from "../../openaireLibrary/monitor/monitor-indicator-stakeholder-base.component";
|
|
import {DomSanitizer, Meta, Title} from "@angular/platform-browser";
|
|
import {LayoutService} from "../../openaireLibrary/dashboard/sharedComponents/sidebar/layout.service";
|
|
import {StatisticsService} from "../../openaireLibrary/monitor-admin/utils/services/statistics.service";
|
|
import {StakeholderService} from "../../openaireLibrary/monitor/services/stakeholder.service";
|
|
import {UserManagementService} from "../../openaireLibrary/services/user-management.service";
|
|
import {IndicatorPath, Visibility} from "../../openaireLibrary/monitor/entities/stakeholder";
|
|
import {ActivatedRoute, Router} from "@angular/router";
|
|
import {PiwikService} from "../../openaireLibrary/utils/piwik/piwik.service";
|
|
import {SEOService} from "../../openaireLibrary/sharedComponents/SEO/SEO.service";
|
|
import {SearchResearchResultsService} from "../../openaireLibrary/services/searchResearchResults.service";
|
|
import {CustomFilterService} from "../../openaireLibrary/shared/customFilter.service";
|
|
import {StringUtils} from "../../openaireLibrary/utils/string-utils.class";
|
|
import {Filter} from "../../openaireLibrary/searchPages/searchUtils/searchHelperClasses.class";
|
|
import {FullScreenModalComponent} from "src/app/openaireLibrary/utils/modal/full-screen-modal/full-screen-modal.component";
|
|
|
|
@Component({
|
|
selector: 'monitor',
|
|
templateUrl: 'monitor.component.html'
|
|
})
|
|
export class MonitorComponent extends MonitorIndicatorStakeholderBaseComponent {
|
|
@ViewChild('fsModal') fsModal: FullScreenModalComponent;
|
|
|
|
constructor(protected _route: ActivatedRoute,
|
|
protected _router: Router,
|
|
protected _meta: Meta,
|
|
protected _title: Title,
|
|
protected _piwikService: PiwikService,
|
|
protected seoService: SEOService,
|
|
protected sanitizer: DomSanitizer,
|
|
protected cdr: ChangeDetectorRef,
|
|
protected layoutService: LayoutService,
|
|
protected statisticsService: StatisticsService,
|
|
protected searchResearchResultsService: SearchResearchResultsService,
|
|
protected customFilterService: CustomFilterService,
|
|
private userManagementService: UserManagementService,
|
|
private stakeholderService: StakeholderService) {
|
|
super();
|
|
}
|
|
|
|
ngOnInit() {
|
|
super.ngOnInit();
|
|
this.requireLogin = false;
|
|
this.subscriptions.push(this.userManagementService.getUserInfo().subscribe(user => {
|
|
this.user = user;
|
|
this.subscriptions.push(this._route.params.subscribe(params => {
|
|
this.loading = true;
|
|
this.activeTopic = null;
|
|
this.activeCategory = null;
|
|
this.activeSubCategory = null;
|
|
this.numberResults = new Map<string, number>();
|
|
this.chartsActiveType = new Map<string, IndicatorPath>();
|
|
this.subscriptions.push(this.stakeholderService.getStakeholderAsObservable().subscribe(stakeholder => {
|
|
if (stakeholder) {
|
|
this.stakeholder = stakeholder;
|
|
|
|
this.subscriptions.push(this._route.queryParams.subscribe(queryParams => {
|
|
this.handleQueryParams(queryParams, params);
|
|
this.subscriptions.push(this.customFilterService.getCustomFilterAsObservable().subscribe(filters => {
|
|
if(filters) {
|
|
let customFilterParams = "";
|
|
for (let customFilter of filters) {
|
|
if (customFilter.isHiddenFilter) {
|
|
customFilterParams += "&fq=" + StringUtils.URIEncode(customFilter.queryFieldName + " exact " + StringUtils.quote((customFilter.valueId)));
|
|
}
|
|
}
|
|
this.subscriptions.push(this.searchResearchResultsService.advancedSearchResults("publication", null, 1, 0, null, this.properties,
|
|
"&refine=true&fields=fos&type=publications", ["fos"], customFilterParams).subscribe(res => {
|
|
this.filters = this.postProcessingFosFilters(res[2]);
|
|
this.title = this.stakeholder.name;
|
|
this.description = this.stakeholder.name;
|
|
this.setMetadata();
|
|
this.setView(params);
|
|
}));
|
|
|
|
}
|
|
}));
|
|
|
|
}));
|
|
// } else {
|
|
// this.navigateToError();
|
|
}
|
|
}));
|
|
}));
|
|
}));
|
|
}
|
|
|
|
hasPermission(visibility: Visibility): boolean {
|
|
return true;
|
|
}
|
|
logIn() {
|
|
this.userManagementService.login();
|
|
}
|
|
|
|
postProcessingFosFilters(refineFilters:Filter[]){
|
|
let filters:Filter[] = [];
|
|
for(let filter of refineFilters){
|
|
if(filter.filterId == "fos"){
|
|
let fos: Filter ={...filter};
|
|
fos.values = [];
|
|
for(let value of filter.values){
|
|
let code = value.id.split(" ")[0];
|
|
if(code.length <= 4){
|
|
fos.values.push(value);
|
|
}
|
|
}
|
|
filters.push(fos);
|
|
}else{
|
|
filters.push(filter);
|
|
}
|
|
}
|
|
return filters;
|
|
}
|
|
|
|
openFsModal(fsModal: FullScreenModalComponent) {
|
|
console.log('open fs feedback modal');
|
|
fsModal.title = 'Contact us';
|
|
fsModal.okButton = false;
|
|
fsModal.stayOpenInBack = true;
|
|
fsModal.open();
|
|
}
|
|
|
|
// closeFsModal() {
|
|
// console.log('close fs feedback modal');
|
|
// }
|
|
} |