New-SiteNavigation

Build navigation bar content for a HTML page from a specification and redering templates

Syntax

 New-SiteNavigation [-NavitemSpecs] <Object[]> [-RelativePath] <String> [-NavTemplate] <Object>  [<CommonParameters>] 

Description

A navigation bar section for a HTML page is built by:

Parameters

An array where each item án object or dictionary with exactly one NoteProperty or key representing a single key-value pair. This parameter provides the data for one item in the navigation bar.

Following key-value pairs are recognized:

Key Value Template Name Description
"text" "url" navitem A clickable hyperlink where text is the link text and url a link to a web page or a local Markdown file. Local file links must be relative to the project root.
"text" "" navlabel A label without hyperlink.
"---" "" navseparator A speparator line.

The structure of the data determines the type of navigation bar item to build. The table above maps supported key-value combinations to the associated named HTML templates.


Parameter Property Value
Required? true
Position? 1
Default value ``
Accept pipeline input? false
Accept wildcard characters? false

-RelativePath <String>

Path to a Markdown file relative to the site root. That file's relative path is used to adjust the links of in the given navigation bar item, so that it can be reached from the location of the HTML page currently being assembled using the Markdown file. The given path should use forward slash '/' path separators.


Parameter Property Value
Required? false
Position? 2
Default value ``
Accept pipeline input? false
Accept wildcard characters? false

An optional dictionary of named HTML templates.

Type Key HTML Template
clickable link "navitem"
<button class='navitem'>
    <a href='{{navurl}}'>{{navtext}}</a>
</button>
label (no link) "navlabel"
<div class='navlabel'>{{navtext}}</div>
separator "navseparator"
<hr/>

The HTML templates listed represent are the values configured in Build.json. These values are used for keys not provided in the given dictionary or if no dictionary is given at all. Additional mappings contained in dictionary are ignored.

For more customization options see Static Site Project Customization.

The css styles used in the templates are defined in md-styles.css.

During the build process the placeholders contained in the HTML template are replaced with content extracted from the NavSpec parameter .

Placeholder Description
{{navurl}} hyperlink to web-page or local file.
{{navtext}} link or label text

Parameter Property Value
Required? false
Position? 3
Default value $defaultNavTemplate
Accept pipeline input? false
Accept wildcard characters? false

Inputs

None

Outputs

HTML fragment for a navigation bar.

Examples

EXAMPLE 1

New-SiteNavigation -NavitemSpecs $specs -RelativePath 'a/b/c/bob.md'

Create navigation content for a file with relative path a/b/c/bob.md and the specification $specs and default templates:

$specs is defined like so:

$specs = @(
    @{ "<img width='90%' src='logo.png' />" = "README.md" },
    @{ "README" = "" },
    @{ "Home" = "README.md" },
    @{ "---" = "" }
)

Output:

<button class="navitem">
   <a href="../../../README.html">
      <img width='90%' src='../../../logo.png' />
   </a>
</button>
<div class="navlabel">README</div>
<button class="navitem">
   <a href="../../../README.html">Home</a>
</button>
<hr/>

Note how the relative path parameter was used to update the links.

Related Links


Module: MarkDownToHTML; Version: 2.4.0; (c) 2018-2021 WetHat Lab. All rights reserved.