import { useQuery } from "@tanstack/react-query"; import { useCallback } from "react"; 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 { useNetworkAwareQueryClient } from "@/hooks/useNetworkAwareQueryClient"; import { clearCache, clearPermanentDownloads, getStorageStats, } from "@/providers/AudioStorage"; 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 = useNetworkAwareQueryClient(); 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 { data: musicCacheStats } = useQuery({ queryKey: ["musicCacheStats"], queryFn: () => getStorageStats(), }); const onDeleteClicked = async () => { try { await deleteAllFiles(); successHapticFeedback(); } catch (_e) { errorHapticFeedback(); toast.error(t("home.settings.toasts.error_deleting_files")); } }; const onClearMusicCacheClicked = useCallback(async () => { try { await clearCache(); queryClient.invalidateQueries({ queryKey: ["musicCacheStats"] }); queryClient.invalidateQueries({ queryKey: ["appSize"] }); successHapticFeedback(); toast.success(t("home.settings.storage.music_cache_cleared")); } catch (_e) { errorHapticFeedback(); toast.error(t("home.settings.toasts.error_deleting_files")); } }, [queryClient, successHapticFeedback, errorHapticFeedback, t]); const onDeleteDownloadedSongsClicked = useCallback(async () => { try { await clearPermanentDownloads(); queryClient.invalidateQueries({ queryKey: ["musicCacheStats"] }); queryClient.invalidateQueries({ queryKey: ["appSize"] }); successHapticFeedback(); toast.success(t("home.settings.storage.downloaded_songs_deleted")); } catch (_e) { errorHapticFeedback(); toast.error(t("home.settings.toasts.error_deleting_files")); } }, [queryClient, successHapticFeedback, errorHapticFeedback, t]); 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 && ( <> {t("home.settings.storage.music_cache_description")} } > )} ); };