Files
lume/src/pages/chat/index.page.tsx
Ren Amamiya cdbf70591e Revert "make some pages only for client"
This reverts commit b7dc808bee.
2023-04-24 14:57:33 +07:00

71 lines
1.9 KiB
TypeScript

import { AccountContext } from '@components/accountProvider';
import FormChat from '@components/form/chat';
import NewsfeedLayout from '@components/layouts/newsfeed';
import { RelayContext } from '@components/relaysProvider';
import { chatMessagesAtom } from '@stores/chat';
import { MESSAGE_RELAYS } from '@stores/constants';
import { usePageContext } from '@utils/hooks/usePageContext';
import { useSetAtom } from 'jotai';
import { useResetAtom } from 'jotai/utils';
import { Suspense, lazy, useContext } from 'react';
import useSWRSubscription from 'swr/subscription';
const MessageList = lazy(() => import('@components/chats/messageList'));
export function Page() {
const pageContext = usePageContext();
const searchParams: any = pageContext.urlParsed.search;
const pubkey = searchParams.pubkey;
const pool: any = useContext(RelayContext);
const activeAccount: any = useContext(AccountContext);
const setChatMessages = useSetAtom(chatMessagesAtom);
const resetChatMessages = useResetAtom(chatMessagesAtom);
useSWRSubscription(pubkey, () => {
// clear old messages
resetChatMessages();
// subscribe for next messages
const unsubscribe = pool.subscribe(
[
{
kinds: [4],
authors: [pubkey],
'#p': [activeAccount.pubkey],
},
{
kinds: [4],
authors: [activeAccount.pubkey],
'#p': [pubkey],
},
],
MESSAGE_RELAYS,
(event: any) => {
setChatMessages((prev) => [...prev, event]);
}
);
return () => {
unsubscribe();
};
});
return (
<NewsfeedLayout>
<div className="flex h-full w-full flex-col justify-between">
<Suspense fallback={<p>Loading...</p>}>
<MessageList />
</Suspense>
<div className="shrink-0 p-3">
<FormChat receiverPubkey={pubkey} />
</div>
</div>
</NewsfeedLayout>
);
}