Forum Discussion
Table in adaptive cards
This is my data for table where the buckets in billingproviderskick will be having many no of objects so , i want to implement this in a table , then i have tried in this as provided in the below code
{
"type": "AdaptiveCard",
"body": [
{
"type": "Table",
"columns": [
{
"width": 1
},
{
"width": 1
}
],
"$data": "${billingProvidersKick.buckets}",
"rows": [
{
"type": "TableRow",
"cells": [
{
"type": "TableCell",
"items": [
{
"type": "TextBlock",
"text": "${val}",
"spacing": "Small"
},
{
"type": "ColumnSet",
"columns": [
{
"type": "Column",
"items": [
{
"type": "Image",
"url": "https://cdn-icons-png.flaticon.com/512/49/49172.png",
"size": "Small"
}
],
"width": "20px"
},
{
"type": "Column",
"items": [
{
"type": "TextBlock",
"weight": "Bolder",
"text": "$${formatNumber(totalBilledAmount, 10)}",
"wrap": true
}
],
"width": "stretch"
}
]
},
{
"type": "ColumnSet",
"columns": [
{
"type": "Column",
"items": [
{
"type": "Image",
"url": "",
"size": "Small"
}
],
"width": "20px"
},
{
"type": "Column",
"items": [
{
"type": "TextBlock",
"weight": "Bolder",
"text": "${formatNumber(distinctClaimCount, 0)}",
"wrap": true
}
],
"width": "stretch"
}
]
},
{
"type": "TextBlock",
"text": "$${formatNumber(totalPaidAmount, 2)}",
"spacing": "Small",
"wrap": true
}
]
},
{
"type": "TableCell",
"items": [
{
"type": "ColumnSet",
"columns": [
{
"type": "Column",
"items": [
{
"type": "Image",
"url": "https://media.istockphoto.com/id/613529262/vector/glass-sphere-with-blood.jpg?s=612x612&w=0&k=20&c=JLKQlDcKkiByAr7GEaIqKUutYnfMIat60BJ4WOdVWrY=",
"altText": "${status}",
"height": "20px"
}
],
"width": "auto"
},
{
"type": "Column",
"spacing": "small",
"selectAction": {
"type": "Action.ToggleVisibility",
"title": "expand",
"targetElements": [
"cardContent${$index}",
"chevronDown${$index}",
"chevronUp${$index}"
]
},
"verticalContentAlignment": "center",
"items": [
{
"type": "Image",
"id": "chevronDown${$index}",
"url": "https://adaptivecards.io/content/down.png",
"width": "20px"
},
{
"type": "Image",
"id": "chevronUp${$index}",
"url": "https://adaptivecards.io/content/up.png",
"width": "20px",
"isVisible": false
}
],
"width": "auto"
}
]
},
{
"type": "Container",
"id": "cardContent${$index}",
"isVisible": false,
"items": [
{
"type": "Container",
"items": [
{
"$data": "${a_claims.buckets}",
"type": "TextBlock",
"text": "* ${val}",
"isSubtle": false,
"wrap": true
}
]
}
]
}
]
}
]
}
]
}
],
"$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
"version": "1.5"
}
{
"billingProvidersKick": {
"buckets": [
{
"val": "normal school",
"count": 20,
"totalBilledAmount": 87687.765768,
"distinctClaimCount": 2,
"totalPaidAmount": 9058.71,
"a_claims": {
"buckets": [
{
"val": "1234567",
"count": 29
},
{
"val": "2345678",
"count": 20
}
]
}
}
]
}
}
here , for each object in bucket the table has been repeated but i wan to repeat the row .
if i add any row as header then this header is attached to every single row
so please guide me as i want to loop row no the table
To repeat the rows instead, you should set the "$data" property at the TableRow level.
{ "type": "AdaptiveCard", "body": [ { "type": "Table", "columns": [ { "width": 1 }, { "width": 1 } ], "rows": [ { "$data": "${billingProvidersKick.buckets}", "type": "TableRow", "cells": [ { "type": "TableCell", "items": [ { "type": "TextBlock", "text": "${val}", "spacing": "Small" }, // ... rest of your code ] }, // ... rest of your code ] } ] } ], "$schema": "http://adaptivecards.io/schemas/adaptive-card.json", "version": "1.5" }
In this JSON, the "$data" property is set at the TableRow level, which means that for each object in the "buckets" array, a new row will be created in the table.
Thanks,
Prasad Das
------------------------------------------------------------------------------------------
If the response is helpful, please click "**Mark as Best Response**" and like it. You can share your feedback via Microsoft Teams Developer Feedback link.
1 Reply
- Prasad_Das-MSFT
Microsoft
To repeat the rows instead, you should set the "$data" property at the TableRow level.
{ "type": "AdaptiveCard", "body": [ { "type": "Table", "columns": [ { "width": 1 }, { "width": 1 } ], "rows": [ { "$data": "${billingProvidersKick.buckets}", "type": "TableRow", "cells": [ { "type": "TableCell", "items": [ { "type": "TextBlock", "text": "${val}", "spacing": "Small" }, // ... rest of your code ] }, // ... rest of your code ] } ] } ], "$schema": "http://adaptivecards.io/schemas/adaptive-card.json", "version": "1.5" }
In this JSON, the "$data" property is set at the TableRow level, which means that for each object in the "buckets" array, a new row will be created in the table.
Thanks,
Prasad Das
------------------------------------------------------------------------------------------
If the response is helpful, please click "**Mark as Best Response**" and like it. You can share your feedback via Microsoft Teams Developer Feedback link.