npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

react-teffex

v1.0.5

Published

Text Effects: Stateful React text effects for amazing websites

Downloads

82

Readme

React text effects

Text Effects: Stateful React text effects for amazing websites

These effects return a <span> element with your text and desired effect. You can use them in links, headings, divs and spans alike. These effects use RAF (request animation frame) for optimal performance and less reliance on setTimeout/setInterval.

Effects

Glitch

Typewriter

Glitch

CodeSandBox example

Have your text randomise between Roman alphabet letters or 1's and 0's and appear in sequence. The effect does discard timers on onMount, so for best practices be sure to remove or set the element to null on unMounting or rerendering.

Note: For the best effect, use a font-family with consistent letter spacing e.g. Courier New, Courier, monospace

Usage

import React, {useEffect} from "react";
import {Glitch} from "react-teffex";

export default function AwesomeGlitchEffect(props) {

  let myGlitchEffects = (
    <div>
      <Glitch alphabet buffer={20} text={"This is glitchy text!"} />
      <Glitch
        alphabet
        reverse
        text={"This is glitchy text comming from the other side!"}
      />
      <br />
      <Glitch text={"This glitches as 1's and zeroes!"} />
      <br />
      <Glitch text={"This glitches as 1's and zeroes!"} />
    </div>
  );

  /* Best practice is to discard the effect when rerendered in order to avoid memory leaks or warnings thereof */

  useEffect(()=>{
    return (myGlitchEffects=null)
  },[])

  return (
    <div className="container">
      {myGlitchEffects}
    </div>
  );
}

Parameters

<Glitch {parameters} />

text:string The text you wish to display through the effect

reverse:boolean Reverse the direction of the glitch effect hwne it flips to the desired letter

id:string CSS id that can be added to your text for CSS modifications and events

speed:number Loop delay of the animation in ms (smaller is faster) (default = 50ms)

glitchSpeed: number Maximum delay before next glitch (the glitch timer uses a random value between 0 and the glitchSpeed in ms, smaller is faster) (default = 5000ms)

dontGlitch:boolean specify if you do not want the text to glitch after initial animation

buffer: number Adds additional loops to the animation in order to delay the word revealing itself (default = 0)

alphabet: boolean Will use the Roman alphabet instead of 1's and 0's

style: object React styled components

extendedAlphabet: boolean; Will use the extended Roman alphabet (i.e. includes characters like ß, ę, į etc.)

onClick:function (event)=>{} Runs a function you provide with the event as the parameter

onMouseEnter:function (event)=>{} Runs a function you provide with the event as the parameter

onMouseLeave:function (event)=>{} Runs a function you provide with the event as the parameter

Typewriter

CodeSandBox example

One of the most elegant typewriter effects for react. No setTimeout or setInterfals used, everything is based on RAF with indexed values for a super lightweight interface. Highly customizable, from the initial delay, to the stutter delay, stutter chance,

Usage

import React from "react";
import {Typewriter} from "react-teffex";

export default function AwesomeGlitchEffect(props) {

  return (
    <div>
      <Typewriter text={"This is a general typewriter"} />
      <Typewriter
        cycle={["This will cycle", "and stop"]}
      />
      <Typewriter
        typeSettings={{ initialDelay: 1000 }}
        text={"This will cycle "}
        cycle={["forever", "and ever"]}
        loop
      />
    </div>
  );

}

Parameters

<Typewriters {parameters} />

text:string The text you wish to display through the effect (persistant)

cycle:string[] Arrays that will display, backspace after cycleDelay time, then display the next item. If it is the last item and no loop prop is provided, it will persist.

cycleDelay:number Amount of time between each cycle in ms

id:string CSS id that can be added to your text for CSS modifications and events

loop: boolean if true, will continuously loop through each cycle provided

typeSettings.stutterTime: number The delay when stuttering (pause typing) in ms

typeSettings.stutterChance: number Chance out of 10 (actually 9) to stutter

typeSettings.typeDelay: number The delay between each character being typed in ms (determines the type speed)

typeSettings.initialDelay: number Initial delay before effect starts in ms

cursorSettings.color: string Colour of the cursor

cursorSettings.cursorBlinkSpeed: string Delay time between cursor blinking in ms

style: object React styled components

onClick:function (event)=>{} Runs a function you provide with the event as the parameter

onMouseEnter:function (event)=>{} Runs a function you provide with the event as the parameter

onMouseLeave:function (event)=>{} Runs a function you provide with the event as the parameter

Contributors

Please feel free to use, mix-up, improve, or add to the effects here. Please ensure that you use the format seen above when adding an effect, documentation is important.

Readme style:

  1. Heading + Description

  2. Contents (edit this when adding)

  3. Effects (Be sure to include these!) 3.1. Effect name 3.2 CodeSandBox example 3.3 Effect description 3.4 Usage 3.5 Effect parameters

How to add to the content section:

Add a <a name="#your_effect_name_here"></a> before your effect's section

Add [your_effect_name_here](#your_effect_name_here) to the content