e-frank / yii2-dragula
asset-bundle and widget for dragula drag and drop library
Installs: 2 584
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 2
Open Issues: 1
Type:yii2-extension
Requires
- bower-asset/dragula: *
This package is auto-updated.
Last update: 2025-01-14 03:18:44 UTC
README
yii2 extension / widget for dragula drag and drop library
does not require any other libraries than dragula.
for a detailed documentation and demo see Dragula example page
configuration options
- 'containers': either array of strings containing the ids of the HTML containers or a JsExpression containing the javascript code for the selector
- 'options': array of dragula configuration options, see Dragula example page or Dragula on gihub
- events
- 'drag': JsExpression javascript function
function (el) { ... }
- 'drop': JsExpression javascript function
function (el) { ... }
- 'over': JsExpression javascript function
function (el, container) { ... }
- 'out': JsExpression javascript function
function (el, container) { ... }
example / usage
####1. HTML container for drag and drop items
<ul id="files"> <li data-filename="file 1">file 1</li> <li data-filename="file 2">file 2</li> <li data-filename="file 3">file 3</li> </ul>
####2. Call widget
<?= \x1\dragula\Dragula::widget([ 'containers' => ['#files'], 'options' => [ 'revertOnSpill' => true, ], 'drop' => new \yii\web\JsExpression('my.dropped'), ]); ?>
####3. Javascript for handling drop event
<script> var my = {}; my.dropped = function(el, container) { var c = $(container); var items = c.find('li[data-filename]'); var result = []; $.each(c.find('li[data-filename]'), function(key, item) { result.push($(item).data('filename')); }); console.log('result', result); // your logic here, e.g. ajax post } </script>
Note that i used jquery in my example code, which is optional and not referenced by this project.
Also, you have to take care of script loading order yourself!