Не вижу предмет, который я перетаскиваю, используя React-dnd - PullRequest
1 голос
/ 01 апреля 2020

Так что, в принципе, все работает нормально, когда я использую html5 бэкэнд, но так как мое приложение будет использоваться и на телефонах, мне нужно было переключиться на сенсорный бэкэнд. И когда я это делаю, все работает отлично, за исключением того, что я не вижу элементы, которые перетаскиваю. Зона выпадения принимает предметы, меняет класс и все такое, но я просто не вижу кровавых вещей, ни на p c, ни на мобильном. Я попытался использовать DragPreviewImage, и он работает при переключении на html5backend, но не при касании.

Компонент перетаскивания:

const [{isDragging}, drag] = useDrag({
    item: {
        type:ItemTypes.CARD,
        name: props.person,
        id: props.id
    },
    collect: monitor => ({
        isDragging: !!monitor.isDragging(),
      }),
})


return (
    <div
    ref={drag}
    className={`${props.classNameToDisplay} ${isDragging ? 'onDrag' : ""}`}
    id={props.id}
    key={props.person}
    onClick={(e) => props.itemOnClick(e, props.person, props.itemClicked)}>
    {props.person}
</div>
);

Удаление компонента ввода:

const DropInput = (props) => {

const[{isOver, canDrop}, drop] = useDrop({
    accept:ItemTypes.CARD,
    canDrop:(item, monitor) => true,
    drop: (item, monitor) => props.itemOnDrop(item,monitor, "regularBet", props.itemClicked),
    collect: monitor => ({
        isOver : !!monitor.isOver(),
        canDrop : !!monitor.canDrop()
    })
})

return (
    <input
    ref={drop}
    className={`${props.classNameToDisplay} ${isOver && canDrop ? 'onDropAllowed' : ''} `}
    onKeyUp={e => props.itemOnKeyUp(e, props.itemClicked)} 
    onChange={e => props.itemOnChange(e, 'name')}
    type="text"
    name={props.itemClicked}
    id={props.itemClicked}
    value={props.itemName}
    placeholder="ime"/>
);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...