iframe
Embed the Agent into your business website using an iframe. When users visit the target webpage, the Agent chat window will load, providing services such as online customer support, pre-sales consultation, and lead collection.
How to Integrate into a Website
- Go to Agent-Integration-iframe and copy the "Integration Code."
- Paste the code into the desired location in your website's HTML page.
- Publish the website to complete the AI Agent embedding and start the conversation.
- If you need to customize the UI and logo, control user message frequency, or display proactive messages to enhance interaction rates, you can proceed with advanced settings.
Custom UI
This feature supports custom configurations for the widget bubble's size, position, color, icon, logo, and name.
- Widget Nickname: Allows custom naming.
- Widget Description: Allows custom description information.
- Theme Settings: Allows customization of the widget's theme color, bubble icon, and Agent appearance.
- Bubble Customization: Supports setting the bubble's display position and size according to business needs.
- Dialog Box Customization: Supports setting the chat window's width and height according to business needs (for compatibility with smaller screens, large values are not recommended).
- Agent LOGO:
- Platform LOGO: Displays the GPTBots Logo.
- Organization LOGO: Displays the custom Logo uploaded by the enterprise here. All Agents under the organization use the same organization Logo.
- Custom LOGO: Displays the uploaded custom Logo. Each Agent can use a different Logo. This feature is an advanced privilege and requires contacting sales for activation.
- No LOGO: The chat window component does not display any Logo information.
Security and Rate Limiting
Domain Whitelist: Defines the domain range where the "widget bubble integration code" can be embedded. If disabled, it is considered unrestricted.
Points Consumption Limit: Defines the points consumption limit for the "widget bubble." If disabled, it is considered unrestricted.
- Up to 3 settings
- Supports setting the total points consumption limit for the widget bubble on a "daily/weekly/monthly" basis
User Consumption Limit: Defines the points consumption limit for each user. If disabled, it is considered unrestricted.
- Up to 3 settings
- Supports setting the points consumption limit for each user on a "daily/weekly/monthly" basis
User Rate Limiting: Defines the message sending frequency limit for each user. If disabled, it is considered unrestricted.
- Up to 3 settings
- Supports setting the message sending limit for each user based on "number of messages/time period"
- When the limit is exceeded, the Agent will no longer respond, and a preset message will be automatically sent.
Event Callback
How to Pass Widget Bubble User Behavior Events to GA4 or Third-Party Systems
- Create a GA4 callback event, obtain the Measurement Protocol API Secret and Measurement ID from the GA4 target project, and fill them in.
- Create a Webhook callback event, select the desired callback event according to the page prompts, and fill in the URL and authentication information.
- "Enable" the callback in the event callback list, and check whether the data is normal in the GA4 or Webhook address. Once the data is successfully stored, you can analyze user data.
Advanced Usage
Set User Information Interface
- Set User ID
- Option 1: The address rule for embedding iframe in a webpage is:
iframe_url
+?user_id=your_user_id
Note: Supports Agent developers in setting user ID
- Option 2: Dynamically set the user ID through javascript code
Array.from(document.getElementsByTagName('iframe')).filter(iframe => iframe.src.includes('gptbots')).forEach(iframe => iframe.contentWindow.postMessage('{"type":"UserId","data":"your_user_id"}', '*'))
Event Callback Data Format
The events and event attributes of the widget bubble transmitted via Webhook or GA4 use the following data format. Please parse and store them accordingly.
{
"client_id": "", //Preferably obtained using the GA4 gtag method to get the client id. If not available, it is generated by GPTBots.
"user_id": "", //Developer-set UserId, null if not set
"event_name": "Show widget bubble", //Event name
"event_params": {
"key1": "abc", //Event attribute name: attribute value (string)
"key2": 123 //Event attribute name: attribute value (number)
}
}