vue-pdfjs-hook
v1.0.1
Published
Vue hook to use easy pdfjs-dist and render a PDF Document in SVG mode
Downloads
22
Readme
Vue-pdfjs-hook
import { usePDF } from 'vue-pdfjs-hook'
<template>
<div class="h-full flex overflow-hidden">
<div class="flex-grow overflow-scroll">
<section
ref="element"
class="block bg-white overflow-hidden mx-auto"
:style="{
width: `${viewport.width}px`,
height: `${viewport.height}px`,
}"
/>
</div>
</div>
</template>
<script lang="ts">
import { defineComponent, ref, shallowRef } from 'vue'
import { usePDF } from 'vue-pdfjs-hook'
export default defineComponent({
setup() {
const element = shallowRef<HTMLElement>()
const file = ref(
'https://raw.githubusercontent.com/mozilla/pdf.js-sample-files/master/tracemonkey.pdf',
)
const numPages = ref(0)
const { viewport } = usePDF({
file,
element,
onDocumentLoadSuccess: (_document) => (numPages.value = _document.numPages),
})
return { element, viewport }
},
})
</script>
Types
type PDFHookOptions = {
element: Ref<HTMLElement | undefined>;
file: Ref<string>;
onDocumentLoadSuccess?: (document: PDFDocumentProxy) => void;
onDocumentLoadFail?: (err: Error) => void;
onPageLoadSuccess?: (page: PDFPageProxy) => void;
onPageLoadFail?: (err: Error) => void;
onPageRenderSuccess?: (page: PDFPageProxy) => void;
onPageRenderFail?: (err: Error) => void;
onPassword?: (callback: (password: string) => void, reason: 'NEED_PASSWORD' | 'INCORRECT_PASSWORD') => void;
workerSrc?: string; // default 'https://cdnjs.cloudflare.com/ajax/libs/pdf.js/${pdfjs.version}/pdf.worker.js'
config?: DocumentInitParameters;
}
export type PDFHookReturn = {
pdfDocument: DeepReadonly<Ref<PDFDocumentProxy>>;
pdfPage: DeepReadonly<Ref<PDFPageProxy>>;
viewport: DeepReadonly<ComputedRef<PageViewport>>;
page: DeepReadonly<Ref<number>>;
rotate: DeepReadonly<Ref<number>>;
scale: DeepReadonly<Ref<number>>;
rotateCW: () => void;
rotateCCW: () => void;
scaleIn: () => void;
scaleOut: () => void;
fitAuto: () => void;
fitWidth: () => void;
nextPage: () => void;
prevPage: () => void;
setPage: (page: number) => void;
};