This project is licensed under GPL 3.0 and later
This project is currently under development, and does NOT have a released version yet.
Per the documentation at https://adaptivecards.io (a Microsoft website), Adaptive Cards are best described as follows:
Adaptive Cards are platform-agnostic snippets of UI, authored in JSON, that apps and services can openly exchange. When delivered to a specific app, the JSON is transformed into native UI that automatically adapts to its surroundings. It helps design and integrate light-weight UI for all major platforms and frameworks.
This is heavily useful in automated bot response applications, etc. including those built upon and working with Microsoft Teams and the Microsoft bot frameworks.
This way, you can use Python object-oriented programming to easily generate the JSON for objects and cards without ever having to touch the JSON underneath.
Okay, you got us - this is Yet Another Implementation of Adaptive Cards (AC for short below).
However, the only Python libraries I could find for Adaptive Cards that were 'developer
friendly' were either Cisco's outdated repository for Adaptive Cards support, or adaptivecards
on PyPI which has not been updated since AC version 1.2. This set of code functions -
adaptivecardsng - is a Python Object-Oriented design of AC development and creation, and
follows the spec at https://adaptivecards.io/explorer/ as closely as it can for the current release.
As of right now while you're reading this document, this library is written to be AC 1.5 compliant.
It also includes a number of additional things that are not available in other versions, such as the specific schemas and Enums that are defined within the AC spec as actual Enums and object types here so that you can more easily choose options without having to remember all the strings. This also makes sure that you don't have any type of unrecognized arguments in the JSON when sending it off to endpoints.
Yep, fully written in Python. Specifically, Python 3, with support for Python 3.7 and newer.
Don't ask for older Python versions, please, because we use certain type definitions and type
hinting that don't work with older versions of Python before 3.7. This is due to what the Python
versions of __future__
support and older than 3.7 does not support the type annotations we use
for type hinting, and we have that there intentionally.
There are some differences between this library and adaptivecards
, there are some distinct
differences.
Because a code sample is more useful to understand, we'll write one here (this is also in the file
examples/readme_example.py
):
from adaptivecardsng.elements import TextBlock, FontType, FontSize, FontWeight
from adaptivecardsng.containers import Container, ColumnSet, Column
from adaptivecardsng.cards import AdaptiveCard
card = AdaptiveCard()
card.body = [
Container(items=[
TextBlock(text=f'Adaptive Cards Example',
font_weight=FontWeight.bolder, font_size=FontSize.large, wrap=True),
ColumnSet(columns=[
Column(width='stretch',
items=[
TextBlock(text="author", font_weight=FontWeight.bolder, wrap=True),
TextBlock(text='version', font_weight=FontWeight.bolder, wrap=True)
]),
Column(width='stretch',
items=[
TextBlock(text="Thomas Ward", wrap=True),
TextBlock(text="0.0.0-alpha.0", wrap=True,
font_type=FontType.monospace)
])
])
]),
TextBlock(text="more information available at "
"[/~https://github.com/teward/adaptivecardsng]"
"(/~https://github.com/teward/adaptivecardsng)",
subtle=True, wrap=True, font_size=FontSize.small)
]
print(str(card))
This generates this output:
{
"$schema": "https://adaptivecards.io/schemas/adaptive-card.json",
"body": [
{
"items": [
{
"size": "large",
"style": "default",
"text": "Adaptive Cards Example",
"type": "TextBlock",
"weight": "bolder",
"wrap": true
},
{
"columns": [
{
"items": [
{
"style": "default",
"text": "author",
"type": "TextBlock",
"weight": "bolder",
"wrap": true
},
{
"style": "default",
"text": "version",
"type": "TextBlock",
"weight": "bolder",
"wrap": true
}
],
"width": "stretch"
},
{
"items": [
{
"style": "default",
"text": "Thomas Ward",
"type": "TextBlock",
"wrap": true
},
{
"fontType": "monospace",
"style": "default",
"text": "0.0.0-alpha.0",
"type": "TextBlock",
"wrap": true
}
],
"width": "stretch"
}
],
"type": "ColumnSet"
}
],
"type": "Container"
},
{
"isSubtle": true,
"size": "small",
"style": "default",
"text": "more information available at [/~https://github.com/teward/adaptivecardsng](/~https://github.com/teward/adaptivecardsng)",
"type": "TextBlock",
"wrap": true
}
],
"type": "AdaptiveCard",
"version": "1.5"
}
And that in turn, when rendered in Teams after properly being transmitted and formatted as a Teams-compatible message looks something like this:
See AUTHORS file for the list of authors and contributors.
Adaptive Cards appear to be a framework developed by Microsoft - https://adaptivecards.io/
Code samples here in the README are inspired by the example provided in the README of the older adaptivecards library by Huu Hoa NGUYEN.
Teams rendering is via Microsoft Teams, a Microsoft Product, using the Incoming Webhook mechanism.