Chat Widget V2
- Getting Started
- Chat Widget Methods
- Chat Widget Events
- Chat Widget Snippet Code Configuration
- Chat Widget Theme Configuration
- Content Security Policy
- CSP Domain Description
- Chat Widget Scenario Best Practice Cases
Getting Started
Chat Widget is a JSSDK (hereafter referred to as Chat widget) that allows embedding into your own website, it comes in handy whenever contacts want to contact you, more detailed configuration and usage documents are here. This document mainly focuses on JSSDK-related content.
Chat Widget Methods
Open chat widget
Theopen
method is used for opening the chat widget by hitting the icon.
webchat.open()
Close chat widget
The close
method is used for minimizing the chat widget by hitting the minimize icon in the chat box header, it needs to be invoked after the initialization of the chat widget.
webchat.close()
Destroy chat widget
The destroy
method is used when you need to remove or delete the running chat widget. It will be completely deleted from your website. If you need to display it again, you need to call the init method. If there is an ongoing conversation, it will be disconnected
webchat.destroy()
Reset chat widget
Thereset
method can reset the entire chat widget back to its original state and clear the local cache. If there is an ongoing conversation, it will also be disconnected.
webchat.reset()
Set context
The setContextParam
method is used for transmitting customized key-value context to TD internal systems such as Studio Flow, for example. We can transmit the customer’s using language or address to the agent. The customized context will be displayed in the Context tab of Conversation through Studio.
The setContextParam can be used to set default values for the Initial screen form in chat-widget. If we set default values for all the form controls of Initial screen, the Initial screen will be skipped before the conversation starts.
webchat.setContextParam({
"var1": "dummy value for var1",
"var2": "dummy value var2",
"field_name1": "dummy name",
"field_email1": "[email protected]"
...
})
Chat Widget Events
Initialization completed
This method is used for doing something after chat widget is initialized. It’s an asynchronous function and receives the customized configuration of chat widget as arguments.
webchat.init(configs).then(function () {
// your own business logic after chat widget initialized
})
When Chat is opened
The onOpenWebchat
method is used for doing something after the chat widget is opened. It receives a callback as its argument to execute your customized logic.
const doSomething = () => {
//your own business logic when chat widget is opened
}
webchat.onOpenWebchat(doSomething)
When chat is closed
TheonCloseWebchat
method is used for doing something after the chat widget is closed. It receives a callback as its argument to execute your customized logic.
const doSomething = () => {
//your own business logic when chat widget is closed
}
webchat.onCloseWebchat(doSomething)
When the conversation starts
The onConversationStart
method is used for doing something after the chat conversation starts. It receives a callback as its argument to execute your customized logic.
const doSomething = () => {
//your own business logic when conversation starts
}
webchat.onConversationStart(doSomething)
Chat Widget Snippet Code Configuration
The snippet code is embedded in the customer’s website and can be customized according to the configuration you transmit.
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{ enableEmoji: true, enableAttachments: true, enableValidation: true, enableResponsiveLayout: true, styles: {} }
);
</script>
<!-- End of Talkdesk Code -->
Field | Type | Required | Description |
---|---|---|---|
window | object | Yes | Browser built-in Window object |
document | object | Yes | Browser built-in Document object |
node | string | Yes | The target Dom to which chat-widget UI is mounted |
props | See [props configuration below for details | Yes | Chat-widget base configuration, such as service config, public methods |
configs | See configs configuration below for details | Yes | Chat-widget customization settings |
props configuration
Field | Type | Required | Default value | Description |
---|---|---|---|---|
touchpointId | string | Yes | - | Use to get the chat-widget touchpoint configuration |
flowId | string | No | - | Deprecated Note: Keep this field only for compatibility, please better use touchpointId instead. |
accountId | string | No | - | Deprecated Note: Keep this field only for compatibility, it won’t work if configured. |
region | enum | Yes | - | The region of the TD endpoints gateway: td-us-1 td-eu-1 td-ca-1 td-usfed-1 |
enablePointMoveTriggerButton | boolean | No | false | Enable/disable drag and move for the chat launcher |
languageCode | string | No | en-US | Using language: en-US pt-PT pt-BR es-ES de-DE fr-FR it-IT ar-SA ar-EG |
autoOpen | boolean | No | false | Automatically open widget after initialization |
configs configuration
Field | Type | Required | Default value | Description |
---|---|---|---|---|
enableEmoji | boolean | No | true | Enable/disable the emoji capability |
enableValidation | boolean | No | false | Enable/disable the validation of the email or phone number in the Initial screen |
enableUserInput | boolean | No | true | Enable/disable the sending box |
enableAttachments | boolean | No | true | Enable/disable sending/receiving attachment capability |
enableResponsiveLayout | boolean | No | true | Enable/disable auto full-screen capability |
languageCode | string | No | en-US | Using language: en-US pt-PT pt-BR es-ES de-DE fr-FR it-IT ar-SA ar-EG |
styles | object | No | - | See theme config below for details |
Chat Widget Theme Configuration
The chat widget supports customizing themes to have a better UX for Customers.
Customizing the chat widget launcher
Launcher
Field | Type | Default value | Description |
---|---|---|---|
chatLauncherColor | string | # 1e0044 | The color for the chat launcher |
chatHoverLauncherColor | string | # 172241 | The hover color for the chat launcher |
triggerButtonWidth | string | 35px | Width of launcher icon. _Note: up to 64 px |
triggerButtonHeight | string | 35px | Height of launcher icon. _Note: up to 64px |
triggerButtonPositionRight | string | 30px | Distance of launcher icon to the right side of the window |
triggerButtonPositionBottom | string | 40px | Distance of launcher icon to the bottom of the window |
Customizing the widget window
Widget window
Field | Type | Default value | Description |
---|---|---|---|
chatIcon | string | sms.svg | Launcher icon. Note: Supports SVG, PNG, and JPG, better as SVG. For a round shape, it should have a transparent background. |
chatTitle | string | Talkdesk Chat | Title for header. |
chatTitleIcon | string | sms.svg | The icon at the left of header. |
chatTitleIconWidth | string | 32px | Width for the icon at the left of header. |
chatTitleIconHeight | string | 32px | Height for the icon at the left of header. |
chatTitleTextColor | string | - | Font color for the title of header. |
chatSubtitle | string | Powered by Talkdesk | Subtitle for header. |
chatSubtitleTextColor | string | # a1acc9 | Font color for the subtitle of header. |
chatCloseButtonColor | string | # ffffff | Color for the close button. |
chatMinimizeButtonColor | string | # ffffff | Color for the minimize button. |
chatContainerWidth | string | 335px | Width of the chat box. |
chatContainerHeight | string | 600px | Height of chat box. |
chatPositionBottom | string | 20px | Distance of chat box to the bottom of the window. |
chatThemeColor | string | # 1E0044 | Background color for launcher and header. |
chatHoverThemeColor | string | # 1A223F | Color of the launcher background when hovering. |
chatThemeMainFont | string | Roboto-Regular, sans-serif | Font of the subtitle, input box placeholder, chat messages, and notifications. Note: It supports web-safe fonts. If you wish to use a non-supported font, we recommend pre-installing the font on your website. |
Customizing the initial screen
Welcome message
Field | Type | Default value | Description |
---|---|---|---|
welcomeMessageBackgroundColor | string | # 4D356A | Background color for the welcome message. |
welcomeMessageTitleFontFamily | string | Roboto-Regular, sans-serif | Font for the title of the welcome message |
welcomeMessageTitleFontSize | string | 24px | Font size for the title of the welcome message. |
welcomeMessageTitleColor | string | # ffffff | Font color for the title of the welcome message. |
welcomeMessageContentFontFamily | string | Roboto-Regular, sans-serif | Font for the content of the welcome message. |
welcomeMessageContentFontSize | string | 16px | Font size for the content of the welcome message. |
welcomeMessageContentColor | string | # ffffff | Font color for the content of the welcome message. |
Custom message
Field | Type | Default value | Description |
---|---|---|---|
customMessageNoBubbleFontFamily | string | Roboto-Regular, sans-serif | Font of the custom message with no bubble. |
customMessageNoBubbleFontSize | string | 14px | Font size of the custom message with no bubble. |
customMessageNoBubbleColor | string | # 202830 | Font color of the custom message with no bubble. |
customMessageBackgroundColor | string | # F2F4F5 | Background color of the custom message with bubble. |
customMessageFontFamily | string | Roboto-Regular, sans-serif | Font of the custom message with bubble. |
customMessageFontSize | string | 14px | Font size of the custom message with bubble. |
customMessageColor | string | # 202830 | Font color of the custom message with bubble. |
Custom field
Field | Type | Default value | Description |
---|---|---|---|
customFieldLabelFontFamily | string | Roboto-Regular, sans-serif | Font for the label of the custom field. |
customFieldLabelFontSize | string | 14px | Font size for the label of the custom field. |
customFieldLabelColor | string | # 202830 | Font color for the label of custom field. |
customFieldInputFontFamily | string | Roboto-Regular, sans-serif | Font for the input text of custom field. |
customFieldInputFontSize | string | 14px | Font size for the input text of custom field. |
customFieldInputColor | string | # 202830 | Font color for the input text of custom field. |
customFieldInputBackgroundColor | string | # ffffff | Background color for custom field. |
customFieldInputPlaceholder | string | Type | Partial placeholder for the custom field. |
customFieldPhoneDescription | string | Include the country code, avoid spaces and/or symbols (e.g. +1123456789) | Phone number input Prompt user description Note: This item will only be displayed if enableValidation is set to true. |
customFieldPhoneInvalidFormatMessage | string | please type a valid phone number | Phone number input Prompt user description Note: This item will only be displayed if enableValidation is set to true. |
customFieldEmailInvalidFormatMessage | string | please type a valid email | Phone number input Prompt user description Note: This item will only be displayed if enableValidation is set to true. |
Custom dropdown
Field | Type | Default value | Description |
---|---|---|---|
customDropdownLabelFontFamily | string | Roboto-Regular, sans-serif | Font for the custom dropdown label. |
customDropdownLabelFontSize | string | 14px | Font size for custom dropdown label. |
customDropdownLabelColor | string | # 202830 | Font color for custom dropdown label. |
customDropdownInputFontFamily | string | Roboto-Regular, sans-serif | Font for custom dropdown input. |
customDropdownInputFontSize | string | 14px | Font size for custom dropdown input. |
customDropdownInputColor | string | # 202830 | Font color for custom dropdown input. |
customDropdownInputBackgroundColor | string | # ffffff | Background color for custom dropdown. |
customDropdownInputPlaceholder | string | Select | Placeholder for custom dropdown. |
Custom button
Field | Type | Default value | Description |
---|---|---|---|
customButtonFontFamily | string | Roboto-Regular, sans-serif | Font of the label of a custom button. |
customButtonFontSize | string | 14px | Font size of the label of a custom button. |
customButtonColor | string | # 003FBD | Font color for the label of custom button. |
customButtonBackgroundColor | string | # ffffff | Background color of a custom button. |
customButtonBorderColor | string | # 003FBD | Border color of a custom button. |
customButtonHeight | string | 32px | Height of a custom button. |
Customizing the conversation
Conversation
Field | Type | Default value | Description |
---|---|---|---|
userTextColor | string | # ffffff | Font color of a message sent by a visitor. |
userBackgroundColor | string | # 5405BD | Background color of a message sent by a visitor. |
userAnchorTextColor | string | # E1CCFE | Font color of an unvisited hyperlink sent by a visitor. |
userAnchorTextColorVisited | string | # B681FC | Font color of a visited hyperlink sent by a visitor. |
userInputHeight | string | 56px | Minimum height of user message input box. |
userInputSeparatorColor | string | # DFDFDF | Color of the separator above the input box. |
chatPlaceholder | string | Type a message... | Placeholder of the input box. |
endedChatMessage | string | End chat | System message text displayed at the end of conversation. |
Bot
Field | Type | Default value | Description |
---|---|---|---|
botTextColor | string. | # 00000. | Agent or VA agent message bubble font color |
botBackgroundColor | string | # F2F4F5 | Background color of a message sent by an agent or a bot. |
botAnchorTextColor | string | # 3232D6 | # 3232D6Font color of an unvisited hyperlink sent by an agent or a bot. |
botAnchorTextColorVisited | string | # 5405BD | # 5405BDFont color of a visited hyperlink sent by an agent or a bot. |
botIcon | string | - | Custom agent avatar. Note: It overrides all the default agent avatar properties. |
botIconHeight | string | 32px | Height of the agent avatar. |
botIconWidth | string | 32px | Width of the agent avatar. |
botIconVerticalAlign | string | top | Placement of the agent avatar towards the message bubble. It can be ‘top’ or ‘bottom’. |
Avatar
Field | Type | Default value | Description |
---|---|---|---|
avatarForegroundColor | string | # 5C6784 | Foreground color of the default agent avatar. |
avatarBackgroundColor | string | # EDF4FC | Background color of the default agent avatar. |
avatarBorderColor | string | # EDF4FC | Border color of the default agent avatar. |
Button
Field | Type | Default value | Description |
---|---|---|---|
buttonTextColor | string | # 005cde | Set the font color of all VA Buttons and buttons in the carousel component |
buttonHoverTextColor | string | # 005cde | Set the font color of all VA Buttons and buttons in the carousel component when the mouse is moved into it |
buttonBackgroundColor | string | rgb(237, 244, 252) | Set the background color of all VA Buttons and buttons in the carousel component |
buttonHoverBackgroundColor | string | rgb(237, 244, 252) | Set the background color of all VA Buttons and buttons in the carousel component when the mouse is moved into it |
Start chat button
Field | Type | Default value | Description |
---|---|---|---|
startChatButtonTextColor | string | # ffffff | Start new conversation button font color |
startChatButtonHoverTextColor | string | # ffffff | The font color of the Start New Conversation button when the mouse is moved into it |
startChatButtonBorderColor | string | # 1e0044 | Start new conversation button border color |
startChatButtonHoverBorderColor | string | # 1e0044 | The color of the border when the mouse is moved into the Start New Conversation button |
startChatButtonBackgroundColor | string | # 1e0044 | Start new conversation button background color |
startChatButtonHoverBackgroundColor | string | # 1e0044 | The background color of the Start New Conversation button when the mouse is moved into it |
startChatButtonLabel | string | Start new chat | Display copy in Start New Conversation button |
Quick reply
Field | Type | Default value | Description |
---|---|---|---|
replyTextColor | string | # 005cde | Set the font color of all VA quick replay buttons |
replyHoverTextColor | string | # edf4fc | Set the font color of all VA quick replay buttons when the mouse is moved into them |
replyBorderColor | string | # 005cde | Set the border color of all VA quick replay buttons |
replyBackgroundColor | string | transparent | Set the background color of all VA quick replay buttons |
Customizing the close conversation dialog
Dialog
Field | Type | Default value | Description |
---|---|---|---|
chatConfirmButtonFontFamily | string | Roboto-Regular, sans-serif | Set the font color of all VA quick replay buttons |
chatConfirmButtonFontSize | string | 14px | Set the font color of all VA quick replay buttons when the mouse is moved into them |
chatConfirmButtonFontColor | string | # ffffff | Set the border color of all VA quick replay buttons |
chatConfirmButtonBackgroundColor | string | # 3E048B | Set the background color of all VA quick replay buttons |
chatCancelButtonFontFamily | string | Roboto-Regular, sans-serif | Font of the cancel button of the dialog box. |
chatConfirmButtonEndChat | string | Yes, end chat | Label of the confirm button of the dialog box when the contact person tries to end the conversation. |
chatConfirmButtonRetryEndChat | string | Try again | Label of the confirm button of the dialog box when an error occurs while attempting to end the conversation. |
chatCancelButtonFontSize | string | 14px | Font size of the cancel button of the dialog box. |
chatCancelButtonFontColor | string | # F2F4F5 | Font color of the cancel button of the dialog box. |
chatCancelButtonEndChat | string | Cancel | Label of the cancel button of the dialog box when the contact person tries to end the conversation. |
chatCancelButtonRetryEndChat | string | Dismiss | Label of the cancel button of the dialog box when an error occurs while attempting to end the conversation. |
Content Security Policy (CSP)
Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks, including Cross-Site Scripting (XSS) and data injection attacks. These attacks are used for everything, from data theft to site defacement or malware distribution.
Most customers use CSP to protect their websites from attack, and they will set strict rules for the third-party libs. In order to run the chat widget steadily, we need to provide a whitelist for the customer to avoid being intercepted.
Usually, the CSP tool will detect the src field in the script, frame, or the elements that have the attribute to decide whether to intercept.
TD Region | CSP Rules |
---|---|
td-us-1 | script-src 'self' https://talkdeskchatsdk.talkdeskapp.com; frame-src 'self' https://talkdeskchatsdk.talkdeskapp.com; connect-src 'self' https://api.talkdeskapp.com; |
td-eu-1 | script-src 'self' https://talkdeskchatsdk.talkdeskapp.com; frame-src 'self' https://talkdeskchatsdk.talkdeskapp.com; connect-src 'self' https://api.talkdeskapp.eu; |
td-ca-1 | script-src 'self' https://talkdeskchatsdk.talkdeskapp.com; frame-src 'self' https://talkdeskchatsdk.talkdeskapp.com; connect-src 'self' https://api.talkdeskappca.com; |
td-usfed-1 | script-src 'self' https://talkdeskchatsdk.talkdeskapp.com; frame-src 'self' https://talkdeskchatsdk.talkdeskapp.com; connect-src 'self' https://api.talkdeskapp-pubsec.com; |
CSP Domain Description
Below is the description of the domains in CSP rules. Each domain plays a crucial role in enabling chat services by specifying trusted sources from which content can be loaded, ensuring both functionality and security for users in their respective regions.
CSP Domains | Description |
---|---|
https://talkdeskchatsdk.talkdeskapp.com | TalkDesk Chat Widget JSSDK remote domain |
https://api.talkdeskapp.com | TalkDesk Gateway domain for US region |
https://api.talkdeskapp.eu | TalkDesk Gateway domain for EU region |
https://api.talkdeskappca.com | TalkDesk Gateway domain for CA region |
https://api.talkdeskapp-pubsec.com | TalkDesk Gateway domain for FedRAMP region Note: The domain is used for the FedRamp, if your website is not supported for FedRamp, you can ignore it. |
Chat Widget Scenario Best Practice Cases
1. Hide chat launcher icon and open chat-widget
In cases where you prefer not to display the default chat launcher icon and instead want to open the chat widget through a custom element on your web page like an icon, link, or menu, you can achieve this by following these steps:
- Hide the Chat Launcher Icon
Utilize the SDK's configuration options to ensure the default launcher icon is hidden from view. - Trigger the Chat Widget Using the webchat.open() API
Implement a custom trigger (e.g., button, menu item, or link) in your web application that calls the webchat.open() method to open the chat widget programmatically.
Example of the integrated code:
+<button onclick="webchat && webchat.open()">your button</button>
+<a href="javasciprt:void(0)" onclick="webchat && webchat.open()">your link</a>
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{
enableValidation: false,
enableEmoji: true,
enableUserInput: true,
enableAttachments: true,
+ styles: {
+ // hidden lanuch chat icon
+ triggerButtonPositionBottom: "-65px",
+ triggerButtonPositionRight: "-65px",
+ },
}
);
</script>
<!-- End of Talkdesk Code -->
2. Automatically open chat widget
The customer needs to automatically open TD chat every time the contact person visits the website. The following is the integration code.
Example of the integrated code:
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{
touchpointId: "<customer touchpointId>",
accountId: "",
region: "<customer td region>",
+ autoOpen: true
},
{ enableValidation: false, enableEmoji: true, enableUserInput: true, enableAttachments: true }
);
</script>
<!-- End of Talkdesk Code -->
3. Show/hide attachments or emojis
The attachments and emojis are controlled by transmitting the enableAttachments and enableEmoji fields in the configs of snippet code.
Example of the integrated code:
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
/*
* Send custom data from your website to TalkDesk!
* If you would like to do it, you need to remove the following commented code and
* modify the webchat.setContextParam parameters to pass in the data you need.
*/
/*function setContext() {
webchat.setContextParam({ "var1": "value1", "var2": "value2", "var3": 100 })
}
// Send data when the chat conversation is initiated
webchat.onConversationStart = function() {
setContext()
}
// Send data when the chat widget is open
webchat.onOpenWebchat = function() {
setContext()
}*/
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{
enableValidation: false,
enableUserInput: true,
+ enableEmoji: true,
+ enableAttachments: true
}
);
</script>
<!-- End of Talkdesk Code -->
4. Automatically fullscreen chat widget
If the screen’s width is lower than 600px or the height is lower than 620px, the chat widget will be resized to full-screen while enabling the enableResponsiveLayout, but we’ll not set it to full-screen for the chat widget at any time if enableResponsiveLayout is disabled.
Example of the integrated code:
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{
enableValidation: false,
enableEmoji: true,
enableUserInput: true,
enableAttachments: true,
+ enableResponsiveLayout: true
}
);
</script>
<!-- End of Talkdesk Code -->
It may not be good to simply disable the full-screen capability. For example, the automatic full-screen capability is still needed on some mobile devices, but you can not use it on a PC. The following is an example.
Example of the integrated code:
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{
enableValidation: false,
enableEmoji: true,
enableUserInput: true,
enableAttachments: true,
+ enableResponsiveLayout: |Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(window.navigator.userAgent),
}
);
</script>
<!-- End of Talkdesk Code -->
5. Transmit custom context to studio flow
We can use the setContextParam method to transmit some useful information to the Conversations App. The method will collect the data and then transmit it to Studio flow, Studio will send the data to the Context card in the Conversations App according to the configuration in the Studio context. Here are the steps on how to display the context in the context card of the Conversations App.
Example of the integrated code:
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
+ webchat.setContextParam({
+ "contact_email": "[email protected]",
+ "contact_name": "dummy",
+ })
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{ enableValidation: false, enableEmoji: true, enableUserInput: true, enableAttachments: true }
);
</script>
<!-- End of Talkdesk Code -->
Step 1: Add a new argument in the Initial step component in studio flow, you can add the context transmitted by the customer.
Step 2: Select the new context you already created in step 1 and save it.
Step 3: Go to the Conversations App to check the data in the Context card at the right hand of the page.
7. Set pre-filled values for the fields on the Initial screen
The Chat Widget JavaScript SDK allows you to dynamically set pre-filled values for the fields on the initial form. This functionality is useful in scenarios where contact person information is already stored in an external system. For instance, if your system maintains such as the contact person's name and email address information, these can be pre-fill into the chat widget fields.
If pre-filled values are provided for ALL fields on the initial form, the data will be automatically submitted to the TalkDesk system when the chat begins.
In this case, the chat widget will bypass the initial form stage, allowing the conversation to start immediately without user input.
Example of the integrated code
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
/*
* Send custom data from your website to TalkDesk!
* If you would like to do it, you need to remove the following commented code and
* modify the webchat.setContextParam parameters to pass in the data you need.
*/
- /*function setContext() {
+ function setContext() {
- webchat.setContextParam({ "var1": "value1", "var2": "value2", "var3": 100 })
+ // Note: Set the default value of the Initial screen form here. If default values are set for all fields, Talkdesk Chat will automatically skip the Initial screen stage and go directly to the conversation ui.
+ webchat.setContextParam({
+ "field_email1": "[email protected]",
+ "field_number1": "+1",
+ })
}
// Send data when the chat conversation is initiated
webchat.onConversationStart = function() {
setContext()
}
// Send data when the chat widget is open
webchat.onOpenWebchat = function() {
setContext()
- }*/
+ }
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{ enableValidation: false, enableEmoji: true, enableUserInput: true, enableAttachments: true }
);
</script>
<!-- End of Talkdesk Code -->
8. Support internationalization and layout
The chat widget allows for multi-language support by configuring the languageCode field. By setting this field, customers can specify the language of the chat interface using standard international language codes. For instance: en-US for English (United States), pt-PT for Portuguese (Portugal).
The default layout direction of the chat widget is Left-to-Right (LTR). It is not necessary to manually set this value for LTR languages, as it is automatically configured based on the language code provided.
For languages that require a Right-to-Left (RTL) layout, such as Arabic, the layout direction is also set automatically. When a language code corresponding to an RTL language is specified (e.g., ar-SA or ar-EG), the chat widget will adjust its layout direction accordingly, providing a seamless user experience for RTL language speakers.
When the languageCode field is set to empty, it will automatically set the browser's language.
If automatic identification or pass-through configuration parameters are not supported, it will be fall back to en-US
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{
enableValidation: false,
enableEmoji: true,
enableUserInput: true,
enableAttachments: true,
+ languageCode: "pt-PT", // Notes support the languageCodes: en-US pt-PT pt-BR es-ES de-DE fr-FR it-IT ar-SA ar-EG
}
);
</script>
<!-- End of Talkdesk Code -->
9. Drag and move chat launcher
The "Drag and Move Chat Launcher" feature enhances the user experience by addressing the need for flexibility and unobstructed access to application information on PC and mobile devices. The ability to move the chat widget, especially within the mobile application for the following reasons:
Customizable Positioning: Users want the flexibility to reposition the chat launcher to a location on their screen that best suits their preferences and usage patterns. This ensures that the chat widget does not interfere with the personal viewing experience.
Unobstructed Access: The current fixed position of the chat widget has been reported to block important application information, which can hinder the user experience by obscuring critical content. Allowing users to move the chat widget ensures that all essential information remains visible and accessible, improving overall usability and satisfaction.
The enablePointMoveTriggerButton is used to turn on the drag and move of the chat launcher, and the value of this field is false by default.
Example of the integrated code:
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{
enableValidation: false,
enableEmoji: true,
enableUserInput: true,
+ enablePointMoveTriggerButton: true
}
);
</script>
<!-- End of Talkdesk Code -->
If you only wish to drag and move the chat launcher on mobile, you can specify the value of this field. The following is an example of the integrated code:
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{
enableValidation: false,
enableEmoji: true,
enableUserInput: true,
+ enablePointMoveTriggerButton: |Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(window.navigator.userAgent)
}
);
</script>
<!-- End of Talkdesk Code -->
10. Use chat jssdk with require.js
If you need to use it with require.js, you need to modify the chat touchpoint snippet code slightly.
Example of the integrated code:
<script type="text/javascript" src="https://dummy/require.js"></script>
<script>
// configuration talkdesk remote js to require.js
require.config({
paths: {
"talkdeskChatSDK": "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk"
},
shim: {
"talkdeskChatSDK": {
exports: "TalkdeskChatSDK"
}
}
})
</script>
<script>
var webchat;
require(["talkdeskChatSDK"], function(TalkdeskChatSDK) {
// td snippet code start
(function(window, document, node, props, configs) {
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
/*
* Send custom data from your website to TalkDesk!
* If you would like to do it, you need to remove the following commented code and
* modify the webchat.setContextParam parameters to pass in the data you need.
*/
/*function setContext() {
webchat.setContextParam({ "var1": "value1", "var2": "value2", "var3": 100 })
}
// Send data when the chat conversation is initiated
webchat.onConversationStart = function() {
setContext()
}
// Send data when the chat widget is open
webchat.onOpenWebchat = function() {
setContext()
}*/
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{ enableValidation: false, enableEmoji: true, enableUserInput: true, enableAttachments: true }
);
// td snippt code end
})
</script>
11. When your website needs to log out or reset the chat widget in other scenarios
Example of the integrated code:
+ <!--Simulate a button on your website that requires logging out or resetting the chat widget-->
+ <button onclick="webchat && webchat.reset()">Reset chat widget</button>
+ <button onclick="webchat && webchat.reset()">Log out</button>
+ <button id="btn">Other scenarios</button>
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{
enableValidation: false,
enableEmoji: true,
enableUserInput: true,
}
);
</script>
<!-- End of Talkdesk Code -->
+ <!--Simulate your website's custom call using javascript-->
+ <script>
+ document.getElementById("btn").onclick = function () {
+ if (webchat) {
+ webchat.reset()
+ }
+ }
+</script>
12. Create and Identify a Contact Automatically
Integrated customers can use the setContextParam
method provided by our JSSDK to pass the contact person's phone number (with country code) or email address from their website.
The contact information must be passed using the
td_contact_person_identification
field, which currently supports the following formats:Email: e.g., [email protected]
Phone Number (with Country Code): e.g.,
+1123456789
<!-- Start of Talkdesk Code -->
<script>
var webchat;
(function(window, document, node, props, configs) {
if (window.TalkdeskChatSDK) {
console.error("TalkdeskChatSDK already included");
return;
}
var divContainer = document.createElement("div");
divContainer.id = node;
document.body.appendChild(divContainer);
var src = "https://talkdeskchatsdk.talkdeskapp.com/v2/talkdeskchatsdk.js";
var script = document.createElement("script");
var firstScriptTag = document.getElementsByTagName("script")[0];
script.type = "text/javascript";
script.charset = "UTF-8";
script.id = "tdwebchatscript";
script.src = src;
script.async = true;
firstScriptTag.parentNode.insertBefore(script, firstScriptTag);
script.onload = function() {
webchat = TalkdeskChatSDK(node, props);
webchat.init(configs);
/*
* Send custom data from your website to TalkDesk!
* If you would like to do it, you need to remove the following commented code and
* modify the webchat.setContextParam parameters to pass in the data you need.
*/
- /*function setContext() {
+ function setContext() {
webchat.setContextParam({
+ // Here, the unique identifier of the contact person is passed to talkdesk. Currently, only phone numbers with country code and email addresses are supported. Please choose one to pass.
+ "td_contact_person_identification": "[email protected]" // or "+1123456789"
})
}
// Send data when the chat conversation is initiated
webchat.onConversationStart = function() {
setContext()
}
// Send data when the chat widget is open
webchat.onOpenWebchat = function() {
setContext()
- }*/
+ }
};
})(
window,
document,
"tdWebchat",
{ touchpointId: "<customer touchpointId>", accountId: "", region: "<customer td region>" },
{ enableValidation: false, enableEmoji: true, enableUserInput: true, enableAttachments: true }
);
</script>
<!-- End of Talkdesk Code -->
Updated 11 days ago