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

@cloudtrain/chatbot-react-native

v0.6.1

Published

CloudTrain Chatbot for React Native

Readme

CloudTrain Chatbot for React Native

A customizable chatbot component for React Native. Works with any RN project (Expo or bare).

Installation

npm install @cloudtrain/chatbot-react-native @cloudtrain/sdk react-native-svg react-native-markdown-display react-native-safe-area-context

Peer dependencies: react, react-native, react-native-svg, react-native-markdown-display, react-native-safe-area-context.

Streaming

For live character-by-character streaming, the chatbot uses expo/fetch when available (Expo SDK 51+). It's picked up automatically — no code changes required.

For bare React Native (no Expo) the chatbot falls back to the non-streaming chat() endpoint and reveals the full response with the same char-paced animation. UX is nearly identical, but the user waits for the full response before the reveal begins rather than seeing live tokens.

Usage

import { CloudtrainChatbot } from '@cloudtrain/chatbot-react-native';

export default function App() {
  return (
    <>
      <YourApp />
      <CloudtrainChatbot apiKey="YOUR_API_KEY" />
    </>
  );
}

The component renders an absolutely-positioned FAB that opens a full-screen modal chat. Place it once at the root of your app.

Props

| Prop | Type | Required | Description | |-------------------|----------|----------|------------------------------------------------------| | apiKey | string | ✅ | API key from CloudTrain. | | baseUrl | string | ❌ | Custom API base URL. Defaults to https://cloudtrain.ai. | | chatSuggestions | string[] | ❌ | Prompts shown in the empty state. | | theme | "light" \| "dark" \| "system" | ❌ | Defaults to system. | | themeOverride | Partial<Theme> | ❌ | Override individual color tokens. | | meta | object | ❌ | Custom metadata forwarded to the AI model. | | hideBranding | boolean | ❌ | Hides the "Powered by CloudTrain" footer. | | botName | string | ❌ | Overrides the agent name in the header. Falls back to the API, then "AI Assistant". | | avatarUrl | string | ❌ | Overrides the agent avatar. Falls back to the API's logo. | | welcomeMessage | string | ❌ | Heading shown in the empty state. | | welcomeSubtitle | string | ❌ | Subline shown under the heading. | | position | "bottom-right" \| "bottom-left" | ❌ | FAB anchor corner. Defaults to bottom-right. | | revealDelayMs | number | ❌ | Ms between each character in the streaming reveal animation. 0 (default) shows characters as they arrive; positive values (e.g. 20) produce a typewriter effect. | | defaultOpen | boolean | ❌ | If true, the chat panel opens automatically on mount. Defaults to false. | | onError | (error: unknown) => void | ❌ | Called when a chat request fails (excludes user-initiated aborts). |

Theming

Pass a themeOverride object with any subset of the theme tokens:

<CloudtrainChatbot
  apiKey="..."
  themeOverride={{
    primary: '#FF6B35',
    primaryForeground: '#fff',
    accent: '#FFE5DA',
  }}
/>

Available tokens: background, foreground, border, primary, primaryForeground, mutedForeground, accent, messageIcon, destructive.

License

MIT