mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 03:18:24 +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