Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ra-jeev/hub-chat
Cloudflare Workers AI LLM Playground with Nuxt
https://github.com/ra-jeev/hub-chat
ai cloudflare cloudflare-ai nuxt nuxthub ssr vue
Last synced: about 4 hours ago
JSON representation
Cloudflare Workers AI LLM Playground with Nuxt
- Host: GitHub
- URL: https://github.com/ra-jeev/hub-chat
- Owner: ra-jeev
- License: mit
- Created: 2024-08-21T10:12:58.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-12-15T05:59:46.000Z (24 days ago)
- Last Synced: 2024-12-31T19:11:00.890Z (7 days ago)
- Topics: ai, cloudflare, cloudflare-ai, nuxt, nuxthub, ssr, vue
- Language: Vue
- Homepage: https://hub-chat.nuxt.dev
- Size: 791 KB
- Stars: 74
- Watchers: 1
- Forks: 14
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Cloudflare Workers AI LLM Playground with Nuxt 💬
[![NuxtHub AI Chat](https://github.com/user-attachments/assets/f393167e-7d21-4d7b-bacf-101103c1d093)](https://hub-chat.nuxt.dev)
Demo:
[![Deploy to NuxtHub](https://hub.nuxt.com/button.svg)](https://hub.nuxt.com/new?template=ai-chat)
## Overview
This project is a chat interface to interact with various text generation models supported by [Cloudflare Workers AI](https://ai.cloudflare.com). 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](https://rajeev.dev/create-cloudflare-workers-ai-llm-playground-using-nuxthub-and-nuxtui).
## 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](https://nuxt.com): Vue.js framework for the application foundation
* [Nuxt UI](https://ui.nuxt.com): Module for creating a sleek and responsive interface
* [Nuxt MDC](https://github.com/nuxt-modules/mdc): For parsing and displaying chat messages
* [NuxtHub](https://hub.nuxt.com): Deployment and administration platform for Nuxt, powered by Cloudflare## Prerequisites
* [Cloudflare Account](https://cloudflare.com): Required for using Workers AI models and deploying the project on Cloudflare Pages
* [NuxtHub Account](https://hub.nuxt.com): 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](https://pnpm.io/):
```bash
pnpm i
```2. Rename `.env.example` to `.env` and update the following environment variables (for NuxtHub project key see point 3):
```bash
# 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
```3. 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)
```bash
npx nuxthub link
```4. Start the application in development mode
```bash
pnpm dev
```Open in your browser.
## Deployment
[![Deploy to NuxtHub](https://hub.nuxt.com/button.svg)](https://hub.nuxt.com/new?template=ai-chat)
### NuxtHub Admin
* Push your code to a GitHub repository.
* Link the repository with NuxtHub.
* Deploy from the Admin console.[Learn more about Git integration](https://hub.nuxt.com/docs/getting-started/deploy#cloudflare-pages-ci)
### Deploy via NuxtHub CLI```bash
npx nuxthub deploy
```[Learn more about CLI deployment](https://hub.nuxt.com/docs/getting-started/deploy#nuxthub-cli)
> [!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](./LICENSE) file for details.