Simplify sidebar styles

This commit is contained in:
Martijn Cuppens 2020-03-13 19:01:33 +01:00 committed by XhmikosR
parent 9efaeba35e
commit 4448856038
3 changed files with 55 additions and 65 deletions

View File

@ -1,72 +1,63 @@
// stylelint-disable declaration-no-important
.bd-links { .bd-links {
font-weight: 600;
@include media-breakpoint-up(md) { @include media-breakpoint-up(md) {
@supports (position: sticky) {
position: sticky; position: sticky;
top: 5rem; top: 5rem;
// Override collapse behaviors
// stylelint-disable-next-line declaration-no-important
display: block !important;
height: subtract(100vh, 7rem); height: subtract(100vh, 7rem);
// Prevent focus styles to be cut off:
padding-left: .25rem;
margin-left: -.25rem;
overflow-y: auto; overflow-y: auto;
} }
}
// Override collapse behaviors a {
@include media-breakpoint-up(md) { display: inline-flex;
display: block !important; align-items: center;
} padding: .1875rem .5rem;
} margin-top: .125rem;
.bd-sidenav-group-link {
padding: .25rem .625rem .25rem .5rem;
font-weight: 600;
color: rgba($black, .65); color: rgba($black, .65);
text-decoration: none; text-decoration: if($link-decoration == none, null, none);
@include border-radius(.25rem); @include border-radius(.25rem);
> * { pointer-events: none; }
&:hover, &:hover,
&:focus { &:focus {
color: rgba($black, .85); color: rgba($black, .85);
text-decoration: if($link-hover-decoration == underline, none, null);
background-color: rgba($bd-purple-bright, .1); background-color: rgba($bd-purple-bright, .1);
} }
}
.bd-sidenav-group { // Indent if there's no submenu
&.has-children .bd-sidenav-group-link::before { &:only-child {
display: inline-block; margin-left: 1.25rem;
margin-right: .25rem; }
// Add chevron if there's a submenu
&:not(:only-child) {
&::before {
width: 1.25em;
line-height: 0; // Align in the middle line-height: 0; // Align in the middle
content: escape-svg($sidebar-collapse-icon); content: escape-svg($sidebar-collapse-icon);
@include transition(transform .35s ease); @include transition(transform .35s ease);
transform-origin: .5em 50%;
} }
[aria-expanded="true"] { &:not(.collapsed) {
color: rgba($black, .85); color: rgba($black, .85);
&::before { &::before {
transform: rotate(90deg); transform: rotate(90deg);
} }
} }
} }
// All levels of nav // Adjust font size and font weights in submenu
.bd-sidebar .nav { + ul {
flex-flow: column nowrap;
padding-left: 1.25rem;
a {
display: inline-block;
padding: .25rem .5rem;
@include font-size(.875rem); @include font-size(.875rem);
color: rgba($black, .65); font-weight: 400;
text-decoration: none;
@include border-radius(.25rem);
&:hover,
&:focus {
color: rgba($black, .85);
background-color: rgba($bd-purple-bright, .1);
} }
} }

View File

@ -11,7 +11,7 @@
<div class="container-xl my-4"> <div class="container-xl my-4">
<div class="row flex-xl-nowrap"> <div class="row flex-xl-nowrap">
<div class="col-md-3 bd-sidebar"> <div class="col-md-3">
{{ partial "docs-sidebar" . }} {{ partial "docs-sidebar" . }}
</div> </div>

View File

@ -2,7 +2,7 @@
{{- $url := split .Permalink "/" -}} {{- $url := split .Permalink "/" -}}
{{- $page_slug := index $url (sub (len $url) 2) -}} {{- $page_slug := index $url (sub (len $url) 2) -}}
<ul class="list-unstyled"> <ul class="list-unstyled mb-0">
{{- range $group := .Site.Data.sidebar -}} {{- range $group := .Site.Data.sidebar -}}
{{- $link := $group.title -}} {{- $link := $group.title -}}
{{- $link_slug := $link | urlize -}} {{- $link_slug := $link | urlize -}}
@ -15,17 +15,16 @@
{{- $group_slug := $group.title | urlize -}} {{- $group_slug := $group.title | urlize -}}
{{- $active_group := eq $.Page.Params.group $group_slug }} {{- $active_group := eq $.Page.Params.group $group_slug }}
<li class="bd-sidenav-group my-1{{ if $active_group }} active{{ end }}{{ if $group.pages }} has-children{{ end }}"> <li class="my-1{{ if $active_group }} active{{ end }}">
<a class="d-inline-flex align-items-center bd-sidenav-group-link" data-toggle="collapse" href="#{{ $group_slug }}-collapse" <a class="{{ if not $active_group }} collapsed{{ end }}" data-toggle="collapse" href="#{{ $group_slug }}-collapse" role="button" aria-expanded="{{ $active_group }}"{{ if $active_group }} aria-current="true"{{ end }}>
role="button" aria-expanded="{{ $active_group }}"{{ if $active_group }} aria-current="true"{{ end }}>
{{ $group.title }} {{ $group.title }}
</a> </a>
{{- if $group.pages }} {{- if $group.pages }}
<ul class="nav bd-sidenav mb-2 collapse{{ if $active_group }} show{{ end }}" id="{{ $group_slug }}-collapse"> <ul class="list-unstyled mb-2 collapse{{ if $active_group }} show{{ end }}" id="{{ $group_slug }}-collapse">
{{- range $doc := $group.pages -}} {{- range $doc := $group.pages -}}
{{- $doc_slug := $doc.title | urlize }} {{- $doc_slug := $doc.title | urlize }}
<li{{ if and $active_group (eq $page_slug $doc_slug) }} class="bd-sidenav-active"{{ end }}> <li>
<a href="/docs/{{ $.Site.Params.docs_version }}/{{ $group_slug }}/{{ $doc_slug }}/"{{ if and $active_group (eq $page_slug $doc_slug) }} class="active" aria-current="page"{{ end }}> <a href="/docs/{{ $.Site.Params.docs_version }}/{{ $group_slug }}/{{ $doc_slug }}/"{{ if and $active_group (eq $page_slug $doc_slug) }} class="active" aria-current="page"{{ end }}>
{{- $doc.title -}} {{- $doc.title -}}
</a> </a>
@ -37,8 +36,8 @@
{{- end }} {{- end }}
<li class="my-3 mx-4 border-top"></li> <li class="my-3 mx-4 border-top"></li>
<li class="bd-sidenav-group pl-3"> <li{{ if eq $page_slug "migration" }} class="active"{{ end }}>
<a class="d-inline-flex align-items-center bd-sidenav-group-link" href="/docs/{{ $.Site.Params.docs_version }}/migration/"> <a href="/docs/{{ $.Site.Params.docs_version }}/migration/">
Migration Migration
</a> </a>
</li> </li>