"use client"; import { FormEvent, useState } from "react"; import { useRouter } from "next/navigation"; import { normalizeImageUrl } from "@/lib/normalize"; import { MarkdownPreview } from "@/components/MarkdownPreview"; const defaultIntro = `## solo-feed 记录模板 - 今日目标: - 产品/交付: - 客户/收入: - 增长/运营: - 学习/复盘: `; export function CreatePostForm({ availableTags = [] }: { availableTags?: string[] }) { const [title, setTitle] = useState(""); const [cover, setCover] = useState(""); const [tags, setTags] = useState(""); const [markdown, setMarkdown] = useState(defaultIntro); const [loading, setLoading] = useState(false); const [preview, setPreview] = useState(false); const router = useRouter(); const addTag = (tag: string) => { const current = new Set( tags .split(",") .map((t) => t.trim()) .filter(Boolean) ); current.add(tag); setTags(Array.from(current).join(", ")); }; async function handleSubmit(e: FormEvent) { e.preventDefault(); setLoading(true); try { const normalizedCover = normalizeImageUrl(cover); const res = await fetch("/api/posts", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ title, markdown, cover: normalizedCover, tags: Array.from( new Set( tags .split(",") .map((t) => t.trim()) .filter(Boolean) ) ) }) }); if (!res.ok) { const data = await res.json().catch(() => ({})); alert(data.error ? JSON.stringify(data.error) : "发布失败"); } else { const data = await res.json(); router.push(`/p/${data.slug}`); router.refresh(); } } finally { setLoading(false); } } return (
); }