2020-03-02 22:23:17 +00:00
# Embeddable Matrix Chatbox
2019-04-27 12:32:04 +00:00
2020-03-23 02:16:25 +00:00
![Demo video of chatbox ](https://media.giphy.com/media/IhmtP0NoG22k6FRQDF/giphy.gif )
2018-05-26 18:53:54 +00:00
2020-05-07 00:57:28 +00:00
Live demo: https://nomadic-labs.github.io/safesupport-chatbox/
2020-03-23 02:09:46 +00:00
2020-03-02 22:17:31 +00:00
Built on:
- [Embeddable React Widget ](https://github.com/seriousben/embeddable-react-widget )
- [Matrix JS SDK ](https://github.com/matrix-org/matrix-js-sdk )
2018-05-30 02:14:07 +00:00
2020-03-02 22:17:31 +00:00
## Usage
2018-06-03 15:15:23 +00:00
```
2020-05-07 19:09:22 +00:00
< script src = "https://unpkg.com/private-safesupport-chatbox" type = "text/javascript" > < / script >
2020-03-02 22:17:31 +00:00
< script >
2020-03-23 02:12:20 +00:00
var config = {
2020-05-07 18:56:51 +00:00
matrixServerUrl: 'https://matrix-client.matrix.org',
botId: '@your-help-bot:matrix.org',
2020-03-23 02:12:20 +00:00
roomName: 'Support Chat',
termsUrl: 'https://tosdr.org/',
introMessage: 'This chat application does not collect any of your personal data or any data from your use of this service.',
agreementMessage: 'Do you want to continue?',
confirmationMessage: 'Waiting for a facilitator to join the chat...',
exitMessage: 'The chat is closed. You may close this window.',
chatUnavailableMessage: 'The chat service is not available right now. Please try again later.',
anonymousDisplayName: 'Anonymous',
}
EmbeddableChatbox.mount(config);
2020-03-02 22:17:31 +00:00
< / script >
2018-06-03 15:15:23 +00:00
```
2020-03-02 22:17:31 +00:00
Options:
| Name | Description | Default
| ----------- | ----------- | --------- |
2020-05-07 18:56:51 +00:00
| `matrixServerUrl` (required) | URL for the Matrix homeserver you want to connect to | `https://matrix-client.matrix.org` |
| `botId` (required) | User ID for the bot account that handles invites | null |
2020-03-22 15:06:20 +00:00
| `introMessage` (optional) | First message the user sees before agreeing to the Terms of Use | `This chat application does not collect any of your personal data or any data from your use of this service.` |
| `termsUrl` (optional) | URL for the Terms of Use for the chat service | `https://tosdr.org/` |
2020-03-02 22:17:31 +00:00
| `roomName` (optional) | Name of the chatroom generated in Riot | 'Support Chat' |
2020-03-22 05:25:07 +00:00
| `agreementMessage` (optional) | Text to show to request agreement to the Terms of Use | `Do you want to continue?` |
| `confirmationMessage` (optional) | Text to show to ask for agreement to continue | `Waiting for a facilitator to join the chat...` |
| `exitMessage` (optional) | Text to show if the user rejects the Terms of Use. | `The chat is closed. You may close this window.` |
| `anonymousDisplayName` (optional) | The display name for the chat user. | `Anonymous` |
2020-06-27 15:42:25 +00:00
| `chatUnavailableMessage` (optional) | Text to show on error or if the service is otherwise unavailable | `The chat service is not available right now. Please try again later.` |
| `waitMessage` (optional) | Text to show if there is at least one facilitator online but they do not respond right away | `Please be patient, our online facilitators are currently responding to other support requests.` |
| `chatOfflineMessage` (optional) | Text to show if there is no-one online respond | `All of the chat facilitators are currently offline.` |
| `size` (optional) | The size of the start button. Can be 'small' or 'large' | `large` |
| `position` (optional) | The position of the start button. Can be 'top left', 'top right', 'bottom left', 'bottom right'. | `bottom right` |
| `maxWaitTime` (optional) | The maximum time (in ms) the chatbox will wait for someone to join before closing the chat and displaying the chat unavailable message | 600000 |
| `waitInterval` (optional) | The interval (in ms) at which the bot sends the wait message | 120000 |
2020-03-02 22:17:31 +00:00
2020-03-23 02:09:46 +00:00
## Feature list
2020-03-23 02:10:32 +00:00
- [x] Can be embedded on any website with Javascript enabled
- [x] WCAG AA compliant
- [x] Light and dark theme
- [x] Support seekers are anonymous
- [x] Uses Matrix's end to end encryption
- [x] If encryption fails, falls back to unencrypted chat
- [x] Status texts are customizeable
- [x] Only initiates chat after user agrees to Terms of Service
- [x] Upon exiting chat, user data is wiped - account deleted, local datastore cleared
- [x] If enabled, the bot account can provide transcript of the conversation
- [x] Automatically parses incoming text messages for URLs and adds the < a > tags
- [x] Easy to customize colour scheme
- [x] Bookmarklet allows users to open the chat on any website
2020-03-23 02:09:46 +00:00
## Bot account
This chatbox is meant to be used with a bot account that handles a number of functions:
* Sends out invitations to facilitators to join the support chat
* Revokes unused invitations when the first facilitator join the chat
* Keeps a transcript of the conversation
* Notifies user if there are not facilitators available
2020-04-29 15:31:23 +00:00
The bot account is invited to the chatroom when a support request is initiated.
2020-03-23 02:09:46 +00:00
2020-05-07 00:57:28 +00:00
You can find the code for the bot at [safesupport-bot ](https://github.com/nomadic-labs/safesupport-bot ).
2020-03-23 02:09:46 +00:00
2020-04-29 15:31:23 +00:00
## Bookmarklet
2020-03-23 02:09:46 +00:00
The bookmarklet is a special link that runs a script on any website. The user saves the link by dragging it to their bookmarks bar. Then they can click on the bookmark on any page to run the script and load the chatbox.
2020-05-07 00:57:28 +00:00
You can try this out on the [live demo ](https://nomadic-labs.github.io/safesupport-chatbox/ ).
2020-03-23 02:09:46 +00:00
2020-03-02 22:17:31 +00:00
## Local development
Clone the project:
2018-06-03 15:15:23 +00:00
```
2020-05-07 00:57:28 +00:00
git clone https://github.com/nomadic-labs/safesupport-chatbox.git
2018-06-03 15:15:23 +00:00
```
2020-03-02 22:17:31 +00:00
Install the dependencies:
2018-06-03 15:15:23 +00:00
```
2020-05-07 00:57:28 +00:00
cd safesupport-chatbox
2020-03-02 22:17:31 +00:00
yarn
2018-06-03 15:15:23 +00:00
```
2018-05-26 18:53:54 +00:00
2020-03-02 22:17:31 +00:00
Start the development server:
```
yarn start
```
2018-06-03 15:15:23 +00:00
2020-03-02 22:17:31 +00:00
Open the demo page at http://localhost:9000/
2018-06-03 15:15:23 +00:00
2020-03-02 22:17:31 +00:00
## Production build
```
yarn build
```