#react-pdf-js
react-pdf-js
provides a component for rendering PDF documents using PDF.js. Written for React 15 and ES2015 using the Airbnb style guide.
Usage
Install with npm install react-pdf-js
Use in your app (showing some basic pagination as well):
import React from 'react';
import PDF from 'react-pdf-js';
class MyPdfViewer extends React.Component {
constructor(props) {
super(props);
this.onDocumentComplete = this.onDocumentComplete.bind(this);
this.onPageCompleted = this.onPageCompleted.bind(this);
this.handlePrevious = this.handlePrevious.bind(this);
this.handleNext = this.handleNext.bind(this);
}
onDocumentComplete(pages) {
this.setState({ page: 1, pages });
}
onPageCompleted(page) {
this.setState({ page });
}
handlePrevious() {
this.setState({ page: this.state.page - 1 });
}
handleNext() {
this.setState({ page: this.state.page + 1 });
}
renderPagination(page, pages) {
let previousButton = <button type="button" className="btn btn-default" onClick={this.handlePrevious}><i className="fa fa-arrow-left"></i> Previous</button>;
if (page === 1) {
previousButton = <button type="button" className="btn btn-default" disabled><i className="fa fa-arrow-left"></i> Previous</button>;
}
let nextButton = <button type="button" className="btn btn-default" onClick={this.handleNext}>Next <i className="fa fa-arrow-right"></i></button>;
if (page === pages) {
nextButton = <button type="button" className="btn btn-default" disabled>Next <i className="fa fa-arrow-right"></i></button>;
}
return <div>{previousButton} {nextButton}</div>;
}
render() {
return <PDF file="somefile.pdf" onDocumentComplete={this.onDocumentComplete} onPageCompleted={this.onPageCompleted} page={this.state.page} />
}
}
module.exports = MyPdfViewer;
Credit
This project is a fork of react-pdfjs which itself was a port of react-pdf, so thank you to
the original authours.