import { useQuery } from "@tanstack/react-query"; import { useTranslation } from "react-i18next"; import { Platform, View } from "react-native"; import { toast } from "sonner-native"; import { Text } from "@/components/common/Text"; import { Colors } from "@/constants/Colors"; import { useHaptic } from "@/hooks/useHaptic"; import { useDownload } from "@/providers/DownloadProvider"; import { ListGroup } from "../list/ListGroup"; import { ListItem } from "../list/ListItem"; export const StorageSettings = () => { const { deleteAllFiles, appSizeUsage } = useDownload(); const { t } = useTranslation(); const successHapticFeedback = useHaptic("success"); const errorHapticFeedback = useHaptic("error"); const { data: size } = useQuery({ queryKey: ["appSize"], queryFn: async () => { const app = await appSizeUsage(); return { appSize: app.appSize, total: app.total, remaining: app.remaining, used: (app.total - app.remaining) / app.total, }; }, }); const onDeleteClicked = async () => { try { await deleteAllFiles(); successHapticFeedback(); } catch (_e) { errorHapticFeedback(); toast.error(t("home.settings.toasts.error_deleting_files")); } }; const calculatePercentage = (value: number, total: number) => { console.log("usage", value, total); return ((value / total) * 100).toFixed(2); }; return ( {t("home.settings.storage.storage_title")} {size && ( {t("home.settings.storage.size_used", { used: Number(size.total - size.remaining).bytesToReadable(), total: size.total?.bytesToReadable(), })} )} {size && ( )} {size && ( {t("home.settings.storage.app_usage", { usedSpace: calculatePercentage(size.appSize, size.total), })} {t("home.settings.storage.device_usage", { availableSpace: calculatePercentage( size.total - size.remaining - size.appSize, size.total, ), })} )} {!Platform.isTV && ( )} ); };