Skip to content

ra-jeev/hub-chat

Repository files navigation

Cloudflare Workers AI LLM Playground with Nuxt 💬

NuxtHub AI Chat

Demo: https://hub-chat.nuxt.dev

Deploy to NuxtHub

Overview

This project is a chat interface to interact with various text generation models supported by Cloudflare Workers AI. It allows users to set different LLM parameters, toggle response streaming, handle streaming/non-streaming responses, parse markdown in responses, and includes a dark mode.

Read the blog post on how I created this LLM playground.

Features

  • Select the text generation model to interact with
  • Set different LLM parameters (temperature, max tokens, system prompt, top_p, top_k, etc.)
  • Toggle LLM response streaming on/off
  • Handle streaming and non-streaming LLM responses on both server and client sides
  • Parse and display markdown in LLM responses
  • Auto-scroll chat container as responses are streamed
  • Dark mode support

Technologies Used

  • Nuxt: Vue.js framework for the application foundation
  • Nuxt UI: Module for creating a sleek and responsive interface
  • Nuxt MDC: For parsing and displaying chat messages
  • NuxtHub: Deployment and administration platform for Nuxt, powered by Cloudflare

Prerequisites

  • Cloudflare Account: Required for using Workers AI models and deploying the project on Cloudflare Pages
  • NuxtHub Account: For managing NuxtHub apps and using AI in development

You can deploy and manage this application with a free Cloudflare and free NuxtHub account.

Setup

  1. Clone the repository and install the dependencies with pnpm:
pnpm i
  1. Rename .env.example to .env and update the following environment variables (for NuxtHub project key see point 3):
# Directly set your nuxthub project key without running npx nuxthub link
NUXT_HUB_PROJECT_KEY=your_nuxthub_project_key
# how to find account id for workers/pages https://developers.cloudflare.com/fundamentals/setup/find-account-and-zone-ids/#find-account-id-workers-and-pages
CLOUDFLARE_ACCOUNT_ID=your_cloudflare_account_id
# How to create PAI token https://developers.cloudflare.com/fundamentals/api/get-started/create-token/
CLOUDFLARE_API_TOKEN=your_cloudflare_api_token
  1. If you didn't set your NuxtHub project key in point 2 above, link your NuxtHub project to use AI models in development (it will ask you to create one if you don't have any)
npx nuxthub link
  1. Start the application in development mode
pnpm dev

Open http://localhost:3000 in your browser.

Deployment

Deploy to NuxtHub

NuxtHub Admin

  • Push your code to a GitHub repository.
  • Link the repository with NuxtHub.
  • Deploy from the Admin console.

Learn more about Git integration

Deploy via NuxtHub CLI

npx nuxthub deploy

Learn more about CLI deployment

Note

Do not forget to add the environment variables to your project's settings

License

This project is licensed under the MIT License. See the LICENSE file for details.

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •