Skip to content

Latest commit

Β 

History

History
159 lines (114 loc) Β· 4.64 KB

README.md

File metadata and controls

159 lines (114 loc) Β· 4.64 KB

πŸ€– LLM Playground πŸš€βœ¨

A powerful and interactive experimental platform for experimenting with large language models, built based on Next.js 14 and modern web technologies.

δΈ­ζ–‡ | English | ζ—₯本θͺž

η•Œι’ι’„θ§ˆ

Interface Preview

Generate results based on user input, supporting Latex expression rendering. Expert Mode Features

Images can be uploaded as context for dialogue. Expert Mode Features

Support chart rendering. Expert Mode Features

The OpenAI model has the function of displaying token probabilities. It can obtain the probability of the currently selected token and provide multiple alternative tokens as well as their probabilities. Expert Mode Features

✨ Key Features ✨

  1. Interactive Chat Interface

    • Real-time markdown editing and preview
    • Role-based conversations
    • Users can upload images for conversation.
    • Under the OpenAI model, token probabilities can be displayed.
    • Advanced message manipulation: reorder, copy, regenerate
    • Expert Mode: enhanced editing and role controls
    • Feedback and animations for seamless UX
    • Model configuration and AI parameter tuning
    • Responsive and accessible design
  2. Rich Text Editor

    • Advanced markdown with GitHub Flavored support
    • KaTeX for LaTeX expressions
    • Mermaid for diagram rendering
    • Persistent content and live rendering
  3. Modern User Experience

    • Customizable and responsive UI
    • Animations, notifications, and error handling
    • Mobile-friendly with accessible components
  4. Advanced Features

    • IndexedDB persistence, multiple language support
    • API integration and message history management
    • Advanced logging and optimized API handling
    • Internationalization and dynamic translations

Tech Stack πŸ› οΈ

  • Framework: Next.js 14
  • Languages: TypeScript
  • Styling: Tailwind CSS, Radix UI
  • State Management: Jotai
  • Data Storage: IndexedDB with Dexie.js
  • Internationalization: next-intl

Project Structure πŸ“

src/
β”œβ”€β”€ actions/
β”œβ”€β”€ app/
β”œβ”€β”€ components/
β”‚   β”œβ”€β”€ playground/
β”‚   └── ui/
β”œβ”€β”€ constants/
β”œβ”€β”€ db/
β”œβ”€β”€ hooks/
β”œβ”€β”€ i18n/
β”œβ”€β”€ stores/
β”œβ”€β”€ styles/
└── utils/

Getting Started πŸš€

Prerequisites

  • Node.js (LTS version)
  • pnpm or npm
  • 302.AI API Key

Installation

  1. Clone the repository:

    git clone https://github.com/302ai/302_llm_playground
    cd 302_llm_playground
  2. Install dependencies:

    pnpm install
  3. Configure environment variables:

    cp .env.example .env.local
    • AI_302_API_KEY: Your 302.AI API key
    • AI_302_API_URL: API endpoint

Development

Start the development server:

pnpm dev

Visit http://localhost:3000 to see the application.

Production Build

pnpm build
pnpm start

Docker Deployment 🐳

Build and run using Docker:

docker build -t llm_playground .
docker run -p 3000:3000 llm_playground

Contributing 🀝

Contributions are welcome! Please feel free to submit issues and pull requests.

License πŸ“œ

This project is licensed under the GNU Affero General Public License v3.0. See the LICENSE file for more details.


Built with ❀️ using Next.js and 302.AI

✨ About 302.AI ✨

302.AI is an enterprise-oriented AI application platform that offers pay-as-you-go services, ready-to-use solutions, and an open-source ecosystem.✨

  1. 🧠 Comprehensive AI capabilities: Incorporates the latest in language, image, audio, and video models from leading AI brands.
  2. πŸš€ Advanced application development: We build genuine AI products, not just simple chatbots.
  3. πŸ’° No monthly fees: All features are pay-per-use, fully accessible, ensuring low entry barriers with high potential.
  4. πŸ› οΈ Powerful admin dashboard: Designed for teams and SMEs - managed by one, used by many.
  5. πŸ”— API access for all AI features: All tools are open-source and customizable (in progress).
  6. πŸ’‘ Powerful development team: Launching 2-3 new applications weekly with daily product updates. Interested developers are welcome to contact us.