58 lines
1.5 KiB
TypeScript
58 lines
1.5 KiB
TypeScript
import { Entity, MegalodonInterface } from 'megalodon'
|
|
import Status from '../status/Status'
|
|
import Reaction from './Reaction'
|
|
import Follow from './Follow'
|
|
import { Account } from '@/db'
|
|
|
|
type Props = {
|
|
notification: Entity.Notification
|
|
account: Account
|
|
client: MegalodonInterface
|
|
onRefresh: (status: Entity.Status) => void
|
|
openMedia: (media: Array<Entity.Attachment>, index: number) => void
|
|
filters: Array<Entity.Filter>
|
|
}
|
|
|
|
export default function Notification(props: Props) {
|
|
switch (props.notification.type) {
|
|
case 'mention': {
|
|
if (props.notification.status) {
|
|
return (
|
|
<Status
|
|
account={props.account}
|
|
client={props.client}
|
|
status={props.notification.status}
|
|
onRefresh={props.onRefresh}
|
|
openMedia={props.openMedia}
|
|
filters={props.filters}
|
|
/>
|
|
)
|
|
} else {
|
|
return null
|
|
}
|
|
}
|
|
case 'favourite':
|
|
case 'reblog':
|
|
case 'poll_expired':
|
|
case 'poll_vote':
|
|
case 'quote':
|
|
case 'status':
|
|
case 'update':
|
|
case 'emoji_reaction':
|
|
case 'reaction': {
|
|
if (props.notification.status) {
|
|
return <Reaction client={props.client} notification={props.notification} onRefresh={props.onRefresh} openMedia={props.openMedia} />
|
|
} else {
|
|
return null
|
|
}
|
|
}
|
|
case 'follow':
|
|
case 'follow_request':
|
|
return <Follow notification={props.notification} />
|
|
|
|
default: {
|
|
return null
|
|
}
|
|
}
|
|
}
|