104 lines
3.9 KiB
TypeScript
104 lines
3.9 KiB
TypeScript
"use client"
|
||
|
||
import { useState } from "react"
|
||
import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow } from "@/components/ui/table"
|
||
import { Button } from "@/components/ui/button"
|
||
import { Input } from "@/components/ui/input"
|
||
import { Search, Filter, RefreshCw } from "lucide-react"
|
||
import type { ContentItem } from "@/types/content"
|
||
|
||
interface ContentViewerProps {
|
||
tagId: string
|
||
}
|
||
|
||
export function ContentViewer({ tagId }: ContentViewerProps) {
|
||
const [contents, setContents] = useState<ContentItem[]>([
|
||
{
|
||
id: "399401",
|
||
title: "一<><E4B880><EFBFBD>理想安全驾这件事情,刻在DNA里...",
|
||
type: "text",
|
||
content: "一在理想安全驾这件事情,刻在DNA里...",
|
||
images: [
|
||
"https://hebbkx1anhila5yf.public.blob.vercel-storage.com/img_v3_02jo_5c61b35b-a919-4520-b653-a5910dea594g.jpg-83VfgjQ3qC7mwDhby6rsZeRwVM6maz.jpeg",
|
||
"https://hebbkx1anhila5yf.public.blob.vercel-storage.com/img_v3_02jo_5c61b35b-a919-4520-b653-a5910dea594g.jpg-83VfgjQ3qC7mwDhby6rsZeRwVM6maz.jpeg",
|
||
"https://hebbkx1anhila5yf.public.blob.vercel-storage.com/img_v3_02jo_5c61b35b-a919-4520-b653-a5910dea594g.jpg-83VfgjQ3qC7mwDhby6rsZeRwVM6maz.jpeg",
|
||
],
|
||
createTime: "2025-02-16 08:50:36",
|
||
publishTime: "2025-02-15 23:37:49",
|
||
status: "published",
|
||
},
|
||
])
|
||
|
||
return (
|
||
<div className="space-y-4">
|
||
<div className="flex items-center space-x-2">
|
||
<div className="relative flex-1">
|
||
<Search className="absolute left-3 top-2.5 h-4 w-4 text-gray-400" />
|
||
<Input placeholder="搜索内容..." className="pl-9" />
|
||
</div>
|
||
<Button variant="outline" size="icon">
|
||
<Filter className="h-4 w-4" />
|
||
</Button>
|
||
<Button variant="outline" size="icon">
|
||
<RefreshCw className="h-4 w-4" />
|
||
</Button>
|
||
</div>
|
||
|
||
<Table>
|
||
<TableHeader>
|
||
<TableRow>
|
||
<TableHead>ID</TableHead>
|
||
<TableHead>内容类型</TableHead>
|
||
<TableHead>内容</TableHead>
|
||
<TableHead>图片</TableHead>
|
||
<TableHead>视频</TableHead>
|
||
<TableHead>推送时间</TableHead>
|
||
<TableHead>内容发布时间</TableHead>
|
||
<TableHead>状态</TableHead>
|
||
</TableRow>
|
||
</TableHeader>
|
||
<TableBody>
|
||
{contents.map((content) => (
|
||
<TableRow key={content.id}>
|
||
<TableCell>{content.id}</TableCell>
|
||
<TableCell>{content.type === "text" ? "图文" : content.type}</TableCell>
|
||
<TableCell className="max-w-[200px] truncate">{content.content}</TableCell>
|
||
<TableCell>
|
||
{content.images && (
|
||
<div className="flex space-x-1">
|
||
{content.images.map((img, index) => (
|
||
<img
|
||
key={index}
|
||
src={img || "/placeholder.svg"}
|
||
alt={`图片 ${index + 1}`}
|
||
className="w-10 h-10 object-cover rounded"
|
||
/>
|
||
))}
|
||
</div>
|
||
)}
|
||
</TableCell>
|
||
<TableCell>{content.video ? "有" : "-"}</TableCell>
|
||
<TableCell>{content.createTime}</TableCell>
|
||
<TableCell>{content.publishTime}</TableCell>
|
||
<TableCell>
|
||
<span
|
||
className={`px-2 py-1 rounded-full text-xs ${
|
||
content.status === "published"
|
||
? "bg-green-100 text-green-800"
|
||
: content.status === "failed"
|
||
? "bg-red-100 text-red-800"
|
||
: "bg-yellow-100 text-yellow-800"
|
||
}`}
|
||
>
|
||
{content.status === "published" ? "已发布" : content.status === "failed" ? "失败" : "待发布"}
|
||
</span>
|
||
</TableCell>
|
||
</TableRow>
|
||
))}
|
||
</TableBody>
|
||
</Table>
|
||
</div>
|
||
)
|
||
}
|
||
|