first commit

This commit is contained in:
rachit1977
2026-06-14 10:03:34 +07:00
commit b55a575ac3
53 changed files with 9257 additions and 0 deletions
+29
View File
@@ -0,0 +1,29 @@
import { Loader2 } from "lucide-react";
import type { ButtonHTMLAttributes } from "react";
type ButtonProps = ButtonHTMLAttributes<HTMLButtonElement> & {
variant?: "primary" | "secondary" | "ghost" | "danger";
loading?: boolean;
};
const variants = {
primary:
"bg-gradient-to-r from-brand-orange to-brand-orangeDark text-white shadow-glow hover:brightness-110",
secondary:
"border border-white/15 bg-white/10 text-white hover:bg-white/15",
ghost: "text-white/80 hover:bg-white/10 hover:text-white",
danger: "border border-red-400/30 bg-red-500/15 text-red-100 hover:bg-red-500/25"
};
export function Button({ className = "", children, variant = "primary", loading, disabled, ...props }: ButtonProps) {
return (
<button
className={`inline-flex min-h-11 items-center justify-center gap-2 rounded-2xl px-4 py-2 text-sm font-semibold transition disabled:cursor-not-allowed disabled:opacity-60 ${variants[variant]} ${className}`}
disabled={disabled || loading}
{...props}
>
{loading ? <Loader2 className="h-4 w-4 animate-spin" /> : null}
{children}
</button>
);
}