Skip to content

gfazioli/mantine-border-animate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

79 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Mantine Border Animate Component

Mantine Border Animate

Overview

This component is created on top of the Mantine library. It requires Mantine 9.x and React 19.

Mantine BorderAnimate provides a flexible wrapper that turns any Mantine or plain React element into a visually striking component with animated borders. Designed for both aesthetics and performance, it uses CSS animations to deliver smooth 60fps effects and exposes controls to tailor the look and behavior: you can show/hide the border, keep it static or continuously animated, and adjust parameters like size, radius, border width, blur, duration, and color transitions.

The component includes three distinct variants — beam (a traveling glow along the perimeter with two rendering modes: path and conic), glow (a rhythmic pulsation with tunable blur and opacity), and pulse (a subtle expand-and-fade "breathing" effect).

Key features include:

  • Two beam rendering modespath (radial-gradient traveling along the border via CSS offset-path, uniform beam size) and conic (rotating conic-gradient, smooth rotation with customizable wedge spread)
  • Custom color stops — multi-color gradients via colorStops for both beam modes
  • Pause on hoverpauseOnHover prop to pause animations during user interaction
  • Custom timing functionstimingFunction prop for full control over animation easing
  • Accessible — automatically respects prefers-reduced-motion to disable animations for users who prefer reduced motion

Advanced visual setups are supported through masking and layering: withMask clips the effect to the border area, while disabling it and using zIndex allows soft background glows behind content. Integration is straightforward via provided stylesheet imports, and examples demonstrate wrapping common Mantine components like Paper, Cards, Buttons, Inputs, and Alerts.

Installation

npm install @gfazioli/mantine-border-animate

or

yarn add @gfazioli/mantine-border-animate

After installation import package styles at the root of your application:

import '@gfazioli/mantine-border-animate/styles.css';

Usage

import { Stack, Title } from '@mantine/core';
import { BorderAnimate } from '@gfazioli/mantine-border-animate';

function Demo() {
  return (
    <BorderAnimate w={300} p={32}>
      <Stack>
        <Title>This is a title</Title>
        <p>This is a paragraph inside the BorderAnimate component.</p>
      </Stack>
    </BorderAnimate>
  );
}

Sponsor

Your support helps me:

  • Keep the project actively maintained with timely bug fixes and security updates
  • Add new features, improve performance, and refine the developer experience
  • Expand test coverage and documentation for smoother adoption
  • Ensure long‑term sustainability without relying on ad hoc free time
  • Prioritize community requests and roadmap items that matter most

Open source thrives when those who benefit can give back—even a small monthly contribution makes a real difference. Sponsorships help cover maintenance time, infrastructure, and the countless invisible tasks that keep a project healthy.

Your help truly matters.

💚 Become a sponsor today and help me keep this project reliable, up‑to‑date, and growing for everyone.


Star History Chart

About

Mantine component offering four border animation variants (beam, glow, gradient, pulse) with customizable colors and full animation control, perfect for creating dynamic, visually engaging UI elements.

Topics

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Sponsor this project

 

Packages

 
 
 

Contributors