mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-03 09:54:02 -05:00
6b3a953c8d
GitOrigin-RevId: 4c25e93effc08c6bf62cdca7e95b31ca36ac154f
131 lines
4.5 KiB
TypeScript
131 lines
4.5 KiB
TypeScript
import { Panel, PanelGroup } from 'react-resizable-panels'
|
|
import { FC } from 'react'
|
|
import { HorizontalResizeHandle } from '../resize/horizontal-resize-handle'
|
|
import classNames from 'classnames'
|
|
import { useLayoutContext } from '@/shared/context/layout-context'
|
|
import EditorNavigationToolbar from '@/features/ide-react/components/editor-navigation-toolbar'
|
|
import ChatPane from '@/features/chat/components/chat-pane'
|
|
import { HorizontalToggler } from '@/features/ide-react/components/resize/horizontal-toggler'
|
|
import { HistorySidebar } from '@/features/ide-react/components/history-sidebar'
|
|
import { HistoryProvider } from '@/features/history/context/history-context'
|
|
import History from '@/features/ide-react/components/history'
|
|
import EditorSidebar from '@/features/ide-react/components/editor-sidebar'
|
|
import { EditorPane } from '@/features/ide-react/components/editor/editor-pane'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { useSidebarPane } from '@/features/ide-react/hooks/use-sidebar-pane'
|
|
import { useChatPane } from '@/features/ide-react/hooks/use-chat-pane'
|
|
import { EditorAndPdf } from '@/features/ide-react/components/editor-and-pdf'
|
|
import { useEditorManagerContext } from '@/features/ide-react/context/editor-manager-context'
|
|
|
|
export const MainLayout: FC = () => {
|
|
const { view } = useLayoutContext()
|
|
|
|
const {
|
|
isOpen: sidebarIsOpen,
|
|
setIsOpen: setSidebarIsOpen,
|
|
panelRef: sidebarPanelRef,
|
|
togglePane: toggleSidebar,
|
|
handlePaneExpand: handleSidebarExpand,
|
|
handlePaneCollapse: handleSidebarCollapse,
|
|
resizing: sidebarResizing,
|
|
setResizing: setSidebarResizing,
|
|
} = useSidebarPane()
|
|
|
|
const {
|
|
isOpen: chatIsOpen,
|
|
panelRef: chatPanelRef,
|
|
togglePane: toggleChat,
|
|
resizing: chatResizing,
|
|
setResizing: setChatResizing,
|
|
handlePaneCollapse: handleChatCollapse,
|
|
handlePaneExpand: handleChatExpand,
|
|
} = useChatPane()
|
|
|
|
const { currentDocumentId } = useEditorManagerContext()
|
|
|
|
const { t } = useTranslation()
|
|
|
|
// keep the editor pane open when a doc is open, even if the history view is open
|
|
const editorPane = currentDocumentId ? <EditorPane /> : null
|
|
|
|
return (
|
|
<div className="ide-react-main">
|
|
<EditorNavigationToolbar />
|
|
<div className="ide-react-body">
|
|
<PanelGroup
|
|
autoSaveId="ide-outer-layout"
|
|
direction="horizontal"
|
|
className={classNames({
|
|
'ide-panel-group-resizing': sidebarResizing || chatResizing,
|
|
})}
|
|
>
|
|
{/* sidebar */}
|
|
<Panel
|
|
ref={sidebarPanelRef}
|
|
id="panel-sidebar"
|
|
order={1}
|
|
defaultSize={15}
|
|
minSize={5}
|
|
maxSize={80}
|
|
collapsible
|
|
onCollapse={handleSidebarCollapse}
|
|
onExpand={handleSidebarExpand}
|
|
>
|
|
<EditorSidebar />
|
|
{view === 'history' && <HistorySidebar />}
|
|
</Panel>
|
|
|
|
<HorizontalResizeHandle
|
|
onDoubleClick={toggleSidebar}
|
|
resizable={sidebarIsOpen}
|
|
onDragging={setSidebarResizing}
|
|
>
|
|
<HorizontalToggler
|
|
id="panel-sidebar"
|
|
togglerType="west"
|
|
isOpen={sidebarIsOpen}
|
|
setIsOpen={setSidebarIsOpen}
|
|
tooltipWhenOpen={t('tooltip_hide_filetree')}
|
|
tooltipWhenClosed={t('tooltip_show_filetree')}
|
|
/>
|
|
</HorizontalResizeHandle>
|
|
|
|
<Panel id="panel-outer-main" order={2}>
|
|
<PanelGroup autoSaveId="ide-inner-layout" direction="horizontal">
|
|
<Panel className="ide-react-panel" id="panel-main" order={1}>
|
|
{view === 'history' ? (
|
|
<HistoryProvider>
|
|
<History />
|
|
</HistoryProvider>
|
|
) : (
|
|
<EditorAndPdf editorPane={editorPane} />
|
|
)}
|
|
</Panel>
|
|
|
|
<HorizontalResizeHandle
|
|
onDoubleClick={toggleChat}
|
|
resizable={chatIsOpen}
|
|
onDragging={setChatResizing}
|
|
/>
|
|
|
|
{/* chat */}
|
|
<Panel
|
|
ref={chatPanelRef}
|
|
id="panel-chat"
|
|
order={2}
|
|
defaultSize={20}
|
|
minSize={5}
|
|
maxSize={30}
|
|
collapsible
|
|
onCollapse={handleChatCollapse}
|
|
onExpand={handleChatExpand}
|
|
>
|
|
<ChatPane />
|
|
</Panel>
|
|
</PanelGroup>
|
|
</Panel>
|
|
</PanelGroup>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|