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

@ryvora/react-use-rect

v2.0.0

Published

๐Ÿ“๐Ÿ–ผ๏ธ Get the bounding rect of a DOM element in React. Perfect for tooltips, popovers, and more!

Downloads

20

Readme

use-rect ๐Ÿ“๐Ÿ–ผ๏ธ

Hey there, Measurement Master! ๐Ÿ“

The use-rect hook is a convenient utility for getting the bounding rectangle (size and position) of a DOM element. It typically uses ResizeObserver (or a similar mechanism) to update the rectangle information whenever the element's size changes.

It's like having a live measuring tape ๐Ÿ“ and level for your components, always giving you their precise dimensions and location!

Why is it useful?

  • Dynamic Layouts: Adjust component behavior or style based on its current size or position.
  • Tooltips/Popovers: Help position floating elements relative to their anchor.
  • Virtualization: Calculate item sizes for virtualized lists.
  • Visualizations: Get dimensions for drawing on a canvas or SVG.

Basic Usage (Conceptual):

import { useRect } from '@ryvora/react-use-rect'; // Hook name might vary
import React, { useRef } from 'react';

function MySizedComponent() {
  const myRef = useRef<HTMLDivElement>(null);
  const rect = useRect(myRef); // Pass the ref to the element you want to measure

  return (
    <div>
      <div
        ref={myRef}
        style={{
          width: '50%',
          padding: '20px',
          border: '1px solid blue',
          resize: 'both', // Make it resizable for demo
          overflow: 'auto',
        }}
      >
        Resize me!
      </div>
      {rect && (
        <pre>
          My Current Rect: Width: {rect.width}px Height: {rect.height}px Top: {rect.top}px Left:{' '}
          {rect.left}px
        </pre>
      )}
    </div>
  );
}

Get the exact measure of your components and build responsive UIs! โœจ๐Ÿ“Š