mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-14 20:40:17 -05:00
ff44afb74c
GitOrigin-RevId: 0b6d25d7012e82a676e3a782730fb6ca481cd1e8
56 lines
1.7 KiB
JavaScript
56 lines
1.7 KiB
JavaScript
import { Button, OverlayTrigger, Tooltip } from 'react-bootstrap'
|
|
import PropTypes from 'prop-types'
|
|
import Icon from '../../../shared/components/icon'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { memo } from 'react'
|
|
import { useLayoutContext } from '../../../shared/context/layout-context'
|
|
|
|
const modifierKey = /Mac/i.test(navigator.platform) ? 'Cmd' : 'Ctrl'
|
|
|
|
function PdfCompileButtonInner({ startCompile, compiling }) {
|
|
const { detachRole, view, pdfLayout } = useLayoutContext()
|
|
|
|
const { t } = useTranslation()
|
|
|
|
const compileButtonLabel = compiling ? t('compiling') + '…' : t('recompile')
|
|
|
|
// show the compile shortcut when the editor is visible
|
|
const showCompileShortcut =
|
|
detachRole !== 'detached' &&
|
|
(view === 'editor' || pdfLayout === 'sideBySide')
|
|
|
|
return (
|
|
<OverlayTrigger
|
|
placement="bottom"
|
|
delayShow={500}
|
|
overlay={
|
|
<Tooltip id="tooltip-logs-toggle" className="keyboard-tooltip">
|
|
{t('recompile_pdf')}{' '}
|
|
{showCompileShortcut && (
|
|
<span className="keyboard-shortcut">({modifierKey} + Enter)</span>
|
|
)}
|
|
</Tooltip>
|
|
}
|
|
>
|
|
<Button
|
|
className="btn-recompile"
|
|
bsStyle="success"
|
|
onClick={() => startCompile()}
|
|
aria-label={compileButtonLabel}
|
|
disabled={compiling}
|
|
>
|
|
<Icon type="refresh" spin={compiling} />
|
|
<span className="toolbar-hide-medium toolbar-hide-small btn-recompile-label">
|
|
{compileButtonLabel}
|
|
</span>
|
|
</Button>
|
|
</OverlayTrigger>
|
|
)
|
|
}
|
|
|
|
PdfCompileButtonInner.propTypes = {
|
|
compiling: PropTypes.bool.isRequired,
|
|
startCompile: PropTypes.func.isRequired,
|
|
}
|
|
|
|
export default memo(PdfCompileButtonInner)
|