Rendering cards inside your application
It's easy to render Adaptive Cards inside your application. We provide SDKs for the all common platforms, as well as provide a detailed specification for creating your own Adaptive Card renderer.
- Install a renderer SDK - for your target platform.
- Create a renderer instance - configured with your app's style, rules, and action event handlers.
- Render a card to native UI - automatically styled to your app.
Platform | Install | Build | Docs | Status |
---|---|---|---|---|
JavaScript | Source | Docs | ||
.NET WPF | Source | Docs | ||
.NET HTML | Source | Docs | ||
Windows UWP | Source | Docs | ||
WinUI 3 | Source | Docs | ||
Android | Source | Docs | ||
iOS | Source | Docs |
The next step is to create an instance of an AdaptiveCardRenderer
.
By default, the actions will render as buttons on the card, but it's up to your app to make them behave as you expect. Each SDK has the equivalent of an OnAction
event that you must handle.
- Action.OpenUrl - open the specified
url
. - Action.Submit - take the result of the submit and send it to the source. How you send it to the source of the card is entirely up to you.
- Action.ShowCard - invokes a dialog and renders the sub-card into that dialog. Note that you only need to handle this if
ShowCardActionMode
is set topopup
.
After you acquire a card payload, simply call the renderer and pass in the card. You will get back a native UI object made up of the card contents. Now just put this UI somewhere in your app.
There are several ways you can customize what is rendered.
A HostConfig is a shared, cross-platform configuration object that controls the basic styling and behavior of cards inside your app. It defines things like font sizes, spacing between elements, colors, number of supported actions, etc.
Most UI frameworks allow you to style the rendered card by using the native UI framework styling. For example, in HTML you can specify CSS classes for the HTML, or in XAML you can pass in a custom ResourceDictionary for fine-grained control of the output.
Each SDK allows you to override the rendering of any element, or even add support for entirely new elements that you define. For example, you can change the Input.Date
renderer to emit your own custom control while still retaining the rest of the output of the renderer. Or you can add support for a custom Rating
element that you define.