后端: - 审核结果拆分为 4 个独立维度 (法规合规/平台规则/品牌安全/Brief匹配度) - 卖点优先级从 required:bool 改为三级 (core/recommended/reference) - AI 语义匹配卖点覆盖 + AI 整体 Brief 匹配度分析 - BriefMatchDetail 评分详情 (覆盖率+亮点+问题点) - min_selling_points 代理商可配置最少卖点数 + Alembic 迁移 - AI 语境复核过滤误报 - Brief AI 解析 + 规则 AI 解析 - AI 未配置/异常时通知品牌方 - 种子数据更新 (新格式审核结果+brief_match_detail) 前端: - 三端审核页面展示四维度评分卡片 - 卖点编辑改为三级优先级选择器 - BriefMatchDetail 展示 (覆盖率进度条+亮点+问题) - min_selling_points 配置 UI - AI 配置页未配置时静默处理 - 文件预览/下载/签名 URL 优化 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
61 lines
1.6 KiB
TypeScript
61 lines
1.6 KiB
TypeScript
'use client'
|
|
|
|
import { useEffect, useState } from 'react'
|
|
import { useRouter, useParams } from 'next/navigation'
|
|
import { api } from '@/lib/api'
|
|
import { USE_MOCK } from '@/contexts/AuthContext'
|
|
import { Loader2 } from 'lucide-react'
|
|
|
|
/**
|
|
* Redirect page: detects task type (script/video) and redirects
|
|
* to the appropriate review detail page.
|
|
*/
|
|
export default function ReviewRedirectPage() {
|
|
const router = useRouter()
|
|
const params = useParams()
|
|
const taskId = params.id as string
|
|
const [error, setError] = useState('')
|
|
|
|
useEffect(() => {
|
|
if (USE_MOCK) {
|
|
router.replace(`/agency/review/script/${taskId}`)
|
|
return
|
|
}
|
|
|
|
async function redirect() {
|
|
try {
|
|
const task = await api.getTask(taskId)
|
|
const isVideo = task.stage.includes('video')
|
|
const path = isVideo
|
|
? `/agency/review/video/${taskId}`
|
|
: `/agency/review/script/${taskId}`
|
|
router.replace(path)
|
|
} catch {
|
|
setError('加载任务失败,请返回重试')
|
|
}
|
|
}
|
|
redirect()
|
|
}, [taskId, router])
|
|
|
|
if (error) {
|
|
return (
|
|
<div className="flex flex-col items-center justify-center min-h-[50vh] gap-4">
|
|
<p className="text-text-secondary">{error}</p>
|
|
<button
|
|
type="button"
|
|
onClick={() => router.back()}
|
|
className="text-accent-indigo hover:underline"
|
|
>
|
|
返回
|
|
</button>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<div className="flex items-center justify-center min-h-[50vh]">
|
|
<Loader2 size={32} className="animate-spin text-accent-indigo" />
|
|
</div>
|
|
)
|
|
}
|