mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-21 15:55:50 +00:00
71 lines
2.4 KiB
TypeScript
71 lines
2.4 KiB
TypeScript
import React from 'react';
|
|
import { logEvent } from 'src/services/analytics/index.js';
|
|
// eslint-disable-next-line custom-rules/prefer-use-keybindings -- enter to continue
|
|
import { Box, Dialog, Link, Newline, Text, useInput } from '@anthropic/ink';
|
|
import { isChromeExtensionInstalled } from '../utils/claudeInChrome/setup.js';
|
|
import { saveGlobalConfig } from '../utils/config.js';
|
|
|
|
const CHROME_EXTENSION_URL = 'https://claude.ai/chrome';
|
|
const CHROME_PERMISSIONS_URL = 'https://clau.de/chrome/permissions';
|
|
|
|
type Props = {
|
|
onDone(): void;
|
|
};
|
|
|
|
export function ClaudeInChromeOnboarding({ onDone }: Props): React.ReactNode {
|
|
const [isExtensionInstalled, setIsExtensionInstalled] = React.useState(false);
|
|
|
|
React.useEffect(() => {
|
|
logEvent('tengu_claude_in_chrome_onboarding_shown', {});
|
|
void isChromeExtensionInstalled().then(setIsExtensionInstalled);
|
|
saveGlobalConfig(current => {
|
|
return { ...current, hasCompletedClaudeInChromeOnboarding: true };
|
|
});
|
|
}, []);
|
|
|
|
// Handle Enter to continue
|
|
useInput((_input, key) => {
|
|
if (key.return) {
|
|
onDone();
|
|
}
|
|
});
|
|
|
|
return (
|
|
<Dialog title="Claude in Chrome (Beta)" onCancel={onDone} color="chromeYellow">
|
|
<Box flexDirection="column" gap={1}>
|
|
<Text>
|
|
Claude in Chrome works with the Chrome extension to let you control your browser directly from Claude Code.
|
|
You can navigate websites, fill forms, capture screenshots, record GIFs, and debug with console logs and
|
|
network requests.
|
|
{!isExtensionInstalled && (
|
|
<>
|
|
<Newline />
|
|
<Newline />
|
|
Requires the Chrome extension. Get started at <Link url={CHROME_EXTENSION_URL} />
|
|
</>
|
|
)}
|
|
</Text>
|
|
|
|
<Text dimColor>
|
|
Site-level permissions are inherited from the Chrome extension. Manage permissions in the Chrome extension
|
|
settings to control which sites Claude can browse, click, and type on
|
|
{isExtensionInstalled && (
|
|
<>
|
|
{' '}
|
|
(<Link url={CHROME_PERMISSIONS_URL} />)
|
|
</>
|
|
)}
|
|
.
|
|
</Text>
|
|
<Text dimColor>
|
|
For more info, use{' '}
|
|
<Text bold color="chromeYellow">
|
|
/chrome
|
|
</Text>{' '}
|
|
or visit <Link url="https://code.claude.com/docs/en/chrome" />
|
|
</Text>
|
|
</Box>
|
|
</Dialog>
|
|
);
|
|
}
|