diff options
Diffstat (limited to 'services/blog/static/slide.js')
| -rw-r--r-- | services/blog/static/slide.js | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/services/blog/static/slide.js b/services/blog/static/slide.js new file mode 100644 index 00000000..4c7a0de8 --- /dev/null +++ b/services/blog/static/slide.js @@ -0,0 +1,60 @@ +import { GlobalWorkerOptions, getDocument } from "/pdf.min.mjs"; + +document.addEventListener("DOMContentLoaded", async () => { + GlobalWorkerOptions.workerSrc = "/pdf.worker.min.mjs"; + + const canvas = document.getElementById("slide"); + const ctx = canvas.getContext("2d"); + const url = canvas.dataset.slideLink; + + let pageNum = 1; + let pageNumPending = null; + let pageRendering = false; + let doc = null; + + const renderPage = async (num) => { + pageRendering = true; + const page = await doc.getPage(num); + + const viewport = page.getViewport({ scale: 1.0 }); + canvas.height = viewport.height; + canvas.width = viewport.width; + + // TODO: error handling + await page.render({ + canvasContext: ctx, + viewport: viewport, + }); + + pageRendering = false; + if (pageNumPending !== null) { + renderPage(pageNumPending); + pageNumPending = null; + } + }; + + const queueRenderPage = (num) => { + if (pageRendering) { + pageNumPending = num; + } else { + renderPage(num); + } + }; + + const prev = document.getElementById("prev"); + prev.addEventListener("click", () => { + if (pageNum <= 1) return; + pageNum--; + queueRenderPage(pageNum); + }); + const next = document.getElementById("next"); + next.addEventListener("click", () => { + if (pageNum >= doc.numPages) return; + pageNum++; + queueRenderPage(pageNum); + }); + + // TODO: error handling + doc = await getDocument(url).promise; + queueRenderPage(pageNum); +}); |
