文件搜索结果里对目录图标着色

This commit is contained in:
xintaofei
2026-03-19 00:35:36 +08:00
parent 33d70b8866
commit dc461c1c18
4 changed files with 59 additions and 59 deletions

View File

@@ -142,7 +142,8 @@ export function SearchCommandDialog({
entry.relativePath
)
const lastSlash = entry.relativePath.lastIndexOf("/")
const dir = lastSlash === -1 ? "" : entry.relativePath.slice(0, lastSlash)
const dir =
lastSlash === -1 ? "" : entry.relativePath.slice(0, lastSlash)
matchers.push({
prefix: dir ? dir + "/" : "",
matcher: ig().add(result.content),
@@ -168,8 +169,7 @@ export function SearchCommandDialog({
if (!f.relativePath.startsWith(prefix)) continue
const relPath = f.relativePath.slice(prefix.length)
if (!relPath) continue
const testPath =
f.kind === "dir" ? `${relPath}/` : relPath
const testPath = f.kind === "dir" ? `${relPath}/` : relPath
if (matcher.ignores(testPath)) {
if (f.kind === "dir") ignoredDirs.add(f.relativePath)
return false
@@ -284,9 +284,7 @@ export function SearchCommandDialog({
)
const placeholder =
activeTab === "conversations"
? t("placeholder")
: t("filePlaceholder")
activeTab === "conversations" ? t("placeholder") : t("filePlaceholder")
return (
<CommandDialog
@@ -387,9 +385,8 @@ export function SearchCommandDialog({
<span
className={cn(
"w-2 h-2 rounded-full shrink-0",
STATUS_COLORS[
conv.status as ConversationStatus
] ?? "bg-gray-400"
STATUS_COLORS[conv.status as ConversationStatus] ??
"bg-gray-400"
)}
/>
<span className="flex-1 truncate">
@@ -430,13 +427,11 @@ export function SearchCommandDialog({
onSelect={() => handleSelectFile(entry)}
>
{entry.kind === "dir" ? (
<Folder className="w-4 h-4 shrink-0 text-muted-foreground" />
<Folder className="w-4 h-4 shrink-0 text-blue-500" />
) : (
<File className="w-4 h-4 shrink-0 text-muted-foreground" />
)}
<span className="flex-1 truncate">
{entry.name}
</span>
<span className="flex-1 truncate">{entry.name}</span>
<span className="text-xs text-muted-foreground shrink-0 truncate max-w-48">
{entry.relativePath}
</span>

View File

@@ -2321,7 +2321,9 @@ export function FileTreeTab() {
<DialogContent
onOpenAutoFocus={(e) => {
e.preventDefault()
const input = (e.currentTarget as HTMLElement | null)?.querySelector("input")
const input = (
e.currentTarget as HTMLElement | null
)?.querySelector("input")
if (input) requestAnimationFrame(() => input.focus())
}}
>
@@ -2388,7 +2390,9 @@ export function FileTreeTab() {
<DialogContent
onOpenAutoFocus={(e) => {
e.preventDefault()
const input = (e.currentTarget as HTMLElement | null)?.querySelector("input")
const input = (
e.currentTarget as HTMLElement | null
)?.querySelector("input")
if (input) requestAnimationFrame(() => input.focus())
}}
>

View File

@@ -26,13 +26,15 @@ export function AuxPanel() {
activeTab === "git_log"
)
// Sync mount flags when activeTab changes programmatically (e.g. revealInFileTree)
// Sync mount flags when activeTab changes programmatically (e.g. revealInFileTree).
/* eslint-disable react-hooks/set-state-in-effect */
useEffect(() => {
if (!isOpen) return
if (activeTab === "file_tree") setHasMountedFileTree(true)
else if (activeTab === "changes") setHasMountedChanges(true)
else if (activeTab === "git_log") setHasMountedGitLog(true)
}, [isOpen, activeTab])
/* eslint-enable react-hooks/set-state-in-effect */
const handleTabValueChange = useCallback(
(value: string) => {

View File

@@ -2040,10 +2040,7 @@ function hasComparableVersion(
}
function buildVersionCheck(agent: AcpAgentInfo): UiCheckItem | null {
if (
agent.distribution_type !== "binary" &&
agent.distribution_type !== "npx"
)
if (agent.distribution_type !== "binary" && agent.distribution_type !== "npx")
return null
const remoteVersion = agent.registry_version ?? "unknown"
@@ -2390,46 +2387,51 @@ export function AcpAgentSettings() {
const runPreflight = useCallback(
async (agentType: AgentType, forceRefresh?: boolean) => {
setChecking((prev) => ({ ...prev, [agentType]: true }))
try {
const [resultState, versionState] = await Promise.allSettled([
acpPreflight(agentType, forceRefresh),
acpDetectAgentLocalVersion(agentType),
])
setChecking((prev) => ({ ...prev, [agentType]: true }))
try {
const [resultState, versionState] = await Promise.allSettled([
acpPreflight(agentType, forceRefresh),
acpDetectAgentLocalVersion(agentType),
])
if (versionState.status === "fulfilled") {
setAgents((prev) => {
if (versionState.value === null) return prev
let changed = false
const next = prev.map((agent) => {
if (agent.agent_type !== agentType) return agent
if (agent.installed_version === versionState.value) return agent
changed = true
return { ...agent, installed_version: versionState.value }
if (versionState.status === "fulfilled") {
setAgents((prev) => {
if (versionState.value === null) return prev
let changed = false
const next = prev.map((agent) => {
if (agent.agent_type !== agentType) return agent
if (agent.installed_version === versionState.value) return agent
changed = true
return { ...agent, installed_version: versionState.value }
})
return changed ? next : prev
})
return changed ? next : prev
})
}
}
if (resultState.status === "fulfilled") {
setCheckState((prev) => ({
...prev,
[agentType]: { result: resultState.value },
}))
} else {
const message =
resultState.reason instanceof Error
? resultState.reason.message
: String(resultState.reason)
if (resultState.status === "fulfilled") {
setCheckState((prev) => ({
...prev,
[agentType]: { result: resultState.value },
}))
} else {
const message =
resultState.reason instanceof Error
? resultState.reason.message
: String(resultState.reason)
setCheckState((prev) => ({
...prev,
[agentType]: { error: message },
}))
}
} catch (err) {
const message = err instanceof Error ? err.message : String(err)
setCheckState((prev) => ({ ...prev, [agentType]: { error: message } }))
} finally {
setChecking((prev) => ({ ...prev, [agentType]: false }))
}
} catch (err) {
const message = err instanceof Error ? err.message : String(err)
setCheckState((prev) => ({ ...prev, [agentType]: { error: message } }))
} finally {
setChecking((prev) => ({ ...prev, [agentType]: false }))
}
}, [])
},
[]
)
const runAllPreflight = useCallback(
async (agentTypes: AgentType[]) => {
@@ -2790,10 +2792,7 @@ export function AcpAgentSettings() {
await runNpxAction(agent, "upgrade")
return
}
if (
action.kind === "uninstall_binary" ||
action.kind === "uninstall_npx"
) {
if (action.kind === "uninstall_binary" || action.kind === "uninstall_npx") {
setUninstallConfirmAgent(agent)
return
}