Coder Social home page Coder Social logo

react-beautiful-dnd's Introduction

react beautiful dnd logo

react-beautiful-dnd

Beautiful and accessible drag and drop for lists with React

CircleCI branch npm

quote application example

Play with this example if you want!

Core characteristics

  • Beautiful and natural movement of items πŸ’
  • Accessible: powerful keyboard and screen reader support ♿️
  • Extremely performant πŸš€
  • Clean and powerful api which is simple to get started with
  • Plays extremely well with standard browser interactions
  • Unopinionated styling
  • No creation of additional wrapper dom nodes - flexbox and focus management friendly!

Get started πŸ‘©β€πŸ«

We have created a free course on egghead.io πŸ₯š to help you get started with react-beautiful-dnd as quickly as possible.

course-logo

Currently supported feature set βœ…

  • Vertical lists ↕
  • Horizontal lists ↔
  • Movement between lists (β–€ ↔ β–€)
  • Combining items
  • Mouse 🐭, keyboard πŸŽΉβ™ΏοΈ and touch πŸ‘‰πŸ“± (mobile, tablet and so on) support
  • Multi drag support
  • Incredible screen reader support ♿️ - we provide an amazing experience for english screen readers out of the box πŸ“¦. We also provide complete customisation control and internationalisation support for those who need it πŸ’–
  • Conditional dragging and conditional dropping
  • Multiple independent lists on the one page
  • Flexible item sizes - the draggable items can have different heights (vertical lists) or widths (horizontal lists)
  • Add and remove items during a drag
  • Compatible with semantic <table> reordering - table pattern
  • Auto scrolling - automatically scroll containers and the window as required during a drag (even with keyboard πŸ”₯)
  • Custom drag handles - you can drag a whole item by just a part of it
  • Compatible with ReactDOM.createPortal - portal pattern
  • 🌲 Tree support through the @atlaskit/tree package
  • A <Droppable /> list can be a scroll container (without a scrollable parent) or be the child of a scroll container (that also does not have a scrollable parent)
  • Independent nested lists - a list can be a child of another list, but you cannot drag items from the parent list into a child list
  • Server side rendering (SSR) compatible - see resetServerContext()
  • Plays well with nested interactive elements by default

Motivation πŸ€”

react-beautiful-dnd exists to create beautiful drag and drop for lists that anyone can use - even people who cannot see. For a good overview of the history and motivations of the project you can take a look at these external resources:

Not for everyone ✌️

There are a lot of libraries out there that allow for drag and drop interactions within React. Most notable of these is the amazing react-dnd. It does an incredible job at providing a great set of drag and drop primitives which work especially well with the wildly inconsistent html5 drag and drop feature. react-beautiful-dnd is a higher level abstraction specifically built for lists (vertical, horizontal, movement between lists, nested lists and so on). Within that subset of functionality react-beautiful-dnd offers a powerful, natural and beautiful drag and drop experience. However, it does not provide the breadth of functionality offered by react-dnd. So react-beautiful-dnd might not be for you depending on what your use case is.

Documentation πŸ“–

About πŸ‘‹

Sensors πŸ”‰

The ways in which somebody can start and control a drag

API πŸ‹οΈβ€

diagram

Guides πŸ—Ί

Patterns πŸ‘·β€

Support πŸ‘©β€βš•οΈ

Read this in other languages 🌎

Author ✍️

Alex Reardon @alexandereardon

Collaborators 🀝

react-beautiful-dnd's People

Contributors

aarbel avatar abeaudoin2013 avatar ajaymathur avatar alexreardon avatar aquibm avatar balonsom avatar bengummer avatar blasz avatar bradleyayers avatar brikou avatar chaficnajjar avatar christianhg avatar danieldelcore avatar danskiiiii avatar davidsunny avatar greenkeeper[bot] avatar homerchen19 avatar hql287 avatar jaredcrowe avatar kulakowka avatar li0liq avatar marshallofsound avatar niwsa avatar noviny avatar rajabellebon avatar rambabusaravanan avatar romellogoodman avatar teleaziz avatar trysound avatar wuweiweiwu avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.