/* eslint-disable react-hooks/exhaustive-deps */ import { ActionIcon, BadgeCustom, CenterCustom, SelectCustom, StackCustom, TextCustom, ViewWrapper, } from "@/components"; import { IconView } from "@/components/_Icon/IconComponent"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; import { GridViewCustomSpan } from "@/components/_ShareComponent/GridViewCustomSpan"; import { ICON_SIZE_BUTTON } from "@/constants/constans-value"; import { apiAdminDonationListOfDonatur } from "@/service/api-admin/api-admin-donation"; import { apiMasterTransaction } from "@/service/api-client/api-master"; import { colorBadgeTransaction } from "@/utils/colorBadge"; import { router, useFocusEffect, useLocalSearchParams } from "expo-router"; import _ from "lodash"; import React, { useEffect } from "react"; import { View } from "react-native"; import { Divider } from "react-native-paper"; export default function AdminDonasiListOfDonatur() { const { id } = useLocalSearchParams(); console.log("[ID >>]", id); const [listData, setListData] = React.useState(null); const [master, setMaster] = React.useState([]); const [selectStatus, setSelectStatus] = React.useState< "berhasil" | "gagal" | "proses" | "menunggu" | "" >(""); useFocusEffect( React.useCallback(() => { onLoadData(); }, [id, selectStatus]) ); const onLoadData = async () => { try { const response = await apiAdminDonationListOfDonatur({ id: id as string, status: "" as any, }); console.log( "[LIST OF DONATUR]", JSON.stringify(response, null, 2) ); if (response.success) { setListData(response.data); } } catch (error) { console.log("[ERROR]", error); setListData([]); } }; useEffect(() => { onLoadMaster(); }, []); const onLoadMaster = async () => { try { const response = await apiMasterTransaction(); if (response.success) { setMaster(response.data); } } catch (error) { console.log("[ERROR]", error); setMaster([]); } }; const searchComponent = ( ({ label: item.name, value: item.name })) } onChange={(value: any) => { console.log("[SELECT STATUS]", value); const statusChooses = _.lowerCase(value); setSelectStatus(statusChooses as any); }} styleContainer={{ width: "100%", marginBottom: 0 }} /> ); return ( <> } > Aksi } component2={ Donatur } component3={ Status } /> {listData?.map((item: any, index: number) => ( } onPress={() => { router.push( `/admin/donation/${id}/berhasil/transaction-detail` ); }} /> } component2={ {item?.Author?.username || "-"} } component3={ {item?.DonasiMaster_StatusInvoice?.name} } /> ))} ); }