mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-15 13:41:05 +00:00
6fe36b6acb
Add output download dropdown GitOrigin-RevId: 1f97f0d681679268d28796fbc8251ffbc6e98433
83 lines
2.2 KiB
JavaScript
83 lines
2.2 KiB
JavaScript
import React from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import { Dropdown, MenuItem } from 'react-bootstrap'
|
|
import { useTranslation, Trans } from 'react-i18next'
|
|
import Icon from '../../../shared/components/icon'
|
|
|
|
export const topFileTypes = ['bbl', 'gls', 'ind']
|
|
|
|
function PreviewDownloadButton({ isCompiling, outputFiles, pdfDownloadUrl }) {
|
|
let topFiles = []
|
|
let otherFiles = []
|
|
const { t } = useTranslation()
|
|
|
|
if (outputFiles) {
|
|
topFiles = outputFiles.filter(file => {
|
|
if (topFileTypes.includes(file.type)) {
|
|
return file
|
|
}
|
|
})
|
|
|
|
otherFiles = outputFiles.filter(file => {
|
|
if (!topFileTypes.includes(file.type)) {
|
|
if (file.type === 'pdf' && file.main === true) return
|
|
return file
|
|
}
|
|
})
|
|
}
|
|
|
|
return (
|
|
<Dropdown id="download-dropdown" disabled={isCompiling}>
|
|
<a
|
|
className="btn btn-xs btn-info"
|
|
disabled={isCompiling || !pdfDownloadUrl}
|
|
download
|
|
href={pdfDownloadUrl || '#'}
|
|
>
|
|
<Icon type="download" modifier="fw" /> {t('download_pdf')}
|
|
</a>
|
|
<Dropdown.Toggle
|
|
className="btn btn-xs btn-info dropdown-toggle"
|
|
aria-label={t('toggle_output_files_list')}
|
|
/>
|
|
<Dropdown.Menu id="download-dropdown-list">
|
|
<FileList list={topFiles} listType="main" />
|
|
|
|
{otherFiles.length > 0 && (
|
|
<>
|
|
<MenuItem divider />
|
|
<MenuItem header>{t('other_output_files')}</MenuItem>
|
|
<FileList list={otherFiles} listType="other" />
|
|
</>
|
|
)}
|
|
</Dropdown.Menu>
|
|
</Dropdown>
|
|
)
|
|
}
|
|
|
|
function FileList({ listType, list }) {
|
|
return list.map((file, index) => {
|
|
return (
|
|
<MenuItem download href={file.url} key={`${listType}-${index}`}>
|
|
<Trans
|
|
i18nKey="download_file"
|
|
components={[<strong />]}
|
|
values={{ type: file.fileName }}
|
|
/>
|
|
</MenuItem>
|
|
)
|
|
})
|
|
}
|
|
|
|
PreviewDownloadButton.propTypes = {
|
|
isCompiling: PropTypes.bool.isRequired,
|
|
outputFiles: PropTypes.array,
|
|
pdfDownloadUrl: PropTypes.string
|
|
}
|
|
|
|
FileList.propTypes = {
|
|
list: PropTypes.array.isRequired,
|
|
listType: PropTypes.string.isRequired
|
|
}
|
|
|
|
export default PreviewDownloadButton
|