import type { FC } from 'react' import MarkdownIt from 'markdown-it' import { useState } from 'react' import { Helmet } from 'react-helmet-async' import MdEditor from 'react-markdown-editor-lite' import { useLocation, useNavigate } from 'react-router-dom' import MainArea from '@/components/layout/MainArea' import { toast } from '@/components/ui/use-toast' import { SITE_TITLE } from '@/config' import { apiPost } from '@/lib/api' import Forbidden from '@/pages/Forbidden' import 'react-markdown-editor-lite/lib/index.css' import type { User, WikiPage } from '@/types' const mdParser = new MarkdownIt type Props = { user: User | null } const WikiNewPage: FC = ({ user }) => { const editable = ['admin', 'member'].some (r => user?.role === r) const location = useLocation () const navigate = useNavigate () const query = new URLSearchParams (location.search) const titleQuery = query.get ('title') ?? '' const [title, setTitle] = useState (titleQuery) const [body, setBody] = useState ('') const handleSubmit = async () => { const formData = new FormData formData.append ('title', title) formData.append ('body', body) try { const data = await apiPost ('/wiki', formData, { headers: { 'Content-Type': 'multipart/form-data' } }) toast ({ title: '投稿成功!' }) navigate (`/wiki/${ data.title }`) } catch { toast ({ title: '投稿失敗', description: '入力を確認してください。' }) } } if (!(editable)) return return ( {`新規 Wiki ページ | ${ SITE_TITLE }`}

新規 Wiki ページ

{/* タイトル */} {/* TODO: タグ補完 */}
setTitle (e.target.value)} className="w-full border p-2 rounded"/>
{/* 本文 */}
mdParser.render (text)} onChange={({ text }) => setBody (text)}/>
{/* 送信 */}
) } export default WikiNewPage