mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
b62cb86bf8
* Create a new shared `SplitMenu` component. * Refactor the pdf compile button & detached compile button: - Rename `detach-compile-button` to `detach-compile-button-wrapper` - Rename `pdf-compile-button-inner` to `detach-compile-button` - Move some of the logic from `detach-compile-button-wrapper` to `detach-compile-button` - Create a new `compile-button.less` to centralize all of the compile button (detached/non-detached) custom styles rule. - Extract the animated striped CSS definition to the dedicated CSS file, change the class from `btn-recompile-group-has-changes` to `btn-striped-animated` - Refactor other className(s) appropriately according to the new component name - Delete the unused `changes-to-autocompile` css rule since it has not been used anywhere * Implement the new pdf compile button with the new `SplitMenu` component. GitOrigin-RevId: d1d055bffd311923fc47b4681605ce8ba8e26f25
50 lines
1.6 KiB
TypeScript
50 lines
1.6 KiB
TypeScript
import { useTranslation } from 'react-i18next'
|
|
import { memo } from 'react'
|
|
import { Button } from 'react-bootstrap'
|
|
import classNames from 'classnames'
|
|
import Icon from '../../../shared/components/icon'
|
|
import { useDetachCompileContext } from '../../../shared/context/detach-compile-context'
|
|
import Tooltip from '../../../shared/components/tooltip'
|
|
|
|
const modifierKey = /Mac/i.test(navigator.platform) ? 'Cmd' : 'Ctrl'
|
|
|
|
function DetachCompileButton() {
|
|
const { t } = useTranslation()
|
|
const { compiling, startCompile, hasChanges } = useDetachCompileContext()
|
|
|
|
const compileButtonLabel = compiling ? `${t('compiling')}…` : t('recompile')
|
|
const tooltipElement = (
|
|
<>
|
|
{t('recompile_pdf')}{' '}
|
|
<span className="keyboard-shortcut">({modifierKey} + Enter)</span>
|
|
</>
|
|
)
|
|
|
|
return (
|
|
<div className="detach-compile-button-container">
|
|
<Tooltip
|
|
id="logs-toggle"
|
|
description={tooltipElement}
|
|
tooltipProps={{ className: 'keyboard-tooltip' }}
|
|
overlayProps={{ delayShow: 500 }}
|
|
>
|
|
<Button
|
|
bsStyle="primary"
|
|
onClick={() => startCompile()}
|
|
disabled={compiling}
|
|
className={classNames('detach-compile-button', {
|
|
'btn-striped-animated': hasChanges,
|
|
'detach-compile-button-disabled': compiling,
|
|
})}
|
|
>
|
|
<Icon type="refresh" spin={compiling} />
|
|
<span className="detach-compile-button-label">
|
|
{compileButtonLabel}
|
|
</span>
|
|
</Button>
|
|
</Tooltip>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default memo(DetachCompileButton)
|