import {Component, ElementRef, Input} from '@angular/core'; import {ActivatedRoute} from '@angular/router'; import {Citation, CitationData} from './citation.class'; declare var CSL:any; declare var Sys:any; // @Component({ selector: 'citeThis', template: `
` }) export class CiteThisComponent { private sub:any; public selectedStyle:string="0"; public citationText:string; public citation:Citation = new Citation(); // public cite: any; @Input() result: any; @Input() id: string; @Input() type: string="article"; public citeproc; public data; constructor(private route: ActivatedRoute) { // this.selectedStyle = this.citation.templates[0]; } ngOnInit() { if(typeof window !== 'undefined') { // this.citeproc = require('./citeproc.js'); // console.log(this.citeproc); this.parseData(); this.updateCitation(); } } parseData(){ var citationData:CitationData = new CitationData(); if(this.result.identifiers && Array.from(this.result.identifiers.keys()).length > 0){ var keys = Array.from(this.result.identifiers.keys()); for (var i=0; i 0 && this.result.types[0]){ citationData.type = this.result.types[0].toLowerCase(); }else if(this.result.type != undefined ){ citationData.type = this.result.type.toLowerCase(); } if(this.result.title && this.result.title.name){ citationData.title = this.result.title.name; } if(this.result.journal && this.result.journal.journal){ citationData["container-title"] = this.result.journal.journal; } if(this.result.publisher){ citationData.publisher = this.result.publisher; } if( this.result.authors){ citationData.author = []; var max_length = (this.result.authors.length > 10)?10:this.result.authors.length; for (var i =0 ;i < max_length; i++){ if(this.result.authors[i] && this.result.authors[i].fullName && this.result.authors[i].fullName.indexOf(", ") !== -1){ citationData.author.push({given:this.result.authors[i].fullName.split(", ")[0], family:this.result.authors[i].fullName.split(", ")[1], 'parse-names':true}); }else{ citationData.author.push({given:"", family:this.result.authors[i].fullName, 'parse-names':true}); } // citationData.authors.push(this.result.authors[i]); } } if(this.result.dateofacceptance != undefined){ citationData.issued = {}; var date:string = (this.result.dateofacceptance)+""; // transform to string in case it is an integer var dateArray:string[] = (date && (date).indexOf('-') !== -1)?[date.split('-')[0]]:[date]; if(dateArray.length < 3){ // dateArray.push[1]; // dateArray.push[1]; } citationData.issued={"date-parts":[[""+dateArray[0]]]}; if(this.result.date ){ citationData.date = this.result.date ; } if(this.result.journal ){ citationData.type = "article-journal"; // in case of APA volume and pages appear only in specific types not just article if(this.result.journal.volume){ citationData.volume = this.result.journal.volume ; } if(this.result.journal["start_page"] && this.result.journal["end_page"]){ citationData.page = this.result.journal["start_page"] +"-" +this.result.journal["end_page"] ; } } } this.data = citationData; // console.log(this.data); } styleChanged(){ this.updateCitation(); } updateCitation(){ var Sys = function Sys(lang, data){ this.lang = lang; this.data = data; this.changeName = function (name) { this.lastName = name; }; this.retrieveLocale= function (lang){ return this.lang; } this.retrieveItem= function(id){ return this.data; } }; var citeproc = new CSL.Engine(new Sys(this.citation.locale, this.data ), this.citation[(this.selectedStyle == "0")?this.citation.templates[0]:this.selectedStyle]); citeproc.updateItems([this.data.id]); this.citationText = citeproc.makeBibliography(); this.citationText = ((this.citationText != null) && (this.citationText.length > 1) && (this.citationText[1].length > 0)) ? this.citationText[1][0] : ''; } }