📘 DOC: improve a11y (#806)

* Add `tabindex="0"` to `<pre>` so that they are navigable by keyboard users if they overflow.

* Landmark elements should have unique names https://dequeuniversity.com/rules/axe/4.3/landmark-unique

* Page must have one main landmark https://dequeuniversity.com/rules/axe/4.3/landmark-one-main

- Main landmark must not be contained by another landmark https://dequeuniversity.com/rules/axe/4.3/landmark-main-is-top-level

* Heading level cannot increase by more than one

* Ensure that links with the same accessible name serve a similar purpose

https://dequeuniversity.com/rules/axe/4.3/identical-links-same-purpose

* Just update the accessible name and require context for the visible link name

* Fix CSS from the removal of the second <main>

* Revert heading level change
This commit is contained in:
Caleb Jasik 2021-07-22 19:12:37 -05:00 committed by GitHub
parent 7b600d597b
commit 4fd6cfe668
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 27 additions and 25 deletions

View file

@ -35,11 +35,11 @@ nav ul {
padding: 0; padding: 0;
} }
.content main > * + * { .content > section > * + * {
margin-top: 1rem; margin-top: 1rem;
} }
.content main > :first-child { .content > section > :first-child {
margin-top: 0; margin-top: 0;
} }
@ -110,24 +110,24 @@ a {
gap: 0.5rem; gap: 0.5rem;
} }
article main :is(ul, ol) > * + * { article > section :is(ul, ol) > * + * {
margin-top: 0.75rem; margin-top: 0.75rem;
} }
article main li > :is(p, pre, blockquote):not(:first-child) { article > section li > :is(p, pre, blockquote):not(:first-child) {
margin-top: 1rem; margin-top: 1rem;
} }
article main :is(ul, ol) { article > section :is(ul, ol) {
padding-left: 1em; padding-left: 1em;
} }
article main ::marker { article > section ::marker {
font-weight: bold; font-weight: bold;
color: var(--theme-text-light); color: var(--theme-text-light);
} }
article main iframe { article > section iframe {
width: 100%; width: 100%;
height: auto; height: auto;
aspect-ratio: 16 / 9; aspect-ratio: 16 / 9;

View file

@ -0,0 +1,3 @@
Array.from(document.getElementsByTagName("pre")).forEach((element) => {
element.setAttribute("tabindex", "0");
});

View file

@ -28,7 +28,7 @@ const DocSidebar: FunctionalComponent<{ headers: any[]; editHref: string }> = ({
}, []); }, []);
return ( return (
<nav class="sidebar-nav"> <nav class="sidebar-nav" aria-labelledby="sidebar-content">
<div class="sidebar-nav-inner"> <div class="sidebar-nav-inner">
<h2 class="heading">On this page</h2> <h2 class="heading">On this page</h2>
<ul> <ul>

View file

@ -3,7 +3,7 @@ import { sidebar } from '../config.ts';
const {currentPage} = Astro.props; const {currentPage} = Astro.props;
--- ---
<nav> <nav aria-labelledby="sidebar-site">
<ul class="nav-groups"> <ul class="nav-groups">
{sidebar.map(category => ( {sidebar.map(category => (
<li> <li>

View file

@ -132,7 +132,7 @@ if (currentPage) {
height: 100%; height: 100%;
} }
.layout.centered #article main { .layout.centered #article > article > section {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
margin: auto; margin: auto;
@ -143,11 +143,11 @@ if (currentPage) {
text-align: center; text-align: center;
} }
.layout.centered #article main :global(> *) { .layout.centered #article > article > section :global(> *) {
margin: 0; margin: 0;
} }
.layout.centered #article main h1 { .layout.centered #article > article > section h1 {
font-size: 5rem; font-size: 5rem;
} }
@ -160,7 +160,7 @@ if (currentPage) {
flex-direction: column; flex-direction: column;
} }
.content > main { .content > section {
margin-bottom: 4rem; margin-bottom: 4rem;
} }
@ -256,7 +256,7 @@ if (currentPage) {
<body> <body>
<header> <header>
<nav class="nav-wrapper"> <nav class="nav-wrapper" title="Top Navigation">
<div class="menu-toggle"> <div class="menu-toggle">
<MenuToggle client:idle/> <MenuToggle client:idle/>
</div> </div>
@ -291,24 +291,25 @@ if (currentPage) {
</header> </header>
<main class={centered ? "layout centered" : "layout"}> <main class={centered ? "layout centered" : "layout"}>
<aside class="sidebar" id="sidebar-site"> <aside class="sidebar" id="sidebar-site" title="Documentation Sections">
<SiteSidebar currentPage={currentPage?.slice(1) ?? ''} /> <SiteSidebar currentPage={currentPage?.slice(1) ?? ''} />
</aside> </aside>
<div id="article"> <div id="article">
<article class="content"> <article class="content">
<main> <section>
<h1 class="content-title" id="overview">{content?.title}</h1> <h1 class="content-title" id="overview">{content?.title}</h1>
<slot /> <slot />
</main> </section>
{currentPage && <ArticleFooter path={currentFile} />} {currentPage && <ArticleFooter path={currentFile} />}
</article> </article>
</div> </div>
<aside class="sidebar" id="sidebar-content"> <aside class="sidebar" id="sidebar-content" title="Table of Contents">
{currentPage && <DocSidebar client:idle headers={headers} editHref={githubEditUrl} />} {currentPage && <DocSidebar client:idle headers={headers} editHref={githubEditUrl} />}
</aside> </aside>
</main> </main>
<script type="module" src="/nav.js" /> <script type="module" src="/nav.js" />
<script type="module" src="/make-scrollable-code-focusable.js" />
<!-- Global site tag (gtag.js) - Google Analytics --> <!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-TEL60V1WM9"></script> <script async src="https://www.googletagmanager.com/gtag/js?id=G-TEL60V1WM9"></script>

View file

@ -23,7 +23,7 @@ src/pages/posts/1.md -> mysite.com/posts/1
## Page Templating ## Page Templating
All Astro components are responsible for returning HTML. Astro Pages return HTML as well, but have the unique responsibility of returning a full `<html>...</html>` page response, including `<head>` ([MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/head)) and `<body>` ([MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/body)). All Astro components are responsible for returning HTML. Astro Pages return HTML as well, but have the unique responsibility of returning a full `<html>...</html>` page response, including `<head>` ([MDN<span class="sr-only">- head</span>](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/head)) and `<body>` ([MDN<span class="sr-only">- body</span>](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/body)).
`<!doctype html>` is optional, and will be added automatically. `<!doctype html>` is optional, and will be added automatically.

View file

@ -7,7 +7,7 @@ Astro components and pages can fetch remote data to help generate your pages. As
## `fetch()` ## `fetch()`
Astro pages have access to the global `fetch()` function in their setup script. `fetch()` is a native JavaScript API ([MDN](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch)) that lets you make HTTP requests for things like APIs and resources. Astro pages have access to the global `fetch()` function in their setup script. `fetch()` is a native JavaScript API ([MDN<span class="sr-only">- fetch</span>](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch)) that lets you make HTTP requests for things like APIs and resources.
Even though Astro component scripts run inside of Node.js (and not in the browser) Astro provides this native API so that you can fetch data at page build time. Even though Astro component scripts run inside of Node.js (and not in the browser) Astro provides this native API so that you can fetch data at page build time.
@ -25,7 +25,7 @@ console.log(data);
## Top-level await ## Top-level await
`await` is another native JavaScript feature that lets you await the response of some asynchronous promise ([MDN](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/await)). Astro supports `await` in the top-level of your component script. `await` is another native JavaScript feature that lets you await the response of some asynchronous promise ([MDN<span class="sr-only">- await</span>](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/await)). Astro supports `await` in the top-level of your component script.
**Important:** These are not yet available inside of non-page Astro components. Instead, do all of your data loading inside of your pages, and then pass them to your components as props. **Important:** These are not yet available inside of non-page Astro components. Instead, do all of your data loading inside of your pages, and then pass them to your components as props.

View file

@ -70,8 +70,8 @@ import Styles from './styles.module.css'; // Use CSS Modules (must end in `.modu
Vue in Astro supports the same methods as `vue-loader` does: Vue in Astro supports the same methods as `vue-loader` does:
- [Scoped CSS][vue-scoped] - [vue-loader - Scoped CSS][vue-scoped]
- [CSS Modules][vue-css-modules] - [vue-loader - CSS Modules][vue-css-modules]
### 📕 Svelte ### 📕 Svelte

View file

@ -110,8 +110,6 @@ export interface JSXTransformOptions {
} }
``` ```
####
### Server Entrypoint (`server.js`) ### Server Entrypoint (`server.js`)
The server entrypoint of a renderer is responsible for checking if a component should use this renderer, and if so, how that component should be rendered to a string of static HTML. The server entrypoint of a renderer is responsible for checking if a component should use this renderer, and if so, how that component should be rendered to a string of static HTML.