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

@fadedrifleman/web-sdk

v4.5.1

Published

SDK for Quibble AI

Downloads

61

Readme

QuibbleAI SDK Documentation

Installation

To install the QuibbleAI SDK, run the following command:

npm i @fadedrifleman/web-sdk

Importing the SDK

Import the necessary modules from the SDK using the following syntax:

import { Quib, Transcriber, useVAD } from '@fadedrifleman/web-sdk';

Configuration

Next.js

For a Next.js project, add the required plugins to your next.config.js:

/** @type {import('next').NextConfig} */
const CopyPlugin = require("copy-webpack-plugin");

const wasmPaths = [
    "./node_modules/onnxruntime-web/dist/*.wasm",
    "./node_modules/@ricky0123/vad-web/dist/silero_vad.onnx",
    "./node_modules/@ricky0123/vad-web/dist/vad.worklet.bundle.min.js"
];

const nextConfig = {
  webpack(config) {
    config.module.rules.push({
      test: /\.svg$/,
      use: ["@svgr/webpack"],
    });

    config.resolve.alias = {
      ...config.resolve.alias,
      sharp$: false,
      "onnxruntime-node$": false,
    };

    config.plugins.push(
      new CopyPlugin({
        patterns: wasmPaths.map((p) => ({
          from: p,
          to: "static/chunks/app",
        })),
      })
    );

    // for Vercel
    config.plugins.push(
      new CopyPlugin({
        patterns: wasmPaths.map((p) => ({
          from: p,
          to: "static/chunks",
        })),
      })
    );

    return config;
  },
  reactStrictMode: false,
  async headers() {
    return [
      {
        source: "/_next/(.*)",
        headers: [
          {
            key: "Cross-Origin-Opener-Policy",
            value: "require-corp",
          },
          {
            key: "Cross-Origin-Embedder-Policy",
            value: "require-corp",
          },
        ],
      },
    ];
  },
};

module.exports = nextConfig;

Vite React App

For a Vite React app, add the required plugins to your vite.config.js:

import react from "@vitejs/plugin-react-swc";
import { viteStaticCopy } from "vite-plugin-static-copy";

export default defineConfig({
  plugins: [
    react(),
    viteStaticCopy({
      targets: [
        {
          src: "node_modules/@ricky0123/vad-web/dist/vad.worklet.bundle.min.js",
          dest: "./",
        },
        {
          src: "node_modules/@ricky0123/vad-web/dist/silero_vad.onnx",
          dest: "./",
        },
        {
          src: "node_modules/onnxruntime-web/dist/*.wasm",
          dest: "./",
        },
      ],
    }),
  ],
});

Quib

The Quib class is a middleware that connects to the QuibbleAI websocket to handle various events such as user input, media output, end call, clear, and more.

Importing the Quib Class

import { Quib } from "@fadedrifleman/web-sdk";

Creating a Quib Object

To create a Quib object, provide the following parameters:

  • protocol: Accepted values are ws for development and wss for production.
  • host: The host URL provided by QuibbleAI.
  • uid: A unique string value provided by the user for each connection.
const quib = new Quib({
  protocol: "wss",
  host: process.env.HOST,
  uid: "unique_connection_ID"
});

Handling Events

  • connected: Triggered when a connection to QuibbleAI's websocket is established.

    quib.on("connected", () => {
        console.log("Connection to websocket established");
    });
  • media: Provides mp3 buffer data for audio playback. This event may occur multiple times for a single audio file.

    quib.on("media", (mediaPayload) => {
        console.log(mediaPayload?.media);
    });
  • mark: Indicates that all media events for the current interaction have been sent.

    quib.on("mark", () => {
        console.log("Audio data for the current interaction completely received");
    });
  • clear: Indicates that the server has detected an interruption and wants you to clear the currently playing media up to the mark event.

    quib.on("clear", () => {
        console.log("Clear the current playing audio up to the mark event");
    });
  • userText: Provides the user text input sent to the LLM.

    quib.on("userText", (data) => {
        console.log(data);
    });
  • assistantText: Provides the text response from the LLM.

    quib.on("assistantText", (data) => {
        console.log(data);
    });
  • endCall: Indicates the end of the conversation from the agent's side.

    quib.on("endCall", () => {
        console.log("Conversation end reached from agent side");
    });
  • close: Indicates that the websocket connection has been closed or is in the process of closing.

    quib.on("close", () => {
        console.log("Websocket has been closed or is in closing state");
    });
  • error: Triggered when there is an error with the websocket connection.

    quib.on("error", (error) => {
        console.log(error);
    });

Methods

  • gpt(text): Sends text input to the LLM.

    quib.gpt("Hello! How are you?");
  • stop(): Initiates the closing of the websocket on your end.

    quib.stop();
  • close(): Closes the websocket connection.

    quib.close();
  • mark(): Indicates that you have finished playing the audio data for this interaction.

    quib.mark();
  • interruption(text): Notifies the websocket of an interruption.

    quib.interruption("Pardon! I can't hear you.");
  • keepAlive(): Keeps the connection alive during inactivity. Recommended to be sent every 5 seconds.

    quib.keepAlive();

Transcriber

The Transcriber class is a middleware that connects to the Deepgram websocket for audio transcription from your microphone.

Importing the Transcriber Class

import { Transcriber } from "@fadedrifleman/web-sdk";

Creating a Transcriber Object

To create a Transcriber object, provide the following parameter:

  • apiKey: Your Deepgram API Key (provided by QuibbleAI).
const transcriber = new Transcriber({ apiKey: process.env.DEEPGRAM_API_KEY });

Handling Events

  • connected: Triggered when a connection to the Deepgram websocket is established.

    transcriber.on("connected", () => {
        console.log("Connection to Deepgram websocket established");
    });
  • error: Triggered when there is an error with the Deepgram websocket connection.

    transcriber.on("error", (error) => {
        console.log(error);
    });
  • close: Indicates that the websocket connection has been closed or is in the process of closing.

    transcriber.on("close", () => {
        console.log("Websocket has been closed or is in closing state");
    });
  • partialTranscription: Provides a partial transcription which may not be the final transcription.

    transcriber.on("partialTranscription", (text) => {
        console.log(text);
    });
  • transcription: Provides the final transcription.

    transcriber.on("transcription", (text) => {
        console.log(text);
    });

Methods

  • send(): Sends audio blob data to Deepgram.

    transcriber.send();
  • keepAlive(): Keeps the connection with the Deepgram websocket alive during inactivity. Recommended to be sent every 9 seconds.

    transcriber.keepAlive();
  • close(): Closes the connection to Deepgram.

    transcriber.close();

useVad

The useVad hook is used for voice activity detection (VAD) with a media device object.

Importing the useVad Hook

import { useVad } from "@fadedrifleman/web-sdk";

Using the useVad Hook

First, define the mediaDevice:

const uMedia = await navigator.mediaDevices.getUserMedia({
  audio: {
    noiseSuppression: true,
    echoCancellation: true,
  },
});

Then, define the onSpeechStart and onSpeechEnd functions:

const onSpeechStartFunction = () => {
  console.log("VAD detected start of speech");
};

const onSpeechEndFunction = () => {
  console.log("VAD detected end of speech");
};

Now, define the useVad hook:

const { start, pause } = useVad({
  userMedia: uMedia,
  onSpeechStart: onSpeechStartFunction,
  onSpeechEnd: onSpeechEndFunction,
});

The useVad hook returns two functions: start and pause.

  • start(): Starts VAD processing of the audio.

    start();
  • pause(): Pauses VAD processing of the audio.

    pause();