ngx-extended-pdf-viewer
Welcome to ngx-extended-pdf-viewer
– a powerful, full-featured PDF viewer for Angular applications. Whether you're building enterprise tools or internal utilities, this library gives you the control and customization options you need, all while preserving a native-like viewing experience.
Built on Mozilla’s pdf.js and extended with dozens of enhancements, it's ideal for serious applications that demand more than just basic PDF display.
🚀 Getting Started
0. Prerequisites
The library requires Angular 17+. Older versions are not supported.
In general, I aim to support the last four Angular versions (roughly two years of updates), but this may not always be feasible. For example, the upcoming version 25 might raise the minimum required Angular version significantly: I plan to support modern Angular (and I know many of you are waiting for that). You can't have an omelette without breaking an egg.
1. Installation
Install via npm:
npm add ngx-extended-pdf-viewer
2. Usage in Your Angular Component
In your component HTML:
<ngx-extended-pdf-viewer [src]="'assets/example.pdf'"></ngx-extended-pdf-viewer>
For NgModule-based applications:
import { NgxExtendedPdfViewerModule } from 'ngx-extended-pdf-viewer';
@NgModule({
imports: [NgxExtendedPdfViewerModule],
})
export class AppModule {}
For standalone components (Angular 17+):
import { Component } from '@angular/core';
import { NgxExtendedPdfViewerModule } from 'ngx-extended-pdf-viewer';
@Component({
selector: 'app-pdf-viewer',
standalone: true,
imports: [NgxExtendedPdfViewerModule],
template: `<ngx-extended-pdf-viewer [src]="'assets/example.pdf'"></ngx-extended-pdf-viewer>`,
})
export class PdfViewerComponent {}
Or configure in main.ts for application-wide availability:
import { bootstrapApplication } from '@angular/platform-browser';
import { importProvidersFrom } from '@angular/core';
import { NgxExtendedPdfViewerModule } from 'ngx-extended-pdf-viewer';
bootstrapApplication(AppComponent, {
providers: [
importProvidersFrom(NgxExtendedPdfViewerModule),
// other providers...
],
});
🧭 For hands-on examples and step-by-step guides, visit the showcase and the getting started page.
🔐 Security Notice
Version 20.0.2
fixes a critical security vulnerability (CVE-2024-4367). Update to this version or newer to stay safe from exploits via malicious PDF files.
Thanks to GitHub users ScratchPDX and Deepak Shakya for reporting the issue promptly.
📣 Roadmap Highlights
Upcoming in Version 25
- Migration to Angular Signals
- Support for standalone components
- Removal of
zone.js
(maybe) - Migration schematics planned (but not promised)
Expect some breaking changes — but better performance and modern Angular support await!
🧩 Core Features
- 🎨 Customizable toolbar and UI - Hide/show any button, customize layout
- 🔍 Advanced search capabilities - Find text, highlight all, multiple search terms, regex support
- 📝 Comprehensive form support - Standard and XFA forms with two-way data binding
- ✏️ PDF annotation and editing - Text, images, ink drawings, highlights, stamps, signatures
- 🔄 Page reordering - Drag and drop pages via thumbnails (v24.2+)
- 📊 Multiple viewing modes - Single page, book mode, infinite scroll, side-by-side
- 🎯 Precision zoom control - Programmatic zoom, fit-to-width/height, custom levels
- 🗂️ Rich sidebar - Thumbnails, document outline, attachments, layers
- 🌍 Internationalization - Built-in support for dozens of languages
- 📱 Mobile optimization - Touch gestures, responsive design, mobile-friendly zoom
- 🖱️ Drag-and-drop support - Load PDFs by dropping files onto the viewer
- 🖥️ Fullscreen mode - Immersive viewing experience
- ♿ Accessibility features - Keyboard navigation, screen reader support, focus indicators
- 🎛️ Advanced JavaScript API - Popup positioning, custom find controllers, annotation events
- 🚀 Performance optimized - Canvas size detection, memory leak prevention, efficient rendering
- 🔗 Direct pdf.js API access - Full TypeScript support for low-level operations
- 🔒 Security features - CSP compatibility, XSS protection
Regarding security: I'm not perfect - it's always a best-effort approach without guarantees. I'm 100% committed, but I need your help, and even so, in the long run, errors are invevitable. The art is to close vulnerabilities before a hacker can exploit then - and that's a joint effort. Together, we'll manage. Don't hesitate to report bugs and vulnerabilities as soon as possible!
See the full list of features on the showcase site.
📦 Version Highlights
Version 24
Version 24.2.0 and above:
- Showcase Application Modernization: The showcase application has been converted to standalone components, demonstrating modern Angular patterns and best practices for integration.
- Page Reordering Feature: New
enablePageReordering
option allows users to reorder PDF pages by dragging thumbnails. Enable it withpdfDefaultOptions.enablePageReordering = true;
. - Translations of ngx-extendeded-pdf-viewer extensions: I had my AI translate the labels of the buttons to 20 European languages. That's an experiment. If it works well, I'll add translations for all 112 languages supported by pdf.js. But let's start small - I don't speak non-European languages, which means I can't verify the AI generates the correct translation!
Version 24.1.0 and above: improved accessability by showing a hover effect when the mouse is over a button and by adding a blue ring to the active element, thus restoring the implementation we used to have a long time ago. Thanks to Megan for contributing this pull request!
Version 24.0.0:
- Upgraded to
pdf.js 5.3
- Minor breaking change: Every Acroform field with the same name is now updated by the two-way binding
[(formData)]
. In earlier versions, only the first field was changed. Kudos to Sebastien Fauvart for submitting this pull request! - There a new "signature editor". Disabled by default, you can opt in with
pdfDefaultOptions.enableSignatureEditor = true;
. Caveat: these signature are not cyptographic PDF signatures. At the time of writing (July 07, 2025), they're merely "stamp annotations".
Version 23
- Popup dialog positioning via JavaScript
- Option to force JavaScript code reload
- Improved mobile stability (reduced canvas resolution)
- Ink editor API updated (breaking change)
- Dialog CSS selectors adjusted for theming
❗ Version 23 includes a CSS bug where search highlights may render text invisible. To work around this, add the following to your global styles.css
:
ngx-extended-pdf-viewer .textLayer .highlight.selected {
opacity: 0.25;
}
Remove this workaround after updating to 24.0.0+.
🧪 Try the Showcase Locally
If you're stuck on a feature, try cloning the showcase repository. It’s a clean and working example, and comparing it to your app often helps locate the issue. And if the showcase doesn’t work — you can blame me!
git clone https://github.com/stephanrauh/extended-pdf-viewer-showcase.git
cd extended-pdf-viewer-showcase
npm install
npm start
👉 Open a ticket here if something’s broken.
🔧 Configuration & Events
- Full list of
[inputs]
, events, and CSS hooks:
Use NgxExtendedPdfViewerService
for:
- Starting/stopping search
- Scrolling to pages or coordinates
- Toggling layers
- Triggering print
🐞 Bug Reports & Feature Requests
We want to hear from you!
👉 File issues here: GitHub Bug Tracker
If possible, include a code snippet or reproduction. Better yet — send a pull request!
🕰️ Need a Fix for an Older Version?
I understand, but... realistically, I can’t maintain old versions in my spare time. The architecture allows for it, but I simply don’t have the bandwidth — unless something critical breaks.
If you're desperate for a fix or a new feature, there’s one option: ask my employer. I work as an IT consultant, and they may be willing to sponsor time to work on ngx-extended-pdf-viewer during business hours.
💡 Alternatives
If this library doesn't fit your needs:
ng2-pdf-viewer
: Minimal and lightweightng2-pdfjs-viewer
: iframe-based, supports multiple PDFs- Native browser PDF viewer: Fast, but limited customization
🙌 Contributions Welcome
Your feedback matters!
- File a ticket to discuss your idea
- Submit a PR (core or showcase). The how-to-build page has detailed instructions for you.
- Even complaints help improve the project!
Just keep it respectful — the ngx-extended-pdf-viewer community is a friendly place, and I want to keep it that way!
📜 License & Acknowledgments
- Apache 2.0 License
- Based on Mozilla’s pdf.js (also published under a friendly Apache 2.0 license)
- Icons from MaterialDesignIcons.com and Google
- Thanks to all users, contributors, and bug reporters! You rock! Just counting the people contributing pull requests - that's already several dozen developers:
🧓 Internet Explorer 11 Support
Still using IE11 in 2025? You're braver than most.
I hate to admit it - but I've dropped support years ago. The last known compatible version is 5.3. Use it at your own risk — no updates, no fixes, no guarantees.