Public/New-Diagram.ps1
function New-Diagram { <# .SYNOPSIS Creates a new mermaid diagram. .DESCRIPTION Creates and returns a new diagram definition, that can be populated and later exported. .INPUTS None. .OUTPUTS Mermaid diagram definition object. .EXAMPLE PS C:\> $diagram = New-MermaidDiagram -ErDiagram PS C:\> $diagram | Add-MermaidErRelation Exactly-one Customer places Zero-or-more Order PS C:\> $diagram | Add-MermaidErRelation Exactly-one Order contains One-or-more LineItem PS C:\> $diagram | Add-MermaidErRelation One-or-more Customer uses One-or-more DeliveryAddress -NonIdentifying PS C:\> $diagram | ConvertTo-MermaidString erDiagram Customer ||--o{ Order : places Order ||--|{ LineItem : contains Customer }|..|{ DeliveryAddress : uses Create a erDiagram, add a few relations and convert it to a diagram string. .LINK https://mermaid-js.github.io/mermaid/#/README?id=diagram-types #> [CmdletBinding( DefaultParameterSetName = 'erDiagram' )] param ( # The mermaid diagram type. [Parameter( Mandatory, ParameterSetName = 'flowchart', Position = 0 )] [switch] $Flowchart, [Parameter( Mandatory, ParameterSetName = 'erDiagram', Position = 0 )] [switch] $ErDiagram, [Parameter( Mandatory, ParameterSetName = 'C4Component', Position = 0 )] [switch] $C4Component, # The diagram orientation. [Parameter( ParameterSetName = 'flowchart', Position = 1 )] [ValidateSet('top-to-bottom', 'top-down', 'bottom-to-top', 'right-to-left', 'left-to-right')] [string] $Orientation, # The diagram title. [Parameter( ParameterSetName = 'flowchart')] [Parameter( ParameterSetName = 'erDiagram')] [string] $Title, # The diagram configuration. [Parameter( ParameterSetName = 'flowchart')] [Parameter( ParameterSetName = 'erDiagram')] [hashtable] $Config ) $definition = [PSCustomObject]@{ Type = $PSCmdlet.ParameterSetName } switch ( $definition.Type ) { erDiagram { if ( $Title ) { $definition | Add-Member Title $Title } if ( $Config ) { $definition | Add-Member Config $Config } $definition | Add-Member Relations @() } flowchart { if ( $Title ) { $definition | Add-Member Title $Title } if ( $Config ) { $definition | Add-Member Config $Config } if ( $Orientation ) { $definition | Add-Member Orientation $Orientation } $definition | Add-Member Nodes @() $definition | Add-Member Links @() $definition | Add-Member Classes @() $definition | Add-Member Clicks @() $definition | Add-Member Subgraphs @() } C4Component { $definition | Add-Member ContainerBoundaries @() $definition | Add-Member Relations @() } } Write-Output $definition } |