public/writing/Write-SpectreCalendar.ps1

using module "..\..\private\completions\Completers.psm1"
using module "..\..\private\completions\Transformers.psm1"

function Write-SpectreCalendar {
    <#
    .SYNOPSIS
    Writes a Spectre Console Calendar text to the console.
 
    .DESCRIPTION
    Writes a Spectre Console Calendar text to the console.
 
    .PARAMETER Date
    The date to display the calendar for.
 
    .PARAMETER Alignment
    The alignment of the calendar.
 
    .PARAMETER Color
    The color of the calendar.
 
    .PARAMETER Border
    The border of the calendar.
 
    .PARAMETER Culture
    The culture of the calendar.
 
    .PARAMETER Events
    The events to highlight on the calendar.
    Takes a hashtable with the date as the key and the event as the value.
 
    .PARAMETER HideHeader
    Hides the header of the calendar. (Date)
 
    .PARAMETER PassThru
    Returns the Spectre Calendar object instead of writing it to the console.
 
    .EXAMPLE
    # **Example 1**
    # This example demonstrates how to write a calendar to the console.
    Write-SpectreCalendar -Date 2024-07-01 -Events @{'2024-07-10' = 'Beach time!'; '2024-07-20' = 'Barbecue' }
 
    .EXAMPLE
    # **Example 2**
    # This example demonstrates how to write a calendar to the console with some event details.
    $events = @{
        '2024-01-10' = 'Hello World!'
        '2024-01-20' = 'Hello Universe!'
    }
    Write-SpectreCalendar -Date 2024-01-01 -Events $events
    #>

    [Reflection.AssemblyMetadata("title", "Write-SpectreCalendar")]
    param (
        [datetime] $Date = [datetime]::Now,
        [ValidateSet([SpectreConsoleJustify], ErrorMessage = "Value '{0}' is invalid. Try one of: {1}")]
        [string] $Alignment = "Left",
        [ColorTransformationAttribute()]
        [ArgumentCompletionsSpectreColors()]
        [Spectre.Console.Color] $Color = $script:AccentColor,
        [ValidateSet([SpectreConsoleTableBorder], ErrorMessage = "Value '{0}' is invalid. Try one of: {1}")]
        [string] $Border = "Rounded",
        [cultureinfo] $Culture = [cultureinfo]::CurrentCulture,
        [Hashtable]$Events,
        [Switch] $HideHeader,
        [Switch] $PassThru
    )
    $calendar = [Spectre.Console.Calendar]::new($date)
    $calendar.Alignment = [Spectre.Console.Justify]::$Alignment
    $calendar.Border = [Spectre.Console.TableBorder]::$Border
    $calendar.BorderStyle = [Spectre.Console.Style]::new($Color)
    $calendar.Culture = $Culture
    $calendar.HeaderStyle = [Spectre.Console.Style]::new($Color)
    $calendar.HighlightStyle = [Spectre.Console.Style]::new($Color)
    if ($HideHeader) {
        $calendar.ShowHeader = $false
    }

    $outputData = @($calendar)

    if ($Events) {
        foreach ($event in $events.GetEnumerator()) {
            # Calendar events don't appear to support Culture.
            $eventDate = $event.Name -as [datetime]
            $calendar = [Spectre.Console.CalendarExtensions]::AddCalendarEvent($calendar, $event.value, $eventDate.Year, $eventDate.Month, $eventDate.Day)
        }
        $outputData += $calendar.CalendarEvents | Sort-Object -Property Day | Format-SpectreTable -Property Description, Year, Month, Day -Border $Border -Color $Color
    }

    if ($PassThru) {
        return $outputData
    }
    
    $outputData | Out-SpectreHost
}