This document describes multi-product message ("MPM") templates, their uses, and how to use them.
MPM templates are marketing templates that allow you to showcase up to 30 products from your ecommerce catalog, organized in up to 10 sections, in a single message.

Customers can browse products and sections within the message, view details for each product, add and remove products from their cart, and submit their cart to place an order. Orders are then sent to you via a webhook.

See our help center article About Multi-product message templates on WhatsApp for common use cases and tips on how to make the most of MPM templates.
In order to create and use MPM templates you must have an ecommerce product catalog, with inventory, connected to your WhatsApp Business Account. See the Cloud API Commerce guide.
You can create MPM templates using the WhatsApp Business Account > Message Templates endpoint or the WhatsApp Manager > Account tools > Message templates panel. Once your template is approved, you can use Cloud API or On-Premises API to send it in a template message.
curl -X POST "https://graph.facebook.com/v23.0/<WHATSAPP_BUSINESS_ACCOUNT_ID>/message_templates" \
-H "Authorization: Bearer <ACCESS_TOKEN>" \
-H "Content-Type: application/json" \
-d '{
"name": "<NAME>",
"category": "<CATEGORY>",
"language": "<LANGUAGE>",
"components": [<COMPONENTS>]
}'| Placeholder | Description | Sample Value |
|---|---|---|
| Required. Template category. Set this to |
|
| Required. Array of objects that describe the components that make up the template. See Components below. | See Components below. |
| Required. Template language and locale code. |
|
| Required. Template name. Maximum 512 characters. |
|
The components value must be an array of objects that describes each component that makes up the template. MPM templates must have the following components:
[
{
"type": "HEADER",
"format": "TEXT",
"text": "<HEADER_TEXT>",
/* Example required if header uses a variable */
"example": {
"header_text": [
"<HEADER_EXAMPLE_TEXT>"
]
}
},
{
"type": "BODY",
"text": "<BODY_TEXT>",
/* Example required if body uses variables */
"example": {
"body_text": [
[
"<BODY_EXAMPLE_TEXT>"
]
]
}
},
{
"type": "FOOTER",
"text": "<FOOTER_TEXT>"
},
{
"type":"BUTTONS",
"buttons": [
{
"type": "MPM",
"text": "View items"
}
]
}
]| Placeholder | Description | Sample Value |
|---|---|---|
| String or array of strings. Example body variable value(s). |
|
| Template body text. Supports multiple variables. If the string contains variables, you must include the example property and sample variable values. 1024 characters maximum. |
|
| Template footer text. 60 characters maximum. |
|
| Example header variable value. |
|
| Template header text. Supports 1 variable. If the string contains a variable, you must include the example property and a sample variable value. 60 characters maximum. |
|
Upon success, the API will respond with:
{
"id": "<ID>",
"status": "<STATUS>",
"category": "MARKETING"
}| Placeholder | Description | Sample Value |
|---|---|---|
| Template ID. |
|
| Template status. Only templates with an |
|
curl 'https://graph.facebook.com/v24.0/102290129340398/message_templates' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer EAAJB...' \
-d '
{
"name": "abandoned_cart",
"language": "en_US",
"category": "MARKETING",
"components": [
{
"type": "HEADER",
"format": "TEXT",
"text": "Forget something, {{1}}?",
"example": {
"header_text": [
"Pablo"
]
}
},
{
"type": "BODY",
"text": "Looks like you left these items in your cart, still interested? Use code {{1}} to get 10% off!",
"example": {
"body_text": [
[
"10OFF"
]
]
}
},
{
"type":"BUTTONS",
"buttons": [
{
"type": "MPM",
"text": "View items"
}
]
}
]
}'
{
"id": "546151681022936",
"status": "PENDING",
"category": "MARKETING"
}
When a customer adds one or more products to their cart and submits an order, we will send you a webhook that describes the order.
{
"object": "whatsapp_business_account",
"entry": [
{
"id": "<ENTRY.ID>",
"changes": [
{
"value": {
"messaging_product": "whatsapp",
"metadata": {
"display_phone_number": "<DISPLAY_PHONE_NUMBER>",
"phone_number_id": "<PHONE_NUMBER_ID>"
},
"contacts": [
{
"profile": {
"name": "<NAME>"
},
"wa_id": "<WA_ID>"
}
],
"messages": [
{
"from": "<FROM>",
"id": "<MESSAGES.ID>",
"timestamp": "<TIMESTAMP>",
"type": "order",
"order": {
"catalog_id": "<CATALOG_ID>",
"product_items": [
{
"product_retailer_id": "<PRODUCT_RETAILER_ID>",
"quantity": <QUANTITY>,
"item_price": <ITEM_PRICE>,
"currency": "<CURRENCY>"
}
]
}
}
]
},
"field": "messages"
}
]
}
]
}| Placeholder | Description | Sample Value |
|---|---|---|
| Ecommerce product catalog ID. |
|
| Item currency. |
|
| Business phone number display number. |
|
| WhatsApp Business Account ID. |
|
| Item price. |
|
| WhatsApp message ID. |
|
| Customer's name. |
|
| Business phone number ID. |
|
| The item SKU number. Labeled as Content ID in the Commerce Manager. |
|
| Number of items ordered (for this particular item). |
|
| UNIX timestamp indicating when we sent you the webhook. |
|
| Customer's WhatsApp phone number. |
|
{
"object": "whatsapp_business_account",
"entry": [
{
"id": "102290129340398",
"changes": [
{
"value": {
"messaging_product": "whatsapp",
"metadata": {
"display_phone_number": "15550051310",
"phone_number_id": "106540352242922"
},
"contacts": [
{
"profile": {
"name": "Pablo Morales"
},
"wa_id": "16505551234"
}
],
"messages": [
{
"from": "16505551234",
"id": "wamid.HBgLMTY1MDM4Nzk0MzkVAgASGBQzQTMxNzA1QzNENEI4ODY0OTY2MAA=",
"timestamp": "1683223069",
"type": "order",
"order": {
"catalog_id": "1537566713439863",
"product_items": [
{
"product_retailer_id": "n6k6x0y7oe",
"quantity": 1,
"item_price": 99.99,
"currency": "USD"
}
]
}
}
]
},
"field": "messages"
}
]
}
]
}
This document explains how to send multi-product message (MPM) templates in template messages.
MPM template messages must have:
Use the MPM button component to define sections and their titles that will appear when the customer taps the View items button, and to designate which products appear in each of those sections.

