New-AMColumnSet
New-AMColumnSet
SYNOPSIS
Creates a ColumnSet element for an Adaptive Card.
SYNTAX
1
New-AMColumnSet [-Id] <String> [-Columns] <Array> [-Verbose <SwitchParameter>] [-Debug <SwitchParameter>] [-ErrorAction <ActionPreference>] [-WarningAction <ActionPreference>] [-InformationAction <ActionPreference>] [-ProgressAction <ActionPreference>] [-ErrorVariable <String>] [-WarningVariable <String>] [-InformationVariable <String>] [-OutVariable <String>] [-OutBuffer <Int32>] [-PipelineVariable <String>] [<CommonParameters>]
DESCRIPTION
Creates a ColumnSet element that allows you to arrange content in multiple columns. ColumnSets are one of the primary layout elements in Adaptive Cards and enable side-by-side content arrangement.
A ColumnSet contains one or more Column objects, each created with the New-AMColumn function. Each column can contain its own set of elements (text, images, etc.).
EXAMPLES
EXAMPLE 1
1
2
3
4
# Create a simple two-column layout
$leftColumn = New-AMColumn -Width "1" -Items @(
(New-AMTextBlock -Text "Left Column Content" -Wrap $true)
)
Example explanation
1
2
3
4
5
6
$rightColumn = New-AMColumn -Width "1" -Items @(
(New-AMTextBlock -Text "Right Column Content" -Wrap $true)
)
$columnSet = New-AMColumnSet -Id "two-column-layout" -Columns @($leftColumn, $rightColumn)
Add-AMElement -Card $card -Element $columnSet
EXAMPLE 2
1
2
3
4
# Create a profile card with image and info
$imageColumn = New-AMColumn -Width "auto" -Items @(
(New-AMImage -Url "https://example.com/profile.jpg" -Size "Small")
)
Example explanation
1
2
3
4
5
6
7
8
$infoColumn = New-AMColumn -Width "stretch" -Items @(
(New-AMTextBlock -Text "Jane Smith" -Size "Medium" -Weight "Bolder"),
(New-AMTextBlock -Text "Senior Engineer" -Spacing "None"),
(New-AMTextBlock -Text "Department: R&D" -Spacing "Small")
)
$profileLayout = New-AMColumnSet -Id "profile-card" -Columns @($imageColumn, $infoColumn)
Add-AMElement -Card $card -Element $profileLayout
EXAMPLE 3
1
2
3
4
# Create a three-column layout with different widths
$col1 = New-AMColumn -Width "2" -Items @(
(New-AMTextBlock -Text "Column 1 (Width 2)")
)
Example explanation
1
2
3
4
5
6
7
8
9
10
$col2 = New-AMColumn -Width "1" -Items @(
(New-AMTextBlock -Text "Column 2 (Width 1)")
)
$col3 = New-AMColumn -Width "1" -Items @(
(New-AMTextBlock -Text "Column 3 (Width 1)")
)
$threeColumnLayout = New-AMColumnSet -Id "proportional-columns" -Columns @($col1, $col2, $col3)
Add-AMElement -Card $card -Element $threeColumnLayout
PARAMETERS
-Id
A unique identifier for the ColumnSet. This ID can be used to reference the ColumnSet when adding elements to it, or when targeting it with visibility toggle actions.
1
2
3
4
5
6
7
8
9
Type: String
Parameter Sets: (All)
Aliases: None
Required: True
Position: 0
Default value: None
Accept pipeline input: False
Accept wildcard characters: False
-Columns
An array of Column objects created using the New-AMColumn function. These columns will be displayed side-by-side within the ColumnSet.
1
2
3
4
5
6
7
8
9
Type: Array
Parameter Sets: (All)
Aliases: None
Required: True
Position: 1
Default value: None
Accept pipeline input: False
Accept wildcard characters: False
CommonParameters
This cmdlet supports the common parameters: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutVariable, -OutBuffer, -PipelineVariable, -Verbose, -WarningAction, and -WarningVariable. For more information, see about_CommonParameters.
INPUTS
None. You cannot pipe input to New-AMColumnSet.
OUTPUTS
System.Collections.Hashtable
Returns a hashtable representing the ColumnSet element.
NOTES
ColumnSets are powerful layout tools in Adaptive Cards. Some key points:
- You can create responsive layouts by using proportional widths (“1”, “2”, etc.)
- Use “auto” width for columns that should be sized to their content
- Use “stretch” width for columns that should fill remaining space
- Each column can have its own vertical alignment
The resulting ColumnSet can be added directly to a card body or to another container element using Add-AMElement.