import { useQuery, useQueryClient } from "@tanstack/react-query"; import { useTranslation } from "react-i18next"; import { Alert, 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 queryClient = useQueryClient(); 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, }; }, // Keep the bar moving while a download is writing to disk. refetchInterval: 10 * 1000, }); const onDeleteClicked = () => { Alert.alert( t("home.settings.storage.delete_all_downloaded_files_confirm"), t("home.settings.storage.delete_all_downloaded_files_confirm_desc"), [ { text: t("common.cancel"), style: "cancel", }, { text: t("common.ok"), style: "destructive", onPress: async () => { try { await deleteAllFiles(); successHapticFeedback(); } catch (_e) { errorHapticFeedback(); toast.error(t("home.settings.toasts.error_deleting_files")); } finally { // Reflect the freed space immediately instead of waiting for // the next poll. queryClient.invalidateQueries({ queryKey: ["appSize"] }); } }, }, ], ); }; const calculatePercentage = (value: number, total: number) => { 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 && ( )} ); };