0.0.99 • Published 9 months ago
@hazelyu/react-chatgpt v0.0.99
react-chatgpt
Embedding your chatgpt agent into your react application, option in tailwindcss, from development to release, all in this react-chatgpt project.
Features
- Component library development starter: You can simply use this project as a starter for developing modern react + tailwindcss npm libraries. The project uses tailwindcss and effectively isolates the styles of the library, allowing it to be seamlessly used in both react or react + tailwindcss projects.
- Fancy and customizable UI: Elevate the appearance and experience of your agent by utilizing the tailwindcss framework, which can be easily customized to suit your preferences.
- Universal chatgpt agent: With its versatile design, you can create agents for any purpose by align with your api implementation.
- Keep context: Keep the full rounds of context.
- Infinite conversation: Start new conversation automatically when reach rate limit.
- Out of the box: Built in i18n support, built in disclaimer support, ready to use out of the box.
- Voice interaction: Supports voice input and output, and voice also supports multiple languages.
- Responsive: Optimized for various screen sizes and adapt automatically.
- Chart support: Chart support with Mermaid.
Quick start
vim ~/.npmrc
//npm.pkg.github.com/:_authToken=<Your Personal Access Token>
//@mystist:registry=https://npm.pkg.github.com/
yarn add @mystist/react-chatgpt
For react project:
import '@mystist/react-chatgpt/dist/style.css'
import { ReactChatGPT } from '@mystist/react-chatgpt'
For nextjs project:
import '@mystist/react-chatgpt/dist/style.css'
import dynamic from 'next/dynamic'
export const ReactChatGPT = dynamic(() => import('@mystist/react-chatgpt').then((module) => module.ReactChatGPT as any), { ssr: false })
Sample Agent component:
./components/Agent/index.tsx
import '@mystist/react-chatgpt/dist/style.css'
import dynamic from 'next/dynamic'
import { useState } from 'react'
export const ReactChatGPT = dynamic(() => import('@mystist/react-chatgpt').then((module) => module.ReactChatGPT as any), { ssr: false })
const DefaultAvatar = () => (
<span className="inline-block h-full w-full overflow-hidden rounded-full bg-gray-100">
<svg className="h-full w-full text-gray-300" fill="currentColor" viewBox="0 0 24 24">
<path d="M24 20.993V24H0v-2.996A14.977 14.977 0 0112.004 15c4.904 0 9.26 2.354 11.996 5.993zM16.002 8.999a4 4 0 11-8 0 4 4 0 018 0z" />
</svg>
</span>
)
export default function Index() {
const [status, setStatus] = useState('')
const identifier = '<your identifier>'
const lang = 'en'
return (
<>
<button onClick={() => setStatus('open')}>
<div className="relative h-16 w-16">
<DefaultAvatar />
<span className="absolute bottom-0 right-0 block h-3 w-3 rounded-full bg-green-400 ring-2 ring-white" />
</div>
</button>
{/* @ts-ignore */}
{identifier && <ReactChatGPT status={status} setStatus={setStatus} identifier={identifier} lang={lang} />}
</>
)
}
Options
status
: The React state represent the opening of the ReactChatGPT component.setStatus
: The React state set function controls the opening of the ReactChatGPT component.identifier
: To retrieve the specified data from the API endpoint with this identifier param.lang
: Specify the language, such as 'en' for English, 'zh' for Chinese, and 'ja' for Japanese.overlayMode
<'auto'(default) | 'modal' | 'slide-over'>: Specify the overlay mode. The default is 'auto', which will use 'modal' for large screens and 'slide-over' for smaller screens.
API dependencies
Checkout src/lib/requests/index.tsx
for the api dependencies.
Be aware that the Configuration api is the basic api to have react-chatgpt up and running:
api/configuration?identifier=<your identifier>&lang=<your lang>
It should return a Configuration object specs here: src/lib/interfaces/index.tsx
Development
yarn
yarn dev
Release
yarn release