mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2025-07-29 23:00:08 +02:00

[web] Add restoreView to LayoutContext GitOrigin-RevId: 3a50c1e215c99236f503285fee1c924df57e07e4
67 lines
2.5 KiB
TypeScript
67 lines
2.5 KiB
TypeScript
import { ToolbarMenuBar } from './menu-bar'
|
|
import { ToolbarProjectTitle } from './project-title'
|
|
import { OnlineUsers } from './online-users'
|
|
import ShareProjectButton from './share-project-button'
|
|
import ChangeLayoutButton from './change-layout-button'
|
|
import ShowHistoryButton from './show-history-button'
|
|
import { LabsActions } from './labs-actions'
|
|
import { useLayoutContext } from '@/shared/context/layout-context'
|
|
import BackToEditorButton from '@/features/editor-navigation-toolbar/components/back-to-editor-button'
|
|
import { useCallback } from 'react'
|
|
import * as eventTracking from '../../../../infrastructure/event-tracking'
|
|
import { ToolbarLogos } from './logos'
|
|
import { useEditorContext } from '@/shared/context/editor-context'
|
|
import importOverleafModules from '../../../../../macros/import-overleaf-module.macro'
|
|
import UpgradeButton from './upgrade-button'
|
|
import getMeta from '@/utils/meta'
|
|
import { useIdeReactContext } from '@/features/ide-react/context/ide-react-context'
|
|
|
|
const [publishModalModules] = importOverleafModules('publishModal')
|
|
const SubmitProjectButton = publishModalModules?.import.NewPublishToolbarButton
|
|
|
|
export const Toolbar = () => {
|
|
const { view, restoreView } = useLayoutContext()
|
|
const { cobranding } = useEditorContext()
|
|
const { permissionsLevel } = useIdeReactContext()
|
|
const shouldDisplaySubmitButton =
|
|
(permissionsLevel === 'owner' || permissionsLevel === 'readAndWrite') &&
|
|
SubmitProjectButton
|
|
|
|
const handleBackToEditorClick = useCallback(() => {
|
|
eventTracking.sendMB('navigation-clicked-history', { action: 'close' })
|
|
restoreView()
|
|
}, [restoreView])
|
|
|
|
if (view === 'history') {
|
|
return (
|
|
<div className="ide-redesign-toolbar">
|
|
<div className="d-flex align-items-center">
|
|
<BackToEditorButton onClick={handleBackToEditorClick} />
|
|
</div>
|
|
<ToolbarProjectTitle />
|
|
<div /> {/* Empty div used for spacing */}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<div className="ide-redesign-toolbar">
|
|
<div className="ide-redesign-toolbar-menu">
|
|
<ToolbarLogos cobranding={cobranding} />
|
|
<ToolbarMenuBar />
|
|
</div>
|
|
<ToolbarProjectTitle />
|
|
<div className="ide-redesign-toolbar-actions">
|
|
<LabsActions />
|
|
<OnlineUsers />
|
|
<ShowHistoryButton />
|
|
<ChangeLayoutButton />
|
|
{shouldDisplaySubmitButton && cobranding && (
|
|
<SubmitProjectButton cobranding={cobranding} />
|
|
)}
|
|
<ShareProjectButton />
|
|
{getMeta('ol-showUpgradePrompt') && <UpgradeButton />}
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|