Adaptive Card Dynamic Table Row with Input

Copper Contributor

Is there a way off returning a unique id for data input within a data bound table row;
e.g.

 

{
  "id": "dac-adaptive-card_9a5e618395add",
  "type": "AdaptiveCard",
  "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
  "version": "1.5",
  "body": [
    {
      "id": "dac-table_62e669cba1fb6",
      "type": "Table",
      "isVisible": true,
      "separator": false,
      "firstRowAsHeaders": true,
      "showGridLines": true,
      "columns": [
        {
          "width": "48px"
        },
        {
          "width": 1
        },
        {
          "width": 1
        },
        {
          "width": 1
        }
      ],
      "rows": [
        {
          "id": "dac-table-row_5b1511475aca9",
          "type": "TableRow",
          "isVisible": true,
          "separator": false,
          "style": "good",
          "cells": [
            {
              "id": "dac-table-cell_13890654f4c46",
              "type": "TableCell",
              "isVisible": true,
              "separator": false,
              "bleed": false,
              "items": []
            },
            {
              "id": "dac-table-cell_158f02ba2663c",
              "type": "TableCell",
              "isVisible": true,
              "separator": false,
              "bleed": false,
              "items": [
                {
                  "id": "dac-text-block_25aace4759935",
                  "type": "TextBlock",
                  "isVisible": true,
                  "separator": false,
                  "isSubtle": false,
                  "wrap": true,
                  "text": "Name"
                }
              ]
            },
            {
              "id": "dac-table-cell_5e858cdd40b07",
              "type": "TableCell",
              "isVisible": true,
              "separator": false,
              "bleed": false,
              "items": [
                {
                  "id": "dac-text-block_b12b5994084d1",
                  "type": "TextBlock",
                  "isVisible": true,
                  "separator": false,
                  "isSubtle": false,
                  "wrap": true,
                  "text": "Company"
                }
              ]
            },
            {
              "id": "dac-table-cell_3f71dba1bef22",
              "type": "TableCell",
              "isVisible": true,
              "separator": false,
              "bleed": false,
              "items": [
                {
                  "id": "dac-text-block_903c643ccd425",
                  "type": "TextBlock",
                  "isVisible": true,
                  "separator": false,
                  "isSubtle": false,
                  "wrap": true,
                  "text": "Phone"
                }
              ]
            }
          ]
        },
        {
          "id": "dac-table-row_0e45fb421026b",
          "type": "TableRow",
          "$data": "${contacts}",
          "isVisible": true,
          "separator": false,
          "cells": [
            {
              "id": "dac-table-cell_05234d36b53ae",
              "type": "TableCell",
              "isVisible": true,
              "separator": false,
              "bleed": false,
              "items": [
                {
                  "id": "dac-image_f896a5e7e02c4",
                  "type": "Image",
                  "$when": "${HasPhoto == ''}",
                  "isVisible": true,
                  "separator": false,
                  "style": "person",
                  "url": "",
                  "size": "small"
                },
                {
                  "id": "dac-image_a54044b1eba5",
                  "type": "Image",
                  "isVisible": true,
                  "separator": false,
                  "style": "person",
                  "url": "${HasPhoto}",
                  "size": "small"
                }
              ]
            },
            {
              "id": "dac-table-cell_09de26a811d27",
              "type": "TableCell",
              "isVisible": true,
              "separator": false,
              "bleed": false,
              "items": [
                {
                  "id": "dac-text-block_a2909e1c1d549",
                  "type": "TextBlock",
                  "isVisible": true,
                  "separator": false,
                  "isSubtle": false,
                  "wrap": true,
                  "text": "${flName}"
                }
              ]
            },
            {
              "id": "dac-table-cell_16f4337b75bc8",
              "type": "TableCell",
              "isVisible": true,
              "separator": false,
              "bleed": false,
              "items": [
                {
                  "id": "dac-text-block_3a5d911c72cc9",
                  "type": "TextBlock",
                  "isVisible": true,
                  "separator": false,
                  "isSubtle": false,
                  "wrap": true,
                  "text": "${Company}"
                }
              ]
            },
            {
              "id": "dac-table-cell_8cb17140318af",
              "type": "TableCell",
              "isVisible": true,
              "separator": false,
              "bleed": false,
              "items": [
                {
                  "id": "phoneNumber",
                  "type": "Input.Text",
                  "isVisible": true,
                  "separator": false,
                  "isRequired": false,
                  "isMultiline": false,
                  "value": "${Phone}"
                }
              ]
            }
          ]
        }
      ]
    },
    {
      "id": "dac-action-set_48ba70e6c17ed",
      "type": "ActionSet",
      "isVisible": true,
      "separator": false,
      "actions": [
        {
          "id": "dac-action-execute_3b8f4c1b86f0e",
          "type": "Action.Execute",
          "title": "Submit"
        }
      ]
    }
  ],
  "_modified": 1700493451320
}

 

