/* eslint-disable react-hooks/exhaustive-deps */ import { BoxButtonOnFooter, ButtonCustom, LoaderCustom, StackCustom, TextCustom, ViewWrapper, } from "@/components"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; import GridTwoView from "@/components/_ShareComponent/GridTwoView"; import { apiAdminUserAccessGetById, apiAdminUserAccessUpdateStatus, } from "@/service/api-admin/api-admin-user-access"; import { router, useFocusEffect, useLocalSearchParams } from "expo-router"; import { useCallback, useState } from "react"; import Toast from "react-native-toast-message"; export default function AdminUserAccessDetail() { const { id } = useLocalSearchParams(); const [data, setData] = useState(null); const [loadData, setLoadData] = useState(false); const [isLoading, setLoading] = useState(false); useFocusEffect( useCallback(() => { onLoadData(); }, [id]) ); const onLoadData = async () => { try { setLoadData(true); const response = await apiAdminUserAccessGetById({ id: id as string }); setData(response.data); } catch (error) { console.log("[ERROR LOAD DATA]", error); } finally { setLoadData(false); } }; const handlerSubmit = async () => { try { setLoading(true); const response = await apiAdminUserAccessUpdateStatus({ id: id as string, active: !data?.active, }); if (!response.success) { Toast.show({ type: "error", text1: "Update aktifasi gagal", }); return; } Toast.show({ type: "success", text1: "Update aktifasi berhasil ", }); router.back(); } catch (error) { console.log("[ERROR UPDATE STATUS]", error); } finally { setLoading(false); } }; return ( <> } footerComponent={ data && ( {data?.active ? "Hapus Akses" : "Berikan Akses"} ) } > {loadData ? ( ) : ( {listData(data && data)?.map((item: any, index: number) => ( {item?.label}} rightIcon={{item?.value}} /> ))} )} ); } const listData = (data: any) => [ { label: "Username", value: (data && data?.username) || "-", }, { label: "Aktivasi", value: data && data?.active ? "Aktif" : "Tidak Aktif", }, { label: "Nomor", value: (data && `+${data?.nomor}`) || "-", }, ];