Getting Started
The chat widget helps your clients interact with your company, as it provides sending and receiving messages. Messages are sent using the WebSocket protocol.
In this article, we will cover instructions for setting up and enabling the chat on your website.
Follow the algorithm below:
1. From your account manager, obtain details for connecting the library for the following parameters:
webchat/package
webchat/uid
webchat/websocket
webchat/datastore
webchat/backend/rootUrl
webchat/backend/history
2. Download the current version of the widget to configure the web chat.
Important: the widget version cannot be more recent than the version of the app backend
3. Place the widget file threadswidget-6.18.0.min.js
in the root or any directory of your site.
4. Download the sample configuration file settings.json
Place the settings.json
file in the same directory where the web chat is located.
You configure all widget settings in this file. You will need to specify the path to it later when initializing the widget (step 9).
5. In the settings.json
file, configure the parameters the data on which you received from your account manager in step 1.
6. Customize the color scheme that matches your website.
Go to the skin
section. In the sample file, the parameters define the colors of the following elements:
Field | Description | Default value |
---|---|---|
name | Name of the appearance theme. The following ones are available: mfms , threadsim , halcyon , adaptive | "threadsim" |
width | Widget width | "366px" |
height | Widget height | "420px" |
colorMain | Main base color | "#008aff" |
colorSecond | Additional base color | "#05b8ff" |
colorLines | Color of lines and agent messages | "#dee4e9" |
colorSubText | Additional text color | "#6e6e6e" |
colorText | Text color | "#000000" |
colorBackground | Widget background color | "#ffffff" |
colorMain 1: Client's message background 2: Background of the message input field colorSecond 3: Background of the attachment preview area colorLines 4: Agent's message background colorSubText 5: Color of the close button 6: Color of system messages colorText 7: Color of the header text colorBackground 8: Widget background color 9: Text color of the attachment preview area 10: Text color of message input field |
7. Configure WebPush notifications.
Create a Firebase project for push notifications.
How to register in Firebase
Create a new project
Enter the project name and select a domain
The project is created. Click Continue.
On the project page, click the Settings button in the Project Overview section and select Project settings.
On the General tab, scroll down to the Your apps section and click the web app icon.
Enter the app's nickname and click Register App.
Obtain the generated service worker script and click Continue to the console.
The app's service worker config will remain available on the General tab of the Project settings page. You will need the parameters of this config in the further steps of the widget configuration.
- Go to the Cloud Messaging tab and obtain the
api_key
andsenderID
values.
Download firebase-messaging-sw.js.
Configure the file. In
config
, specify the parameters of service worker for the widget:var config = {
enable: false,
firebaseConfig: {
apiKey: 'FIX_ME',
authDomain: 'FIX_ME',
projectId: 'FIX_ME',
storageBucket: 'FIX_ME',
messagingSenderId: 'FIX_ME',
appId: 'FIX_ME',
},
title: 'edna Chat',
icon: '',
};where:
enable
- The parameter that enables/disables the functionality (possibles values aretrue
andfalse
)firebaseConfig
- Firebase platform connection parameters, service worker configurationtitle
- Header the client will see in the push messageicon
- Push notification icon in the base64 format
Similarly, configure the
pushNotification
section in thesettings.json
configuration file.Share the
sender_id
(Sender ID
) andapi_key
(Server Key
) values from the Cloud Messaging tab of your Firebase project with your account manager.Place the
firebase-messaging-sw.js
file in the root of the website. This script must be available here:http(s)://****/firebase-messaging-sw.js
(where****
is the domain that is being configured).
8. Download the web-notification-sw.js file.
Place the web-notification-sw.js
file in the root of the website. This script must be available here: http(s)://****/web-notification-sw.js
(where ****
is the domain that is being configured).
This is required for the browser web notifications about new messages in the widget to operate properly.
9. Embed the widget on your website.
Enable the widget: To place the chat widget on the page where it will be displayed, add the following initialization code before the closing
</body>
tag:<!-- BEGIN CHAT {literal} -->
<script type="text/javascript">
!function(e,a){"use strict";window.ThreadsWidget={},e=e||"/settings.json";function n(e,t){const n=setInterval(function(){ThreadsWidget&&!ThreadsWidget.isDummy&&(clearInterval(n),ThreadsWidget[e]&&ThreadsWidget[e].apply(void 0,t))},100)}ThreadsWidget.isDummy=!0,["hideInvite","version","commitHash","showChat","hideChat","onHideChat","onScenarios","onLoad","on","reInit","init","unInit"].forEach(t=>{ThreadsWidget[t]=(...e)=>{n(t,e)}});const t=function(){const i=new XMLHttpRequest;return function(e,t,n,a){i.onreadystatechange=function(){if(4===i.readyState)if(200===this.status)n(i.response);else{if("function"!=typeof a)throw new Error(i.response);a(i)}},i.open(e,t),i.send()}}();function i(t){t.webchat&&(t.webchat.filename=t.filename),a&&"string"==typeof a&&(t.webchat.currentLocale=a),a&&"object"==typeof a&&(a.locale&&"string"==typeof a.locale&&(t.webchat.currentLocale=a.locale),a.unavailable&&"boolean"==typeof a.unavailable&&(t.webchat.isUnavailableOnStart=a.unavailable));try{sessionStorage.setItem("__threadsWidget",JSON.stringify(t.webchat))}catch(e){window.__threadsWidget=JSON.stringify(t.webchat)}if(t.filename){const e=document.createElement("script"),n=(e.type="text/javascript",e.async=!0,e.src=t.filename,document.getElementsByTagName("script")[0]);n?n.parentNode.insertBefore(e,n):document.body.appendChild(e)}else console.error("Invalid bundle")}function o(){t("GET",e+"?rnd="+Math.random(),function(e){const t=JSON.parse(e);i(t)})}"complete"===document.readyState?o():window.addEventListener("DOMContentLoaded",o,!1)}("settings.json",{});
</script>
<!-- {/literal} END CHAT -->Connect the configuration file by specifying the path to
settings.json
at the very end of the initialization script:...}("settings.json");
Make sure to set the absolute path to the settings file from the root of your site as the value of this parameter. For example,
("/your/path/to/settings.json")
Save the changes and publish them on your website
The following is an example of the file directory:
10. Open the page on your website.
11. If everything is configured correctly, a button to open the chat will appear in the lower right corner of the browser window. When you click it, the chat start window loads.
Once the widget is embedded, make sure that all settings have been made correctly by conducting a few simple, basic tests:
- Sign in the agent WP and switch to the Active status (your account manager will share the agent credentials with you).
- Send a message from the chat widget. In the agent WP, you will see the message as one of the threads in the queue.
- Respond to the message in the agent WP. You will see the response in the chat widget.
- Try to send several messages this way (for example, messages with attachments). Make sure that once the message is read by the recipient, two checkmarks indicating that the message was read are displayed next to the message in the sender's chat. This indicates that the read statuses work properly.
If there are issues with sending and/or receiving messages, please make sure it configured correctly.
If you have any questions about the details of the setup process, you can always contact our implementation engineers at support@edna.io or contact your account manager.