"use client"; import React, { useEffect, useState } from "react"; import { useParams, useRouter } from "next/navigation"; import dynamic from "next/dynamic"; import { Input } from "@/components/ui/input"; import { Button } from "@/components/ui/button"; import { useToast } from "@/components/ui/use-toast"; const MarkdownEditor = dynamic(() => import("@uiw/react-md-editor"), { ssr: false }); const EditPage = () => { const params = useParams<{ slug: string }>() as { slug: string }; const router = useRouter(); const { slug } = params; const { toast } = useToast(); const [title, setTitle] = useState(""); const [content, setContent] = useState(""); const [vulnerabilities, setVulnerabilities] = useState(""); const [loading, setLoading] = useState(false); useEffect(() => { if (slug) { fetch(`/api/mdx/pages/${slug}`) .then((response) => response.json()) .then((data) => { setTitle(data.title); setContent(data.content); setVulnerabilities(data.vulnerabilities || ""); }) .catch((error) => console.error("Failed to load page", error)); } }, [slug]); const savePage = async () => { setLoading(true); const response = await fetch(`/api/mdx/pages/${slug}`, { method: "PUT", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ title, content, vulnerabilities }) }); if (response.ok) { setLoading(false); toast({ description: "Page successfully updated" }); router.push(`/admin/multi-logs/`); } else { setLoading(false); toast({ description: "Page Updated" }); } }; const handleEditorChange = (value?: string) => { if (value !== undefined) { setContent(value); } }; return (

Edit Page: {slug}

setTitle(e.target.value)} placeholder="Page Title" />

Vulnerabilities

setVulnerabilities(value || "")} height={200} />
); }; export default EditPage;