import Button, { IconButton, LinkButton } from '@components/shared/Button' import { Dialog, Transition } from '@headlessui/react' import { CalendarIcon, FaceSmileIcon, InboxIcon, TrashIcon, XMarkIcon, } from '@heroicons/react/20/solid' import { bs58 } from '@project-serum/anchor/dist/cjs/utils/bytes' import { WalletContextState, useWallet } from '@solana/wallet-adapter-react' import { Payload, SIWS } from '@web3auth/sign-in-with-solana' import { useHeaders } from 'hooks/notifications/useHeaders' import { useIsAuthorized } from 'hooks/notifications/useIsAuthorized' import { useNotifications } from 'hooks/notifications/useNotifications' import { Fragment, useCallback, useEffect, useMemo, useState } from 'react' import { NOTIFICATION_API } from 'utils/constants' import NotificationCookieStore from '@store/notificationCookieStore' import dayjs from 'dayjs' import { useTranslation } from 'next-i18next' import { notify } from 'utils/notifications' export const createSolanaMessage = ( wallet: WalletContextState, setCookie: (wallet: string, token: string) => void, ) => { const payload = new Payload() payload.domain = window.location.host payload.address = wallet.publicKey!.toString() payload.uri = window.location.origin payload.statement = 'Login to Mango Notifications Admin App' payload.version = '1' payload.chainId = 1 const message = new SIWS({ payload }) const messageText = message.prepareMessage() const messageEncoded = new TextEncoder().encode(messageText) wallet.signMessage!(messageEncoded) .then(async (resp) => { const tokenResp = await fetch(`${NOTIFICATION_API}auth`, { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({ ...payload, signatureString: bs58.encode(resp), }), }) const body = await tokenResp.json() const token = body.token const error = body.error if (error) { notify({ type: 'error', title: 'Error', description: error, }) return } setCookie(payload.address, token) }) .catch((e) => { notify({ type: 'error', title: 'Error', description: e.message ? e.message : `${e}`, }) }) } const NotificationsDrawer = ({ isOpen, onClose, }: { isOpen: boolean onClose: () => void }) => { const { t } = useTranslation('notifications') const { data, refetch } = useNotifications() const wallet = useWallet() const isAuth = useIsAuthorized() const headers = useHeaders() const setCookie = NotificationCookieStore((s) => s.setCookie) const [isRemoving, setIsRemoving] = useState(false) const unseenNotifications = useMemo(() => { if (!data || !data.length) return [] return data.filter((x) => !x.seen) }, [data]) const markAsSeen = useCallback( async (ids: number[]) => { try { const resp = await fetch(`${NOTIFICATION_API}notifications/seen`, { method: 'POST', headers: headers.headers, body: JSON.stringify({ ids: ids, seen: true, }), }) const body = await resp.json() const error = body.error if (error) { notify({ type: 'error', title: 'Error', description: error, }) return } refetch() } catch (e) { notify({ type: 'error', title: 'Error', description: JSON.stringify(e), }) } }, [NOTIFICATION_API, headers], ) const remove = useCallback( async (ids: number[]) => { setIsRemoving(true) try { const resp = await fetch( `${NOTIFICATION_API}notifications/removeForUser`, { method: 'POST', headers: headers.headers, body: JSON.stringify({ ids: ids, }), }, ) const body = await resp.json() const error = body.error if (error) { notify({ type: 'error', title: 'Error', description: error, }) return } refetch() } catch (e) { notify({ type: 'error', title: 'Error', description: JSON.stringify(e), }) } setIsRemoving(false) }, [NOTIFICATION_API, headers], ) // Mark all notifications as seen when the inbox is opened useEffect(() => { if (isOpen && unseenNotifications?.length) { markAsSeen([...unseenNotifications.map((x) => x.id)]) } }, [isOpen, unseenNotifications]) return (

{t('notifications')}

{data?.length ? ( remove(data.map((n) => n.id))} > {t('clear-all')} ) : null}
{isAuth ? ( <> {data?.length ? ( <>
{data?.map((notification) => (

{notification.title}

remove([notification.id])} className="mt-1 text-th-fgd-3" hideBg >

{dayjs(notification.createdAt).format( 'DD MMM YYYY, h:mma', )}

{notification.content}

))}
) : (

{t('empty-state-title')}

{t('empty-state-desc')}

)} ) : (

{t('unauth-title')}

{t('unauth-desc')}

)}
) } export default NotificationsDrawer