I want to create a list of multiple options where users can select any option on a multiple choice list and get a response back based on selection. here is an example in the image.
Solved! Go to Solution.
PVA + Bot Framework Composer to display a dynamic adaptive card
For this example, I will use the current version of Power Virtual Agents that's extensible with the Bot Framework Composer. I will provide an example on how to present a chatbot user with an adaptive card that contains dynamic content that is retrieved from an external data source. I use Dataverse in this example, but the approach should be similar for any other data source, as I retrieve data with a Power Automate cloud flow and pass the data back to Power Virtual Agents.
In my scenario, I start in Power Virtual Agents:
Before going to Power Automate (to retrieve my data) or in Bot Framework Composer (to enrich my dialog with an adaptive card), the first thing I need to do is create and design an adaptive card.
I designed a sample card that looks like this:
The corresponding card JSON payload is:
{
"type": "AdaptiveCard",
"body": [
{
"type": "TextBlock",
"size": "Medium",
"weight": "Bolder",
"text": "️ Our Locations in X"
},
{
"type": "FactSet",
"facts": [
{
"title": "Option A",
"value": "Address 1"
},
{
"title": "Option B",
"value": "Address 2"
}
]
},
{
"type": "Container",
"items": [
{
"type": "TextBlock",
"text": " Open for more details",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false
},
{
"type": "ActionSet",
"actions": [
{
"type": "Action.OpenUrl",
"title": " Option A",
"url": "https://www.bing.com/search?q=Option A"
},
{
"type": "Action.OpenUrl",
"title": " Option B",
"url": "https://www.bing.com/search?q=Option B"
}
],
"spacing": "None",
"separator": true
},
{
"type": "TextBlock",
"text": " Select store",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false,
"horizontalAlignment": "Left",
"spacing": "Large"
}
],
"spacing": "Large"
},
{
"type": "ActionSet",
"actions": [
{
"type": "Action.Submit",
"title": " Option A",
"id": "A",
"data": "Option A"
},
{
"type": "Action.Submit",
"title": " Option B",
"id": "B",
"data": "Option B"
}
]
}
],
"$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
"version": "1.3"
}
To make the adaptive card dynamic, I will use Power Automate to provide the various JSON arrays my card needs in the expected format. Because I have 3 datasets that are slighthly different, I will create 3 array variables in my cloud flow: "List Of Accounts" for the FactSet, "List Of Accounts Actions" for the first ActionSet, and "List Of Accounts Actions Submit" for the second Action Set.
From my topic in Power Virtual Agents:
In Power Automate:
Now I need to use the data returned from my query to build the various variables I want to pass back to Power Virtual Agents and to my adaptive cards in Bot Framework Composer:
Back in Power Virtual Agents:
I'm now going to move over to the Bot Framework Composer.
In Bot Framework Composer:
Example:
- ```{
"type": "AdaptiveCard",
"body": [
{
"type": "TextBlock",
"size": "Medium",
"weight": "Bolder",
"text": "️ Our Locations in ${virtualagent.UserCity}"
},
{
"type": "FactSet",
"facts": ${virtualagent.ListOfAccounts}
},
{
"type": "Container",
"items": [
{
"type": "TextBlock",
"text": " Open for more details",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false
},
{
"type": "ActionSet",
"actions": ${virtualagent.ListOfAccountsActions},
"spacing": "None",
"separator": true
},
{
"type": "TextBlock",
"text": " Select store",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false,
"horizontalAlignment": "Left",
"spacing": "Large"
}
],
"spacing": "Large"
},
{
"type": "ActionSet",
"actions": ${virtualagent.ListOfAccountsActionsSubmit}
}
],
"$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
"version": "1.3"
}```
I return to my Power Virtual Agents "Store Locations" topic, and under "All other conditions", I add:
And that's it.
The adaptive card with dynamic content is presented to the user:
I am trying the same and the only way I can think of is (if the list of items is dynamic), call Power Automate and have Power Automate generate a adaptive card with buttons. Although adaptive cards support templating / data mapping, I am not able to find a way to map buttons to a list, so right now I am composing the card json and sending that into a "Post adaptive card to MS Teams and wait for response" action. That's for teams though, but if you want generic multiple choice, then have you seen this? https://learn.microsoft.com/en-us/composer/how-to-ask-for-user-input?tabs=v2x
Thanks!
Good-day
My bot behaves unexpectedly, sustaining the state of the first call of Array and didn't get through. I reviewed quite many times and had no clue. Appreciate any insight given.
Details:
1. created a PVC topic, called Main menu, redirect to a BFC dialog called BFCmainMenu
2. created a BFC dialog, called BFCmainMenu, with:
3. The branching dialog BFCbranchMenu mentioned at last bullet point above eventually redirect to a PVC topic
4. The abovementioned PVC topic eventually redirect to BFCmainMenu
However, chatbot does not display the main-Menu anymore, instead it displays the branch-Menu.
PVA + Bot Framework Composer to display a dynamic adaptive card
For this example, I will use the current version of Power Virtual Agents that's extensible with the Bot Framework Composer. I will provide an example on how to present a chatbot user with an adaptive card that contains dynamic content that is retrieved from an external data source. I use Dataverse in this example, but the approach should be similar for any other data source, as I retrieve data with a Power Automate cloud flow and pass the data back to Power Virtual Agents.
In my scenario, I start in Power Virtual Agents:
Before going to Power Automate (to retrieve my data) or in Bot Framework Composer (to enrich my dialog with an adaptive card), the first thing I need to do is create and design an adaptive card.
I designed a sample card that looks like this:
The corresponding card JSON payload is:
{
"type": "AdaptiveCard",
"body": [
{
"type": "TextBlock",
"size": "Medium",
"weight": "Bolder",
"text": "️ Our Locations in X"
},
{
"type": "FactSet",
"facts": [
{
"title": "Option A",
"value": "Address 1"
},
{
"title": "Option B",
"value": "Address 2"
}
]
},
{
"type": "Container",
"items": [
{
"type": "TextBlock",
"text": " Open for more details",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false
},
{
"type": "ActionSet",
"actions": [
{
"type": "Action.OpenUrl",
"title": " Option A",
"url": "https://www.bing.com/search?q=Option A"
},
{
"type": "Action.OpenUrl",
"title": " Option B",
"url": "https://www.bing.com/search?q=Option B"
}
],
"spacing": "None",
"separator": true
},
{
"type": "TextBlock",
"text": " Select store",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false,
"horizontalAlignment": "Left",
"spacing": "Large"
}
],
"spacing": "Large"
},
{
"type": "ActionSet",
"actions": [
{
"type": "Action.Submit",
"title": " Option A",
"id": "A",
"data": "Option A"
},
{
"type": "Action.Submit",
"title": " Option B",
"id": "B",
"data": "Option B"
}
]
}
],
"$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
"version": "1.3"
}
To make the adaptive card dynamic, I will use Power Automate to provide the various JSON arrays my card needs in the expected format. Because I have 3 datasets that are slighthly different, I will create 3 array variables in my cloud flow: "List Of Accounts" for the FactSet, "List Of Accounts Actions" for the first ActionSet, and "List Of Accounts Actions Submit" for the second Action Set.
From my topic in Power Virtual Agents:
In Power Automate:
Now I need to use the data returned from my query to build the various variables I want to pass back to Power Virtual Agents and to my adaptive cards in Bot Framework Composer:
Back in Power Virtual Agents:
I'm now going to move over to the Bot Framework Composer.
In Bot Framework Composer:
Example:
- ```{
"type": "AdaptiveCard",
"body": [
{
"type": "TextBlock",
"size": "Medium",
"weight": "Bolder",
"text": "️ Our Locations in ${virtualagent.UserCity}"
},
{
"type": "FactSet",
"facts": ${virtualagent.ListOfAccounts}
},
{
"type": "Container",
"items": [
{
"type": "TextBlock",
"text": " Open for more details",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false
},
{
"type": "ActionSet",
"actions": ${virtualagent.ListOfAccountsActions},
"spacing": "None",
"separator": true
},
{
"type": "TextBlock",
"text": " Select store",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false,
"horizontalAlignment": "Left",
"spacing": "Large"
}
],
"spacing": "Large"
},
{
"type": "ActionSet",
"actions": ${virtualagent.ListOfAccountsActionsSubmit}
}
],
"$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
"version": "1.3"
}```
I return to my Power Virtual Agents "Store Locations" topic, and under "All other conditions", I add:
And that's it.
The adaptive card with dynamic content is presented to the user:
PVA unified authoring canvas to display a dynamic adaptive card
In this second answer, I use the unified authoring canvas to provide an example on how to present a chatbot user with an adaptive card that contains dynamic content that is retrieved from an external data source. I use Dataverse in this example, but the approach should be similar for any other data source, as I retrieve data with a Power Automate cloud flow and pass the data back to Power Virtual Agents.
In Power Virtual Agents, using the unified authoring canvas:
Before going to Power Automate (to retrieve my data) the first thing I need to do is create and design an adaptive card.
I designed a sample card that looks like this:
The corresponding card JSON payload is:
{
"type": "AdaptiveCard",
"body": [
{
"type": "TextBlock",
"size": "Medium",
"weight": "Bolder",
"text": "️ Our Locations in X"
},
{
"type": "FactSet",
"facts": [
{
"title": "Option A",
"value": "Address 1"
},
{
"title": "Option B",
"value": "Address 2"
}
]
},
{
"type": "Container",
"items": [
{
"type": "TextBlock",
"text": " Open for more details",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false
},
{
"type": "ActionSet",
"actions": [
{
"type": "Action.OpenUrl",
"title": " Option A",
"url": "https://www.bing.com/search?q=Option A"
},
{
"type": "Action.OpenUrl",
"title": " Option B",
"url": "https://www.bing.com/search?q=Option B"
}
],
"spacing": "None",
"separator": true
},
{
"type": "TextBlock",
"text": " Select store",
"wrap": true,
"size": "Default",
"weight": "Bolder",
"color": "Accent",
"isSubtle": false,
"horizontalAlignment": "Left",
"spacing": "Large"
}
],
"spacing": "Large"
},
{
"type": "ActionSet",
"actions": [
{
"type": "Action.Submit",
"title": " Option A",
"id": "A",
"data": "Option A"
},
{
"type": "Action.Submit",
"title": " Option B",
"id": "B",
"data": "Option B"
}
]
}
],
"$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
"version": "1.3"
}
To make the adaptive card dynamic, I use Power Automate to provide the various JSON arrays my card needs in the expected format. Because I have 3 datasets that are slighthly different, I create 3 array variables in my cloud flow: "List Of Accounts" for the FactSet, "List Of Accounts Actions" for the first ActionSet, and "List Of Accounts Actions Submit" for the second Action Set.
From my topic in Power Virtual Agents:
In Power Automate:
Now I need to use the data returned from my query to build the various variables I want to pass back to Power Virtual Agents and to my adaptive cards in Bot Framework Composer:
Back in Power Virtual Agents:
Under "All other conditions", I add:
{
type: "AdaptiveCard",
body: [
{
type: "TextBlock",
size: "Medium",
weight: "Bolder",
text: "🗺️ Our Locations in " & Topic.UserCity
},
{
type: "FactSet",
facts: ForAll(
Table(ParseJSON(Topic.ListOfAccounts)),
{
title: Text(ThisRecord.Value.title),
value: Text(ThisRecord.Value.value)
}
)
},
{
type: "Container",
items: [
{
type: "TextBlock",
text: "🔎 Open for more details",
wrap: true,
size: "Default",
weight: "Bolder",
color: "Accent",
isSubtle: false
},
{
type: "ActionSet",
actions: ForAll(
Table(ParseJSON(Topic.ListOfAccountsActions)),
{
type: Text(ThisRecord.Value.type),
title: Text(ThisRecord.Value.title),
url: Text(ThisRecord.Value.url)
}
),
spacing: "None",
separator: true
},
{
type: "TextBlock",
text: "👆 Select store",
wrap: true,
size: "Default",
weight: "Bolder",
color: "Accent",
isSubtle: false,
horizontalAlignment: "Left",
spacing: "Large"
}
],
spacing: "Large"
},
{
type: "ActionSet",
actions: ForAll(
Table(ParseJSON(Topic.ListOfAccountsActionsSubmit)),
{
type: Text(ThisRecord.Value.type),
title: Text(ThisRecord.Value.title),
id: Text(ThisRecord.Value.id),
data: Text(ThisRecord.Value.data)
}
)
}
],
'$schema': "http://adaptivecards.io/schemas/adaptive-card.json",
version: "1.3"
}
I then can:
And that's it.
The adaptive card with dynamic content is presented to the user:
Excellent illustration. Despite my nil knowledge on PA, I strived to follow your guide, attempting to induce a "better solution" to my own situation. I finally got it working with numerous trial-and-error in those PA flows/external data source etc.
I had a breakthrough in my learning!
Thank you so much HenryJammes!
Great to hear @gorLookPo – we plan to create a few MS Learn articles out of these and hopefully they will be easier to follow. Feel free to reach out by private message to share the steps that require more guidance 🙂
Episode Six of Power Platform Connections sees David Warner and Hugo Bernier talk to talk to Business Applications MVP Shane Young, alongside the latest news, product updates, and community blogs. Use the hashtag #PowerPlatformConnects on social media for a chance to have your work featured on the show! Show schedule in this episode: 0:00 Cold Open 00:24 Show Intro 01:02 Shane Young Interview 22:00 Blogs & Articles 22:20 Integrate FullCalendar.io with Power Pages 23:50 Text Data 25:15 Zero to Hero Power Apps Saga 25:44 Parent Hub Association 26:33 Using Custom Values for OneNote Power Automate References 28:04 Dynamics Power Israel 28:44 Create Beautiful Canvas Apps in Dataverse for Teams 30:36 Outro & Bloopers Check out the blogs and articles featured in this week’s episode: https://francomusso.com/integrate-fullcalendar-io-with-power-pages-from-json-basics-to-advanced-output-with-bootstrap-modal @crmbizcoach https://yerawizardcat.com/text/ @YerAWizardCat www.fromzerotoheroes.com/mentorship @thevictordantas https://www.expiscornovus.com/2023/03/16/parent-hub-association/ @Expiscornovus https://lindsaytshelton.com/2023/03/15/the-painful-process-of-custom-values-for-onenote-power-automate-references/ @lshelton_Tech https://never-stop-learning.de/create-beautiful-canvas-apps-in-dataverse-for-teams/ @MMe2K Action requested: Feel free to provide feedback on how we can make our community more inclusive and diverse. This episode premiered live on our YouTube at 12pm PST on Thursday 23rd March 2023. Video series available at Power Platform Community YouTube channel. Upcoming events: Business Applications Launch – April 4th – Free and Virtual! M365 Conference - May 1-5th - Las Vegas Power Apps Developers Summit – May 19-20th - London European Power Platform conference – Jun. 20-22nd - Dublin Microsoft Power Platform Conference – Oct. 3-5th - Las Vegas Join our Communities: Power Apps Community Power Automate Community Power Virtual Agents Community Power Pages Community If you’d like to hear from a specific community member in an upcoming recording and/or have specific questions for the Power Platform Connections team, please let us know. We will do our best to address all your requests or questions.
Super Users – 2023 Season 1 We are excited to kick off the Power Users Super User Program for 2023 - Season 1. The Power Platform Super Users have done an amazing job in keeping the Power Platform communities helpful, accurate and responsive. We would like to send these amazing folks a big THANK YOU for their efforts. Super User Season 1 | Contributions July 1, 2022 – December 31, 2022 Super User Season 2 | Contributions January 1, 2023 – June 30, 2023 Curious what a Super User is? Super Users are especially active community members who are eager to help others with their community questions. There are 2 Super User seasons in a year, and we monitor the community for new potential Super Users at the end of each season. Super Users are recognized in the community with both a rank name and icon next to their username, and a seasonal badge on their profile. Power Apps Power Automate Power Virtual Agents Power Pages Pstork1* Pstork1* Pstork1* OliverRodrigues BCBuizer Expiscornovus* Expiscornovus* ragavanrajan AhmedSalih grantjenkins renatoromao Mira_Ghaly* Mira_Ghaly* Sundeep_Malik* Sundeep_Malik* SudeepGhatakNZ* SudeepGhatakNZ* StretchFredrik* StretchFredrik* 365-Assist* 365-Assist* cha_cha ekarim2020 timl Hardesh15 iAm_ManCat annajhaveri SebS Rhiassuring LaurensM abm TheRobRush Ankesh_49 WiZey lbendlin Nogueira1306 Kaif_Siddique victorcp RobElliott dpoggemann srduval SBax CFernandes Roverandom schwibach Akser CraigStewart PowerRanger MichaelAnnis subsguts David_MA EricRegnier edgonzales zmansuri GeorgiosG ChrisPiasecki ryule AmDev fchopo phipps0218 tom_riha theapurva takolota Akash17 momlo BCLS776 Shuvam-rpa rampprakash ScottShearer Rusk ChristianAbata cchannon Koen5 a33ik AaronKnox Matren Alex_10 Jeff_Thorpe poweractivate Ramole DianaBirkelbach DavidZoon AJ_Z PriyankaGeethik BrianS StalinPonnusamy HamidBee CNT Anonymous_Hippo Anchov KeithAtherton alaabitar Tolu_Victor KRider sperry1625 IPC_ahaas zuurg rubin_boer cwebb365 If an * is at the end of a user's name this means they are a Multi Super User, in more than one community. Please note this is not the final list, as we are pending a few acceptances. Once they are received the list will be updated.
We are excited to share the ‘Power Platform Communities Front Door’ experience with you! Front Door brings together content from all the Power Platform communities into a single place for our community members, customers and low-code, no-code enthusiasts to learn, share and engage with peers, advocates, community program managers and our product team members. There are a host of features and new capabilities now available on Power Platform Communities Front Door to make content more discoverable for all power product community users which includes ForumsUser GroupsEventsCommunity highlightsCommunity by numbersLinks to all communities Users can see top discussions from across all the Power Platform communities and easily navigate to the latest or trending posts for further interaction. Additionally, they can filter to individual products as well. Users can filter and browse the user group events from all power platform products with feature parity to existing community user group experience and added filtering capabilities. Users can now explore user groups on the Power Platform Front Door landing page with capability to view all products in Power Platform. Explore Power Platform Communities Front Door today. Visit Power Platform Community Front door to easily navigate to the different product communities, view a roll up of user groups, events and forums.
Today, we are excited to unveil new features within Power Platform that incorporate next-generation AI, in including conversation boosters with Power Virtual Agents and AI Builder introducing a create text with GPT model. These features bring both a new way for developers to solve business problems and a new way for end-users to leverage AI in the flow of their work to be more productive. This is a glimpse of what’s to come as we continue to ramp up our investment in AI across Power Platform. We recognize the significance of both AI and low code for organizations and the benefits these technologies in union can have for all developers: a more intuitive, iterative experience for citizen developers and accelerated development for professional developers. We announced AI Builder 4 years ago as the first AI capability in Power Platform, followed by Power Apps Ideas 18 months ago, which was the first infusion of generative AI in a commercially- available product. And we have continued to invest, with the addition of express design in Power Apps, and description to flow in Power Automate late last year. Today, we’re taking another big step forward in this journey with the launch of next-generation AI features for Power Virtual Agents and AI Builder, enabled by Azure Open AI service. New! – Conversation booster in Microsoft Power Virtual Agents New! – Create text with GPT model in AI Builder AI Builder create text with GPT model Read the full Product blog here: https://aka.ms/PP-GPT **Tips & tricks for using the Power Virtual Agents Boost Conversational Coverage Preview: Solved: Tips & tricks for using the Power Virtual Agents B... - Power Platform Community (microsoft.com)
We are so excited to see you for the Microsoft Power Platform Conference in Las Vegas October 3-5 2023! But first, let's take a look back at some fun moments and the best community in tech from MPPC 2022 in Orlando, Florida. Featuring guest speakers such as Charles Lamanna, Heather Cook, Julie Strauss, Nirav Shah, Ryan Cunningham, Sangya Singh, Stephen Siciliano, Hugo Bernier and many more. Register today: https://www.powerplatformconf.com/
Following our recent release of Conversation Boosters for PVA, today we’re excited to go further and announce Copilot for Power Virtual Agents! With Copilot, using the power of Azure Open AI, you simply describe what you would like your bot to, using natural language, and Copilot will build an entire PVA topic - ready to use in seconds! What can the new Copilot in Power Virtual Agents do? CREATE entire topic from scratch with a simple description. REFINE content in an existing topic, such as asking for additional questions to be added or updating existing nodes (example: providing message variations). SUMMARIZE information collected from a user with adaptive cards. ITERATE over just part of a dialog with specific node selection. Try Copilot in Power Virtual Agents now: https://aka.ms/tryPVA Learn more in the full blog post: https://aka.ms/GPT-PP