danswer/examples/widget/README.md

70 lines
1.9 KiB
Markdown
Raw Permalink Normal View History

# Danswer Chat Bot Widget
Note: The widget requires a Danswer API key, which is a paid (cloud/enterprise) feature.
2024-07-19 20:20:51 -07:00
This is a code example for how you can use Danswer's APIs to build a chat bot widget for a website! The main code to look at can be found in `src/app/widget/Widget.tsx`.
2024-07-19 20:12:03 -07:00
## Getting Started
To get the widget working on your webpage, follow these steps:
### 1. Install Dependencies
2024-07-19 20:12:03 -07:00
Ensure you have the necessary dependencies installed. From the `examples/widget/README.md` file:
2024-07-19 20:12:03 -07:00
```bash
2024-07-19 20:20:51 -07:00
npm i
2024-07-19 20:12:03 -07:00
```
### 2. Set Environment Variables
Make sure to set the environment variables `NEXT_PUBLIC_API_URL` and `NEXT_PUBLIC_API_KEY` in a `.env` file at the root of your project:
```bash
NEXT_PUBLIC_API_URL=
NEXT_PUBLIC_API_KEY=
```
### 3. Run the Development Server
Start the development server to see the widget in action.
2024-07-19 20:12:03 -07:00
2024-07-19 20:20:51 -07:00
```bash
npm run dev
```
2024-07-19 20:12:03 -07:00
2024-07-19 20:20:51 -07:00
Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
### 4. Integrate the Widget
To integrate the widget into your webpage, you can use the `ChatWidget` component. Heres an example of how to include it in a page component:
```jsx
import ChatWidget from 'path/to/ChatWidget';
function MyPage() {
return (
<div>
<h1>My Webpage</h1>
<ChatWidget />
</div>
);
}
export default MyPage;
```
### 5. Deploy
Once you are satisfied with the widget, you can build and start the application for production:
```bash
npm run build
npm run start
```
### Custom Styling and Configuration
If you need to customize the widget, you can modify the `ChatWidget` component in the `examples/widget/src/app/widget/Widget.tsx` file.
By following these steps, you should be able to get the chat widget working on your webpage.
If you want to get fancier, then take a peek at the Chat implementation within Danswer itself [here](https://github.com/danswer-ai/danswer/blob/main/web/src/app/chat/ChatPage.tsx#L82).