2022-11-11 18:02:50 +01:00
import $ from 'jquery' ;
const { pageData } = window . config ;
2023-12-12 19:31:11 +08:00
async function initInputCitationValue ( $citationCopyApa , $citationCopyBibtex ) {
2022-11-11 18:02:50 +01:00
const [ { Cite , plugins } ] = await Promise . all ( [
import ( /* webpackChunkName: "citation-js-core" */ '@citation-js/core' ) ,
import ( /* webpackChunkName: "citation-js-formats" */ '@citation-js/plugin-software-formats' ) ,
import ( /* webpackChunkName: "citation-js-bibtex" */ '@citation-js/plugin-bibtex' ) ,
2022-11-13 21:10:58 +01:00
import ( /* webpackChunkName: "citation-js-csl" */ '@citation-js/plugin-csl' ) ,
2022-11-11 18:02:50 +01:00
] ) ;
const { citationFileContent } = pageData ;
const config = plugins . config . get ( '@bibtex' ) ;
config . constants . fieldTypes . doi = [ 'field' , 'literal' ] ;
config . constants . fieldTypes . version = [ 'field' , 'literal' ] ;
const citationFormatter = new Cite ( citationFileContent ) ;
const lang = document . documentElement . lang || 'en-US' ;
const apaOutput = citationFormatter . format ( 'bibliography' , { template : 'apa' , lang } ) ;
const bibtexOutput = citationFormatter . format ( 'bibtex' , { lang } ) ;
$citationCopyBibtex . attr ( 'data-text' , bibtexOutput ) ;
$citationCopyApa . attr ( 'data-text' , apaOutput ) ;
2023-12-12 19:31:11 +08:00
}
2022-11-11 18:02:50 +01:00
2023-12-12 19:31:11 +08:00
export async function initCitationFileCopyContent ( ) {
2022-11-11 18:02:50 +01:00
const defaultCitationFormat = 'apa' ; // apa or bibtex
if ( ! pageData . citationFileContent ) return ;
const $citationCopyApa = $ ( '#citation-copy-apa' ) ;
const $citationCopyBibtex = $ ( '#citation-copy-bibtex' ) ;
const $inputContent = $ ( '#citation-copy-content' ) ;
if ( ( ! $citationCopyApa . length && ! $citationCopyBibtex . length ) || ! $inputContent . length ) return ;
const updateUi = ( ) => {
const isBibtex = ( localStorage . getItem ( 'citation-copy-format' ) || defaultCitationFormat ) === 'bibtex' ;
const copyContent = ( isBibtex ? $citationCopyBibtex : $citationCopyApa ) . attr ( 'data-text' ) ;
$inputContent . val ( copyContent ) ;
$citationCopyBibtex . toggleClass ( 'primary' , isBibtex ) ;
$citationCopyApa . toggleClass ( 'primary' , ! isBibtex ) ;
} ;
2023-12-12 19:31:11 +08:00
try {
await initInputCitationValue ( $citationCopyApa , $citationCopyBibtex ) ;
} catch ( e ) {
console . error ( ` initCitationFileCopyContent error: ${ e } ` , e ) ;
return ;
}
updateUi ( ) ;
2022-11-11 18:02:50 +01:00
$citationCopyApa . on ( 'click' , ( ) => {
localStorage . setItem ( 'citation-copy-format' , 'apa' ) ;
updateUi ( ) ;
} ) ;
$citationCopyBibtex . on ( 'click' , ( ) => {
localStorage . setItem ( 'citation-copy-format' , 'bibtex' ) ;
updateUi ( ) ;
} ) ;
$inputContent . on ( 'click' , ( ) => {
2023-04-20 18:28:27 +09:00
$inputContent . trigger ( 'select' ) ;
2022-11-11 18:02:50 +01:00
} ) ;
$ ( '#cite-repo-button' ) . on ( 'click' , ( ) => {
$ ( '#cite-repo-modal' ) . modal ( 'show' ) ;
} ) ;
}