remove jquery all together

This commit is contained in:
Aaron Qian 2023-01-04 18:12:39 -08:00
parent b0f5b0b059
commit 8580a1f463
No known key found for this signature in database
GPG key ID: BF1A987C395B5B0E
61 changed files with 4113 additions and 684 deletions

View file

@ -1,171 +1,165 @@
import { insertScript } from '../../core';
import { insertScript } from '../../core'
const PDFJS_BUNDLE = "https://cdn.jsdelivr.net/npm/pdfjs-dist@3.0.279/build/pdf.min.js";
const WORKER_BUNDLE = "https://cdn.jsdelivr.net/npm/pdfjs-dist@3.0.279/build/pdf.worker.min.js";
const PDFJS_BUNDLE = 'https://cdn.jsdelivr.net/npm/pdfjs-dist@3.0.279/build/pdf.min.js'
const WORKER_BUNDLE = 'https://cdn.jsdelivr.net/npm/pdfjs-dist@3.0.279/build/pdf.worker.min.js'
class PDFViewer {
constructor(el) {
constructor (el) {
const {
url,
hidePaginator,
hideLoader,
scale,
pageNum
} = el.dataset;
} = el.dataset
if(url == null) {
throw new Error('Cannot load PDF! Attribute `data-url` is not set.');
if (url == null) {
throw new Error('Cannot load PDF! Attribute `data-url` is not set.')
}
// props
this.url = url;
this.hidePaginator = hidePaginator !== 'false';
this.hideLoader = hideLoader !== 'false';
this.scale = scale || 3;
this.url = url
this.hidePaginator = hidePaginator !== 'false'
this.hideLoader = hideLoader !== 'false'
this.scale = scale || 3
// initial state
this.pageNum = parseInt(pageNum ,10) || 1;
this.loaded = false;
this.pageRendering = false;
this.pageNumPending = null;
this.pageNum = parseInt(pageNum, 10) || 1
this.loaded = false
this.pageRendering = false
this.pageNumPending = null
// DOM elements
this.$canvas = el.getElementsByClassName('pdf-canvas')[0];
if(this.$canvas == null) {
throw new Error('canvas element not found!');
this.canvas = el.getElementsByClassName('pdf-canvas')[0]
if (this.canvas == null) {
throw new Error('canvas element not found!')
};
this.$paginator = el.getElementsByClassName("paginator")[0];
this.$loadingWrapper = el.getElementsByClassName('loading-wrapper')[0];
this.$next = el.getElementsByClassName('next')[0];
this.$prev = el.getElementsByClassName('prev')[0];
this.$pageNum = el.getElementsByClassName('page-num')[0];
this.$pageCount = el.getElementsByClassName('page-count')[0];
this.paginator = el.getElementsByClassName('paginator')[0]
this.loadingWrapper = el.getElementsByClassName('loading-wrapper')[0]
this.next = el.getElementsByClassName('next')[0]
this.prev = el.getElementsByClassName('prev')[0]
this.pageNum = el.getElementsByClassName('page-num')[0]
this.pageCount = el.getElementsByClassName('page-count')[0]
// context
this.ctx = this.$canvas.getContext('2d');
this.ctx = this.canvas.getContext('2d')
// events
this.$next.addEventListener('click', this.handleNextPage.bind(this));
this.$prev.addEventListener('click', this.handlePrevPage.bind(this));
this.next.addEventListener('click', this.handleNextPage.bind(this))
this.prev.addEventListener('click', this.handlePrevPage.bind(this))
this.showPaginator();
this.showLoader();
this.loadPDF();
this.showPaginator()
this.showLoader()
this.loadPDF()
}
/**
* If we haven't disabled the loader, show loader and hide canvas
*/
showLoader() {
if(this.hideLoader) return;
this.$loadingWrapper.style.display = 'flex';
this.$canvas.style.display = 'none';
showLoader () {
if (this.hideLoader) return
this.loadingWrapper.style.display = 'flex'
this.canvas.style.display = 'none'
}
/**
* If we haven't disabled the paginator, show paginator
*/
showPaginator() {
if(this.hidePaginator) return;
this.$paginator.style.display = 'block';
showPaginator () {
if (this.hidePaginator) return
this.paginator.style.display = 'block'
}
/**
* Hides loader and shows canvas
*/
showContent() {
this.$loadingWrapper.style.display = 'none';
this.$canvas.style.display = 'block';
showContent () {
this.loadingWrapper.style.display = 'none'
this.canvas.style.display = 'block'
}
/**
* Asynchronously downloads PDF.
*/
async loadPDF() {
this.pdfDoc = await window.pdfjsLib.getDocument(this.url).promise;
async loadPDF () {
this.pdfDoc = await window.pdfjsLib.getDocument(this.url).promise
this.$pageCount.textContent = this.pdfDoc.numPages;
this.pageCount.textContent = this.pdfDoc.numPages
// If the user passed in a number that is out of range, render the last page.
if(this.pageNum > this.pdfDoc.numPages) {
if (this.pageNum > this.pdfDoc.numPages) {
this.pageNum = this.pdfDoc.numPages
}
this.renderPage(this.pageNum);
this.renderPage(this.pageNum)
}
/**
* Get page info from document, resize canvas accordingly, and render page.
* @param num Page number.
*/
async renderPage(num) {
this.pageRendering = true;
async renderPage (num) {
this.pageRendering = true
const page = await this.pdfDoc.getPage(num)
const viewport = page.getViewport({ scale: this.scale })
this.canvas.height = viewport.height
this.canvas.width = viewport.width
const page = await this.pdfDoc.getPage(num);
const viewport = page.getViewport({ scale: this.scale });
this.$canvas.height = viewport.height;
this.$canvas.width = viewport.width;
// Wait for rendering to finish
await page.render({
canvasContext: this.ctx,
viewport,
}).promise;
viewport
}).promise
this.pageRendering = false;
this.showContent();
this.pageRendering = false
this.showContent()
if (this.pageNumPending !== null) {
// New page rendering is pending
this.renderPage(this.pageNumPending);
this.pageNumPending = null;
this.renderPage(this.pageNumPending)
this.pageNumPending = null
}
// Update page counters
this.$pageNum.textContent = num;
this.pageNum.textContent = num
}
/**
* If another page rendering in progress, waits until the rendering is
* finished. Otherwise, executes rendering immediately.
*/
queueRenderPage(num) {
queueRenderPage (num) {
if (this.pageRendering) {
this.pageNumPending = num;
this.pageNumPending = num
} else {
this.renderPage(num);
this.renderPage(num)
}
}
/**
* Displays previous page.
*/
handlePrevPage() {
handlePrevPage () {
if (this.pageNum <= 1) {
return;
return
}
this.pageNum--;
this.queueRenderPage(this.pageNum);
this.pageNum--
this.queueRenderPage(this.pageNum)
}
/**
* Displays next page.
*/
handleNextPage() {
handleNextPage () {
if (this.pageNum >= this.pdfDoc.numPages) {
return;
return
}
this.pageNum++;
this.queueRenderPage(this.pageNum);
this.pageNum++
this.queueRenderPage(this.pageNum)
}
}
insertScript('pdfjs', PDFJS_BUNDLE, () => {
window.pdfjsLib.GlobalWorkerOptions.workerSrc = WORKER_BUNDLE;
Array.from(document.getElementsByClassName('pdf-viewer')).forEach(el => {
console.log(el);
new PDFViewer(el);
});
});
window.pdfjsLib.GlobalWorkerOptions.workerSrc = WORKER_BUNDLE
Array.from(document.getElementsByClassName('pdf-viewer')).forEach(el => new PDFViewer(el))
})