mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-28 15:12:52 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			132 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
			Vendored
		
	
	
	
| /**
 | |
|  * Invoice Ninja (https://invoiceninja.com)
 | |
|  *
 | |
|  * @link https://github.com/invoiceninja/invoiceninja source repository
 | |
|  *
 | |
|  * @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
 | |
|  *
 | |
|  * @license https://opensource.org/licenses/AAL
 | |
|  */
 | |
| 
 | |
| class PDF {
 | |
|     constructor(url, canvas) {
 | |
|         this.url = url;
 | |
|         this.canvas = canvas;
 | |
|         this.context = canvas.getContext('2d');
 | |
|         this.currentPage = 1;
 | |
|         this.maxPages = 1;
 | |
|         this.currentScale = 1.75;
 | |
|         this.currentScaleText = document.getElementById('zoom-level');
 | |
| 
 | |
|         if (matchMedia('only screen and (max-width: 480px)').matches) {
 | |
|             this.currentScale = 0.5;
 | |
|         }
 | |
| 
 | |
|         this.currentScaleText.textContent = this.currentScale * 100 + '%';
 | |
|     }
 | |
| 
 | |
|     handlePreviousPage() {
 | |
|         if (this.currentPage == 1) {
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         this.currentPage -= 1;
 | |
| 
 | |
|         this.handle();
 | |
|     }
 | |
| 
 | |
|     handleNextPage() {
 | |
|         if (this.currentPage == this.maxPages) {
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         this.currentPage += 1;
 | |
| 
 | |
|         this.handle();
 | |
|     }
 | |
| 
 | |
|     handleZoomChange(zoom = null) {
 | |
|         if (this.currentScale == 0.25 && !zoom) {
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         if (zoom) {
 | |
|             this.currentScale += 0.25;
 | |
|             this.currentScaleText.textContent = this.currentScale * 100 + '%';
 | |
| 
 | |
|             return this.handle();
 | |
|         }
 | |
| 
 | |
|         this.currentScale -= 0.25;
 | |
|         this.currentScaleText.textContent = this.currentScale * 100 + '%';
 | |
| 
 | |
|         return this.handle();
 | |
|     }
 | |
| 
 | |
|     prepare() {
 | |
|         let previousPageButton = document
 | |
|             .getElementById('previous-page-button')
 | |
|             .addEventListener('click', () => this.handlePreviousPage());
 | |
| 
 | |
|         let nextPageButton = document
 | |
|             .getElementById('next-page-button')
 | |
|             .addEventListener('click', () => this.handleNextPage());
 | |
| 
 | |
|         let zoomInButton = document
 | |
|             .getElementById('zoom-in')
 | |
|             .addEventListener('click', () => this.handleZoomChange(true));
 | |
| 
 | |
|         let zoomOutButton = document
 | |
|             .getElementById('zoom-out')
 | |
|             .addEventListener('click', () => this.handleZoomChange());
 | |
| 
 | |
|         return this;
 | |
|     }
 | |
| 
 | |
|     setPagesInViewport() {
 | |
|         let currentPageContainer = document.getElementById(
 | |
|             'current-page-container'
 | |
|         );
 | |
| 
 | |
|         let totalPageContainer = document.getElementById(
 | |
|             'total-page-container'
 | |
|         );
 | |
| 
 | |
|         let paginationButtonContainer = document.getElementById(
 | |
|             'pagination-button-container'
 | |
|         );
 | |
| 
 | |
|         currentPageContainer.innerText = this.currentPage;
 | |
|         totalPageContainer.innerText = this.maxPages;
 | |
| 
 | |
|         if (this.maxPages > 1) {
 | |
|             paginationButtonContainer.style.display = 'flex';
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     async handle() {
 | |
|         let pdf = await pdfjsLib.getDocument(this.url).promise;
 | |
| 
 | |
|         let page = await pdf.getPage(this.currentPage);
 | |
| 
 | |
|         this.maxPages = pdf.numPages;
 | |
| 
 | |
|         let viewport = await page.getViewport({ scale: this.currentScale });
 | |
| 
 | |
|         this.canvas.height = viewport.height;
 | |
|         this.canvas.width = viewport.width;
 | |
| 
 | |
|         page.render({
 | |
|             canvasContext: this.context,
 | |
|             viewport,
 | |
|         });
 | |
| 
 | |
|         this.setPagesInViewport();
 | |
|     }
 | |
| }
 | |
| 
 | |
| const url = document.querySelector("meta[name='pdf-url'").content;
 | |
| const canvas = document.getElementById('pdf-placeholder');
 | |
| 
 | |
| new PDF(url, canvas).prepare().handle();
 |