Examples/Example16.ps1

[CmdletBinding()]
param (
    [System.String[]] $Format = 'Html',
    [System.String] $Path = '~\Desktop',
    [System.Management.Automation.SwitchParameter] $PassThru
)

Import-Module PScribo -Force -Verbose:$false

$example16 = Document -Name 'PScribo Example 16' {

    <#
        If you do not have a collection/array of objects that you wish to create
        a table from, PScribo supports creating a table from single ordered hashtable
        or an array of ordered hashtables.

        NOTE: You cannot pipe a single hashtable or an array of hashtables to the
              'Table' cmdlet. You MUST pass the hashtable(s) via the -HashTable parameter.
              If you pipe the hashtable(s), the hashtable object's properties are
              displayed and not the hashtable key/value pairs!

        Creating a hashtable does permit the utilisation of spaces in the key names,
        requiring that the -Headers parameter does not necessarily need to be used.

        NOTE: This is not a standard hashtable, but a System.Collections.Specialized.OrderedDictionary
              object. These can be created with the [Ordered] attribute on the hashtable
              declaration, e.g. [Ordered] @{ Key1 = Value1; Key2 = Value2; }

        The following example creates a table with a single row with the hashtable keys
        used as the header values and the corresponding values as the first table row.
    #>

    $hashtable = [Ordered] @{
        'Column 1' = 'Some random text'
        'Column2' = 345
        'Custom Property' = $true
    }
    Table -Hashtable $hashtable
}
$example16 | Export-Document -Path $Path -Format $Format -PassThru:$PassThru