
Understanding the default snippet
When you copy the widget code from Widget in the sidebar, you get a snippet like this:chat.load() function initializes the widget. You can extend it with additional configuration options described in this guide.
Setting the agent version
TheversionID property specifies which version of your agent to load. The snippet from the Voiceflow UI defaults to production, but you can also use development or staging to test changes before publishing.
development, click the Run button or press R from your agent’s canvas to push your latest changes. If versionID is set to production or staging before you’ve published your agent, the widget won’t render any messages.
Setting the runtime URL
This feature is only available to Enterprise customers who are hosted on a Private Cloud.
url property defines the runtime endpoint the widget communicates with. Private Cloud customers should replace the default URL with their dedicated runtime endpoint provided by Voiceflow.
Configuring chat persistence
Chat persistence determines whether users return to an ongoing conversation or start fresh when they reload the page, open a new tab, or come back later. Configure this with thepersistence property inside the assistant object.
| Option | Behavior |
|---|---|
localStorage | Default. Conversations persist across page reloads and browser sessions. |
sessionStorage | Conversations persist across page reloads but reset when all tabs are closed. |
memory | Conversations reset on every page reload or new tab. |
Passing a custom user ID
You can assign a unique ID to each user with theuserID property. This ID becomes available in your agent as the built-in {user_id} variable, which is useful for identifying users across sessions and personalizing interactions.
Passing custom variables
You can pre-fill variables when the widget loads using thelaunch.event.payload field. These values populate the last_event system variable and can be accessed using Code step.
user_name and user_email as variables in your project first. Also, last_event is updated on each user interaction (eg: when the widget loads, an intent triggers, or a button is clicked), so capture these values at the start of the conversation.
Annotating transcripts with metadata
You can pass user profile information that appears in your Transcripts. This metadata is for labeling conversations in the UI only and isn’t available to your agent’s logic.API methods
Once the widget script loads, it registers the API aswindow.voiceflow.chat. You can use these methods to control the widget programmatically.
| Method | Description | Available in overlay mode | Available in embedded mode |
|---|---|---|---|
load({ config }) | Initializes the chat widget. Parses configuration, fetches remote assistant settings from the Voiceflow API. Nothing works until load is called. | Yes | Yes |
open() | Opens the chat window. If the session is idle, also triggers the launch event (starts the conversation). Emits a voiceflow:open broadcast event. Only effective in overlay mode. | Yes | No |
close() | Closes the chat window, interrupts audio, clears no-reply timeouts, and saves the session. Emits a voiceflow:close broadcast event. Only effective in overlay mode. | Yes | No |
destroy() | After calling this, all methods become no-ops until load is called again.. | Yes | Yes |
show() | Shows the widget again after it was hidden with hide(). Only effective in overlay mode. | Yes | No |
hide() | Hides the entire widget (chat window AND launcher button) from view. Only effective in overlay mode. | Yes | No |
showPopover() | Shows the chat as a popover dialog. Only effective in overlay mode. | Yes | No |
hidePopover() | Hides the popover dialog with a closing animation. Only effective in overlay mode. | Yes | No |
isPopoverShowing() | Returns whether the popover is currently visible (including during close animation). Only effective in overlay mode. | Yes | No |
interact({ action }) | Sends a simulated user action. Can trigger specific intents or events. | Yes | Yes |
proactive.push(...messages) | Pushes proactive messages (speech bubbles) that appear near the launcher button before the user opens chat. Only effective in overlay mode. | Yes | No |
proactive.clear() | Clears all proactive messages. Only effective in overlay mode. | Yes | No-op |
Examples
Open the widget automatically after 3 seconds:Sending proactive messages
Proactive messages appear outside the chat window before users open it. They’re useful for prompting engagement, such as offering help or announcing promotions. These messages don’t appear in transcripts and don’t consume credits.
Pushing messages
Usewindow.voiceflow.chat.proactive.push() to send one or more messages:
Clearing messages
Usewindow.voiceflow.chat.proactive.clear() to hide all proactive messages:
Triggering messages based on user behavior
You can trigger proactive messages when users perform specific actions. For example, show a message when someone visits a certain page:Listening for events
The widget emits events you can listen for using themessage event listener. Voiceflow events are stringified JSON objects with a type beginning with voiceflow:.
| Event type | Description |
|---|---|
voiceflow:open | The widget was opened. |
voiceflow:close | The widget was closed. |
voiceflow:interact | The assistant responded to an interaction. |
voiceflow:save_session | The conversation state was cached. |
Allowing dangerous HTML elements
Only enable dangerous HTML if you understand XSS risks and are using your own trusted code. Learn more about XSS vulnerabilities.
<script> and <iframe> are blocked in messages for security reasons. You can enable them, but doing so introduces cross-site scripting (XSS) vulnerabilities.