category.js 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. "use strict";
  2. var loading = false,
  3. dnd_successful = false;
  4. function dragend_process(t) {
  5. if (loading) {
  6. window.setTimeout(function() {
  7. dragend_process(t);
  8. }, 50);
  9. }
  10. if (!dnd_successful) {
  11. t.style.opacity = 1.0;
  12. } else {
  13. t.parentNode.removeChild(t);
  14. }
  15. }
  16. function init_draggable() {
  17. if (!(window.$ && window.url_freshrss)) {
  18. if (window.console) {
  19. console.log('FreshRSS waiting for JS…');
  20. }
  21. window.setTimeout(init_draggable, 50);
  22. return;
  23. }
  24. $.event.props.push('dataTransfer');
  25. var draggable = '[draggable="true"]',
  26. dropzone = '[dropzone="move"]';
  27. $('.drop-section').on('dragstart', draggable, function(e) {
  28. e.dataTransfer.effectAllowed = 'move';
  29. e.dataTransfer.setData('text/html', e.target.outerHTML);
  30. e.dataTransfer.setData('text', e.target.getAttribute('data-feed-id'));
  31. e.target.style.opacity = 0.3;
  32. dnd_successful = false;
  33. });
  34. $('.drop-section').on('dragend', draggable, function(e) {
  35. dragend_process(e.target);
  36. });
  37. $('.drop-section').on('dragenter', dropzone, function(e) {
  38. $(e.target).addClass('drag-hover');
  39. });
  40. $('.drop-section').on('dragleave', dropzone, function(e) {
  41. $(e.target).removeClass('drag-hover');
  42. });
  43. $('.drop-section').on('dragover', dropzone, function(e) {
  44. e.dataTransfer.dropEffect = "move";
  45. return false;
  46. });
  47. $('.drop-section').on('drop', dropzone, function(e) {
  48. var feed_id = e.dataTransfer.getData('text'),
  49. cat_id = e.target.parentNode.getAttribute('data-cat-id');
  50. loading = true;
  51. $.ajax({
  52. type: 'POST',
  53. url: './?c=feed&a=move',
  54. data : {
  55. f_id: feed_id,
  56. c_id: cat_id
  57. }
  58. }).success(function() {
  59. $(e.target).after(e.dataTransfer.getData('text/html'));
  60. loading = false;
  61. }).complete(function() {
  62. dnd_successful = true;
  63. });
  64. $(e.target).removeClass('drag-hover');
  65. return false;
  66. });
  67. }
  68. if (document.readyState && document.readyState !== 'loading') {
  69. init_draggable();
  70. } else if (document.addEventListener) {
  71. document.addEventListener('DOMContentLoaded', function () {
  72. init_draggable();
  73. }, false);
  74. }