Skip to content

2.6.0

Compare
Choose a tag to compare
@alexreardon alexreardon released this 14 Nov 05:06
· 725 commits to master since this release

Features

Touch support! #11 📱👍

Mobile, tablet as well as other touch devices

Some examples recorded from an iphone 6s.

Mobile portrait Mobile landscape
Mobile portrait Mobile landscape

We have really sweated the details to bring you a drag and drop experience that works out of the box which is intuitive for users, respects standard browser touch interactions as much as possible, and looks amazing ✨.

This is the most requested feature of the library and it is exciting to see it ship!

If you are interested to read a bit more about the thinking that went into it you can read the docs as well as the discussions surroundings its creation.

Changes

Adding DragHandleProvided event handlers

These are used to start and manage part of the touch interactions.

type DragHandleProvided = {|
  onMouseDown: (event: MouseEvent) => void,
  onKeyDown: (event: KeyboardEvent) => void,
  onClick: (event: MouseEvent) => void,
+  onTouchStart: (event: TouchEvent) => void,
+  onTouchMove: (event: TouchEvent) => void,
  tabIndex: number,
  'aria-grabbed': boolean,
  draggable: boolean,
  onDragStart: () => void,
  onDrop: () => void
|}

DraggableStyle

Styles are applied by default to Draggables to facilitate a better touch device drag and drop experience. Consumers can opt out of these styles or change them if they really need too for their specific use case.

type DraggableStyle = DraggingStyle | NotDraggingStyle

+type BaseStyle = {
+  // Disable standard long press action
+  WebkitTouchCallout: 'none',
+
+  // Disable grey overlay on active anchors
+  WebkitTapHighlightColor: 'rgba(0,0,0,0)',
+
+  // Avoid pull to refresh action and anchor focus on Android Chrome
+  touchAction: 'none',
+}

+ type DraggingStyle = BaseStyle & {
  pointerEvents: 'none',
  position: 'fixed',
  width: number,
  height: number,
  boxSizing: 'border-box',
  top: number,
  left: number,
  margin: 0,
  transform: ?string,
  zIndex: ZIndex,
}
+ type NotDraggingStyle = BaseStyle & {
  transition: ?string,
  transform: ?string,
  pointerEvents: 'none' | 'auto',
|}

Improvements

  • Major refactor to drag handle logic to simply how different types of dragging is done as well as adding lots more test cases #165
  • Updating the readme with an updated example #168. Thanks @skroth!
  • Remove disclaimer for moving between droppables #160. Thanks @on3iro!
  • Adding keyboard patching example #152. Thanks @hql287!

Broader thanks

Getting dragging working on touch devices is no easy feat. The quality of this release would not have been possible without close examination of how others have already tackled this problem. In no particular order, a huge thank you to the following projects and those who work on them: