picocss/scss/components/_dropdown.scss

209 lines
5 KiB
SCSS
Raw Normal View History

2022-10-22 13:11:51 +07:00
@use "../settings" as *;
2022-10-22 11:44:10 +07:00
/**
* Dropdown ([role="list"])
*/
2022-03-06 09:37:03 +07:00
// Menu
details[role="list"],
li[role="list"] {
position: relative;
2022-03-06 13:28:27 +07:00
}
2022-03-06 13:28:27 +07:00
details[role="list"] summary + ul,
li[role="list"] > ul {
display: flex;
z-index: 99;
position: absolute;
top: auto;
right: 0;
left: 0;
flex-direction: column;
margin: 0;
padding: 0;
2022-10-22 13:11:51 +07:00
border: var(#{$}border-width) solid var(#{$}dropdown-border-color);
border-radius: var(#{$}border-radius);
2022-03-06 13:28:27 +07:00
border-top-right-radius: 0;
border-top-left-radius: 0;
2022-10-22 13:11:51 +07:00
background-color: var(#{$}dropdown-background-color);
box-shadow: var(#{$}card-box-shadow);
color: var(#{$}dropdown-color);
2022-03-06 13:28:27 +07:00
white-space: nowrap;
li {
width: 100%;
margin-bottom: 0;
2022-10-22 13:11:51 +07:00
padding: calc(var(#{$}form-element-spacing-vertical) * 0.5)
var(#{$}form-element-spacing-horizontal);
2022-03-06 13:28:27 +07:00
list-style: none;
2022-03-06 13:28:27 +07:00
&:first-of-type {
2022-10-22 13:11:51 +07:00
margin-top: calc(var(#{$}form-element-spacing-vertical) * 0.5);
2022-03-06 13:28:27 +07:00
}
2022-03-06 13:28:27 +07:00
&:last-of-type {
2022-10-22 13:11:51 +07:00
margin-bottom: calc(var(#{$}form-element-spacing-vertical) * 0.5);
2022-03-06 13:28:27 +07:00
}
2022-03-06 13:28:27 +07:00
a {
display: block;
2022-10-22 13:11:51 +07:00
margin: calc(var(#{$}form-element-spacing-vertical) * -0.5)
calc(var(#{$}form-element-spacing-horizontal) * -1);
padding: calc(var(#{$}form-element-spacing-vertical) * 0.5)
var(#{$}form-element-spacing-horizontal);
2022-03-06 13:28:27 +07:00
overflow: hidden;
2022-10-22 13:11:51 +07:00
color: var(#{$}dropdown-color);
2022-03-06 13:28:27 +07:00
text-decoration: none;
text-overflow: ellipsis;
&:hover {
2022-10-22 13:11:51 +07:00
background-color: var(#{$}dropdown-hover-background-color);
}
2022-01-23 17:03:03 +07:00
}
}
}
2022-01-23 17:03:03 +07:00
// Marker
details[role="list"] summary,
li[role="list"] > a {
&::after {
display: block;
2022-03-06 16:24:19 +07:00
width: 1rem;
2022-10-22 13:11:51 +07:00
height: calc(1rem * var(#{$}line-height, 1.5));
2022-03-06 16:24:19 +07:00
margin-inline-start: 0.5rem;
float: right;
transform: rotate(0deg);
2022-03-06 16:24:19 +07:00
background-position: right center;
background-size: 1rem auto;
background-repeat: no-repeat;
content: "";
}
}
// Global dropdown only
details[role="list"] {
padding: 0;
border-bottom: none;
// Style <summary> as <select>
summary {
margin-bottom: 0;
2022-03-06 09:37:03 +07:00
&:not([role]) {
height: calc(
2022-10-22 13:11:51 +07:00
1rem * var(#{$}line-height) + var(#{$}form-element-spacing-vertical) * 2 +
var(#{$}border-width) * 2
);
2022-10-22 13:11:51 +07:00
padding: var(#{$}form-element-spacing-vertical) var(#{$}form-element-spacing-horizontal);
border: var(#{$}border-width) solid var(#{$}form-element-border-color);
border-radius: var(#{$}border-radius);
background-color: var(#{$}form-element-background-color);
color: var(#{$}form-element-placeholder-color);
line-height: inherit;
cursor: pointer;
2022-10-22 13:11:51 +07:00
@if $enable-transitions {
transition: background-color var(#{$}transition), border-color var(#{$}transition),
color var(#{$}transition), box-shadow var(#{$}transition);
}
&:active,
&:focus {
2022-10-22 13:11:51 +07:00
border-color: var(#{$}form-element-active-border-color);
background-color: var(#{$}form-element-active-background-color);
}
&:focus {
2022-10-22 13:11:51 +07:00
box-shadow: 0 0 0 var(#{$}outline-width) var(#{$}form-element-focus-color);
}
}
}
// Close for details[role="list"]
&[open] summary {
border-bottom-right-radius: 0;
border-bottom-left-radius: 0;
2022-03-06 09:37:03 +07:00
&::before {
display: block;
2022-01-23 17:03:03 +07:00
z-index: 1;
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
2022-03-06 10:53:20 +07:00
background: none;
2022-02-27 22:43:15 +07:00
content: "";
cursor: default;
}
}
2022-02-27 22:43:15 +07:00
}
// All Dropdowns inside <nav>
2022-03-06 13:28:27 +07:00
nav details[role="list"] summary,
nav li[role="list"] a {
display: flex;
direction: ltr;
}
2022-03-06 09:37:03 +07:00
2022-03-06 13:28:27 +07:00
nav details[role="list"] summary + ul,
nav li[role="list"] > ul {
min-width: fit-content;
2022-10-22 13:11:51 +07:00
border-radius: var(#{$}border-radius);
2022-02-27 22:43:15 +07:00
2022-03-06 13:28:27 +07:00
li a {
border-radius: 0;
2022-02-27 22:43:15 +07:00
}
}
// Dropdowns inside <nav> as nested <details>
2022-03-06 13:28:27 +07:00
nav details[role="list"] {
2022-03-06 09:37:03 +07:00
summary,
summary:not([role]) {
height: auto;
2022-10-22 13:11:51 +07:00
padding: var(#{$}nav-link-spacing-vertical) var(#{$}nav-link-spacing-horizontal);
2022-03-06 09:37:03 +07:00
}
&[open] summary {
2022-10-22 13:11:51 +07:00
border-radius: var(#{$}border-radius);
}
2022-03-06 13:28:27 +07:00
summary + ul {
2022-10-22 13:11:51 +07:00
margin-top: var(#{$}outline-width);
2022-03-06 13:28:27 +07:00
margin-inline-start: 0;
2022-03-06 09:37:03 +07:00
}
2022-03-06 13:28:27 +07:00
2022-03-06 09:37:03 +07:00
summary[role="link"] {
2022-10-22 13:11:51 +07:00
margin-bottom: calc(var(#{$}nav-link-spacing-vertical) * -1);
line-height: var(#{$}line-height);
2022-03-06 09:37:03 +07:00
+ ul {
2022-10-22 13:11:51 +07:00
margin-top: calc(var(#{$}nav-link-spacing-vertical) + var(#{$}outline-width));
margin-inline-start: calc(var(#{$}nav-link-spacing-horizontal) * -1);
2022-03-06 09:37:03 +07:00
}
}
}
2022-02-27 22:43:15 +07:00
// Dropdowns inside a <nav> without using <details>
li[role="list"] {
2022-03-06 09:37:03 +07:00
// Open on hover (for mobile)
// or on active/focus (for keyboard navigation)
&:hover > ul,
a:active ~ ul,
a:focus ~ ul {
display: flex;
}
2022-02-27 22:43:15 +07:00
> ul {
display: none;
2022-10-22 13:11:51 +07:00
margin-top: calc(var(#{$}nav-link-spacing-vertical) + var(#{$}outline-width));
2022-03-06 09:37:03 +07:00
margin-inline-start: calc(
2022-10-22 13:11:51 +07:00
var(#{$}nav-element-spacing-horizontal) - var(#{$}nav-link-spacing-horizontal)
2022-03-06 09:37:03 +07:00
);
}
2022-02-27 22:43:15 +07:00
> a::after {
2022-10-22 13:11:51 +07:00
background-image: var(#{$}icon-chevron);
2022-02-27 22:43:15 +07:00
}
2022-10-15 23:22:12 +07:00
}