在拖拽时,react-beautiful-dnd不会在material-ui-next.com持久抽屉中显示可拖动项目

时间:2018-04-10 09:55:38

标签: material-ui drawer

我有一个persistent drawer,其中包含一个带有可拖动项目的可放置列表。功能就在那里,但拖动项目时,未显示正在拖动的项目。我可以完美地拖动项目并分配空间,包括dnd框架所预期的动画,我只是无法看到我正在拖动的内容。如果我将抽屉改为永久抽屉,一切都按预期工作。有什么建议吗?

我的组件(原型代码中): (DragDropContext在父组件中声明)

import React from 'react';
import { Divider, Drawer, IconButton, List, ListItem, Paper, 
withStyles } from 'material-ui';
import { Draggable, Droppable } from 'react-beautiful-dnd';

const styles = {
  list: {
    width: 250,
    marginTop: 70
  },
};

const getItemStyle = (isDragging, draggableStyle) => ({
  // some basic styles to make the items look a bit nicer
  userSelect: 'none',
  padding: 8 * 2,
  margin: `0 0 8px 0`,

  // change background colour if dragging
  background: isDragging ? 'lightgreen' : 'red',

  // styles we need to apply on draggables
      ...draggableStyle,

});

const getListStyle = isDraggingOver => ({
  background: isDraggingOver ? 'lightblue' : 'none',
  padding: 8,
  width: 250,
});

class WidgetDrawer extends React.Component {

  state = { items: [{ id: 1, content: 'Widget A'}, { id: 2, content: 'Widget B'}]};

  renderWidgets() {
    const widgets = [{
      name: 'Widget A'
    }, {
      name: 'Widget B'
    }];

    return widgets.map((widget, index) => {
      return <Draggable key={widget.name} draggableId={widget.name} index={index}>
                  {(provided, snapshot) => (
                    <div>
                      <div
                        ref={provided.innerRef}
                        {...provided.draggableProps}
                        {...provided.dragHandleProps}
                        style={getItemStyle(
                          snapshot.isDragging,
                          provided.draggableProps.style
                        )}
                      >
                        <ListItem>
                          <Paper>
                            {widget.name}
                          </Paper>
                        </ListItem>
                      </div>
                      {provided.placeholder}
                    </div>
                  )}
                </Draggable>
    })
  }

  render() {

    const { classes } = this.props;

    const fullList = (
      <div className={classes.list}>
          <Droppable droppableId="droppable">
          {(provided, snapshot) => (
            <div
              ref={provided.innerRef}
              style={getListStyle(snapshot.isDraggingOver)}
            >
              {this.state.items.map((item, index) => (
                <Draggable key={item.id} draggableId={item.id} index {index}>
                  {(provided, snapshot) => (
                    <div>
                      <div
                        ref={provided.innerRef}
                        {...provided.draggableProps}
                        {...provided.dragHandleProps}
                        style={getItemStyle(
                          snapshot.isDragging,
                          provided.draggableProps.style
                        )}
                      >
                        {item.content}
                      </div>
                      {provided.placeholder}
                    </div>
                  )}
                </Draggable>
              ))}
              {provided.placeholder}
            </div>
          )}
        </Droppable>
      </div>
    );

    return (
     <Drawer
       variant='permanent'
       anchor="right"
       open={this.props.open}
       onClose={this.props.toggleDrawer}>
      <div
        tabIndex={0}
        role="button"
        onClick={this.props.toggleDrawer}
        onKeyDown={this.props.toggleDrawer}
      >
        {fullList}
      </div>
    </Drawer>
    )
  }
}

export default withStyles(styles)(WidgetDrawer);

4 个答案:

答案 0 :(得分:1)

可以通过覆盖

中提供的道具来解决此问题
const getItemStyle = (isDragging, draggableStyle) => ({
  ...draggableStyle,
  userSelect: 'none',
  position:static,
  padding: 8 * 2,
  margin: `0 0 8px 0`,
  background: isDragging ? 'lightgreen' : 'red',    
});

答案 1 :(得分:1)

在“转换”后,可拖动项消失后,在Material-UI抽屉中使用react-beautiful-dnd时,我遇到了同样的问题。

但是,可以通过将可放置列表的transform属性设置为none并防止从Drawer或任何其他变换元素继承该变换来防止此行为。

<Droppable style={{ transform: "none" }} droppableId="droppable">

答案 2 :(得分:0)

对于任何为此苦苦挣扎的人。这很可能是因为您的父元素上设置了一个转换。即使它是零变换,也会使固定子项上的变换混乱。因此,唯一已知的解决方案是删除父对象上的转换(或将其设置为“ none”)。

或者您可以尝试使用React Portal来寻找替代解决方案。

https://github.com/atlassian/react-beautiful-dnd/issues/128

答案 3 :(得分:0)

如果这里的任何答案不起作用,我建议使用他们的 reparenting guide。 基本上他们已经实现了一个克隆 api,它将把拖动的元素克隆到 dom 的根目录。据说它比使用门户的性能更高。