* 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>
217 lines
10 KiB
TypeScript
217 lines
10 KiB
TypeScript
import { c as _c } from "react-compiler-runtime";
|
|
import { feature } from 'bun:bundle';
|
|
import * as React from 'react';
|
|
import { EnterPlanModeTool } from 'src/tools/EnterPlanModeTool/EnterPlanModeTool.js';
|
|
import { ExitPlanModeV2Tool } from 'src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.js';
|
|
import { useNotifyAfterTimeout } from '../../hooks/useNotifyAfterTimeout.js';
|
|
import { useKeybinding } from '../../keybindings/useKeybinding.js';
|
|
import type { AnyObject, Tool, ToolUseContext } from '../../Tool.js';
|
|
import { AskUserQuestionTool } from '../../tools/AskUserQuestionTool/AskUserQuestionTool.js';
|
|
import { BashTool } from '../../tools/BashTool/BashTool.js';
|
|
import { FileEditTool } from '../../tools/FileEditTool/FileEditTool.js';
|
|
import { FileReadTool } from '../../tools/FileReadTool/FileReadTool.js';
|
|
import { FileWriteTool } from '../../tools/FileWriteTool/FileWriteTool.js';
|
|
import { GlobTool } from '../../tools/GlobTool/GlobTool.js';
|
|
import { GrepTool } from '../../tools/GrepTool/GrepTool.js';
|
|
import { NotebookEditTool } from '../../tools/NotebookEditTool/NotebookEditTool.js';
|
|
import { PowerShellTool } from '../../tools/PowerShellTool/PowerShellTool.js';
|
|
import { SkillTool } from '../../tools/SkillTool/SkillTool.js';
|
|
import { WebFetchTool } from '../../tools/WebFetchTool/WebFetchTool.js';
|
|
import type { AssistantMessage } from '../../types/message.js';
|
|
import type { PermissionDecision } from '../../utils/permissions/PermissionResult.js';
|
|
import { AskUserQuestionPermissionRequest } from './AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.js';
|
|
import { BashPermissionRequest } from './BashPermissionRequest/BashPermissionRequest.js';
|
|
import { EnterPlanModePermissionRequest } from './EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.js';
|
|
import { ExitPlanModePermissionRequest } from './ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.js';
|
|
import { FallbackPermissionRequest } from './FallbackPermissionRequest.js';
|
|
import { FileEditPermissionRequest } from './FileEditPermissionRequest/FileEditPermissionRequest.js';
|
|
import { FilesystemPermissionRequest } from './FilesystemPermissionRequest/FilesystemPermissionRequest.js';
|
|
import { FileWritePermissionRequest } from './FileWritePermissionRequest/FileWritePermissionRequest.js';
|
|
import { NotebookEditPermissionRequest } from './NotebookEditPermissionRequest/NotebookEditPermissionRequest.js';
|
|
import { PowerShellPermissionRequest } from './PowerShellPermissionRequest/PowerShellPermissionRequest.js';
|
|
import { SkillPermissionRequest } from './SkillPermissionRequest/SkillPermissionRequest.js';
|
|
import { WebFetchPermissionRequest } from './WebFetchPermissionRequest/WebFetchPermissionRequest.js';
|
|
|
|
/* eslint-disable @typescript-eslint/no-require-imports */
|
|
const ReviewArtifactTool = feature('REVIEW_ARTIFACT') ? (require('../../tools/ReviewArtifactTool/ReviewArtifactTool.js') as typeof import('../../tools/ReviewArtifactTool/ReviewArtifactTool.js')).ReviewArtifactTool : null;
|
|
const ReviewArtifactPermissionRequest = feature('REVIEW_ARTIFACT') ? (require('./ReviewArtifactPermissionRequest/ReviewArtifactPermissionRequest.js') as typeof import('./ReviewArtifactPermissionRequest/ReviewArtifactPermissionRequest.js')).ReviewArtifactPermissionRequest : null;
|
|
const WorkflowTool = feature('WORKFLOW_SCRIPTS') ? (require('../../tools/WorkflowTool/WorkflowTool.js') as typeof import('../../tools/WorkflowTool/WorkflowTool.js')).WorkflowTool : null;
|
|
const WorkflowPermissionRequest = feature('WORKFLOW_SCRIPTS') ? (require('../../tools/WorkflowTool/WorkflowPermissionRequest.js') as typeof import('../../tools/WorkflowTool/WorkflowPermissionRequest.js')).WorkflowPermissionRequest : null;
|
|
const MonitorTool = feature('MONITOR_TOOL') ? (require('../../tools/MonitorTool/MonitorTool.js') as typeof import('../../tools/MonitorTool/MonitorTool.js')).MonitorTool : null;
|
|
const MonitorPermissionRequest = feature('MONITOR_TOOL') ? (require('./MonitorPermissionRequest/MonitorPermissionRequest.js') as typeof import('./MonitorPermissionRequest/MonitorPermissionRequest.js')).MonitorPermissionRequest : null;
|
|
import type { ContentBlockParam } from '@anthropic-ai/sdk/resources/messages.mjs';
|
|
/* eslint-enable @typescript-eslint/no-require-imports */
|
|
import type { z } from 'zod/v4';
|
|
import type { PermissionUpdate } from '../../utils/permissions/PermissionUpdateSchema.js';
|
|
import type { WorkerBadgeProps } from './WorkerBadge.js';
|
|
function permissionComponentForTool(tool: Tool): React.ComponentType<PermissionRequestProps> {
|
|
switch (tool) {
|
|
case FileEditTool:
|
|
return FileEditPermissionRequest;
|
|
case FileWriteTool:
|
|
return FileWritePermissionRequest;
|
|
case BashTool:
|
|
return BashPermissionRequest;
|
|
case PowerShellTool:
|
|
return PowerShellPermissionRequest;
|
|
case ReviewArtifactTool:
|
|
return ReviewArtifactPermissionRequest ?? FallbackPermissionRequest;
|
|
case WebFetchTool:
|
|
return WebFetchPermissionRequest;
|
|
case NotebookEditTool:
|
|
return NotebookEditPermissionRequest;
|
|
case ExitPlanModeV2Tool:
|
|
return ExitPlanModePermissionRequest;
|
|
case EnterPlanModeTool:
|
|
return EnterPlanModePermissionRequest;
|
|
case SkillTool:
|
|
return SkillPermissionRequest;
|
|
case AskUserQuestionTool:
|
|
return AskUserQuestionPermissionRequest;
|
|
case WorkflowTool:
|
|
return WorkflowPermissionRequest ?? FallbackPermissionRequest;
|
|
case MonitorTool:
|
|
return MonitorPermissionRequest ?? FallbackPermissionRequest;
|
|
case GlobTool:
|
|
case GrepTool:
|
|
case FileReadTool:
|
|
return FilesystemPermissionRequest;
|
|
default:
|
|
return FallbackPermissionRequest;
|
|
}
|
|
}
|
|
export type PermissionRequestProps<Input extends AnyObject = AnyObject> = {
|
|
toolUseConfirm: ToolUseConfirm<Input>;
|
|
toolUseContext: ToolUseContext;
|
|
onDone(): void;
|
|
onReject(): void;
|
|
verbose: boolean;
|
|
workerBadge: WorkerBadgeProps | undefined;
|
|
/**
|
|
* Register JSX to render in a sticky footer below the scrollable area.
|
|
* Fullscreen mode only (non-fullscreen has no sticky area — terminal
|
|
* scrollback moves everything together). Call with null to clear.
|
|
*
|
|
* Used by ExitPlanModePermissionRequest to keep response options visible
|
|
* while the user scrolls through a long plan. The callback is stable —
|
|
* JSX passed should use refs for callbacks that close over component state
|
|
* to avoid stale closures (React reconciles the JSX, preserving Select's
|
|
* internal focus/input state).
|
|
*/
|
|
setStickyFooter?: (jsx: React.ReactNode | null) => void;
|
|
};
|
|
export type ToolUseConfirm<Input extends AnyObject = AnyObject> = {
|
|
assistantMessage: AssistantMessage;
|
|
tool: Tool<Input>;
|
|
description: string;
|
|
input: z.infer<Input>;
|
|
toolUseContext: ToolUseContext;
|
|
toolUseID: string;
|
|
permissionResult: PermissionDecision;
|
|
permissionPromptStartTimeMs: number;
|
|
/**
|
|
* Called when user interacts with the permission dialog (e.g., arrow keys, tab, typing).
|
|
* This prevents async auto-approval mechanisms (like the bash classifier) from
|
|
* dismissing the dialog while the user is actively engaging with it.
|
|
*/
|
|
classifierCheckInProgress?: boolean;
|
|
classifierAutoApproved?: boolean;
|
|
classifierMatchedRule?: string;
|
|
workerBadge?: WorkerBadgeProps;
|
|
onUserInteraction(): void;
|
|
onAbort(): void;
|
|
onDismissCheckmark?(): void;
|
|
onAllow(updatedInput: z.infer<Input>, permissionUpdates: PermissionUpdate[], feedback?: string, contentBlocks?: ContentBlockParam[]): void;
|
|
onReject(feedback?: string, contentBlocks?: ContentBlockParam[]): void;
|
|
recheckPermission(): Promise<void>;
|
|
};
|
|
function getNotificationMessage(toolUseConfirm: ToolUseConfirm): string {
|
|
const toolName = toolUseConfirm.tool.userFacingName(toolUseConfirm.input as never);
|
|
if (toolUseConfirm.tool === ExitPlanModeV2Tool) {
|
|
return 'OpenClaude needs your approval for the plan';
|
|
}
|
|
if (toolUseConfirm.tool === EnterPlanModeTool) {
|
|
return 'OpenClaude wants to enter plan mode';
|
|
}
|
|
if (feature('REVIEW_ARTIFACT') && toolUseConfirm.tool === ReviewArtifactTool) {
|
|
return 'OpenClaude needs your approval for a review artifact';
|
|
}
|
|
if (!toolName || toolName.trim() === '') {
|
|
return 'OpenClaude needs your attention';
|
|
}
|
|
return `OpenClaude needs your permission to use ${toolName}`;
|
|
}
|
|
|
|
// TODO: Move this to Tool.renderPermissionRequest
|
|
export function PermissionRequest(t0) {
|
|
const $ = _c(18);
|
|
const {
|
|
toolUseConfirm,
|
|
toolUseContext,
|
|
onDone,
|
|
onReject,
|
|
verbose,
|
|
workerBadge,
|
|
setStickyFooter
|
|
} = t0;
|
|
let t1;
|
|
if ($[0] !== onDone || $[1] !== onReject || $[2] !== toolUseConfirm) {
|
|
t1 = () => {
|
|
onDone();
|
|
onReject();
|
|
toolUseConfirm.onReject();
|
|
};
|
|
$[0] = onDone;
|
|
$[1] = onReject;
|
|
$[2] = toolUseConfirm;
|
|
$[3] = t1;
|
|
} else {
|
|
t1 = $[3];
|
|
}
|
|
let t2;
|
|
if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
|
|
t2 = {
|
|
context: "Confirmation"
|
|
};
|
|
$[4] = t2;
|
|
} else {
|
|
t2 = $[4];
|
|
}
|
|
useKeybinding("app:interrupt", t1, t2);
|
|
let t3;
|
|
if ($[5] !== toolUseConfirm) {
|
|
t3 = getNotificationMessage(toolUseConfirm);
|
|
$[5] = toolUseConfirm;
|
|
$[6] = t3;
|
|
} else {
|
|
t3 = $[6];
|
|
}
|
|
const notificationMessage = t3;
|
|
useNotifyAfterTimeout(notificationMessage, "permission_prompt");
|
|
let t4;
|
|
if ($[7] !== toolUseConfirm.tool) {
|
|
t4 = permissionComponentForTool(toolUseConfirm.tool);
|
|
$[7] = toolUseConfirm.tool;
|
|
$[8] = t4;
|
|
} else {
|
|
t4 = $[8];
|
|
}
|
|
const PermissionComponent = t4;
|
|
let t5;
|
|
if ($[9] !== PermissionComponent || $[10] !== onDone || $[11] !== onReject || $[12] !== setStickyFooter || $[13] !== toolUseConfirm || $[14] !== toolUseContext || $[15] !== verbose || $[16] !== workerBadge) {
|
|
t5 = <PermissionComponent toolUseContext={toolUseContext} toolUseConfirm={toolUseConfirm} onDone={onDone} onReject={onReject} verbose={verbose} workerBadge={workerBadge} setStickyFooter={setStickyFooter} />;
|
|
$[9] = PermissionComponent;
|
|
$[10] = onDone;
|
|
$[11] = onReject;
|
|
$[12] = setStickyFooter;
|
|
$[13] = toolUseConfirm;
|
|
$[14] = toolUseContext;
|
|
$[15] = verbose;
|
|
$[16] = workerBadge;
|
|
$[17] = t5;
|
|
} else {
|
|
t5 = $[17];
|
|
}
|
|
return t5;
|
|
}
|