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 🙏

© 2024 – Pkg Stats / Ryan Hefner

real-typer

v2.0.5

Published

A JavaScript library that gives the effect of typing texts

Downloads

1,714

Readme

Real-Typer npm version

A JavaScript library that gives the effect of typing for texts. Live Example

Using CDN

Import the CDN using script tags

<script src="https://cdn.statically.io/gh/cyrus2281/Real-Typer/main/src/JavaScript/dist/real-typer.min.js"></script>

Using NPM

install package with

npm install real-typer

import the file in your JS file.

import 'real-typer'

Quick Start:

create a html container.

    <div class="typer"></div>

make sure you have imported the script using CDN or npm and import.

create an object of RealTyper and pass the html element, the strings, and the options

Then call the type method to start typing.

    <script>
        const typer = new RealTyper.Typer(
            document.querySelector(".typer"),
            [
                "First Sample Text",
                "Second Sample Text",
                "Third Sample Text"
            ]);
        const typeInstance = typer.type();
    </script>

if you app is not finding RealTyper call it with window prefix.

    const typer = new window.RealTyper.Typer(document.querySelector(".typer"), "test");

Emitters

You can use emit to add an string to the list of strings being typed.

    const index = true;
    typeInstance.emit("New String", index);
  • index is optional and if not passed the string will be added to the end of the list.
  • index can be a number or true. if it is a number the string will be added to the list at that index. if it is true the string will be added to the last string.

Customization

the following properties can be changed.

    <script>
        const typer = new RealTyper.Typer(
            document.querySelector(".typer"),
            [
                "First Sample Text",
                "Second Sample Text",
                "Third Sample Text"
            ],
            {
                cursorCharacter : "|",
                cursorBlink: true,
                typeSpeed : 100,
                deleteSpeed : 50,
                holdDelay : 1500,
                pauseDelay : 1000,
                startDelay : 0,
                delete : true,
                deleteLastString : true,
                loop : true,
                loopHold : 1500,
                loopStartIndex : ,
                callback : null,
                callbackArgs : null,
                developerMode : true,
            }
        );
        const typeInstance = typer.type();
    </script>

Interface:

Properties::

strings (default: undefined)   : Strings to be type, this value can be pass as an argument or be children of the selected component

htmlElement (default: undefined) : the html component that the strings are written into
   
cursorCharacter (default: "|")   : value for the cursor symbol. put "" for no cursor

cursorBlink (default: true)      : whether to blink the cursor or not

typeSpeed (default: 100)         : the speed at which the characters are written

deleteSpeed (default: 50)        : the speed at which the characters are deleted

holdDelay (default: 1500)        : the amount of delay before starting to delete

pauseDelay (default: 1000)       : the amount of delay before starting the next string

startDelay (default: 0)          : the amount of delay before starting to type since the call of method

delete (default: true)           : whether to delete the string or not

deleteLastString (default: true) : whether to delete the last string or not (only happens if 'delete' is true)

loop (default: true)             : whether to loop or not

loopHold (default: 1500)         : the amount of pause before repeating the cycle

loopStartIndex (default: 0)      : Index of the string that the loop will start from the second cycle and on

callback (default: null)         : callback function that will run after each cycle

callbackArgs (default: null)     : argument that will be passed to the callback function

developerMode (default: false)   : logs errors in the console for debugging [recommend for development]

type instance:

emit (input: string, index: undefined|number|true)   : to add an string to the list of strings being typed

Author: Cyrus Mobini

Licensed under the MIT license. http://www.opensource.org/licenses/mit-license.php

Copyright 2023 Cyrus Mobini