mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-05-29 15:40:10 +00:00
69 lines
1.7 KiB
TypeScript
69 lines
1.7 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2026 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import type React from 'react';
|
|
import { useMemo } from 'react';
|
|
import { Box, Text } from 'ink';
|
|
import { theme } from '../semantic-colors.js';
|
|
import {
|
|
type Config,
|
|
UserAccountManager,
|
|
AuthType,
|
|
} from '@google/gemini-cli-core';
|
|
|
|
interface UserIdentityProps {
|
|
config: Config;
|
|
}
|
|
|
|
export const UserIdentity: React.FC<UserIdentityProps> = ({ config }) => {
|
|
const authType = config.getContentGeneratorConfig()?.authType;
|
|
const email = useMemo(() => {
|
|
if (authType) {
|
|
const userAccountManager = new UserAccountManager();
|
|
return userAccountManager.getCachedGoogleAccount() ?? undefined;
|
|
}
|
|
return undefined;
|
|
}, [authType]);
|
|
|
|
const tierName = useMemo(
|
|
() => (authType ? config.getUserTierName() : undefined),
|
|
[config, authType],
|
|
);
|
|
|
|
if (!authType) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<Box flexDirection="column">
|
|
{/* User Email /auth */}
|
|
<Box>
|
|
<Text color={theme.text.primary} wrap="truncate-end">
|
|
{authType === AuthType.LOGIN_WITH_GOOGLE ? (
|
|
<Text>
|
|
<Text bold>Signed in with Google{email ? ':' : ''}</Text>
|
|
{email ? ` ${email}` : ''}
|
|
</Text>
|
|
) : (
|
|
`Authenticated with ${authType}`
|
|
)}
|
|
</Text>
|
|
<Text color={theme.text.secondary}> /auth</Text>
|
|
</Box>
|
|
|
|
{/* Tier Name /upgrade */}
|
|
{tierName && (
|
|
<Box>
|
|
<Text color={theme.text.primary} wrap="truncate-end">
|
|
<Text bold>Plan:</Text> {tierName}
|
|
</Text>
|
|
<Text color={theme.text.secondary}> /upgrade</Text>
|
|
</Box>
|
|
)}
|
|
</Box>
|
|
);
|
|
};
|