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

bykugan

v1.0.0

Published

Lightweight, cross-browser usage screen recording utility for web and mobile

Readme

Bykugan

Lightweight, cross-browser usage screen recording utility for web and mobile.

Bykugan is a simple wrapper around the MediaRecorder API that specifically target screen recording (via getDisplayMedia). It provides an easy-to-use API to start, stop, and save screen recordings.

Features

  • 🎥 Easy Screen Recording: Simple start() and stop() methods.
  • 💾 Auto-Save: built-in save() method to download the recording.
  • ⚙️ Configurable: Support for custom MediaStreamConstraints and MIME types.
  • 📱 Lightweight: Zero external dependencies (only dev dependencies).

Installation

npm install bykugan

Usage

Basic Example

import { BykuganRecorder } from 'bykugan';

const recorder = new BykuganRecorder();

// Start recording
// This will prompt the user to select a screen/window to share
await recorder.start();

// ... some time later ...

// Stop recording
// Returns a Blob of the recording
const blob = await recorder.stop();

// Download the recording
recorder.save('my-recording.webm');

Checking Support

import { BykuganRecorder } from 'bykugan';

if (BykuganRecorder.isSupported()) {
    console.log("Screen recording is supported!");
} else {
    console.warn("Screen recording is not supported in this browser.");
}

API

new BykuganRecorder(options)

Creates a new recorder instance.

  • options Object (optional)
    • timeSlice number: The number of milliseconds to record into each Blob (default: 1000).
    • mimeType string: The MIME type to use for the recording (e.g., 'video/webm'). If not provided, it attempts to find the best supported type.
    • constraints MediaStreamConstraints: Constraints passed to getDisplayMedia (default: { video: true, audio: false }).

Methods

recorder.start()

  • Starts the screen capture.
  • Returns: Promise<MediaStream> - The media stream of the screen capture.

recorder.stop()

  • Stops the recording.
  • Returns: Promise<Blob> - The recorded video blob.

recorder.save(filename)

  • Downloads the recorded blob to the user's device.
  • filename string: The name of the file to download (default: 'recording.webm').

recorder.getBlob()

  • Returns the current recorded Blob.

static BykuganRecorder.isSupported()

  • Returns true if the browser supports navigator.mediaDevices.getDisplayMedia and MediaRecorder.

License

MIT