Skip to content

A Survey of Rich Messaging in Chatbots

mr_kite edited this page Apr 30, 2018 · 124 revisions

This is a survey of rich message types across popular chat platforms -- sometimes referred to as channels in the chatbot context -- to get a sense of what is implemented and how they overlap. This also attempts to give names for each category or type of rich message piece with select screenshots to aid in deciding what should be added to Rocket.chat.

Rich Message Feature Messenger Telegram Kik Slack Viber
Basic Rich Message x x x x x
Rich Message With Buttons x x x x x
Rich Message With Audio/Video x x x x x
Rich Message With Embedded List x x x x x
Carousel x x
Buttons x x x x x
Dropdown Menu x
Rich Messaging Below Composer x x x x
Integrated Webviews x

Basic Rich Message

This is the simplest form of rich message. It has no buttons that allow a user to send a message back in the chat but it does have an image and provides a hyperlink so the user can click and open up some web page. It generally consists of a title, text body, image, and link and is variously referred to as card or slide or attachment. We've chosen to stay away from attachment below in order to distinguish it from a file that a user may upload into a chat window.

Rich Message With Buttons

This is an image with a button or buttons associated with it and when the button is clicked it performs an action:

Rich Message With Audio/Video

A Telegram message with audio:

A viber message with video:

Rich Message With Embedded List

Rich messages often contain multiple UI items, and how these items are referred to varies across platforms. We're using the term Embedded List for messages that contain a list of items. In the below example from Messenger the message contains an image, title, subtitle, url, three vertical buttons, and three horizontal buttons.

Messenger has a template for more elaborately displaying elements vertically than the standard list layout -- list layout being just cards/slides displayed vertically -- called list template. It has a few different layout options.

Slack uses the term attachments for its list of items in a message. For example a url or a button are attachments. How Slack builds its messages with attachments can be seen and tried out with their Message Builder.

While Viber, Kik, and Telegram also support Embedded List messages their emphasis seems to be more on using Custom Keyboards for things like buttons, images, etc. See Custom Keyboards below.

Carousel

A list of cards/slides can be displayed left to right with a slider -- Facebook recommends using this only when you think the first one is very likely to be desired and the ones to the right are just possible/recommendations of things the user might be interested in.

Note: the documentation of some platforms calls vertical displays of cards/slides also a "carousel". This is called simply "list layout" in other places. We're probably better off reserving the term carousel for only the horizontal display with slider to avoid confusion.

Buttons

These are clickable words or graphics possibly with styling and an image/icon associated with it. Currently Rocket.chat has command words that operates similarly in a rudimentary way. Buttons in chatbots have a wide range of styles and placements.

Horizontal Buttons

Below are a couple horizontal buttons in Slack followed by other examples from Messenger's Quick Replies.

Vertical Buttons

Here's an example from Telegram of buttons listed vertically.

Messenger's button template uses vertical buttons. Attaching three of these is supported in Messenger (Other platforms don't seem to have that limitation on the number of vertically listed buttons):

Actions Upon Button Click

So far we've seen four types of actions that occur on click of buttons:

  1. Send a message into the chat window
  2. Send a message back to the bot but do not display it in the chat window
  3. Open up a new web page via a url
  4. A configurably sizable webview in front of the chat window. See Integrated Webview below.

Special Buttons

Messenger has a number of similarly-formed pre-defined message templates for actions like Buy, Share, Call, Play Game, etc that then go to built-in follow-on actions like a checkout dialog in the case of Buy.

Telegram has a couple of these that it calls special buttons. Theirs request the user's phone number and/or location. Another Telegram example is if a message is sent with a game content type then there is a built in "play GameName" button.

One of Kik's Suggested Repsonses button options is something called Friend Picker that can be used to invite friends to a bot.

Dropdown Menu

Slack has a feature called Message Menus which supports a dropdown that can be populated with predetermined actions/choices, a list of members, a list of workspaces, etc.

Rich Messaging Below Composer

Of the surveyed platforms, only Slack doesn't appear to support bot content below the composer.

Custom Keyboards

Kik, Telegram, and Viber have a feature called custom keyboards which is a special keyboard with predefined reply options or actions. Here are a couple examples from Telegram and Viber:

Persistent Menu

Messenger by contrast supports what it calls a Persistent Menu below the composer. An always-on menu, it follows the below pattern of a couple menu items and then "More" with an arrow to others):

Integrated Webviews

The pages displayed in Messenger webviews can include a javascript SDK file, which allows the webview to access platform components/context like user profile, payments, what bot you are talking to, etc. The height of the webview when it opens is configurable:

Thus far Messenger is the only chat with this webview functionality that we've seen.

Resources and Further Notes

Message Specifications

Kik
Messenger
Slack
Telegram
Viber

Channel Inspector

Microsoft's Bot Framework site has a Channel Inspector in which you can see what different bot features -- carousel, buttons, etc -- look like in different platforms.

Bot List Sites

https://chatbottle.co/ and https://botlist.co/ have a searchable list of thousands of bots. The results list the platforms in which that bot is supported. This is useful for somewhat apples-to-apples comparisons of a given bot across platforms. You can also filter the search to only give bots supported in a desired platform (filter for Kik bots for example).

Viber/Messenger/Telegram Element Comparison

A survey of elements of Viber, Messenger, and Telegram. Includes Audio and Video.

Notes On Slack

This link from last year noting what Slack is lacking in bot support still seems accurate. Namely the following are not yet supported: conversational ui alignment, webview integration, horizontal scrolling carousel, quick replies.

Clone this wiki locally