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 🙏

© 2024 – Pkg Stats / Ryan Hefner

@isbl/react-resizer

v0.2.4

Published

Resizer component for react

Downloads

9

Readme

@isbl/react-resizer

MIT License npm dependencies Releases

Resizable component. But first please ask yourself if you need it, because you can just set:

.element {
  resize: both;
  overflow: auto;
}

to achieve similar effect with just css.

This library does the following:

  • It does not set width and height until user interaction so that you can let layout to determine initial size
  • It works with SSR
  • It works with multi-touch (handles on multiple elements or multiple handles on one)
  • Allows you to set your on styling using any solution you like (css-in-js, react styles or plain old clases)
  • Does not require handles to be direct descendant of the container

Install

yarn add @isbl/react-resizer

or

npm i @isbl/react-resizer

Usage

Basic usage which allows styling of the container but not of separate handles:

import Resizer from '@isbl/react-resizer'

function MyComponent() {
  return (
    <Resizer direction="horizontal">
      <p>Lorem ipsum dolor sit amet</p>
    </Resizer>
  )
}

Usage which allows to customize handles:

import Resizer, { useResizerHandle, ResizerContainer } from '@isbl/react-resizer'

function CustomHandle({ direction }) {
  return (
    <div
      style={{
        background: 'white',
        display: 'inline-block',
        touchAction: 'none'
      }}
      {...useResizerHandle(direction)}
    >
      {direction}
    </div>
  )
}

function MyComponent() {
  return (
    <ResizerContainer style={{ width: 700, background: 'papayawhip' }}>
      Lorem ipsum dolor sit amet
      <CustomHandle direction="vertical" />
      <CustomHandle direction="horizontal" />
      <CustomHandle direction="both" />
    </ResizerContainer>
  )
}

Main rule is that useResizerHandle can only be used in subtree of ResizerContainer and that return value has to be spread on DOM element which is supposed to act as the handle.

This library does not dictate any styling except for setting of width and height on the container, but you probably want to set touch-action: none on handles.

Source structure

src/lib.tsx contains main source file. Rest is just example app using this component where src/index.tsx is entrypoint to that app.

Developing

First you need to install dependencies which you can do by running npm install.

To develop this library just run npm run start. To build it for consumption by other apps run npm run prepare. You can run tests using npm test or npm test -- --watch to run them in watch mode. For tests to work you have to have dev server running.