import { ShoppingBagIcon } from "@heroicons/react/24/outline";
import {
type PostActionFilter,
useWhoExecutedActionOnPostQuery,
type WhoExecutedActionOnPostRequest
} from "@hey/indexer";
import { motion } from "motion/react";
import { useCallback } from "react";
import { Virtualizer } from "virtua";
import SingleAccount from "@/components/Shared/Account/SingleAccount";
import AccountListShimmer from "@/components/Shared/Shimmer/AccountListShimmer";
import { EmptyState, ErrorMessage } from "@/components/Shared/UI";
import cn from "@/helpers/cn";
import useLoadMoreOnIntersect from "@/hooks/useLoadMoreOnIntersect";
import { useAccountStore } from "@/store/persisted/useAccountStore";
import { accountsList } from "@/variants";
interface PostExecutorsProps {
postId: string;
filter: PostActionFilter;
}
const PostExecutors = ({ postId, filter }: PostExecutorsProps) => {
const { currentAccount } = useAccountStore();
const request: WhoExecutedActionOnPostRequest = {
filter: { anyOf: [filter] },
post: postId
};
const { data, error, fetchMore, loading } = useWhoExecutedActionOnPostQuery({
skip: !postId,
variables: { request }
});
const accounts = data?.whoExecutedActionOnPost?.items;
const pageInfo = data?.whoExecutedActionOnPost?.pageInfo;
const hasMore = pageInfo?.next;
const handleEndReached = useCallback(async () => {
if (hasMore) {
await fetchMore({
variables: { request: { ...request, cursor: pageInfo?.next } }
});
}
}, [fetchMore, hasMore, pageInfo?.next, request]);
const loadMoreRef = useLoadMoreOnIntersect(handleEndReached);
if (loading) {
return