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

@cozimacode/react-bot

v2.1.0

Published

A clean, compact and responsive chat widget for React Apps.

Downloads

25

Readme

ReactBot

Features at a glance

  • Responsive, user friendly chat interface
  • Totally customizable
  • Supports multiple bot instances on a single page (v2 and above)
  • Extremely low learning curve
  • Lightweight

Demonstration

demo

Fork our repository if you'd like to play with the demo.

Installation

npm

npm install @cozimacode/react-bot

yarn

yarn add @cozimacode/react-bot

UNPKG

<script src="https://unpkg.com/@cozimacode/react-bot"></script>

You can access it via window.ReactBot

Usage

1- Import the ReactBot component and the stylesheet in your app and pass the mandatory handleUserInput prop that accepts a function to process the user input.

import React from "react";
import { ReactBot } from "@cozimacode/react-bot";
import "@cozimacode/react-bot/dist/styles.css";

function Demo() {
  const handleUserInput = (input) => {
    //You can send this message to the backend or mock a response
  };

  return <ReactBot handleUserInput={handleUserInput} />;
}

export default Demo;

2- Import the addBotMessage method to add a plain text bot response.

import React from "react";
import { ReactBot, addBotMessage } from "@cozimacode/react-bot";
import "@cozimacode/react-bot/dist/styles.css";

function Demo() {
  const handleUserInput = (input) => {
    if (input.indexOf("Hi") > -1) {
      addBotMessage("Hi there!");
    }
  };

  return <ReactBot handleUserInput={handleUserInput} />;
}

export default Demo;

3- You are in the driver's seat when it comes to customization. You can set an initial response, change the title, the launch icon, the avatar etc. See Props below for all available customizations.

import React from 'react';
import { ReactBot } from '@cozimacode/react-bot';
import launcherIcon from './launcherIcon.png';
import "@cozimacode/react-bot/dist/styles.css";

function Demo() {
    const handleUserInput = (input) => {
    ...
  };

    return (
      <ReactBot
        handleUserInput={handleUserInput}
        customLauncherIcon={launcherIcon}
        title="ReactBot"
        messagePlaceHolder="Type something here..."
      />
    );
}

export default Demo;

Props

| prop | type | required | default value | description | | ---------------------- | ----------------------------------------------------------------------- | ------------------------------------------------------ | ----------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | autofocus | boolean | NO | true | Focuses on the input field on launch. | | botId | string | YES (if using multiple bots feature) | default | Passing a unique ID to this prop is mandatory only if you require multiple bots on the same page. | | chatAvatar | string | NO | | The chat avatar for the bot response. | | className | string | NO | | Useful for custom styling and overwriting default styles. | | customLauncherIcon | string | NO | | Change the default launcher icon/image. | | handleUserInput | (input: string, showTyping: () => void, hideTyping: () => void) => void | YES | | Accepts a function that processes the user input. The first argument depicts the user input as a string. The second and third arguments are functions to show and hide typing indicator respectively. | | initialResponse | object | NO | | Accepts an object with keys Component, props and avatar, just like addCustomResponse method. Use it to show a default response. | | messagePlaceHolder | string | NO | Type a message... | Placeholder for input. | | title | string | NO | Hi, there! | Title for the chat widget. | | titleAvatar | string | NO | | The picture that will be shown before the title in header. | | typingGif | string | NO | | Show a different gif/png for typing indicator. |

Overriding Styles

Feel free to create a custom CSS stylesheet and override the default CSS classes to match your overall app design. All styles are prefixed with rcb- to avoid any conflicts.

.rcb-bot-message {
  background-color: #afd2ff;
}

.rcb-user-message {
  background-color: #c53658;
}

Methods

  • addBotMessage You can use this method to simulate a response from the bot after processing the user input through the backend. The first argument accepts a plain text value. The second argument takes the botId which only needs to be passed if using the multiple bots feature and needs to match the ID you pass to ReactBot.

  • addUserMessage This method can be used to add a message as a user without invoking the handleUserInput function. First argument accepts a plain text value. For the second argument, it is same scenario as mentioned above for addBotMessage.

  • addCustomComponent This is used to add any custom React component. The first argument accepts an object with the component class, props for it (if any) and an optional boolean to show/hide the chat avatar. For the second argument, it is same scenario as mentioned above for addBotMessage.

    addCustomComponent({
      Component: CustomReactComponent,
      props: { propOne: value, propTwo: value },
      avatar: true,
    });

Multiple Bots

multiple-bots

v2 and above supports multiple bot instances on the same page. Passing the botId prop with a unique identification key is mandatory when using this feature.

Also, the methods above need the same ID passed to them as the second argument. Check the demo project for a sample of multiple bots.

Need further customization?

You are more than welcome to fork our code repository and make any changes or add any custom features as you please. If you feel like sharing your work with the community, then we'd love for you to contribute to this project.

About

This project is written and maintained by Naser Baig.

I am always looking for exciting projects to work on. If you happen to be working on one of them and need a frontend engineer, then let's connect.