pro-chat

pro-chat

๐Ÿค– Components Library for Quickly Building LLM Chat Interfaces.

Stars: 514

Visit
 screenshot

ProChat is a components library focused on quickly building large language model chat interfaces. It empowers developers to create rich, dynamic, and intuitive chat interfaces with features like automatic chat caching, streamlined conversations, message editing tools, auto-rendered Markdown, and programmatic controls. The tool also includes design evolution plans such as customized dialogue rendering, enhanced request parameters, personalized error handling, expanded documentation, and atomic component design.

README:

ProChat

Components Library for Quickly Building LLM Chat Interfaces.



English ยท ็ฎ€ไฝ“ไธญๆ–‡ ยท Changelog . Report Bug ยท Request Feature

Table of contents

TOC

๐Ÿ“ฆ Installation

[!IMPORTANT]

This package is ESM only.

To install @ant-design/pro-chat, run the following command:

$ pnpm install @ant-design/pro-chat

This project is based on antd antd-style, so if you have not installed these two dependencies, please install them.

$ pnpm install antd-style // peerDependencies
$ pnpm install antd // peerDependencies

Compile with Next.js

[!NOTE]

By work correct with Next.js SSR, add transpilePackages: ['@ant-design/pro-chat'] to next.config.js. For example:

const nextConfig = {
  transpilePackages: [
    '@ant-design/pro-chat',
    '@ant-design/pro-editor',
    'react-intersection-observer',
  ],
};

[!NOTE]

If you are using a new version of NextJs (higher than 14), you no longer need to configure transpilePackages to run in NextJs.


๐Ÿ”จ Usage

import { ProChat } from '@ant-design/pro-chat';

export default () => (
  <ProChat
    request={async (messages) => {
      // Send a request with Message as the parameter
      return Message; // Supports both streaming and non-streaming
    }}
  />
);

โœจ Features

[!NOTE]

ProChat focuses on quickly setting up a large language model chat dialogue framework. It aims to empower developers to easily create rich, dynamic, and intuitive chat interfaces.

Framework and Solutions for Chat Interface Components:

  • ๐Ÿ”„ Automatic Chat Caching: Maintains conversation continuity without any extra effort, ensuring a smooth user experience.
  • ๐Ÿ’ฌ Streamlined Conversations: Offers the choice between different conversation styles, catering to diverse user preferences.
  • โœ๏ธ Message Editing Features: Provides a suite of editing tools, including request redo, edit combination, and deletion, for precise conversation control.
  • ๐Ÿ“– Auto-rendered Markdown: Delivers a rich text experience that immerses users by transforming Markdown into beautifully formatted messages.
  • ๐ŸŽš๏ธ Programmatic Controls (Ref): Commands the chat flow with precision, allowing developers to create a tailored conversational experience.

Design Evolution / In Progress

  • [ ] Customized Dialogue Rendering with Edit Capabilities - issue/21
  • [ ] Enhanced Request Parameters - The power to infuse additional parameters into your requests is on the horizon
  • [ ] Personalized Error Handling - Craft unique fallbacks and configurations for those unexpected moments
  • [ ] Expanded Documentation & Globalization - Access comprehensive guides and international support for a truly borderless experience
  • [ ] Atomic Component Design - Anticipate a modular approach to design that promises both simplicity and versatility

๐Ÿ‘€ Showcase

Let's showcase some of ProChat's signature features:

Streamlined Dialogue Content Editor
Engage in Streamlined Conversations that flow as naturally as a river Refine, reshape, and perfect your dialogue with tools that allow for real-time edits.
Integrated Render
Dive into the vivid world of chat with our Built-in Render, a tool designed to bring text to life.

๐Ÿ–ฅ Browser compatibility

[!NOTE]

edge Edge chrome safari electron_48x48
Edge last 2 versions last 2 versions last 2 versions last 2 versions

โŒจ๏ธ Local Development

You can use Github Codespaces for online development:

Or clone it for local development:

$ git clone https://github.com/ant-design/pro-chat.git
$ cd pro-chat
$ pnpm install
$ pnpm dev

๐Ÿค Contributing

[!IMPORTANT]

Join our collaborative ecosystem. Your contributions are the heartbeat of our project. Here's how you can be an integral part of our vibrant community:

  • Integrate and Innovate: Incorporate Ant Design Pro, umi, and ProChat into your projects. Your real-world usage and feedback are invaluable to us.
  • Voice Your Insights: Encounter a glitch? Have a query? Your perspectives matter. Share them by submitting issues and help us enhance the user experience.
  • Shape the Future: Have code enhancements or feature ideas? We invite you to propose pull requests and contribute directly to the evolution of our codebase.

Every contribution, big or small, is celebrated. Join us in our mission to refine and elevate the world of open-source enterprise UI components. ๐Ÿ˜ƒ





๐Ÿ›ฃ๏ธ Ecosystem

  • ProComponents - Designed for Enterprise-Level Application, Use Ant Design like a Pro!.
  • ProEditor - The Ultimate Editor UI Framework and Components.
  • ProFlow - A Flow Editor Framework base on React-Flow.
  • ProChat - Components Library for Quickly Building LLM Chat Interfaces.


๐Ÿ“ License

Copyright ยฉ 2023 - present AFX & Ant Digital.
This project is MIT licensed.

For Tasks:

Click tags to check more tools for each tasks

For Jobs:

Alternative AI tools for pro-chat

Similar Open Source Tools

For similar tasks

For similar jobs