feat:实际应用自定义prompt,修复docker同级目录问题

This commit is contained in:
SengokuCola
2026-05-08 13:05:39 +08:00
parent 2c14fd8d49
commit fb3f4c28ef
8 changed files with 216 additions and 18 deletions

View File

@@ -2,6 +2,7 @@ import { useEffect, useState } from 'react'
import {
Clock,
Code2,
Copy,
FileCode2,
FileText,
RefreshCw,
@@ -10,6 +11,7 @@ import {
import { Badge } from '@/components/ui/badge'
import { Button } from '@/components/ui/button'
import { useToast } from '@/hooks/use-toast'
import { Input } from '@/components/ui/input'
import { ScrollArea } from '@/components/ui/scroll-area'
import {
@@ -49,6 +51,7 @@ function formatSize(size: number): string {
}
export function ReasoningProcessPage() {
const { toast } = useToast()
const [items, setItems] = useState<ReasoningPromptFile[]>([])
const [stages, setStages] = useState<string[]>([])
const [sessions, setSessions] = useState<string[]>([])
@@ -165,6 +168,31 @@ export function ReasoningProcessPage() {
setPage(1)
}
async function handleCopyPrompt() {
if (!textContent || contentLoading) {
toast({
title: '暂无可复制内容',
description: '请先选择一条包含 txt 的 prompt 记录',
variant: 'destructive',
})
return
}
try {
await navigator.clipboard.writeText(textContent)
toast({
title: '已复制完整 Prompt',
description: selected ? `${selected.stage}/${selected.session_id}/${selected.stem}` : undefined,
})
} catch (err) {
toast({
title: '复制失败',
description: err instanceof Error ? err.message : '请手动选择文本复制',
variant: 'destructive',
})
}
}
return (
<div className="flex h-full min-h-0 flex-col gap-3 overflow-hidden p-3 lg:p-4">
<div className="flex flex-col gap-2 lg:flex-row lg:items-center lg:justify-between">
@@ -328,6 +356,17 @@ export function ReasoningProcessPage() {
</div>
{selected && (
<div className="flex items-center gap-2 text-xs text-muted-foreground">
<Button
variant="outline"
size="sm"
className="h-8 gap-1.5"
onClick={handleCopyPrompt}
disabled={!selected.text_path || contentLoading || !textContent}
title="复制完整 Prompt"
>
<Copy className="h-3.5 w-3.5" />
</Button>
{selected.text_path && (
<span className="inline-flex items-center gap-1">
<FileText className="h-3.5 w-3.5" />