import React from "react"; import { Text, View } from "react-native"; import { Bar as ProgressBar } from "react-native-progress"; import colors from "@movie-web/tailwind-config/colors"; export interface DownloadItemProps { filename: string; progress: number; speed: number; fileSize: number; downloaded: number; } const formatBytes = (bytes: number, decimals = 2) => { if (bytes === 0) return "0 Bytes"; const k = 1024; const dm = decimals < 0 ? 0 : decimals; const sizes = ["Bytes", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"]; const i = Math.floor(Math.log(bytes) / Math.log(k)); return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + " " + sizes[i]; }; export const DownloadItem: React.FC = ({ filename, progress, speed, fileSize, downloaded, }) => { const percentage = (progress * 100).toFixed(0); const formattedFileSize = formatBytes(fileSize); const formattedDownloaded = formatBytes(downloaded); return ( {filename} {percentage}% - {formattedDownloaded} of {formattedFileSize} {speed} MB/s ); };