2023-11-16 00:15:44 +09:00
|
|
|
import { useRouter } from 'next/router'
|
2023-11-17 23:01:54 +09:00
|
|
|
import { HTMLAttributes, useEffect, useState } from 'react'
|
2023-11-16 00:15:44 +09:00
|
|
|
import { FaChevronLeft, FaX } from 'react-icons/fa6'
|
|
|
|
import Thread from './Thread'
|
2023-12-02 19:26:45 +09:00
|
|
|
import { Entity, MegalodonInterface } from 'megalodon'
|
2023-11-29 00:37:21 +09:00
|
|
|
import Reply from './Reply'
|
2023-12-02 11:50:42 +09:00
|
|
|
import Profile from './Profile'
|
2024-01-02 13:24:18 +09:00
|
|
|
import Tag from './Tag'
|
2023-12-12 00:00:44 +09:00
|
|
|
import { Account } from '@/db'
|
2024-01-31 00:51:36 +09:00
|
|
|
import { useIntl } from 'react-intl'
|
2023-11-16 00:15:44 +09:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
client: MegalodonInterface
|
2023-12-12 00:00:44 +09:00
|
|
|
account: Account
|
2024-03-09 15:00:27 +09:00
|
|
|
openMedia: (media: Array<Entity.Attachment>, index: number) => void
|
2023-11-17 23:01:54 +09:00
|
|
|
} & HTMLAttributes<HTMLElement>
|
2023-11-16 00:15:44 +09:00
|
|
|
|
|
|
|
export default function Detail(props: Props) {
|
2024-01-02 13:24:18 +09:00
|
|
|
const [target, setTarget] = useState<'status' | 'reply' | 'profile' | 'tag' | null>(null)
|
2023-11-16 00:15:44 +09:00
|
|
|
const router = useRouter()
|
2024-01-31 00:51:36 +09:00
|
|
|
const { formatMessage } = useIntl()
|
2023-11-16 00:15:44 +09:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (router.query.status_id) {
|
|
|
|
setTarget('status')
|
2023-11-29 00:37:21 +09:00
|
|
|
} else if (router.query.reply_target_id) {
|
|
|
|
setTarget('reply')
|
2023-12-02 11:50:42 +09:00
|
|
|
} else if (router.query.user_id) {
|
|
|
|
setTarget('profile')
|
2024-01-02 13:24:18 +09:00
|
|
|
} else if (router.query.tag) {
|
|
|
|
setTarget('tag')
|
2023-11-16 00:15:44 +09:00
|
|
|
} else {
|
|
|
|
setTarget(null)
|
|
|
|
}
|
|
|
|
}, [router.query])
|
|
|
|
|
|
|
|
const back = () => {
|
|
|
|
router.back()
|
|
|
|
}
|
|
|
|
|
|
|
|
const close = () => {
|
|
|
|
router.push({ query: { id: router.query.id, timeline: router.query.timeline } })
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
{target && (
|
2024-03-15 01:12:19 +09:00
|
|
|
<div className={`${props.className}`} style={props.style}>
|
2024-03-09 18:26:43 +09:00
|
|
|
<div className="theme-bg-secondary text-gray-200 flex justify-between p-2 items-center" style={{ height: '44px' }}>
|
2024-01-02 13:24:18 +09:00
|
|
|
<div className="flex gap-4 items-center">
|
2024-01-31 00:51:36 +09:00
|
|
|
<button className="text-lg" title={formatMessage({ id: 'detail.back' })}>
|
|
|
|
<FaChevronLeft onClick={back} />
|
|
|
|
</button>
|
2024-01-02 13:24:18 +09:00
|
|
|
{target === 'tag' && `#${router.query.tag}`}
|
|
|
|
</div>
|
2024-01-31 00:51:36 +09:00
|
|
|
<div className="flex items-center">
|
|
|
|
<button className="text-lg" title={formatMessage({ id: 'detail.close' })}>
|
|
|
|
<FaX onClick={close} />
|
|
|
|
</button>
|
2024-01-02 13:24:18 +09:00
|
|
|
</div>
|
2023-11-16 00:15:44 +09:00
|
|
|
</div>
|
2023-12-12 00:00:44 +09:00
|
|
|
{target === 'status' && (
|
|
|
|
<Thread
|
|
|
|
client={props.client}
|
|
|
|
account={props.account}
|
|
|
|
status_id={router.query.status_id as string}
|
|
|
|
openMedia={props.openMedia}
|
|
|
|
/>
|
|
|
|
)}
|
2023-12-02 19:26:45 +09:00
|
|
|
{target === 'reply' && (
|
2023-12-12 00:00:44 +09:00
|
|
|
<Reply
|
|
|
|
client={props.client}
|
|
|
|
account={props.account}
|
|
|
|
status_id={router.query.reply_target_id as string}
|
|
|
|
openMedia={props.openMedia}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
{target === 'profile' && (
|
|
|
|
<Profile client={props.client} account={props.account} user_id={router.query.user_id as string} openMedia={props.openMedia} />
|
2023-12-02 19:26:45 +09:00
|
|
|
)}
|
2024-01-02 13:24:18 +09:00
|
|
|
{target === 'tag' && (
|
|
|
|
<Tag client={props.client} account={props.account} tag={router.query.tag as string} openMedia={props.openMedia} />
|
|
|
|
)}
|
2023-11-16 00:15:44 +09:00
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|