|
8
|
1 <!doctype html>
|
|
21
|
2 <html lang="en">
|
|
8
|
3 <head>
|
|
|
4 <meta name="viewport" content="width=device-width, initial-scale=1">
|
|
|
5 <style>
|
|
|
6 @import "/site.css";
|
|
|
7 @import "/dad.css";
|
|
|
8
|
|
|
9 [item] {
|
|
|
10 background-color: LightGreen;
|
|
|
11 padding: 8px;
|
|
|
12 }
|
|
|
13 [item][in] {
|
|
|
14 border: 1px solid;
|
|
|
15 }
|
|
|
16 </style>
|
|
|
17 <script src="/dad.js"></script>
|
|
|
18 <script>
|
|
|
19 dad.onEnter = function(event) {
|
|
|
20 event.dropzone.setAttribute('in','');
|
|
|
21 };
|
|
|
22
|
|
|
23 dad.onLeave = function(event) {
|
|
|
24 event.dropzone.removeAttribute('in');
|
|
|
25 };
|
|
|
26
|
|
|
27 dad.onDrop = function(event) {
|
|
20
|
28 let dropzone = event.dropzone;
|
|
8
|
29 if( !dropzone )
|
|
|
30 return;
|
|
|
31 let original = event.original
|
|
24
|
32 let items = Array.from(document.querySelectorAll('[item]'));
|
|
|
33 let iDropzone = items.indexOf(dropzone);
|
|
|
34 let iOriginal = items.indexOf(original);
|
|
8
|
35 let where = iDropzone < iOriginal ? 'beforebegin' : 'afterend';
|
|
|
36 dropzone.insertAdjacentElement(where,original);
|
|
|
37 };
|
|
|
38
|
|
|
39 function init() {
|
|
|
40 let items = document.querySelectorAll('[item]');
|
|
|
41 for( let i=0; i<items.length; i++ ) {
|
|
|
42 let item = items[i];
|
|
|
43 dad.setDraggable(item);
|
|
|
44 dad.setDropzone(item);
|
|
|
45 }
|
|
|
46 }
|
|
|
47 </script>
|
|
|
48 </head>
|
|
|
49 <body>
|
|
|
50 <h1>List</h1>
|
|
|
51 <script>
|
|
|
52 for( let i=1; i<=10; i++ ) {
|
|
|
53 document.write(`
|
|
|
54 <p item>${i} - drag me</p>
|
|
|
55 ` );
|
|
|
56 }
|
|
|
57 </script>
|
|
|
58 <p>bottom</p>
|
|
|
59 </body>
|
|
|
60 <script> init(); </script>
|
|
|
61 </html>
|