Files
gemini-cli/packages/cli/src/ui/App.tsx
T

39 lines
1.3 KiB
TypeScript
Raw Normal View History

/**
* @license
* Copyright 2025 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import { useIsScreenReaderEnabled } from 'ink';
import { useUIState } from './contexts/UIStateContext.js';
import { StreamingContext } from './contexts/StreamingContext.js';
import { QuittingDisplay } from './components/QuittingDisplay.js';
import { ScreenReaderAppLayout } from './layouts/ScreenReaderAppLayout.js';
import { DefaultAppLayout } from './layouts/DefaultAppLayout.js';
2025-11-11 07:50:11 -08:00
import { AlternateBufferQuittingDisplay } from './components/AlternateBufferQuittingDisplay.js';
import { useAlternateBuffer } from './hooks/useAlternateBuffer.js';
export const App = () => {
const uiState = useUIState();
2025-11-11 07:50:11 -08:00
const isAlternateBuffer = useAlternateBuffer();
const isScreenReaderEnabled = useIsScreenReaderEnabled();
if (uiState.quittingMessages) {
2025-11-11 07:50:11 -08:00
if (isAlternateBuffer) {
return (
<StreamingContext.Provider value={uiState.streamingState}>
<AlternateBufferQuittingDisplay />
</StreamingContext.Provider>
);
} else {
return <QuittingDisplay />;
}
}
2025-04-17 18:06:21 -04:00
return (
<StreamingContext.Provider value={uiState.streamingState}>
{isScreenReaderEnabled ? <ScreenReaderAppLayout /> : <DefaultAppLayout />}
</StreamingContext.Provider>
2025-04-17 18:06:21 -04:00
);
2025-04-15 21:41:08 -07:00
};