Work

  • National Web Strategy for Local Communities
  • QuickPickle, Behavioral Testing for Modern Web Apps
  • Svelte Supabase Auth
  • Svelte Ken Burns, CSS-Only Slideshow Component
  • Image Crop or Pad, Tiny Image Resizer for Visual Testing
  • Ocean Library Online Search
  • Markdown Chord Formatter

National Web Strategy for Local Communities

A national community directory and a multi-tenant hosting platform for local community websites in support of the national communications strategy of an American religious organization.

DrupalAegirContent StrategyUI/UX DesignGoogle AnalyticsDigitalOceanLinuxNginxOpenStreetMapLeafletMySQL
interactive us map of bahai communities with state selector and contact info
DrupalAegirContent StrategyUI/UX DesignGoogle AnalyticsDigitalOceanLinuxNginxOpenStreetMapLeafletMySQL

QuickPickle, Behavioral Testing for Modern Web Apps

A Vitest plugin that brings Gherkin syntax and BDD testing to modern JavaScript and TypeScript projects with full ESM support.

VitestTestingBehavioral TestingGherkinTypeScriptOpen SourceGitHub ActionsCI/CDChangesets
VitestTestingBehavioral TestingGherkinTypeScriptOpen SourceGitHub ActionsCI/CDChangesets

Svelte Supabase Auth

A drop-in solution for authentication and user management in projects using Supabase Auth, built in Svelte and available as both a Svelte component and a custom element usable in any front-end framework or even plain HTML.

SvelteSupabasePostgresAuthenticationTypeScriptWeb Componentsi18nMulti-factor AuthenticationOpen SourceBDDGitHub Actions
simple authentication form with email address and password
SvelteSupabasePostgresAuthenticationTypeScriptWeb Componentsi18nMulti-factor AuthenticationOpen SourceBDDGitHub Actions

Svelte Ken Burns, CSS-Only Slideshow Component

A CSS-based slideshow component for Svelte that creates dynamic pan-and-zoom motion effects inspired by filmmaker Ken Burns' documentary style, functioning entirely without JavaScript.

SvelteSvelteKitTypeScriptCSSAnimationOpen Source
demo site screenshot of the slideshow interface with mountain village photo and sliders for adjusting animation settings
SvelteSvelteKitTypeScriptCSSAnimationOpen Source

Image Crop or Pad, Tiny Image Resizer for Visual Testing

A lightweight, dependency-free JavaScript library that crops or pads images to target dimensions, designed for automated visual testing workflows where images need consistent sizing for comparison.

JavaScriptSvelteKitVisual Regression TestingImage ProcessingAutomated TestingOpen SourceVitest
image resizing playground comparing fail fast crop pad and pad and adjust strategies
JavaScriptSvelteKitVisual Regression TestingImage ProcessingAutomated TestingOpen SourceVitest

Ocean Library Online Search

A domain-specific search algorithm for long-form literature, combining content importance and match quality to produce useful sentence-level search results.

ElasticSearchFull Text SearchLong-form ContentBehavioral TestingBDDCucumberBM25TypeScript
ocean search for adam and eve comparing legacy and fixed results
ElasticSearchFull Text SearchLong-form ContentBehavioral TestingBDDCucumberBM25TypeScript

Markdown Chord Formatter

A markdown-it plugin that enables musicians to add musical chords to lyric sheets using simple bracket notation, with support for chord diagrams, multiple notational styles, and visual fretboard representations.

JavaScriptTypeScriptMarkdownmarkdown-itMusicOpen SourceObsidianAutomated TestingHTML
markdown it chords demo showing chord notation in brackets converted to formatted lyrics with guitar diagrams
JavaScriptTypeScriptMarkdownmarkdown-itMusicOpen SourceObsidianAutomated TestingHTML
view my portfolio →
© 2026 David Hunt
Home Portfolio Tags Résumé