Public/Elements/New-CardImage.ps1

<#
.SYNOPSIS
    Creates a new Image element for an Adaptive Card.
 
.DESCRIPTION
    The New-CardImage function creates an Image element that displays images in an Adaptive Card.
    It supports various sizing options, fit modes, and accessibility features to ensure proper
    image display across different devices and platforms.
 
.PARAMETER Url
    The URL of the image to display. Supports both HTTP/HTTPS URLs and data URLs.
    The image should be accessible by the client application displaying the Adaptive Card.
 
.PARAMETER AltText
    Alternative text for the image, used for accessibility purposes. This text is read by
    screen readers and displayed when the image cannot be loaded. Should describe the content
    or purpose of the image.
 
.PARAMETER FitMode
    Specifies how the image should be fitted within its allocated space. Valid values are:
    - Cover: Scale the image to cover the entire area, may crop parts of the image
    - Contain: Scale the image to fit completely within the area, may leave empty space
    - Fill: Stretch the image to fill the entire area, may distort the image proportions
 
.PARAMETER Size
    The size of the image. Valid values are:
    - Auto: Automatic sizing based on the image's natural dimensions
    - Stretch: Stretch to fill available width
    - Small: Small fixed size
    - Medium: Medium fixed size
    - Large: Large fixed size
 
.PARAMETER Id
    An optional unique identifier for the Image element. Useful for referencing the image
    in actions like toggle visibility or for accessibility purposes.
 
.PARAMETER Separator
    A switch parameter that adds a separator line above the image element. Useful for
    visually separating the image from preceding elements.
 
.PARAMETER AllowExpand
    A switch parameter that allows the image to be expanded when clicked/tapped.
    When enabled, users can interact with the image to view it in a larger format.
 
.OUTPUTS
    System.Collections.Hashtable
        Returns a hashtable representing the Image element structure for the Adaptive Card.
 
.EXAMPLE
    New-CardImage -Url "https://example.com/logo.png" -AltText "Company Logo"
     
    Creates a basic image element with a URL and alt text.
 
.EXAMPLE
    New-CardImage -Url "https://example.com/photo.jpg" -AltText "Team Photo" -Size "Large" -FitMode "Cover"
     
    Creates a large image that covers its allocated space, potentially cropping parts of the image.
 
.EXAMPLE
    New-CardImage -Url "https://example.com/chart.png" -AltText "Sales Chart" -Id "SalesChart" -AllowExpand -Separator
     
    Creates an expandable image with a separator line above it and an ID for reference in actions.
 
.EXAMPLE
    New-CardImage -Url "" -AltText "Red pixel" -Size "Small"
     
    Creates a small image using a data URL (base64 encoded image).
 
.NOTES
    - The Url parameter should point to an accessible image resource
    - AltText is crucial for accessibility and should meaningfully describe the image
    - FitMode and Size parameters work together to control image appearance
    - AllowExpand provides interactive image viewing capabilities
    - The Separator parameter helps with visual organization of card elements
    - Data URLs are supported for embedding small images directly in the card
 
.LINK
    https://docs.microsoft.com/en-us/adaptive-cards/authoring-cards/card-schema#image
#>

Function New-CardImage {
    param(
        [string]$Url,
        [string]$AltText,
        [ValidateSet("Cover","Contain","Fill")]
        [string]$FitMode,
        [ValidateSet("Auto","Stretch","Small","Medium","Large")]
        [string]$Size,
        [string]
        [Parameter(Mandatory = $false)]
        $Id,
        [switch]$Separator, 
        [switch]$AllowExpand,
        [switch]$AsBase64
        
    )

    $Image = @{
        type    = "Image"
        url     = $Url
        altText = $AltText
    }

    if( $AsBase64 ) {
        #Download the image and convert to base64
        $WebClient = New-Object System.Net.WebClient
        $ImageBytes = $WebClient.DownloadData($Url)
        $Base64String = [Convert]::ToBase64String($ImageBytes)

        $Image.url = "data:image/png;base64,$Base64String"
    }

    if ($Separator) {
        $Image.separator = $true
    }
    
    if ($FitMode) {
        $Image.fitMode = $FitMode
    }

    if ($Id) {
        $Image.id = $Id
    }
    
    if ($Size) {
        $Image.size = $Size
    }

    if ($AllowExpand) {
        $Image.allowExpand = $true
    }

    return $Image

}