import byteSize from 'byte-size' import dayjs from 'dayjs' import { toFinite } from 'lodash' import type { SubscriptionInfo as ISubscriptionInfo } from '~/types' const getSubscriptionsInfo = (subscriptionInfo: ISubscriptionInfo) => { const { Download = 0, Upload = 0, Total = 0, Expire = 0 } = subscriptionInfo const total = byteSize(Total, { units: 'iec' }) const used = byteSize(Download + Upload, { units: 'iec', }) const percentage = toFinite((((Download + Upload) / Total) * 100).toFixed(2)) const expireStr = () => { if (Expire === 0) { return 'Null' } return dayjs(Expire * 1000).format('YYYY-MM-DD') } return { total, used, percentage, expireStr, } } export const SubscriptionInfo = (props: { subscriptionInfo?: ISubscriptionInfo }) => { if (!props.subscriptionInfo) { return } const info = getSubscriptionsInfo(props.subscriptionInfo) return ( <>
{`${info.used}`} / {`${info.total}`} ( {info.percentage}% )
Expire: {info.expireStr()}
) }