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

@designbyadrian/react-interactive-input

v2.0.3

Published

Adjust values in numeric input boxes by clicking and dragging horizontally, just like in Blender and similar 3D applications.

Downloads

284

Readme

NPM Version NPM Unpacked Size npm bundle size GitHub License

In Blender and similar 3D applications, users can adjust values in numeric input boxes by clicking and dragging horizontally, often referred to as scrubbing.

The user typically clicks and holds the mouse over the number, then drags left or right to decrease or increase the value smoothly. This provides quick, precise control over numeric adjustments without needing to type manually or rely on up/down arrows.

This component is a React implementation of that behavior, with a few additional features and customizations.

Features

  • Interactive Input: Click and drag to adjust numeric values smoothly.
  • Customizable: Control the step, min, and max values for the input.
  • Controlled Component: Fully controlled input field with a callback for value changes.
  • Input Masking: Custom input component for handling negative numbers.
  • Theming: Easily customize styles to match your application's look and feel.
  • Accessibility: Built with accessibility in mind.

Try it out

You can try out the component in the Storybook.

🦄🕹️🍕

Installation

To install the library, use npm or yarn:

npm install @designbyadrian/react-interactive-input
# or
yarn add @designbyadrian/react-interactive-input

Usage

import { InteractiveInput } from '@designbyadrian/react-interactive-input';

function MyComponent() {
  return <InteractiveInput value={42} onChange={value => console.log(value)} />;
}

Attributes

The InteractiveInput component accepts all properties of the HTMLInputElement element, especially the following attributes:

  • value: The initial value of the input field.
  • onChange: A callback function that receives the new value when it changes.
  • step: The amount to increment or decrement the value when scrubbing.
  • min: The minimum value allowed.
  • max: The maximum value allowed.

Components

The library exports two components: InteractiveInput and MaskedInput.

InteractiveInput

The main component for interactive input behavior.

MaskedInput

A custom input component featuring input masking specifically designed to address limitations with negative numbers in standard HTML input elements. This component ensures that negative values are properly formatted and accepted by the input field, preventing unexpected behavior or errors when handling signed numbers.

You can provide your own masking function to customize the behavior of the input field.

Example:

import { MaskedInput } from '@designbyadrian/react-interactive-input';

function MyComponent() {
  return (
    <MaskedInput
      value="-4.2"
      onChange={e => console.log(parseFloat(e.target.value))}
    />
  );
}

Running locally

To run the project locally, follow these steps:

  1. Clone the repository:
git clone
  1. Install the dependencies:
npm install
# or
yarn
  1. Start the development server:
npm run dev
# or
yarn dev

The project will be available at http://localhost:6006.

License

This project is licensed under the MIT License. See the LICENSE file for more information.