Reveal Button
A modern button with animated text reveal, fade, and background glow effects. Perfect for creative, playful, and interactive UIs.
Demo
Interactive Demo
Hover to reveal the animated text and background glow.
Loading...
Installation
Install the required dependencies to get started:
bash
Loading...
Type Integration
Create a lib folder at the root of your project and add a types.ts file with the following interface. This interface is used by all button components for consistent props and TypeScript support.
typescript
Loading...
Usage
Import and use the RevealButton component in your Next.js application:
tsx
Loading...
Props
| Prop | Type | Default | Description |
|---|---|---|---|
children | React.ReactNode | - | Button content (usually text or icon). |
onClick | () => void | undefined | Click handler for the button. |
className | string | "" | Additional CSS classes for the button. |
disabled | boolean | false | Disables the button if true. |
type | "button" | "submit" | "reset" | "button" | Button type attribute. |
Features
- Animated text reveal effect on hover (each character fades and slides in)
- Default text fades out and scales up on hover
- Background pink glow effect on hover
- Framer Motion-powered transitions
- Customizable label and style
- TypeScript support
- Production-ready and accessible
Dependencies
Next.js 15+
Framer Motion
Tailwind CSS (recommended)
TypeScript (recommended)