import { useRouter } from 'next/router' import Timeline from '@/components/timelines/Timeline' import { useEffect, useState } from 'react' import { Account, db } from '@/db' import generator, { Entity, MegalodonInterface } from 'megalodon' import Notifications from '@/components/timelines/Notifications' import Media from '@/components/Media' import Report from '@/components/report/Report' export default function Page() { const router = useRouter() const [account, setAccount] = useState(null) const [client, setClient] = useState(null) const [attachment, setAttachment] = useState(null) const [report, setReport] = useState(null) useEffect(() => { if (router.query.id) { if (router.query.id && typeof localStorage !== 'undefined') { localStorage.setItem('lastAccount', router.query.id as string) } const f = async () => { const a = await db.accounts.get(parseInt(router.query.id as string)) if (a) { setAccount(a) const c = generator(a.sns, a.url, a.access_token, 'Whalebird') setClient(c) } } f() } }, [router.query.id]) useEffect(() => { if (router.query.timeline && router.query.id && typeof localStorage !== 'undefined') { localStorage.setItem(`${router.query.id}_lastTimeline`, router.query.timeline as string) } }, [router.query.id, router.query.timeline]) useEffect(() => { if (router.query.modal && router.query.report_target_id) { const f = async () => { const res = await client.getStatus(router.query.report_target_id as string) setReport(res.data) } f() } }, [router.query.modal, router.query.report_target_id]) const closeReport = () => { setReport(null) router.push({ query: Object.assign({}, router.query, { report_target_id: null }) }) } if (!account || !client) return null return ( <> {(router.query.timeline as string) === 'notifications' ? ( ) : ( )} setAttachment(null)} attachment={attachment} /> {report && } ) }