/* eslint-disable react-hooks/exhaustive-deps */
import {
AvatarUsernameAndOtherComponent,
BoxWithHeaderSection,
CenterCustom,
OS_Wrapper,
Spacing,
StackCustom,
TextCustom,
} from "@/components";
import { PAGINATION_DEFAULT_TAKE, PADDING_INLINE } from "@/constants/constans-value";
import { createPaginationComponents } from "@/helpers/paginationHelpers";
import { usePagination } from "@/hooks/use-pagination";
import { apiInvestmentGetInvestorById } from "@/service/api-client/api-investment";
import { formatCurrencyDisplay } from "@/utils/formatCurrencyDisplay";
import { RefreshControl } from "react-native";
interface InvestmentInvestorProps {
investmentId: string;
}
export default function Investment_ScreenInvestor({
investmentId,
}: InvestmentInvestorProps) {
const pagination = usePagination({
fetchFunction: async (page) => {
return await apiInvestmentGetInvestorById({
id: investmentId,
page: String(page),
});
},
pageSize: PAGINATION_DEFAULT_TAKE,
dependencies: [investmentId],
onError: (error) => {
console.error("Error fetching investors:", error);
},
});
const renderItem = ({ item }: { item: any }) => (
Rp. {formatCurrencyDisplay(item?.nominal)}
);
const { ListEmptyComponent, ListFooterComponent } =
createPaginationComponents({
loading: pagination.loading,
refreshing: pagination.refreshing,
listData: pagination.listData,
isInitialLoad: pagination.isInitialLoad,
emptyMessage: "Tidak ada investor",
skeletonCount: PAGINATION_DEFAULT_TAKE,
skeletonHeight: 120,
});
return (
}
/>
);
}