import { Component, OnInit } from '@angular/core'; import { ActivatedRoute, Router } from '@angular/router'; import { MetricsInfo, PiwikInfo } from '../../../domain/typeScriptClasses'; import { PiwikService } from '../../../services/piwik.service'; import { RepositoryService } from '../../../services/repository.service'; import { loadingMetrics, loadingMetricsError } from '../../../domain/shared-messages'; import { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser'; import { AuthenticationService } from '../../../services/authentication.service'; import { SharedService } from "../../../services/shared.service"; @Component ({ selector: 'metrics-show', templateUrl: 'metrics-show.component.html' }) export class MetricsShowComponent implements OnInit { errorMessage: string; loadingMessage: string; repoId: string; piwik: PiwikInfo; repoMetrics: MetricsInfo; pageViews = '--'; totalViews = '--'; totalDownloads = '--'; viewsUrl: SafeResourceUrl; downloadsUrl: SafeResourceUrl; constructor( private route: ActivatedRoute, private router: Router, private sanitizer: DomSanitizer, private piwikService: PiwikService, private repoService: RepositoryService, private authService: AuthenticationService, private sharedService: SharedService) {} ngOnInit() { if(this.sharedService.getRepository()) { this.repoId = this.sharedService.getRepository().id; this.piwik = this.sharedService.getRepository().piwikInfo; this.getMetrics(); } this.sharedService.repository$.subscribe( r => { this.repoId = r.id; this.piwik = r.piwikInfo; this.getMetrics(); } ); let body = document.getElementsByTagName('body')[0]; body.classList.remove("top_bar_active"); //remove the class body.classList.remove("page_heading_active"); body.classList.remove("landing"); body.classList.add("dashboard"); } getMetrics() { this.loadingMessage = loadingMetrics; this.repoService.getMetricsInfoForRepository(this.repoId).subscribe( metrics => { this.repoMetrics = metrics; if (this.repoMetrics.metricsNumbers.pageviews) { this.pageViews = this.repoMetrics.metricsNumbers.pageviews; } if (this.repoMetrics.metricsNumbers.total_views) { this.totalViews = this.repoMetrics.metricsNumbers.total_views; } if (this.repoMetrics.metricsNumbers.total_downloads) { this.totalDownloads = this.repoMetrics.metricsNumbers.total_downloads; } this.getViewsUrl(); this.getDownloadsUrl(); }, error => { this.loadingMessage = ''; this.errorMessage = loadingMetricsError; console.log(error); }, () => { this.loadingMessage = ''; this.errorMessage = ''; } ); } getViewsUrl () { let encodedURL = encodeURIComponent('{"library":"HighCharts","chartDescription":{"queries":[{"name":"Monthly views","type":"line","query":{"name":"usagestats.views.monthly", "parameters":["' + this.piwik.openaireId + '"], "profile":"OpenAIRE All-inclusive" }}],"chart":{"backgroundColor":"#FFFFFFFF","borderColor":"#335cadff","borderRadius":0,"borderWidth":0,"plotBorderColor":"#ccccccff","plotBorderWidth":0},"title":{"text":""},"subtitle":{},"yAxis":{"title":{"text":"Monthly views"}},"xAxis":{"title":{}},"lang":{"noData":"No Data available for the Query"},"exporting":{"enabled":false},"plotOptions":{"series":{"dataLabels":{"enabled":false}}},"legend":{"enabled":false},"credits":{"href":null,"enabled":true,"text":"Created by OpenAIRE via HighCharts"}}}'); this.viewsUrl = this.sanitizer.bypassSecurityTrustResourceUrl(`${this.repoMetrics.diagramsBaseURL}chart?json=${encodedURL}`); // this.viewsUrl = this.sanitizer.bypassSecurityTrustResourceUrl( // `${this.repoMetrics.diagramsBaseURL}merge.php?com=query // &data=[{"query":"dtsrcRepoViews","dtsrcName":"${this.piwik.openaireId}", // "table":"","fields":[{"fld":"sum","agg":"sum","type":"chart","yaxis":1,"c":false}], // "xaxis":{"name":"month","agg":"sum"},"group":"","color":"","type":"chart","size":30, // "sort":"xaxis","xStyle":{"r":-30,"s":"0","l":"-","ft":"-","wt":"-"},"title":"","subtitle":"", // "xaxistitle":"","yaxisheaders":["Monthly views"],"generalxaxis":"","theme":0,"in":[]}] // &info_types=["spline"]&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` // ); } getDownloadsUrl () { let encodedURL = encodeURIComponent('{"library":"HighCharts","chartDescription":{"queries":[{"name":"Monthly downloads","type":"line","query":{"name":"usagestats.downloads.monthly", "parameters":["' + this.piwik.openaireId + '"], "profile":"OpenAIRE All-inclusive" }}],"chart":{"backgroundColor":"#FFFFFFFF","borderColor":"#335cadff","borderRadius":0,"borderWidth":0,"plotBorderColor":"#ccccccff","plotBorderWidth":0},"title":{"text":""},"subtitle":{},"yAxis":{"title":{"text":"Monthly downloads"}},"xAxis":{"title":{}},"lang":{"noData":"No Data available for the Query"},"exporting":{"enabled":false},"plotOptions":{"series":{"dataLabels":{"enabled":false}}},"legend":{"enabled":false},"credits":{"href":null,"enabled":true,"text":"Created by OpenAIRE via HighCharts"}}}'); this.downloadsUrl = this.sanitizer.bypassSecurityTrustResourceUrl(`${this.repoMetrics.diagramsBaseURL}chart?json=${encodedURL}`); // this.downloadsUrl = this.sanitizer.bypassSecurityTrustResourceUrl( // `${this.repoMetrics.diagramsBaseURL}merge.php?com=query // &data=[{"query":"dtsrcRepoDownloads","dtsrcName":"${this.piwik.openaireId}", // "table":"","fields":[{"fld":"sum","agg":"sum","type":"chart","yaxis":1,"c":false}], // "xaxis":{"name":"month","agg":"sum"},"group":"","color":"","type":"chart","size":30, // "sort":"xaxis","xStyle":{"r":-30,"s":"0","l":"-","ft":"-","wt":"-"},"title":"","subtitle":"", // "xaxistitle":"","yaxisheaders":["Monthly downloads"],"generalxaxis":"","theme":0,"in":[]}] // &info_types=["spline"]&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` // ); } }