2022-09-05 17:05:38 +05:30
|
|
|
import React, { useRef, useState, useCallback } from 'react';
|
2022-08-04 14:42:22 +05:30
|
|
|
import useIsFocused from './hooks/useIsFocused';
|
2022-09-05 17:05:38 +05:30
|
|
|
import usePdfDocument from './hooks/usePdfDocument';
|
2022-08-04 14:42:22 +05:30
|
|
|
import VerticalPages from './VerticalPages';
|
2022-08-28 16:48:51 +05:30
|
|
|
import ZoomControls from './ui/ZoomControls';
|
2022-09-11 19:28:32 +05:30
|
|
|
import MessageService from './messageService';
|
2022-09-05 17:05:38 +05:30
|
|
|
import { DownloadButton, PrintButton } from './ui/IconButtons';
|
|
|
|
|
|
|
|
require('./miniViewer.css');
|
2022-08-04 14:42:22 +05:30
|
|
|
|
2022-08-27 18:02:20 +05:30
|
|
|
export interface MiniViewerAppProps {
|
|
|
|
pdfPath: string;
|
|
|
|
isDarkTheme: boolean;
|
|
|
|
anchorPage: number;
|
|
|
|
pdfId: string;
|
2022-09-11 19:28:32 +05:30
|
|
|
resourceId?: string;
|
|
|
|
messageService: MessageService;
|
2022-08-27 18:02:20 +05:30
|
|
|
}
|
2022-08-04 14:42:22 +05:30
|
|
|
|
2022-08-27 18:02:20 +05:30
|
|
|
export default function MiniViewerApp(props: MiniViewerAppProps) {
|
2022-09-05 17:05:38 +05:30
|
|
|
const pdfDocument = usePdfDocument(props.pdfPath);
|
2022-08-04 14:42:22 +05:30
|
|
|
const isFocused = useIsFocused();
|
2022-08-28 16:48:51 +05:30
|
|
|
const [zoom, setZoom] = useState<number>(1);
|
2022-08-04 14:42:22 +05:30
|
|
|
const containerEl = useRef<HTMLDivElement>(null);
|
2022-09-05 17:05:38 +05:30
|
|
|
const [activePage, setActivePage] = useState(1);
|
|
|
|
|
|
|
|
const onActivePageChange = useCallback((page: number) => {
|
|
|
|
setActivePage(page);
|
|
|
|
}, []);
|
2022-08-04 14:42:22 +05:30
|
|
|
|
2022-09-11 19:28:32 +05:30
|
|
|
const onDoubleClick = useCallback((pageNo: number) => {
|
|
|
|
props.messageService.openFullScreenViewer(props.resourceId, pageNo);
|
|
|
|
}, [props.messageService, props.resourceId]);
|
|
|
|
|
2022-09-05 17:05:38 +05:30
|
|
|
if (!pdfDocument) {
|
2022-08-04 14:42:22 +05:30
|
|
|
return (
|
|
|
|
<div className="mini-app loading">
|
2022-10-26 16:04:08 +01:00
|
|
|
<div></div>
|
2022-08-04 14:42:22 +05:30
|
|
|
</div>);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className={`mini-app${isFocused ? ' focused' : ''}`}>
|
|
|
|
<div className={`app-pages${isFocused ? ' focused' : ''}`} ref={containerEl}>
|
2022-08-28 16:48:51 +05:30
|
|
|
<VerticalPages
|
2022-09-05 17:05:38 +05:30
|
|
|
pdfDocument={pdfDocument}
|
2022-08-28 16:48:51 +05:30
|
|
|
isDarkTheme={props.isDarkTheme}
|
|
|
|
anchorPage={props.anchorPage}
|
|
|
|
pdfId={props.pdfId}
|
|
|
|
rememberScroll={true}
|
|
|
|
container={containerEl}
|
|
|
|
showPageNumbers={true}
|
2022-09-05 17:05:38 +05:30
|
|
|
zoom={zoom}
|
2022-09-11 19:28:32 +05:30
|
|
|
textSelectable={true}
|
|
|
|
onTextSelect={props.messageService.textSelected}
|
|
|
|
onDoubleClick={onDoubleClick}
|
2022-09-05 17:05:38 +05:30
|
|
|
pageGap={2}
|
|
|
|
onActivePageChange={onActivePageChange} />
|
2022-08-04 14:42:22 +05:30
|
|
|
</div>
|
|
|
|
<div className='app-bottom-bar'>
|
|
|
|
<div className='pdf-info'>
|
2022-09-05 17:05:38 +05:30
|
|
|
<div style={{ paddingRight: '0.4rem' }}>{activePage}/{pdfDocument.pageCount} pages</div>
|
2022-08-28 16:48:51 +05:30
|
|
|
<ZoomControls onChange={setZoom} zoom={zoom} />
|
2022-09-05 17:05:38 +05:30
|
|
|
<PrintButton onClick={pdfDocument?.printPdf}/>
|
|
|
|
<DownloadButton onClick={pdfDocument?.downloadPdf}/>
|
2022-08-04 14:42:22 +05:30
|
|
|
</div>
|
2022-09-05 17:05:38 +05:30
|
|
|
<div className="can-hide">{isFocused ? '' : 'Click to enable scroll'}</div>
|
2022-08-04 14:42:22 +05:30
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|