0.1.2 • Published 6 years ago
react-drag-elements v0.1.2
About
This project is inspired by the MacOS Launchpad iOS Springboard UI, where items can be dragged around and reordered.
Setup
yarn add react-drag-elementsor
npm install react-drag-elementsUsage
import useDragElements from 'react-drag-elements'
const initialItems = [
  { id: 0, text: 'One', color: '#616AFF' },
  { id: 1, text: 'Two', color: '#2DBAE7' },
  { id: 2, text: 'Three', color: '#fd4e4e' },
]
export default function App() {
  const { items, getItemProps } = useDragElements({
    initialItems,
    delay: 200, // optional
    debounceMs: 200, // optional
    easeFunction: `ease-out` // optional
  })
  return (
    <ul>
      {items.map((item: any) => (
        <li key={item.id}>
          <button
            {...getItemProps(item.id)}
            style={{ background: item.color }}
          >
            <span>{item.text}</span>
          </button>
        </li>
      ))}
    </ul>
  )
}Props
initialItems
Array of objects with each item containing a unique id
delay
number, defaults to 250
debounceMs
number, defaults to 200
easeFunction
string, defaults to a subtle springy
cubic-bezier(.39,.28,.13,1.14)
Example
git clone git@github.com:timc1/react-drag-elements.gitcd react-drag-elements/exampleyarnyarn start