mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	Add PDF rendering via PDFObject (#24086)
Use [PDFObject](https://pdfobject.com/) to embed PDFs, replacing our outdated PDF.js copy we vendor (the last non-webpack vendoring). [Commit 1](673e0263da) is the PDFObject integration [Commit 2](9336f5769d) is the removal of PDF.js <img width="1251" alt="Screenshot 2023-05-27 at 09 57 52" src="https://github.com/go-gitea/gitea/assets/115237/169ce50c-bd1d-4bb0-86e5-1710bd0400a9"> <img width="1257" alt="Screenshot 2023-05-27 at 10 12 50" src="https://github.com/go-gitea/gitea/assets/115237/318f7ee9-fb11-4093-83e7-17475aa70629"> Fallback for unsupporting browsers (most mobile ones, except Firefox Mobile): <img width="358" alt="Screenshot 2023-05-27 at 09 43 34" src="https://github.com/go-gitea/gitea/assets/115237/8c12d7ba-57d6-4228-89a0-5fef9fad0cbb"> --------- Co-authored-by: Giteabot <teabot@gitea.io>
This commit is contained in:
		@@ -21,6 +21,7 @@ import {initRepoIssueContentHistory} from './features/repo-issue-content.js';
 | 
			
		||||
import {initStopwatch} from './features/stopwatch.js';
 | 
			
		||||
import {initFindFileInRepo} from './features/repo-findfile.js';
 | 
			
		||||
import {initCommentContent, initMarkupContent} from './markup/content.js';
 | 
			
		||||
import {initPdfViewer} from './render/pdf.js';
 | 
			
		||||
 | 
			
		||||
import {initUserAuthLinkAccountView, initUserAuthOauth2} from './features/user-auth.js';
 | 
			
		||||
import {
 | 
			
		||||
@@ -177,4 +178,5 @@ onDomReady(() => {
 | 
			
		||||
  initUserAuthWebAuthnRegister();
 | 
			
		||||
  initUserSettings();
 | 
			
		||||
  initRepoDiffView();
 | 
			
		||||
  initPdfViewer();
 | 
			
		||||
});
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										19
									
								
								web_src/js/render/pdf.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								web_src/js/render/pdf.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,19 @@
 | 
			
		||||
import {htmlEscape} from 'escape-goat';
 | 
			
		||||
 | 
			
		||||
export async function initPdfViewer() {
 | 
			
		||||
  const els = document.querySelectorAll('.pdf-content');
 | 
			
		||||
  if (!els.length) return;
 | 
			
		||||
 | 
			
		||||
  const pdfobject = await import(/* webpackChunkName: "pdfobject" */'pdfobject');
 | 
			
		||||
 | 
			
		||||
  for (const el of els) {
 | 
			
		||||
    const src = el.getAttribute('data-src');
 | 
			
		||||
    const fallbackText = el.getAttribute('data-fallback-button-text');
 | 
			
		||||
    pdfobject.embed(src, el, {
 | 
			
		||||
      fallbackLink: htmlEscape`
 | 
			
		||||
        <a role="button" class="ui basic button pdf-fallback-button" href="[url]">${fallbackText}</a>
 | 
			
		||||
      `,
 | 
			
		||||
    });
 | 
			
		||||
    el.classList.remove('is-loading');
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user