Files
Wdipl-react/components/ui/shimmer-button.tsx

33 lines
1.1 KiB
TypeScript
Raw Normal View History

2025-07-11 16:54:37 +05:30
import React from "react";
import { cn } from "./utils";
interface ShimmerButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {
children: React.ReactNode;
className?: string;
}
const ShimmerButton = React.forwardRef<HTMLButtonElement, ShimmerButtonProps>(
2025-09-26 16:03:21 +05:30
({ className, children, disabled, ...props }, ref) => {
2025-07-11 16:54:37 +05:30
return (
<button
ref={ref}
2025-09-26 16:03:21 +05:30
disabled={disabled}
2025-07-11 16:54:37 +05:30
className={cn(
2025-09-26 16:03:21 +05:30
"relative inline-flex items-center justify-center gap-2 rounded-md bg-accent px-6 py-3 text-sm font-medium text-accent-foreground transition-all duration-300 whitespace-nowrap overflow-hidden",
!disabled
? "hover:bg-accent/90 cursor-pointer before:absolute before:inset-0 before:-translate-x-full before:animate-[shimmer_2s_infinite] before:bg-gradient-to-r before:from-transparent before:via-white/10 before:to-transparent"
: "bg-gray-700 text-gray-400 cursor-not-allowed before:!hidden",
2025-07-11 16:54:37 +05:30
className
)}
{...props}
>
{children}
</button>
);
}
);
ShimmerButton.displayName = "ShimmerButton";
2025-09-26 16:03:21 +05:30
export { ShimmerButton };