How To Enable The Ghost Effect On A Table Row In Safari HTML5?
Solution 1:
On OSX Safari the drag helper (ghost effect) shows up as soon as you attach drag&drop related event listeners to the table rows.
<table>
<tr id="row1" draggable="true">
<td>1</td>
<td>2</td>
<td>3</td>
</tr>
<tr id="row2">
<td>4</td>
<td>5</td>
<td>6</td>
</tr>
</table>
With only this, drag helper won't show up.
But as soon as you attach an event, it will:
var row1 = document.getElementById('row1');
row1.addEventListener('dragstart', function(e) {
//Dragstart code here
}, false);
Hope this helps.
Solution 2:
Very late answer, but I've just been dealing with this issue myself, and hopefully this might be useful to someone else discovering this question.
According to this answer, there's a bug in Safari when generating the drag ghost for elements with display: table-row
within a <table>
(it also appears to apply to display: table-group
.) That answer suggests changing the display
property to something else, which does indeed cause a correct drag ghost to be created, although it of course changes the layout in (probably) unwanted ways.
The trick I've found is to change the style in my onDragStart
handler, and use a timeout to (almost) immediately reset it. I also temporarily hard-code to the row and cell widths to match their current sizes as these are otherwise recalculated. Finally, I explicitly set the drag image to ensure that it's correctly positioned under the mouse pointer. Here's a function which does the trick when passed the drag event:
function hackRowForDragInSafari(event) {
let row = event.target
for (let cell of row.cells) {
cell.style.setProperty('width', cell.offsetWidth + 'px', 'important')
}
row.style.setProperty('width', row.offsetWidth + 'px', 'important')
row.style.setProperty('display', 'block', 'important')
setTimeout(() => {
for (let cell of row.cells) {
cell.style.removeProperty('width')
}
row.style.removeProperty('display')
row.style.removeProperty('width')
})
event.dataTransfer.setDragImage(event.target, event.offsetX, event.offsetY)
}
Ideally, you'd only trigger this if the UA is Safari, and you'll want to adapt this to your use case if you're using a drag handle in a cell, or if you're already using staying on your table this would break, etc.
Post a Comment for "How To Enable The Ghost Effect On A Table Row In Safari HTML5?"