A smooth text animation component for Svelte applications that provides customizable character-by-character animations with optimized performance.
You can check out the Demo in a Svelte Playground!
npm install svelte-text-animation
<script>
import { TextAnimation, map } from 'svelte-text-animation';
import { Tween } from 'svelte/motion';
let progress = new Tween(0);
const animate = () => {
    progress.target = progress.current === 0 ? 1 : 0;
};
</script>
<TextAnimation
    text="Hello World"
    progress={progress.current}
    styleCallback={(i) => `font-weight: ${map(i, 200, 900)}`}
/>
| Prop | Type | Default | Description | 
|---|---|---|---|
| text | string | required | The text to be animated | 
| progress | number | required | Animation progress (0-1) | 
| styleCallback | function | required | Style generator function | 
| spread | number | 3 | Number of characters affected on each side | 
| edgeFlatness | number | 5 | Controls the flatness of the edge decay curve. Higher values make the curve flatter in the middle, keeping the effect intensity closer to 1 for a larger range. Must be an integer >= 2. | 
| innerClassName | string | "" | CSS class for character spans | 
<TextAnimation
    text="Dynamic Weight"
    progress={progress}
    styleCallback={(i) => `font-weight: ${map(i, 200, 900)}`}
/>
<TextAnimation
    text="Color Fade"
    progress={progress}
    styleCallback={(i) => `color: rgba(255, 0, 0, ${i})`}
/>
<script>
import { Tween } from 'svelte/motion';
import { cubicInOut } from 'svelte/easing';
import TextAnimation, { map } from 'svelte-text-animation';
const progress = new Tween(0, { 
    duration: 3800, 
    easing: cubicInOut 
});
// Auto animation
progress.target = 1;
setInterval(() => (progress.target = progress.target == 0 ? 1 : 0), 4300);
</script>
<link href="https://fonts.googleapis.com/css2?family=Climate+Crisis:[email protected]&display=swap" rel="stylesheet" />
<TextAnimation
    text="Variable Font Magic"
    className="climate-crisis"
    progress={progress.current}
    spread={5}
    edgeFlatness={5}
    styleCallback={(intensity) => `
        font-size: ${map(intensity, 5, 4)}rem;
        font-variation-settings: "YEAR" ${map(intensity, 1979, 2040)};
    `}
/>
<style>
    :global(.climate-crisis) {
        font-family: 'Climate Crisis', sans-serif;
        font-optical-sizing: auto;
        font-weight: 400;
        font-style: normal;
    }
</style>
map utility function for value interpolationMIT