import { useQuery } from '@tanstack/react-query'; import { usePlHooksApiClient } from 'pl-hooks/contexts/api-client'; import { queryClient, usePlHooksQueryClient } from 'pl-hooks/contexts/query-client'; import { type NormalizedNotification, normalizeNotification } from 'pl-hooks/normalizers/normalizeNotifications'; import { useAccount } from '../accounts/useAccount'; import { useStatus } from '../statuses/useStatus'; import type { Account } from 'pl-hooks/normalizers/normalizeAccount'; import type { Status } from 'pl-hooks/normalizers/normalizeStatus'; const getNotificationStatusId = (n: NormalizedNotification) => { if (['mention', 'status', 'reblog', 'favourite', 'poll', 'update', 'emoji_reaction', 'event_reminder', 'participation_accepted', 'participation_request'].includes(n.type)) // @ts-ignore return n.status_id; return null; }; const importNotification = (notification: NormalizedNotification) => { queryClient.setQueryData( ['notifications', 'entities', notification.id], existingNotification => existingNotification?.duplicate ? existingNotification : notification, ); }; const useNotification = (notificationId: string) => { const queryClient = usePlHooksQueryClient(); const { client } = usePlHooksApiClient(); const notificationQuery = useQuery({ queryKey: ['notifications', 'entities', notificationId], queryFn: () => client.notifications.getNotification(notificationId) .then(normalizeNotification), }, queryClient); const notification = notificationQuery.data; const accountsQuery = queryClient.getQueriesData({ queryKey: ['accounts', 'entities', notification?.account_ids], }); const moveTargetAccountQuery = useAccount(notification?.type === 'move' ? notification.target_id : undefined); const statusQuery = useStatus(notification ? getNotificationStatusId(notification) : false); let data: (NormalizedNotification & { account: Account; accounts: Array; target: Account | null; status: Status | null; }) | null = null; if (notification) { data = { ...notification, account: accountsQuery[0][1]!, accounts: accountsQuery.map(([_, account]) => account!).filter(Boolean), target: moveTargetAccountQuery.data, status: statusQuery.data, }; } return { ...notificationQuery, data }; }; export { useNotification, importNotification };