Number manual sidebar navigation
This commit is contained in:
parent
4ab47e5719
commit
aa6e5c51c1
|
|
@ -4,13 +4,14 @@ import '../style.css';
|
|||
|
||||
const { title = 'Decodal', active = '', playground = false } = Astro.props;
|
||||
|
||||
function renderNav(items) {
|
||||
function renderNav(items, prefix = []) {
|
||||
return `<ul class="nav-tree">${items
|
||||
.map((item) => {
|
||||
.map((item, index) => {
|
||||
const number = [...prefix, index + 1];
|
||||
const href = `/docs/${item.slug}/`;
|
||||
const activeClass = active === item.slug ? ' class="active"' : '';
|
||||
const children = item.children ? renderNav(item.children) : '';
|
||||
return `<li><a${activeClass} href="${href}">${item.title}</a>${children}</li>`;
|
||||
const children = item.children ? renderNav(item.children, number) : '';
|
||||
return `<li><a${activeClass} href="${href}"><span class="nav-number">${number.join('.')}.</span>${item.title}</a>${children}</li>`;
|
||||
})
|
||||
.join('')}</ul>`;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -80,18 +80,29 @@ a:hover {
|
|||
.nav-tree a {
|
||||
border-radius: 6px;
|
||||
color: #374151;
|
||||
display: block;
|
||||
display: flex;
|
||||
font-size: 14px;
|
||||
gap: 6px;
|
||||
line-height: 1.35;
|
||||
padding: 4px 8px;
|
||||
}
|
||||
|
||||
.nav-number {
|
||||
color: #94a3b8;
|
||||
flex: 0 0 auto;
|
||||
font-variant-numeric: tabular-nums;
|
||||
}
|
||||
|
||||
.nav-tree a.active {
|
||||
background: #dbeafe;
|
||||
color: #1d4ed8;
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
.nav-tree a.active .nav-number {
|
||||
color: #2563eb;
|
||||
}
|
||||
|
||||
main {
|
||||
min-width: 0;
|
||||
padding: 36px;
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user