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

@jolly-pixel/resize-handle

v1.0.0

Published

<h1 align="center"> resize-handle </h1>

Readme

💃 Getting Started

This package is available in the Node Package Repository and can be easily installed with npm or yarn.

$ npm i @jolly-pixel/resize-handle
# or
$ yarn add @jolly-pixel/resize-handle

👀 Usage example

import { ResizeHandle } from "@jolly-pixel/resize-handle";

const sidebar = document.getElementById("sidebar") as HTMLElement;

// Creates a drag handle and inserts it next to the sidebar.
// Dragging the handle resizes the sidebar horizontally.
const handle = new ResizeHandle(sidebar, {
  direction: "left",
  collapsable: true
});

handle.addEventListener("dragStart", () => console.log("resize started"));
handle.addEventListener("drag", () => console.log("resizing…"));
handle.addEventListener("dragEnd", () => console.log("resize ended"));

Then style the handle and the global drag-cursor helpers in your CSS:

.resize-handle {
  width: 4px;
  cursor: ew-resize;
  background: #ccc;
}

.resize-handle.top,
.resize-handle.bottom {
  height: 4px;
  cursor: ns-resize;
}

/* Applied to <html> while dragging — lock the cursor globally */
html.handle-dragging.vertical  * { cursor: ew-resize !important; }
html.handle-dragging.horizontal * { cursor: ns-resize !important; }

To temporarily disable a handle without destroying it, add the disabled CSS class to handle.handleElt. The handle will stop responding to pointer events until the class is removed.

📚 API

ResizeHandleOptions

interface ResizeHandleOptions {
  /**
   * The direction in which the handle resizes the target.
   * Also controls where the handle element is inserted in the DOM:
   * - "left" / "top"  → handle inserted after the target
   * - "right" / "bottom" → handle inserted before the target
   */
  direction: "left" | "right" | "top" | "bottom";
  /**
   * When true, double-clicking the handle collapses the target to zero size.
   * Double-clicking again restores the previous size.
   * @default false
   */
  collapsable?: boolean;
}

new ResizeHandle(targetElt, options)

Creates a resize handle for targetElt. A <div class="resize-handle"> is inserted adjacent to the target in the DOM. If a matching div.resize-handle sibling already exists it is reused.

Throws an Error if direction is not one of the four valid values.

ResizeHandle extends EventTarget. The following events are dispatched on the instance:

  • "dragStart" — fired when the user presses the left mouse button on the handle.
  • "drag" — fired on each pointermove while dragging.
  • "dragEnd" — fired when the pointer is released or cancelled.

CSS classes

The handle element (handleElt) receives these classes automatically:

  • resize-handle — always present, identifies the element.
  • "left" / "right" / "top" / "bottom" — matches the direction option.
  • collapsable — present when collapsable: true.
  • disabled — add this yourself to pause drag interaction without destroying the handle.

While a drag is in progress, <html> receives:

  • handle-dragging — always set during a drag.
  • vertical — set for horizontal handles ("left" / "right").
  • horizontal — set for vertical handles ("top" / "bottom").

✨ Contributors guide

If you are a developer looking to contribute to the project, you must first read the CONTRIBUTING guide.

Once you have finished your development, check that the tests (and linter) are still good by running the following script:

$ npm run test
$ npm run lint

[!CAUTION] In case you introduce a new feature or fix a bug, make sure to include tests for it as well.

📃 License

MIT