with data of

 

{
  "contacts": [
    {
      "HasPhoto": "https://randomuser.me/api/portraits/men/66.jpg",
      "flName": "Al Balfour",
      "Company": "Madison Company",
      "Phone": "202.555.8300",
      "$root": {
        "contacts": {}
      }
    },
    {
      "HasPhoto": "",
      "flName": "Albert McCaine",
      "Company": "Southland Hospital",
      "Phone": "408.819.7000",
      "$root": {
        "contacts": {}
      }
    }
  ]
}

 


when you submit this data it will only return the data for last phoneNumber ID
Screenshot 2023-11-20 at 15.26.36.png
Is there a way to bind a unique id to the phoneNumber, or return the data an array of 

 

[{"phoneNumber":"202.555.8300"}, {"phoneNumber":"408.819.7000"}]

 


Thanks in advance

6 Replies

@RichardRose - Adaptive Cards does not support dynamic IDs that could be bound to the data. The ID of an input field must be a constant string and cannot be bound to data.

 

 

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. Click here to escalate. 

This is why I asked about return an array of the constant string id, rather than the last found.
This seems an oversight in the table implementation.
Table Cells allow you to add input fields bound to a id string and table rows can be repeated, the two are not compatible unless the return data from the inputs reflects the row bound data.
Allowing Input fileds in table cells is misleading otherwise as they are incomplete

@RichardRose - In the Adaptive Card, you can have multiple input fields, each with a unique ID. When the user interacts with the card and submits it, the data from these fields is sent back to your bot in a JSON object. The keys in this object correspond to the IDs of the input fields in the card.

{
    "type": "AdaptiveCard",
    "body": [
        {
            "type": "Input.Text",
            "id": "input1",
            "placeholder": "Input 1"
        },
        {
            "type": "Input.Text",
            "id": "input2",
            "placeholder": "Input 2"
        }
    ],
    "actions": [
        {
            "type": "Action.Submit",
            "title": "Submit"
        }
    ],
    "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
    "version": "1.2"
}

In this example, data['input1'] and data['input2'] will give you the values of the corresponding input fields in the Adaptive Card. If you want to return an array of these values, you can simply put them in an array:

app.adaptiveCards.actionSubmit('Action.Submit', async (context, _state, data) => {
    const input1 = data['input1'];
    const input2 = data['input2'];
    const result = [input1, input2];
    await context.sendActivity(`Result array is: ${result}`);
});

This will send a message with the array of input field values.

you are missing the point, the rows of the table are generated by binding them to an array of data,
repeating the row template that is defined including an input for the phoneNumber.
These are not hardcode rows with an unique id set for each input.
They are data driven so could be 2 rows or 50, it doesn't matter.
This is the issue, there is no way of collecting the input for the x amount of rows unless either,
1. each rows assigns a dynamic ID to the phoneNumber input - which is not going to happen;
2. the data on submit returns an array of phoneNumer ID's each indexed to the row that they were entered on - a possibility for future enhancement

@RichardRose - Okay, got it. Let us do some analysis on it if it can be achieved. We will revert back to you.

@RichardRose - We checked but could not find any way. To achieve your requirements, we recommend you give your feedback in Teams Feedback Portal.