Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yakGPT/yakGPT
Locally running, hands-free ChatGPT UI
https://github.com/yakGPT/yakGPT
Last synced: 3 months ago
JSON representation
Locally running, hands-free ChatGPT UI
- Host: GitHub
- URL: https://github.com/yakGPT/yakGPT
- Owner: yakGPT
- License: mit
- Created: 2023-03-30T14:44:17.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-05-08T23:58:37.000Z (9 months ago)
- Last Synced: 2024-10-16T06:21:59.701Z (3 months ago)
- Language: TypeScript
- Homepage: https://yakgpt.vercel.app
- Size: 15.9 MB
- Stars: 1,597
- Watchers: 16
- Forks: 259
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-privacy-front-ends - YakGPT - Locally running, hands-free ChatGPT UI. `TypeScript/MIT`. (List / ChatGPT)
- awesome-open-gpt - yakGPT
- awesome-chatgpt - yakGPT/yakGPT - Locally running, hands-free ChatGPT UI (UIs / Web applications)
- project-awesome - yakGPT/yakGPT - Locally running, hands-free ChatGPT UI (TypeScript)
- Awesome-ChatGPT - yakGPT
README
# YakGPT
A simple, locally running ChatGPT UI that makes your text generation faster and chatting even more engaging!
## Features
- **GPT 3.5 & GPT 4** via OpenAI API
- **Speech-to-Text** via Azure & OpenAI Whisper
- **Text-to-Speech** via Azure & Eleven Labs
- Run locally on browser – no need to install any applications
- Faster than the official UI – connect directly to the API
- Easy mic integration – no more typing!
- Use your own API key – ensure your data privacy and security
- Data submitted via the API is not used for training and stored for 30 days only
- All state stored locally in localStorage – no analytics or external service calls
- Access on https://yakgpt.vercel.app or run locally!> Note that GPT-4 API access is needed to use it. GPT 3.5 is enabled for all users.
## Screenshots
| Mobile | Voice Mode | Light Theme | Dark Theme |
| ---------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- |
| ![image](https://user-images.githubusercontent.com/129409586/229259007-ec4e0a27-cb5e-42fb-91b1-8e4efde99689.png) | ![image](https://user-images.githubusercontent.com/129409586/229259076-b29fe1e6-78a6-47c5-a330-fa34845a0e5f.png) | ![image](https://user-images.githubusercontent.com/129409586/229259145-0dd24f32-ea01-47f5-beab-68b80bfb1bb9.png) | ![image](https://user-images.githubusercontent.com/129409586/229259112-6e7223f8-d92d-49a7-9551-50276bf32089.png) |## 🚀 Getting Started
Visit [YakGPT](https://yakgpt.vercel.app) to try it out without installing, or follow these steps to run it locally:
### Prerequisites
You'll need the following tools installed on your computer to run YakGPT locally.
- [Git](https://git-scm.com/)
- [Yarn](https://yarnpkg.com/) (or npm or pnpm)
- Any modern web browser like Google Chrome, Mozilla Firefox, or Microsoft Edge### Installation
1. Clone the repository:
```
$ git clone https://github.com/yakGPT/YakGPT.git
```2. Install dependencies, build the bundle and run the server
```
$ yarn
$ yarn build
$ yarn start
```Then navigate to http://localhost:3000
Congratulations! 🎉 You are now running YakGPT locally on your machine.
## 🔑 API Key Configuration
To utilize YakGPT, you'll need to acquire an API key for OpenAI. The app should prompt you to insert you key.
### Add to .env.local(⚠️ Local use only)
If you want the keys to persist across app builds, you can add it to the .env.local.
```
$ echo "NEXT_PUBLIC_OPENAI_API_KEY=" > .env.local
$ echo "NEXT_PUBLIC_11LABS_API_KEY=" >> .env.local
```## 🐳 Docker
To use the pre-built Docker image from Docker Hub (only for amd64), run:
```
$ docker run -it -p 3000:3000 yakgpt/yakgpt:latest
```---
To build the Docker image yourself (such as if you're on arm64), run:
```
$ docker build -t yakgpt:latest .
$ docker run -it -p 3000:3000 yakgpt:latest
```## 🎤 Microphone Integration
YakGPT makes chatting a breeze with its microphone integration! Activate your microphone using your browser's permissions, and YakGPT will automatically convert your speech into text.
You can also toggle the mic integration as needed by clicking on the microphone icon in the app.
Remember to use a supported web browser and ensure your microphone is functioning properly.
## 🛡️ Data Privacy and Security
YakGPT ensures your data privacy and security by letting you use your own API key. Your conversation with YakGPT takes place directly between your browser and OpenAI's GPT-3 API, with no intermediary servers.
## 📃 License
This project is licensed under the MIT License - see the [`LICENSE`](LICENSE) file for details
## 🙌 Acknowledgments
- [OpenAI](https://openai.com/) for building such amazing models and making them cheap as chips.
- [Mantine UI](https://ui.mantine.dev/) just an all-around amazing UI library.
- [opus-media-recorder](https://github.com/kbumsik/opus-media-recorder) A real requirement for me was to be able to walk-and-talk. OpenAI's Whisper API is unable to accept the audio generated by Safari, and so I went back to wav recording which due to lack of compression makes things incredibly slow on mobile networks. `opus-media-recorder` saved my butt by allowing cross-platform compressed audio recording via web worker magic. 🤗Got feedback, questions or ideas? Feel free to submit an issue!