Files
claude-code/src/utils/autoRunIssue.tsx
claude-code-best 5b1a52b8e0 更新大量 tsx 原始文件; 已经迁移 login panel; 部分 (#121)
* 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>
2026-04-04 23:24:27 +08:00

98 lines
2.4 KiB
TypeScript

import * as React from 'react'
import { useEffect, useRef } from 'react'
import { KeyboardShortcutHint } from '../components/design-system/KeyboardShortcutHint.js'
import { Box, Text } from '../ink.js'
import { useKeybinding } from '../keybindings/useKeybinding.js'
type Props = {
onRun: () => void
onCancel: () => void
reason: string
}
/**
* Component that shows a notification about running /issue command
* with the ability to cancel via ESC key
*/
export function AutoRunIssueNotification({
onRun,
onCancel,
reason,
}: Props): React.ReactNode {
const hasRunRef = useRef(false)
// Handle ESC key to cancel
useKeybinding('confirm:no', onCancel, { context: 'Confirmation' })
// Run /issue immediately on mount
useEffect(() => {
if (!hasRunRef.current) {
hasRunRef.current = true
onRun()
}
}, [onRun])
return (
<Box flexDirection="column" marginTop={1}>
<Box>
<Text bold>Running feedback capture...</Text>
</Box>
<Box>
<Text dimColor>
Press <KeyboardShortcutHint shortcut="Esc" action="cancel" /> anytime
</Text>
</Box>
<Box>
<Text dimColor>Reason: {reason}</Text>
</Box>
</Box>
)
}
export type AutoRunIssueReason = 'feedback_survey_bad' | 'feedback_survey_good'
/**
* Determines if /issue should auto-run for Ant users
*/
export function shouldAutoRunIssue(reason: AutoRunIssueReason): boolean {
// Only for Ant users
if (process.env.USER_TYPE !== 'ant') {
return false
}
switch (reason) {
case 'feedback_survey_bad':
return false
case 'feedback_survey_good':
return false
default:
return false
}
}
/**
* Returns the appropriate command to auto-run based on the reason
* ANT-ONLY: good-claude command only exists in ant builds
*/
export function getAutoRunCommand(reason: AutoRunIssueReason): string {
// Only ant builds have the /good-claude command
if (process.env.USER_TYPE === 'ant' && reason === 'feedback_survey_good') {
return '/good-claude'
}
return '/issue'
}
/**
* Gets a human-readable description of why /issue is being auto-run
*/
export function getAutoRunIssueReasonText(reason: AutoRunIssueReason): string {
switch (reason) {
case 'feedback_survey_bad':
return 'You responded "Bad" to the feedback survey'
case 'feedback_survey_good':
return 'You responded "Good" to the feedback survey'
default:
return 'Unknown reason'
}
}