blob: eb5dd04f22291e1ec5a77c57eb03ff80c9a79966 (
plain)
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
|
<?xml version="1.0" encoding="utf-8"?>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>drofEffect after drop event is cancelled</title>
<style type="text/css">
div
{display:inline-block;
vertical-align:top;
background-color:olive;
color:white;
padding:20px;
width:100px;
height:100px;}
div:nth-child(2)
{background-color:green;}
div:nth-child(3)
{background-color:teal;}
</style>
<script type="application/ecmascript">
var effects = ['copy','move','link'], result = false, e = 0;
function selectText()
{window.getSelection().selectAllChildren(document.querySelector('p'))}
function dropSelection(event,element)
{event.preventDefault();
e = element;
if(event.dataTransfer.dropEffect == effects[element])
{result = true}
selectText();}
function endDrag(event)
{document.querySelectorAll('div')[e].appendChild(document.createTextNode((result && event.dataTransfer.dropEffect == effects[e])?' PASS ':' FAIL '));}
</script>
</head>
<body onload="selectText()">
<div ondrop="dropSelection(event,0)" dropzone="copy string:text/plain"/>
<div ondrop="dropSelection(event,1)" dropzone="move string:text/plain"/>
<div ondrop="dropSelection(event,2)" dropzone="link string:text/plain"/>
<p ondragend="endDrag(event)">Drag me</p>
<p>You should be able to drag selection and drop it onto any of the green boxes.</p>
</body>
</html>
|