53 行
1.3 KiB
JavaScript
53 行
1.3 KiB
JavaScript
import React, { useState } from "react";
|
|
import { Document, Page, pdfjs } from "react-pdf";
|
|
pdfjs.GlobalWorkerOptions.workerSrc = `//cdnjs.cloudflare.com/ajax/libs/pdf.js/${pdfjs.version}/pdf.worker.min.js`;
|
|
|
|
export default function PDFViewer(props) {
|
|
const [numPages, setNumPages] = useState(null);
|
|
const [pageNumber, setPageNumber] = useState(1); //default fisrt page
|
|
|
|
function onDocumentLoadSuccess({ numPages }) {
|
|
setNumPages(numPages);
|
|
setPageNumber(1);
|
|
}
|
|
|
|
function changePage(offset) {
|
|
setPageNumber(prevPageNumber => prevPageNumber + offset);
|
|
}
|
|
|
|
function previousPage() {
|
|
changePage(-1);
|
|
}
|
|
|
|
function nextPage() {
|
|
changePage(1);
|
|
}
|
|
|
|
const { pdf } = props;
|
|
|
|
return (
|
|
<>
|
|
<Document
|
|
file={pdf}
|
|
onLoadSuccess={onDocumentLoadSuccess}
|
|
>
|
|
<Page pageNumber={pageNumber} />
|
|
</Document>
|
|
<div>
|
|
<p>
|
|
ページ {pageNumber || (numPages ? 1 : "--")} of {numPages || "--"}
|
|
</p>
|
|
<button type="button" disabled={pageNumber <= 1} onClick={previousPage}>
|
|
前
|
|
</button>
|
|
<button
|
|
type="button"
|
|
disabled={pageNumber >= numPages}
|
|
onClick={nextPage}
|
|
>
|
|
次
|
|
</button>
|
|
</div>
|
|
</>
|
|
);
|
|
} |