react-ipdf-viewer

A React component for viewing PDF documents using Mozilla's pdf.js
. Embed a customizable PDF viewer in your React applications with page navigation, zoom, rotation, download, print, and full-screen support.
Features
- Render PDFs from URLs or local files with smooth navigation.
- Enable zoom, rotation, download, print, and full-screen via toolbar.
- Support light and dark themes for accessibility.
- Auto-adjust height for responsive design.
- Compatible with modern browsers (Chrome, Firefox, Safari, Edge).
- Built-in zoom and navigation controls.
- TypeScript-compatible for type-safe development.
Installation
Install the package via npm:
npm install react-ipdf-viewer
Or using Yarn:
yarn add react-ipdf-viewer
Dependencies
Ensure you have the following peer dependencies installed:
react
(>=16.8.0)
react-dom
(>=16.8.0)
pdfjs-dist
(>=2.9.359)
Install them if needed:
npm install react react-dom pdfjs-dist
Usage
Import the ReactIPdfViewer
component and provide a PDF file URL or path via the src
prop. Customize with props like theme
, showControls
, and feature toggles. The component supports PDF documents only; place local PDFs in your public/
folder or use a hosted URL.
Example: Viewing a PDF
import React from 'react';
import ReactIPdfViewer from 'react-ipdf-viewer';
import './App.css';
const PDF = 'sample.pdf';
const App = () => {
return (
<div className="App">
<ReactIPdfViewer
src={PDF}
theme="dark"
autoHeight
showControls
allowDownload
allowPrint
allowRotate
allowFullScreen
/>
</div>
);
};
export default App;
Example: Viewing an Image
import React from 'react';
import ReactIPdfViewer from 'react-ipdf-viewer';
import './App.css';
const sampleImage = 'sample.jpg';
const App = () => {
return (
<div className="App">
<ReactIPdfViewer
src={sampleImage}
theme="dark"
autoHeight
showControls
allowDownload
allowPrint
allowRotate
allowFullScreen
/>
</div>
);
};
export default App;
Alternative Example: Minimal PDF Viewer
import React from 'react';
import ReactIPdfViewer from 'react-ipdf-viewer';
const App = () => {
return (
<ReactIPdfViewer
src="https://example.com/sample.pdf"
theme="light"
autoHeight={false}
showControls={false}
allowDownload={true}
allowPrint={false}
allowRotate={true}
allowFullScreen={true}
/>
);
};
export default App;
API
ReactIPdfViewer
A React component to render a PDF viewer with customizable controls.
Props
src | string | URL or path to the PDF file to render. Also accepts document={{ url }} . | None | 'sample.pdf' or 'https://example.com/sample.pdf' |
theme | string | Sets the viewer’s theme. Options: 'light' , 'dark' . | 'light' | 'dark' |
autoHeight | boolean | Automatically adjusts the viewer’s height to fit the PDF or container. | false | true |
showControls | boolean | Displays the toolbar with navigation and feature controls. | true | true |
allowDownload | boolean | Enables a download button in the toolbar. | true | true |
allowPrint | boolean | Enables a print button in the toolbar. | true | false |
allowRotate | boolean | Enables rotation controls (left, right) in the toolbar. | true | true |
allowFullScreen | boolean | Enables a full-screen toggle button in the toolbar. | true | true |
Example
<ReactIPdfViewer
src="sample.pdf"
theme="dark"
autoHeight
showControls
allowDownload
allowPrint={false}
allowRotate
allowFullScreen
/>
Error Handling and Troubleshooting
The ReactIPdfViewer
component may encounter issues when loading or rendering PDFs. Below are common errors and solutions.
Common Errors
Error Handling Tips
Additional Features
Beyond the core props, ReactIPdfViewer
offers:
- Zoom Controls: Adjust zoom via toolbar buttons.
- Page Navigation: Move between pages using toolbar buttons or keyboard shortcuts.
- Custom Styling: Apply custom CSS to the toolbar via
css
prop (e.g., { navbarWrapper: 'custom-navbar' }
).
- TypeScript Compatibility: Works in TypeScript projects.
Limitations
- Supports PDFs only.
- No built-in annotations or text selection.
- Large PDFs may impact performance on low-end devices.
Contributing
Contributions are welcome! To contribute:
- Fork the repository.
- Create a feature branch (
git checkout -b feature/YourFeature
).
- Commit your changes (
git commit -m 'Add YourFeature'
).
- Push to the branch (
git push origin feature/YourFeature
).
- Open a Pull Request.
Please ensure your code follows the existing style and includes tests where applicable.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Contact
For issues, questions, or feature requests, please open an issue on the GitHub repository or contact Sudeepa R.# react-ipdf-viewer