Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ojasskapre/nextjs-starter-template
A starter template for building Next.js applications with Supabase for authentication, TypeScript, and Tailwind CSS. Includes branches for creating Langchain and LLM chat interfaces and integrating Stripe subscription payments, making it ideal for setting up modern, scalable web apps with robust auth, AI-driven features, and payment processing.
https://github.com/ojasskapre/nextjs-starter-template
langchain langchain-js nextjs stripe supabase tailwindcss typescript
Last synced: 2 months ago
JSON representation
A starter template for building Next.js applications with Supabase for authentication, TypeScript, and Tailwind CSS. Includes branches for creating Langchain and LLM chat interfaces and integrating Stripe subscription payments, making it ideal for setting up modern, scalable web apps with robust auth, AI-driven features, and payment processing.
- Host: GitHub
- URL: https://github.com/ojasskapre/nextjs-starter-template
- Owner: ojasskapre
- Created: 2024-08-03T18:25:30.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-08-29T19:23:02.000Z (5 months ago)
- Last Synced: 2024-11-01T18:51:38.756Z (3 months ago)
- Topics: langchain, langchain-js, nextjs, stripe, supabase, tailwindcss, typescript
- Language: TypeScript
- Homepage:
- Size: 813 KB
- Stars: 11
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Next.js + Supabase Auth + Langchain starter code
## Overview
This project is a chatbot application built using Next.js, TypeScript, Supabase, Langchain, and FastAPI. The frontend is responsible for the user interface and handles user interactions, while the backend, powered by FastAPI + SQLAlchemy, processes chat messages using OpenAI's GPT-3.5 model and manages API endpoints. The application includes user authentication via Supabase, allowing users to sign up, log in, and manage their sessions. This architecture ensures a clear separation of concerns, with the backend handling all AI-related logic and the frontend focused on delivering a seamless user experience.
## Features
- **Real-time Chat**: Users can send messages and receive responses from the AI in real-time.
- **User Authentication**: Sign up and log in functionality using Supabase.
- **Stop Answer Streaming**: Allow users to stop the streaming of the AI's response mid-answer.
- **Create New Chat**: Enable users to start a new chat session.
- **Save Chat History**: Save the chat history for users to access later.
- **Access Previous Chats**: Allow users to go back to any previous chat and continue the conversation.
- **Markdown Support**: Messages can include Markdown formatting, including LaTeX for mathematical expressions.
- **Backend API**: FastAPI backend to handle chat processing and interactions with OpenAI's GPT-3.5 model.## Technologies Used
- **Next.js**: A React framework for building server-side rendered applications.
- **TypeScript**: A superset of JavaScript that adds static types.
- **Langchain**: A framework for building applications with language models.
- **Supabase**: An open-source Firebase alternative for authentication and database management.
- **React**: A JavaScript library for building user interfaces.
- **Tailwind CSS**: A utility-first CSS framework for styling.
- **Shadcn**: A component library for creating accessible and consistent UI components.
- **FastAPI**: A modern, fast (high-performance) web framework for building APIs with Python 3.11+## Getting Started
### Prerequisites
- Node.js (version 18 or later)
- npm or yarn
- A Supabase account
- An OpenAI account
- Python 3.11 or later
- Poetry (for managing Python dependencies)### Installation
##### Frontend
1. Clone the repository:
```bash
git clone https://github.com/ojasskapre/nextjs-starter-template.git
cd nextjs-starter-template/frontend
```2. Install dependencies:
```bash
npm install
```or
```bash
yarn install
```3. Set up your Supabase project:
- Create a new project on [Supabase](https://supabase.io/).
- Set up authentication and database tables as per your requirements.
- Obtain your Supabase URL and API key.4. Set up your OpenAI API key:
- Sign up or log in to [OpenAI](https://openai.com/).
- Create an API key from the API section of your account.5. Create a `.env.local` file in the root of the project and add your Supabase and OpenAI credentials:
```plaintext
NEXT_PUBLIC_SUPABASE_URL=your_supabase_url
NEXT_PUBLIC_SUPABASE_ANON_KEY=your_supabase_anon_key
OPENAI_API_KEY=your_openai_api_key
```6. Start the development server:
```bash
npm run dev
```or
```bash
yarn dev
```7. Open your browser and navigate to `http://localhost:3000`.
#### Backend
1. Navigate to backend folder
```bash
cd ../backend
```2. Install Poetry if you haven't already:
```bash
curl -sSL https://install.python-poetry.org | python3 -
```3. Install the backend dependencies:
```bash
poetry install
```4. Set up environment variables
- Create a .env file in the backend directory with your configuration:
```bash
OPENAI_API_KEY=your_openai_api_key
DATABASE_URL=your_database_url
SUPABASE_URL=your-project-url
SUPABASE_ANON_KEY=your-anon-key
```5. Run the FastAPI server
```bash
poetry run uvicorn app.main:app --reload
```6. The FastAPI server will be running at `http://127.0.0.1:8000`.
#### Running the Application using Docker Compose
1. Make sure you have Docker and Docker Compose installed on your system.
2. Ensure that you have set up the environment variables in the `.env` file in the `frontend` and `backend` directory.
3. Run the following command to start the application:```bash
docker compose up --build
```4. The application will be running at `http://localhost:3000`.
5. The FastAPI server will be running at `http://localhost:8000`.
6. Remember to stop the containers using `docker compose down` when you are done.#### Alternative Setup (Not using FastAPI)
Instead of using FastAPI to handle and respond to chat queries, you can opt to handle everything directly in the Next.js frontend by leveraging `langchain.js`, `@langchain/openai`. This approach simplifies the architecture by keeping everything within the frontend, which can be useful for specific use cases.
Steps to implement:
1. Create the API Route in Next.js
Navigate to the `@/app/api/chat/` directory and create a new file named `route.ts`.
```bash
cd frontend/app/api/chat
```2. Copy the contents from [@/example/chat.route.ts](https://github.com/ojasskapre/nextjs-starter-template/blob/main/frontend/src/example/chat.route.ts) to the newly created `route.ts` file.
3. Update the api parameter in `useChat()` in [@/components/chat/Section.tsx](https://github.com/ojasskapre/nextjs-starter-template/blob/main/frontend/src/components/chat/Section.tsx) from `${backendUrl}/api/chat` to `/api/chat`
4. Follow the frontend installation steps and start the application
## To-Do Features Checklist
- [ ] **Regenerate Answer**: Allow users to regenerate the AI's response.
- [ ] **Add Attachments**: Allow users to add attachments to their messages.