Copilot widget
Embed the Copilot in your app
Learn how to embed the copilot in your app
the chat widget enables you to interact with the Copilot from your dashboard and see the changes in realtime. OpenCopilot is a react web app that you can embed in your web app.
there are several ways you can integrate the Copilot Chat widget into your application/webpage
Using simple js script
-
by using CDN script into your html file.
<script src="https://unpkg.com/@openchatai/widget@latest/dist-embed/pilot.js"></script>
this will automatically register a new function called
initAiCoPilot
on the global window object. -
Init the copilot (when document fully loads) by calling the
initAiCoPilot
function and passing the required options. There are plenty of options that you can pass to the copilot, you can find them here<script> const options = { apiUrl: "https://api.opencopilot.so/backend" socketUrl: "https://api.opencopilot.so" initialMessage: "Hey! happy to help.", token: "your_copilot_token_goes_here", // you can get your token from the dashboard triggerSelector: "#triggerSelector", // the selector of the element that will trigger the copilot when clicked headers: { // optional: you can pass your authentication tokens to the copilot or any other header you want to send with every request Authorization: "Bearer your_auth_token_goes_here", AnyKey: "AnyValue" }, containerProps: { // optional: you can pass any props to the container div className: "your-custom-class-name", style: { position: "fixed", height: "100%", bottom: "0", right: "0", width: "400px", }, } } window.addEventListener("DOMContentLoaded", ()=>initAiCoPilot(options)); // window.onload </script>
As a React Component
-
Install the widget from npm.
npm install @openchatai/widget
-
Use the Component inside your application
import { CopilotWidget,Root } from "@openchatai/widget";
const options = {
apiUrl: "https://api.opencopilot.so/backend",
socketUrl: "https://api.opencopilot.so",
initialMessage: "Hey! happy to help.",
token: "your_copilot_token_goes_here", // you can get your token from the dashboard
defaultOpen: true,
headers: {
// optional: you can pass your authentication tokens to the copilot or any other header you want to send with every request
Authorization: "Bearer your_auth_token_goes_here",
AnyKey: "AnyValue"
},
}
const containerProps = {
// optional: you can pass any props to the container div
className: "your-custom-class-name",
style: {
position: "fixed",
height: "100%",
bottom: "0",
right: "0",
width: "400px",
},
}
function Widget(){
return (
<Root containerProps={containerProps} options={options}>
<CopilotWidget triggerSelector='#copilot-trigger' />
</Root>
)
}
Options
Options
Object
Available options
Option | Description | type |
---|---|---|
initialMessage | The message that will be first present when the copilot is initialized | string |
token | Your copilot token | string |
triggerSelector | The selector of the element that will trigger the copilot when clicked | string |
apiUrl | the url of the copilot api. | string |
headers | An object of headers that will be sent with every request (can be used to authenticate your api requests) | Record<string,string> |
containerProps | An object of props that will be passed to the container div | Record<string,string> |
socketUrl | The url of the socket url that will be used to send and receive messages | string |
components | List of components that will be used to render any UI component. learn more about responding with UI | object[] |
debug | If true, the copilot will log all the messages and events to the console and to the chat ui (default: false) | boolean |
onHandoff | A function that will be called when the user is handed off to a human agent. read more about handoff | function |