2023-11-04 10:14:00 +01:00
|
|
|
import { Entity, MegalodonInterface } from 'megalodon'
|
|
|
|
import Status from '../status/Status'
|
|
|
|
import Reaction from './Reaction'
|
|
|
|
import Follow from './Follow'
|
|
|
|
|
|
|
|
type Props = {
|
|
|
|
notification: Entity.Notification
|
|
|
|
client: MegalodonInterface
|
|
|
|
onRefresh: (status: Entity.Status) => void
|
2023-12-02 11:26:45 +01:00
|
|
|
openMedia: (media: Entity.Attachment) => void
|
2023-11-04 10:14:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
export default function Notification(props: Props) {
|
|
|
|
switch (props.notification.type) {
|
|
|
|
case 'mention': {
|
|
|
|
if (props.notification.status) {
|
2023-12-02 11:26:45 +01:00
|
|
|
return <Status client={props.client} status={props.notification.status} onRefresh={props.onRefresh} openMedia={props.openMedia} />
|
2023-11-04 10:14:00 +01:00
|
|
|
} 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) {
|
2023-12-02 11:26:45 +01:00
|
|
|
return <Reaction client={props.client} notification={props.notification} onRefresh={props.onRefresh} openMedia={props.openMedia} />
|
2023-11-04 10:14:00 +01:00
|
|
|
} else {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case 'follow':
|
|
|
|
case 'follow_request':
|
|
|
|
return <Follow notification={props.notification} />
|
|
|
|
|
|
|
|
default: {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|