-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathparent-draggable.js
58 lines (52 loc) · 1.62 KB
/
parent-draggable.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
;(function () {
var pageMouseX, pageMouseY
var $iframe = document.querySelector('#app-frame')
var frameTop = 0
var frameLeft = 0
$iframe.style.top = frameTop + 'px'
$iframe.style.left = frameLeft + 'px'
window.addEventListener('message', evt => {
const data = evt.data
switch (data.msg) {
case 'NOTEPAD_DRAG_START':
handleDragStart(data.mouseX, data.mouseY)
break
case 'NOTEPAD_DRAG_MOUSEMOVE':
handleFrameMousemove(data.offsetX, data.offsetY)
break
case 'NOTEPAD_DRAG_END':
handleDragEnd()
break
}
})
function handleDragStart (mouseX, mouseY) {
console.log("Drag Start")
pageMouseX = frameLeft + mouseX
pageMouseY = frameTop + mouseY
document.addEventListener('mouseup', handleDragEnd)
document.addEventListener('mousemove', handlePageMousemove)
}
function handleDragEnd () {
console.log("Drag End")
document.removeEventListener('mouseup', handleDragEnd)
document.removeEventListener('mousemove', handlePageMousemove)
}
function handleFrameMousemove (offsetX, offsetY) {
console.log("Drag In Progress - Frame")
frameTop += offsetY
frameLeft += offsetX
$iframe.style.top = frameTop + 'px'
$iframe.style.left = frameLeft + 'px'
pageMouseX += offsetX
pageMouseY += offsetY
}
function handlePageMousemove (evt) {
console.log("Drag in Progress - Page")
frameTop += evt.clientX - pageMouseX
frameLeft += evt.clientY - pageMouseY
$iframe.style.top = frameTop + 'px'
$iframe.style.left = frameLeft + 'px'
pageMouseX = evt.clientX
pageMouseY = evt.clientY
}
})()