Voiceflow’s web chat API gives you programmatic control over the widget’s behavior. You can customize how conversations persist, pass in user data, trigger intents, send proactive messages, and listen for events.Documentation Index
Fetch the complete documentation index at: https://docs.voiceflow.com/llms.txt
Use this file to discover all available pages before exploring further.
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.
Choosing which environment the widget loads
By default, the widget respects your project’s traffic split: each new session is routed to an environment based on the split you’ve configured, so the widget works with A/B tests and gradual rollouts without any extra configuration. To force the widget to load a specific environment, pass that environment’s alias asversionID. Copy the alias from the Alias column in Settings → Environments.
versionID is set, the widget loads that environment’s live version and ignores the traffic split. If the environment has no published version yet, the widget won’t render any messages.
If your project was created before environments launched and has not yet been migrated, the legacy
development, staging, and production values continue to work as versionID. After migrating, update your snippet to use your new environment aliases (or remove versionID to use the traffic split).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.