mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-17 13:55:50 +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>
70 lines
2.3 KiB
TypeScript
70 lines
2.3 KiB
TypeScript
import chalk from 'chalk'
|
|
import React from 'react'
|
|
import { useClipboardImageHint } from '../hooks/useClipboardImageHint.js'
|
|
import { useVimInput } from '../hooks/useVimInput.js'
|
|
import { Box, color, useTerminalFocus, useTheme } from '../ink.js'
|
|
import type { VimTextInputProps } from '../types/textInputTypes.js'
|
|
import type { TextHighlight } from '../utils/textHighlighting.js'
|
|
import { BaseTextInput } from './BaseTextInput.js'
|
|
|
|
export type Props = VimTextInputProps & {
|
|
highlights?: TextHighlight[]
|
|
}
|
|
|
|
export default function VimTextInput(props: Props): React.ReactNode {
|
|
const [theme] = useTheme()
|
|
const isTerminalFocused = useTerminalFocus()
|
|
|
|
// Show hint when terminal regains focus and clipboard has an image
|
|
useClipboardImageHint(isTerminalFocused, !!props.onImagePaste)
|
|
|
|
const vimInputState = useVimInput({
|
|
value: props.value,
|
|
onChange: props.onChange,
|
|
onSubmit: props.onSubmit,
|
|
onExit: props.onExit,
|
|
onExitMessage: props.onExitMessage,
|
|
onHistoryReset: props.onHistoryReset,
|
|
onHistoryUp: props.onHistoryUp,
|
|
onHistoryDown: props.onHistoryDown,
|
|
onClearInput: props.onClearInput,
|
|
focus: props.focus,
|
|
mask: props.mask,
|
|
multiline: props.multiline,
|
|
cursorChar: props.showCursor ? ' ' : '',
|
|
highlightPastedText: props.highlightPastedText,
|
|
invert: isTerminalFocused ? chalk.inverse : (text: string) => text,
|
|
themeText: color('text', theme),
|
|
columns: props.columns,
|
|
maxVisibleLines: props.maxVisibleLines,
|
|
onImagePaste: props.onImagePaste,
|
|
disableCursorMovementForUpDownKeys:
|
|
props.disableCursorMovementForUpDownKeys,
|
|
disableEscapeDoublePress: props.disableEscapeDoublePress,
|
|
externalOffset: props.cursorOffset,
|
|
onOffsetChange: props.onChangeCursorOffset,
|
|
inputFilter: props.inputFilter,
|
|
onModeChange: props.onModeChange,
|
|
onUndo: props.onUndo,
|
|
})
|
|
|
|
const { mode, setMode } = vimInputState
|
|
|
|
React.useEffect(() => {
|
|
if (props.initialMode && props.initialMode !== mode) {
|
|
setMode(props.initialMode)
|
|
}
|
|
}, [props.initialMode, mode, setMode])
|
|
|
|
return (
|
|
<Box flexDirection="column">
|
|
<BaseTextInput
|
|
inputState={vimInputState}
|
|
terminalFocus={isTerminalFocused}
|
|
highlights={props.highlights}
|
|
{...props}
|
|
/>
|
|
</Box>
|
|
)
|
|
}
|