public/formatting/New-SpectreChartItem.ps1

using module "..\..\private\models\SpectreChartItem.psm1"
using module "..\..\private\completions\Completers.psm1"

<#
.SYNOPSIS
Creates a new SpectreChartItem object.

.DESCRIPTION
The New-SpectreChartItem function creates a new SpectreChartItem object with the specified label, value, and color for use in Format-SpectreBarChart and Format-SpectreBreakdownChart.

.PARAMETER Label
The label for the chart item.

.PARAMETER Value
The value for the chart item.

.PARAMETER Color
The color for the chart item. Must be a valid Spectre color as name, hex or a Spectre.Console.Color object.

.EXAMPLE
New-SpectreChartItem -Label "Sales" -Value 1000 -Color "green"

This example creates a new SpectreChartItem object with a label of "Sales", a value of 1000, and a green color.

#>

function New-SpectreChartItem {
    [Reflection.AssemblyMetadata("title", "New-SpectreChartItem")]
    param (
        [Parameter(Mandatory)]
        [string]$Label,
        [Parameter(Mandatory)]
        [double]$Value,
        [Parameter(Mandatory)]
        [ValidateSpectreColor()]
        [ArgumentCompletionsSpectreColors()]
        [string]$Color
    )

    return [SpectreChartItem]::new($Label, $Value, $Color)
}