* chore: rebrand user-facing copy to OpenClaude Replace lingering Claude Code branding in CLI, tips, and runtime UI with OpenClaude/openclaude, including the startup tip Gitlawb mention. Co-Authored-By: Claude GPT-5.4 <noreply@openclaude.dev> * chore: address branding-sweep review feedback - PermissionRequest.tsx: rebrand the two remaining "Claude needs your approval/permission" notifications to OpenClaude (review-artifact and generic tool permission paths). - main.tsx, teleport.tsx, session.tsx, WebFetchTool/utils.ts, skills/bundled/{debug,updateConfig}.ts: replace leftover `claude --…` CLI hints and "Claude Code" labels missed by the original sweep. - main.tsx: drop the inline gitlawb.com marketing copy from the stale-prompt tip; keep it a pure rebrand. - auth.ts: finish the half-rename so both `claude setup-token` and `claude auth login` references in the same error block now read `openclaude …`. - mcp/client.ts: keep `name: 'claude-code'` for MCP server allowlist compatibility (now explicit via comment) and replace the "Anthropic's agentic coding tool" description with an OpenClaude one. - MCPSettings.tsx: point the empty-server-list hint at https://github.com/Gitlawb/openclaude instead of code.claude.com. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com> * chore: replace help link with OpenClaude repo URL Replace https://code.claude.com/docs/en/overview with https://github.com/Gitlawb/openclaude in the help screen. Co-Authored-By: OpenClaude <openclaude@gitlawb.com> --------- Co-authored-by: Claude GPT-5.4 <noreply@openclaude.dev> Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com> Co-authored-by: OpenClaude <openclaude@gitlawb.com>
121 lines
3.5 KiB
TypeScript
121 lines
3.5 KiB
TypeScript
import { c as _c } from "react-compiler-runtime";
|
|
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, Link, Newline, Text, useInput } from '../ink.js';
|
|
import { isChromeExtensionInstalled } from '../utils/claudeInChrome/setup.js';
|
|
import { saveGlobalConfig } from '../utils/config.js';
|
|
import { Dialog } from './design-system/Dialog.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(t0) {
|
|
const $ = _c(20);
|
|
const {
|
|
onDone
|
|
} = t0;
|
|
const [isExtensionInstalled, setIsExtensionInstalled] = React.useState(false);
|
|
let t1;
|
|
let t2;
|
|
if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
|
|
t1 = () => {
|
|
logEvent("tengu_claude_in_chrome_onboarding_shown", {});
|
|
isChromeExtensionInstalled().then(setIsExtensionInstalled);
|
|
saveGlobalConfig(_temp);
|
|
};
|
|
t2 = [];
|
|
$[0] = t1;
|
|
$[1] = t2;
|
|
} else {
|
|
t1 = $[0];
|
|
t2 = $[1];
|
|
}
|
|
React.useEffect(t1, t2);
|
|
let t3;
|
|
if ($[2] !== onDone) {
|
|
t3 = (_input, key) => {
|
|
if (key.return) {
|
|
onDone();
|
|
}
|
|
};
|
|
$[2] = onDone;
|
|
$[3] = t3;
|
|
} else {
|
|
t3 = $[3];
|
|
}
|
|
useInput(t3);
|
|
let t4;
|
|
if ($[4] !== isExtensionInstalled) {
|
|
t4 = !isExtensionInstalled && <><Newline /><Newline />Requires the Chrome extension. Get started at{" "}<Link url={CHROME_EXTENSION_URL} /></>;
|
|
$[4] = isExtensionInstalled;
|
|
$[5] = t4;
|
|
} else {
|
|
t4 = $[5];
|
|
}
|
|
let t5;
|
|
if ($[6] !== t4) {
|
|
t5 = <Text>Claude in Chrome works with the Chrome extension to let you control your browser directly from OpenClaude. You can navigate websites, fill forms, capture screenshots, record GIFs, and debug with console logs and network requests.{t4}</Text>;
|
|
$[6] = t4;
|
|
$[7] = t5;
|
|
} else {
|
|
t5 = $[7];
|
|
}
|
|
let t6;
|
|
if ($[8] !== isExtensionInstalled) {
|
|
t6 = isExtensionInstalled && <>{" "}(<Link url={CHROME_PERMISSIONS_URL} />)</>;
|
|
$[8] = isExtensionInstalled;
|
|
$[9] = t6;
|
|
} else {
|
|
t6 = $[9];
|
|
}
|
|
let t7;
|
|
if ($[10] !== t6) {
|
|
t7 = <Text dimColor={true}>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{t6}.</Text>;
|
|
$[10] = t6;
|
|
$[11] = t7;
|
|
} else {
|
|
t7 = $[11];
|
|
}
|
|
let t8;
|
|
if ($[12] === Symbol.for("react.memo_cache_sentinel")) {
|
|
t8 = <Text bold={true} color="chromeYellow">/chrome</Text>;
|
|
$[12] = t8;
|
|
} else {
|
|
t8 = $[12];
|
|
}
|
|
let t9;
|
|
if ($[13] === Symbol.for("react.memo_cache_sentinel")) {
|
|
t9 = <Text dimColor={true}>For more info, use{" "}{t8}{" "}or visit <Link url="https://code.claude.com/docs/en/chrome" /></Text>;
|
|
$[13] = t9;
|
|
} else {
|
|
t9 = $[13];
|
|
}
|
|
let t10;
|
|
if ($[14] !== t5 || $[15] !== t7) {
|
|
t10 = <Box flexDirection="column" gap={1}>{t5}{t7}{t9}</Box>;
|
|
$[14] = t5;
|
|
$[15] = t7;
|
|
$[16] = t10;
|
|
} else {
|
|
t10 = $[16];
|
|
}
|
|
let t11;
|
|
if ($[17] !== onDone || $[18] !== t10) {
|
|
t11 = <Dialog title="Claude in Chrome (Beta)" onCancel={onDone} color="chromeYellow">{t10}</Dialog>;
|
|
$[17] = onDone;
|
|
$[18] = t10;
|
|
$[19] = t11;
|
|
} else {
|
|
t11 = $[19];
|
|
}
|
|
return t11;
|
|
}
|
|
function _temp(current) {
|
|
return {
|
|
...current,
|
|
hasCompletedClaudeInChromeOnboarding: true
|
|
};
|
|
}
|