A library that makes using pdfjs in react projects easy.
Demo: pdf-viewport.lukas-moeller.ch
Add pdfjs-dist
and pdf-viewport
as dependencies:
$ yarn add pdfjs-dist pdf-viewport
$ npm install --save pdfjs-dist pdf-viewport
Set pdfjsLib.GlobalWorkerOptions.workerSrc
. You could for example use a hosted variant of the worker or use worker-loader
to bundle the worker yourself using webpack.
import * as pdfjsLib from "pdfjs-dist/es5/build/pdf";
pdfjsLib.GlobalWorkerOptions.workerSrc = "[your worker url]"
Load the PDF using getDocument
from pdfjs. You can do this e.g. using useEffect
or react-query:
const [pdf, setPdf] = React.useState<PDFDocumentProxy | undefined>();
React.useEffect(() => {
getDocument(examplePdf).promise.then(setPdf);
}, []);
Now you can use pdf-viewport
to render the PDF using one of its components:
<PdfViewport
aspectRatio={portraitA4}
pdf={pdf}
pageNumber={1}
>
<PdfCanvasLayer />
</PdfViewport>
Coming soon!