import axios from 'axios' 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 { API_BASE_URL, SITE_TITLE } from '@/config' 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 } export default ({ user }: Props) => { if (!(['admin', 'member'].some (r => user?.role === r))) return 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 res = await axios.post (`${ API_BASE_URL }/wiki`, formData, { headers: { 'Content-Type': 'multipart/form-data', 'X-Transfer-Code': localStorage.getItem ('user_code') || '' } }) const data = res.data as WikiPage toast ({ title: '投稿成功!' }) navigate (`/wiki/${ data.title }`) } catch { toast ({ title: '投稿失敗', description: '入力を確認してください。' }) } } return ( {`新規 Wiki ページ | ${ SITE_TITLE }`}

新規 Wiki ページ

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