Skip to content

Commit

Permalink
feat(theme): use inert to avoid traverse menus and content with keybo…
Browse files Browse the repository at this point in the history
…ard (#2932)
  • Loading branch information
userquin authored Sep 10, 2023
1 parent c0ce7f7 commit 070fc0a
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 17 deletions.
17 changes: 10 additions & 7 deletions src/client/theme-default/Layout.vue
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,16 @@ import VPNav from './components/VPNav.vue'
import VPSidebar from './components/VPSidebar.vue'
import VPSkipLink from './components/VPSkipLink.vue'
import { useData } from './composables/data'
import { useNav } from './composables/nav'
import { useCloseSidebarOnEscape, useSidebar } from './composables/sidebar'
const {
isOpen: isSidebarOpen,
open: openSidebar,
close: closeSidebar
close: closeSidebar,
isSidebarEnabled,
} = useSidebar()
const { isScreenOpen } = useNav()
const route = useRoute()
watch(() => route.path, closeSidebar)
Expand All @@ -33,24 +36,24 @@ provide('hero-image-slot-exists', heroImageSlotExists)
<template>
<div v-if="frontmatter.layout !== false" class="Layout" :class="frontmatter.pageClass" >
<slot name="layout-top" />
<VPSkipLink />
<VPSkipLink :inert="isSidebarOpen || isScreenOpen" />
<VPBackdrop class="backdrop" :show="isSidebarOpen" @click="closeSidebar" />
<VPNav v-if="frontmatter.navbar !== false">
<VPNav v-if="frontmatter.navbar !== false" :inert="isSidebarOpen">
<template #nav-bar-title-before><slot name="nav-bar-title-before" /></template>
<template #nav-bar-title-after><slot name="nav-bar-title-after" /></template>
<template #nav-bar-content-before><slot name="nav-bar-content-before" /></template>
<template #nav-bar-content-after><slot name="nav-bar-content-after" /></template>
<template #nav-screen-content-before><slot name="nav-screen-content-before" /></template>
<template #nav-screen-content-after><slot name="nav-screen-content-after" /></template>
</VPNav>
<VPLocalNav :open="isSidebarOpen" @open-menu="openSidebar" />
<VPLocalNav :inert="isSidebarOpen || isScreenOpen" :open="isSidebarOpen" @open-menu="openSidebar" />

<VPSidebar :open="isSidebarOpen">
<VPSidebar :inert="!isSidebarEnabled && (!isSidebarOpen || isScreenOpen)" :open="isSidebarOpen">
<template #sidebar-nav-before><slot name="sidebar-nav-before" /></template>
<template #sidebar-nav-after><slot name="sidebar-nav-after" /></template>
</VPSidebar>

<VPContent>
<VPContent :inert="isSidebarOpen || isScreenOpen">
<template #page-top><slot name="page-top" /></template>
<template #page-bottom><slot name="page-bottom" /></template>

Expand All @@ -76,7 +79,7 @@ provide('hero-image-slot-exists', heroImageSlotExists)
<template #aside-ads-after><slot name="aside-ads-after" /></template>
</VPContent>

<VPFooter />
<VPFooter :inert="isSidebarOpen || isScreenOpen" />
<slot name="layout-bottom" />
</div>
<Content v-else />
Expand Down
18 changes: 10 additions & 8 deletions src/client/theme-default/components/VPSkipLink.vue
Original file line number Diff line number Diff line change
Expand Up @@ -27,14 +27,16 @@ function focusOnTargetAnchor({ target }: Event) {
</script>

<template>
<span ref="backToTop" tabindex="-1" />
<a
href="#VPContent"
class="VPSkipLink visually-hidden"
@click="focusOnTargetAnchor"
>
Skip to content
</a>
<div>
<span ref="backToTop" tabindex="-1" />
<a
href="#VPContent"
class="VPSkipLink visually-hidden"
@click="focusOnTargetAnchor"
>
Skip to content
</a>
</div>
</template>

<style scoped>
Expand Down
4 changes: 2 additions & 2 deletions src/client/theme-default/composables/nav.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import { ref, watch } from 'vue'
import { useRoute } from 'vitepress'

export function useNav() {
const isScreenOpen = ref(false)
const isScreenOpen = ref(false)

export function useNav() {
function openScreen() {
isScreenOpen.value = true
window.addEventListener('resize', closeScreenOnTabletWindow)
Expand Down

0 comments on commit 070fc0a

Please sign in to comment.