import { ChatBubbleBottomCenterIcon } from "@heroicons/react/24/outline";
import { PageSize, type PostsRequest, usePostsQuery } from "@hey/indexer";
import { useCallback } from "react";
import SinglePost from "@/components/Post/SinglePost";
import PostFeed from "@/components/Shared/Post/PostFeed";
interface PostsProps {
query: string;
}
const Posts = ({ query }: PostsProps) => {
const request: PostsRequest = {
filter: { searchQuery: query },
pageSize: PageSize.Fifty
};
const { data, error, fetchMore, loading } = usePostsQuery({
variables: { request }
});
const posts = data?.posts?.items;
const pageInfo = data?.posts?.pageInfo;
const hasMore = pageInfo?.next;
const handleEndReached = useCallback(async () => {
if (hasMore) {
await fetchMore({
variables: { request: { ...request, cursor: pageInfo?.next } }
});
}
}, [fetchMore, hasMore, pageInfo?.next, request]);
return (
}
emptyMessage={
No posts for “{query}”
}
error={error}
errorTitle="Failed to load posts"
handleEndReached={handleEndReached}
hasMore={hasMore}
items={posts ?? []}
loading={loading}
renderItem={(post) => }
/>
);
};
export default Posts;