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

55 lines
1.5 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-04 16:21:00 -08:00
import { useSettings } from '../contexts/SettingsContext.js';
export const DefaultAppLayout: React.FC = () => {
const uiState = useUIState();
const { rootUiRef, terminalHeight } = uiState;
2025-11-04 16:21:00 -08:00
const settings = useSettings();
useFlickerDetector(rootUiRef, terminalHeight);
return (
<Box
flexDirection="column"
width={uiState.mainAreaWidth}
ref={uiState.rootUiRef}
2025-11-04 16:21:00 -08:00
height={
settings.merged.ui?.useAlternateBuffer ? terminalHeight - 1 : undefined
}
flexShrink={0}
flexGrow={0}
overflow="hidden"
>
<MainContent />
<Box flexDirection="column" ref={uiState.mainControlsRef}>
<Notifications />
{uiState.dialogsVisible ? (
<DialogManager
terminalWidth={uiState.mainAreaWidth}
addItem={uiState.historyManager.addItem}
/>
) : (
<Composer />
)}
<ExitWarning />
</Box>
</Box>
);
};