mirror of
https://github.com/khairul169/garage-webui.git
synced 2025-06-17 22:29:32 +07:00
34 lines
940 B
TypeScript
34 lines
940 B
TypeScript
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)));
|
|
|
|
return `${(bytes / Math.pow(divider, i)).toFixed(1)} ${sizes[i]}`;
|
|
};
|
|
|
|
export const handleError = (err: unknown) => {
|
|
toast.error((err as Error)?.message || "Unknown error");
|
|
};
|
|
|
|
export const copyToClipboard = async (text: string) => {
|
|
try {
|
|
await navigator.clipboard.writeText(text);
|
|
toast.success("Copied to clipboard");
|
|
} catch (err) {
|
|
handleError(err);
|
|
}
|
|
};
|