npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@jovotech/output-facebookmessenger

v4.0.0-beta.9

Published

--- title: 'Facebook Messenger Output' excerpt: 'Learn more about Jovo output templates for Facebook Messenger.' --- # Facebook Messenger Output

Readme


title: 'Facebook Messenger Output' excerpt: 'Learn more about Jovo output templates for Facebook Messenger.'

Facebook Messenger Output

Learn more about output templates for Facebook Messenger.

Introduction

Jovo offers the ability to create structured output that is then translated into native platform responses.

This structured output is called output template. Its root properties are generic output elements that work across platforms. Learn more about how generic output is translated into a Facebook Messenger response below.

{
  message: `Hello world! What's your name?`
}

You can also add platform-specific output to an output template. Learn more about Facebook Messenger-specific output below.

{
  // ...
  platforms: {
    facebookMessenger: {
      // ...
    }
  }
}

Generic Output Elements

Generic output elements are in the root of the output template and work across platforms. Learn more in the Jovo output template docs.

Below, you can find a list of generic output elements that work with Facebook Messenger:

message

The generic message element contains the main response of your bot, which is usually displayed in a chat bubble:

{
  message: 'Hello world!',
}

It is also possible to use message as an object which contains both a speech (the spoken text on platforms like Alexa) and a text (written text to be displayed in chat bubbles) field. In this case, Facebook Messenger uses the text element.

{
  message: {
    speech: 'Hello listener!',
    text: 'Hello reader!'
  }
}

Under the hood, Jovo translates the message into message.text as part of a call to the Facebook Send API (see the official Facebook Messenger docs):

{
  "recipient": {
    "id": "<PSID>"
  },
  "message": {
    "text": "Hello world!"
  }
}

quickReplies

The generic quickReplies element allows you to define small buttons that help the user answer a question faster. This concept is also called quick replies in the Facebook Messenger documentation.

Quick replies can be an array of strings:

{
  // ...
  quickReplies: [ 'yes', 'no' ]
}

Alternatively, you can use an array of objects that includes a text (what the user sees) and a value (what is passed to the bot):

{
  // ...
  quickReplies: [
    {
      text: 'oh yeah',
      value: 'yes'
    },
    {
      text: 'hell no',
      value: 'no'
    }
  ]
}

Under the hood, Jovo translates these into Facebook Messenger quick replies of the type text. Learn more in the official Facebook Messenger documentation. The quick replies are added to a message:

{
  "recipient":{
    "id":"<PSID>"
  },
  "messaging_type": "RESPONSE",
  "message": {
    "quick_replies": [
      {
        "content_type": "text",
        "title": "oh yeah",
        "payload": "yes"
      },
      {
        "content_type": "text",
        "title": "hell no",
        "payload": "no"
      }
    ]
  }
}

The payload is the value that gets passed to the NLU integration to turn raw text into structured content. For quick replies that are passed as strings, the title and payload are the same. If the quick replies are objects, the text gets turned into title and the value into payload.

For other quick reply content types, see nativeQuickReplies below.

card

The generic card element can be used to send a Facebook Messenger generic template. Learn more about other templates below.

Here is an example of a card with all properties that are supported by Facebook Messenger:

{
  // ...
  card: {
    title: 'Hello world!',
    subtitle: 'Welcome to the show.',
    imageUrl: 'https://...',

    // Facebook Messenger specific properties
    defaultAction: { /* ... */ },
    buttons: [ /* ... */ ]
  },
}

The following values are specific for Facebook Messenger and are described in detail in sections below:

  • defaultAction: A URL that is opened in the Facebook Messenger webview when a user taps the template. This element has the same properties as the URL button type that's described in the buttons section below.
  • buttons: Up to 3 buttons that can be attached to the card.

Under the hood, Jovo translates the card into the following generic template:

{
  "recipient":{
    "id": "<PSID>"
  },
  "message":{
    "attachment":{
      "type": "template",
      "payload":{
        "template_type": "generic",
        "elements": [
           {
            "title": "Hello world!",
            "image_url":"https://...",
            "subtitle": "Welcome to the show.",
            "default_action": {
              "type": "web_url",
              "url": "https://...",
              "webview_height_ratio": "tall",
            },
            "buttons": [
              {
                "type":"postback",
                "title":"Start Chatting",
                "payload":"DEVELOPER_DEFINED_PAYLOAD"
              }              
            ]      
          }
        ]
      }
    }
  }
}

Learn more about this structure in the official API reference by Facebook.

