NOTE: Please note that proper utilization through code build is available starting from the "AI Chatbot Pro" plan or higher of the Sendbird AI Chatbot pricing plan.
What is this for?
This is a Sendbird Chat AI Widget implemented on top of React UiKit.
![chat-ai-widget](https://github.com/sendbird/chat-ai-widget/assets/104121286/360d2a17-dfc6-4810-a7c4-2f0615b43c3d)
How to use
-
Prepare Sendbird Application ID and Bot ID
If you need the Sendbird Application ID and Bot ID, See How to get Application ID and Bot ID
-
Install Library
npm install @sendbird/chat-ai-widget
-
Add import ...
and <ChatAiWidget/>
Component to your Code.
import { ChatAiWidget } from "@sendbird/chat-ai-widget";
import "@sendbird/chat-ai-widget/dist/style.css";
const App = () => {
return (
<ChatAiWidget
applicationId="AE8F7EEA-4555-4F86-AD8B-5E0BD86BFE67" // Your Sendbird Application ID
botId="khan-academy-bot" // Your Bot ID
/>
);
}
Not using React in your environment? You can also load this Chat AI Widget component from an HTML file on your website. Please refer to js-example.html for an example.
<script crossorigin src="https://unpkg.com/react@18.2.0/umd/react.development.js"></script>
<script crossorigin src="https://unpkg.com/react-dom@18.2.0/umd/react-dom.development.js"></script>
<script>process = { env: { NODE_ENV: '' } }</script>
<script
crossorigin
src="https://unpkg.com/@sendbird/chat-ai-widget@latest/dist/index.umd.js"
></script>
<link href="https://unpkg.com/@sendbird/chat-ai-widget@latest/dist/style.css" rel="stylesheet" />
<script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>
...
<div id="root"></div>
<script type="text/babel">
const { ChatAiWidget } = window.ChatAiWidget
const App = () => {
return (
<ChatAiWidget
applicationId="AE8F7EEA-4555-4F86-AD8B-5E0BD86BFE67"
botId="khan-academy-bot"
/>
)
}
ReactDOM.createRoot(document.querySelector('#root')).render(<div><App/></div>);
</script>
Run locally
npm run install:deps
npm run dev
Demo URL
https://sendbird.github.io/chat-ai-widget/
How to get Application ID and Bot ID
Prerequisites
- Sendbird Account: Go to Sendbird Dashboard and create an account for a free trial. If you already have a Sendbird account, sign into your account.
- Create a Application:
- Create a new application by clicking Create + at the bottom right of your screen.
- Enter a name for your application. Choose a Product Type and Region. Then, click Confirm.
- Click the application you just created under Applications. You will see the application's Application ID which you will need when initializing the Chat SDK.
- Knowledge Base Source: Prepare data for AI ChatBot to reference in
PDF
or txt
format and URL
. This data will serve as the Knowledge Base Source that AI Chatbot will use to generate responses.
1. Navigate to Your Sendbird Application
- Navigate to the application you created on the Sendbird Dashboard.
- In the dashboard, navigate to the Chat menu and click on AI Chatbot under it.
![image](https://github.com/sf-luke-cha/ai-chatbot-tutorial/assets/104121286/e7d00cf0-fcf0-440b-8506-b46c077fff0d)
2. Set Up Your AI Chatbot
-
Click on the Create Bot button to set up a new AI chatbot.
-
In the Bot Name field, enter Bot Name you want, and make sure to select a unique Bot ID(will be used to invite Bot when creating a new Chat Room).
-
For the Bot AI Engine, select OpenAI ChatGPT for this time.
-
Specify the Knowledge Base Source. There are three options:
-
None: This uses the basic OpenAI Model, and you can adjust the specific parameters to suit your needs.
-
File: In this option, you can select a PDF or txt file as the Knowledge Base Source.
-
URL: In this option, the contents of a specified URL will be automatically analyzed and used as the Knowledge Base Source.
-
Click on the Create button to create your AI Chatbot.
3. Testing Your AI Chatbot
After your chatbot has been created, you can start testing conversations directly from the web interface.
![image](https://github.com/sf-luke-cha/ai-chatbot-tutorial/assets/104121286/f1d39df3-b50a-4c6d-a419-ef4bca5dcb87)
Basic Customization
You can customize the UI of the ChatBot by using the ChatAiWidget
component. The following are the props that can be used to customize the UI.
import { ChatAiWidget } from "@sendbird/chat-ai-widget";
import '@sendbird/chat-ai-widget/dist/style.css';
const customConstants = {
applicationId: 'AE8F7EEA-4555-4F86-AD8B-5E0BD86BFE67',
botId: 'khan-academy-bot',
botNickName: 'Khan Academy Support Bot',
userNickName: 'User',
betaMark: false,
suggestedMessageContent: {
replyContents: [
{
title: 'Yes, it was helpful! 👍',
text: 'Thanks for your feedback! You can also build your own AI chatbot in Sendbird.',
buttonText: 'Try free trial',
link: 'https://dashboard.sendbird.com/auth/signup',
},
{
title: 'No, I need more help. 💬',
text: "I'm sorry, we couldn't help you. Let us know how we can improve by talking to one of our teammates.",
buttonText: 'Talk to an expert',
link: 'https://sendbird.com/contact-sales',
},
],
messageFilterList: [
'Can you please clarify?',
'How can I assist you',
'How can I help you',
'Can you clarify',
"That's not a question I can answer unfortunately",
'Try again',
"I couldn't find the answer to your question",
'Can you try again?',
'I apologize for any confusion',
"I'm sorry, I couldn't understand your question",
"That's not a valid question",
'Is there a specific question you have',
"I'm here to help you with any questions you have",
],
},
firstMessageData: [
{
data: [
{
suggested_replies: [
'What can I learn from Pre-K 8th grade?',
'Tell me about Math',
],
},
],
message: "Hi~ I'm Khan Academy Support ChatBot. Ask me anything!",
},
],
createGroupChannelParams: {
name: 'Khan Academy Support Bot',
coverUrl:
'https://images.unsplash.com/photo-1526304640581-d334cdbbf45e?ix' +
'lib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2070&q=80',
},
chatBottomContent: {
text: 'Sendbird AI ChatBot',
backgroundColor:
'linear-gradient(273.73deg, #4DCD90 -0.83%, #6210CC 48.04%, #6210CC 75.45%)',
},
messageBottomContent: {
text: 'AI-generated response powered by OpenAI',
infoIconText:
'This response is generated by AI and may lack complete accuracy.'
},
replacementTextList: [['the Text extracts', 'ChatBot Knowledge Base']],
enableSourceMessage: false,
enableEmojiFeedback: true,
enableMention: true,
enableMobileView: true,
autoOpen: false,
};
const App = () => {
return (
<ChatAiWidget
applicationId={customConstants.applicationId}
botId={customConstants.botId}
botNickName={customConstants.botNickName}
userNickName={customConstants.userNickName}
betaMark={customConstants.betaMark}
customBetaMarkText={customConstants.customBetaMarkText}
suggestedMessageContent={customConstants.suggestedMessageContent}
firstMessageData={customConstants.firstMessageData}
createGroupChannelParams={customConstants.createGroupChannelParams}
chatBottomContent={customConstants.chatBottomContent}
messageBottomContent={customConstants.messageBottomContent}
replacementTextList={customConstants.replacementTextList}
enableSourceMessage={customConstants.enableSourceMessage}
enableEmojiFeedback={customConstants.enableEmojiFeedback}
enableMention={customConstants.enableMention}
enableMobileView={customConstants.enableMobileView}
/>
);
};
export default App;
Advanced Customization
import { ChatAiWidget } from "@sendbird/chat-ai-widget";
import '@sendbird/chat-ai-widget/dist/style.css';
import { SessionHandler } from '@sendbird/chat'
const USER_ID = 'UserId';
const issueSessionToken = async (userId, ...) => {
};
const memoizedConfigureSession = useCallback(
(sdk) => {
const sessionHandler = new SessionHandler();
sessionHandler.onSessionTokenRequired = (resolve, reject) => {
console.warn('SessionHandler.onSessionTokenRequired()');
issueSessionToken(USER_ID)
.then(token => {
resolve(token);
})
.catch(err => reject(err));
};
sessionHandler.onSessionRefreshed = () => {
console.warn('SessionHandler.onSessionRefreshed()');
};
sessionHandler.onSessionError = (err) => {
console.warn('SessionHandler.onSessionError()', err);
};
sessionHandler.onSessionClosed = () => {
console.warn('SessionHandler.onSessionClosed()');
};
console.warn(sessionHandler);
return sessionHandler;
},[]);
const customConfigs = {
instantConnect: true / false,
autoOpen: true / false,
configureSession: memoizedConfigureSession,
stringSet: {{
MESSAGE_INPUT__PLACE_HOLDER: 'Type a message',
}}
customRefreshComponent: {
icon: 'Your SVG icon',
style: {
position: 'relative' as React.CSSProperties['position'],
right: 0,
},
width: '16px',
height: '16px',
onClick: () => { ... },
}
}
const customConstants = {
}
const App = () => {
return (
<ChatAiWidget
/**
* userId & configureSession should be used together to create a group channel on the client side.
*/
userId={USER_ID}
configureSession={customConfigs.configureSession}
stringSet={customConfigs.stringSet}
customRefreshComponent={customConfigs.customRefreshComponent}
instantConnect={customConfigs.instantConnect}
autoOpen={customConfigs.autoOpen}
{...customConstants}
/>
);
};
export default App;