[Trunk | Library] : Bug Fix: title of Project Publications csv, now always on top.

git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@56268 d315682c-612b-4755-9ff5-7f18f6832af3
This commit is contained in:
konstantina.galouni 2019-06-28 10:48:52 +00:00
parent 3405681ac7
commit 5fbcd7bf7d
1 changed files with 85 additions and 122 deletions

View File

@ -360,6 +360,7 @@ export class OrganizationComponent {
let projects = []; let projects = [];
let counter: number = count; let counter: number = count;
let title: boolean = false; let title: boolean = false;
let title_index: number = 0;
let filename: string = 'funder-project-publications-report'; let filename: string = 'funder-project-publications-report';
@ -371,26 +372,23 @@ export class OrganizationComponent {
this.countPublSub = this._searchPublicationsService.numOfEntityPublications(projects[index].id, "project", this.properties).subscribe( this.countPublSub = this._searchPublicationsService.numOfEntityPublications(projects[index].id, "project", this.properties).subscribe(
data => data =>
{ {
// let index: number = this.organizationInfo.projects.get(funder).indexOf(project); //if(data == 0 && title) { // if no publications for this project
let url: string;
if(!title) {
//url = this.downloadURLAPI+"projects/"+projects[index].id+"?type=publications&format=csv-special";//&size="+data;
url = this.downloadURLAPI+"?format=csv-special&type=publications&fq=(((oaftype exact result) and (resulttypeid exact publication)) and (relprojectid exact \""+projects[index].id+"\"))"
} else {
//url = this.downloadURLAPI+"projects/"+projects[index].id+"/publications?format=csv-special-notitle";//&size="+data;
url = this.downloadURLAPI+"?format=csv-special-notitle&type=publications&fq=(((oaftype exact result) and (resulttypeid exact publication)) and (relprojectid exact \""+projects[index].id+"\"))"
}
if(data == 0 && (counter > 1 || title)) { // if no publications for this project if(data == 0 && (counter > 1 || title)) { // if no publications for this project
counter--; counter--;
response[index] = ""; response[index] = "";
//console.info("index: "+index, "counter: "+counter, "id:"+projects[index].id, response[index]);
if(counter == 0) { if(counter == 0) {
for(let i=0; i<count; i++) { //for(let i=count-1; i>=0; i--) {
for(let i=0; i < projects.length; i++) {
if(response[i] != "") { if(response[i] != "") {
if(i == title_index) {
totalResponse = response[i]+totalResponse;
} else {
totalResponse += response[i]; totalResponse += response[i];
} }
} }
}
this.closeLoading(); this.closeLoading();
var csvurl = window.URL.createObjectURL(new Blob([totalResponse], { type: 'text/csv' })); var csvurl = window.URL.createObjectURL(new Blob([totalResponse], { type: 'text/csv' }));
@ -402,13 +400,16 @@ export class OrganizationComponent {
a.click(); a.click();
window.URL.revokeObjectURL(csvurl); window.URL.revokeObjectURL(csvurl);
a.remove(); // remove the element a.remove(); // remove the element
//window.open(window.URL.createObjectURL(new Blob([totalResponse], { type: 'text/csv' })));
// if(this.properties.enablePiwikTrack && (typeof document !== 'undefined')){
// this._piwikService.trackDownload(this.properties, url).subscribe();
// }
} }
} else { } else {
let url: string;
if(!title) {
title_index = index;
//console.info(title_index);
url = this.downloadURLAPI+"?format=csv-special&type=publications&fq=(((oaftype exact result) and (resulttypeid exact publication)) and (relprojectid exact \""+projects[index].id+"\"))"
} else {
url = this.downloadURLAPI+"?format=csv-special-notitle&type=publications&fq=(((oaftype exact result) and (resulttypeid exact publication)) and (relprojectid exact \""+projects[index].id+"\"))"
}
title = true; title = true;
this.downloadProjectPublSub = this._reportsService.getCSVResponse(url).subscribe( this.downloadProjectPublSub = this._reportsService.getCSVResponse(url).subscribe(
@ -416,13 +417,19 @@ export class OrganizationComponent {
{ {
counter--; counter--;
response[index] = data; response[index] = data;
//console.info("index: "+index, "counter: "+counter, "id:"+projects[index].id, response[index]);
if(counter == 0) { if(counter == 0) {
for(let i=0; i<count; i++) { //for(let i=count-1; i>=0; i--) {
for(let i=0; i < projects.length; i++) {
if(response[i] != "") { if(response[i] != "") {
if(i == title_index) {
totalResponse = response[i]+totalResponse;
} else {
totalResponse += response[i]; totalResponse += response[i];
} }
} }
}
this.closeLoading(); this.closeLoading();
var csvurl = window.URL.createObjectURL(new Blob([totalResponse], { type: 'text/csv' })); var csvurl = window.URL.createObjectURL(new Blob([totalResponse], { type: 'text/csv' }));
@ -434,15 +441,9 @@ export class OrganizationComponent {
a.click(); a.click();
window.URL.revokeObjectURL(csvurl); window.URL.revokeObjectURL(csvurl);
a.remove(); // remove the element a.remove(); // remove the element
//window.open(window.URL.createObjectURL(new Blob([totalResponse], { type: 'text/csv' })));
// if(this.properties.enablePiwikTrack && (typeof document !== 'undefined')){
// this._piwikService.trackDownload(this.properties, url).subscribe();
// }
} }
}, },
err => { err => {
//console.log("Error downloading the file.");
this.handleError("Error downloading file: "+filename, err); this.handleError("Error downloading file: "+filename, err);
this.closeLoading(); this.closeLoading();
@ -453,55 +454,17 @@ export class OrganizationComponent {
} }
}, },
err => { err => {
//console.log("Error getting number of publications for project.")
this.handleError("Error getting number of publications for project with id: "+projects[index].id, err); this.handleError("Error getting number of publications for project with id: "+projects[index].id, err);
}); });
}//); }
}, },
err => { err => {
//console.log("Error getting projects project.");
this.handleError("Error getting projects for organization with id: "+this.organizationId, err); this.handleError("Error getting projects for organization with id: "+this.organizationId, err);
this.closeLoading(); this.closeLoading();
this.confirmOpenCsvError(); this.confirmOpenCsvError();
} }
); );
// let counter: number = this.organizationInfo.projects.get(funder).length;
//
// for(let project of this.organizationInfo.projects.get(funder)) {
// this._searchPublicationsService.numOfEntityPublications(project.id, "projects/").subscribe(
// data =>
// {
// let index: number = this.organizationInfo.projects.get(funder).indexOf(project);
//
// let url: string;
// if(index == 0) {
// url = this.downloadURLAPI+"projects/"+project.id+"/publications?format=csv-special&size="+data;
// } else {
// url = this.downloadURLAPI+"projects/"+project.id+"/publications?format=csv-special-notitle&size="+data;
// }
//
// this._reportsService.getCSVResponse(url).subscribe(
// data =>
// {
// counter--;
//
// response[index] = data;
//
// if(counter == 0) {
// for(let i=0; i<this.organizationInfo.projects.get(funder).length; i++) {
// totalResponse += response[i]+"\n";
// }
// window.open(window.URL.createObjectURL(new Blob([totalResponse], { type: 'text/csv' })));
// }
// },
// error => console.log("Error downloading the file."),
// () => console.log('Completed file download.'));
// },
// error => console.log("Error getting number of publications for project."));
// }//);
} }
private updateDescription(description:string) { private updateDescription(description:string) {