aboutsummaryrefslogtreecommitdiff
path: root/p/scripts/category.js
diff options
context:
space:
mode:
authorGravatar Clément <clement@selfhost.fr> 2017-02-15 14:14:03 +0100
committerGravatar Clément <clement@selfhost.fr> 2017-02-15 14:14:03 +0100
commit5a1bb1393b4496eb35a2ffb3cc63d41c9dc1e2e5 (patch)
tree67028e45792c575c25c92616633f64cc7a4a13eb /p/scripts/category.js
parent7e949d50320317b5c3b5a2da2bdaf324e794b2f7 (diff)
parent5f637bd816b7323885bfe1751a1724ee59a822f6 (diff)
Merge remote-tracking branch 'FreshRSS/master'
Diffstat (limited to 'p/scripts/category.js')
-rw-r--r--p/scripts/category.js125
1 files changed, 125 insertions, 0 deletions
diff --git a/p/scripts/category.js b/p/scripts/category.js
new file mode 100644
index 000000000..fbcd83a01
--- /dev/null
+++ b/p/scripts/category.js
@@ -0,0 +1,125 @@
+"use strict";
+/* globals i18n */
+/* jshint globalstrict: true */
+
+var loading = false,
+ dnd_successful = false;
+
+function dragend_process(t) {
+ t.setAttribute('draggable', 'false');
+
+ if (loading) {
+ window.setTimeout(function() {
+ dragend_process(t);
+ }, 50);
+ return;
+ }
+
+ if (!dnd_successful) {
+ t.style.display = '';
+ t.style.opacity = '';
+ t.setAttribute('draggable', 'true');
+ } else {
+ var parent = $(t.parentNode);
+ $(t).remove();
+
+ if (parent.children().length <= 0) {
+ parent.append('<li class="item disabled" dropzone="move">' + i18n.category_empty + '</li>');
+ }
+ }
+}
+
+var dragFeedId = '',
+ dragHtml = '';
+
+function init_draggable() {
+ if (!(window.$ && window.i18n)) {
+ if (window.console) {
+ console.log('FreshRSS waiting for JS…');
+ }
+ window.setTimeout(init_draggable, 50);
+ return;
+ }
+
+ var draggable = '[draggable="true"]',
+ dropzone = '[dropzone="move"]';
+
+ $('.drop-section').on('dragstart', draggable, function(e) {
+ var drag = $(e.target).closest('[draggable]')[0];
+ e.originalEvent.dataTransfer.effectAllowed = 'move';
+ dragHtml = drag.outerHTML;
+ dragFeedId = drag.getAttribute('data-feed-id');
+ e.originalEvent.dataTransfer.setData('text', dragFeedId);
+ drag.style.opacity = 0.3;
+
+ dnd_successful = false;
+ });
+ $('.drop-section').on('dragend', draggable, function(e) {
+ dragend_process(e.target);
+ });
+
+ $('.drop-section').on('dragenter', dropzone, function(e) {
+ $(this).addClass('drag-hover');
+
+ e.preventDefault();
+ });
+ $('.drop-section').on('dragleave', dropzone, function(e) {
+ var pos_this = $(this).position(),
+ scroll_top = $(document).scrollTop(),
+ top = pos_this.top,
+ left = pos_this.left,
+ right = left + $(this).width(),
+ bottom = top + $(this).height(),
+ mouse_x = e.originalEvent.screenX,
+ mouse_y = e.originalEvent.clientY + scroll_top;
+
+ if (left <= mouse_x && mouse_x <= right &&
+ top <= mouse_y && mouse_y <= bottom) {
+ // HACK because dragleave is triggered when hovering children!
+ return;
+ }
+ $(this).removeClass('drag-hover');
+ });
+ $('.drop-section').on('dragover', dropzone, function(e) {
+ e.originalEvent.dataTransfer.dropEffect = "move";
+
+ e.preventDefault();
+ return false;
+ });
+ $('.drop-section').on('drop', dropzone, function(e) {
+ loading = true;
+
+ $.ajax({
+ type: 'POST',
+ url: './?c=feed&a=move',
+ data : {
+ f_id: dragFeedId,
+ c_id: e.target.parentNode.getAttribute('data-cat-id'),
+ _csrf: context.csrf,
+ }
+ }).done(function() {
+ $(e.target).after(dragHtml);
+ if ($(e.target).hasClass('disabled')) {
+ $(e.target).remove();
+ }
+ dnd_successful = true;
+ }).always(function() {
+ loading = false;
+ dragFeedId = '';
+ dragHtml = '';
+ });
+
+ $(this).removeClass('drag-hover');
+
+ e.preventDefault();
+ });
+}
+
+
+if (document.readyState && document.readyState !== 'loading') {
+ init_draggable();
+} else if (document.addEventListener) {
+ document.addEventListener('DOMContentLoaded', function () {
+ init_draggable();
+ }, false);
+}