mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
6fe36b6acb
Add output download dropdown GitOrigin-RevId: 1f97f0d681679268d28796fbc8251ffbc6e98433
75 lines
2.2 KiB
JavaScript
75 lines
2.2 KiB
JavaScript
import React from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import PreviewDownloadButton from './preview-download-button'
|
|
import PreviewRecompileButton from './preview-recompile-button'
|
|
import PreviewLogsToggleButton from './preview-logs-toggle-button'
|
|
|
|
function PreviewToolbar({
|
|
compilerState,
|
|
logsState,
|
|
onClearCache,
|
|
onRecompile,
|
|
onRunSyntaxCheckNow,
|
|
onSetAutoCompile,
|
|
onSetDraftMode,
|
|
onSetSyntaxCheck,
|
|
onToggleLogs,
|
|
outputFiles,
|
|
pdfDownloadUrl,
|
|
showLogs
|
|
}) {
|
|
return (
|
|
<div className="toolbar toolbar-pdf">
|
|
<div className="toolbar-pdf-left">
|
|
<PreviewRecompileButton
|
|
compilerState={compilerState}
|
|
onRecompile={onRecompile}
|
|
onRunSyntaxCheckNow={onRunSyntaxCheckNow}
|
|
onSetAutoCompile={onSetAutoCompile}
|
|
onSetDraftMode={onSetDraftMode}
|
|
onSetSyntaxCheck={onSetSyntaxCheck}
|
|
onClearCache={onClearCache}
|
|
/>
|
|
<PreviewDownloadButton
|
|
isCompiling={compilerState.isCompiling}
|
|
outputFiles={outputFiles}
|
|
pdfDownloadUrl={pdfDownloadUrl}
|
|
/>
|
|
</div>
|
|
<div className="toolbar-pdf-right">
|
|
<PreviewLogsToggleButton
|
|
logsState={logsState}
|
|
showLogs={showLogs}
|
|
onToggle={onToggleLogs}
|
|
/>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
PreviewToolbar.propTypes = {
|
|
compilerState: PropTypes.shape({
|
|
isAutoCompileOn: PropTypes.bool.isRequired,
|
|
isCompiling: PropTypes.bool.isRequired,
|
|
isDraftModeOn: PropTypes.bool.isRequired,
|
|
isSyntaxCheckOn: PropTypes.bool.isRequired,
|
|
logEntries: PropTypes.object.isRequired
|
|
}),
|
|
logsState: PropTypes.shape({
|
|
nErrors: PropTypes.number.isRequired,
|
|
nWarnings: PropTypes.number.isRequired,
|
|
nLogEntries: PropTypes.number.isRequired
|
|
}),
|
|
showLogs: PropTypes.bool.isRequired,
|
|
onClearCache: PropTypes.func.isRequired,
|
|
onRecompile: PropTypes.func.isRequired,
|
|
onRunSyntaxCheckNow: PropTypes.func.isRequired,
|
|
onSetAutoCompile: PropTypes.func.isRequired,
|
|
onSetDraftMode: PropTypes.func.isRequired,
|
|
onSetSyntaxCheck: PropTypes.func.isRequired,
|
|
onToggleLogs: PropTypes.func.isRequired,
|
|
pdfDownloadUrl: PropTypes.string,
|
|
outputFiles: PropTypes.array
|
|
}
|
|
|
|
export default PreviewToolbar
|