carousel

A generic carousel element is a horizontally scrollable set of card items. In Facebook's definition, this is called a carousel of generic templates.

This is how a carousel can be defined:

{
  // ...
  carousel: {
    items: [
      {
        title: 'Hello world!',
        subtitle: 'Welcome to the show.',
        imageUrl: 'https://...',
      },
      {
        title: 'Hello again!',
        subtitle: 'This is element 2.',
        imageUrl: 'https://...',
      }
    ]
  },
}

The elements in an items array can contain all properties that are shown in the card section.

Facebook Messenger Output Elements

It is possible to add platform-specific output elements to an output template. Learn more in the Jovo output template documentation.

For Facebook Messenger, you can add output elements inside a facebookMessenger object:

{
  // ...
  platforms: {
    facebookMessenger: {
      // ...
    }
  }
}

These elements include:

nativeQuickReplies

The generic quickReplies element can be used for text based quick replies that are supported by many platforms. Additionally, Facebook Messenger supports quick replies that allow you to ask users for their phone number or their email address.

For this, you can use the nativeQuickReplies element that offers all properties in the same way as they are detailed in the official Facebook Messenger API reference.

Here is an example for a phone number quick reply:

import { QuickReplyContentType } from '@jovotech/output-facebookmessenger';

// ...

{
  // ...
  platforms: {
    facebookMessenger: {
      nativeQuickReplies: [
        {
          content_type: QuickReplyContentType.UserPhoneNumber // or 'user_phone_number'
        }
      ]
    }
  }
}

The following quick reply types are supported:

| Enum key | Enum value | Links | |----------|------------|-------| | QuickReplyContentType.Text | 'text' | Code, Official Docs | | QuickReplyContentType.UserPhoneNumber | 'user_phone_number' | Code, Official Docs | | QuickReplyContentType.UserEmail | 'user_email' | Code, Official Docs |

template

Facebook offers different types of message templates. The generic template (which is the result of the generic card element from above) is one example for structured data that can be displayed. Learn more about templates in the official Facebook Messenger docs](https://developers.facebook.com/docs/messenger-platform/send-messages/templates).

You can add a template like this:

import { TemplateType } from '@jovotech/output-facebookmessenger';

// ...

{
  // ...
  platforms: {
    facebookMessenger: {
      template: [
        {
          template_type: TemplateType.Receipt // or 'receipt'
        }
      ]
    }
  }
}

Depending on the type, different properties can be added in the same way they are used in the Facebook Messenger API,for example:

import { TemplateType } from '@jovotech/output-facebookmessenger';

// ...

{
  // ...
  platforms: {
    facebookMessenger: {
      template: [
        {
          template_type: TemplateType.Receipt, // or 'receipt'
          recipient_name: 'Some Name',
          order_number: '2021100123',
          // ...
        }
      ]
    }
  }
}

Here is a table of all supported template types:

| Enum key | Enum value | Links | |----------|------------|-------| | TemplateType.Generic | 'generic' | Code, Official Docs | | TemplateType.Receipt | 'receipt' | Code, Official Docs | | TemplateType.Button | 'button' | Code, Official Docs | | TemplateType.Media | 'media' | Code, Official Docs |

A template gets translated into the following:

{
  "recipient":{
    "id":"<PSID>"
  },
  "message":{
    "attachment":{
      "type":"template",
      "payload":{
        "template_type":"<TEMPLATE_TYPE>",
        // ...
      }
    }
  }
}

buttons

All templates (including the generic card element that gets translated into a generic template) may contain buttons, which are added using the buttons array.

import { ButtonType } from '@jovotech/output-facebookmessenger';

// ...

{
  // ...
  card: {
    // ...
    buttons: [
      {
        type: ButtonType.Postback, // or 'postback'
        title: 'Start Chatting',
        payload: 'DEVELOPER_DEFINED_PAYLOAD' // what happens with payload?
      }

    ],
  },
}

Here is a table of all supported button types:

| Enum key | Enum value | Links | |----------|------------|-------| | ButtonType.Postback | 'postback' | Code, Official Docs | | ButtonType.Url | 'web_url' | Code, Official Docs | | ButtonType.Call | 'phone_number' | Code, Official Docs | | ButtonType.LogIn | 'account_link' | Code, Official Docs | | ButtonType.LogOut | 'account_unlink' | Code, Official Docs | | ButtonType.GamePlay | 'game_play' | Code, Official Docs |

Learn more about all buttons types in the official Facebook Messenger docs