npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@wmcadigital/ui-accordion

v0.1.0-alpha.2

Published

Allows users to reveal or hide related content on a page

Downloads

9

Readme

Accordion

Accessible, lightweight accordion behaviour used across the design system. The script provides a small initializer that wires up click handlers on markup that follows the project's CSS conventions.

Markup

Minimal accessible markup the script expects:

<div class="ds-accordion">
  <button class="ds-accordion__summary-wrapper" aria-controls="accordion-01" aria-expanded="false">
    <div class="ds-accordion__summary">Summary title</div>
  </button>
  <div id="accordion-01" class="ds-accordion__content">
    <!-- panel content -->
  </div>
</div>

Notes:

  • The toggling element must be a focusable control (usually a button).
  • The toggler should have aria-controls pointing to the content id and an aria-expanded attribute (the script will update it).

Installation

This package is built into the monorepo and distributed as a compiled script and styles. In an application bundler or demo, include the script and call the initializer after DOM ready:

<script type="module">
  import initAccordions from '@wmcadigital/ui-accordion/dist/scripts/accordion.js';
  document.addEventListener('DOMContentLoaded', () => initAccordions());
</script>

Or, if you use the default build output via a bundler you can import the default export:

import initAccordions from '@wmcadigital/ui-accordion';
initAccordions();

Options

The initializer accepts an optional options object to customise selectors, class and attribute names:

initAccordions({
  rootSelector: '.my-accordion',
  summarySelector: '.my-summary',
  openClass: 'is-open',
});

Accessibility

  • Use a button for the summary control so it is keyboard-accessible by default.
  • Keep aria-controls and aria-expanded in sync — the script will update aria-expanded automatically when a user toggles.
  • Ensure each content panel has a unique id referenced by its toggler's aria-controls.
  • Provide sufficient heading structure inside the summary for screen reader users. Avoid duplicate id values across accordions.

Behaviour and keyboard

  • Click toggles open/closed state and updates aria-expanded.
  • The component does not move focus; if required, manage focus in your page-level scripts.

Contributing

If you need additional features (keyboard navigation between headers, single-open behaviour, etc.) open a PR or issue with proposed API and tests.