To install OddoChat on your server follow the steps below:
Open the archive
supportboard 1.2.3.zip
and extract the folder in a server location of your choice.
Navigate to the link
http://[your-site]/supportboard/admin.php
and complete the installation. Replace [your-site] with with your website URL. If you change the directory name, replace
supportboard
with the new directory name.
Once the installation is complete, log in with the email and password you created in the previous step and you're done!
Display the chat
To display the chat on your website include the following scripts into the
<head></head>
or
<footer></footer>
area of each page where the chat is shown. Replace
[YOUR-SUPPORT-BOARD-URL]
with the URL of your OddoChat installation. Ex. https://example.com/supportboard/js/main.js.
<!-- Not required if jQuery is already loaded -->
<script src="/users/u14/14400/imports/7912/docs/[YOUR-SUPPORT-BOARD-URL]/js/min/jquery.min.js"></script>
<script id="sbinit" src="/users/u14/14400/imports/7912/docs/[YOUR-SUPPORT-BOARD-URL]/js/main.js"></script>
URL parameters
lang=LANGUAGE-CODE
See the
multilingualdocs for more details.
url=APP-URL
Use this parameter if your application directory URL / folder has been changed. Replace APP-URL with the FULL URL of the application folder. You can also define the URL via JavaScript:
var SB_INIT_URL = "APP-URL"
.
Site migration
If you migrate the chat to a new domain / URL you need to edit the
config.php
file (it's in the OddoChat folder) and update the
SB_URL
constant with the new URL.
Minify JS
For performance reasons, you may want to load the minified main.js file:
[YOUR-SUPPORT-BOARD-URL]/js/min/main.min.js
. Please note that if you contact us for support you will need to load again the non-minified version.
To install OddoChat on WordPress follow the steps below:
Go to the
Plugins
page and click
Add new
then
Upload plugin
and upload the file
supportboard 1.2.3.zip
.
Once the installation is complete you should see a new left menu item named
OddoChat
. You're done, the chat is automatically shown on all pages.
To display the chat on your website go to
https://cloud.board.support/account/?tab=installationand copy the embed code, then paste it into your website pages. If you are using WordPress, you can download the OddoChat Cloud plugin
here.
Requirements
Your web project must support HTML and PHP, and pages containing the chat must be opened via a web browser.
You cannot display the chat on a HTML page opened directly on a local computer. Use a local server like Xampp instead.
Your server must allow the access of the following file:
supportboard/include/ajax.php
If you're using the WordPress version of OddoChat and you have any security plugins installed, please make sure that they don't block the
supportboard/include/ajax.php
file.
JQuery 1.1+
PHP 7.4+
In your server settings,
CURL
,
ZIP ARCHIVE
, must be enabled and working correctly.
Read and write file permissions must be granted for the OddoChat
uploads
,
resources/language
and
apps
folders. OddoChat must be able to save and read the files in these folders.
MySQL 5.5+
MySQL - The SQL mode "ONLY_FULL_GROUP_BY", and the setting "ANSI_QUOTES", must be disabled.
All OddoChat folders should have 755 permissions, all OddoChat files should have 644 permissions.
Once the installation is completed you can check the system requirements from
Settings > Miscellaneous > System requirements
.
Activation
To activate OddoChat and enable all of the features (including updates and more secure encryption), you need to enter the Envato purchase code in
Admin > Settings > Miscellaneous
.
Apps installation
To download, install, and activate the apps go to the
Settings > Apps
area of OddoChat and enter the Envato purchase code or license key.
To update OddoChat and the apps, enter the admin area and click on the version number in the lower left corner.
You can also activate automatic updates via
Settings > Miscellaneous
.
To enable the updates, you need to have a valid Envato purchase code. To update the OddoChat apps you need to have a separate valid License Key or Envato purchase code for each specific app. Besides, the License Key must not be older than 1 year (only for apps purchased outside of CodeCanyon). If your License Key is expired, you will need to purchase a new license to enable App updates again. Apps purchased on CodeCanyon have lifetime updates.
The latest versions of the apps may not work if OddoChat has not been updated to the latest version.
If you're using the WordPress version of OddoChat , keep in mind that you cannot update OddoChat from the WordPress plugins page.
If you're having any issues at all, please contact our friendly support team at support@board.support. Before contacting us, please make sure that your server has all the requirements listed above. On that same note, if you are using the WordPress version, please make sure that your WordPress installation has all the requirements listed above.
General issue
For any issue you can check the system requirements from
Settings > Miscellaneous > System requirements
. We can not provide support about solving the issues reported by the system requirement function, please contact your hosting or server support if you need help.
Blank screen when accessing the admin area
Check if the browser console has error (on Chrome you can open it from
Settings > More tools > Developer tools > Console
).
Enable the PHP debug and check the PHP error logs.
If you have the WordPress version, disable all security plugins and plugins related to your hosting.
Cross-domain configuration
If you want to use the same chat installation on multiple domains, your server should allow cross-origin requests. To enable cross-origin requests on your server follow the steps below:
Cross-domain configuration via server
For Apache servers
— Edit the
.htaccess
file of the domain where the plugin is installed and enter the code
<IfModule mod_headers.c>Header set Access-Control-Allow-Origin "*"</IfModule>
or
<IfModule mod_headers.c="">header('Access-Control-Allow-Origin: *');</IfModule>
at the very top of the file. To make it works you need to have at least
AllowOverride +FileInfo
or
AllowOverride All
in the Apache config.
For nginx servers
— Edit the file
/etc/nginx/nginx.conf
of the domain where the plugin is installed and enter the code
add_header Access-Control-Allow-Origin "*";
at the very top of the file. If you're using Plesk go to
Domains > example.com > Apache and nginx settings > Additional nginx directives
and insert
add_header 'Access-Control-Allow-Origin' '*';
.
If none of the previous solutions work or you can't change the server settings, follow the steps below:
Edit the file
supportboard/config.php
and enter the code
define('SB_CROSS_DOMAIN', true);
at the end of the file.
Upload the following folders into your destination domain(the domain where the chat should be shown, not the one where OddoChat is installed):
supportboard/media/fonts
and
supportboard/media/icons
. You can upload the files where you want, for example,
http://www.example.com/chat-files
. If the chat is loaded on multiple domains upload the files on each domain.
Edit again the file
supportboard/config.php
and Enter the code
define('SB_CROSS_DOMAIN_URL', 'YOUR-URL');
at the end of the file. Replace
YOUR-URL
with the URL that points to the files you just uploaded, for example,
http://www.example.com/chat-files
. If the chat is loaded on multiple domains replace
YOUR-URL
with the an array of URLs, for example,
["http://www.example.com/chat-files", "http://www.example-2.com/chat-files"]
.
Blocking zoom on iOS devices
When using the chat on iPhones the textarea is automatically zoomed when the user's start typing a new message. To stop the zoom Enter the code below into the
<head>
area of all the pages that include the chat.
By default, the admin URL is something like
https://your-website.com/support/admin.php
. You can hide the
admin.php
part of the URL and make it like
https://your-website.com/support/
by inserting the following code in your
.htaccess
file:
You cannot see and test the chat as a user if you're logged-into the admin area. To test the chat as a user, please log out of your admin account. Alternatively, you can use another browser window in “private” or “incognito” mode. Additionally, you can force a logout by executing the SBF.reset() function in the browser console.
Reset email or password of the admin account
If you can no longer log in to the admin area you can reset your password and email by following the steps below:
Edit your
MySQL Database
. You can edit it from your hosting panel, usually with
phpMyAdmin
.
Edit the table
sb_users
.
Find your admin account, and make sure the value of the column
user_type
is
admin
.
Reset your password by editing the
password
column and by inserting the new password as a hash. To generate a hash for your password, visit
https://phppasswordhash.com/, or Enter the hash
$2y$10$i7OComVhUh8BHcyx9VzUfuN.hnNsnKzK1Hd/GKK2KIwBo7Y6stppu
(password: 12345678).
Reset your email address from the column
email
.
If you're using the WordPress version, you can delete the user from the database and WordPress will generate it again. You can also create a new WordPress user with administrative privileges, then logout from your current account, and log in with the new one. Once you're into OddoChat , change the password of your previous agent from
Users > Agents
.
Admin account deleted
If you have accidentally deleted all your admin and agent accounts and you can no longer log in to the admin area, you can resolve this issue by following the steps below:
Edit your
MySQL Database
. You can edit it from your hosting panel, usually with
phpMyAdmin
.
Edit the table
sb_users
.
You can convert any existing user to an admin by editing the column
user_type
, and entering the value
admin
.
You can also add a new user by assigning a value to the columns first_name, last_name, password, email, and user_type fields. The value of the password column must be a hash. To generate a hash for your password, visit
https://phppasswordhash.com/. Also, the value of the column
user_type
must be
admin
.
Server down
If your server and/or website goes down or suddenly stops working after a few minutes of chat usage, the issue could be related to your server's Firewall. This usually happens as a result of an IP Address Banning (Fail2Ban) or Web Application Firewall (ModSecurity) settings. The multiple AJAX requests from the chat to the database are recognized as a "server attack" and so your server places a temporary block on your IP address. This issue should only affect you and/or your developers; visitors/users should not be affected. To confirm whether or not this is the issue, use a VPN service like
Hotspot Shield. When the server goes down, activate the VPN to change your IP and try accessing your website again. If the website works normally, the issue is confirmed. To solve it temporarily disable fail2ban or contact your hosting support for additional support.
Disable chat via JS
Enter the code
var SB_DISABLED = true;
into a page to prevent the chat from loading.
CONVERSATIONS
Manage Conversations
Conversations have a total of four different statuses:
mark as read
,
archive
,
delete
and
restore
. You can manage the status of a conversation by opening it in the conversations area and then clicking any of the corresponding icon buttons in the top right of the conversation window.
Search for conversations
You can for conversations by department ID, assigned agent ID, conversation title, conversation ID, message text, message attachments name, user first name, user last name, user email
Information
When you empty the
trash
, all the conversations in the trash are permanently deleted.
When a user sends a new message to an archived or trashed conversation, the conversation is automatically restored and will now be visible in the
Inbox area
.
Trashed conversations are deleted automatically after 30 days.
When a user is deleted, all the conversations and messages are permanently deleted too.
An agent can delete their messages by opening the message menu and clicking
Delete
. The message menu becomes visible when you hover the mouse cursor over the message.
Text Editor and Automated Messages Features
The text editor of the admin area and automated messages(example: welcome and subscribe messages) can be used to create stylized messages:
— All text links are automatically converted to clickable hyperlinks.
— The editor also supports text formatting syntax:
To make text
bold, surround it with
*
: *your text*.
To make text
italic, surround it with
__
: __your text__.
To make text
strikethrough, surround it with
~
: ~your text~.
To insert a
single-line code
comment, surround it with
`
: `your text`.
To insert a
code block, surround it with
```
: ```your text```.
HTML and other code languages — For security reasons, no HTML, JavaScript (JS), or other code languages are permitted. However, you can use HTML snippets by utilizing custom rich messages (discussed below).
To insert a line break into a message, use the keyboard combination
SHIFT + ENTER
or
CTRL + ENTER
.
Merge fields
Merge fields are strings replaced by external values when used. Merge fields can be used in any message or automated message, including chatbot messages.
Code
Description
{user_name}
Full name of the active user.
{user_email}
Email of the active user.
{agent_name}
Full name of the active agent.
{agent_email}
Email of the active agent.
Rich Messages
Rich messages are special messages with interactive features like buttons, dropdowns, or inputs. They allow an agent to request information from the user via a user input form or to diplay interactive contents. Rich messages can be inserted into a chat message using shortcodes. Shortcodes accept various parameters like title and description. The available rich messages are listed below.
How it works:
1
Create and send
Create a rich message by inserting the shortcode into the text editor of the admin area. Customize all of the parameters with your information and send your message.
2
Message is displayed
When a shortcode is used, the user sees the rich message (not the shortcode) and can select or enter the required information to complete the form submission.
3
User's response is submitted
Once the rich message form has been filled out and sent by the user, a success message is shown and the form data is saved.
Rich Messages
Name
Shortcode
Description
Card
[card image="URL" header="TITLE" description="Lorem ipsum dolor sit amete" link="URL" link-text="Purchase" extra="$599" target="_blank"]
Call-to-action card with an image, title, description, link, and more.
Slider
[slider image-1="URL" header-1="TITLE" description-1="Lorem ipsum dolor sit amete" link-1="URL" link-text-1="Purchase" extra-1="$599" image-2="URL" header-2="TITLE" description-2="Lorem ipsum dolor sit amete" link-2="URL" link-text-2="Purchase" extra-2="$599" target="_blank"]
Slider of call-to-action cards with an image, title, description, link, and more. You can add up to 10 slides.
Form to collect the user's email and phone number. All attributes are optional. Follow up settings used as default values. Add the attribute
required-messaging-apps="true"
to force users to provide their email and phone on messaging apps.
Articles with search area. The
link
attribute is used as fallback message for Facebook Messenger, WhatsApp, Telegram messages.
Rating
[rating label-positive="Helpful" label-negative="Not helpful" label="Rate and review" success-negative=""]
Agent rating form. To make the rating shortcode work on WhatsApp, Messenger, Telegram you need to use Dialogflow and the chatbot, create a new
Intent
with
rating
as
input Context
, nothing as
output Context
, a list of the user's most common messages for a positive rating as
Training phrases
(e.g. good, positive) and
{ "rating": 1, "force-message": true }
as
Custom Payload
response. For the negative rating create a new intent with same context but replace the training phrases and the custom payload to
{ "rating": -1, "force-message": true }
. The shortcode must include also a
title
or
message
.
Display a link or open an article. The attribute
target="_blank"
is optional and open the link in a new window. The attribute
style="link"
is optional and change the button design. To open an article on click the link value must be
#article-ID
, replace ID with the article ID.
Display a YouTube or Vimeo video. The value of the attribute
type
can be
youtube
or
vimeo
. The attribute
id
is the ID of the video, get it from the URL. The attribute
height
is optional and sets the video height in px.
You can create custom rich messages with your own custom content by going to
Settings > Miscellaneous
. Currently, custom rich messages are static and there are no interactive options available as there are with shortcodes. However, you can insert custom HTML codes.
HTML codes
When creating a custom rich message, you can use the following codes:
The allowed file attachments extensions are set in the supportboard/include/upload.php file. The following image formats are displayed automatically: .jpg, .jpeg, .png.
Add new allowed file extensions by adding the code
define("SB_FILE_EXTENSIONS", ["exe", "abc", ...])
to the
config.php
file of your OddoChat installation folder. Replace ["exe", "abc", ...] with an array containing the extensions you want to allow.
USERS
Manage Users
Manage users from the
Users area
in the left menu of the admin area.
Search users
You can search users by name, surname, email, and custom fields.
Delete users
You can delete a user by opening the
User edit box
and then clicking
Delete user
. To delete multiple users at once, select the users you want to delete from the Users table and then click the top right
Delete icon
.
When a user is deleted, all of their conversations and messages are automatically deleted permanently.
If a user of a deleted user come back to the website, a new user is automatically created.
Visitors are automatically deleted every 24 hours.
Additional user table columns
To display additional columns in the user table go to
Settings > Admin > Users table additional columns
and add the new columns. The value of each column is the slug of the user detail or extra user detail you want to display. The slug is lowercase and with spaces replaced by the char
-
. For example, the slug of the extra user detail "Date of birth" is "date-of-birth".
User types
Type
Description
user
A "user" is any user with an email.
lead
A "lead" is any user with no user details, who is automatically registered, and with at least one conversation.
visitor
A "visitor" is any user who has not started a conversation. Note: Visitors are automatically deleted every 24 hours.
Manage Agents
Manage agents from the
Users area
. An agent is a special user that can log in to the admin area and reply to all of the conversations. There are two types of agents: Agents. Admins are the only ones that can create new Agents; they also have access to the settings area. Agents can only manage users and conversations.
If you are using the WordPress version of OddoChat , an admin is created on plugin activation with the same user and password of the logged-in user.
Information
New users are automatically displayed in the user table in real time.
To view online users and receive the online user notification enable
Settings > Users > Register all visitors
.
To receive the online user notification you need to enable also
Settings > Miscellaneous > Pusher
.
The log-in form is shown only if the registration password field is shown.
The password field is always shown when the user system is set to "WordPress".
If
Settings> Users > Allow Duplicate Emails
is enabled and a user enters an already registered email, a new user is created and the email is removed from the old user. The new user will not have access to the old user's messages and conversations. You can also automatically log in a user via
URL parameters.
SETTINGS
Settings
Office Hours
You can set the office hours timetable from
Settings > Miscellaneous
. Office hours are used for:
Automatically displaying the timetable and a message when a user sends a message during out-of-office hours or if all agents are offline. To enable this feature set up the
Offline message
at
Settings > Messages > Offline Message
. The offline message is sent to the same user maximum 1 time per hour.
Disabling and hiding the chat during out-of-office hours.
Disabling the Dialogflow chatbot during regular office hours and enabling it during out-of-office hours.
More information
Blank values in the timetable settings are considered out-of-office hours.
The office hours are in UTC format. Your UTC is generated automatically when you click the field
Settings > Miscellaneous > UTF offset.
To manually get the UTC offset of your area, go to:
https://browserspy.dk/or
wikipedia.org/wiki/List_of_UTC_time_offsetsand copy the offset (e.g. for UTC −12:00, enter -12). Only integers are accepted. If your offset is not an integer (e.g. UTC -12:30 or UTC -12:45), try searching for an alternative UTC offset. If you can't find an integer offset, you will need to manually adjust the times in the office hours table to fix the gap.
The date and time format of the timetable matchs automatically the one used in the country of the browser language of the user.
The offline message is not sent automatically if
Settings > Dialogflow > Human takeover
is active. When the Dialogflow human takeover option is active, the offline message is sent only on human takeover.
The offline message is not sent is you're using the Slack app and you or any other agent is online via Slack.
Knowledge Base Articles
Knowledge base articles provide instant answers to customers to help reduce customer support volume. To manage the articles, go to
Settings > Articles
. Articles support HTML code, which can be used to add images, videos, and other content. Here are some HTML code examples that you can use:
The articles can be shown in the chat dashboard by enabling them from the
Settings > Chat
area.
The articles can be shown in a dedicated page by inserting the code
<script>var SB_ARTICLES_PAGE = true;</script>
into any page showing the chat. To set the location of the articles area Enter the code
<div id="sb-articles" class="sb-loading"></div>
. If you're using the WordPress version you can use the shortcode
[sb-articles]
.
Alternatively, articles can be shared via the rich message shortcode,
[articles]
.
More information
Translate the categories from
Settings > Translations
by adding the translation name and its translation.
If you use categories, only the articles assigned to a category are displayed.
If there is at least one translated article in the user's language, only the translated articles are displayed.
Articles are synchronized automatically with the Dialogflow knowledge base if the Dialogflow app is installed.
You can create an internal chat link to an article with the
button rich message.
OddoChat is fully multilingual and provides powerful features to detect the user's language on the fly.
Edit translations
To edit the languages of both chat and admin, go to
Settings > Translations
. Some settings, such as e-mail contents, are directly translatable and therefore do not need to be translated here.
Chat language
OddoChat is already translated into 41 languages. There are many options available to set the language:
OPTION 1
Go to
Settings > Chat
and check the
Translate automatically
option. This feature will automatically use the chat language of the user's browser.
OPTION 2 - PHP ONLY
Add the URL parameter
lang=LANGUAGE-CODE
to the script that loads the chat, replacing "LANGUAGE-CODE" with the two-letters language code you would like to display. Example:
https://board.support/supportboard/js/main.js?lang=en
. Go to
wikipedia.org/wiki/List_of_ISO_639-1_codesfor the complete languages code list (see column 639-1).
OPTION 2 - WORDPRESS ONLY
Go to
Settings > WordPress
and set the option
Force language
.
OPTION 3 - WORDPRESS ONLY
The WordPress version of OddoChat uses the default language of the WordPress installation; or the language of the current page or post if the website is multilingual. This feature is compatible with WPML, Polylang, and other multilingual plugins. Note: This feature is automatically disabled if the option
Chat > Translate automatically
is active.
Admin language
To translate the admin area follow the steps below:
Translate the texts in your language from the
Settings > Translations
.
To set the admin area language you have three options:
Activate the option
Settings > Admin > Automatically translate admin area
. This feature automatically translate the admin area to match the agent profile language or the agent browser language.
Edit the file
config.php
inside your OddoChat installation directory and Enter the code
define('SB_ADMIN_LANG', 'LANGUAGE-CODE');
at the end of the file content. Replace
LANGUAGE-CODE
with the language code of the language you want to use, use only 2 letters, for example, insert only
es
, not
es_ES
.
Translate custom contents
You can translate almost any custom content: rich messages, titles, descriptions, automatic messages, chat header, and more. To add translations, select the language you want and click the
New translation
button.
Add a new language
To add a new language, follow the steps below:
Via FTP or a File Manager, go to
supportboardresourceslanguagesfront
.
Duplicate (copy and paste it in the same directory) the
supportboardresourceslanguagesfrontsource.json
file.
Go to
Settings > Translations
and the new language should appear automatically.
To add a new language for the admin area, follow the exact same steps, but use folder
admin
instead. New languages will not be lost or deleted on plugin updates.
Information
If a translation string is missing, add it by clicking the button
Add new translation
.
If a translation string is not working, make sure to remove all white spaces and break lines at the start and the end of the string.
The translations edits are not saved in the database but directly in the translation files. When a translation is edited, and saved, a backup is created into the
uploads
folder. The backup is restored automatically on plugin update and plugin activation.
You can add missing translation strings also by code. Edit the language files located in
supportboardresourceslanguages
. Once you edited a file, the new strings will appear in
Settings > Translations
.
Departments
Departments give you the power to distribute conversations and assign various agents to specific departments. For example, you can create a department entitled "Sales" and assign specific conversations to that department. To start using departments, follow the steps below:
Go to
Settings > Miscellaneous
and add your required departments. After saving, reload the page.
Go to
Users > Agents
and edit an agent, you will see a new field where you can set the department of the agent.
Reload the page and you're done! In the
Conversations area
, you will now see an option to set the department.
Settings
Display in dashboard
Displays the departments' list in the chat dashboard and force users to choose a department before starting a conversation.
Display images
Displays the department image instead of the department color.
Label
Replace the label
Departments
(plural) with another text. The name is displayed in the admin and tickets area.
Label single
Replace the label
Department
(singular) with another text. The name is displayed in the admin and tickets area.
Dashboard title
Set the title of the chat dashboard list. Default: Departments.
How it works
Agents and admins can only access conversations, users, and agents that have been assigned to their specific department.
When an agent is assigned to a new department, an email notification is sent to all of the agents assigned to the new department.
The
General department
is global and gives agents access to all of the conversations within all departments. Also, all agents without a department are automatically assigned to the General department.
To automatically assign a department to the user conversations you can Enter the JavaScript variable
var SB_DEFAULT_DEPARTMENT = ID;
into the pages where the chat is displayed, replace ID with the department ID. For more details check the APIs
here.
Admins with no assigned department always see the conversations of all departments.
The chatbot can assign a department to the active conversation via
dialogflow actions.
How to assign a department
You can assign a department to a conversation in several ways:
Via
Settings > Miscellaneous > Departments settings > Display in dashboard
. This setting will force the user to choose a department when starting a new conversation.
Via
Settings > Automations > More
.
Via JavaScript the variable
var SB_DEFAULT_DEPARTMENT = ID;
. Enter the code into the pages where the chat is displayed and replace ID with the department ID. For more details check the API
here.
When the queue is activated via
Settings > Miscellaneous > Queue
, users enter into a queue automatically when an agent's chat limit is reached. When a user enters the queue, a message with the current position in the queue and the estimated waiting time is displayed. OddoChat automatically assigns the conversations to all available agents proportionately. When an agent marks a conversation as completed (by archiving it), the queue is updated and a new conversation is received.
More information
Only online agents are counted as "available" agents; only online agents will receive new conversations.
Admins are not included; admins always see all the conversations.
Agents must archive a conversation to mark it as completed; this will automatically give them access to the next conversation in the queue.
Agents can switch their status between online and offline by hovering over their profile image and then clicking the label of the profile pop-up at the bottom-left of the admin area.
Agents can only view their conversations; however, they can see all of the conversations of a single user.
Agents can only search and filter their conversations.
The waiting time is displayed in minutes and is calculated as follows: queue position X response time = waiting time. For example, if a user is 5th in the queue, and the response time has been set to 4 minutes (via Settings > Miscellaneous > Queue), then the total wait time displayed to the user will be 20 minutes.
If a user is in the queue and leaves (e.g. by closing the browser) for more than 1 minute, the conversation is saved; however, once the user comes back, the queue is reset and the user will lose their previous position.
The queue is compatible with the departments.
If Dialogflow human takeover is active, the queue is activated only on human takeover.
For conversations started from messaging apps like WhatsApp, it is not possible to respect the limit of conversations per agent, all conversations will be immediately and proportionally assigned to an agent.
Use
Settings > Messages > Offline message
to prevent the chat from showing the queue update message to the user.
When the sound option is active, a sound is played when it's the user's turn.
How to test the queue
To simulate multiple users and agents, open the chat in multiple different browsers (e.g. Opera, Firefox, Brave, Chrome, etc.). Each browser can simulate two users/agents: one in normal mode and one in "private" or "incognito" mode.
To reset the chat and start a new user session, open the browser console, enter
SBF.reset()
, and press
ENTER
.
Routing
When the routing is activated via
Settings > Miscellaneous > Routing
, OddoChat automatically assigns the users conversations to all available agents proportionately.
Information
Conversations are assigned to online agents first. If all agents are offline, conversations are assigned proportionally between all agents.
Conversations are assigned to agents with less active conversations. A conversation is active if it's not deleted, or archived. If routing is active, you should archive the conversations once completed.
Admins are not included; admins always see all the conversations.
Agents can switch their status between online and offline by hovering over their profile image and then clicking the label of the profile pop-up at the bottom-left of the admin area.
Agents can view only their conversations; however, they can see all of the conversations of a single user.
Agents can search and filter only their conversations.
The routing is compatible with the departments.
When routing is active agents can manually route conversations to other agents from the right panel of the conversations area.
If the conversation is archived and the user reopens it in the future by sending a new message, if the assigned agent in the conversation is offline, the conversation is assigned to another agent.
Manual routing
When the routing is activated via
Settings > Miscellaneous > Hide conversation of other agents
agents see only their own conversations and can select the unassigned ones.
Agents menu
: displays the agents' menu to assign the active conversation to another agent.
Routing if offline
: if the conversation is archived and the user reopens it in the future by sending a new message, if the assigned agent in the conversation is offline, the conversation is assigned to another online if there is at least one, otherwise to no agent.
View unassigned conversations
: allow agents to view the unassigned conversations, when an agent replies the conversation is automatically assigned to him and the conversation is removed in real-time from the admin area of the other agents. Check this option to enable the manual routing.
Email piping
Email piping lets you, your agents, and your users reply to chat messages via email.
Activation
To activate the email piping go to
Settings > Notifications > Email piping
and enter your POP3/IMAP email server information, then set the email address to use for the email piping in
Settings > Notifications > SMTP
and you're done! The email address must be the one to which the email piping server connects to. OddoChat will send all emails from this email address and you, your agents, and your users will reply to this email address.
Information
The setting
Notifications > User email notifications
must be enabled to send replies to the user email.
If you're using the Dialogflow App, and the settings
Settings > Dialogflow > Human takeover
is active, no emails are sent if the chatbot knows the answer.
If the setting
Convert all emails
is active, all emails sent to your inbox will be converted to chat messages, mind that all emails, including spam, promotional emails and more would be wrongly converted too.
If the setting
convert all emails
is active, email sent by email addresses of agents and admins will be ignored, use another email address for testing.
If the setting
convert all emails
is active, each email sent directly to the email piping address will generate a new user conversation.
You can not use the same email address used for the email piping to reply. All your OddoChat agents and admins must use a different email address.
Agents must reply via email from the same email address registered in OddoChat .
When agents reply in OddoChat, emails are always sent to the user, even if user email notifications are disabled.
The email is sent to the Agents only if they are offline. If they are online no emails are sent.
For Google Gmail and Google Workspace emails, you need to replace your Google password with a Google app password, details on
https://support.google.com/accounts/answer/185833(Create & use App Passwords section). Enter
imap.gmail.com
as host and
993
as port.
Email piping requires
php5-imap
module (IMAP module). If it's not installed on your server you can install it with the command
apt-get install php5-imap
. If you have issues contact your hosting/server support.
The
Delimiter
option add a text at the top of all emails:
### Please type your reply above this line ###
. This text tells OddoChat to delete all the content below it and it's usefult to cut out all of the reply quotes. Activate it if you see duplicated messages in the chat. If this option is active, you and your users can not use the string
###
in the emails.
Email attachments are supported.
In order for email piping to work, email replies must contain the OddoChat recipient's name. Ex.
OddoChat | SB2457-4734 <example@email.com>
. All major email clients like Outlook Web, Outlook, Gmail, Yahoo Mail, support the recipient's name by default via chatbot reply or reply all buttons.
Because of the nature of how emails work, each email client uses their personal codes, delimiters, and automatic strings, and more. For this reason, some chat messages converted from emails can contain invalid texts. We are working to optimize as many email clients as possible, for now, the following email clients are optimized and should not return any invalid text: Outlook Web, Outlook, Gmail, Yahoo Mail.
Email piping supports departments, if the user's conversation is assigned to a department, the email notifications are sent only to the agents assigned to that department.
Cron job
OddoChat tries to process emails via cron jobs every 60 seconds, details
here.
You can manually trigger execution and speed up cron jobs via API with the PHP function
sb_email_piping(), or the WEB API function
email-piping.
You can create a cron job that runs the URL
[SUPPORT-BOARD-INSTALLATION-URL]/include/api.php?piping=true
*. Use the command
*/59 * * * * wget [SUPPORT-BOARD-INSTALLATION-URL]/include/api.php?piping=true
to run it via a command. Replace
[SUPPORT-BOARD-INSTALLATION-URL]
with your OddoChat URL *.
You can also use this cron job file:
download. The cron job command is
php -f YOUR-FILE-PATH/cron.php
.
If you manually run the cron job, check the setting
Disable cron job
to stop OddoChat from manually triggering it and to improve performance.
*
If you are using the cloud version the URL is
https://cloud.board.support/script/include/api.php?piping=true&cloud=API-TOKEN
, replace API-TOKEN with your API Token (https://cloud.board.support/account/?tab=installation)
Pusher
Activate Pusher (recommended) to use the WebSockets instead of HTTP AJAX requests for the chat functionalities. WebSockets drastically improve the chat performance by removing the need for repeated AJAX requests to your server for checking for new messages and conversations. WebSockets also improve responsivness of the chat: faster messages delivery, more accurate online and typing status, more accurate online users list and more.
Enter the name of your app and choose the cluster closest to your location.
From the left menu of the dashboard click
App Settings
and enable
client events
.
From the left menu of the dashboard click
Keys
, copy
App ID
,
Key
,
Secret
,
Cluster
.
Go to
Settings > Miscellaneous > Pusher
, and paste app ID, key, secret, cluster.
You're done.
Information
Pusher is free to use for up to 200k messages and 100 concurrent connections per day. Messages are used for the following functions and more: user registration, online user status, chat messages, and chatbot messages. Pusher channels count calculation is explained
here.
When Pusher is active the following AJAX requests are replaced by WebSockets: checking for new messages, checking for new conversations, online/offline status, typing status, online users list.
When Pusher is active the
last activity
value of users and agents is updated only on page load or when they send new messages.
When Pusher is active the option
Settings > Users > Register all visitors
is automatically activated and it can not be disabled.
Direct messages
Direct messages allow you to send а single chat message, email, or text message, to a single user or several users. Read the information below to understand how it works.
General
To send a message go to the
Users
area and click the direct message icon. Direct message buttons are also available in the profile box of the user.
To send a message to all users, enter
All
in the
User IDs
field.
To send a message to a group of users, enter their IDs in the
User IDs
field. You can check the users and then click the direct message icon to enter the IDs automatically.
The chat message is sent to the active conversation, if any, otherwise to a new conversation.
If the option
Settings > User email notifications
is active, all users with an email are notified via email.
If the option
Settings > Text message notifications > Active for users
is active, all users with a phone number are notified via text message.
If the option
Settings > Push notifications
is active, a push notification is sent to all users.
The message is also sent to messaging apps such as WhatsApp and Messenger if the user is connected to them.
To send a message to all users of a single messaging app enter one of the following strings:
whatsapp
,
messenger
,
instagram
,
telegram
,
twitter
,
google
,
wechat
. Enter
tickets
to send a message only to the users who created a OddoChat ticket via the Tickets app.
Direct email
Email header and email signature are automatically included in all emails, set them from
Settings > Notifications
.
The HTML language is supported.
The subject supports merge fields.
Direct text messages
To enable direct text messages you must enable the SMS in
Settings > Notifications > Text message notifications
.
Automations
Automations allow running multilingual automatic tasks when conditions set by you are met.
To delete a condition, set it to empty. To disable an automation, delete all conditions.
Automations are sent only 1 time to users.
If you used an automation in the past, and users already received it, you need to delete the automation and create a new one to show it to the users.
Repeat
only works if used in conjunction with
date time
.
When
date time
is used in conjunction with the criteria
is exactly
, the value must not contain hours and minutes (hh:mm). Ex. 25/10/2021 (25/10/2021 10:30 will not work).
The setting
Settings > Users > Register all visitors
must be active if there are message automations that are executed on page load.
City
,
countries
,
languages
work automatically only if both the settings
Settings > Users > Register all visitors
and
Settings > Users > Full visitor details
are enabled.
Cities
work only if the user detail
location
is set and equal to
city, country
, or if the user detail
city
is set.
Countries
work only if the user details
country_code
, or
country
is set, or if the user detail
location
is set and equal to
city, country
. The country name must be in english.
languages
work only if the user details
browser_language
, or
language
is set.
A visitor is a
Returning visitor
only if it visits the website again after 24h or more.
The pop-ups appear only if the chat is closed, and they overwrite the default pop-up. You can check the
message fallback
option to send a message instead of showing the pop-up if the chat is open.
You may need to enable
Settings > Users > Register all visitors
if you want to send an automated message to new users.
Chat messages and popup fallback messages are sent only if the last user or agent message of the conversation is older than 10 minutes. This feature prevents unwanted automated messages to be sent during an agent-user conversation.
The
Custom variable
condition check for the JavaScript variables with the given names and values. For example, the condition
example=ABC
is met if into the chat's page there is this JavaScript code:
var example = "ABC";
. Add multiple variables separated by commas.
Newsletter
Follow the steps below to complete the synchronization with your newsletter service. The user is subscribed in the following cases: registration form, user update, follow-up message, subscribe message, email shortcode.
To get the
List ID
, enter in SendGrid and click
Marketing > Contacts
(
https://mc.sendgrid.com/contacts), then click on a list, or create a new one. The last part of the URL is the list ID. Ex. https://mc.sendgrid.com/contacts/lists/8558c1e7-3c99-4428-a68f-78df2e437f8e (the list ID is 8558c1e7-3c99-4428-a68f-78df2e437f8e).
Elastic Email
To get the
Key
, enter in Elastic Email, then click
Settings
from the top right profile menu. Click
Create Additional API key
(
https://elasticemail.com/account#/settings/new/create-api), set a name and choose
Plugin
or
Full access
, or
Custom
and make sure the permission
Contacts
is set to
View & Modify
.
The
List ID
is the list name. Important! Existing list's or segment names must not have any spaces in them.
Campaign Monitor
To get the
Key
, enter in Campaign Monitor, then click
Account settings
from the top right profile menu. Click
API keys > Generate API key
.
To get the
List ID
, enter in Campaign Monitor, then click
List and subscribers
from the top menu. Select a list and then click
Settings
from the left menu and copy the
List API ID
.
HubSpot
To get the
Key
, enter in HubSpot, then get it from
Settings > Integrations > API key
.
To get the
List ID
, enter in HubSpot, then get it from
Contacts > List > List details
.
Moosend
To get the
Key
, enter in Moosend, then click
Settings > API key
.
To get the
List ID
, enter in Moosend, then get it from
Audience > Email lists
.
GetResponse
To get the
List ID
, enter in GetResponse, then get it from
Lists > Your list > Settings
(https://app.getresponse.com/lists). Copy the
List token
value.
To get the
Key
, enter in ConvertKit, then get it from
Settings > Advanced > API secret
.
To get the
List ID
, enter in ConvertKit, then get it from
Grow > Landing Pages & Forms
. Open you form and copy the numeric part of the URL. For example the ID of the form with URL
https://app.convertkit.com/forms/designers/3003412/edit
is
3003412
.
ActiveCampaign
To get the
Key
, enter in ActiveCampaign, then get it from
Account settings > Developer
.
To get the
List ID
, enter in ActiveCampaign, then get it from
Left menu > Lists
or
Left menu > Contacts > Lists
. Open your list and copy the list ID in the URL. For example the ID of the list with URL
https://schiocco.activehosted.com/app/contacts/?listid=1&status=1
is
1
. The list ID must be in this format:
domain:list-ID
. The
domain
is the first part of your dashboard URL. For example the domain of
https://schiocco.activehosted.com/
is
schiocco
and the final value to insert in OddoChat is
schiocco:1
.
MailerLite
To get the
Key
, enter in MailerLite, then get it from
Left menu > Integrations > MailerLite API
.
To get the
List ID
, enter in MailerLite, then get it from
Left menu > Subscribers > Groups
. View a group and copy the Group ID from the URL (e.g.
....group=18783408688903967...
).
To get the
List ID
, enter in MailerLite, then get it from
Contacts > Contacts lists > Your list
. Get the List ID by clicking the
?
icon next to the lists's email. E.g. 1202546.
Enter the
IAM
dashboard and click
Left menu > Access management > Users
.
Click
Add new user
, enter the username and continue.
Select
Add user to group
and on the
User groups
section below click
Create group
. In
Permissions policies
search for
AmazonS3FullAccess
and select it. Click
Create user group
.
Assign the new group to the user you are creating and continue, then click
Create user
.
Select the newly created user and open the
Security credentials
tab.
In the
Access keys
area, click
Create access key
and select
Application running outside AWS
. Continue until you get the keys and save them in
OddoChat > Settings > Miscellaneous > Amazon S3
.
Visit the
Amazon S3
dashboard and click
Create bucket
.
Set the bucket name and region you want. Save the region and name in
OddoChat > Settings > Miscellaneous > Amazon S3
. Check
ACLs enabled
and
Bucket owner preferred
. Uncheck
Block all public access
and all related checkboxes.
Click
Create bucket
.
This feature is technical and optional. Support does not cover any help related to this feature.
NOTIFICATIONS
Notifications
To understand how notifications work and when they are sent read the information below. If you think notifications are not working, most probably you're just testing them in the wrong way, please read the information below before asking for support.
Email notifications
Both agents and users can receive an email notification when a new message is received.
Email notifications for admin and agents
When a user sends their first message, if the conversation is assigned to a department, an email is sent only to the agents assigned to that department, if the conversation is assigned to a specific agent, an email is sent only to that agent, otherwise an email is sent to all agents who are not online at the moment. Subsequent emails are sent only to the last agent in the conversation.
Email notifications are sent only if the last agent in the conversation is offline.
If you're using the Dialogflow App, and
Settings > Dialogflow > Human takeover
is active, no emails are sent if the chatbot knows the answer.
If you don't receive the emails make sure they are working by sending a test email from
Settings > Notifications > Test user email
or
Test agent email
. If you don't receive the test email, your server, or your SMTP server, is not working. Open the browser console for more details about the error. Because this is not an issue related to OddoChat , the support doesn't cover it, please contact your server/hosting/SMTP support instead.
Email notifications for users
When an agent sends a message to a user, an email is sent to the user only if the user is offline.
Only 1 email is sent. Subsequent messages will not trigger a new email alert.
Create the email
To manage the emails and create the contents go to
Settings > Notifications
. You can use text and HTML. New lines are automatically converted to
<br />
. You can use the following merge fields in the email. Merge fields are automatically replaced with the updated information.
Code
Description
{recipient_name}
The name of the user or agent who is receiving the email.
{sender_name}
The name of the user or agent who was sending the message that triggered the email notification.
{sender_profile_image}
The profile image of the user or agent who was sending the message that triggered the email notification.
{message}
The links to any attachments that were part of the message that triggered the email notification.
{attachments}
Emails may not be delivered for several reasons; below are the most common ones:
Problems?
Emails may not be delivered several reasons; below are the most common ones:
Reason
Description
Solution
Hosting problems
The email server of your web hosting provider is not able to send emails or the emails are sent but are automatically detected as spam and deleted by the email clients.
Please contact your web hosting provider regarding email support or use your SMTP server by activating it in
Settings > Notifications > SMTP
.
SMTP problems
The email is not sent also if you activated the SMTP option in the
Notifications
area.
We don't provide support for problems related to your SMTP. Send a test email to get details about the issue or use
sendgrid.com, you can send 40000 emails for 30 days for free, then 100/day forever for free. Note: if you're using Gmail enter
smtp.gmail.com
as host and set
465
or
587
as port. You need also to allow access to Gmail to less secure apps, you can do it from
https://myaccount.google.com/lesssecureapps.
Push notifications
Push notifications are like Desktop notifications but with some key difference. Desktop notifications, also called Web notifications, are requested directly by the client while Push notifications come from a server. The main difference is that the Push notifications work always, also if your device is offline, or OddoChat is not open. Also, they are persistent and always visible until closed. Push notifications require an external service to work. We use Pusher, it is free to use for the admin notifications sent to the agents, and it's free to use for up to 2000 users/devices when sending notifications to the users. Unfortunately, Apple has yet to provide iOS support, but we hope it will come soon.
Upload this file to your site at the following location:
https://your-site.com/service-worker.js
Go to
Settings > Notifications > Push notifications > Service Worker URL
and enter the URL of the file. Ex.
https://your-site.com/service-worker.js
. If you are using the cloud version, enter
https://cloud.board.support/sw.js
. If you are using the SaaS version, replace
cloud.board.support
with your domain.
You're done.
Information
Pusher is free to use for up to 1000 concurrent subscribers. While you should be able to use the free plan for the admin area and all the agents, you may need a paid plan for Push notifications sent to the users depending on your site traffic.
Push notifications are currently not supported on iPhone and iOS devices. Push notifications are supported only on Mac, Windows, and Android devices.
Push notifications only work for full HTTPS websites. The only exception is localhost to ease development.
When a user click the notification the last page visited by the user is open and the chat is open automatically.
On desktop the browser needs to be running since that is the process that receives the push messages.
When push notifications are active, they replace desktop notifications.
On Android and mobile devices, desktop notifications may not work, in which case you need to use push notifications.
If Push notifications are active and not working, disable them and try again.
Push notifications can not be received on a desktop PC unless a browser is running.
Push notifications for admin and agents
When an agent click the notification the admin area is open and the right conversation is selected. If the admin area is already open the notification will not open a new tab.
When a user sends their first message, a Push notification is sent to all validated agents; subsequent notifications are sent only to the last agent in the conversation.
If you're using the Dialogflow App, and
Settings > Dialogflow > Human takeover
is active, no notifications are sent if the chatbot knows the answer.
If you're using the WordPress version, Push notifications are not supported in the WordPress admin area, you need to access the OddoChat admin area directly, more details
here.
If the
Routing
setting is active, only the agent assigned to the conversation receive the notification, admins see all conversations but don't receive notifications.
If the
Queue
setting is active, only the agent assigned to the conversation receive the notification. Notifications are not sent for messages sent by the user while waiting in queue. Admins see all conversations but don't receive notifications.
If a user conversation is assigned to a department, only the agents assigned to that department receive the notification.
If a user conversation is not assigned to any department, only agents with no assigned department receive the notification.
Notifications are not supported on iPhone and iOS devices.
Notifications are sent only if the last agent in the conversation is offline.
and
Settings > Dialogflow > Human takeover
is active, no notifications are sent if the chatbot knows the answer.
If push notifications are not working, make sure you allowed the notifications, in Chrome you can check this from
Privacy and Security > Site settings > Notifications
. If they don't work on a mobile device, try these steps too: install the PWA or delete it and install it again, restart the mobile device.
Desktop notifications
Desktop notifications
Notifications are not sent if the user is viewing a page with include the chat (the user browser is open and visible, and the active page contains the chat).
Notifications are not supported on iPhone and iOS devices.
Notifications work only for secure URLs that use HTTPS (not HTTP). Your OddoChat admin URL must use HTTPS.
When push notifications are active, they replace desktop notifications.
Text message notifications
Both agents and users can be notified via text message when a new message comes in. Text message notifications are provided by Twilio. Twilio is a paid service, but it is cheap, and you can use the trial version to test text message notifications for free.
Once into the dashboard, click
Get a Trial Number
, then
Choose this number
.
Enter the OddoChat admin area, go to
Settings > Notifications > Text message notifications
, and paste account SID, auth token, trial number (or a purchased phone number). Find all details in the
Twilio dashboard.
If you're using the trial version, you can send notifications only to verified numbers. Enter the Twilio dashboard and click the left button
# (Phone Numbers)
, then click
Verified Caller IDs
and add your phone number.
To start using the service live and to receive text messages in OddoChat you need to purchase a phone number. After the purchase go to
Phone numbers > Manage > Active numbers
, click your number, and enter the URL of OddoChat , get it from
OddoChat > Settings > Notifications > Text message notifications > Get configuration URL
.
You're done.
Information
All phone numbers must have the country code starting with the symbol
+
(eg. +15558675310).
You can get the user's phone number via registration form, follow-up message, subscribe messageor, or via
[email]
shortcode. You can manually enter the user phone from the admin area or via API.
When a user sends their first message, if the conversation is assigned to a department, a test message is sent only to the agents assigned to that department, if the conversation is assigned to a specific agent, a text message is sent only to that agent, otherwise an text message is sent an email is sent to all agents who are not online at the moment. Subsequent text messages are sent only to the last agent in the conversation.
Text message notifications are sent only if the last agent in the conversation is offline.
If you're using the Dialogflow App, and
Settings > Dialogflow > Human takeover
is active, no text messages are sent if the chatbot knows the answer.
To use the Sender ID feature enter the sender name in the
Sender number
field.
Sound notifications
Sounds work only after the user or agent interact with the document (the user or agent clicked somewhere).
WORDPRESS
WordPress
The settings below are related to the WordPress version of OddoChat.
User Synchronization
WordPress users can be automatically synchronized with OddoChat by selecting "WordPress" under the
Users system
in the
Settings > WordPress
area. When active, the front-end chat automatically recognize all logged-in WordPress users and create a new OddoChat user account with the same details (name, surname, email, and password). Also, the log-in form recognize the email and password of each WordPress user. On OddoChat login, the user is automatically logged in WordPress as well.
To create a WordPress user when a visitor register to OddoChat enable the option
Settings > WordPress > WordPress registration
and include password and email fields in the registration form, they are required. The WordPress user if logged in automtically.
More information
Direct access and PWA
You can access the admin area directly without going through WordPress by navigating to
/wp-content/plugins/supportboard/supportboard/admin.php
and logging in with your default WordPress user or agent email and password. Keep in mind that your wp-content folder might be different. By accessing the admin directly, you will also be able to use the admin area as a Progressive Web App. You can find more details on this by clicking
here.
Login and logout
To logout from the admin area of OddoChat , logout from WordPress from the admin area of OddoChat , once logged-out you will be able to login with another WordPress account. To access the admin area from within WordPress you must log in with one of the following WordPress user roles: administrator, author, editor.
Get a page or Post Type ID
To get the ID of a specific page or Post Type, go to the admin area of WordPress and edit the page or post. The ID is displayed in the address bar. Example:
http://your-site.com/wp-admin/post.php?post=11&action=edit&lang=en
(the page/post ID is equal to 11).
Get a Post Type slug
The Post Type slug of the blog archive and posts is
post
. The Post Type of the pages is
page
. To obtain the slug of a custom Post Type, go to the admin area of WordPress and open the custom Post Type page from the left menu. The slug is displayed in the address bar. Example:
http://your-site.com/wp-admin/edit.php?post_type=food
(the slug is
food
).
Disable WordPress Emoji
The prevent WordPress from replacing the chat emiji with the WordPress ones Enter the code below in the file
functions.php
of your theme.
If you have multisite installation, you must install OddoChat in the main website.
WOOCOMMERCE
WooCommerce
The settings below are related to the WooCommerce App for the WordPress version of OddoChat .
Dialogflow
Getting started
To start using the Dialogflow chatbot go
Settings > WooCommerce > Dialogflow synchronization
and click
Synchronize entities now
, then click
Create Intents now
. Once the synchronization is completed you're done. The chatbot will start replying to the users' questions.
Built-in Intents questions list
By importing the built-in Intents the chatbot can answer the questions like the below ones. For the full list please visit the Intents area of the Dialogflow console.
Do you sell any shoes for less than $299?
Show me your bags
Do you have anything for women in promotion?
What are the best shoes of 2020?
Add Abstract Print to the cart
Remove Abstract Print from the cart
What do you sell
What's the status of my order?
Where my order will be shipped?
Display the products in my cart!
Do you ship in Australia?
Where do you ship?
Open the shoes page.
Go to the cashmere tank page, please.
Actions
The following actions allow the chatbot to interact with the shop autonomously on behalf of the user. To use an action go to Dialogflow, edit an
Intent
, and add a new
Custom Payload
response with the following syntax:
{ "ACTION-NAME": ACTION-VALUE }
.
Removes a product from the user's cart. Replace PRODUCT-NAME-OR-ID with the ID or full name of a product.
{ "woocommerce-checkout": true }
Redirects the user to the checkout page.
Multilingual
The multilingual feature is compatible with WPML and Polylang plugins.
To activate the multilingual feature go to
Settings > WordPress > Multilingual plugin
and choose WPML or Polylang. The synchronization automatically creates the Entities in all available languages of your website. For a language to work, the chatbot must be translated into that language in Dialogflow, more details
here.
The built-in Dialogflow Intents are only in English, to translate them go to your
Dialogflow Console, choose the language you want to translate, go to the
Intents
page, and translate the existing WooCommerce Intents.
If you edit an existing built-in WooCommerce Intent in Dialogflow and then you import again the intents from
Settings > WooCoommerce > Dialogflow synchronization
you will lose your customization. To keep your edits change the Intent name.
The chatbot can display up to 15 products via the slider rich message.
The chatbot is automatically updated every 60 min by default, but it can take longer. If you update a product, category, tag, or attribute, please wait a few hours for the new contents to take effect.
The synchronization detects the following events: product deleted, product restored from trash, product updated, new product added, product deleted, category or tag deleted, category or tag updated, new category or tag added.
To improve the chatbot add all the possible variants of an attribute, including the variants not used in your products. Example: if you sell only yellow and red t-shirts add all possible colors to the attribute color, not only yellow and red.
You can manually synch the chatbot at any time from
Settings > WooCommerce > Dialogflow synchronization
Products must have the
Regular price
attribute set.
Products names must not use the double-quote char:
"
.
Some multilingual feature is not compatible with
sub-domains
or
external domains
language URLs.
Merge fields and shortcodes
The following merge fields and shortcodes can be used in emails and messages.
Code
Description
Compatibility
{product_images}
Slider of product's images. If there are no results, the full message is replaced by "No results found".
Dialogflow
{shipping_location_check}
Check if the store ship in the given country.
Dialogflow
{product_attribute_terms}
Attribute terms list of a product's attribute.
Dialogflow
{product_attribute_name}
Attribute name of an attribute term.
Dialogflow
{category_link}
Category page link.
Dialogflow
{tag_link}
Tag page link.
Dialogflow
{product_name}
Product name.
Dialogflow, Automated Messages
{product_image}
Product image.
Dialogflow, Automated Messages
{product_price}
Product price.
Dialogflow, Automated Messages
{product_description}
Product description.
Dialogflow, Automated Messages
{product_rating}
Product rating. If the product has no ratings yet, the full message is replaced by "[product name] has no ratings or reviews yet.".
Dialogflow, Automated Messages
{product_link}
Product link.
Dialogflow, Automated Messages
{shipping_locations}
List of the shipping countries.
Dialogflow, Messages, Automated Messages
{shop_link}
Shop link.
Dialogflow, Messages, Automated messages
{cart_link}
Cart link.
Dialogflow, Messages, Automated Messages
{cart}
List of the products in the user's cart. If the cart is empty, the full message is replaced by "Your cart is currently empty".
Dialogflow, Automated Messages
{order_status}
Status of the last user's order. If the user has never placed an order, the full message is replaced by "You haven't placed an order yet".
Dialogflow, Automated Messages
{order_details)
Details of the last order user's order. If the user has never placed an order, the full message is replaced by "You haven't placed an order yet".
Dialogflow, Automated Messages
{product_card}
Product card. Optional attributes:
id
The product ID.
link-type
The action on user click. Available values: purchase, checkout, link. Default: purchase.
link-text
The button text. Default: Purchase.
Dialogflow, Messages, Automated Messages
{products_slider}
Search for the products matching the given attribures and display them in a slider of products cards. If there are no results, the full message is replaced by "No results found". Optional attributes:
id
The products IDs separated by commas. If this attribute is setted, all other attrbutes are ignored.
tag
Display only the products of the given tag.
category
Display only the products of the given category.
discounted
Set it to true to show only the products in promotions.
rating
Display only the products with a rating equal or bigger than the given value. Enter a value from 1 to 5.
max-price
Display only the products with a price equal or smaller than the given value. Enter a number.
min-price
Display only the products with a price equal or bigger than the given value. Enter a number.
attribute
Display only the products with the given attribute term.
link-type
The action on user click. Available values: purchase, checkout, link. Default: purchase.
link-text
The button text. Default: Purchase.
language
The language code of the products to display.
Add a product or multiple products to the user's cart. Optionally apply a coupon code, and redirect the user to the checkout page.
More information
Waiting list
The message is sent automatically when a user visits a page of a product that's out of stock.
The message is sent automatically when a user tries to purchase a product that's out of stock via the chatbot.
The message is sent a maximum of 1 time every 24 hours for each out of stock product.
If the user'email is not set, the chat asks for the user' email automatically.
Removed item from cart notification
If the coupon is included, the chat message is sent only for the first removed item, then again after coupon expiration.
The coupon is valid only for the removed items.
The following merge fields can be used in the email subject too: {coupon}, {discount_price}, {original_price}, {product_names}, {customer_name}.
Only the users with an email will get notified via email.
Returning visitors notification
The chat message is sent after 15 seconds.
The chat message is sent to the active conversation, if any, otherwise to a new conversation.
A visitor is a "returning visitor" only if at least 24 hours have passed since the last visit.
The chat message is sent only 1 time, if the visitor returns again, the message is not sent.
Follow-up message
If the message contains a coupon, the message is sent only if there are no other valid coupons assigned to the user.
Miscellaneous
When a visitor completes a purchase, a new OddoChat user with the details provided in the checkout form is automatically created.
The automatic messages(abandoned cart message, follow-up messages, ...) are sent to the active conversation, if any, otherwise to a new conversation.
The default coupon values are 0% discount and 7 days expiration.
Coupons in the trash are still valid, you must permanently delete them.
All coupons can be used only 1 time.
Expired coupons are deleted automatically via cron jobs.
The products pop-up of the admin conversations area search by product name, description, and price.
The products pop-up of the admin conversations area is multilingual and displays automatically the products of the user's language if available.
To view orders of guest users who did not send any chat message before the purchase you need to enable
Settings > Users > Register all visitors
.
The setting
Ticket products selector > Exclude products
accepts WooCommerce product IDs separated by commas.
WhatsApp shop
To allow a user to purchase your WooCommerce shop products on WhatsApp the
product ID
of your WhatsApp shop products must be the same as the
product ID
of your WooCommerce products. Once the user has sent the WhatsApp order, WooCommerce automatically saves it, use the merge field
{catalog_checkout}
to send the user the checkout link.
The settings below are related to the Tickets App.
Installation and usage
PHP installation
To display the tickets area include the following script into your page.
<script src="/users/u14/14400/imports/7912/docs/supportboard/js/min/jquery.min.js"></script> <!-- Not required if jQuery is already loaded -->
<script id="sbinit" src="supportboard/js/main.js?mode=tickets"></script>
You can not include both chat and tickets area on the same page. Make sure to remove the script that loads the chat. You can show the tickets area also by inserting the code
<script>SB_TICKETS = true;</script>
into any page showing the chat.
To set the position of the tickets area Enter the code
<div id="sb-tickets"></div>
. The tickets area will be displayed inside this div element. By default, the tickets area is appended to the
body
.
WordPress installation
To display the tickets use the shortcode
[sb-tickets]
. Insert it in any page, post, or post type item.
Cloud version installation
To display the tickets area include the cloud chat script into your page and add the attribute
&mode=tickets
to the script URL, e.g.
<script id="chat-init" src="https://cloud.board.support/account/js/init.js?id=65895623&mode=tickets"></script>
. You can show the tickets area also by inserting the code
<script>SB_TICKETS = true;</script>
into any page showing the chat.
Information
Tickets are the same of chat conversations and messages, the only difference from the chat is the front-end panel.
Most of the settings of the chat are compatible with the Tickets App but not all of them. The dashboard settings, the pop-up message, and more are not compatible.
Dedicated APIs for the Tickets App are available in the API section.
To remove the mandatory 'New ticket' form for new users, activate the welcome message of
Settings > Messages > Welcome message. The welcome message delay is ignored in the tickets area, the message is sent immediately.
.
To manually disable the mandatory registration only on a single page use the JavaScript code
var SB_REGISTRATION_REQUIRED = true
. Set it to
true
to force the registration instead.
DIALOGFLOW
Dialogflow
The settings below are related to the Dialogflow App.
Synchronization
To start using Dialogflow with OddoChat follow the steps below.
Activate the Dialogflow API by entering
Dialogflow API
on the top search bar. Click
Dialogflow API
and then click
Enable
.
Create your first project by clicking the
Select a project
button on top-left.
Name the project as you want.
Select the project and the go to
Left menu > APIs and services > OAuth consent screen
. Select
External
and click
Create
.
In
App name
enter what you want, in
User support email
and
Developer contact information
enter your email. Click
Save and continue
.
In the scopes area, click
Add or remove scopes
, scroll bottom and into the
Manually add scopes
area enter
https://www.googleapis.com/auth/dialogflow,https://www.googleapis.com/auth/cloud-language,https://www.googleapis.com/auth/cloud-translation
. Click
Add to table
and then
Update
and
Save and continue
.
In the test users area, click
Add users
and add your Google email, use the same email as the currently logged in account. Click
Save and continue
.
Go to
Left menu > APIs and services > Credentials
and click
Create credentials
, select
OAuth client ID
.
As
Application type
select
Web application
. Enter any name you want. In
Authorised redirect URI
enter the redirect URL, get it from
OddoChat > Settings > Dialogflow > Synchronization > Authorised redirect URI
. Click
Create
.
Copy
Client ID
and
Client Secret
and paste them into
OddoChat > Settings > Dialogflow > Synchronization
. Save the settings.
Click
OddoChat > Settings > Dialogflow > Synchronization > Synchronize
. Login with the same Google account you have used till now. On the next screen click
Continue
.
On the next screen select all scopes and click
Continue
.
Copy the
Refresh token
and paste it into
OddoChat > Settings > Dialogflow > Synchronization > Refresh token
.
You are almost done! Now you have to enter your chatbot Project ID or Agent Name, to get it follow the
steps below. Note that the app does not need to be approved by Google.
Get Project ID
Log in to the Dialogflow ES console by going to
dialogflow.cloud.google.com. You must sign in with the same Google account used during the synchronization.
Click the
gear icon
at the top left, near the chatbot name, and open the settings area.
. If you haven't created a chatbot yet, follow the
instructions belowto create your first bot.
Copy the
Project ID
.
Make sure to choose
US / GLOBAL
on the top left of the Dialogflow dashboard
.
Select the project of the desidered agent and go to the agents page. You can enter the agents page by selecting the agent and by clicking the top button
Agents > View all agents
.
Click the options menu for the desiderate agent in click
Copy name
.
If you haven't created a chatbot as of yet, follow the instructions below to create your first bot. The creation and management of your Dialogflow chatbot is handled entirely by Dialogflow. There are a lot of tutorials online that can help you create and configure your Dialogflow bot.
Create a basic chatbot
To create your first chatbot enter the
Dialogflow consoleand create an agent. As
Google project
select the same project used during the synchronization.
Add a new
Intent
from the left menu and open it.
In the
Training phrases
area adds the user's question you want the chatbot to reply to, add as many variants are you can. For example, if you want to the chatbot to reply to users asking for your business address, add variants like "what is your address", "address", "where are you".
In the
Responses
area adds the bot answer as a
text response
.
You have created your first question and answer! Test if from the right area or from the OddoChat chat. Add new Intents to populate your chatbot with the questions and answers you want. You can include basic pre-built questions and answers by enabling the
Small Talk
feature from the left menu.
Here are some great resources to help you build a more complex chatbot:
The following actions give the chatbot the ability to interact with the website autonomously on behalf of the user. To use an action go to Dialogflow, edit an
Intent
, and add a new
Custom Payload
response with the following syntax:
{ "ACTION-NAME": ACTION-VALUE }
.
Action code
Description
{ "human-takeover": true }
Disable the chatbot for 5 minutes, notify agents, and leave the conversation marked as unread.
{ "disable-bot": true }
Disable the chatbot for 5 minutes.
{ "redirect": "URL" }
Redirect the user to the given URL. Add the value
"new-window": true
to open the URL in a new window.
{ "open-article": ID }
Open the article with the given ID.
{ "transcript": true }
Generate the conversation transcript as a text file and download it. Set it to
email
to send the transcript to the user's email, add the value
message: "Your message"
to include a message in the email.
{ "department": ID }
Change or set the conversation department and notify the agents.
{ "agent": ID }
Change or set the agent assigned to the conversation and notify the agent.
Send an email to the active user or agents. Attachments syntax:
[["name", "link"], ["name", "link"], ...]}
. Recipient value can be
active_user
or
agents
.
{ "update-user": true }
Tells the admin area to update the user of the active conversation. Use this action in combination with other actions to update the user details of the admin area in real-time.
{ "archive-chat": true }
Archive the chat and send the close message if active.
Update the details of the active user. You can update all details, including
first_name
,
last_name
,
email
,
user_type
,
password
You can update the user extra details, like the phone number, by entering the values into the
extra
key, the values must use the following syntax:
"slug": [value, "label"]
. Download an example
here. To upload an Intent go to the
Intents
area and click the 3-dots menu icon on the top-right, then click
Upload Intent
. Start the conversation by sending the message "start".
Automatic Translation
To enable the language detection feature and automatic translation of agent messages to the language of the user, and user messages to the language of the agent, check the option
Settings > Dialogflow > Automatic translation
and synchronize Dialogflow. The Google account used for the Dialogflow synchronization must have billing and the
cloud-translation
service enabled, to do that follow the steps below:
On the top search bar type
cloud translation
, select the
Cloud Translation API
service and enable it. Please note that this is a paid service with a free tier, additional charges may occur.
Enable the billing by clicking
Left menu > Billing
and by enabling a billing account with a valid payment method. Enable billing for the project of your Dialogflow agent.
Once you completed the Google account setup the automatic translations start working immediately. Here more details:
The user messages in the admin area are translated automatically in real-time to match the agent language.
The agent messages are translated automatically in real-time to match the user language.
Agents can view the original message by opening the message menu and by clicking
View original message
.
The agent language is based on the
language
user detail of the agent if set, otherwise on the browser language, or admin area language.
The user language is based on the
language
user detail of the user if set, otherwise on the browser language, or it can be detected with the feature
Setting > Dialogflow > Language detection
.
Language detection
The user message must be at least 2 words long.
Language detection is executed only for the first 2 user messages of a conversation.
Human Takeover
General information
When the human takeover is activated the chatbot is automatically disabled for as long as the agent is online. After that, the chatbot is activated again but no default fallback messages will be sent within 10 days of human takeover if the chatbot doesn't know the answer to the user's question in the same conversation. You can force a Dialogflow message to be always sent by adding to the Intent the custom Payload value
"force-message": true
.
The chatbot is fully activated again when the conversation is archived or deleted.
If you're using Slack, no messages will be sent if the chatbot knows the answer. Once the human takeover is active all conversation's messages are sent to Slack.
When a human agent reply to a user the human takeover is activated automatically.
Human takeover option
When the option
Human takeover
is active the following happens:
If enabled, the request is sent only if the message sent by the user is longer than 3 chars and contains at least two words. This optimization prevents mistaken requests.
The conversations to which the chatbot was able to answer correctly, are marked as read and moved at the bottom of the
Inbox
list.
When the user confirms the human takeover, or if it is automatic, the following happens:
The conversation is marked as unread and moved on top of the
Inbox
.
Any future user messages in the same conversation sent within 10 days of the human takeover, and without an answer from the bot, will trigger agent notifications.
If agents email notifications are active, an email notification is sent to the agent assigned to the conversation, or, if the user's conversation is assigned to a department, to the agents assigned to that department, otherwise it is sent to all offline agents.
If push notifications are active, a push notification is sent to the agent assigned to the conversation, or, if the user's conversation is assigned to a department, to the agents assigned to that department, otherwise it is sent to all offline agents.
If text message notifications are active, a text message is sent to the agent assigned to the conversation, or, if the user's conversation is assigned to a department, to the agents assigned to that department, otherwise it is sent to all offline agents.
No human takeover requests within 10 days of the human takeover will be sent in the same conversation.
If
Settings > Message > Follow up message
is active, the message requesting the user's email is sent only if the user does not have the email.
If
Settings > Messages > Offline Message
is active, the offline message is sent only if it is not office hours or if all agents are offline.
If
Settings > Miscellaneous > Queue
is active, the queue is activated.
Manual human takeover
You can manually trigger the human takeover by creating a new
Intent
with the following
Custom Payload
response:
{ "human-takeover": true }
.
The manual takeover automatically notify agents via email and leave the conversation marked as unread.
To manually send a human take over request use the chips rich message with ID
sb-human-takeover
. Ex.
[chips id="sb-human-takeover" options="Human support,Cancel" message=""]
.
WhatsApp, Messenger, Telegram
The make the human takeover request work on WhatsApp, Messenger, Telegram you need to create a new
Intent
with
human-takeover
as
input Context
, nothing as
output Context
, a list of the user's most common confirmation messages as
Training phrases
(e.g. ok, yes) and
{ "human-takeover": true }
as
Custom Payload
response
.
Smart Reply
Smart Reply suggests quick responses in real-time during a conversation. Once active, you will see the suggested replies in the conversation area, if any. There are two ways to populate the suggestions: via bot, via agent Assist.
Bot Suggestions
To use the bot's suggestions just sync Dialogflow normally and train the chatbot as usual. The same chatbot used for the users will be used.
Agent Assist Suggestions
Agent Assist requires techincal knowledge in order to work and it's intended only for enterprise business with a data set of at least 30.000 conversations. If you never used Agent Assist you most likely don't have the knowledge and data to use it, and so you can ignore it. More details at
https://cloud.google.com/agent-assist/docs/conversation-profile.
Information
Smart reply first look for a suggestion from the bot, if there is at least one it returns the results, otherwise look for the suggestion via the agent assistant if available. The agent assistant is never used if the chatbot gives at least one hint.
OpenAI
OpenAI (ChatGPT) integration gives your chatbot the ability to answer general questions about almost anything you can imagine. To start using it, follow the steps below.
When this option is active, OpenAI will generate new user expressions in real time when you open the
Dialogflow Intent
window by clicking the
Send to dialogflow
menu item of a message in a conversation.
Generate user expressions - Button
When you click the button
Generate user expressions
, openAI will update your Dialogflow agent and generate new user expressions for each Intent.
Make a backup of your Dialogflow agent first.
This task can take several minutes or even hours if your chatbot has a lot of Intents. Since the operation takes a long time, your server may interrupt the operation (operation timeout) before it finishes, in which case you need to click the button again. You can verify if the operation is interrupted by checking the browser console for errors.
This task is performed only once per Intent. Previously processed Intents will be ignored.
This task checks existing user expressions and does not create duplicates.
The first 5 user expressions will be used to generate new user expressions.
Since this is an automated process, we strongly recommend reviewing your Intents after the task has been completed.
Information
The OpenAI query is performed only if the chatbot does not know the answer to the user's question and if the length of the user's message is greater than 6 characters.
Google search
The Google search features give your chatbot the ability to search for answers on Google and your website and automatically correct misspelled user questions. To start using it, follow the steps below.
Create a search and setup it is as you want. We recommend to add only your website and Wikipedia if you want your chatbot to reply to general questions, leave disabled the option
Search the entire web
. Use the setting
Entities
to exclude invalid results.
Go to
Edit search engine > Setup > Basic
and copy the
Search engine ID
value, paste it in OddoChat .
The
Entities
setting analyze the user's message and recognize and extract entities like cities, events, dates, and more. Use it to exclude invalid results returned by Google search. To enable this setting follow the steps below.
Enter
Cloud Natural Language API
in the search bar at the top, select
Cloud Natural Language API
and enable the API
.
Enable the billing by clicking
Left menu > Billing
and by enabling a billing account with a valid payment method. Enable billing for the project of your Dialogflow agent.
Information
The Google search is performed only if the chatbot does not know the answer to the user's question and if the length of the user's message is greater than 6 characters.
If the Google search returns a result, the Dialogflow context
google-search
is automatically activated. The context contains the attribute
link
which is the website's link of the Google search result. Use the context to create a new intent that provides the link, if the user sends a message like
tell me more
or
I want to know more
.
Google Search is not required to activate the spelling correction. You can disable Google Search and activate only spelling correction.
If Google Search is active, it will have priority over OpenAI.
Fulfillment
The fulfillment data sent to your webhook URL is like below:
The
payload
and
session
fields contain the OddoChat user ID and conversation ID.
Information
Knowledge Base
Knowledge Base are automatically enabled. Knowledge Base is a feature that gives your chatbot the ability to search within documents (such as a PDF) or web pages to find an answer. To create your first Knowledge Base, go to
cloud.google.com/dialogflow/docs/knowledge-connectors
Dialogflow response
The full Dialogflow
JSON
response is automatically saved in the database,
sb_messages
, column
payload
.
User attachments
User attachments are sent to Dialogflow by appending the attachments to the message details in the following format:
Replace "name" with the actual name of the attachment to display and replace "YOUR-LINK" with the actual URL of the file. Images attachments are displayed automatically as images.
Rich messages
To allow Dialogflow to send rich messages, simply enter the rich message shortcode into the
TEXT RESPONSE
field or add a new
Custom Payload
response and insert this JSON code:
{ "rich-message": "shortcode" }
. Replace "shortcode" with the rich message shortcode, to have a valid JSON code you need to replace all
"
chars with
"
. To obtain the shortcodes or to learn how to create a rich message, please click
here.
Rich message response
When the user interacts with rich messages via the OddoChat chat (e.g. by clicking a button), the rich message response is sent to Dialogflow in the following format:
ID|response
, or
ID
if the rich message type is registration, email, follow up, in this case the rich message values are sent as array in the
queryParams['payload']
key.
ID
is the rich message ID, which can be set by adding the attribute id="YOUR-ID" to the shortcode. If no ID has been set, a random ID will be used instead.
response
is the input or selection of the user. To block Dialogflow from replying to a rich message add a new intent with
ID
as the only user expression and no response.
If the user is interacting with the chatbot via a messaging app (e.g. WhatsApp), the response of the rich message does not contain the rich message ID and Dialogflow
contexts
must be used to allow Dialogflow to understand which Intent to activate for a specific rich message response.
Get rich message response for registration, email, follow up
From
Left menu > Fulfillment
enable
Webhooks
, you only need to enter the URL of the file that will receive the Dialogflow webhook data.
Create an Intent with the ID of the rich message, for the registration form, enter
registration
, for the follow up form enter
sb-follow-up-form
, for email forms enter
email
.
Enable the Fulfillment for the Intent
You're done! The file of the webhook URL will receive the OddoChat rich message user details.
Dialogflow chatbot optimization
If the chatbot is replying with the wrong intents, go to
Dialogflow Console > chatbot Settings > ML Settings
, and set the
ML CLASSIFICATION THRESHOLD
to a larger number, such as 0.6.
Sequential survey
To create a sequential survey like the one of the demo you need to Enter the
Rich message ID
in the
Training phrases
, check the example below.
Go to Dialogflow and create a new intent. In the
Training phrases
area enter the user expression
survey example
. In the
Responses
area enter the code
[buttons id="test-survey-1" options="Software,Physical products,Services" title="What is your type of business?" message="Please choose the type that best suits your company." success="Your company type is "]
Create a new intent. Enter the user expression
test-survey-1
and as response enter
[select id="seq-survey-2" options="Priority post, Express courier, International courier" title="Shipping methods" message="Choose the preferred shipping method of your customers" success="Your customers preferred shipping method is"]
Create a new intent. Enter the user expression
test-survey-2
and as response enter
Thank you for completing our survey!
.
You're done.
Bot training
Agents can add new Intents and chatbot responses, and add new training phrases to existing intents on the fly from the admin area by moving the mouse cursor over a message and clicking the Dialogflow Intent icon. New Intents will contain also the responses, while the update of existing intents will add new training phrases only, but not new chatbot responses. If you're using Dialogflow CX, the chatbot responses will be added to the latest flow used in the conversation if any, otherwise to the start flow.
Departments linking
Get the department IDs from
Settings > Miscellaneous > departments
.
Get the project IDs from the Dialogflow settings area of your agents.
More information
You can activate the chatbot via API but sending a message with no text and payload
{ "event": "activate-bot" }
.
Supported chinese language is only Chinese - Simplified. Please use the Dialogflow language Chinese - Simplified (zh-CN) only. The languages codes zh-HK and zh-TW will not work.
The following details are sent to Dialogflow in the
queryParams
parameter when detecting an intent:
conversation_id
,
user_id
.
To trigger the welcome event in Dialogflow CX, create a
Event Handler
and insert
Welcome
as
Custom Event
.
OddoChat articles are synchronized automatically with the Dialogflow knowledge base.
Use the JS variable
SB_DIALOGFLOW_AGENT = "AGENT ID"
to change the default Dialogflow agent, replace "AGENT ID" with the
project ID
.
WHATSAPP
WhatsApp
The settings below are related to the WhatsApp app.
Installation
From
Settings > Apps
, click
WhatsApp
and enter your license key to install and activate the app. If you have the cloud version the app is already active.
In
OddoChat > Settings > WhatsApp > Cloud API > Secret key
enter a random string then go to
https://developers.facebook.com/appsand select your app. Click
Add product
and add
WhatsApp
, then go to
WhatsApp > Configuration
and in
Webhook URL
enter the URL you get from
OddoChat > Settings > WhatsApp > Cloud API > Configuration URL
. In
Verify token
enter the secret key you previously entered in OddoChat. Click
Verify
and save, click
Webhook fields > Manage
, enable the following Webhook fields:
messages
.
In
OddoChat > Settings > WhatsApp > Cloud API > Token
enter the test token for testing, and follow the instructions below for getting the permanent access token.
Visit
https://business.facebook.comand go to
Left menu > Settings > More system settings
, then go to
Users > System Users
to view the system user you created, or create a new one. Click on that user and select
Add Assets
. The system user needs to be an admin.
Click
Left menu > Apps
and under
Select Assets
and choose your app. Enable
Develop App
for that app and save.
Click
Generate Token
and select your app, enable the following permissions:
whatsapp_business_management
,
whatsapp_business_messaging
,
business_management
. Click
Generate Token
and save. Paste the token in
OddoChat > Settings > WhatsApp > Cloud API > Token
.
To get the
Phone ID
enter
https://developers.facebook.com, select your app and go to
Left menu > WhatsApp > Getting started
.
You can test the integration from
https://developers.facebook.com, select your app and go to
Left menu > WhatsApp > Getting started
.
Enter your dashboard and from
Left menu > WhatsApp Accounts
generate the
API key
and copy and paste it in
OddoChat > Settings > WhatsApp > 360dialog settings
.
Complete the form and choose
WhatsApp
,
Alerts & Notifications
,
With no code at all
,
3rd party integrations
.
From the
Twilio console
copy
ACCOUNT SID
and
AUTH TOKEN
and paste them into
OddoChat > Settings > WhatsApp > Twilio settings
, save the changes.
You will now set up a free test account to run some tests and make sure the integration works with OddoChat . From the left menu click
Messaging > Settings > WhatsApp sandbox settings
and enter into
WHEN A MESSAGE COMES IN
and
STATUS CALLBACK URL
the URL of OddoChat , get it from
OddoChat > Settings > WhatsApp > Twilio settings > Get configuration URL
. Mind that localhost will not work, you need a public URL and a live server.
From the left menu click
Messaging > Try it out > Send a WhatsApp message
. Follow the instructions and send the message with the code to the WhatApp number provided. Click the next buttons until the configuration is complete.
Done! OddoChat should start receiving the WhatsApp messages sent to the sandbox account, and you can reply to those messages from the OddoChat .
To publicly use the WhatsApp integration with your customers you need to update your account and enable billing, you can do that
here. After that you will need to purchase a Twilio number, which will be the phone number of your official WhatsApp Business account. More details
here. You cannot use the phone number of your existing WhatsApp Business account, you must use a Twilio number. More details
here.
Fallback messages
As for
WhatsApp Business Policy, you cannot send outbound marketing and solicitation messages to end users. End user users must reach out to you first. You have 24 hours from when the end user's message was sent from WhatsApp to reply to the message. If you want to send a message after 24 hours from the last user's message you need to use the text message fallback or WhatsApp template message.
Text message fallback
To enable the text message fallback you must set up the SMS in
Settings > Notifications > Text message notifications
.
More details
here
WhatsApp Template Messages
A WhatsApp Template Message is a message format that you can use over and over again to message users once they have opted-in and given your app permission to send them messages. You can not Enter the original message into the template, you must use it to notify the user of a new message and instruct him on how to view it, for example by providing a link to your website where the chat is shown.
WhatsApp Cloud API
To get the
Template name
and manage the templates visit
https://business.facebook.comand go to
Left menu > Settings > More system settings
, then go to
Accounts > WhatsApp accounts > Settings
and click
WhatsApp Manager
.
In
Template languages
enter all the language codes supported by your template, separated by commas. If a language is not found the fist language code is used instead. Language codes list
here(copy only the language code, e.g. it, es, en_US).
In
Header parameters
and
Body parameters
enter the supported merge fields separated by commas, e.g. {recipient_name}, {conversation_url_parameter}. The number of parameters entered here must match the number of parameters of the template. Use this feature if your template uses dynamic values. Order is important, the first merge field will be used as the first template parameter.
Twilio
Enter the template code into
OddoChat > Settings > WhatsApp > Template fallback
If you're using the Twilio sandbox for testing you can use pre-approved templates like
Your {{1}} code is {{2}}
, you can replace the variables with the OddoChat ones like
{recipient_name}
, for example,
Your {recipient_name} code is {recipient_email}
. More details
here.
360dialog
Get the
Namespace
value from
Left menu > WhatsApp accounts > Details
.
Get
Template name
and
Template default language
from your 360dialog templates area.
In
Custom parameters
Enter the supported merge fields separated by commas, example: {recipient_name}, {conversation_url_parameter}. Use this feature if your template uses dynamic values. Order is important, the first merge field will be used as the first template dynamic value.
OddoChat will try to use the template with the same language as the user, if it is not available, it will use the template with the default language. The following template languages are not compatible: en_GB(use en_US), pt_PT(use pt_BR), zh_HK and zh_TW(use zh_CN), es_AR and es_MX(use es_ES).
WhatsApp shop
To displays the products of your shop use the merge fields below.
Display multiple products. Replace
id
with the catalog ID. Add products by grouping them into sections, via the attributes
product_id_[A]_[B]
, replace [A] with the section index, starting from 1, replace [B] with the product index, starting from 1 for each section. You must also add the attribute
section_[A]=""
for each section, replace [A] with the section index. The attributes
header
and
body
are required,
footer
is optional.
When the user sends the order, the order information is sent to the URL specified in
Settings > WhatsApp > Order webhook
. The page at that URL should process the order and send a message to the user via the PHP API function
sb_whatsapp_send_message()
.
If you does not receive WhatsApp messages make sure you are not assigning the WhatsApp conversations to a department and that the WhatsApp number used for testing is not a phone number of a OddoChat admin or agent. Also, make sure you setup correctly the WhatsApp webhook URL.
If you can not send messages, an error should appear in the admin area when you try to send a message to the user.
We cannot provide support for Twilio or 360dialog configuration, including all related issues.
We cannot provide support in getting your WhatsApp account or WhatsApp message template approved.
WhatsApp conversations and messages are compatible with routing and queue.
If you are testing with the sandbox and after 72 hours you can no longer send messages to your phone number you must link again your phone number to your sandbox.
If you send chips, buttons or select rich messages, with more than 3 options, you can use the
whatsapp="Your menu text"
shortcode attribute to set the text of the WhatsApp message menu.
MESSENGER
Messenger
The settings below are related to the Messenger app.
Installation
From
Settings > Apps
, click
Messenger
and enter your license key to install and activate the app. If you have the cloud version the app is already active.
Once the App is installed go to
Settings > Messenger
and click
Start synchronization
.
Complete the synchronization by choosing at least 1 Facebook page and enter the returned information in Settings > Messenger > Facebook pages.
You're done. All messages sent to the Facebook pages and Instagram accounts you selected will appear in the conversation admin area of OddoChat .
Instagram
To link Instagram to your Facebook page and OddoChat follow the steps below.
Enter the Settings area of your Facebook Page and click
Left Menu > Instagram
(https://www.facebook.com/YOUR-PAGE-SLUG/settings/).
Click
Connect account
and complete the setup.
Sync Messenger with OddoChat again and you're done.
More information
If you don't receive Instagram messages make sure to enable
Settings > Privacy > Messages > Connected tools - Allow access
from your Instagram mobile app. Also, make sure your Instagram account is not setup as a professional account, it must be a business account.
Every OddoChat user has only 1 Facebook and Instagram conversation.
OddoChat rich messages are automatically converted to Facebook rich messages when possible, some part of the rich message could be removed or changed.
Only private Facebook messages will get sent to your team inbox. If someone posts a Facebook message on your wall it won't appear in your team inbox.
When someone sends a message to your company Facebook page or Instagram account they will get designated as a lead in OddoChat . You'll only be able to see the user's Facebook or Instagram name and profile picture.
Messenger conversations and messages are compatible with routing and queue.
Dialogflow is supported for Facebook and Instagram, including the following features: Human takeover, OddoChat rich messages, language detection and chatbot language switcher.
Follow-up message is supported, but the delay setting is ignored, the message is sent instantly.
Offline message is supported, but the timetable is not sent.
Only 1 Facebook account can be synchronized, to link pages from multiple Facebook accounts, the account synchronized in OddoChat must be an admin of all Facebook pages of the other Facebook accounts.
TWITTER
Twitter
The settings below are related to the Twitter app.
Create your first app by entering the app name and click
Get keys
, copy
API Key (Consumer key)
and
API Key Secret (Consumer secret)
and paste them in
OddoChat > Settings > Twitter
.
Request the
Elevated
access from
https://developer.twitter.com/en/portal/products/elevated. Click
Apply for Elevated
and complete the form as follow: In the first area
In your words
and in
Will your app use Tweet, Retweet, Like, Follow, or Direct Message functionality?
enter
I need access to the Account Activity API to start receiving Twitter Direct Messages to my chat software(OddoChat ) and to reply to them directly from OddoChat , details at https://board.support/twitter.
Disable all the other fields by clicking No: Are you planning to analyze Twitter data?, Do you plan to display Tweets or aggregate data about Twitter content outside Twitter?, Will your product, service, or analysis make Twitter content or derived information available to a government entity?
Wait a few days for Twitter to review and approve the Elevated access, you will receive an email from Twitter.
Once you have Elevated access, enter the developers dashboard (
https://developer.twitter.com/en/portal/dashboard) and from the left menu click
Products > Premium > Dev environments
and under
Account Activity API / Sandbox
click
Set up dev environment
, in
Dev environment label
enter
sb
or the same value entered in
Settings > Twitter > Synchronization > Dev environment label
.
Enter your app
Settings
area from
Left menu > Projects & Apps > Your project > Your app
and under
User authentication settings
click
Set up
and activate
OAuth 1.0a
. In
App permissions
check
Read and write and Direct message
, in
Callback URI / Redirect URL
enter the URL you get from
OddoChat > Settings > Twitter > Get callback URL
, in
Website URL
enter your website URL.
Enter your app
Keys and tokens
area from
Left menu > Projects & Apps > Your project > Your app > Keys and tokens
and under
Authentication Tokens
generate
Access Token and Secret
, copy and paste them in
OddoChat > Settings > Twitter
.
Enter your Twitter profile username in
OddoChat > Settings > Twitter > Your username
. Get it from your Twitter profile page, copy the name starting with @ or the URL part containing your username. Ex.
https://twitter.com/
SupportBoard1
.
Save the OddoChat settings and click the button
OddoChat > Settings > Twitter > Subscribe
and you're done. All messages sent to your Twitter account will be received by OddoChat .
More information
If you receive duplicate messages, the Twitter account you are using for testing may be the same as the one you synced. Try sending a message from another Twitter account.
Use a live domain, localhost is not supported.
When a message is received from a Twitter user you may send up to 5 messages in response within a 24 hour window. No messages can be sent after 24 hours of receiving the Twitter message.
You can send maximum 3 or 4 attachments depending by the media type.
The following OddoChat rich messages are not supported: images slider, slider, card.
GOOGLE BUSINESS MESSAGES
Google Business Messages
The settings below are related to the Google Business Messages app.
Installation
In
OddoChat > Settings > Business Messages > Synchronization > Client token
enter a random string and save.
Configure the
Webhook
by entering the
Webhook URL
and the
Client token
and save the changes, get the values from
OddoChat > Settings > Business Messages > Synchronization
.
Click
Service account
from the left menu and create a new key, download the key and open it with a text editor such as Notepad, copy
private_key
,
client_email
, and paste the values in
OddoChat > Settings > Business Messages > Synchronization
.
You are done! To test your agent visit
https://business-communications.cloud.google.com/console, click your brand to enter your brand
Overview
area, under
Agent information > Agent test URLs
click on the button suitable for your mobile device and open the link from your mobile device.
More information
The values of chips, buttons and select rich messages must have a maximum of 25 characters, and the maximum 13 values are allowed.
Avatar image must be a JPG image of 1024x1024px with a maximum size of 50KB.
TELEGRAM
Telegram
The settings below are related to the Telegram app.
Installation
Go to the admin area of OddoChat , then go to
Settings > Apps > Telegram
, and enter the
Envato purchase code
to install and activate the app. If you have the cloud version the app is already active.
If you have already created a Telegram bot in the past, type the command
/mybots
and open your bot, then click
API token
.
If you never created a Telegram bot before, type the command
/newbot
to create a new bot. The BotFather will ask you for a name and username, enter them and generate the authentication token. More details at
https://core.telegram.org/bots.
Copy the token and paste it into
OddoChat > Telegram > Token
, then click
Synchronize now
. Your website must use HTTPS (SSL certificate), HTTP is not supported.
You're done. All messages sent to your Telegram bot will appear in the conversation admin area of OddoChat.
More information
OddoChat rich messages are automatically converted to Telegram rich messages when possible, otherwise they are removed from the message.
Telegram conversations and messages are compatible with routing and queue.
Dialogflow is supported, including the following features: Human takeover, OddoChat rich messages, language detection and chatbot language switcher.
Follow-up message is supported, but the delay setting is ignored, the message is sent instantly.
Offline message is supported, but the timetable is not sent.
VIBER
Viber
The settings below are related to the Viber app.
Installation
From
Settings > Apps
, click
Viber
and enter your license key to install and activate the app. If you have the cloud version the app is already active.
Copy the token and paste it into
OddoChat > Viber > Token
, then click
Synchronize now
. Your website must use HTTPS (SSL certificate), HTTP is not supported.
You're done. All messages sent to your Viber bot will appear in the conversation admin area of OddoChat.
More information
OddoChat rich messages are automatically converted to Viber rich messages when possible, otherwise they are removed from the message.
Viber conversations and messages are compatible with routing and queue.
Dialogflow is supported, including the following features: Human takeover, OddoChat rich messages, language detection and chatbot language switcher.
Follow-up message is supported, but the delay setting is ignored, the message is sent instantly.
Offline message is supported, but the timetable is not sent.
SLACK
Slack
The settings below are related to the Slack App.
Synchronization
To sync Slack click the button
Start synchronization
of the
Settings > Slack
area and follow the instructions.
Having Problems?
The synchronization of Slack may not be successful for a number of reasons; below are the most common ones:
Problem description
Solution
You can receive messages on Slack, but you cannot send messages from Slack to OddoChat
Navigate to
/supportboard/apps/slack/post.php
from your browser. If you receive a
403 - Forbidden
error, you will need to contact your web hosting provider and ask them to set the correct file permissions for this file and/or to add a Firewall role to prevent the firewall from blocking the file. It must be allowed to be executed freely without any restrictions. Also, in
Workspace Settings > Permissions
, you must allow anyone to create public channels.
If you have further issues please contact the Slack support team at
https://api.slack.com/support.
Slack sync not working
Double check whether or not you chose a public Slack channel when you attempted to synchronize Slack. If you did not, try syncing Slack once again, this time choosing a public channel instead. The general channel is a good option.
Manually archive channels
To archive a channel in Slack, follow these steps:
Open the Slack channel you want to archive.
On the top right click the gear icon and select
Additional options
.
Click the info icon in the top right area of the screen, then click the
More icon
, and then click
Additional options...
. Click
Archive this channel
.
Departments linking
Get the department IDs from
Settings > Miscellaneous > departments
.
Get the channel IDs by clicking the button
Get channel IDs
.
User fields
The setting
Settings > Slack > User fields
allows you to choose which user details to include in the message sent to the main channel when a new user sends the first message. You can include the slug of your custom user details or the following slugs:
browser
,
browser_language
,
location
,
email
,
user_type
,
token
,
creation_time
,
country_code
,
current_url
,
os
,
city
,
address
,
postal_code
,
phone
,
birthdate
,
company
,
timezone
,
website
. Default: email, browser, browser_language, location.
Information
When a new user sends the first message, a Slack message with the user details and a button to join the user's channel is sent to the main channel selected during the synchronization, or to the channel linked to the conversation's department. Only the Slack account used during the synchronization will automatically join the user's channel, other Slack members will have to join it manually via the button.
When
Settings > Slack > Agent linking
is set, if the conversation is assigned to a department, only agents assigned to that department will receive the message, if the conversation is assigned to a single agent only that agent will receive the message.
Slack is free to use. Only large companies may need a paid subscription plan, more details
here.
Push notifcations are compatible with Slack, when agents send messages via Slack, Push notifications are sent to users.
If you're using Dialogflow, no messages will be received in Slack if the chatbot knows the answer. Once the human takeover is active all conversation's messages are sent to Slack.
The Slack app is compatible with email piping and the messaging apps.
Deleting or leaving a channel is not supported, only archiving a channel is supported.
When a conversation is archived in OddoChat , the linked Slack channel is also archived.
When replying via Slack to a user, if the user is notified by email or text message, a Slack message is sent to notify you.
Use the Slack command
/archive
to archive a conversation from Slack.
PERFEX CRM
Perfex
The settings below are related to the Perfex app.
Installation
The installation requires two steps:
From
Settings > Apps
, click
Perfex
and enter your Envato purchase code to install and activate the app. Once the App is installed go to
Settings > Perfex
and enter the database information and the Perfex URL. You can get the information from the file
application/config/app-config.php
in your Perfex installation folder. If you do not know the Perfex prefix leave it empty, the default prefix is
tbl
.
Go to the admin area of Perfex, then go to
Setups > Modules
and install the OddoChat module by uploading the file
module.zip
. Once the module is installed go to
Setups > OddoChat
and enter the OddoChat plugin URL. If you're using the WordPress version, the URL must be like this:
https://example.com/wp-content/plugins/supportboard/supportboard
.
To show OddoChat inside the Perfex admin area, OddoChat must be installed in the same domain and same file system of the Perfex installation.
If you have issues, or if you have changed the Perfex database details, make sure the file
supportboard/config.php
use the correct Perfex database details. Updating the details in OddoChat will not update the details in the config.php file
Zendesk
Zendesk
The settings below are related to the Zendesk App.
Installation
Get the
domain
from the URL of your Zendesk admin area, copy the first part of the URL: https://
domain
.zendesk.com/. For example, the domain of
https://supportboard.zendesk.com/agent/get-started/ticketing-system/ticketing-intro
is
supportboard
.
Get the
API key
from
Left menu > Admin > Channels > API > Settings
. Click
Add API token
.
The
email
is your Zendesk account email.
More information
Tickets converted by OddoChat are automatically synchronized when new messages are sent and received in OddoChat , and they are linked to an existing Zendesk user if any, otherwise a new Zendesk user is created.
OddoChat links Zendesk users to OddoChat users via email or phone number.
WHMCS
WHMCS
The settings below are related to the WHMCS App.
Installation
The process requires two installations, one is the WHMCS add-on, and one is the OddoChat App.
App installation
Go to the admin area of OddoChat , then go to
Settings > Apps > WHMCS
, and enter the
License Key
to install the app. Once the App is installed go to
Settings > Whmcs
and enter the database information and the WHMCS URL.
WHMCS add-on installation
Enter the folder
supportboard
inside the
addon.zip
(download it
here) file into the
/modules/addons/
directory of your WHMCS installation.
Click the
Configure
button and enter the OddoChat plugin URL.
How to update
Updating the WHMCS App in OddoChat is easy, you can enable the automatic updates or manually update it. Details
here. To update the WHMCS add-on you will need to download the latest version of the add-on from
https://board.support/docs/files/whmcs/addon.zipand manually replace the
/modules/addons/supportboard/
directory of your WHMCS installation with the new one just downloaded.
If you have issues, or if you have changed the WHMCS database details, make sure the file
supportboard/config.php
use the correct WHMCS database details. Updating the details in OddoChat will not update the details in the config.php file.
ULTIMATE MEMBERSHIP PRO
Ultimate Membership Pro
The settings below are related to the Ultimate Membership Pro app.
Users synchronization
New users are synchronized automatically. To manually syncronize existing users go to
Settings > WordPress > Synchronize users
and click
Import users
.
More information
To limits the access to a specific plan only use this shortcode
[ihc-hide-content ihc_mb_type="show" ihc_mb_who="4" ihc_mb_template="2"]<script id="sbinit" src="/users/u14/14400/imports/7912/docs/YOUR-URL/supportboard/supportboard/js/main.js"></script>[/ihc-hide-content]
Replace
4
with the user's level you want and
YOUR-URL
with your WordPress /plugins/ folder URL. You also need to check
Settings > WordPress > Manual init
.
ARMEMBER
ARMember
The settings below are related to the ARMember app.
Users synchronization
New users are synchronized automatically. To manually syncronize existing users go to
Settings > WordPress > Synchronize users
and click
Import users
.
More information
A user is a paid member only if it has at least one active paid plan which is not expired.
Active eCommerce
Active eCommerce
The settings below are related to the Active eCommerce app.
Installation
The process requires two installations, one is the OddoChat App, and one is the installation in Active eCommerce.
App installation
Go to the admin area of OddoChat , then go to
Settings > Apps > Active eCommerce
, and enter the
License Key
to install the app. Once the App is installed go to
Settings > Active eCommerce
and enter the database information, the Active eCommerce URL, and the other settings.
The Secret Key can be found in the file
.env
located in the root directory of Active eCommerce. Copy the APP_KEY value.
If you have issues, make sure the file
supportboard/config.php
use the correct Active eCommerce database details.
Installation in Active eCommerce
Edit the file
resourcesviewsfrontendincfooter.blade.php
in the directory of Active eCommerce and Enter the code below just after the footer opening tag
<footer
. Replace
[YOUR-SITE]
with the URL of your OddoChat installation.
Updating the Active eCommerce App in OddoChat is easy, you can enable the automatic updates or manually update it. Details
here. If you update Active eCommerce, you will need to insert again the code above in the file
footer.blade.php
.
Sellers chat
To force sellers to see only the conversations of users writing from their product pages enable the option
Settings > Miscellaneous > Hide conversations of other agents
. After that, just click the button
Settings > Active eCommerce > Import vendors
and you're done! The sellers will be registered in OddoChat and can log in to the admin area.
Admins can always see the conversations of all agents(sellers).
Martfury
Martfury
The settings below are related to the Martfury app.
Installation
Go to the admin area of OddoChat , then go to
Settings > Apps > Martfury
, and enter the
License Key
to install the app.
Once the app is installed go to
Settings > Martfury
and enter the
database information
,
Martfury URL
,
Secret key
. Get the information from the
.env
file located in the root directory of Martfury.
Set the Martfury path in
Settings > Martfury > Martfury path
. Get this information by uploading
this filein the
/public/
folder of the root directory of Martfury, after the upload open it via browser (e.g. https://shop.com/public/path.php).
To show the chat on the website enter the OddoChat code of the
PHP installationinto
Martfury Admin > Appearance > Custom JS > Footer JS
. Do not include jQuery.
If you have issues, make sure the file
supportboard/config.php
use the correct Martfury database details.
How to update
Updating the Martfury App in OddoChat is easy, you can enable the automatic updates or manually update it. Details
here.
Sellers chat
To force stores to see only the conversations of users writing from their product pages follow the steps below.
Check the options
Settings > Martfury > Private chat
,
Settings > Chat > Disable dashboard
,
Settings > Chat > Allow only one conversation
.
From
Settings > Martfury > Import vendors
import all vendors.
In
Settings > Martfury > Private chat linking
each each vendor to the correct store. You can get the vendor IDs from
Users > Agents and Admins
.
Create a new
Provider
and then a new
Messaging API channel
, select
Messaging API
as channel type
From the channel
Basic settings
area copy
Channel secret
and paste it into
OddoChat > Settings > Line > Synchronization > Channel secret
.
From the channel
Messaging API
area generate a
Channel access token (long-lived)
, copy it and paste it into
OddoChat > Settings > Line > Synchronization > Access token
.
Enter your Webhook URL into
Webhook URL
and click
Verify
. Get the Webhook URL from
OddoChat > Settings > Line > Synchronization > Webhook URL
.
Enable
Use webhook
.
Scane the
QR code
with your LINE mobile app to start writing to your channel.
You're done. All messages sent to your LINE bot account will appear in the conversation admin area of OddoChat.
More information
You have 7 days from when the end user's message was sent from WhatsApp to reply to the message.
Stickers are not supported.
OddoChat rich messages are automatically converted to LINE rich messages when possible, otherwise they are removed from the message.
LINE conversations and messages are compatible with routing and queue.
Dialogflow is supported, including the following features: Human takeover, OddoChat rich messages, language detection and chatbot language switcher.
Follow-up message is supported, but the delay setting is ignored, the message is sent instantly.
Offline message is supported, but the timetable is not sent.
WECHAT
WeChat
The settings below are related to the WeChat app.
Installation
From
Settings > Apps
, click
WeChat
and enter your license key to install and activate the app. If you have the cloud version the app is already active.
After the registration enter
Official accounts
area and from the left menu click
Settings and development > WeChat verification
. You must complete the verification, it takes a few weeks and costs USD 99, or CNY 300 for chinese entities.
From the left menu click
Settings and development > Basic configuration
and copy
Developer ID(App ID)
,
Developer Password(App Secret)
. Paste the information into
OddoChat > Settings > WeChat
.
From the left menu click
Settings and development > Basic configuration
and complete the server configuration (服务器配置(已启用). In
Server Address(URL)
enter the URL you get from
OddoChat > Settings > WeChat > Synchronization > Get configuration URL
. In
Token
insert any value you want, the same value must be entered in
OddoChat > Settings > WeChat > Token
.
You're done. All messages sent to your WeChat account will appear in the conversation admin area of OddoChat.
More information
If you receive an error like
{"errcode":41001,"errmsg":"access_token missing rid: 631111-470b3b22-48553870"}
you need to whitelist your server IP address from
Official Account > Settings and Development > Basic Configuration > IP whitelist
.
WeChat files and location attachments are not supported and are not received by OddoChat.
Links are not supported in WeChat, they are converted to texts.
OddoChat rich messages are automatically converted to WeChat rich messages when possible, otherwise they are removed from the message.
WeChat conversations and messages are compatible with routing and queue.
Dialogflow is supported, including the following features: Human takeover, OddoChat rich messages, language detection and chatbot language switcher.
Follow-up message is supported, but the delay setting is ignored, the message is sent instantly.
Offline message is supported, but the timetable is not sent.
MORE SETTINGS
More settings
This section contains help for other settings not listed above.
Progressive Web App
The OddoChat admin area is a PWA, which means that you can install it on desktop, Mac, or mobile devices and use it like a fully-functional app. Note: This feature is optimized for Google Chrome.
Desktop installation
Enter in your admin area (e.g. https://www.your-site.com/supportboard/admin.php), and click the
+
icon on the top right of the URL bar of your Chrome browser.
Mobile installation - Cloud version only
If you are using the cloud version of OddoChat you can use the apps available on Google Play and Apple Store.
Change "your-site" with the URL of your website and also keep in mind that the "wp-content" folder name may be different from the one of your installation.
Change PWA icon and name
Download the file
manifest.json
here. Edit it and replace
YOUR NAME
with your brand name,
YOUR NAME DESCRIPTION
with any text you want, and
example.png
with the relative URL of your icon, the icon size must be 512 x 512 px. After you finished editing the file move it into the OddoChat installation folder, the same folder where is located the file admin.php. Mind that because this is customization our support doesn't cover it, if you need help you can
hire us.
Keyboard shortcuts
Admin area keyboard shortcuts are enabled on both PC and MAC and work as follows:
Shortcut
Description
ENTER
or
SPACE
Confirm or close a dialog alert; the same as clicking
OK
.
ESC
or
CANCEL
Decline a dialog alert and close it.
SHIFT + ENTER
or
CTRL + ENTER
Add a line break to a message. This only works for the admin editor.
ESC
Close a lightbox.
CANCEL
In the admin conversations area, archive a conversation, or delete it.
CTRL + UP/DOWN ARROW
In the admin conversations area, navigate between the conversations of the list.
CTRL + RIGHT/LEFT ARROW
In the admin users area, navigate between the users.
CTRL + V
Paste an image from the clipboard and send it as message.
Config file
The
config.php
file is a special file that contains the MySQL database log-in details and other import settings. Most of the settings are generated automatically, but some are optional. You can add the following settings below:
Code
Description
define('SB_UPLOAD_URL', 'YOUR-URL')
Change the uploads directory (the default directory is: /supportboard/uploads/). Enter a URL: for example, https://your-site.com/myuplaods/. For this setting you need also to define the SB_UPLOAD_PATH.
define('SB_UPLOAD_PATH', 'YOUR-PATH')
Change the uploads directory path (the default path is: /supportboard/uploads/). Enter a PATH: for example, C:xampphtdocsuploads. Finding the root path of your website can be a bit tricky. You can try copying the path displayed in your FTP client or simply contact your web hosting provider for additional support.
$GLOBALS['SB_LOCAL_SETTINGS'] = []
Overwrite the default settings. The value is an array of keys and values, each key is a setting, e.g.
["registration-required" => [true]]
. View an example
here. Get the settings list from
resources/json/settings.json
and the files
settings.json
inside the app folders.
Cron Jobs
Cron jobs are executed by the first user that visit the website at any given hour of the day.
Cron jobs are executed every 60 minutes, but it can take longer, or it can take less time as well, in relation to the traffic of your website.
Because cron jobs are initiated by users, if you have less than 1 visitor per minute, it could take longer. As long as there is at least one active user on the site, execution every minute is guaranteed.
You can speed up the cron jobs execution by manually run them via
WEB API, or
PHP API.
Logs
The log file is saved in the OddoChat installation directory.
The logs record the following actions of agents and administrators: message sent, message deleted, conversation archived, conversation deleted, conversation restored, conversation assigned to an agent, conversation assigned to a department, user updated, user deleted.
Supervisor
Supervisors must be administrators.
Add multiple supervisors by adding comma separated admin IDs.
URL parameters
Front-end chat
URL parameters allow the chat to perform specific actions on page load. To use them, append the URL parameters below to any URL on your website that displays the chat. Ex. https://example.com/?conversation=1234
URL parameter
Description
?token=TOKEN
Login an existing user. Replace TOKEN with the user's token.
?conversation=ID
Open a conversation. Replace ID with the conversation ID. The attribute
token
is required for not logged in users.
?chat=open
Open the chat.
Admin area
URL parameters allow the administration area to perform specific actions on page load. To use them, append the URL parameters below to your admin URL. Ex. https://example.com/supportboard/admin.php?conversation=1234
URL parameter
Description
?conversation=ID
Open a conversation of the conversations area. Replace ID with the conversation ID.
?user=ID
Open the profile box of a user. Replace ID with the user ID.
?setting=ID
Open a setting of the settings area. Replace ID with the setting ID.
?report=ID
Open a report of the reports area. Replace ID with the report ID.
?area=name
Open an area of the admin. Replace name with: conversations, users, settings, reports.
Zapier
Integrate Zapier with OddoChat by following the steps below. Integration is based on the OddoChat webhooks, each webhook is a Zapier trigger, so you have 15+ Zapier triggers available, for more details visit the
webhookspage.
Create a new integration by clicking
Start a Zapier Integration
, or visit
https://developer.zapier.com/app/new. Fill in all required fields, like name and description, and click
Create
, you can enter any text you want, but keep the name of the app in mind because you will need it later.
From the left menu click
Triggers
and then
Add Trigger
.
Fill in all required fields, like key and description, and click
Save And Continue
, you can enter any text you want.
On top click
API Configuration
, choose
REST Hook
as
Trigger Type
, and click
Save
.
Search for your newly created app by entering the app name and click it. In
Trigger Event
select your trigger and click
continue
.
Copy the
Webhook URL
, click
Continue
, and then enter the OddoChat admin area and enter it into
Settings > Miscellaneous > Webhooks > URL
, activate the webhooks, save the settings and reload OddoChat .
Make something to trigger a webhook like sending a message, or creating a new user, then go back to Zapier and click
Test Trigger
and you should see the OddoChat webhook data. Click
Continue
.
Click the right button
Filters
and set up the filter in order to trigger the integration only if a variable exists. You need the filter because OddoChat will send all webhooks to all zaps. Example: if your zap wants to integrate the messages of OddoChat , you will need to set the filter to continue only if the variable
message
exists.
Click
Continue
, or
+
and add your integration.
To use multiple zaps and webhooks you will need to update
Settings > Miscellaneous > Webhooks > URL
and add the new zap IDs, separated by commas. Example: if you have two zaps with URLs
https://hooks.zapier.com/hooks/catch/10352851/bbad21f/
and
https://hooks.zapier.com/hooks/catch/10352851/aaaa66t/
, the URL must be
https://hooks.zapier.com/hooks/catch/10352851/bbad21f,aaaa66t/
.
More Information
If you change the plugin folder name after the installation, you need to update it in the constant
SB_URL
of the file
config.php
.
Welcome messages are not sent to slack and conversations containing only the welcome message (and no response) are automatically archived.
Follow-up messages are sent a maximum of once every 24 hours.
A popup message is always shown default, until the user manually closes it; then it stays closed.
The Users and Conversations sections in the OddoChat admin area use auto-pagination on scroll, which is limited to 100 results per scroll.
The privacy message is not shown if the
Require registration
option has been enabled.