Beautiful and accessible drag and drop for lists with React
npm install @adaptabletools/react-beautiful-dnd##
This is a fork of the react-beautiful-dnd project, done by AdaptableTools.
The only change is to add support for React 19.
Hey all,
We are taking the next step in saying thank you and goodbye to our friend react-beautiful-dnd.
- ๐ We will be soon deprecating react-beautiful-dnd on npm. When we do you will start to get console warnings in your build tools.
- ๐ On Apr 30, 2025 (six months from posting) we will archiving the react-beautiful-dnd Github repository (it will become read only).
Thank you everybody for your support of this project.
---

Beautiful and accessible drag and drop for lists with React


- 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!
We have created a free course on egghead.io ๐ฅ to help you get started with react-beautiful-dnd as quickly as possible.

- Vertical lists โ - ๐ Rethinking drag and drop There are a lot of libraries out there that allow for drag and drop interactions within React. Most notable of these is the amazing - Installation > The ways in which somebody can start and control a drag - Mouse dragging ๐ญ - - - Virtual lists ๐พ - Engineering health -  Alex Reardon @alexandereardon > Alex is no longer personally maintaning this project. The other wonderful maintainers are carrying this project forward. - Daniel Del Core - Bogdan Chadkin @IAmTrySound
- Horizontal lists โ
- Movement between lists (โค โ โค)
- Virtual list support ๐พ - unlocking 10,000 items @ 60fps
- 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 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
- Able to move the dragging item to another element while dragging (clone, portal) - Reparenting your
- Create scripted drag and drop experiences ๐ฎ
- Allows extensions to support for any input type you like ๐น
- ๐ฒ Tree support through the @atlaskit/tree package
- A 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 defaultMotivation ๐ค
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:
- ๐ง React podcast: fast, accessible and beautiful drag and dropNot for everyone โ๏ธ
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 ๐
$3
- Examples and samples
- Get started
- Design principles
- Animations
- Accessibility
- Browser support$3
- Touch dragging ๐๐ฑ
- Keyboard dragging ๐นโฟ๏ธ
- Create your own sensor (allows for any input type as well as scripted experiences)$3
- _Wraps the part of your application you want to have drag and drop enabled for_
- - _An area that can be dropped into. Contains s_
- - _What can be dragged around_
- resetServerContext() - _Utility for server side rendering (SSR)_$3
responders - _onDragStart, onDragUpdate, onDragEnd and onBeforeDragStart_
- Combining s
- Common setup issues
- Using innerRef
- Setup problem detection and error recovery
- Rules for draggableId and droppableIds
- Browser focus retention
- Customising or skipping the drop animation
- Auto scrolling
- Controlling the screen reader
- Use the html5 doctype
- TypeScript and flow: type information
- Dragging s
- Avoiding image flickering
- Non-visible preset styles
- How we detect scroll containers
- How we use dom events - _Useful if you need to build on top of react-beautiful-dnd_
- Adding s during a drag (11.x behaviour) - _โ ๏ธ Advanced_
- Setting up Content Security Policy$3
- Multi drag
- Tables
- Reparenting a - _Using our cloning API or your own portal_$3
- Community and addons
- Release notes and changelog
- Upgrading
- Road map
- MediaRead this in other languages ๐
- 
- 
- 
- Creator โ๏ธ
Maintainers
- Many other @Atlassian's!Collaborators ๐ค