Skip to content

Lightweight, zero-dependency, number input component with mouse drag actions just like in Blender and 3D Studio Max.

License

Notifications You must be signed in to change notification settings

mackan92/react-input-with-drag

 
 

Repository files navigation

💄 React input with drag

Lightweight, zero-dependency, number input component with mouse drag actions just like in Blender and 3D Studio Max.

Install

npm install --save-dev react-input-with-drag

Usage

import InputWithDrag from 'react-input-with-drag';
import type { InputWithDragChangeHandler } from 'react-input-with-drag';

function App() {
  const handleChange: InputWithDragChangeHandler = value => {
    // fired on input change and drag end
  };

  const handleInput: InputWithDragChangeHandler = value => {
    // fired on every input change, including every pixel dragged
  };

  return (
    <InputWithDrag value={100} onChange={handleChange} onInput={handleInput} />
  );
}

Properties

Since react-input-with-drag overloads a regular HTML input, all the typical properties are accepted, like onChange, onInput, step, min, and max. Being a React component, you can override the styles with either style or className as well.

Additionally, these are props to customise react-input-with-drag:

| prop | default | description | | :-------- | :------------------ | :---------------------------------------------------------- | --- | | modifiers | { shiftKey: 0.1 } | Sets the precision of a drag when a modifier key is pressed | |

Note

A modifier takes the step property into account. If step is 0.1, the default shift key will add/subtract by 0.01

About

Lightweight, zero-dependency, number input component with mouse drag actions just like in Blender and 3D Studio Max.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 99.3%
  • Other 0.7%