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

@reyhappen/react-easy-sort

v1.7.5

Published

A React component to sort items in lists or grids

Downloads

6

Readme

react-easy-sort

A React component to sort items in lists or grids

version Monthly downloads MIT License PRs Welcome

react-easy-sort-demo

The goal of this component is to allow sorting elements with drag and drop.

It is mobile friendly by default. It doesn't block scrolling the page when swiping inside it: the user needs to press an item during at least 200ms to start the drag gesture.

On non-touch devices, the drag gesture only starts after moving an element by at least one pixel. This is done to avoid blocking clicks on clickable elements inside an item.

Features

  • Supports horizontal and vertical lists
  • Supports grid layouts
  • Mobile-friendly
  • IE11 support 🙈

Demo

Check out the examples:

Installation

yarn add @reyhappen/react-easy-sort

or

npm install @reyhappen/react-easy-sort --save

Basic usage

import SortableList, { SortableItem } from '@reyhappen/react-easy-sort'
import { arrayMoveImmutable } from 'array-move'

const App = () => {
  const [items, setItems] = React.useState(['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I'])

  const onSortEnd = (oldIndex: number, newIndex: number) => {
    setItems((array) => arrayMoveImmutable(array, oldIndex, newIndex))
  }

  return (
    <SortableList onSortEnd={onSortEnd} className="list" draggedItemClassName="dragged" draggedForbiddenClassName="notallowedcursor" forbiddenPointType="element">
      {items.map((item) => (
        <SortableItem key={item}>
          <div className="item">{item}</div>
        </SortableItem>
      ))}
    </SortableList>
  )
}

Props

SortableList

| Name | Description | Type | Default | | ----------------------------- | :---------------------------------------------------------------------: | :--------------------------------------------: | --------------: | | as | Determines html tag for the container element | keyof JSX.IntrinsicElements | div | | onSortEnd* | Called when the user finishes a sorting gesture. | (oldIndex: number, newIndex: number) => void | - | | draggedItemClassName | Class applied to the item being dragged | string | - | | draggedForbiddenClassName | Class applied to the item being dragged out of the container element | string | - | | forbiddenPointType | whether to use a point or an element to determine the item is in the forbidden position | 'point' or 'element' | point | | lockAxis | Determines if an axis should be locked | 'x' or 'y' | | | allowDrag | Determines whether items can be dragged | boolean | true | | customHolderRef | Ref of an element to use as a container for the dragged item | React.RefObject<HTMLElement \| null> | document.body | | dropTarget | React element to use as a dropTarget | ReactNode | |

SortableItem

This component doesn't take any other props than its child. This child should be a single React element that can receives a ref. If you pass a component as a child, it needs to be wrapped with React.forwardRef().

SortableKnob

You can use this component if you don't want the whole item to be draggable but only a specific area of it.

import SortableList, { SortableItem, SortableKnob } from '@reyhappen/react-easy-sort'
import arrayMove from 'array-move'

const App = () => {
  const [items, setItems] = React.useState(['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I'])

  const onSortEnd = (oldIndex: number, newIndex: number) => {
    setItems((array) => arrayMove(array, oldIndex, newIndex))
  }

  return (
    <SortableList onSortEnd={onSortEnd} className="list" draggedItemClassName="dragged" draggedForbiddenClassName="notallowedcursor" forbiddenPointType="element">
      {items.map((item) => (
        <SortableItem key={item}>
          <div className="item">
            <SortableKnob>
              <div>Drag me</div>
            </SortableKnob>
            {item}
          </div>
        </SortableItem>
      ))}
    </SortableList>
  )
}

This component doesn't take any other props than its child. This child should be a single React element that can receive a ref. If you pass a component as a child, it needs to be wrapped with React.forwardRef().

Recommended CSS rules

To disable browser default behaviors that can interfer with the dragging experience, we recommend adding the following declarations on the "items":

  • user-select: none;: disable the selection of content inside the item (the blue box)
  • pointer-events: none;: required for some browsers if your items contain images (see the Interactive avatars demo)

Development

yarn
yarn start

Now, open http://localhost:3001/index.html and start hacking!

License

MIT

Maintainers

This project is maintained by Valentin Hervieu.

This project was originally part of @ricardo-ch organisation because I (Valentin) was working at Ricardo. After leaving this company, they gracefully accepted to transfer the project to me. ❤️

Alternatives

  • https://github.com/clauderic/react-sortable-hoc : before creating this library, I was using it and it was also supporting grid layouts. However, we had a lot of errors reported to our Sentry and this project was not maintained anymore.
  • https://github.com/atlassian/react-beautiful-dnd : another great library for sorting items. However, it doesn't support grid layouts (as of 2021-02-05).