To send an approved MPM template in a template message, send a POST request to the WhatsApp Business Phone Number > Messages endpoint. Use the POST body to define the contents of the message and to describe any variables to inject into the template itself.
curl -X POST "https://graph.facebook.com/v23.0/<BUSINESS_PHONE_NUMBER_ID>/messages" \
-H "Authorization: Bearer <ACCESS_TOKEN>" \
-H "Content-Type: application/json" \
-d '
{
"messaging_product": "whatsapp",
"recipient_type": "individual",
"to": "<TO>",
"type": "template",
"template": {
"name": "<NAME>",
"language": {
"code": "<CODE>"
},
"components": [
{
"type": "header",
"parameters": [
{
"type": "text",
"text": "<HEADER_TEXT>"
}
]
},
{
"type": "body",
"parameters": [
{
"type": "text",
"text": "<BODY_TEXT>"
}
]
},
{
"type": "button",
"sub_type": "mpm",
"index": 0,
"parameters": [
{
"type": "action",
"action": {
"thumbnail_product_retailer_id": "<THUMBNAIL_PRODUCT_RETAILER_ID>",
"sections": [
{
"title": "<TITLE>",
"product_items": [
{
"product_retailer_id": "<PRODUCT_RETAILER_ID_1>"
},
{
"product_retailer_id": "<PRODUCT_RETAILER_ID_2>"
}
// ... Add up to 30 product items per section
]
}
// ... Add up to 10 section objects as needed
]
}
}
]
}
]
}
}'| Placeholder | Description | Sample Value |
|---|---|---|
| Required if template uses variables. String or array of strings. Text to replace body variable(s) defined in the template. |
|
| Template language and locale code. |
|
| Required if template uses a variable. Text to replace header variable defined in the template. |
|
| Template name. |
|
| SKU number of the item you want to appear in the section. SKU numbers are labeled as Content ID in the Commerce Manager. Supports up to 30 products total, across all sections. |
|
| Item SKU number. Labeled as Content ID in the Commerce Manager. The thumbnail of this item will be used as the template message's header image. |
|
| Section title text. You can define up to 10 sections. Maximum 24 characters. Markdown is not supported. |
|
| Customer phone number. |
|
Upon success, the API will respond with:
{
"messaging_product": "whatsapp",
"contacts": [
{
"input": "<INPUT>",
"wa_id": "<WA_ID>"
}
],
"messages": [
{
"id": "<ID>"
}
]
}| Placeholder | Description | Sample Value |
|---|---|---|
| WhatsApp message ID. |
|
| Customer WhatsApp phone number. |
|
| Customer WhatsApp ID. |
|
This example sends an approved template named "abandoned_cart" and injects a variable (the customer's first name) into the template header and a discount code into the template body. It also defines two sections ("Popular Bundles" and "Premium Packages") and identifies the products (a total of 3) that should be injected into those sections.
curl 'https://graph.facebook.com/v24.0/106540352242922/messages' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer EAAJB...' \
-d '
{
"messaging_product": "whatsapp",
"recipient_type": "individual",
"to": "16505551234",
"type": "template",
"template": {
"name": "abandoned_cart",
"language": {
"code": "en_US"
},
"components": [
{
"type": "header",
"parameters": [
{
"type": "text",
"text": "Pablo"
}
]
},
{
"type": "body",
"parameters": [
{
"type": "text",
"text": "10OFF"
}
]
},
{
"type": "button",
"sub_type": "mpm",
"index": 0,
"parameters": [
{
"type": "action",
"action": {
"thumbnail_product_retailer_id": "2lc20305pt",
"sections": [
{
"title": "Popular Bundles",
"product_items": [
{
"product_retailer_id": "2lc20305pt"
},
{
"product_retailer_id": "nseiw1x3ch"
}
]
},
{
"title": "Premium Packages",
"product_items": [
{
"product_retailer_id": "n6k6x0y7oe"
}
]
}
]
}
}
]
}
]
}
}'
{
"messaging_product": "whatsapp",
"contacts": [
{
"input": "16505551234",
"wa_id": "16505551234"
}
],
"messages": [
{
"id": "wamid.HBgLMTY1MDM4Nzk0MzkVAgARGBJDOEI3ODgxNzQzMjJBQTdEQTcA"
}
]
}