garage-webui/src/lib/utils.ts

34 lines
940 B
TypeScript
Raw Normal View History

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 = ["B", "KB", "MB", "GB", "TB"];
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");
};
2024-08-17 00:51:57 +07:00
export const copyToClipboard = async (text: string) => {
try {
await navigator.clipboard.writeText(text);
toast.success("Copied to clipboard");
} catch (err) {
handleError(err);
}
};