reactjsdrag-and-dropreact-dnd

How to fix 'Could not find the drag and drop manager in the context of DragSource(Component)'


I have following code

const VisiblePropsPanelItem = React.forwardRef(
({ classes, onChangeValue, attrib, isDragging, connectDragSource, connectDropTarget }, ref) => {
    const elementRef = useRef(null)
    connectDragSource(elementRef)
    connectDropTarget(elementRef)


    const opacity = isDragging ? 0 : 1
    useImperativeHandle(ref, () => ({
        getNode: () => elementRef.current,
    }))
const value = !!(attrib.value)

    return (
  <div ref={elementRef} key={ attrib.name } className = { classes.statusTaskUnit }>
        <CheckBox
          className = { classes.statusCheckBox }
          color = "primary"
          value = { value }
          onChangeValue = { () => { onChangeValue(attrib) } }
        />
        <div className = { classes.statusTextUnit }>{ attrib.name }</div>
          <IconButton aria-label="Comments">
            <DragIcon />
          </IconButton>
    </div>
    )
},
)

export default DropTarget(
CARD,
{
    hover(
  props: MyProps,
        monitor: DropTargetMonitor,
        component: CardInstance,
    ) {
        if (!component) {
            return null
        }
        const node = component.getNode()
        if (!node) {
            return null
        }
        const dragIndex = monitor.getItem().index
        const hoverIndex = props.index

        if (dragIndex === hoverIndex) {
            return
        }

        const hoverBoundingRect = node.getBoundingClientRect()

        const hoverMiddleY =
            (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2

        const clientOffset = monitor.getClientOffset()

        const hoverClientY = (clientOffset).y - hoverBoundingRect.top

        if (dragIndex < hoverIndex && hoverClientY < hoverMiddleY) {
            return
        }

        if (dragIndex > hoverIndex && hoverClientY > hoverMiddleY) {
            return
        }

    },
},
(connect: DropTargetConnector) => ({
    connectDropTarget: connect.dropTarget(),
}),
)(
DragSource(
    CARD,
    {
        beginDrag: (props: MyProps) => ({
            name: props.attrib.name,
            value: props.attrib.value,
        }),
    },
    (connect: DragSourceConnector, monitor: DragSourceMonitor) => ({
        connectDragSource: connect.dragSource(),
        isDragging: monitor.isDragging(),
    }),
)(VisiblePropsPanelItem),
)

but when I try to run it, I get: Uncaught Invariant Violation: Could not find the drag and drop manager in the context of DragSource (Component). Make sure you have your app with DragDropContext.

How can i fix it?

The code is taken from here: https://github.com/react-dnd/react-dnd/blob/master/packages/examples/src/04-sortable/simple/Card.tsx


Solution

  • You need to wrap your root component with dragDropContext or dragDropContextProvider.

    For example:

    import React, { Component } from "react";
    // import ReactDOM from "react-dom";
    import HTML5Backend from "react-dnd-html5-backend";
    import { DragDropContext as dragDropContext } from "react-dnd";
    import DragBox from "./DragBox";
    import DropBox from "./DropBox";
    
    class MainContext extends Component {
      render() {
        return (
          <div style={{ borderStyle: "solid" }}>
            <p style={{ padding: "0px 10px" }}>Main Context</p>
            <DragBox />
            <DropBox />
          </div>
        );
      }
    }
    
    module.exports = dragDropContext(HTML5Backend)(MainContext);
    

    Full example