2019-07-22 11:16:50 +02:00
import { Component , Input , ViewChild } from '@angular/core' ;
import { ActivatedRoute , Router } from '@angular/router' ;
import { Meta , Title } from '@angular/platform-browser' ;
import { ProjectService } from './project.service' ;
import { ProjectInfo } from '../../utils/entities/projectInfo' ;
import { RouterHelper } from '../../utils/routerHelper.class' ;
2019-09-11 11:45:54 +02:00
import { FetchResearchResults } from '../../utils/fetchEntitiesClasses/fetchResearchResults.class' ;
import { SearchResearchResultsService } from '../../services/searchResearchResults.service' ;
2019-07-22 11:16:50 +02:00
import { ModalLoading } from '../../utils/modal/loading.component' ;
import { ReportsService } from '../../services/reports.service' ;
import { ErrorCodes } from '../../utils/properties/errorCodes'
import { PiwikService } from '../../utils/piwik/piwik.service' ;
import { EnvProperties } from '../../utils/properties/env-properties' ;
import { SEOService } from '../../sharedComponents/SEO/SEO.service' ;
2019-04-24 14:31:01 +02:00
import { HelperFunctions } from "../../utils/HelperFunctions.class" ;
2019-07-22 11:16:50 +02:00
import { HelperService } from "../../utils/helper/helper.service" ;
2019-11-07 10:51:09 +01:00
import { Location } from "@angular/common" ;
2020-03-16 14:09:46 +01:00
import { HtmlProjectReportService } from "../htmlProjectReport/htmlProjectReport.service" ;
2020-05-08 17:04:24 +02:00
import { StringUtils } from "../../utils/string-utils.class" ;
2020-05-19 17:59:20 +02:00
import { ResultLandingInfo } from "../../utils/entities/resultLandingInfo" ;
import { ResultPreview } from "../../utils/result-preview/result-preview" ;
import { SearchResult } from "../../utils/entities/searchResult" ;
import { IndexInfoService } from "../../utils/indexInfo.service" ;
2017-12-19 13:53:46 +01:00
@Component ( {
2019-07-22 11:16:50 +02:00
selector : 'project' ,
templateUrl : 'project.component.html' ,
} )
Replace meta service import and use with meta and title from angular/platform-browser for user, publication, claimAdmin,claimsByToken, directLinking, linkingGeneric, myClaims, depositBySubject, depositBySubjectResult, deposit, depositResult, dataProvider, htmlProjectReport, organization, project, software, search, advancedSearchPage, searchPage and searchPageTableView component
git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@51835 d315682c-612b-4755-9ff5-7f18f6832af3
2018-04-17 15:00:23 +02:00
2019-07-22 11:16:50 +02:00
export class ProjectComponent {
2018-04-11 10:59:01 +02:00
@Input ( ) piwikSiteId = null ;
2019-07-22 11:16:50 +02:00
@Input ( ) communityId = null ;
2017-12-19 13:53:46 +01:00
public projectInfo : ProjectInfo ;
2019-07-22 11:16:50 +02:00
public projectId : string ;
2017-12-19 13:53:46 +01:00
public projectName : string ;
// Metrics tab variables
public metricsClicked : boolean ;
public viewsFrameUrl : string ;
public downloadsFrameUrl : string ;
private totalViews : number ;
private totalDownloads : number ;
private pageViews : number ;
// Statistics tab variables
public statsClicked : boolean ;
public chartScientificResultsUrl : string ;
public chartAccessModeUrl : string ;
public chartDatasourcesUrl : string ;
2020-03-16 14:09:46 +01:00
// Clipboard variable for HTML dynamic content
public clipboard ;
2017-12-19 13:53:46 +01:00
2019-07-22 11:16:50 +02:00
public project ;
2017-12-19 13:53:46 +01:00
// CSV variables
public downloadURLAPI : string ;
public csvParams : string ;
2020-03-16 14:09:46 +01:00
// HTML (download) variables
public header1 : string = "" ;
public header2 : string = "" ;
public htmlResultDownload : string = "" ;
2017-12-19 13:53:46 +01:00
// Message variables
public warningMessage = "" ;
public errorMessage = "" ;
public showLoading : boolean = true ;
// Active tab variable for responsiveness
public activeTab : string = "Publications" ;
2020-03-16 14:09:46 +01:00
@ViewChild ( 'statisticsModal' ) statisticsModal ;
2020-05-19 01:40:14 +02:00
@ViewChild ( 'linkProjectModal' ) linkProjectModal ;
@ViewChild ( 'shareResultsModal' ) shareResultsModal ;
@ViewChild ( 'downloadReportModal' ) downloadReportModal ;
2018-06-08 13:21:42 +02:00
// Request results for publications, research data and software only the one time (first time tab is clicked)
private reloadPublications : boolean = true ;
2017-12-19 13:53:46 +01:00
private reloadDatasets : boolean = true ;
private reloadSoftware : boolean = true ;
2018-07-26 18:38:59 +02:00
private reloadOrps : boolean = true ;
2017-12-19 13:53:46 +01:00
2020-03-16 14:09:46 +01:00
// Variables for entity selections on the right column
public share_research_results_type : string = "" ;
public download_research_results_type : string = "" ;
2017-12-19 13:53:46 +01:00
// Variables for publications, research data, software tabs
2019-09-11 11:45:54 +02:00
public fetchPublications : FetchResearchResults ;
public fetchDatasets : FetchResearchResults ;
public fetchSoftware : FetchResearchResults ;
public fetchOrps : FetchResearchResults ;
2020-05-20 18:45:50 +02:00
public searchNumber : number = 5 ;
2017-12-19 13:53:46 +01:00
2019-07-22 11:16:50 +02:00
public routerHelper : RouterHelper = new RouterHelper ( ) ;
public errorCodes : ErrorCodes = new ErrorCodes ( ) ;
public pageContents = null ;
public divContents = null ;
2017-12-19 13:53:46 +01:00
2020-03-16 14:09:46 +01:00
public indexUpdateDate : Date ;
public showFeedback : boolean ;
public feedbackFields : string [ ] = [
'Title' , 'Funding Information' , 'Duration' ,
'Organizations' , 'Other' ] ;
2019-12-10 15:45:13 +01:00
2019-07-22 11:16:50 +02:00
@ViewChild ( ModalLoading ) loading : ModalLoading ;
2017-12-19 13:53:46 +01:00
// Alert box when something is wrong with CSV requests
@ViewChild ( 'AlertModalCsvError' ) alertCsvError ;
2020-03-16 14:09:46 +01:00
// Description variables for view more/less functionality
public thresholdDescription : number = 670 ;
public showNumDescription : number = 670 ;
// Organizations variables for view more/less functionality
public thresholdOrganizations : number = 20 ;
public showNumOrganizations : number = 20 ;
2019-07-22 11:16:50 +02:00
sub : any ;
piwiksub : any ;
infoSub : any ;
downloadFilePiwikSub : any ;
2020-03-16 14:09:46 +01:00
downloadHtmlFilePiwikSub : any ;
2019-07-22 11:16:50 +02:00
properties : EnvProperties ;
2020-03-16 14:09:46 +01:00
public subHTML : any ;
constructor ( private route : ActivatedRoute ,
private _router : Router ,
private _location : Location ,
2019-07-22 11:16:50 +02:00
private _meta : Meta ,
private _title : Title ,
2019-11-07 10:51:09 +01:00
private seoService : SEOService ,
2020-03-16 14:09:46 +01:00
private _piwikService : PiwikService ,
private helper : HelperService ,
private _projectService : ProjectService ,
private _searchResearchResultsService : SearchResearchResultsService ,
private _reportsService : ReportsService ,
2020-05-19 17:59:20 +02:00
private htmlService : HtmlProjectReportService ,
private indexInfoService : IndexInfoService ) { }
2017-12-19 13:53:46 +01:00
ngOnInit() {
2018-02-05 14:14:59 +01:00
this . route . data
. subscribe ( ( data : { envSpecific : EnvProperties } ) = > {
2019-07-22 11:16:50 +02:00
this . properties = data . envSpecific ;
2020-05-19 17:59:20 +02:00
this . indexInfoService . getLastIndexDate ( this . properties ) . subscribe ( lastIndexUpdate = > {
if ( lastIndexUpdate ) {
this . indexUpdateDate = new Date ( lastIndexUpdate ) ;
} else if ( this . properties . lastIndexUpdate ) {
this . indexUpdateDate = new Date ( this . properties . lastIndexUpdate ) ;
}
} ) ;
2019-07-22 11:16:50 +02:00
//this.getDivContents();
this . getPageContents ( ) ;
this . updateUrl ( data . envSpecific . baseLink + this . _router . url ) ;
2018-02-05 14:14:59 +01:00
} ) ;
2019-07-22 11:16:50 +02:00
this . sub = this . route . queryParams . subscribe ( params = > {
this . metricsClicked = false ;
this . statsClicked = false ;
2019-09-11 11:45:54 +02:00
this . fetchPublications = new FetchResearchResults ( this . _searchResearchResultsService ) ;
this . fetchDatasets = new FetchResearchResults ( this . _searchResearchResultsService ) ;
this . fetchSoftware = new FetchResearchResults ( this . _searchResearchResultsService ) ;
this . fetchOrps = new FetchResearchResults ( this . _searchResearchResultsService ) ;
2019-07-22 11:16:50 +02:00
var title = "Project" ;
var description = "" ;
2020-03-16 14:09:46 +01:00
this . header1 = "" ;
2019-07-22 11:16:50 +02:00
this . updateTitle ( title ) ;
this . updateDescription ( description ) ;
2017-12-19 13:53:46 +01:00
this . projectId = params [ 'projectId' ] ;
2018-03-16 16:56:35 +01:00
var grantId = params [ 'grantId' ] ;
var funder = params [ 'funder' ] ;
2019-07-22 11:16:50 +02:00
if ( this . projectId ) {
this . getProjectInfo ( this . projectId ) ;
this . actionsAfterLoadId ( ) ;
} else if ( grantId && funder ) {
this . getProjectInfoByGrantId ( grantId , funder ) ;
} else {
2018-03-16 16:56:35 +01:00
2019-07-22 11:16:50 +02:00
this . showLoading = false ;
2019-11-07 10:51:09 +01:00
this . _router . navigate ( [ '/error' ] , { queryParams : { "page" : this . _location . path ( true ) , "page_type" : "project" } } ) ;
2019-10-31 12:39:23 +01:00
//this.warningMessage = "No valid project id";
2017-12-19 13:53:46 +01:00
}
2018-02-05 14:14:59 +01:00
this . downloadURLAPI = this . properties . csvAPIURL ;
2017-12-19 13:53:46 +01:00
this . createClipboard ( ) ;
2019-04-24 14:31:01 +02:00
HelperFunctions . scroll ( ) ;
2019-07-22 11:16:50 +02:00
} ) ;
}
2020-03-16 14:09:46 +01:00
public getFileNameType ( type : string ) {
if ( type == "results" ) {
return "research-outcomes" ;
} else if ( type == "publications" ) {
return "publications" ;
} else if ( type == "datasets" ) {
return "research-data" ;
} else if ( type == "software" ) {
return "software" ;
} else if ( type == "other" ) {
return "other-research-products" ;
}
return "results" ;
}
public getCsvParams ( type : string ) {
// if(type == "results") {
// type = "publications&type=datasets&type=software&type=other";
// }
return "?format=csv-special&type=" + type + "&fq=(relprojectid exact \"" + this . projectId + "\")" ;
}
2019-07-22 11:16:50 +02:00
private getPageContents() {
2020-04-07 13:15:28 +02:00
this . helper . getPageHelpContents ( this . properties , this . communityId , this . _router . url ) . subscribe ( contents = > {
2019-07-22 11:16:50 +02:00
this . pageContents = contents ;
} )
}
private getDivContents() {
2020-04-07 13:15:28 +02:00
this . helper . getDivHelpContents ( this . properties , this . communityId , this . _router . url ) . subscribe ( contents = > {
2019-07-22 11:16:50 +02:00
this . divContents = contents ;
} )
}
2020-03-16 14:09:46 +01:00
getDynamicContent ( type : string ) {
return "<script type=\"text/javascript\">"
2019-07-22 11:16:50 +02:00
+ "\n<!--"
+ "\ndocument.write('<div id=\"oa_widget\"></div>');"
+ "\ndocument.write('<script type=\"text/javascript\""
2019-12-11 12:13:57 +01:00
+ " src=\"" + this . properties . widgetLink
2020-03-16 14:09:46 +01:00
+ this . projectId + "&type="
+ type
+ "\"></script>');"
2019-07-22 11:16:50 +02:00
+ "\n-->"
+ "\n</script>" ;
2020-03-16 14:09:46 +01:00
}
2019-07-22 11:16:50 +02:00
2020-03-16 14:09:46 +01:00
actionsAfterLoadId() {
2019-07-22 11:16:50 +02:00
this . getProjectInfo ( this . projectId ) ;
//this.searchPublications();
2019-09-11 11:45:54 +02:00
this . fetchPublications . getNumForEntity ( "publication" , "project" , this . projectId , this . properties ) ;
this . fetchDatasets . getNumForEntity ( "dataset" , "project" , this . projectId , this . properties ) ;
this . fetchSoftware . getNumForEntity ( "software" , "project" , this . projectId , this . properties ) ;
this . fetchOrps . getNumForEntity ( "other" , "project" , this . projectId , this . properties ) ;
2019-07-22 11:16:50 +02:00
}
2017-12-19 13:53:46 +01:00
ngOnDestroy() {
2019-07-22 11:16:50 +02:00
if ( this . sub ) {
2018-09-05 14:37:47 +02:00
this . sub . unsubscribe ( ) ;
}
2019-07-22 11:16:50 +02:00
if ( this . piwiksub ) {
2017-12-19 13:53:46 +01:00
this . piwiksub . unsubscribe ( ) ;
}
2019-07-22 11:16:50 +02:00
if ( this . infoSub ) {
2017-12-19 13:53:46 +01:00
this . infoSub . unsubscribe ( ) ;
}
2019-07-22 11:16:50 +02:00
if ( this . downloadFilePiwikSub ) {
2017-12-19 13:53:46 +01:00
this . downloadFilePiwikSub . unsubscribe ( ) ;
}
2020-03-16 14:09:46 +01:00
if ( this . downloadHtmlFilePiwikSub ) {
this . downloadHtmlFilePiwikSub . unsubscribe ( ) ;
}
2017-12-19 13:53:46 +01:00
}
private createClipboard() {
2019-07-22 11:16:50 +02:00
if ( typeof window !== 'undefined' ) {
2020-03-16 14:09:46 +01:00
delete this . clipboard ;
2019-07-22 11:16:50 +02:00
let Clipboard ;
Clipboard = require ( 'clipboard' ) ;
2020-03-16 14:09:46 +01:00
this . clipboard = new Clipboard ( '.clipboard_btn' ) ;
2019-07-22 11:16:50 +02:00
}
2017-12-19 13:53:46 +01:00
}
private searchPublications() {
2020-05-20 18:45:50 +02:00
this . fetchPublications . getResultsForEntity ( "publication" , "project" , this . projectId , 1 , this . searchNumber , this . properties ) ;
2018-06-08 13:21:42 +02:00
this . reloadPublications = false ;
2017-12-19 13:53:46 +01:00
}
private searchDatasets() {
2020-05-20 18:45:50 +02:00
this . fetchDatasets . getResultsForEntity ( "dataset" , "project" , this . projectId , 1 , this . searchNumber , this . properties ) ;
2019-07-22 11:16:50 +02:00
this . reloadDatasets = false ;
//this.activeTab = "Research Data";
2017-12-19 13:53:46 +01:00
}
private searchSoftware() {
2020-05-20 18:45:50 +02:00
this . fetchSoftware . getResultsForEntity ( "software" , "project" , this . projectId , 1 , this . searchNumber , this . properties ) ;
2019-07-22 11:16:50 +02:00
this . reloadSoftware = false ;
2017-12-19 13:53:46 +01:00
}
2018-07-26 18:38:59 +02:00
private searchOrps() {
2020-05-20 18:45:50 +02:00
this . fetchOrps . getResultsForEntity ( "other" , "project" , this . projectId , 1 , this . searchNumber , this . properties ) ;
2019-07-22 11:16:50 +02:00
this . reloadOrps = false ;
2018-07-26 18:38:59 +02:00
}
2018-06-08 13:21:42 +02:00
public searchPublicationsInit() {
2019-07-22 11:16:50 +02:00
if ( this . reloadPublications && this . fetchPublications . searchUtils . totalResults > 0 ) {
this . searchPublications ( ) ;
} else if ( this . fetchPublications . searchUtils . totalResults == 0 ) {
//this.statsClicked=true;
//this.activeTab = "Statistics";
}
2018-06-08 13:21:42 +02:00
}
2017-12-19 13:53:46 +01:00
public searchDatasetsInit() {
2019-07-22 11:16:50 +02:00
if ( this . reloadDatasets && this . fetchDatasets . searchUtils . totalResults > 0 ) {
this . searchDatasets ( ) ;
} else if ( this . fetchDatasets . searchUtils . totalResults == 0 ) {
//this.statsClicked=true;
//this.activeTab = "Statistics";
}
2017-12-19 13:53:46 +01:00
}
public searchSoftwareInit() {
2019-07-22 11:16:50 +02:00
if ( this . reloadSoftware && this . fetchSoftware . searchUtils . totalResults > 0 ) {
this . searchSoftware ( ) ;
}
2017-12-19 13:53:46 +01:00
}
2018-07-26 18:38:59 +02:00
public searchOrpsInit() {
2019-07-22 11:16:50 +02:00
if ( this . reloadOrps && this . fetchOrps . searchUtils . totalResults > 0 ) {
this . searchOrps ( ) ;
}
2018-07-26 18:38:59 +02:00
}
2019-07-22 11:16:50 +02:00
private getProjectInfo ( id : string ) {
this . warningMessage = '' ;
2020-03-17 16:19:25 +01:00
this . errorMessage = "" ;
2017-12-19 13:53:46 +01:00
this . showLoading = true ;
2018-06-28 16:52:45 +02:00
this . projectInfo = null ;
2017-12-19 13:53:46 +01:00
2018-02-05 14:14:59 +01:00
this . infoSub = this . _projectService . getProjectInfo ( id , this . properties ) . subscribe (
2017-12-19 13:53:46 +01:00
data = > {
2019-07-22 11:16:50 +02:00
this . projectInfo = data ;
2017-12-19 13:53:46 +01:00
2019-07-22 11:16:50 +02:00
this . actionsAfterGettingProjectInfo ( ) ;
2017-12-19 13:53:46 +01:00
} ,
err = > {
2019-07-22 11:16:50 +02:00
//console.log(err);
this . handleError ( "Error getting project for id: " + this . projectId , err ) ;
2019-10-31 12:39:23 +01:00
if ( err . status == 404 ) {
2019-11-07 10:51:09 +01:00
this . _router . navigate ( [ '/error' ] , { queryParams : { "page" : this . _location . path ( true ) , "page_type" : "project" } } ) ;
2019-10-31 12:39:23 +01:00
}
2019-06-03 10:53:57 +02:00
this . seoService . createLinkForCanonicalURL ( this . properties . baseLink + this . properties . searchLinkToProjects ) ;
2020-03-17 16:19:25 +01:00
this . errorMessage = 'No project found' ;
2019-07-22 11:16:50 +02:00
this . showLoading = false ;
}
2017-12-19 13:53:46 +01:00
) ;
2018-03-16 16:56:35 +01:00
}
2019-07-22 11:16:50 +02:00
private getProjectInfoByGrantId ( grantId : string , funder : string ) {
this . warningMessage = '' ;
2020-03-17 16:19:25 +01:00
this . errorMessage = "" ;
2019-07-22 11:16:50 +02:00
this . showLoading = true ;
this . projectInfo = null ;
this . _projectService . getProjectInfoByGrantId ( grantId , funder , this . properties ) . subscribe (
data = > {
this . projectInfo = data ;
this . actionsAfterGettingProjectInfo ( ) ;
this . projectId = this . projectInfo . id ;
this . actionsAfterLoadId ( ) ;
} ,
err = > {
//console.log(err);
this . handleError ( "Error getting project for grant id: " + grantId + " and funder: " + funder , err ) ;
2020-03-17 16:19:25 +01:00
if ( err . status == 404 ) {
this . _router . navigate ( [ '/error' ] , { queryParams : { "page" : this . _location . path ( true ) , "page_type" : "project" } } ) ;
}
2019-07-22 11:16:50 +02:00
this . seoService . createLinkForCanonicalURL ( this . properties . baseLink + this . properties . searchLinkToProjects ) ;
this . errorMessage = 'No project found' ;
this . showLoading = false ;
}
) ;
2018-03-16 16:56:35 +01:00
}
2019-07-22 11:16:50 +02:00
actionsAfterGettingProjectInfo() {
this . projectName = this . projectInfo . acronym ;
if ( this . projectName == undefined || this . projectName == '' ) {
this . projectName = this . projectInfo . title ;
}
this . seoService . createLinkForCanonicalURL ( this . properties . baseLink + this . _router . url ) ;
this . updateTitle ( this . projectName ) ;
2020-03-16 14:09:46 +01:00
this . updateDescription ( "project, " + this . projectName + "," + this . projectInfo . funding . funderShortName + "," + this . projectInfo . acronym ) ;
2019-07-22 11:16:50 +02:00
if ( this . properties . enablePiwikTrack && ( typeof document !== 'undefined' ) ) {
this . piwiksub = this . _piwikService . trackView ( this . properties , this . projectName , this . piwikSiteId ) . subscribe ( ) ;
}
this . project = {
funderId : "" ,
2020-03-16 14:09:46 +01:00
funderName : ( ( this . projectInfo . funding ) ? this . projectInfo . funding . funderShortName : '' ) ,
2019-07-22 11:16:50 +02:00
projectId : this.projectId ,
projectName : this.projectInfo.title ,
projectAcronym : this.projectInfo.acronym ,
startDate : this.projectInfo.startDate ,
endDate : this.projectInfo.endDate
} ;
2017-12-19 13:53:46 +01:00
2019-12-04 13:56:37 +01:00
this . viewsFrameUrl = this . properties . framesAPIURL + 'merge.php?com=query&data=[{"query":"projRepoViews","projTitle":"' + this . projectId + '","table":"","fields":[{"fld":"sum","agg":"sum","type":"column","yaxis":1,"c":false}],"xaxis":{"name":"month","agg":"sum"},"group":"","color":"","type":"chart","size":80,"sort":"xaxis","xStyle":{"r":-30,"s":"6","l":"-","ft":"-","wt":"-"},"title":"","subtitle":"","xaxistitle":"","yaxisheaders":["Monthly views"],"generalxaxis":"","theme":0,"in":[]}]&info_types=["column"]&stacking=&steps=false&fontFamily=Courier&spacing=[5,0,0,0]&style=[{"color":"rgba(0, 0, 0, 1)","size":"18"},{"color":"rgba(0, 0, 0, 1)","size":"18"},{"color":"000000","size":""},{"color":"000000","size":""}]&backgroundColor=rgba(255,255,255,1)&colors[]=rgba(124, 181, 236, 1)&colors[]=rgba(67, 67, 72, 1)&colors[]=rgba(144, 237, 125, 1)&colors[]=rgba(247, 163, 92, 1)&colors[]=rgba(128, 133, 233, 1)&colors[]=rgba(241, 92, 128, 1)&colors[]=rgba(228, 211, 84, 1)&colors[]=rgba(43, 144, 143, 1)&colors[]=rgba(244, 91, 91, 1)&colors[]=rgba(145, 232, 225, 1)&xlinew=0&ylinew=1&legends=true&tooltips=true&persistent=false' ;
2018-03-16 16:56:35 +01:00
2019-12-04 13:56:37 +01:00
this . downloadsFrameUrl = this . properties . framesAPIURL + 'merge.php?com=query&data=[{"query":"projRepoDownloads","projTitle":"' + this . projectId + '","table":"","fields":[{"fld":"sum","agg":"sum","type":"column","yaxis":1,"c":false}],"xaxis":{"name":"month","agg":"sum"},"group":"","color":"","type":"chart","size":80,"sort":"xaxis","xStyle":{"r":-30,"s":"6","l":"-","ft":"-","wt":"-"},"title":"","subtitle":"","xaxistitle":"","yaxisheaders":["Monthly downloads"],"generalxaxis":"","theme":0,"in":[]}]&info_types=["column"]&stacking=&steps=false&fontFamily=Courier&spacing=[5,0,0,0]&style=[{"color":"rgba(0, 0, 0, 1)","size":"18"},{"color":"rgba(0, 0, 0, 1)","size":"18"},{"color":"000000","size":""},{"color":"000000","size":""}]&backgroundColor=rgba(255,255,255,1)&colors[]=rgba(124, 181, 236, 1)&colors[]=rgba(67, 67, 72, 1)&colors[]=rgba(144, 237, 125, 1)&colors[]=rgba(247, 163, 92, 1)&colors[]=rgba(128, 133, 233, 1)&colors[]=rgba(241, 92, 128, 1)&colors[]=rgba(228, 211, 84, 1)&colors[]=rgba(43, 144, 143, 1)&colors[]=rgba(244, 91, 91, 1)&colors[]=rgba(145, 232, 225, 1)&xlinew=0&ylinew=1&legends=true&tooltips=true&persistent=false' ;
2018-03-16 16:56:35 +01:00
2019-07-22 11:16:50 +02:00
//stats tab charts
2020-05-08 17:04:24 +02:00
if ( this . properties . useNewStatistisTool ) {
this . chartScientificResultsUrl = this . properties . statisticsFrameNewAPIURL +
2020-05-11 15:52:21 +02:00
'chart?json=' + StringUtils . URIEncode ( '{"library":"HighCharts","chartDescription":{"queries":[{"name":"Research outcomes","type":"column","query":{"name":"projScient","parameters":["' + this . projectId + '"]}}],"chart":{"backgroundColor":"#FFFFFFFF","borderColor":"#335cadff","borderRadius":0,"borderWidth":0,"plotBorderColor":"#ccccccff","plotBorderWidth":0},"title":{"text":"Produced research outcomes per year"},"subtitle":{},"yAxis":{"title":{"text":"Research outcomes"}},"xAxis":{"title":{"text":"Year"}},"lang":{"noData":"No Data available for the Query"},"exporting":{"enabled":false},"plotOptions":{"series":{"dataLabels":{"enabled":false}}},"legend":{"enabled":true,"align":"center","verticalAlign":"bottom","layout":"horizontal"},"credits":{"href":null,"enabled":true,"text":"Created by OpenAIRE via HighCharts"}}}' ) ;
2020-05-08 17:04:24 +02:00
this . chartAccessModeUrl = this . properties . statisticsFrameNewAPIURL +
'chart?json=' + StringUtils . URIEncode (
2020-05-12 11:08:14 +02:00
'{"library":"HighCharts","chartDescription":{"queries":[{"name":"Research outcomes","type":"pie","query":{"name":"projOA","parameters":["' + this . projectId + '"]}}],"chart":{"backgroundColor":"#FFFFFFFF","borderColor":"#335cadff","borderRadius":0,"borderWidth":0,"plotBorderColor":"#ccccccff","plotBorderWidth":0},"title":{"text":"Access mode of research outcomes"},"subtitle":{},"yAxis":{"title":{"text":"Research outcomes"}},"xAxis":{"title":{"text":"Access mode"}},"lang":{"noData":"No Data available for the Query"},"exporting":{"enabled":false},"plotOptions":{"series":{"dataLabels":{"enabled":false}}},"legend":{"enabled":true,"align":"center","verticalAlign":"bottom","layout":"horizontal"},"credits":{"href":null,"enabled":true,"text":"Created by OpenAIRE via HighCharts"}}}' ) ;
2020-05-08 17:04:24 +02:00
this . chartDatasourcesUrl = this . properties . statisticsFrameNewAPIURL +
'chart?json=' + StringUtils . URIEncode (
2020-05-11 15:52:21 +02:00
'{"library":"HighCharts","chartDescription":{"queries":[{"name":"Research outcomes","type":"bar","query":{"name":"projPubsRepos","parameters":["' + this . projectId + '"]}}],"chart":{"backgroundColor":"#FFFFFFFF","borderColor":"#335cadff","borderRadius":0,"borderWidth":0,"plotBorderColor":"#ccccccff","plotBorderWidth":0},"title":{"text":"Research outcomes per datasource"},"subtitle":{},"yAxis":{"title":{"text":"Research outcomes"}},"xAxis":{"title":{"text":"Datasource"}},"lang":{"noData":"No Data available for the Query"},"exporting":{"enabled":false},"plotOptions":{"series":{"dataLabels":{"enabled":false}}},"legend":{"enabled":true,"align":"center","verticalAlign":"bottom","layout":"horizontal"},"credits":{"href":null,"enabled":true,"text":"Created by OpenAIRE via HighCharts"}}}' ) ;
2020-05-08 17:04:24 +02:00
} else {
this . chartScientificResultsUrl = this . properties . statisticsFrameAPIURL + 'chart.php?com=query&persistent=false&data={"query":"projScient","projTitle":"' + this . projectId + '", "table": "result", "fields": [{"fld": "number", "agg": "count", "type": "spline", "yaxis":1, "c":false}], "xaxis":{"name": "result_classifications-type", "agg": "avg"}, "group": "", "color": "", "type": "chart", "size":30, "sort": "xaxis", "xStyle":{"r": "-", "s": "-", "l": "-", "ft": "-", "wt": "-"}, "yaxisheaders": [""], "fieldsheaders": ["Research Outcomes"], "in": [], "filters": [{"name": "result_datasources-datasource-name", "values": [" "], "to": "-1"}], "having": [], "incfilters": [], "inchaving": [], "title": "", "subtitle": "", "xaxistitle": ""}&w=90%&h=90%' ;
this . chartAccessModeUrl = this . properties . statisticsFrameAPIURL + 'chart.php?com=query&persistent=false&data={"query":"projOA","projTitle":"' + this . projectId + '", "table": "result", "fields": [{"fld": "number", "agg": "count", "type": "pie", "yaxis":1, "c":false}], "xaxis":{"name": "result_classifications-type", "agg": "avg"}, "group": "", "color": "", "type": "chart", "size":30, "sort": "xaxis", "xStyle":{"r": "-", "s": "-", "l": "-", "ft": "-", "wt": "-"}, "yaxisheaders": [""], "fieldsheaders": ["Research Outcomes"], "in": [], "filters": [{"name": "result_datasources-datasource-name", "values": [" "], "to": "-1"}], "having": [], "incfilters": [], "inchaving": [], "title": "", "subtitle": "", "xaxistitle": ""}&w=90%&h=90%' ;
this . chartDatasourcesUrl = this . properties . statisticsFrameAPIURL + 'chart.php?com=query&persistent=false&data={"query":"projPubsRepos","projTitle":"' + this . projectId + '", "table": "result", "fields": [{"fld": "number", "agg": "count", "type": "bar", "yaxis":1, "c":false}], "xaxis":{"name": "result_classifications-type", "agg": "avg"}, "group": "", "color": "", "type": "chart", "size":30, "sort": "xaxis", "xStyle":{"r": "-", "s": "-", "l": "-", "ft": "-", "wt": "-"}, "yaxisheaders": [""], "fieldsheaders": ["Research Outcomes"], "in": [], "filters": [{"name": "result_datasources-datasource-name", "values": [" "], "to": "-1"}], "having": [], "incfilters": [], "inchaving": [], "title": "", "subtitle": "", "xaxistitle": ""}&w=90%&h=90%' ;
}
2018-03-16 16:56:35 +01:00
2019-07-22 11:16:50 +02:00
this . showLoading = false ;
}
2020-03-16 14:09:46 +01:00
public downloadCsvFile ( url : string , filename : string ) {
2019-07-22 11:16:50 +02:00
this . openLoading ( ) ;
this . setMessageLoading ( "Downloading CSV file" ) ;
this . _reportsService . downloadCSVFile ( url ) . subscribe (
data = > {
this . closeLoading ( ) ;
2020-03-16 14:09:46 +01:00
let url = window . URL . createObjectURL ( data ) ;
this . download ( url , filename + ".csv" ) ;
2019-07-22 11:16:50 +02:00
if ( this . properties . enablePiwikTrack && ( typeof document !== 'undefined' ) ) {
this . downloadFilePiwikSub = this . _piwikService . trackDownload ( this . properties , url ) . subscribe ( ) ;
}
} ,
error = > {
//console.log("Error downloading the file.");
this . handleError ( "Error downloading file: " + filename , error ) ;
this . closeLoading ( ) ;
2020-03-16 14:09:46 +01:00
this . confirmOpenFileDownloadError ( "CSV" ) ;
2019-07-22 11:16:50 +02:00
} / * ,
2019-02-14 11:44:30 +01:00
( ) = > console . log ( 'Completed file download.' ) * /
2019-07-22 11:16:50 +02:00
) ;
}
2017-12-19 13:53:46 +01:00
2019-07-22 11:16:50 +02:00
public metricsResults ( $event ) {
this . totalViews = $event . totalViews ;
this . totalDownloads = $event . totalDownloads ;
this . pageViews = $event . pageViews ;
}
2020-05-05 12:37:36 +02:00
public get hasMetrics ( ) : boolean {
return ! ( this . totalViews && this . totalDownloads && this . pageViews ) || this . totalViews > 0 || this . totalDownloads > 0 || this . pageViews > 0 ;
}
2017-12-19 13:53:46 +01:00
2020-03-16 14:09:46 +01:00
public openStatistics() {
this . statsClicked = true ;
this . statisticsModal . cancelButton = false ;
this . statisticsModal . okButton = false ;
this . statisticsModal . alertTitle = "Statistics of" ;
this . statisticsModal . open ( ) ;
}
2020-05-19 01:40:14 +02:00
public openLinkProjectModal() {
this . linkProjectModal . cancelButton = false ;
this . linkProjectModal . okButton = false ;
this . linkProjectModal . alertTitle = "Link this project to" ;
2020-05-20 18:45:50 +02:00
//this.linkProjectModal.alertHeader = false;
2020-05-19 01:40:14 +02:00
this . linkProjectModal . open ( ) ;
}
public openShareResultsModal() {
this . shareResultsModal . cancelButton = false ;
this . shareResultsModal . okButton = false ;
this . shareResultsModal . alertTitle = "Share results" ;
this . shareResultsModal . open ( ) ;
}
public openDownloadReportModal() {
this . downloadReportModal . cancelButton = false ;
this . downloadReportModal . okButton = false ;
this . downloadReportModal . alertTitle = "Download report" ;
this . downloadReportModal . open ( ) ;
}
2020-03-16 14:09:46 +01:00
private createHeaders ( type : string ) {
this . openLoading ( ) ;
this . setMessageLoading ( "Downloading HTML file" ) ;
if ( ! this . header1 ) {
this . createHeader1 ( ) ;
}
if ( type == "publications" ) {
this . header2 = this . fetchPublications . searchUtils . totalResults . toLocaleString ( 'en-US' ) + " publications" ;
} else if ( type == "datasets" ) {
this . header2 = this . fetchDatasets . searchUtils . totalResults . toLocaleString ( 'en-US' ) + " research data" ;
} else if ( type == "software" ) {
this . header2 = this . fetchSoftware . searchUtils . totalResults . toLocaleString ( 'en-US' ) + " software" ;
} else if ( type == "other" ) {
this . header2 = this . fetchOrps . searchUtils . totalResults . toLocaleString ( 'en-US' ) + " other research products" ;
} else if ( type == "results" ) {
let totalResults : number = ( + this . fetchPublications . searchUtils . totalResults ) +
( + this . fetchDatasets . searchUtils . totalResults ) +
( + this . fetchSoftware . searchUtils . totalResults ) +
( + this . fetchOrps . searchUtils . totalResults ) ;
this . header2 = totalResults . toLocaleString ( 'en-US' ) + " research outcomes" ;
}
}
private createHtmlFile ( type : string , filename : string ) {
let intro : string = '<!doctype html>' ;
intro += '<html lang="en-gb" dir="ltr" vocab="http://schema.org/">' ;
intro += '<head>' ;
intro += '<title>' + this . header1 + '</title>' ;
intro += '</head>' ;
if ( typeof window !== 'undefined' ) {
this . subHTML = this . htmlService . getHTML ( this . projectId , type , this . properties . csvAPIURL ) . subscribe (
data = > {
//console.info(data);
this . htmlResultDownload = intro + '<body><div>' + this . header1 + '</div><div><h4>' + this . header2 + '</h4></div>' ;
this . htmlResultDownload += "<table><thead><tr> <th>Type</th><th>Title</th><th>Authors</th><th>Publication Year</th><th>DOI</th><th>Permanent Identifier</th><th>Publication type</th><th>Journal</th><th>Project Name (GA Number)</th><th>Access Mode</th></tr></thead><tbody>" + data + "</tbody></table>" ;
this . htmlResultDownload += '</body></html>' ;
//console.info(this.htmlResultDownload);
this . closeLoading ( ) ;
let url = window . URL . createObjectURL ( new Blob ( [ this . htmlResultDownload ] , { type : 'text/html' } ) ) ;
this . download ( url , filename + ".html" ) ;
if ( this . properties . enablePiwikTrack && ( typeof document !== 'undefined' ) ) {
this . downloadHtmlFilePiwikSub = this . _piwikService . trackDownload ( this . properties , url ) . subscribe ( ) ;
}
} ,
err = > {
this . handleError ( "Error getting html for id: " + this . projectId , err ) ;
//this.errorMessage = 'Service not available';
this . closeLoading ( ) ;
this . confirmOpenFileDownloadError ( "HTML" ) ;
}
) ;
} else {
this . closeLoading ( ) ;
this . confirmOpenFileDownloadError ( "HTML" ) ;
}
}
downloadHtmlFile ( type : string , filename : string ) {
this . createHeaders ( type ) ;
this . createHtmlFile ( type , filename ) ;
}
createHeader1() {
// if (title != undefined && title != "") {
// this.header1 += title;
// }
// if ((title != undefined && title != "") &&
// ((acronym != undefined && acronym != "") ||
// (code != undefined && code != ""))) {
// this.header1 += "(";
// }
// if (acronym != undefined && acronym != "") {
// this.header1 += acronym + " - ";
// }
// if (code != undefined && code != "") {
// this.header1 += code;
// }
// if ((title != undefined && title != "") &&
// ((acronym != undefined && acronym != "") ||
// (code != undefined && code != ""))) {
// this.header1 += ")";
// }
this . header1 = "<div style=\"font-size:12px;\"><span>Project</span>" ;
if ( this . projectInfo . startDate || this . projectInfo . endDate ) {
this . header1 += "<span> . "
}
if ( this . projectInfo . startDate && ! this . projectInfo . endDate ) {
this . header1 += "from " ;
}
if ( ! this . projectInfo . startDate && this . projectInfo . endDate ) {
this . header1 += "until " ;
}
if ( this . projectInfo . startDate ) {
let startYear = ( new Date ( this . projectInfo . startDate ) ) . getFullYear ( ) ;
this . header1 += startYear ;
}
if ( this . projectInfo . startDate && this . projectInfo . endDate ) {
this . header1 += " - " ;
}
if ( this . projectInfo . endDate ) {
let endYear = ( new Date ( this . projectInfo . endDate ) ) . getFullYear ( ) ;
this . header1 += endYear ;
}
if ( this . projectInfo . startDate || this . projectInfo . endDate ) {
this . header1 += "</span>"
}
if ( this . projectInfo . status ) {
this . header1 += "<span> . " + this . projectInfo . status + "</span>" ;
}
if ( this . projectInfo . funding && this . projectInfo . funding . code ) {
this . header1 += "<span> . " + this . projectInfo . funding . code + "</span>" ;
}
this . header1 += "</div>" ;
this . header1 += "<h1 style=\"margin:0;\"><div><a href=\"" + window . location . href + "\">" ;
if ( this . projectInfo . acronym ) {
this . header1 += this . projectInfo . acronym ;
} else {
this . header1 += "[no title available]" ;
}
this . header1 += "</a></div></h2>" ;
//<showTitle [titleName]="title" classNames="uk-margin-remove-bottom"></showTitle>
if ( this . projectInfo . title ) {
this . header1 += "<div><span>" + this . projectInfo . title + "</span></div>" ;
}
}
public download ( url , filename ) {
//var url = window.URL.createObjectURL(new Blob([this.htmlResultDownload], { type: 'text/html' }));
var a = window . document . createElement ( 'a' ) ;
window . document . body . appendChild ( a ) ;
a . setAttribute ( 'style' , 'display: none' ) ;
a . href = url ;
a . download = filename ;
a . click ( ) ;
window . URL . revokeObjectURL ( url ) ;
a . remove ( ) ; // remove the element
}
// copyToClipboard(element: HTMLElement) {
// if (typeof document !== 'undefined') {
// if (window.getSelection) {
// const selection = window.getSelection();
// const range = document.createRange();
// range.selectNodeContents(element);
// selection.removeAllRanges();
// selection.addRange(range);
// document.execCommand('copy');
// } else {
// console.warn("Could not select text in node: Unsupported browser.");
// }
// }
// }
2020-05-19 01:40:14 +02:00
public onSelectActiveTab ( activeTabId ) {
2020-05-20 22:34:29 +02:00
if ( this . activeTab != activeTabId ) { // tab really changed
2020-05-19 01:40:14 +02:00
if ( activeTabId == 'summary' ) {
this . activeTab = 'summary' ;
} else if ( activeTabId == 'publications' ) {
this . activeTab = 'publications' ;
this . searchPublicationsInit ( ) ;
} else if ( activeTabId == 'datasets' ) {
this . activeTab = 'datasets' ;
this . searchDatasetsInit ( ) ;
} else if ( activeTabId == 'software' ) {
this . activeTab = 'software' ;
this . searchSoftwareInit ( ) ;
} else if ( activeTabId == 'other' ) {
this . activeTab = "other" ;
this . searchOrpsInit ( ) ;
} else if ( activeTabId == 'statistics' ) {
this . activeTab = 'statistics' ;
this . statsClicked = true ;
}
}
}
2019-07-22 11:16:50 +02:00
private updateDescription ( description : string ) {
2019-12-05 17:07:07 +01:00
this . _meta . updateTag ( { content : description.substring ( 0 , 160 ) } , "name='description'" ) ;
this . _meta . updateTag ( { content : description.substring ( 0 , 160 ) } , "property='og:description'" ) ;
2019-07-22 11:16:50 +02:00
}
2017-12-19 13:53:46 +01:00
2019-07-22 11:16:50 +02:00
private updateTitle ( title : string ) {
2019-08-02 16:55:32 +02:00
var _prefix = "" ;
2019-12-05 17:07:07 +01:00
// if(!this.communityId) {
// _prefix = "OpenAIRE | ";
// }
// var _title = _prefix + ((title.length > 50) ? title.substring(0, 50) : title);
this . _title . setTitle ( title ) ;
this . _meta . updateTag ( { content : title } , "property='og:title'" ) ;
2019-07-22 11:16:50 +02:00
}
2017-12-19 13:53:46 +01:00
2019-07-22 11:16:50 +02:00
private updateUrl ( url : string ) {
this . _meta . updateTag ( { content : url } , "property='og:url'" ) ;
}
private openLoading() {
if ( this . loading ) {
this . loading . open ( ) ;
2017-12-19 13:53:46 +01:00
}
2019-07-22 11:16:50 +02:00
}
2017-12-19 13:53:46 +01:00
2019-07-22 11:16:50 +02:00
private closeLoading() {
if ( this . loading ) {
this . loading . close ( ) ;
2017-12-19 13:53:46 +01:00
}
2019-07-22 11:16:50 +02:00
}
2019-02-15 13:50:24 +01:00
2019-07-22 11:16:50 +02:00
private setMessageLoading ( message : string ) {
if ( this . loading ) {
this . loading . message = message ;
2019-02-15 13:50:24 +01:00
}
2019-07-22 11:16:50 +02:00
}
2020-03-16 14:09:46 +01:00
public confirmOpenFileDownloadError ( fileType : string ) {
2019-07-22 11:16:50 +02:00
this . alertCsvError . cancelButton = false ;
this . alertCsvError . okButton = true ;
2020-03-16 14:09:46 +01:00
this . alertCsvError . alertTitle = "ERROR DOWNLOADING " + fileType + " FILE" ;
2019-07-22 11:16:50 +02:00
this . alertCsvError . message = "There was an error in csv downloading. Please try again later." ;
this . alertCsvError . okButtonText = "OK" ;
this . alertCsvError . open ( ) ;
}
private handleError ( message : string , error ) {
console . error ( "Project Landing Page: " + message , error ) ;
}
isRouteAvailable ( routeToCheck : string ) {
2020-03-16 14:09:46 +01:00
for ( let i = 0 ; i < this . _router . config . length ; i ++ ) {
let routePath : string = this . _router . config [ i ] . path ;
2019-07-22 11:16:50 +02:00
if ( routePath == routeToCheck ) {
2019-06-12 16:13:56 +02:00
return true ;
}
}
return false ;
}
2020-05-19 01:40:14 +02:00
private getEntityName ( entityType :string , plural :boolean , full :boolean ) : string {
if ( entityType == "publication" ) {
return "publication" + ( plural ? "s" : "" ) ;
} else if ( entityType == "dataset" ) {
return ( full ? "research data" : ( "dataset" + ( plural ? "s" : "" ) ) ) ;
} else if ( entityType == "software" ) {
return "software" ;
} else if ( entityType == "other" ) {
return ( full ? ( "other research product" + ( plural ? "s" : "" ) ) : "other" ) ;
} else if ( entityType == "dataprovider" ) {
return ( full ? ( "content provider" + ( plural ? "s" : "" ) ) : "dataprovider" + ( plural ? "s" : "" ) ) ;
} else {
return entityType + ( plural ? "s" : "" ) ;
}
}
2020-05-19 17:59:20 +02:00
public getResultPreview ( result : SearchResult , type : string ) : ResultPreview {
return ResultPreview . searchResultConvert ( result , type ) ;
}
2020-05-20 22:48:32 +02:00
public scroll() {
HelperFunctions . scroll ( ) ;
}
2017-12-19 13:53:46 +01:00
}