category.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. "use strict";
  2. function init_draggable() {
  3. $.event.props.push('dataTransfer');
  4. var feeds_draggable = '.box-content > .feed',
  5. box_dropzone = '.box-content';
  6. $('.box').on('dragstart', feeds_draggable, function(e) {
  7. e.dataTransfer.effectAllowed = 'move';
  8. e.dataTransfer.setData('html', e.target.outerHTML);
  9. e.dataTransfer.setData('feed-id', e.target.getAttribute('data-feed-id'));
  10. });
  11. $('.box').on('dragend', feeds_draggable, function(e) {
  12. var parent = e.target.parentNode;
  13. parent.removeChild(e.target);
  14. });
  15. $('.box').on('dragenter', box_dropzone, function(e) {
  16. $(e.target).addClass('drag-hover');
  17. });
  18. $('.box').on('dragleave', box_dropzone, function(e) {
  19. $(e.target).removeClass('drag-hover');
  20. });
  21. $('.box').on('dragover', box_dropzone, function(e) {
  22. e.dataTransfer.dropEffect = "move";
  23. return false;
  24. });
  25. $('.box').on('drop', box_dropzone, function(e) {
  26. var feed_id = e.dataTransfer.getData('feed-id'),
  27. cat_id = e.target.parentNode.getAttribute('data-cat-id');
  28. $.ajax({
  29. type: 'POST',
  30. url: './?c=feed&a=move',
  31. data : {
  32. f_id: feed_id,
  33. c_id: cat_id
  34. }
  35. });
  36. $(e.target).after(e.dataTransfer.getData('html'));
  37. $(e.target).removeClass('drag-hover');
  38. return false;
  39. });
  40. }
  41. if (document.readyState && document.readyState !== 'loading') {
  42. init_draggable();
  43. } else if (document.addEventListener) {
  44. document.addEventListener('DOMContentLoaded', function () {
  45. init_draggable();
  46. }, false);
  47. }