Fractal React Typewriter Effect
This is a package that gives your text a typing effect, with extra features like looping multitext and callback functions on text change! Forked from kevoese/react-typewriter-effect.
This package lets you create a typewriting effect for text elements.
Typewriter Effect animates when the component is in view. By default, it uses the document reference to check if the component is in view or not; but you can pass the ref
object which is scrollable to the scollArea
props.
For example
const myRef = document.querySelector('.scrollable-div')
<TypeWriterEffect width="230" trackWidth="13" percentage={score} scrollArea={myRef}/>
Otherwise
If scrollArea
is not defined, the document reference object is used.
Set up
To use the package, start by installing the package on your React project file with:
npm i react-typewriter-effect
For a single text display
import TypeWriterEffect from 'react-typewriter-effect';
<TypeWriterEffect
textStyle={{ fontFamily: 'Red Hat Display' }}
startDelay={100}
cursorColor="black"
text="This is a single text"
typeSpeed={100}
scrollArea={myAppRef}
/>
Output
For a multiple text display
Set the multiText
props to an array of strings which are displayed sequentially.
import TypeWriterEffect from 'react-typewriter-effect';
<TypeWriterEffect
textStyle={{
fontFamily: 'Red Hat Display',
color: '#3F3D56',
fontWeight: 500,
fontSize: '1.5em',
}}
startDelay={2000}
cursorColor="#3F3D56"
multiText={[
'Hey there, This is a type writer animation package',
'it consist of two types...',
'Single text display and multi text display',
'Fonts can be customized.',
'The type speed can be customized as well',
]}
loop={true}
nextTextDelay={1000}
typeSpeed={30}
/>
Output
Properties and description
-
text
(must be a string): Required in single text display mode. The text in string. -
multiText
(array of string): Required in multitext mode. -
nextTextDelay
(must be a number): Delay before each text is erased in multitext or looped display, in milliseconds. -
loop
(a boolean): If true, continuously cycle through the text. Default: false. -
typeSpeed
(must be a number): Speed of typing, in milliseconds. -
startDelay
(must be a number): Delay before the animation starts, in milliseconds. -
hideCursorAfterText
(a boolean): It removes the cursor after typing. -
cursorColor
(must be a string): Color of the cursor. -
textStyle
(must be an object): Custom CSS styles that can be applied to the text in this object. -
scrollArea
(must be a DOM element): The scrollable area. By default, it isdocument
.