mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-15 21:05:51 +00:00
Apply proper TypeScript type corrections without any unsafe casts:
- Fix unknown/never/{} types from decompilation
- Correct function signatures and parameter types
- Add missing type declarations and interfaces
- Fix Ink component prop types
- Update API client/provider type annotations
Test files with mock data casts are included as-is (acceptable pattern).
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
86 lines
2.8 KiB
TypeScript
86 lines
2.8 KiB
TypeScript
import React from 'react'
|
|
import { logEvent } from 'src/services/analytics/index.js'
|
|
import { Box, Dialog, Link, Text } from '@anthropic/ink'
|
|
import { updateSettingsForSource } from '../utils/settings/settings.js'
|
|
import { Select } from './CustomSelect/index.js'
|
|
|
|
// NOTE: This copy is legally reviewed — do not modify without Legal team approval.
|
|
export const AUTO_MODE_DESCRIPTION =
|
|
"Auto mode lets Claude handle permission prompts automatically — Claude checks each tool call for risky actions and prompt injection before executing. Actions Claude identifies as safe are executed, while actions Claude identifies as risky are blocked and Claude may try a different approach. Ideal for long-running tasks. Sessions are slightly more expensive. Claude can make mistakes that allow harmful commands to run, it's recommended to only use in isolated environments. Shift+Tab to change mode."
|
|
|
|
type Props = {
|
|
onAccept(): void
|
|
onDecline(): void
|
|
// Startup gate: decline exits the process, so relabel accordingly.
|
|
declineExits?: boolean
|
|
}
|
|
|
|
export function AutoModeOptInDialog({
|
|
onAccept,
|
|
onDecline,
|
|
declineExits,
|
|
}: Props): React.ReactNode {
|
|
React.useEffect(() => {
|
|
logEvent('tengu_auto_mode_opt_in_dialog_shown', {})
|
|
}, [])
|
|
|
|
function onChange(value: 'accept' | 'accept-default' | 'decline') {
|
|
switch (value) {
|
|
case 'accept': {
|
|
logEvent('tengu_auto_mode_opt_in_dialog_accept', {})
|
|
updateSettingsForSource('userSettings', {
|
|
skipAutoPermissionPrompt: true,
|
|
})
|
|
onAccept()
|
|
break
|
|
}
|
|
case 'accept-default': {
|
|
logEvent('tengu_auto_mode_opt_in_dialog_accept_default', {})
|
|
updateSettingsForSource('userSettings', {
|
|
skipAutoPermissionPrompt: true,
|
|
permissions: { defaultMode: 'auto' },
|
|
})
|
|
onAccept()
|
|
break
|
|
}
|
|
case 'decline': {
|
|
logEvent('tengu_auto_mode_opt_in_dialog_decline', {})
|
|
onDecline()
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
return (
|
|
<Dialog title="Enable auto mode?" color="warning" onCancel={onDecline}>
|
|
<Box flexDirection="column" gap={1}>
|
|
<Text>{AUTO_MODE_DESCRIPTION}</Text>
|
|
|
|
<Link url="https://code.claude.com/docs/en/security" />
|
|
</Box>
|
|
|
|
<Select
|
|
options={[
|
|
...((process.env.USER_TYPE as string) !== 'ant'
|
|
? [
|
|
{
|
|
label: 'Yes, and make it my default mode',
|
|
value: 'accept-default' as const,
|
|
},
|
|
]
|
|
: []),
|
|
{ label: 'Yes, enable auto mode', value: 'accept' as const },
|
|
{
|
|
label: declineExits ? 'No, exit' : 'No, go back',
|
|
value: 'decline' as const,
|
|
},
|
|
]}
|
|
onChange={value =>
|
|
onChange(value as 'accept' | 'accept-default' | 'decline')
|
|
}
|
|
onCancel={onDecline}
|
|
/>
|
|
</Dialog>
|
|
)
|
|
}
|