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 🙏

© 2026 – Pkg Stats / Ryan Hefner

@mit-app-inventor/chatbot

v2.0.0

Published

A pure JavaScript implementation of the MIT App Inventor ChatBot component.

Readme

MIT App Inventor ChatBot.js

This package implements the ChatBot component from MIT App Inventor in pure JavaScript.

Install

npm install --save @mit-app-inventor/chatbot

Usage

NB: To use the ChatBot, you will need a token from App Inventor and an API key for the LLM service in question. You can either provide the ApiKey directly in your source (not advised) or you can create a short API key via https://chatbotadmin.appinventor.mit.edu/. The use of a short key will prevent leaking your real API key in your sources and the short key can only be used via the ChatBot proxy. You can revoke short keys via the admin interface.

import { ChatBot } from '@mit-app-inventor/chatbot';
const chatbot = new ChatBot('YOUR-TOKEN-HERE');
const response = await chatbot.Converse('What is 2+2?');
document.body.appendChild(document.createTextElement(response));

Additionally, you need a Token. For now, the easiest way to do this is to navigate to https://code.appinventor.mit.edu and continue without an account. In this new anonymous account, you can start a blank project and then add a ChatBot to Screen1. From there, expand the Advanced category under Properties and copy the Token value.

API

The API of ChatBot generally follows the App Inventor blocks described here. However, some minor enhancements have been made for the convenience of developers writing JavaScript.

// Idomatic App Inventor by providing the event handler
chatbot.GotResponse = (response) => {
  document.body.appendChild(document.createTextElement(response));
}
chatbot.Converse('What is 2+2?');  // This calls GotResponse eventually

// JavaScript await
const response = await chatbot.Converse('What is 2+2?');
document.body.appendChild(document.createTextElement(response));

Converse(question)

Asks the question of the ChatBot. This will call GotResponse with the response text and return a Promise that will resolve when the response is returned.

ConverseWithImage(question, source)

Asks the question of the ChatBot using the given source as an image context. The source can be be an HTMLImageElement, an HTMLCanvasElement, or a Blob that contains image data.

A Promise resolving to the response text will be returned, and the GotResponse callback will also be run.

CreateImage(description)

Asks the ChatBot to create an image given description. The GotResponseWithImage method will be called with the response text and image URL as parameters:

chatbot.GotResponseWithImage = (text, image) => {
  document.querySelector('img.output').src = image;
  document.body.appendChild(document.createTextNode(text));
}
chatbot.CreateImage("a cat with a hat");

If using the async syntax, a Promise to an object with the keys responseText and responseImage is returned that can be awaited:

{
  "responseText": "Okay, here's an image of...",
  "responseImage": "..."
}