mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-11 18:24:43 +02:00
47 lines
1.5 KiB
TypeScript
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/>);
|