1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-11 18:24:43 +02:00
joplin/packages/pdf-viewer/main.tsx
2022-11-28 18:21:41 +01:00

47 lines
1.5 KiB
TypeScript

import React from 'react';
import shim from '@joplin/lib/shim';
shim.setReact(React);
const { createRoot } = require('react-dom/client');
import * as pdfjsLib from 'pdfjs-dist';
import MiniViewerApp from './miniViewer';
import MessageService from './messageService';
import FullViewer from './FullViewer';
require('./common.css');
// Setting worker path to worker bundle.
pdfjsLib.GlobalWorkerOptions.workerSrc = 'pdf.worker.js';
const url = window.frameElement.getAttribute('x-url');
const type = window.frameElement.getAttribute('x-type');
const appearance = window.frameElement.getAttribute('x-appearance');
const anchorPage = Number(window.frameElement.getAttribute('x-anchorPage')) || null;
const pdfId = window.frameElement.getAttribute('id');
const resourceId = window.frameElement.getAttribute('x-resourceid');
const title = window.frameElement.getAttribute('x-title');
document.documentElement.setAttribute('data-theme', appearance);
const messageService = new MessageService(type);
function App() {
if (type === 'mini') {
return <MiniViewerApp pdfPath={url}
isDarkTheme={appearance === 'dark'}
anchorPage={anchorPage}
pdfId={pdfId}
resourceId={resourceId}
messageService={messageService}/>;
} else if (type === 'full') {
return <FullViewer pdfPath={url}
isDarkTheme={appearance === 'dark'}
startPage={anchorPage || 1}
title={title}
messageService={messageService} />;
}
return <div>Error: Unknown app type "{type}"</div>;
}
const root = createRoot(document.getElementById('pdf-root'));
root.render(<App/>);