overleaf-cep/services/web/frontend/js/features/pdf-preview/components/pdf-preview-error-boundary-fallback.tsx
David 1d648f9755 Merge pull request #23502 from overleaf/dp-pdf-typescript
Convert PDF Preview components to typescript

GitOrigin-RevId: 34594d21143727fa42b8b595aa12125a4dd7ae5e
2025-02-13 09:06:41 +00:00

53 lines
1.2 KiB
TypeScript

import { Trans, useTranslation } from 'react-i18next'
import { ErrorBoundaryFallback } from '../../../shared/components/error-boundary-fallback'
function PdfPreviewErrorBoundaryFallback({
type,
}: {
type: 'preview' | 'pdf' | 'logs'
}) {
const { t } = useTranslation()
const showInfoLink = (
<Trans
i18nKey="try_recompile_project_or_troubleshoot"
components={[
// eslint-disable-next-line jsx-a11y/anchor-has-content
<a
href="/learn/how-to/Resolving_access%2C_loading%2C_and_display_problems"
target="_blank"
key="troubleshooting-link"
/>,
]}
/>
)
switch (type) {
case 'pdf':
return (
<ErrorBoundaryFallback>
<p>{t('pdf_viewer_error')}</p>
<p>{showInfoLink}</p>
</ErrorBoundaryFallback>
)
case 'logs':
return (
<ErrorBoundaryFallback>
<p>{t('log_viewer_error')}</p>
<p>{showInfoLink}</p>
</ErrorBoundaryFallback>
)
case 'preview':
default:
return (
<ErrorBoundaryFallback>
<p>{t('pdf_preview_error')}</p>
<p>{showInfoLink}</p>
</ErrorBoundaryFallback>
)
}
}
export default PdfPreviewErrorBoundaryFallback