New — hover-time tooltips & auto-highlighting markers in WaveformPlayer 1.16. What's new →

Packages

The whole family on npm.

A small, zero-dependency set of vanilla-JS audio packages — scoped under @arraypress, all MIT-licensed. Versions are live from npm.

17 packages 121.6k downloads / month

Core

The foundation everything else builds on.
WaveformPlayer ~10KB v1.19.1

The zero-config core. Canvas waveform player with six visual styles, keyboard control and Media Session — vanilla JS, zero dependencies.

npm i @arraypress/waveform-player
116.1k/mo npm GitHub

Extensions

Optional add-ons that drive the core player.
WaveformBar ~6KB v1.9.0

Persistent Spotify-style bottom bar — queue, volume, repeat, favorites, cart, DJ markers and cross-page session persistence.

npm i @arraypress/waveform-bar
1.5k/mo npm GitHub
WaveformPlaylist ~4KB v1.7.0

Playlist and chapter navigation — podcasts, courses, albums and audiobooks. Fully keyboard-accessible.

npm i @arraypress/waveform-playlist
805/mo npm GitHub
WaveformTracker ~2KB v1.0.1

Privacy-first listen analytics. Credits real media-time engagement, ignores seeks, no cookies — send to any endpoint.

npm i @arraypress/waveform-tracker
203/mo npm GitHub

Tooling

Build-time helpers — no runtime.
WaveformGen v1.5.1

Node CLI + library to pre-generate waveform peaks (and BPM) from audio files — instant render, no client-side decode.

npm i @arraypress/waveform-gen
261/mo npm GitHub

Framework wrappers

Typed Astro, React, Vue & Svelte components.
Player · Astro v0.4.0

Typed Astro component wrapper with lazy IntersectionObserver mounting.

npm i @arraypress/waveform-player-astro
918/mo npm GitHub
Player · React v0.4.0

React wrapper — forwardRef imperative handle and typed props.

npm i @arraypress/waveform-player-react
722/mo npm GitHub
Bar · Astro v0.2.0

<WaveformBar> + <WaveformBarTrigger> components for Astro.

npm i @arraypress/waveform-bar-astro
561/mo npm GitHub
Bar · React v0.2.0

<WaveformBar> + <WaveformBarTrigger> components for React.

npm i @arraypress/waveform-bar-react
384/mo npm GitHub
Playlist · Astro v0.2.1

Typed <WaveformPlaylist> for Astro — tracks and chapters as props.

npm i @arraypress/waveform-playlist-astro
Playlist · React v0.2.0

React <WaveformPlaylist> — typed tracks/chapters and a ref handle.

npm i @arraypress/waveform-playlist-react
Player · Vue v0.2.0

Vue 3 wrapper — typed props, event emits and a template-ref imperative handle.

npm i @arraypress/waveform-player-vue
Player · Svelte v0.2.0

Svelte 5 wrapper — typed props, callback props and exported instance methods.

npm i @arraypress/waveform-player-svelte
Bar · Vue v0.1.0

<WaveformBar> + <WaveformBarTrigger> components for Vue 3.

npm i @arraypress/waveform-bar-vue
Bar · Svelte v0.1.0

<WaveformBar> + <WaveformBarTrigger> components for Svelte 5.

npm i @arraypress/waveform-bar-svelte
Playlist · Vue v0.2.0

Vue 3 <WaveformPlaylist> — declarative tracks/chapters and a ref handle.

npm i @arraypress/waveform-playlist-vue
Playlist · Svelte v0.2.0

Svelte 5 <WaveformPlaylist> — declarative tracks/chapters and exported nav methods.

npm i @arraypress/waveform-playlist-svelte

New here? Start with the docs or browse the products.

Start shipping beautiful audio.

Free, open-source and ~10KB — add a div and go.

Read the docs

API reference, guides and recipes for all nine packages.

Browse docs

Open the builder

Configure a player visually and copy the HTML, JS or React.

Try it

Star on GitHub

MIT-licensed, open source, zero dependencies.

View source