dragula.js 69 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971
  1. (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.dragula = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
  2. 'use strict';
  3. var cache = {};
  4. var start = '(?:^|\\s)';
  5. var end = '(?:\\s|$)';
  6. function lookupClass (className) {
  7. var cached = cache[className];
  8. if (cached) {
  9. cached.lastIndex = 0;
  10. } else {
  11. cache[className] = cached = new RegExp(start + className + end, 'g');
  12. }
  13. return cached;
  14. }
  15. function addClass (el, className) {
  16. var current = el.className;
  17. if (!current.length) {
  18. el.className = className;
  19. } else if (!lookupClass(className).test(current)) {
  20. el.className += ' ' + className;
  21. }
  22. }
  23. function rmClass (el, className) {
  24. el.className = el.className.replace(lookupClass(className), ' ').trim();
  25. }
  26. module.exports = {
  27. add: addClass,
  28. rm: rmClass
  29. };
  30. },{}],2:[function(require,module,exports){
  31. (function (global){
  32. 'use strict';
  33. var emitter = require('contra/emitter');
  34. var crossvent = require('crossvent');
  35. var classes = require('./classes');
  36. var doc = document;
  37. var documentElement = doc.documentElement;
  38. var animateDuration = 300;
  39. function dragula (initialContainers, options) {
  40. var len = arguments.length;
  41. if (len === 1 && Array.isArray(initialContainers) === false) {
  42. options = initialContainers;
  43. initialContainers = [];
  44. }
  45. var _mirror; // mirror image
  46. var _source; // source container
  47. var _item; // item being dragged
  48. var _offsetX; // reference x
  49. var _offsetY; // reference y
  50. var _moveX; // reference move x
  51. var _moveY; // reference move y
  52. var _initialSibling; // reference sibling when grabbed
  53. var _currentSibling; // reference sibling now
  54. var _copy; // item used for copying
  55. var _renderTimer; // timer for setTimeout renderMirrorImage
  56. var _lastDropTarget = null; // last container item was over
  57. var _grabbed; // holds mousedown context until first mousemove
  58. var o = options || {};
  59. if (o.moves === void 0) { o.moves = always; }
  60. if (o.accepts === void 0) { o.accepts = always; }
  61. if (o.invalid === void 0) { o.invalid = invalidTarget; }
  62. if (o.containers === void 0) { o.containers = initialContainers || []; }
  63. if (o.isContainer === void 0) { o.isContainer = never; }
  64. if (o.copy === void 0) { o.copy = false; }
  65. if (o.copySortSource === void 0) { o.copySortSource = false; }
  66. if (o.revertOnSpill === void 0) { o.revertOnSpill = false; }
  67. if (o.removeOnSpill === void 0) { o.removeOnSpill = false; }
  68. if (o.direction === void 0) { o.direction = 'vertical'; }
  69. if (o.ignoreInputTextSelection === void 0) { o.ignoreInputTextSelection = true; }
  70. if (o.mirrorContainer === void 0) { o.mirrorContainer = doc.body; }
  71. if (o.staticClass === void 0) { o.staticClass = ''; }
  72. var drake = emitter({
  73. containers: o.containers,
  74. start: manualStart,
  75. end: end,
  76. cancel: cancel,
  77. remove: remove,
  78. destroy: destroy,
  79. canMove: canMove,
  80. dragging: false
  81. });
  82. if (o.removeOnSpill === true) {
  83. drake.on('over', spillOver).on('out', spillOut);
  84. }
  85. events();
  86. return drake;
  87. function isContainer (el) {
  88. return drake.containers.indexOf(el) !== -1 || o.isContainer(el);
  89. }
  90. function events (remove) {
  91. var op = remove ? 'remove' : 'add';
  92. touchy(documentElement, op, 'mousedown', grab);
  93. touchy(documentElement, op, 'mouseup', release);
  94. }
  95. function eventualMovements (remove) {
  96. var op = remove ? 'remove' : 'add';
  97. touchy(documentElement, op, 'mousemove', startBecauseMouseMoved);
  98. }
  99. function movements (remove) {
  100. var op = remove ? 'remove' : 'add';
  101. crossvent[op](documentElement, 'selectstart', preventGrabbed); // IE8
  102. crossvent[op](documentElement, 'click', preventGrabbed);
  103. }
  104. function destroy () {
  105. events(true);
  106. release({});
  107. }
  108. function preventGrabbed (e) {
  109. if (_grabbed) {
  110. e.preventDefault();
  111. }
  112. }
  113. function grab (e) {
  114. _moveX = e.clientX;
  115. _moveY = e.clientY;
  116. var ignore = whichMouseButton(e) !== 1 || e.metaKey || e.ctrlKey;
  117. if (ignore) {
  118. return; // we only care about honest-to-god left clicks and touch events
  119. }
  120. var item = e.target;
  121. var context = canStart(item);
  122. if (!context) {
  123. return;
  124. }
  125. _grabbed = context;
  126. eventualMovements();
  127. if (e.type === 'mousedown') {
  128. if (isInput(item)) { // see also: https://github.com/bevacqua/dragula/issues/208
  129. item.focus(); // fixes https://github.com/bevacqua/dragula/issues/176
  130. } else {
  131. e.preventDefault(); // fixes https://github.com/bevacqua/dragula/issues/155
  132. }
  133. }
  134. }
  135. function startBecauseMouseMoved (e) {
  136. if (!_grabbed) {
  137. return;
  138. }
  139. if (whichMouseButton(e) === 0) {
  140. release({});
  141. return; // when text is selected on an input and then dragged, mouseup doesn't fire. this is our only hope
  142. }
  143. // truthy check fixes #239, equality fixes #207
  144. if (e.clientX !== void 0 && e.clientX === _moveX && e.clientY !== void 0 && e.clientY === _moveY) {
  145. return;
  146. }
  147. if (o.ignoreInputTextSelection) {
  148. var clientX = getCoord('clientX', e);
  149. var clientY = getCoord('clientY', e);
  150. var elementBehindCursor = doc.elementFromPoint(clientX, clientY);
  151. if (isInput(elementBehindCursor)) {
  152. return;
  153. }
  154. }
  155. var grabbed = _grabbed; // call to end() unsets _grabbed
  156. eventualMovements(true);
  157. movements();
  158. end();
  159. start(grabbed);
  160. var offset = getOffset(_item);
  161. _offsetX = getCoord('pageX', e) - offset.left;
  162. _offsetY = getCoord('pageY', e) - offset.top;
  163. classes.add(_copy || _item, 'gu-transit');
  164. renderMirrorImage();
  165. drag(e);
  166. }
  167. function canStart (item) {
  168. if (drake.dragging && _mirror) {
  169. return;
  170. }
  171. if (isContainer(item)) {
  172. return; // don't drag container itself
  173. }
  174. var handle = item;
  175. while (getParent(item) && isContainer(getParent(item)) === false) {
  176. if (o.invalid(item, handle)) {
  177. return;
  178. }
  179. item = getParent(item); // drag target should be a top element
  180. if (!item) {
  181. return;
  182. }
  183. }
  184. var source = getParent(item);
  185. if (!source) {
  186. return;
  187. }
  188. if ((o.staticClass && item.classList.contains(o.staticClass))) {
  189. return;
  190. }
  191. if (o.invalid(item, handle)) {
  192. return;
  193. }
  194. var movable = o.moves(item, source, handle, nextEl(item));
  195. if (!movable) {
  196. return;
  197. }
  198. return {
  199. item: item,
  200. source: source
  201. };
  202. }
  203. function canMove (item) {
  204. return !!canStart(item);
  205. }
  206. function manualStart (item) {
  207. var context = canStart(item);
  208. if (context) {
  209. start(context);
  210. }
  211. }
  212. function start (context) {
  213. if (isCopy(context.item, context.source)) {
  214. _copy = context.item.cloneNode(true);
  215. drake.emit('cloned', _copy, context.item, 'copy');
  216. }
  217. _source = context.source;
  218. _item = context.item;
  219. _initialSibling = _currentSibling = nextEl(context.item);
  220. drake.dragging = true;
  221. drake.emit('drag', _item, _source);
  222. }
  223. function invalidTarget () {
  224. return false;
  225. }
  226. function end () {
  227. if (!drake.dragging) {
  228. return;
  229. }
  230. var item = _copy || _item;
  231. drop(item, getParent(item));
  232. }
  233. function ungrab () {
  234. _grabbed = false;
  235. eventualMovements(true);
  236. movements(true);
  237. }
  238. function release (e) {
  239. ungrab();
  240. if (!drake.dragging) {
  241. return;
  242. }
  243. var item = _copy || _item;
  244. var clientX = getCoord('clientX', e);
  245. var clientY = getCoord('clientY', e);
  246. var elementBehindCursor = getElementBehindPoint(_mirror, clientX, clientY);
  247. var dropTarget = findDropTarget(elementBehindCursor, clientX, clientY);
  248. if (dropTarget && ((_copy && o.copySortSource) || (!_copy || dropTarget !== _source))) {
  249. drop(item, dropTarget);
  250. } else if (o.removeOnSpill) {
  251. remove();
  252. } else {
  253. cancel();
  254. }
  255. }
  256. function drop (item, target) {
  257. var parent = getParent(item);
  258. if (_copy && o.copySortSource && target === _source) {
  259. parent.removeChild(_item);
  260. }
  261. if (isInitialPlacement(target)) {
  262. drake.emit('cancel', item, _source, _source);
  263. } else {
  264. drake.emit('drop', item, target, _source, _currentSibling);
  265. }
  266. cleanup();
  267. }
  268. function remove () {
  269. if (!drake.dragging) {
  270. return;
  271. }
  272. var item = _copy || _item;
  273. var parent = getParent(item);
  274. if (parent) {
  275. parent.removeChild(item);
  276. }
  277. drake.emit(_copy ? 'cancel' : 'remove', item, parent, _source);
  278. cleanup();
  279. }
  280. function cancel (revert) {
  281. if (!drake.dragging) {
  282. return;
  283. }
  284. var reverts = arguments.length > 0 ? revert : o.revertOnSpill;
  285. var item = _copy || _item;
  286. var parent = getParent(item);
  287. var initial = isInitialPlacement(parent);
  288. if (initial === false && reverts) {
  289. if (_copy) {
  290. if (parent) {
  291. parent.removeChild(_copy);
  292. }
  293. } else {
  294. _source.insertBefore(item, _initialSibling);
  295. }
  296. }
  297. if (initial || reverts) {
  298. drake.emit('cancel', item, _source, _source);
  299. } else {
  300. drake.emit('drop', item, parent, _source, _currentSibling);
  301. }
  302. cleanup();
  303. }
  304. function cleanup () {
  305. var item = _copy || _item;
  306. ungrab();
  307. removeMirrorImage();
  308. if (item) {
  309. classes.rm(item, 'gu-transit');
  310. }
  311. if (_renderTimer) {
  312. clearTimeout(_renderTimer);
  313. }
  314. drake.dragging = false;
  315. if (_lastDropTarget) {
  316. drake.emit('out', item, _lastDropTarget, _source);
  317. }
  318. drake.emit('dragend', item);
  319. _source = _item = _copy = _initialSibling = _currentSibling = _renderTimer = _lastDropTarget = null;
  320. }
  321. function isInitialPlacement (target, s) {
  322. var sibling;
  323. if (s !== void 0) {
  324. sibling = s;
  325. } else if (_mirror) {
  326. sibling = _currentSibling;
  327. } else {
  328. sibling = nextEl(_copy || _item);
  329. }
  330. return target === _source && sibling === _initialSibling;
  331. }
  332. function findDropTarget (elementBehindCursor, clientX, clientY) {
  333. var target = elementBehindCursor;
  334. while (target && !accepted()) {
  335. target = getParent(target);
  336. }
  337. return target;
  338. function accepted () {
  339. var droppable = isContainer(target);
  340. if (droppable === false) {
  341. return false;
  342. }
  343. var immediate = getImmediateChild(target, elementBehindCursor);
  344. var reference = getReference(target, immediate, clientX, clientY);
  345. var initial = isInitialPlacement(target, reference);
  346. if (initial) {
  347. return true; // should always be able to drop it right back where it was
  348. }
  349. return o.accepts(_item, target, _source, reference);
  350. }
  351. }
  352. function drag (e) {
  353. if (!_mirror) {
  354. return;
  355. }
  356. e.preventDefault();
  357. var clientX = getCoord('clientX', e);
  358. var clientY = getCoord('clientY', e);
  359. var x = clientX - _offsetX;
  360. var y = clientY - _offsetY;
  361. _mirror.style.left = x + 'px';
  362. _mirror.style.top = y + 'px';
  363. var item = _copy || _item;
  364. var elementBehindCursor = getElementBehindPoint(_mirror, clientX, clientY);
  365. var dropTarget = findDropTarget(elementBehindCursor, clientX, clientY);
  366. var changed = dropTarget !== null && dropTarget !== _lastDropTarget;
  367. if (changed || dropTarget === null) {
  368. out();
  369. _lastDropTarget = dropTarget;
  370. over();
  371. }
  372. var parent = getParent(item);
  373. if (dropTarget === _source && _copy && !o.copySortSource) {
  374. if (parent) {
  375. parent.removeChild(item);
  376. }
  377. return;
  378. }
  379. var reference;
  380. var immediate = getImmediateChild(dropTarget, elementBehindCursor);
  381. if (immediate !== null) {
  382. reference = getReference(dropTarget, immediate, clientX, clientY);
  383. } else if (o.revertOnSpill === true && !_copy) {
  384. reference = _initialSibling;
  385. dropTarget = _source;
  386. } else {
  387. if (_copy && parent) {
  388. parent.removeChild(item);
  389. }
  390. return;
  391. }
  392. if (
  393. (reference === null && changed) ||
  394. reference !== item &&
  395. reference !== nextEl(item)
  396. ) {
  397. _currentSibling = reference;
  398. var itemRect = item.getBoundingClientRect();
  399. var referenceRect = reference ? reference.getBoundingClientRect() : null;
  400. var direct = o.direction;
  401. // if isPositive is true, the direction is right or down
  402. var isPositive;
  403. if (referenceRect) {
  404. isPositive = direct === 'horizontal' ? (itemRect.x < referenceRect.x) : (itemRect.y < referenceRect.y);
  405. }else{
  406. isPositive = true;
  407. }
  408. // mover is the element to be exchange passively
  409. var mover;
  410. if (isPositive) {
  411. mover = reference ? (reference.previousElementSibling ? reference.previousElementSibling : reference) : dropTarget.lastElementChild;
  412. } else {
  413. mover = reference; //upward or right
  414. }
  415. if (!mover) {
  416. return;
  417. }
  418. if (o.staticClass && mover.classList.contains(o.staticClass)) {
  419. return;
  420. }
  421. var moverRect = mover && mover.getBoundingClientRect();
  422. dropTarget.insertBefore(item, reference);
  423. if (mover && moverRect) {
  424. animate(moverRect, mover);
  425. animate(itemRect, item);
  426. }
  427. drake.emit('shadow', item, dropTarget, _source);
  428. }
  429. function moved (type) { drake.emit(type, item, _lastDropTarget, _source); }
  430. function over () { if (changed) { moved('over'); } }
  431. function out () { if (_lastDropTarget) { moved('out'); } }
  432. }
  433. function spillOver (el) {
  434. classes.rm(el, 'gu-hide');
  435. }
  436. function spillOut (el) {
  437. if (drake.dragging) { classes.add(el, 'gu-hide'); }
  438. }
  439. function renderMirrorImage () {
  440. if (_mirror) {
  441. return;
  442. }
  443. var rect = _item.getBoundingClientRect();
  444. _mirror = _item.cloneNode(true);
  445. _mirror.style.width = getRectWidth(rect) + 'px';
  446. _mirror.style.height = getRectHeight(rect) + 'px';
  447. classes.rm(_mirror, 'gu-transit');
  448. classes.add(_mirror, 'gu-mirror');
  449. o.mirrorContainer.appendChild(_mirror);
  450. touchy(documentElement, 'add', 'mousemove', drag);
  451. classes.add(o.mirrorContainer, 'gu-unselectable');
  452. drake.emit('cloned', _mirror, _item, 'mirror');
  453. }
  454. function removeMirrorImage () {
  455. if (_mirror) {
  456. classes.rm(o.mirrorContainer, 'gu-unselectable');
  457. touchy(documentElement, 'remove', 'mousemove', drag);
  458. getParent(_mirror).removeChild(_mirror);
  459. _mirror = null;
  460. }
  461. }
  462. function getImmediateChild (dropTarget, target) {
  463. var immediate = target;
  464. while (immediate !== dropTarget && getParent(immediate) !== dropTarget) {
  465. immediate = getParent(immediate);
  466. }
  467. if (immediate === documentElement) {
  468. return null;
  469. }
  470. return immediate;
  471. }
  472. function getReference (dropTarget, target, x, y) {
  473. var horizontal = o.direction === 'horizontal';
  474. var reference = target !== dropTarget ? inside() : outside();
  475. return reference;
  476. function outside () { // slower, but able to figure out any position
  477. var len = dropTarget.children.length;
  478. var i;
  479. var el;
  480. var rect;
  481. for (i = 0; i < len; i++) {
  482. el = dropTarget.children[i];
  483. rect = el.getBoundingClientRect();
  484. if (horizontal && (rect.left + rect.width / 2) > x) { return el; }
  485. if (!horizontal && (rect.top + rect.height / 2) > y) { return el; }
  486. }
  487. return null;
  488. }
  489. function inside () { // faster, but only available if dropped inside a child element
  490. var rect = target.getBoundingClientRect();
  491. if (horizontal) {
  492. return resolve(x > rect.left + getRectWidth(rect) / 2);
  493. }
  494. return resolve(y > rect.top + getRectHeight(rect) / 2);
  495. }
  496. function resolve (after) {
  497. return after ? nextEl(target) : target;
  498. }
  499. }
  500. function isCopy (item, container) {
  501. return typeof o.copy === 'boolean' ? o.copy : o.copy(item, container);
  502. }
  503. }
  504. function touchy (el, op, type, fn) {
  505. var touch = {
  506. mouseup: 'touchend',
  507. mousedown: 'touchstart',
  508. mousemove: 'touchmove'
  509. };
  510. var pointers = {
  511. mouseup: 'pointerup',
  512. mousedown: 'pointerdown',
  513. mousemove: 'pointermove'
  514. };
  515. var microsoft = {
  516. mouseup: 'MSPointerUp',
  517. mousedown: 'MSPointerDown',
  518. mousemove: 'MSPointerMove'
  519. };
  520. if (global.navigator.pointerEnabled) {
  521. crossvent[op](el, pointers[type], fn);
  522. } else if (global.navigator.msPointerEnabled) {
  523. crossvent[op](el, microsoft[type], fn);
  524. } else {
  525. crossvent[op](el, touch[type], fn);
  526. crossvent[op](el, type, fn);
  527. }
  528. }
  529. function whichMouseButton (e) {
  530. if (e.touches !== void 0) { return e.touches.length; }
  531. if (e.which !== void 0 && e.which !== 0) { return e.which; } // see https://github.com/bevacqua/dragula/issues/261
  532. if (e.buttons !== void 0) { return e.buttons; }
  533. var button = e.button;
  534. if (button !== void 0) { // see https://github.com/jquery/jquery/blob/99e8ff1baa7ae341e94bb89c3e84570c7c3ad9ea/src/event.js#L573-L575
  535. return button & 1 ? 1 : button & 2 ? 3 : (button & 4 ? 2 : 0);
  536. }
  537. }
  538. function getOffset (el) {
  539. var rect = el.getBoundingClientRect();
  540. return {
  541. left: rect.left + getScroll('scrollLeft', 'pageXOffset'),
  542. top: rect.top + getScroll('scrollTop', 'pageYOffset')
  543. };
  544. }
  545. function getScroll (scrollProp, offsetProp) {
  546. if (typeof global[offsetProp] !== 'undefined') {
  547. return global[offsetProp];
  548. }
  549. if (documentElement.clientHeight) {
  550. return documentElement[scrollProp];
  551. }
  552. return doc.body[scrollProp];
  553. }
  554. function getElementBehindPoint (point, x, y) {
  555. var p = point || {};
  556. var state = p.className;
  557. var el;
  558. p.className += ' gu-hide';
  559. el = doc.elementFromPoint(x, y);
  560. p.className = state;
  561. return el;
  562. }
  563. function never () { return false; }
  564. function always () { return true; }
  565. function getRectWidth (rect) { return rect.width || (rect.right - rect.left); }
  566. function getRectHeight (rect) { return rect.height || (rect.bottom - rect.top); }
  567. function getParent (el) { return el.parentNode === doc ? null : el.parentNode; }
  568. function isInput (el) { return el.tagName === 'INPUT' || el.tagName === 'TEXTAREA' || el.tagName === 'SELECT' || isEditable(el); }
  569. function isEditable (el) {
  570. if (!el) { return false; } // no parents were editable
  571. if (el.contentEditable === 'false') { return false; } // stop the lookup
  572. if (el.contentEditable === 'true') { return true; } // found a contentEditable element in the chain
  573. return isEditable(getParent(el)); // contentEditable is set to 'inherit'
  574. }
  575. function nextEl (el) {
  576. return el.nextElementSibling || manually();
  577. function manually () {
  578. var sibling = el;
  579. do {
  580. sibling = sibling.nextSibling;
  581. } while (sibling && sibling.nodeType !== 1);
  582. return sibling;
  583. }
  584. }
  585. /**
  586. * Create an animation from position before sorting to present position
  587. * @param prevRect including element's position infomation before sorting
  588. * @param target element after sorting
  589. */
  590. function animate (prevRect, target) {
  591. if (!prevRect || !target) {
  592. return;
  593. }
  594. var currentRect = target.getBoundingClientRect();
  595. var originProps = {transition: target.style.transition, transform: target.style.transform};
  596. Object.assign(target.style, {
  597. transition: 'none',
  598. transform: 'translate(' + (prevRect.left - currentRect.left) + 'px,' + (prevRect.top - currentRect.top) + 'px)'
  599. });
  600. target.offsetWidth; // repaint
  601. Object.assign(target.style, {transition: 'all ' + animateDuration + 'ms', transform: 'translate(0,0)'});
  602. clearTimeout(target.animated);
  603. target.animated = setTimeout(function () {
  604. Object.assign(target.style, {originProps: originProps});
  605. target.animated = false;
  606. }, animateDuration);
  607. }
  608. function getEventHost (e) {
  609. // on touchend event, we have to use `e.changedTouches`
  610. // see http://stackoverflow.com/questions/7192563/touchend-event-properties
  611. // see https://github.com/bevacqua/dragula/issues/34
  612. if (e.targetTouches && e.targetTouches.length) {
  613. return e.targetTouches[0];
  614. }
  615. if (e.changedTouches && e.changedTouches.length) {
  616. return e.changedTouches[0];
  617. }
  618. return e;
  619. }
  620. function getCoord (coord, e) {
  621. var host = getEventHost(e);
  622. var missMap = {
  623. pageX: 'clientX', // IE8
  624. pageY: 'clientY' // IE8
  625. };
  626. if (coord in missMap && !(coord in host) && missMap[coord] in host) {
  627. coord = missMap[coord];
  628. }
  629. return host[coord];
  630. }
  631. module.exports = dragula;
  632. }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
  633. },{"./classes":1,"contra/emitter":5,"crossvent":6}],3:[function(require,module,exports){
  634. module.exports = function atoa (a, n) { return Array.prototype.slice.call(a, n); }
  635. },{}],4:[function(require,module,exports){
  636. 'use strict';
  637. var ticky = require('ticky');
  638. module.exports = function debounce (fn, args, ctx) {
  639. if (!fn) { return; }
  640. ticky(function run () {
  641. fn.apply(ctx || null, args || []);
  642. });
  643. };
  644. },{"ticky":9}],5:[function(require,module,exports){
  645. 'use strict';
  646. var atoa = require('atoa');
  647. var debounce = require('./debounce');
  648. module.exports = function emitter (thing, options) {
  649. var opts = options || {};
  650. var evt = {};
  651. if (thing === undefined) { thing = {}; }
  652. thing.on = function (type, fn) {
  653. if (!evt[type]) {
  654. evt[type] = [fn];
  655. } else {
  656. evt[type].push(fn);
  657. }
  658. return thing;
  659. };
  660. thing.once = function (type, fn) {
  661. fn._once = true; // thing.off(fn) still works!
  662. thing.on(type, fn);
  663. return thing;
  664. };
  665. thing.off = function (type, fn) {
  666. var c = arguments.length;
  667. if (c === 1) {
  668. delete evt[type];
  669. } else if (c === 0) {
  670. evt = {};
  671. } else {
  672. var et = evt[type];
  673. if (!et) { return thing; }
  674. et.splice(et.indexOf(fn), 1);
  675. }
  676. return thing;
  677. };
  678. thing.emit = function () {
  679. var args = atoa(arguments);
  680. return thing.emitterSnapshot(args.shift()).apply(this, args);
  681. };
  682. thing.emitterSnapshot = function (type) {
  683. var et = (evt[type] || []).slice(0);
  684. return function () {
  685. var args = atoa(arguments);
  686. var ctx = this || thing;
  687. if (type === 'error' && opts.throws !== false && !et.length) { throw args.length === 1 ? args[0] : args; }
  688. et.forEach(function emitter (listen) {
  689. if (opts.async) { debounce(listen, args, ctx); } else { listen.apply(ctx, args); }
  690. if (listen._once) { thing.off(type, listen); }
  691. });
  692. return thing;
  693. };
  694. };
  695. return thing;
  696. };
  697. },{"./debounce":4,"atoa":3}],6:[function(require,module,exports){
  698. (function (global){
  699. 'use strict';
  700. var customEvent = require('custom-event');
  701. var eventmap = require('./eventmap');
  702. var doc = global.document;
  703. var addEvent = addEventEasy;
  704. var removeEvent = removeEventEasy;
  705. var hardCache = [];
  706. if (!global.addEventListener) {
  707. addEvent = addEventHard;
  708. removeEvent = removeEventHard;
  709. }
  710. module.exports = {
  711. add: addEvent,
  712. remove: removeEvent,
  713. fabricate: fabricateEvent
  714. };
  715. function addEventEasy (el, type, fn, capturing) {
  716. return el.addEventListener(type, fn, capturing);
  717. }
  718. function addEventHard (el, type, fn) {
  719. return el.attachEvent('on' + type, wrap(el, type, fn));
  720. }
  721. function removeEventEasy (el, type, fn, capturing) {
  722. return el.removeEventListener(type, fn, capturing);
  723. }
  724. function removeEventHard (el, type, fn) {
  725. var listener = unwrap(el, type, fn);
  726. if (listener) {
  727. return el.detachEvent('on' + type, listener);
  728. }
  729. }
  730. function fabricateEvent (el, type, model) {
  731. var e = eventmap.indexOf(type) === -1 ? makeCustomEvent() : makeClassicEvent();
  732. if (el.dispatchEvent) {
  733. el.dispatchEvent(e);
  734. } else {
  735. el.fireEvent('on' + type, e);
  736. }
  737. function makeClassicEvent () {
  738. var e;
  739. if (doc.createEvent) {
  740. e = doc.createEvent('Event');
  741. e.initEvent(type, true, true);
  742. } else if (doc.createEventObject) {
  743. e = doc.createEventObject();
  744. }
  745. return e;
  746. }
  747. function makeCustomEvent () {
  748. return new customEvent(type, { detail: model });
  749. }
  750. }
  751. function wrapperFactory (el, type, fn) {
  752. return function wrapper (originalEvent) {
  753. var e = originalEvent || global.event;
  754. e.target = e.target || e.srcElement;
  755. e.preventDefault = e.preventDefault || function preventDefault () { e.returnValue = false; };
  756. e.stopPropagation = e.stopPropagation || function stopPropagation () { e.cancelBubble = true; };
  757. e.which = e.which || e.keyCode;
  758. fn.call(el, e);
  759. };
  760. }
  761. function wrap (el, type, fn) {
  762. var wrapper = unwrap(el, type, fn) || wrapperFactory(el, type, fn);
  763. hardCache.push({
  764. wrapper: wrapper,
  765. element: el,
  766. type: type,
  767. fn: fn
  768. });
  769. return wrapper;
  770. }
  771. function unwrap (el, type, fn) {
  772. var i = find(el, type, fn);
  773. if (i) {
  774. var wrapper = hardCache[i].wrapper;
  775. hardCache.splice(i, 1); // free up a tad of memory
  776. return wrapper;
  777. }
  778. }
  779. function find (el, type, fn) {
  780. var i, item;
  781. for (i = 0; i < hardCache.length; i++) {
  782. item = hardCache[i];
  783. if (item.element === el && item.type === type && item.fn === fn) {
  784. return i;
  785. }
  786. }
  787. }
  788. }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
  789. },{"./eventmap":7,"custom-event":8}],7:[function(require,module,exports){
  790. (function (global){
  791. 'use strict';
  792. var eventmap = [];
  793. var eventname = '';
  794. var ron = /^on/;
  795. for (eventname in global) {
  796. if (ron.test(eventname)) {
  797. eventmap.push(eventname.slice(2));
  798. }
  799. }
  800. module.exports = eventmap;
  801. }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
  802. },{}],8:[function(require,module,exports){
  803. (function (global){
  804. var NativeCustomEvent = global.CustomEvent;
  805. function useNative () {
  806. try {
  807. var p = new NativeCustomEvent('cat', { detail: { foo: 'bar' } });
  808. return 'cat' === p.type && 'bar' === p.detail.foo;
  809. } catch (e) {
  810. }
  811. return false;
  812. }
  813. /**
  814. * Cross-browser `CustomEvent` constructor.
  815. *
  816. * https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent.CustomEvent
  817. *
  818. * @public
  819. */
  820. module.exports = useNative() ? NativeCustomEvent :
  821. // IE >= 9
  822. 'function' === typeof document.createEvent ? function CustomEvent (type, params) {
  823. var e = document.createEvent('CustomEvent');
  824. if (params) {
  825. e.initCustomEvent(type, params.bubbles, params.cancelable, params.detail);
  826. } else {
  827. e.initCustomEvent(type, false, false, void 0);
  828. }
  829. return e;
  830. } :
  831. // IE <= 8
  832. function CustomEvent (type, params) {
  833. var e = document.createEventObject();
  834. e.type = type;
  835. if (params) {
  836. e.bubbles = Boolean(params.bubbles);
  837. e.cancelable = Boolean(params.cancelable);
  838. e.detail = params.detail;
  839. } else {
  840. e.bubbles = false;
  841. e.cancelable = false;
  842. e.detail = void 0;
  843. }
  844. return e;
  845. }
  846. }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
  847. },{}],9:[function(require,module,exports){
  848. var si = typeof setImmediate === 'function', tick;
  849. if (si) {
  850. tick = function (fn) { setImmediate(fn); };
  851. } else {
  852. tick = function (fn) { setTimeout(fn, 0); };
  853. }
  854. module.exports = tick;
  855. },{}]},{},[2])(2)
  856. });
  857. //# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","classes.js","dragula.js","node_modules/atoa/atoa.js","node_modules/contra/debounce.js","node_modules/contra/emitter.js","node_modules/crossvent/src/crossvent.js","node_modules/crossvent/src/eventmap.js","node_modules/custom-event/index.js","node_modules/ticky/ticky-browser.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC9pBA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACtDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACrGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","'use strict';\n\nvar cache = {};\nvar start = '(?:^|\\\\s)';\nvar end = '(?:\\\\s|$)';\n\nfunction lookupClass (className) {\n  var cached = cache[className];\n  if (cached) {\n    cached.lastIndex = 0;\n  } else {\n    cache[className] = cached = new RegExp(start + className + end, 'g');\n  }\n  return cached;\n}\n\nfunction addClass (el, className) {\n  var current = el.className;\n  if (!current.length) {\n    el.className = className;\n  } else if (!lookupClass(className).test(current)) {\n    el.className += ' ' + className;\n  }\n}\n\nfunction rmClass (el, className) {\n  el.className = el.className.replace(lookupClass(className), ' ').trim();\n}\n\nmodule.exports = {\n  add: addClass,\n  rm: rmClass\n};\n","'use strict';\n\nvar emitter = require('contra/emitter');\nvar crossvent = require('crossvent');\nvar classes = require('./classes');\nvar doc = document;\nvar documentElement = doc.documentElement;\nvar animateDuration = 300;\n\nfunction dragula (initialContainers, options) {\n  var len = arguments.length;\n  if (len === 1 && Array.isArray(initialContainers) === false) {\n    options = initialContainers;\n    initialContainers = [];\n  }\n  var _mirror; // mirror image\n  var _source; // source container\n  var _item; // item being dragged\n  var _offsetX; // reference x\n  var _offsetY; // reference y\n  var _moveX; // reference move x\n  var _moveY; // reference move y\n  var _initialSibling; // reference sibling when grabbed\n  var _currentSibling; // reference sibling now\n  var _copy; // item used for copying\n  var _renderTimer; // timer for setTimeout renderMirrorImage\n  var _lastDropTarget = null; // last container item was over\n  var _grabbed; // holds mousedown context until first mousemove\n\n  var o = options || {};\n  if (o.moves === void 0) { o.moves = always; }\n  if (o.accepts === void 0) { o.accepts = always; }\n  if (o.invalid === void 0) { o.invalid = invalidTarget; }\n  if (o.containers === void 0) { o.containers = initialContainers || []; }\n  if (o.isContainer === void 0) { o.isContainer = never; }\n  if (o.copy === void 0) { o.copy = false; }\n  if (o.copySortSource === void 0) { o.copySortSource = false; }\n  if (o.revertOnSpill === void 0) { o.revertOnSpill = false; }\n  if (o.removeOnSpill === void 0) { o.removeOnSpill = false; }\n  if (o.direction === void 0) { o.direction = 'vertical'; }\n  if (o.ignoreInputTextSelection === void 0) { o.ignoreInputTextSelection = true; }\n  if (o.mirrorContainer === void 0) { o.mirrorContainer = doc.body; }\n  if (o.staticClass === void 0) { o.staticClass = ''; }\n\n\n  var drake = emitter({\n    containers: o.containers,\n    start: manualStart,\n    end: end,\n    cancel: cancel,\n    remove: remove,\n    destroy: destroy,\n    canMove: canMove,\n    dragging: false\n  });\n\n  if (o.removeOnSpill === true) {\n    drake.on('over', spillOver).on('out', spillOut);\n  }\n\n  events();\n\n  return drake;\n\n  function isContainer (el) {\n    return drake.containers.indexOf(el) !== -1 || o.isContainer(el);\n  }\n\n  function events (remove) {\n    var op = remove ? 'remove' : 'add';\n    touchy(documentElement, op, 'mousedown', grab);\n    touchy(documentElement, op, 'mouseup', release);\n  }\n\n  function eventualMovements (remove) {\n    var op = remove ? 'remove' : 'add';\n    touchy(documentElement, op, 'mousemove', startBecauseMouseMoved);\n  }\n\n  function movements (remove) {\n    var op = remove ? 'remove' : 'add';\n    crossvent[op](documentElement, 'selectstart', preventGrabbed); // IE8\n    crossvent[op](documentElement, 'click', preventGrabbed);\n  }\n\n  function destroy () {\n    events(true);\n    release({});\n  }\n\n  function preventGrabbed (e) {\n    if (_grabbed) {\n      e.preventDefault();\n    }\n  }\n\n  function grab (e) {\n    _moveX = e.clientX;\n    _moveY = e.clientY;\n\n    var ignore = whichMouseButton(e) !== 1 || e.metaKey || e.ctrlKey;\n    if (ignore) {\n      return; // we only care about honest-to-god left clicks and touch events\n    }\n    var item = e.target;\n    var context = canStart(item);\n    if (!context) {\n      return;\n    }\n    _grabbed = context;\n    eventualMovements();\n    if (e.type === 'mousedown') {\n      if (isInput(item)) { // see also: https://github.com/bevacqua/dragula/issues/208\n        item.focus(); // fixes https://github.com/bevacqua/dragula/issues/176\n      } else {\n        e.preventDefault(); // fixes https://github.com/bevacqua/dragula/issues/155\n      }\n    }\n  }\n\n  function startBecauseMouseMoved (e) {\n    if (!_grabbed) {\n      return;\n    }\n    if (whichMouseButton(e) === 0) {\n      release({});\n      return; // when text is selected on an input and then dragged, mouseup doesn't fire. this is our only hope\n    }\n    // truthy check fixes #239, equality fixes #207\n    if (e.clientX !== void 0 && e.clientX === _moveX && e.clientY !== void 0 && e.clientY === _moveY) {\n      return;\n    }\n    if (o.ignoreInputTextSelection) {\n      var clientX = getCoord('clientX', e);\n      var clientY = getCoord('clientY', e);\n      var elementBehindCursor = doc.elementFromPoint(clientX, clientY);\n      if (isInput(elementBehindCursor)) {\n        return;\n      }\n    }\n\n    var grabbed = _grabbed; // call to end() unsets _grabbed\n    eventualMovements(true);\n    movements();\n    end();\n    start(grabbed);\n\n    var offset = getOffset(_item);\n    _offsetX = getCoord('pageX', e) - offset.left;\n    _offsetY = getCoord('pageY', e) - offset.top;\n\n    classes.add(_copy || _item, 'gu-transit');\n    renderMirrorImage();\n    drag(e);\n  }\n\n  function canStart (item) {\n    if (drake.dragging && _mirror) {\n      return;\n    }\n    if (isContainer(item)) {\n      return; // don't drag container itself\n    }\n    var handle = item;\n    while (getParent(item) && isContainer(getParent(item)) === false) {\n      if (o.invalid(item, handle)) {\n        return;\n      }\n      item = getParent(item); // drag target should be a top element\n      if (!item) {\n        return;\n      }\n    }\n    var source = getParent(item);\n    if (!source) {\n      return;\n    }\n\n    if ((o.staticClass && item.classList.contains(o.staticClass))) {\n      return;\n    }\n\n    if (o.invalid(item, handle)) {\n      return;\n    }\n\n    var movable = o.moves(item, source, handle, nextEl(item));\n    if (!movable) {\n      return;\n    }\n\n    return {\n      item: item,\n      source: source\n    };\n  }\n\n  function canMove (item) {\n    return !!canStart(item);\n  }\n\n  function manualStart (item) {\n    var context = canStart(item);\n    if (context) {\n      start(context);\n    }\n  }\n\n  function start (context) {\n    if (isCopy(context.item, context.source)) {\n      _copy = context.item.cloneNode(true);\n      drake.emit('cloned', _copy, context.item, 'copy');\n    }\n\n    _source = context.source;\n    _item = context.item;\n    _initialSibling = _currentSibling = nextEl(context.item);\n\n    drake.dragging = true;\n    drake.emit('drag', _item, _source);\n  }\n\n  function invalidTarget () {\n    return false;\n  }\n\n  function end () {\n    if (!drake.dragging) {\n      return;\n    }\n    var item = _copy || _item;\n    drop(item, getParent(item));\n  }\n\n  function ungrab () {\n    _grabbed = false;\n    eventualMovements(true);\n    movements(true);\n  }\n\n  function release (e) {\n    ungrab();\n\n    if (!drake.dragging) {\n      return;\n    }\n    var item = _copy || _item;\n    var clientX = getCoord('clientX', e);\n    var clientY = getCoord('clientY', e);\n    var elementBehindCursor = getElementBehindPoint(_mirror, clientX, clientY);\n    var dropTarget = findDropTarget(elementBehindCursor, clientX, clientY);\n    if (dropTarget && ((_copy && o.copySortSource) || (!_copy || dropTarget !== _source))) {\n      drop(item, dropTarget);\n    } else if (o.removeOnSpill) {\n      remove();\n    } else {\n      cancel();\n    }\n  }\n\n  function drop (item, target) {\n    var parent = getParent(item);\n    if (_copy && o.copySortSource && target === _source) {\n      parent.removeChild(_item);\n    }\n    if (isInitialPlacement(target)) {\n      drake.emit('cancel', item, _source, _source);\n    } else {\n      drake.emit('drop', item, target, _source, _currentSibling);\n    }\n    cleanup();\n  }\n\n  function remove () {\n    if (!drake.dragging) {\n      return;\n    }\n    var item = _copy || _item;\n    var parent = getParent(item);\n    if (parent) {\n      parent.removeChild(item);\n    }\n    drake.emit(_copy ? 'cancel' : 'remove', item, parent, _source);\n    cleanup();\n  }\n\n  function cancel (revert) {\n    if (!drake.dragging) {\n      return;\n    }\n    var reverts = arguments.length > 0 ? revert : o.revertOnSpill;\n    var item = _copy || _item;\n    var parent = getParent(item);\n    var initial = isInitialPlacement(parent);\n    if (initial === false && reverts) {\n      if (_copy) {\n        if (parent) {\n          parent.removeChild(_copy);\n        }\n      } else {\n        _source.insertBefore(item, _initialSibling);\n      }\n    }\n    if (initial || reverts) {\n      drake.emit('cancel', item, _source, _source);\n    } else {\n      drake.emit('drop', item, parent, _source, _currentSibling);\n    }\n    cleanup();\n  }\n\n  function cleanup () {\n    var item = _copy || _item;\n    ungrab();\n    removeMirrorImage();\n    if (item) {\n      classes.rm(item, 'gu-transit');\n    }\n    if (_renderTimer) {\n      clearTimeout(_renderTimer);\n    }\n    drake.dragging = false;\n    if (_lastDropTarget) {\n      drake.emit('out', item, _lastDropTarget, _source);\n    }\n    drake.emit('dragend', item);\n    _source = _item = _copy = _initialSibling = _currentSibling = _renderTimer = _lastDropTarget = null;\n  }\n\n  function isInitialPlacement (target, s) {\n    var sibling;\n    if (s !== void 0) {\n      sibling = s;\n    } else if (_mirror) {\n      sibling = _currentSibling;\n    } else {\n      sibling = nextEl(_copy || _item);\n    }\n    return target === _source && sibling === _initialSibling;\n  }\n\n  function findDropTarget (elementBehindCursor, clientX, clientY) {\n    var target = elementBehindCursor;\n    while (target && !accepted()) {\n      target = getParent(target);\n    }\n    return target;\n\n    function accepted () {\n      var droppable = isContainer(target);\n      if (droppable === false) {\n        return false;\n      }\n\n      var immediate = getImmediateChild(target, elementBehindCursor);\n      var reference = getReference(target, immediate, clientX, clientY);\n      var initial = isInitialPlacement(target, reference);\n      if (initial) {\n        return true; // should always be able to drop it right back where it was\n      }\n      return o.accepts(_item, target, _source, reference);\n    }\n  }\n\n  function drag (e) {\n    if (!_mirror) {\n      return;\n    }\n    e.preventDefault();\n\n    var clientX = getCoord('clientX', e);\n    var clientY = getCoord('clientY', e);\n    var x = clientX - _offsetX;\n    var y = clientY - _offsetY;\n\n    _mirror.style.left = x + 'px';\n    _mirror.style.top = y + 'px';\n\n    var item = _copy || _item;\n    var elementBehindCursor = getElementBehindPoint(_mirror, clientX, clientY);\n    var dropTarget = findDropTarget(elementBehindCursor, clientX, clientY);\n    var changed = dropTarget !== null && dropTarget !== _lastDropTarget;\n    if (changed || dropTarget === null) {\n      out();\n      _lastDropTarget = dropTarget;\n      over();\n    }\n    var parent = getParent(item);\n    if (dropTarget === _source && _copy && !o.copySortSource) {\n      if (parent) {\n        parent.removeChild(item);\n      }\n      return;\n    }\n    var reference;\n    var immediate = getImmediateChild(dropTarget, elementBehindCursor);\n    if (immediate !== null) {\n      reference = getReference(dropTarget, immediate, clientX, clientY);\n    } else if (o.revertOnSpill === true && !_copy) {\n      reference = _initialSibling;\n      dropTarget = _source;\n    } else {\n      if (_copy && parent) {\n        parent.removeChild(item);\n      }\n      return;\n    }\n    if (\n      (reference === null && changed) ||\n      reference !== item &&\n      reference !== nextEl(item)\n    ) {\n      _currentSibling = reference;\n\n      var itemRect = item.getBoundingClientRect();\n      var referenceRect = reference ? reference.getBoundingClientRect() : null;\n      var direct = o.direction;\n      // if isPositive is true, the direction is right or down\n      var isPositive;\n      if (referenceRect) {\n        isPositive = direct === 'horizontal' ? (itemRect.x < referenceRect.x) : (itemRect.y < referenceRect.y);\n      }else{\n        isPositive = true;\n      }\n      // mover is the element to be exchange passively\n      var mover;\n      if (isPositive) {\n        mover = reference ? (reference.previousElementSibling ? reference.previousElementSibling : reference) : dropTarget.lastElementChild;\n      } else {\n        mover = reference; //upward or right\n      }\n      if (!mover) {\n        return;\n      }\n      if (o.staticClass && mover.classList.contains(o.staticClass)) {\n        return;\n      }\n      var moverRect = mover && mover.getBoundingClientRect();\n      dropTarget.insertBefore(item, reference);\n      if (mover && moverRect) {\n        animate(moverRect, mover);\n        animate(itemRect, item);\n      }\n      drake.emit('shadow', item, dropTarget, _source);\n    }\n    function moved (type) { drake.emit(type, item, _lastDropTarget, _source); }\n    function over () { if (changed) { moved('over'); } }\n    function out () { if (_lastDropTarget) { moved('out'); } }\n  }\n\n  function spillOver (el) {\n    classes.rm(el, 'gu-hide');\n  }\n\n  function spillOut (el) {\n    if (drake.dragging) { classes.add(el, 'gu-hide'); }\n  }\n\n  function renderMirrorImage () {\n    if (_mirror) {\n      return;\n    }\n    var rect = _item.getBoundingClientRect();\n    _mirror = _item.cloneNode(true);\n    _mirror.style.width = getRectWidth(rect) + 'px';\n    _mirror.style.height = getRectHeight(rect) + 'px';\n    classes.rm(_mirror, 'gu-transit');\n    classes.add(_mirror, 'gu-mirror');\n    o.mirrorContainer.appendChild(_mirror);\n    touchy(documentElement, 'add', 'mousemove', drag);\n    classes.add(o.mirrorContainer, 'gu-unselectable');\n    drake.emit('cloned', _mirror, _item, 'mirror');\n  }\n\n  function removeMirrorImage () {\n    if (_mirror) {\n      classes.rm(o.mirrorContainer, 'gu-unselectable');\n      touchy(documentElement, 'remove', 'mousemove', drag);\n      getParent(_mirror).removeChild(_mirror);\n      _mirror = null;\n    }\n  }\n\n  function getImmediateChild (dropTarget, target) {\n    var immediate = target;\n    while (immediate !== dropTarget && getParent(immediate) !== dropTarget) {\n      immediate = getParent(immediate);\n    }\n    if (immediate === documentElement) {\n      return null;\n    }\n    return immediate;\n  }\n\n  function getReference (dropTarget, target, x, y) {\n    var horizontal = o.direction === 'horizontal';\n    var reference = target !== dropTarget ? inside() : outside();\n    return reference;\n\n    function outside () { // slower, but able to figure out any position\n      var len = dropTarget.children.length;\n      var i;\n      var el;\n      var rect;\n      for (i = 0; i < len; i++) {\n        el = dropTarget.children[i];\n        rect = el.getBoundingClientRect();\n        if (horizontal && (rect.left + rect.width / 2) > x) { return el; }\n        if (!horizontal && (rect.top + rect.height / 2) > y) { return el; }\n      }\n      return null;\n    }\n\n    function inside () { // faster, but only available if dropped inside a child element\n      var rect = target.getBoundingClientRect();\n      if (horizontal) {\n        return resolve(x > rect.left + getRectWidth(rect) / 2);\n      }\n      return resolve(y > rect.top + getRectHeight(rect) / 2);\n    }\n\n    function resolve (after) {\n      return after ? nextEl(target) : target;\n    }\n  }\n\n  function isCopy (item, container) {\n    return typeof o.copy === 'boolean' ? o.copy : o.copy(item, container);\n  }\n}\n\nfunction touchy (el, op, type, fn) {\n  var touch = {\n    mouseup: 'touchend',\n    mousedown: 'touchstart',\n    mousemove: 'touchmove'\n  };\n  var pointers = {\n    mouseup: 'pointerup',\n    mousedown: 'pointerdown',\n    mousemove: 'pointermove'\n  };\n  var microsoft = {\n    mouseup: 'MSPointerUp',\n    mousedown: 'MSPointerDown',\n    mousemove: 'MSPointerMove'\n  };\n  if (global.navigator.pointerEnabled) {\n    crossvent[op](el, pointers[type], fn);\n  } else if (global.navigator.msPointerEnabled) {\n    crossvent[op](el, microsoft[type], fn);\n  } else {\n    crossvent[op](el, touch[type], fn);\n    crossvent[op](el, type, fn);\n  }\n}\n\nfunction whichMouseButton (e) {\n  if (e.touches !== void 0) { return e.touches.length; }\n  if (e.which !== void 0 && e.which !== 0) { return e.which; } // see https://github.com/bevacqua/dragula/issues/261\n  if (e.buttons !== void 0) { return e.buttons; }\n  var button = e.button;\n  if (button !== void 0) { // see https://github.com/jquery/jquery/blob/99e8ff1baa7ae341e94bb89c3e84570c7c3ad9ea/src/event.js#L573-L575\n    return button & 1 ? 1 : button & 2 ? 3 : (button & 4 ? 2 : 0);\n  }\n}\n\nfunction getOffset (el) {\n  var rect = el.getBoundingClientRect();\n  return {\n    left: rect.left + getScroll('scrollLeft', 'pageXOffset'),\n    top: rect.top + getScroll('scrollTop', 'pageYOffset')\n  };\n}\n\nfunction getScroll (scrollProp, offsetProp) {\n  if (typeof global[offsetProp] !== 'undefined') {\n    return global[offsetProp];\n  }\n  if (documentElement.clientHeight) {\n    return documentElement[scrollProp];\n  }\n  return doc.body[scrollProp];\n}\n\nfunction getElementBehindPoint (point, x, y) {\n  var p = point || {};\n  var state = p.className;\n  var el;\n  p.className += ' gu-hide';\n  el = doc.elementFromPoint(x, y);\n  p.className = state;\n  return el;\n}\n\nfunction never () { return false; }\nfunction always () { return true; }\nfunction getRectWidth (rect) { return rect.width || (rect.right - rect.left); }\nfunction getRectHeight (rect) { return rect.height || (rect.bottom - rect.top); }\nfunction getParent (el) { return el.parentNode === doc ? null : el.parentNode; }\nfunction isInput (el) { return el.tagName === 'INPUT' || el.tagName === 'TEXTAREA' || el.tagName === 'SELECT' || isEditable(el); }\nfunction isEditable (el) {\n  if (!el) { return false; } // no parents were editable\n  if (el.contentEditable === 'false') { return false; } // stop the lookup\n  if (el.contentEditable === 'true') { return true; } // found a contentEditable element in the chain\n  return isEditable(getParent(el)); // contentEditable is set to 'inherit'\n}\n\nfunction nextEl (el) {\n  return el.nextElementSibling || manually();\n  function manually () {\n    var sibling = el;\n    do {\n      sibling = sibling.nextSibling;\n    } while (sibling && sibling.nodeType !== 1);\n    return sibling;\n  }\n}\n\n/**\n * Create an animation from position before sorting to present position\n * @param prevRect including element's position infomation before sorting\n * @param target element after sorting\n */\nfunction animate (prevRect, target) {\n  if (!prevRect || !target) {\n    return;\n  }\n  var currentRect = target.getBoundingClientRect();\n  var originProps = {transition: target.style.transition, transform: target.style.transform};\n  Object.assign(target.style, {\n    transition: 'none',\n    transform: 'translate(' + (prevRect.left - currentRect.left) + 'px,' + (prevRect.top - currentRect.top) + 'px)'\n  });\n  target.offsetWidth; // repaint\n  Object.assign(target.style, {transition: 'all ' + animateDuration + 'ms', transform: 'translate(0,0)'});\n  clearTimeout(target.animated);\n  target.animated = setTimeout(function () {\n    Object.assign(target.style, {originProps: originProps});\n    target.animated = false;\n  }, animateDuration);\n}\n\n\nfunction getEventHost (e) {\n  // on touchend event, we have to use `e.changedTouches`\n  // see http://stackoverflow.com/questions/7192563/touchend-event-properties\n  // see https://github.com/bevacqua/dragula/issues/34\n  if (e.targetTouches && e.targetTouches.length) {\n    return e.targetTouches[0];\n  }\n  if (e.changedTouches && e.changedTouches.length) {\n    return e.changedTouches[0];\n  }\n  return e;\n}\n\nfunction getCoord (coord, e) {\n  var host = getEventHost(e);\n  var missMap = {\n    pageX: 'clientX', // IE8\n    pageY: 'clientY' // IE8\n  };\n  if (coord in missMap && !(coord in host) && missMap[coord] in host) {\n    coord = missMap[coord];\n  }\n  return host[coord];\n}\n\nmodule.exports = dragula;\n","module.exports = function atoa (a, n) { return Array.prototype.slice.call(a, n); }\n","'use strict';\n\nvar ticky = require('ticky');\n\nmodule.exports = function debounce (fn, args, ctx) {\n  if (!fn) { return; }\n  ticky(function run () {\n    fn.apply(ctx || null, args || []);\n  });\n};\n","'use strict';\n\nvar atoa = require('atoa');\nvar debounce = require('./debounce');\n\nmodule.exports = function emitter (thing, options) {\n  var opts = options || {};\n  var evt = {};\n  if (thing === undefined) { thing = {}; }\n  thing.on = function (type, fn) {\n    if (!evt[type]) {\n      evt[type] = [fn];\n    } else {\n      evt[type].push(fn);\n    }\n    return thing;\n  };\n  thing.once = function (type, fn) {\n    fn._once = true; // thing.off(fn) still works!\n    thing.on(type, fn);\n    return thing;\n  };\n  thing.off = function (type, fn) {\n    var c = arguments.length;\n    if (c === 1) {\n      delete evt[type];\n    } else if (c === 0) {\n      evt = {};\n    } else {\n      var et = evt[type];\n      if (!et) { return thing; }\n      et.splice(et.indexOf(fn), 1);\n    }\n    return thing;\n  };\n  thing.emit = function () {\n    var args = atoa(arguments);\n    return thing.emitterSnapshot(args.shift()).apply(this, args);\n  };\n  thing.emitterSnapshot = function (type) {\n    var et = (evt[type] || []).slice(0);\n    return function () {\n      var args = atoa(arguments);\n      var ctx = this || thing;\n      if (type === 'error' && opts.throws !== false && !et.length) { throw args.length === 1 ? args[0] : args; }\n      et.forEach(function emitter (listen) {\n        if (opts.async) { debounce(listen, args, ctx); } else { listen.apply(ctx, args); }\n        if (listen._once) { thing.off(type, listen); }\n      });\n      return thing;\n    };\n  };\n  return thing;\n};\n","'use strict';\n\nvar customEvent = require('custom-event');\nvar eventmap = require('./eventmap');\nvar doc = global.document;\nvar addEvent = addEventEasy;\nvar removeEvent = removeEventEasy;\nvar hardCache = [];\n\nif (!global.addEventListener) {\n  addEvent = addEventHard;\n  removeEvent = removeEventHard;\n}\n\nmodule.exports = {\n  add: addEvent,\n  remove: removeEvent,\n  fabricate: fabricateEvent\n};\n\nfunction addEventEasy (el, type, fn, capturing) {\n  return el.addEventListener(type, fn, capturing);\n}\n\nfunction addEventHard (el, type, fn) {\n  return el.attachEvent('on' + type, wrap(el, type, fn));\n}\n\nfunction removeEventEasy (el, type, fn, capturing) {\n  return el.removeEventListener(type, fn, capturing);\n}\n\nfunction removeEventHard (el, type, fn) {\n  var listener = unwrap(el, type, fn);\n  if (listener) {\n    return el.detachEvent('on' + type, listener);\n  }\n}\n\nfunction fabricateEvent (el, type, model) {\n  var e = eventmap.indexOf(type) === -1 ? makeCustomEvent() : makeClassicEvent();\n  if (el.dispatchEvent) {\n    el.dispatchEvent(e);\n  } else {\n    el.fireEvent('on' + type, e);\n  }\n  function makeClassicEvent () {\n    var e;\n    if (doc.createEvent) {\n      e = doc.createEvent('Event');\n      e.initEvent(type, true, true);\n    } else if (doc.createEventObject) {\n      e = doc.createEventObject();\n    }\n    return e;\n  }\n  function makeCustomEvent () {\n    return new customEvent(type, { detail: model });\n  }\n}\n\nfunction wrapperFactory (el, type, fn) {\n  return function wrapper (originalEvent) {\n    var e = originalEvent || global.event;\n    e.target = e.target || e.srcElement;\n    e.preventDefault = e.preventDefault || function preventDefault () { e.returnValue = false; };\n    e.stopPropagation = e.stopPropagation || function stopPropagation () { e.cancelBubble = true; };\n    e.which = e.which || e.keyCode;\n    fn.call(el, e);\n  };\n}\n\nfunction wrap (el, type, fn) {\n  var wrapper = unwrap(el, type, fn) || wrapperFactory(el, type, fn);\n  hardCache.push({\n    wrapper: wrapper,\n    element: el,\n    type: type,\n    fn: fn\n  });\n  return wrapper;\n}\n\nfunction unwrap (el, type, fn) {\n  var i = find(el, type, fn);\n  if (i) {\n    var wrapper = hardCache[i].wrapper;\n    hardCache.splice(i, 1); // free up a tad of memory\n    return wrapper;\n  }\n}\n\nfunction find (el, type, fn) {\n  var i, item;\n  for (i = 0; i < hardCache.length; i++) {\n    item = hardCache[i];\n    if (item.element === el && item.type === type && item.fn === fn) {\n      return i;\n    }\n  }\n}\n","'use strict';\n\nvar eventmap = [];\nvar eventname = '';\nvar ron = /^on/;\n\nfor (eventname in global) {\n  if (ron.test(eventname)) {\n    eventmap.push(eventname.slice(2));\n  }\n}\n\nmodule.exports = eventmap;\n","\nvar NativeCustomEvent = global.CustomEvent;\n\nfunction useNative () {\n  try {\n    var p = new NativeCustomEvent('cat', { detail: { foo: 'bar' } });\n    return  'cat' === p.type && 'bar' === p.detail.foo;\n  } catch (e) {\n  }\n  return false;\n}\n\n/**\n * Cross-browser `CustomEvent` constructor.\n *\n * https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent.CustomEvent\n *\n * @public\n */\n\nmodule.exports = useNative() ? NativeCustomEvent :\n\n// IE >= 9\n'function' === typeof document.createEvent ? function CustomEvent (type, params) {\n  var e = document.createEvent('CustomEvent');\n  if (params) {\n    e.initCustomEvent(type, params.bubbles, params.cancelable, params.detail);\n  } else {\n    e.initCustomEvent(type, false, false, void 0);\n  }\n  return e;\n} :\n\n// IE <= 8\nfunction CustomEvent (type, params) {\n  var e = document.createEventObject();\n  e.type = type;\n  if (params) {\n    e.bubbles = Boolean(params.bubbles);\n    e.cancelable = Boolean(params.cancelable);\n    e.detail = params.detail;\n  } else {\n    e.bubbles = false;\n    e.cancelable = false;\n    e.detail = void 0;\n  }\n  return e;\n}\n","var si = typeof setImmediate === 'function', tick;\nif (si) {\n  tick = function (fn) { setImmediate(fn); };\n} else {\n  tick = function (fn) { setTimeout(fn, 0); };\n}\n\nmodule.exports = tick;"]}