-
Notifications
You must be signed in to change notification settings - Fork 69
/
Copy pathvue-dragula.js
65 lines (53 loc) · 1.29 KB
/
vue-dragula.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import dragula from 'dragula'
import DragulaService from './service'
if (!dragula) {
throw new Error('[vue-dragula] cannot locate dragula.')
}
export default function (Vue) {
let service = new DragulaService(Vue)
let name = 'globalBag'
let drake
Vue.vueDragula = {
options: service.setOptions,
eventBus: service.eventBus
}
Vue.directive('dragula', {
params: ['bag'],
bind () {
let container = this.el
let bagName = this.params.bag
if (bagName !== undefined && bagName.length !== 0) {
name = bagName
}
let bag = service.find(name)
if (bag) {
drake = bag.drake
drake.containers.push(container)
return
}
drake = dragula({
containers: [container]
})
service.add(name, drake)
service.handleModels(name, drake)
},
update (newValue, oldValue) {
if (!newValue) { return }
if (!drake.models) {
drake.models = [newValue]
} else {
let modelIndex = oldValue
? drake.models.indexOf(oldValue)
: -1
if (modelIndex >= 0) {
drake.models.splice(modelIndex, 1, newValue)
} else {
drake.models.push(newValue)
}
}
},
unbind () {
service.destroy(name)
}
})
}