Files
gemini-cli/packages/cli/src/ui/layouts/DefaultAppLayout.tsx
T

81 lines
2.6 KiB
TypeScript
Raw Normal View History

/**
* @license
* Copyright 2025 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import type React from 'react';
import { Box } from 'ink';
import { Notifications } from '../components/Notifications.js';
import { MainContent } from '../components/MainContent.js';
import { DialogManager } from '../components/DialogManager.js';
import { Composer } from '../components/Composer.js';
import { ExitWarning } from '../components/ExitWarning.js';
import { useUIState } from '../contexts/UIStateContext.js';
import { useFlickerDetector } from '../hooks/useFlickerDetector.js';
2025-11-11 07:50:11 -08:00
import { useAlternateBuffer } from '../hooks/useAlternateBuffer.js';
import { CopyModeWarning } from '../components/CopyModeWarning.js';
import { ToolConfirmationQueue } from '../components/ToolConfirmationQueue.js';
import { useConfirmingTool } from '../hooks/useConfirmingTool.js';
import { useConfig } from '../contexts/ConfigContext.js';
export const DefaultAppLayout: React.FC = () => {
const uiState = useUIState();
const config = useConfig();
2025-11-11 07:50:11 -08:00
const isAlternateBuffer = useAlternateBuffer();
// If the event-driven scheduler is enabled AND we have a tool waiting,
// we switch the footer mode to "Queue".
const confirmingTool = useConfirmingTool();
const showConfirmationQueue =
config.isEventDrivenSchedulerEnabled() && confirmingTool !== null;
const { rootUiRef, terminalHeight } = uiState;
useFlickerDetector(rootUiRef, terminalHeight);
2025-11-11 07:50:11 -08:00
// If in alternate buffer mode, need to leave room to draw the scrollbar on
// the right side of the terminal.
return (
<Box
flexDirection="column"
width={uiState.terminalWidth}
height={isAlternateBuffer ? terminalHeight : undefined}
paddingBottom={isAlternateBuffer ? 1 : undefined}
2025-11-04 16:21:00 -08:00
flexShrink={0}
flexGrow={0}
overflow="hidden"
2025-11-11 07:50:11 -08:00
ref={uiState.rootUiRef}
>
<MainContent />
2025-11-11 07:50:11 -08:00
<Box
flexDirection="column"
ref={uiState.mainControlsRef}
flexShrink={0}
flexGrow={0}
width={uiState.terminalWidth}
2025-11-11 07:50:11 -08:00
>
<Notifications />
2025-11-11 07:50:11 -08:00
<CopyModeWarning />
{uiState.customDialog ? (
uiState.customDialog
) : uiState.dialogsVisible ? (
2025-09-29 14:19:19 -07:00
<DialogManager
terminalWidth={uiState.terminalWidth}
2025-09-29 14:19:19 -07:00
addItem={uiState.historyManager.addItem}
/>
) : (
<>
{showConfirmationQueue && confirmingTool && (
<ToolConfirmationQueue confirmingTool={confirmingTool} />
)}
<Composer isFocused={!showConfirmationQueue} />
</>
)}
<ExitWarning />
</Box>
</Box>
);
};