Mercurial Hosting > dad
view src/examples/list2.html @ 19:dac260018e2e default tip
minor
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Sun, 15 Sep 2024 08:15:23 -0600 |
parents | 969d5980b375 |
children |
line wrap: on
line source
<!doctype html> <html> <head> <meta name="viewport" content="width=device-width, initial-scale=1"> <style> @import "/site.css"; @import "/dad.css"; [item] { background-color: LightGreen; padding: 8px; } </style> <script src="/dad.js"></script> <script> function indexOf(a,el) { for( let i=0; i<a.length; i++ ) { if( a[i] === el ) return i; } return -1; } dad.onEnter = function(event) { let dropzone = event.dropzone let original = event.original let items = document.querySelectorAll('[item]'); let iDropzone = indexOf(items,dropzone); let iOriginal = indexOf(items,original); let where = iDropzone < iOriginal ? 'beforebegin' : 'afterend'; dropzone.insertAdjacentElement(where,original); }; function init() { let items = document.querySelectorAll('[item]'); for( let i=0; i<items.length; i++ ) { let item = items[i]; dad.setDraggable(item); dad.setDropzone(item); } } </script> </head> <body> <h1>Dynamic List</h1> <script> for( let i=1; i<=10; i++ ) { document.write(` <p item>${i} - drag me</p> ` ); } </script> <p>bottom</p> </body> <script> init(); </script> </html>