-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontainer_controller.js
40 lines (32 loc) · 1.04 KB
/
container_controller.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
import { Controller } from "stimulus"
export default class extends Controller {
static outlets = ["dnd--item"]
disableDrag(event) {
event.preventDefault()
this.element.classList.remove("dropzone")
}
move(event, droppedOn) {
droppedOn.element.insertAdjacentElement(this.beforeOrAfter(event, droppedOn),
this.draggedItem(event).element)
this.draggedItem(event).element.draggable = false
this.reorder()
}
movingUp(event, over) {
const dragged = this.draggedItem(event)
return dragged.sortOrder() > over.sortOrder()
}
// private
reorder(){
this.dndItemOutlets.forEach((item, index) => {
item.setSortOrder(index)
item.element.classList.remove("drop-above", "drop-below")
})
}
beforeOrAfter(event, droppedOn) {
return this.movingUp(event, droppedOn) ? "beforebegin" : "afterend"
}
draggedItem(event) {
const draggedId = event.dataTransfer.getData("text/plain")
return this.dndItemOutlets.find(item => item.rowId() == draggedId)
}
}