aboutsummaryrefslogtreecommitdiffstats
path: root/web_src/js/render/pdf.ts
blob: 283b4ed85c9334d949c5346edf1dbce9164ce242 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import {htmlEscape} from 'escape-goat';
import {registerGlobalInitFunc} from '../modules/observer.ts';

export async function initPdfViewer() {
  registerGlobalInitFunc('initPdfViewer', async (el: HTMLInputElement) => {
    const pdfobject = await import(/* webpackChunkName: "pdfobject" */'pdfobject');

    const src = el.getAttribute('data-src');
    const fallbackText = el.getAttribute('data-fallback-button-text');
    pdfobject.embed(src, el, {
      fallbackLink: htmlEscape`
        <a role="button" class="ui basic button pdf-fallback-button" href="[url]">${fallbackText}</a>
      `,
    });
    el.classList.remove('is-loading');
  });
}