You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1.7 KiB
HTML
40 lines
1.7 KiB
HTML
{{ $page := . }}
|
|
|
|
{{ $basepath := path.Clean (urls.Parse site.BaseURL).Path }}
|
|
{{ $breakpoint := $page.Param "paige.menu.breakpoint" | default "sm" }}
|
|
{{ $links := false }}
|
|
{{ $pills := false }}
|
|
|
|
{{ if eq $basepath "/" }}
|
|
{{ $basepath = "" }}
|
|
{{ end }}
|
|
|
|
{{ with $page.Param "paige.menu.style" }}
|
|
{{ if eq . "links" }}
|
|
{{ $links = true }}
|
|
{{ else if eq . "pills" }}
|
|
{{ $pills = true }}
|
|
{{ else }}
|
|
{{ errorf "invalid menu style: %q" . }}
|
|
{{ end }}
|
|
{{ else }}
|
|
{{ $pills = true }}
|
|
{{ end }}
|
|
|
|
<nav class="justify-content-center my-3 navbar navbar-expand-{{ $breakpoint }}">
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#paige-menu-toggler" aria-controls="paige-menu-toggler" aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
<div class="collapse justify-content-center mt-3 mt-{{ $breakpoint }}-0 navbar-collapse" id="paige-menu-toggler">
|
|
<div class="align-items-center flex-column flex-{{ $breakpoint }}-row justify-content-center nav {{ if $pills }} nav-pills {{ end }}">
|
|
{{ range site.Menus.main }}
|
|
{{ $pagepath := strings.TrimPrefix $basepath $.RelPermalink }}
|
|
{{ $menupath := strings.TrimPrefix $basepath .URL }}
|
|
{{ $active := or (and (eq $menupath "/") (eq $pagepath "/")) (and (ne $menupath "/") (hasPrefix $pagepath $menupath)) }}
|
|
|
|
<a {{ if $active }} aria-current="page" {{ end }} class="{{ if $active }} active {{ if $links }} link-secondary {{ end }} {{ end }} nav-link" href="{{ .URL | safeURL }}">{{ .Name }}</a>
|
|
{{ end }}
|
|
</div>
|
|
</div>
|
|
</nav>
|