annotate src/examples/nested.html @ 20:0b3376e13e22 default tip

add nested example
author Franklin Schmidt <fschmidt@gmail.com>
date Tue, 18 Feb 2025 17:23:17 -0700
parents src/examples/list2.html@969d5980b375
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
1 <!doctype html>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
2 <html>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
3 <head>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
4 <meta name="viewport" content="width=device-width, initial-scale=1">
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
5 <style>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
6 @import "/site.css";
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
7 @import "/dad.css";
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
8
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
9 [drop] {
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
10 margin-top: 8px;
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
11 margin-bottom: 8px;
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
12 }
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
13 [drag] {
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
14 background-color: LightGreen;
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
15 padding: 8px;
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
16 display: inline-block;
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
17 }
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
18 </style>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
19 <script src="/dad.js"></script>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
20 <script>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
21 function indexOf(a,el) {
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
22 for( let i=0; i<a.length; i++ ) {
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
23 if( a[i] === el )
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
24 return i;
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
25 }
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
26 return -1;
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
27 }
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
28
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
29 dad.whatToDrag = function(draggable) {
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
30 return draggable.parentNode;
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
31 };
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
32
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
33 dad.onEnter = function(event) {
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
34 let dropzone = event.dropzone;
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
35 let original = event.original;
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
36 let filter = original.getAttribute('drop');
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
37 if( dropzone.getAttribute('drop') !== filter ) {
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
38 return false;
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
39 }
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
40 let items = document.querySelectorAll(`[drop="${filter}"]`);
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
41 let iDropzone = indexOf(items,dropzone);
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
42 let iOriginal = indexOf(items,original);
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
43 let where = iDropzone < iOriginal ? 'beforebegin' : 'afterend';
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
44 dropzone.insertAdjacentElement(where,original);
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
45 };
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
46
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
47 function init() {
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
48 let items = document.querySelectorAll('[drop]');
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
49 for( let item of items ) {
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
50 dad.setDropzone(item);
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
51 let filter = item.getAttribute('drop');
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
52 let drag = item.querySelector(`[drag="${filter}"]`);
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
53 dad.setDraggable(drag);
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
54 }
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
55 }
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
56 </script>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
57 </head>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
58 <body>
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
59 <h1>Nested Dynamic Lists</h1>
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
60 <ul>
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
61 <script>
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
62 for( let i=1; i<=5; i++ ) {
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
63 document.write(`
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
64 <li drop="top">${i} - <span drag=top>drag me</span>
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
65 <ul>
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
66 ` );
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
67 for( let j=1; j<=i; j++ ) {
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
68 document.write(`
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
69 <li drop="n${i}">${j} - <span drag="n${i}">drag me</span>
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
70 ` );
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
71 }
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
72 document.write(`
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
73 </ul>
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
74 </li>
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
75 ` );
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
76 }
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
77 </script>
20
0b3376e13e22 add nested example
Franklin Schmidt <fschmidt@gmail.com>
parents: 8
diff changeset
78 </ul>
8
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
79 <p>bottom</p>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
80 </body>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
81 <script> init(); </script>
969d5980b375 add lists
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
82 </html>