shellphone.app/app/messages/components/conversations-list.tsx

37 lines
966 B
TypeScript
Raw Normal View History

2021-08-01 03:05:40 +00:00
import { Link, useQuery, Routes } from "blitz";
2021-07-31 14:33:18 +00:00
import getConversationsQuery from "../queries/get-conversations";
2021-07-31 14:33:18 +00:00
export default function ConversationsList() {
const conversations = useQuery(getConversationsQuery, {})[0];
2021-07-31 14:33:18 +00:00
if (Object.keys(conversations).length === 0) {
return <div>empty state</div>;
2021-07-31 14:33:18 +00:00
}
return (
<ul className="divide-y">
{Object.entries(conversations).map(([recipient, messages]) => {
const lastMessage = messages[messages.length - 1]!;
2021-07-31 14:33:18 +00:00
return (
<li key={recipient} className="py-2">
2021-08-01 03:05:40 +00:00
<Link
href={Routes.ConversationPage({
recipient: encodeURI(recipient),
2021-08-01 03:05:40 +00:00
})}
>
2021-07-31 14:33:18 +00:00
<a className="flex flex-col">
<div className="flex flex-row justify-between">
<strong>{recipient}</strong>
2021-08-01 14:03:49 +00:00
<div>{new Date(lastMessage.sentAt).toLocaleString("fr-FR")}</div>
2021-07-31 14:33:18 +00:00
</div>
<div>{lastMessage.content}</div>
</a>
</Link>
</li>
);
2021-07-31 14:33:18 +00:00
})}
</ul>
);
2021-07-31 14:33:18 +00:00
}