Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions .Jules/palette.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,3 +29,7 @@
## 2026-06-12 - Robust Skip-to-Content Links
**Learning:** Adding a "Skip to main content" link is a critical accessibility requirement for keyboard users. To make it robust, it needs to be hidden visually but appear when focused using `transform: translateY(-100%)` instead of magic pixel numbers, and the target container (e.g., `<main>`) must have a matching `id` and `tabindex="-1"` so it can programmatically receive focus across all browsers.
**Action:** Always include a visually hidden 'Skip to main content' link immediately after the opening `<body>` tag. Set the main content container with an `id` and explicitly `tabindex="-1"`.

## 2026-06-21 - Accessible Anchor Buttons
**Learning:** When using `<a>` tags with `href="#"` as buttons, native behavior causes them to respond to `Enter` but not `Spacebar`, which is expected of elements functioning as buttons. Additionally, the spacebar defaults to page scrolling.
**Action:** Always include `role="button"` on `<a>` tags used as buttons. Bind a `keydown` event listener to handle the `Spacebar` key specifically, calling `e.preventDefault()` to stop the default scrolling behavior, ensuring full keyboard accessibility parity.
2 changes: 1 addition & 1 deletion concepts.html
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ <h1>CHARLES WILLIAMS</h1>
<a href="products.html">Products</a>
<a href="concepts.html" class="active" aria-current="page">Concepts</a>
<a href="contact.html">Contact</a>
<a href="#" id="sitrep-btn">OSINT</a>
<a href="#" id="sitrep-btn" role="button" aria-haspopup="dialog">OSINT</a>
</nav>
<div id="local-info" class="local-info-widget"></div>
</div>
Expand Down
2 changes: 1 addition & 1 deletion contact.html
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ <h2>Get in Touch</h2>
</a>


<a href="#" id="sitrep-btn" class="button">
<a href="#" id="sitrep-btn" class="button" role="button" aria-haspopup="dialog">
<svg aria-hidden="true" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-activity"><polyline points="22 12 18 12 15 21 9 3 6 12 2 12"></polyline></svg>
OSINT
</a>
Expand Down
6 changes: 6 additions & 0 deletions modal.js
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,12 @@ const openModal = (e) => {
const btns = document.querySelectorAll('#sitrep-btn');
btns.forEach(btn => {
btn.addEventListener('click', openModal);
btn.addEventListener('keydown', (e) => {
if (e.key === ' ' || e.code === 'Space') {
e.preventDefault();
openModal(e);
}
});
});

// Close modal via button
Expand Down
2 changes: 1 addition & 1 deletion products.html
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ <h1>CHARLES WILLIAMS</h1>
<a href="products.html" class="active" aria-current="page">Products</a>
<a href="concepts.html">Concepts</a>
<a href="contact.html">Contact</a>
<a href="#" id="sitrep-btn">OSINT</a>
<a href="#" id="sitrep-btn" role="button" aria-haspopup="dialog">OSINT</a>
</nav>
<div id="local-info" class="local-info-widget"></div>
</div>
Expand Down