gitea源码

citation.ts 3.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import {getCurrentLocale} from '../utils.ts';
  2. import {fomanticQuery} from '../modules/fomantic/base.ts';
  3. const {pageData} = window.config;
  4. async function initInputCitationValue(citationCopyApa: HTMLButtonElement, citationCopyBibtex: HTMLButtonElement) {
  5. const [{Cite, plugins}] = await Promise.all([
  6. // @ts-expect-error: module exports no types
  7. import(/* webpackChunkName: "citation-js-core" */'@citation-js/core'),
  8. // @ts-expect-error: module exports no types
  9. import(/* webpackChunkName: "citation-js-formats" */'@citation-js/plugin-software-formats'),
  10. // @ts-expect-error: module exports no types
  11. import(/* webpackChunkName: "citation-js-bibtex" */'@citation-js/plugin-bibtex'),
  12. // @ts-expect-error: module exports no types
  13. import(/* webpackChunkName: "citation-js-csl" */'@citation-js/plugin-csl'),
  14. ]);
  15. const {citationFileContent} = pageData;
  16. const config = plugins.config.get('@bibtex');
  17. config.constants.fieldTypes.doi = ['field', 'literal'];
  18. config.constants.fieldTypes.version = ['field', 'literal'];
  19. const citationFormatter = new Cite(citationFileContent);
  20. const lang = getCurrentLocale() || 'en-US';
  21. const apaOutput = citationFormatter.format('bibliography', {template: 'apa', lang});
  22. const bibtexOutput = citationFormatter.format('bibtex', {lang});
  23. citationCopyBibtex.setAttribute('data-text', bibtexOutput);
  24. citationCopyApa.setAttribute('data-text', apaOutput);
  25. }
  26. export async function initCitationFileCopyContent() {
  27. const defaultCitationFormat = 'apa'; // apa or bibtex
  28. if (!pageData.citationFileContent) return;
  29. const citationCopyApa = document.querySelector<HTMLButtonElement>('#citation-copy-apa');
  30. const citationCopyBibtex = document.querySelector<HTMLButtonElement>('#citation-copy-bibtex');
  31. const inputContent = document.querySelector<HTMLInputElement>('#citation-copy-content');
  32. if ((!citationCopyApa && !citationCopyBibtex) || !inputContent) return;
  33. const updateUi = () => {
  34. const isBibtex = (localStorage.getItem('citation-copy-format') || defaultCitationFormat) === 'bibtex';
  35. const copyContent = (isBibtex ? citationCopyBibtex : citationCopyApa).getAttribute('data-text');
  36. inputContent.value = copyContent;
  37. citationCopyBibtex.classList.toggle('primary', isBibtex);
  38. citationCopyApa.classList.toggle('primary', !isBibtex);
  39. };
  40. document.querySelector('#cite-repo-button')?.addEventListener('click', async () => {
  41. try {
  42. await initInputCitationValue(citationCopyApa, citationCopyBibtex);
  43. } catch (e) {
  44. console.error(`initCitationFileCopyContent error: ${e}`, e);
  45. return;
  46. }
  47. updateUi();
  48. citationCopyApa.addEventListener('click', () => {
  49. localStorage.setItem('citation-copy-format', 'apa');
  50. updateUi();
  51. });
  52. citationCopyBibtex.addEventListener('click', () => {
  53. localStorage.setItem('citation-copy-format', 'bibtex');
  54. updateUi();
  55. });
  56. inputContent.addEventListener('click', () => {
  57. inputContent.select();
  58. });
  59. fomanticQuery('#cite-repo-modal').modal('show');
  60. });
  61. }