mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-18 06:15:51 +00:00
* style(B1-1): 格式化 ink/buddy/cli/context/screens/tasks/services/keybindings/state (43 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 修复了 Box.tsx 和 ScrollBox.tsx 中无效的 global.d.ts import。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-2): 格式化 commands (79 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-3): 格式化 components/messages,permissions,mcp,sandbox,shell (104 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-4): 格式化 components/PromptInput,FeedbackSurvey,tasks,agents,skills,design-system,wizard (73 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-5): 格式化 components其余 + hooks + tools (232 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * style(B1-6): 格式化 main/entrypoints/utils/moreright (21 files) 纯格式化:移除分号、React Compiler import、import 多行展开。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * docs: 更新 README,新增 Run.ps1/TODO.md,删除 V6.md - README.md: 大幅重写,更详细版本历史和配置示例 - Run.ps1: 新增 Windows 启动脚本 - TODO.md: 新增包完成清单 - V6.md: 删除(架构重构规划已不适用) Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: 修复以前的问题 * fix: 修复 login 面板的问题 --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
102 lines
3.4 KiB
TypeScript
102 lines
3.4 KiB
TypeScript
import * as React from 'react'
|
|
import { useCallback, useState } from 'react'
|
|
import { useDoublePress } from '../hooks/useDoublePress.js'
|
|
import { Box, Text } from '../ink.js'
|
|
import { useKeybinding } from '../keybindings/useKeybinding.js'
|
|
import { useShortcutDisplay } from '../keybindings/useShortcutDisplay.js'
|
|
import {
|
|
useAppState,
|
|
useAppStateStore,
|
|
useSetAppState,
|
|
} from '../state/AppState.js'
|
|
import {
|
|
backgroundAll,
|
|
hasForegroundTasks,
|
|
} from '../tasks/LocalShellTask/LocalShellTask.js'
|
|
import { getGlobalConfig, saveGlobalConfig } from '../utils/config.js'
|
|
import { env } from '../utils/env.js'
|
|
import { isEnvTruthy } from '../utils/envUtils.js'
|
|
import { KeyboardShortcutHint } from './design-system/KeyboardShortcutHint.js'
|
|
|
|
type Props = {
|
|
onBackgroundSession: () => void
|
|
isLoading: boolean
|
|
}
|
|
|
|
/**
|
|
* Shows a hint when user presses Ctrl+B to background the current session.
|
|
* Uses double-press pattern: first press shows hint, second press within 800ms backgrounds.
|
|
*
|
|
* Only activates when:
|
|
* 1. isLoading is true (a query is in progress)
|
|
* 2. No foreground tasks (bash/agent) are running (those take priority for Ctrl+B)
|
|
*/
|
|
export function SessionBackgroundHint({
|
|
onBackgroundSession,
|
|
isLoading,
|
|
}: Props): React.ReactElement | null {
|
|
const setAppState = useSetAppState()
|
|
const appStateStore = useAppStateStore()
|
|
|
|
const [showSessionHint, setShowSessionHint] = useState(false)
|
|
|
|
const handleDoublePress = useDoublePress(
|
|
setShowSessionHint,
|
|
onBackgroundSession,
|
|
() => {}, // First press just shows the hint
|
|
)
|
|
|
|
// Handler for task:background - prioritizes foreground tasks, falls back to session backgrounding
|
|
// Skip all background functionality if background tasks are disabled
|
|
const handleBackground = useCallback(() => {
|
|
if (isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_BACKGROUND_TASKS)) {
|
|
return
|
|
}
|
|
const state = appStateStore.getState()
|
|
if (hasForegroundTasks(state)) {
|
|
// Existing behavior - background running bash/agent tasks
|
|
backgroundAll(() => appStateStore.getState(), setAppState)
|
|
if (!getGlobalConfig().hasUsedBackgroundTask) {
|
|
saveGlobalConfig(c =>
|
|
c.hasUsedBackgroundTask ? c : { ...c, hasUsedBackgroundTask: true },
|
|
)
|
|
}
|
|
} else if (
|
|
isEnvTruthy("false") &&
|
|
isLoading
|
|
) {
|
|
// New behavior - double-press to background session (gated)
|
|
handleDoublePress()
|
|
}
|
|
}, [setAppState, appStateStore, isLoading, handleDoublePress])
|
|
|
|
// Only eat ctrl+b when there's something to background. Without this gate
|
|
// the binding double-fires with readline backward-char at an idle prompt.
|
|
const hasForeground = useAppState(hasForegroundTasks)
|
|
const sessionBgEnabled = isEnvTruthy("false")
|
|
useKeybinding('task:background', handleBackground, {
|
|
context: 'Task',
|
|
isActive: hasForeground || (sessionBgEnabled && isLoading),
|
|
})
|
|
|
|
// Get the configured shortcut for task:background
|
|
const baseShortcut = useShortcutDisplay('task:background', 'Task', 'ctrl+b')
|
|
// In tmux, ctrl+b is the prefix key, so users need to press it twice to send ctrl+b
|
|
const shortcut =
|
|
env.terminal === 'tmux' && baseShortcut === 'ctrl+b'
|
|
? 'ctrl+b ctrl+b'
|
|
: baseShortcut
|
|
|
|
if (!isLoading || !showSessionHint) {
|
|
return null
|
|
}
|
|
|
|
return (
|
|
<Box paddingLeft={2}>
|
|
<Text dimColor>
|
|
<KeyboardShortcutHint shortcut={shortcut} action="background" />
|
|
</Text>
|
|
</Box>
|
|
)
|
|
}
|