Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/maxinexiong/openai-api-web-apps

This repository hosts a collection of custom web applications powered by OpenAI's GPT models (incl. o1 models, gpt-4o, gpt-4o-mini and gpt-4-turbo), Whisper model, and TTS model. These apps include an interactive chatbot ("Talk to GPT") for text or voice communication, and a coding assistant ("CodeMaxGPT") that supports various coding tasks.
https://github.com/maxinexiong/openai-api-web-apps

ai-project assistants-api chat-completion-api chatbot chatgpt code-generation gpt-4-turbo gpt-4o gpt-4o-mini o1-mini o1-preview openai openai-api openai-api-chatbot openai-assistants openai-assistants-api openai-whisper python streamlit streamlit-cloud

Last synced: 20 days ago
JSON representation

This repository hosts a collection of custom web applications powered by OpenAI's GPT models (incl. o1 models, gpt-4o, gpt-4o-mini and gpt-4-turbo), Whisper model, and TTS model. These apps include an interactive chatbot ("Talk to GPT") for text or voice communication, and a coding assistant ("CodeMaxGPT") that supports various coding tasks.

Awesome Lists containing this project

README

        

# OpenAI API Web Applications

[![GitHub](https://badgen.net/badge/icon/GitHub?icon=github&color=black&label)](https://github.com/MaxineXiong)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Made with Python](https://img.shields.io/badge/Python->=3.6-blue?logo=python&logoColor=white)](https://www.python.org)
[![OpenAI API](https://img.shields.io/badge/OpenAI_API-E5E4E2?logo=OpenAI&logoColor=%23000000)](https://openai.com/blog/openai-api)
[![ChatGPT](https://img.shields.io/badge/ChatGPT-00A67E?logo=openai)](https://chat.openai.com/)


Click the badge below to access the web applications:

[![Open in Streamlit](https://static.streamlit.io/badges/streamlit_badge_black_white.svg)](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/)


## Table of Contents
- [Project Description](#project-description)
- [Talk to GPT](#talk-to-gpt)
- [CodeMaxGPT](#codemaxgpt)
- [Features](#features)
- [Repository Structure](#repository-structure)
- [Usage](#usage)
- [Get Started with Talk to GPT](#get-started-with-talk-to-gpt)
- [Get Started with CodeMaxGPT](#get-started-with-codemaxgpt)
- [Contribution](#contribution)
- [License](#license)
- [Acknowledgement](#acknowledgement)


## Project Description

Welcome to the **[unofficial platform for custom web applications powered by OpenAI APIs](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/)**! This repository hosts
a collection of web applications deployed on *[Streamlit Cloud](https://streamlit.io/cloud)*. These applications leverage the capabilities of OpenAI's powerful language models to provide
unique functionalities. Currently, the platform includes two web applications:

### Talk to GPT
[![Open in Streamlit](https://static.streamlit.io/badges/streamlit_badge_black_white.svg)](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/Talk_To_GPT)

The first web application, **[Talk to GPT](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/Talk_To_GPT)**, is an interactive chatbot application that allows users to
communicate with the model using text messages or speech input. Developed using OpenAI's [**Chat Completions API**](https://platform.openai.com/docs/guides/text-generation/chat-completions-api), and powered by OpenAI's [***GPT models***](https://platform.openai.com/docs/models/overview) (incl. [***o1-mini***](https://platform.openai.com/docs/models#o1), [***o1-preview***](https://platform.openai.com/docs/models#o1), [***gpt-4o***](https://platform.openai.com/docs/models#gpt-4o), [***gpt-4o-mini***](https://platform.openai.com/docs/models#gpt-4o-mini), and [***gpt-4-turbo***](https://platform.openai.com/docs/models#gpt-4-turbo-and-gpt-4))
for generating high-quality responses, [***Whisper model***](https://platform.openai.com/docs/models/whisper) for speech-to-text conversion, and [***TTS model***](https://platform.openai.com/docs/models/tts) for text-to-speech audio output, this application offers a conversational experience similar to interacting with a human expert. Users can select between the ***GPT-4o***, ***GPT-4o mini***, ***o1-mini***, ***o1-preview***, and ***GPT-4 Turbo*** models based on their needs, and have the option to play the bot's responses in audio format, enhancing
the conversational experience with a greater sense of immersion and realism. Additionally, the application provides a variety of built-in prompts that assign roles or personas to the chatbot,
providing an effective starting point for each type of conversation, and ensuring that the chatbot will produce the desired responses in an efficient and appropriate manner.

### CodeMaxGPT
[![Open in Streamlit](https://static.streamlit.io/badges/streamlit_badge_black_white.svg)](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/CodeMaxGPT)

The second web application, **[CodeMaxGPT](https://maxinexiong.github.io/intro-codemaxgpt.html)**, is designed to provide coding assistance to programmers. Built on OpenAI's [**Assistants API**](https://platform.openai.com/docs/assistants/overview?context=with-streaming),
it is specifically tuned and optimized to cater to the diverse needs of developers, including code generation, debugging, refactoring, and documentation. The platform allows users to choose between the ***GPT-4o***, ***GPT-4o mini***, ***o1-mini***, ***o1-preview***, and ***GPT-4 Turbo*** models, providing auto-prompts
for the GPT model based on various use cases that a user may select. It also features a more user-friendly interface compared to the original [ChatGPT](https://openai.com/blog/chatgpt), allowing users to comfortably enter or
paste code and even upload code scripts directly from their local computer. With its user-friendly interface, advanced auto-prompting features, and seamless code uploading capabilities,
**CodeMaxGPT** is the ultimate coding companion. Whether you're a junior developer tackling complex programs or a seasoned pro exploring
new programming languages or frameworks, **CodeMaxGPT** has you covered.


## Features

**[Talk to GPT](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/Talk_To_GPT)** provides the following features:

1) Constructed using with OpenAI's **Chat Completions API**, enables the selection of either the ***GPT-4o***, ***GPT-4o mini***, ***o1-mini***, ***o1-preview***, or ***GPT-4 Turbo*** model to **generate high-quality human-like responses** to user’s prompts.

2) Enables communication with the GPT model through either **text messages** or **speech input**.

3) Utilizes OpenAI's ***Whisper*** model for accurate **speech-to-text conversion** for user’s speech input, and ***TTS*** (**text-to-speech**) model for chatbot's audio response output.

4) Provides an option to **play the bot’s responses in audio format** for an immersive and realistic conversational experience.

5) Offers a variety of **built-in prompts** that assign roles or personas to the chatbot, provides an effective starting point for each type of conversations, and ensures that the chatbot will produce the desired responses in an efficient manner.

Below are the features offered by **[CodeMaxGPT](https://maxinexiong.github.io/intro-codemaxgpt.html)**:

1) Enables the selection of either the ***GPT-4o***, ***GPT-4o mini***, ***o1-mini***, ***o1-preview***, or ***GPT-4 Turbo*** model to **generate high-quality human-like responses** to user’s prompts.

2) Built upon OpenAI's **Assistants API**, **specifically tuned and optimized** to provide coding assistance to programmers of all levels.

3) Supports **various coding tasks**, including code generation, debugging, refactoring, adding comments, code reviewing, generating GitHub README, and suggesting solutions to coding challenges.

4) Provides **auto-prompts** for the GPT model tailored to the various coding tasks that users may need help with.

5) Offers a **user-friendly interface** that surpasses the original ChatGPT.

6) Allows **comfortable code entry and pasting**, and **direct uploading of code scripts** from the user’s local computer, for enhanced convenience.

7) Enables users to code confidently in unfamiliar territory.


## Repository Structure

The repository structure of the project is as follows:
```
OpenAI-API-Web-Apps/
├── .streamlit/
│ └── config.toml
├── assets/
│ ├── ChatGPT-Tkinter-Desktop-App.exe
│ └── cover-page.gif
├── pages/
│ ├── 2_Talk_To_GPT.py
│ └── 3_CodeMaxGPT.py
├── Home.py
├── packages.txt
├── requirements.txt
├── .gitignore
├── README.md
└── LICENSE
```
The description of each file and folder in the repository is as follows:

* **.streamlit/**: This folder contains the **config.toml** file, which configures the appearance of the Streamlit web application. The **config.toml** file specifies the theme settings such as primary color, background color, text color, and font.
* **assets/**: This folder contains additional assets used in the project, including the **cover-page.gif** image file for the cover page. It also includes the **ChatGPT-Tkinter-Desktop-App.exe**, which is a simplified desktop version of **Talk to GPT**. You can find the source code for the desktop application in the [ChatGPT-Tkinter-Desktop-App](https://github.com/MaxineXiong/ChatGPT-Tkinter-Desktop-App.git) repository.
* **pages/**: This folder contains the Python code that powers the three web applications. It includes the following Python scripts:
- **2_Talk_To_GPT.py**: Python script for the **Talk to GPT** web application.
- **3_CodeMaxGPT.py**: Python script for the **CodeMaxGPT** web application.
* **Home.py**: This is a Python script for the home page of the Streamlit web applications. It contains code related to the navigation between the three web applications.
* **packages.txt**: The file manages the project dependencies and is necessary for deploying the web applications on _Streamlit Cloud_.
* **requirements.txt**: This file lists all the required Python modules and packages. It is also necessary for the deployment of the web applications on _Streamlit Cloud_. It ensures that the required dependencies are installed when deploying the applications.
* **.gitignore**: This file intentionally specifies untracked files that Git should ignore.
* **README.md**: Provides an overview of this repository.
* **LICENSE**: The license file for the project.


## **Usage**

The web applications are currently hosted on *Streamlit Cloud*. To access the applications, please visit [**OpenAI API Web Applications on Streamlit**](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/). Once you visit the URL, you will be presented with a home page where you can select the desired web application. Click on the application you want to use, and it will open in a new tab or window.

### **Get Started with Talk to GPT**

To use the **Talk to GPT** application, follow these steps:

1. Visit the [**Talk to GPT on Streamlit**](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/Talk_To_GPT).
2. Select your desired GPT model.
3. Input your [OpenAI API key](https://platform.openai.com/api-keys) in the field at the top.
4. You can start interacting with the chatbot using either the "MESSAGE BOT" or "TALK TO BOT" options.
5. For text input, click on the "MESSAGE BOT" expander, select a built-in prompt from the dropdown menu, and press CTRL + Enter to submit. The chatbot will respond with a generated message. You can continue the conversation by entering your own messages.
6. For speech input, make sure the text message input field is cleared, then click on the "TALK TO BOT" expander, click on the microphone icon, and speak your message. The speech input will be converted to text, and the chatbot will respond accordingly.

Below are two GIF images that demonstrate the usage of the **Talk to GPT** application:




Interacting through text messages

###




Interacting through speech input

###

You can also view the full demo video of the **Talk to GPT** application by clicking on the badge below.

[![Watch Demo - Talk to GPT](https://img.shields.io/badge/Watch_Demo-Talk_to_GPT-6699FF)](https://1drv.ms/v/s!AhxVr7ogXVBRlS_l5uFoOAseoO7t)


### **Get Started with CodeMaxGPT**

To use the **CodeMaxGPT** application, follow these steps:

1. Visit the [**Introducing CodeMaxGPT**](https://maxinexiong.github.io/intro-codemaxgpt.html) webpage.
2. Click on the "Get started now" button, and you'll be directed to the [**CodeMaxGPT on Streamlit**](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/CodeMaxGPT).
3. Select your desired GPT model (*o1-mini* is **recommended**).
4. Input your [OpenAI API key](https://platform.openai.com/api-keys) in the field at the top.
5. You can now start interacting with the coding assistant by entering your text message or selecting a request from the dropdown menu. Then, enter, paste, or upload your code as needed.
6. The coding assistant will provide suggestions, completions, and other assistance based on the request prompt you select and the code you provide.
7. Feel free to explore the other features of **CodeMaxGPT** to assist you in your coding tasks.

For a detailed demonstration of using **CodeMaxGPT**, please visit the [**introduction page**](https://maxinexiong.github.io/intro-codemaxgpt.html) of the web application, or click on the badge below.

[![Watch Demos - CodeMaxGPT](https://img.shields.io/badge/Watch_Demos-CodeMaxGPT-6699FF)](https://maxinexiong.github.io/intro-codemaxgpt.html)


## **Contribution**

Contributions are welcome! If you would like to contribute to the development of these web applications, please follow these steps:

1. Fork the repository.
2. Create a new branch for your feature or bug fix.
3. Make your changes and commit them.
4. Push your changes to your forked repository.
5. Submit a pull request detailing your changes.

Please ensure that your contributions align with the project's coding conventions and standards. Your efforts are greatly appreciated!


## **License**

This project is licensed under the [MIT License](https://choosealicense.com/licenses/mit/). Feel free to modify and use the code for your own purposes. However, please note that OpenAI's usage policies and guidelines still apply when using the OpenAI API.


## **Acknowledgement**

I would like to acknowledge the following organizations and technologies for their contributions to this project:

- [OpenAI](https://openai.com/) for developing the powerful language models and APIs, which have enabled me to create these web applications.
- [Streamlit](https://streamlit.io/) for providing a wide range of widgets and *Streamlit Cloud*, which is a platform that allows me to deploy these web applications easily and efficiently.
- [Python](https://www.python.org/) for providing a powerful programming language that has been instrumental in the development of these applications.
- [GitHub](https://github.com/) for hosting this repository and providing a collaborative platform for open-source development.


Thank you for choosing to use the [**OpenAI API Web Apps**](https://maxinexiong-openai-api-web-apps-home-xbxlm8.streamlit.app/). I hope that these applications will greatly amplify your programming capabilities and boost your efficiency, both in your work and in your everyday life.