picocss/scss/components/_nav.scss

142 lines
2.7 KiB
SCSS
Raw Normal View History

2019-11-27 15:31:49 +07:00
/**
* Nav
*/
2022-03-06 10:53:20 +07:00
// Reboot based on :
// - sanitize.css v13.0.0 | CC0 1.0 Universal | github.com/csstools/sanitize.css
// Prevent VoiceOver from ignoring list semantics in Safari (opinionated)
:where(nav li)::before {
float: left;
content: "\200B";
}
// Pico
//
2021-07-02 16:54:41 +07:00
// Horizontal Nav
2019-11-27 15:31:49 +07:00
nav,
nav ul {
display: flex;
}
nav {
justify-content: space-between;
ol,
2019-11-27 15:31:49 +07:00
ul {
align-items: center;
margin-bottom: 0;
padding: 0;
list-style: none;
&:first-of-type {
2022-02-27 14:41:34 +07:00
margin-left: calc(var(--nav-element-spacing-horizontal) * -1);
2019-11-27 15:31:49 +07:00
}
&:last-of-type {
2022-02-27 14:41:34 +07:00
margin-right: calc(var(--nav-element-spacing-horizontal) * -1);
2019-11-27 15:31:49 +07:00
}
}
li {
display: inline-block;
margin: 0;
2022-03-06 09:37:03 +07:00
padding: var(--nav-element-spacing-vertical)
var(--nav-element-spacing-horizontal);
2019-11-27 15:31:49 +07:00
2022-02-27 14:41:34 +07:00
// Minimal support for buttons and forms elements
> * {
--spacing: 0;
2019-11-27 15:31:49 +07:00
}
}
2022-03-06 13:40:49 +07:00
:where(a, [role="link"]) {
2022-02-27 14:41:34 +07:00
display: inline-block;
2022-03-06 09:37:03 +07:00
margin: calc(var(--nav-link-spacing-vertical) * -1)
calc(var(--nav-link-spacing-horizontal) * -1);
2022-02-27 14:41:34 +07:00
padding: var(--nav-link-spacing-vertical) var(--nav-link-spacing-horizontal);
2021-07-02 16:54:41 +07:00
border-radius: var(--border-radius);
text-decoration: none;
2022-03-06 13:40:49 +07:00
&:is([aria-current], :hover, :active, :focus) {
2021-07-02 16:54:41 +07:00
text-decoration: none;
}
2019-11-27 15:31:49 +07:00
}
2022-09-11 13:57:40 +07:00
// Breadcrumb
&[aria-label="breadcrumb"] {
align-items: center;
2022-09-13 02:16:29 +07:00
justify-content: start;
& ul li {
2022-09-13 02:16:29 +07:00
&:not(:first-child) {
margin-inline-start: var(--nav-link-spacing-horizontal);
}
&:not(:last-child) {
2022-09-13 02:16:29 +07:00
::after {
position: absolute;
width: calc(var(--nav-link-spacing-horizontal) * 2);
margin-inline-start: calc(var(--nav-link-spacing-horizontal) / 2);
content: "/";
2022-06-12 12:31:35 +02:00
color: var(--muted-color);
2022-09-13 02:16:29 +07:00
text-align: center;
}
}
}
2022-09-13 02:16:29 +07:00
& a[aria-current] {
background-color: transparent;
2022-06-12 12:31:35 +02:00
color: inherit;
2022-09-13 02:16:29 +07:00
text-decoration: none;
pointer-events: none;
}
}
// Minimal support for role="button"
[role="button"] {
margin-right: inherit;
margin-left: inherit;
padding: var(--nav-link-spacing-vertical) var(--nav-link-spacing-horizontal);
}
2019-11-27 15:31:49 +07:00
}
// Vertical Nav
aside {
nav,
ol,
2019-11-27 15:31:49 +07:00
ul,
li {
display: block;
}
li {
2022-03-06 09:37:03 +07:00
padding: calc(var(--nav-element-spacing-vertical) * 0.5)
var(--nav-element-spacing-horizontal);
2019-11-27 15:31:49 +07:00
a {
2022-02-27 14:41:34 +07:00
display: block;
}
2022-03-06 09:37:03 +07:00
2022-02-27 14:41:34 +07:00
// Minimal support for links as buttons
[role="button"] {
margin: inherit;
2019-11-27 15:31:49 +07:00
}
}
}
2022-09-13 02:16:29 +07:00
// Breadcrumb RTL
[dir="rtl"] {
nav {
&[aria-label="breadcrumb"] {
& ul li {
&:not(:last-child) {
::after {
content: "\\";
}
}
}
}
}
}