meface/docs/.vuepress/theme/components/SidebarLink.vue

98 lines
2.3 KiB
Vue
Raw Normal View History

2023-11-17 10:54:23 +08:00
<script>
import { isActive } from '@theme/helpers/utils'
export default {
functional: true,
props: ['item', 'sidebarDepth'],
render (h,
{
parent: {
$page,
$site,
$route,
$themeConfig,
$themeLocaleConfig
},
props: {
item,
sidebarDepth
}
}) {
// use custom active class matching logic
// due to edge case of paths ending with / + hash
const selfActive = isActive($route, item.path)
// for sidebar: auto pages, a hash link should be active if one of its child
// matches
const active = item.type === 'auto'
? selfActive || item.children.some(c => isActive($route, item.basePath + '#' + c.slug))
: selfActive
const link = renderLink(h, item.path, item.title || item.path, active)
return link
}
}
function renderLink (h, to, text, active) {
return h('router-link', {
props: {
to,
activeClass: '',
exactActiveClass: ''
},
class: {
active,
'sidebar-link': true
}
}, text)
}
// function renderChildren (h, children, path, route, maxDepth, depth = 1) {
// if (!children || depth > maxDepth) return null
// return h('ul', { class: 'sidebar-sub-headers' }, children.map(c => {
// const active = isActive(route, path + '#' + c.slug)
// return h('li', { class: 'sidebar-sub-header' }, [
// renderLink(h, path + '#' + c.slug, c.title, active),
// renderChildren(h, c.children, path, route, maxDepth, depth + 1)
// ])
// }))
// }
</script>
<style lang="stylus">
.sidebar .sidebar-sub-headers
padding-left 1.5rem
font-size 0.95em
.sidebar-sub-headers a.sidebar-link
margin 0 1rem 0 0.6rem
a.sidebar-link
font-size 1em
font-weight 400
display block!important
color var(--text-color)
padding 0.35rem 1rem 0.35rem 2.25rem
line-height 1.7
background var(--background-color)
// margin 0 0 0 1.5rem
box-sizing: border-box
&:hover
color $accentColor
&.active
font-weight 600
color $accentColor
background var(--default-color-8)
border-right 3px solid $accentColor
.sidebar-group &
// padding-left 2rem
.sidebar-sub-headers &
padding-top 0.25rem
padding-bottom 0.25rem
border-left none
&.active
font-weight 500
background transparent
color $accentColor
</style>