2024-08-14 15:36:25 +07:00
|
|
|
import clsx from "clsx";
|
|
|
|
import { toast } from "sonner";
|
|
|
|
import { twMerge } from "tailwind-merge";
|
|
|
|
|
|
|
|
export const cn = (...args: any[]) => {
|
|
|
|
return twMerge(clsx(...args));
|
|
|
|
};
|
|
|
|
|
|
|
|
export const ucfirst = (text?: string | null) => {
|
|
|
|
return text ? text.charAt(0).toUpperCase() + text.slice(1) : null;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const readableBytes = (bytes?: number | null, divider = 1024) => {
|
|
|
|
if (bytes == null || Number.isNaN(bytes)) return "n/a";
|
|
|
|
|
|
|
|
const sizes = ["Bytes", "KB", "MB", "GB", "TB"];
|
2024-08-16 23:10:19 +07:00
|
|
|
const i = Math.max(0, Math.floor(Math.log(bytes) / Math.log(divider)));
|
2024-08-14 15:36:25 +07:00
|
|
|
|
|
|
|
return `${(bytes / Math.pow(divider, i)).toFixed(1)} ${sizes[i]}`;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const handleError = (err: unknown) => {
|
|
|
|
toast.error((err as Error)?.message || "Unknown error");
|
|
|
|
};
|