Hi, I'm Eric Kwoka. I am a Full-Stack Engineer and User Experience Professional

Currently Listening:Everywhere - Fleetwood Mac
Scroll Down

Most DevelopedSkills

A sampling of the core technologies I have become talented in. There are always more things to learn, but I have found a lot of the underlying skills here to be transferrable as I explore new technologies.

  • PreactPreact/React
  • TypeScriptTypeScript
  • Tailwind CSSTailwind CSS
  • ShopifyShopify Liquid
  • AlpineJSAlpine

ProjectCustom Spotify Webapp

Custom Spotify Webapp

This is my attempt at recreating Spotify but with some (imho improved) UI/UX as well as extend it with additional features.

This project is built on top of a custom scaffold I put together I call a PETT App.

At the core is Preact (a lightweight React alternative) coupled with some custom utilities and the Spotify API and Web Playback SDKs to enable a powerful native-like experience.

This is complemented by esbuild for 🔥 BLAZINGLY FAST 🔥 build times. So fast there isn't a need for a special dev server.

Note: This project is still a work in progress and is not accessible by users that have not been manually approved. This is a restriction imposed by Spotify. For access, just message me!

  • PreactPreact/React
  • FaunaDB
  • Spotify Web SDK
  • esbuildesbuild
  • Netlify Functions
  • TypeScriptTypeScript
  • Tailwind CSSTailwind CSS

ProjectDok-Dabang eCommerce

Dok-Dabang eCommerce

A demonstration eCommerce site for a Cafe.

This uses a custom Static Site Generator to build the site from Liquid templates and JSON Data. The whole build pipeline was architected from scratch.

This project was the 🏆 Winner 🏆 for Webjam 11!

  • AlpineJSAlpine
  • ShopifyShopify Liquid
  • Tailwind CSSTailwind CSS

PackageESLint Filename Enforcement

A simple ESLint plugin to enforce the name of JS and TS module files matching to the names of their exports.

Rules:

  • match-named-export: Enforces that the filename matches to a named export.
  • match-default-export: Enforces that filenames match the name of the default export.
NPM VersionNPM DownloadsMINZIPPED Size

PackageSpotify API

Born from my own difficulties using other wrapper libraries for Spotify, this library seeks to be the best possible API wrapper.

  • 🏷 Types out of the box!
  • 🌴 Treeshakeable and composable!
  • ⚡️ Improved performance from the intelligent use of caches and batching!
  • 🏗 Consistent Behavior through normalized return types!
  • 🦕 Supports Deno and Bun out of the box!
NPM VersionNPM DownloadsMINZIPPED SizeNPM Type Definitions

PackagePreact Heroicons

The beautiful Heroicons all bundled up as Preact components. Tree-shakable and Typed for use in any Preact project.

This project was a necessity, as the official Heroicons React components are not compatible with Preact typings, and of course also require preact-compat which just won't do.

NPM VersionNPM DownloadsMINZIPPED SizeNPM Type Definitions
View all packages

Open SourceContributions

Userback

Offers Delayed Initialization in React

Refactors initialization to gracefully handle multiple init calls and enabling options to delay initialization until the UI is needed.

AlpineJSAlpine

Prevents Coercion of Space to Minus

Fixes a bug in which Space and Underscore key presses were being coerced into a 'minus' keypress in key handlers

AlpineJSAlpine

Add Promise to $nextTick

To bring the functionality more inline with Vue's implementation of $nextTick, the magic returns a Promise that resolves when the callback is run.

Flamethrower Router

Performance Optimizations

Improves the performance of the DOM diff'ing algorithm, optimized for the most common scenarios.