Menu Component
A CSS implementation of the Sprout menu component.
Example
html
<div class="demo-wrapper">
<!-- Medium variant with combination of anchor/button/custom items -->
<div class="spr-menu-md">
<button class="spr-menu-item" tabindex="0">Some Button Item</button>
<button class="spr-menu-item" tabindex="0">Another Button Item</button>
<a class="spr-menu-item" tabindex="0">Also Anchor</a>
<a class="spr-menu-item active" tabindex="0">And More Anchor</a>
<div class="spr-menu-item" role="button" tabindex="0">
<div style="display: flex; justify-content: space-between">
<span>Even Custom</span>
<div class="custom-item">
π
</div>
</div>
</div>
</div>
<!-- Small variant with combination of anchor/button/custom items -->
<div class="spr-menu-sm">
<button class="spr-menu-item" tabindex="0">Some Button Item</button>
<button class="spr-menu-item" tabindex="0">Another Button Item</button>
<a class="spr-menu-item" tabindex="0">Also Anchor</a>
<a class="spr-menu-item active" tabindex="0">And More Anchor</a>
<div class="spr-menu-item" role="button" tabindex="0">
<div style="display: flex; justify-content: space-between">
<span>Even Custom</span>
<div class="custom-item">
π
</div>
</div>
</div>
</div>
</div>
<style>
.custom-item { width: 30px; border-radius: 10px; background-color: indianred; color: white; text-align: center }
.demo-wrapper { display: flex; justify-content: space-around; align-items: flex-start }
</style>
Compiled CSS
Example
scss
@import 'components/menu';
css
compiled
@keyframes openPopover {
from {
transform: scale(0.9);
}
to {
transform: scale(1);
}
}
.spr-icon-rotate-90 {
transform: rotate(90deg);
}
.spr-icon-rotate-180 {
transform: rotate(180deg);
}
.spr-icon-rotate-270 {
transform: rotate(270deg);
}
.spr-menu-md,
.spr-menu-sm {
padding: 0.5rem 0rem;
box-shadow: 0 4px 8px 0 rgba(24, 25, 27, 0.15);
min-width: 224px;
background-color: #fff;
animation: openPopover 0.15s;
}
.spr-menu-md:focus:not(:focus-visible),
.spr-menu-sm:focus:not(:focus-visible) {
outline: none;
}
.spr-menu-md:focus-visible,
.spr-menu-sm:focus-visible {
outline: 5px auto Highlight;
outline: 5px auto -webkit-focus-ring-color;
}
.spr-menu-content {
display: flex;
flex-direction: column;
}
.spr-menu-content > :not(:last-child) {
margin-bottom: 0rem;
}
button.spr-menu-item {
border: none;
background: none;
box-shadow: none;
padding: 0;
cursor: pointer;
font: inherit;
color: inherit;
}
a.spr-menu-item, a.spr-menu-item:visited, a.spr-menu-item:active, a.spr-menu-item:link {
font: inherit;
color: inherit;
text-decoration: none;
}
a.spr-menu-item,
button.spr-menu-item,
.spr-menu-item {
color: #18191b;
display: block;
cursor: pointer;
box-sizing: border-box;
text-align: left;
border-left: 4px solid transparent;
width: 100%;
}
a.spr-menu-item:focus:not(:focus-visible),
button.spr-menu-item:focus:not(:focus-visible),
.spr-menu-item:focus:not(:focus-visible) {
outline: none;
}
a.spr-menu-item:focus-visible,
button.spr-menu-item:focus-visible,
.spr-menu-item:focus-visible {
outline: 5px auto Highlight;
outline: 5px auto -webkit-focus-ring-color;
}
a.spr-menu-item:hover:not([disabled]),
button.spr-menu-item:hover:not([disabled]),
.spr-menu-item:hover:not([disabled]) {
transition-property: background-color;
transition-duration: 0.11s;
transition-timing-function: ease-in-out;
background-color: rgba(24, 25, 27, 0.08);
}
a.spr-menu-item:active, a.spr-menu-item:hover:active:not([disabled]),
button.spr-menu-item:active,
button.spr-menu-item:hover:active:not([disabled]),
.spr-menu-item:active,
.spr-menu-item:hover:active:not([disabled]) {
transition-property: background-color;
transition-duration: 0.11s;
transition-timing-function: ease-in-out;
background-color: rgba(24, 25, 27, 0.18);
}
a.spr-menu-item[disabled],
button.spr-menu-item[disabled],
.spr-menu-item[disabled] {
cursor: default;
color: rgba(24, 25, 27, 0.5);
}
a.spr-menu-item.active,
button.spr-menu-item.active,
.spr-menu-item.active {
border-left: 0.25rem solid #20883a;
}
.spr-menu-md a.spr-menu-item, .spr-menu-md
button.spr-menu-item, .spr-menu-md
.spr-menu-item {
padding: 0.75rem 1rem 0.75rem 0.75rem;
font-family: "AvenirNext", "Helvetica Neue", Arial, sans-serif;
font-size: 1rem;
line-height: 1.5rem;
letter-spacing: 0;
font-weight: 400;
font-weight: bold;
}
.spr-menu-sm a.spr-menu-item, .spr-menu-sm
button.spr-menu-item, .spr-menu-sm
.spr-menu-item {
padding: 0.5rem 1rem 0.5rem 0.75rem;
font-family: "AvenirNext", "Helvetica Neue", Arial, sans-serif;
font-size: 0.875rem;
line-height: 1.5rem;
letter-spacing: 0;
font-weight: 400;
font-weight: bold;
}
@keyframes openMenu {
from {
transform: scale(0.9);
}
to {
transform: scale(1);
}
}