aboutsummaryrefslogtreecommitdiff
path: root/p/scripts/category.js
blob: 4378aa9cdb1166e8cdce91e96ba004a43d3651a6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
"use strict";


function init_draggable() {
	$.event.props.push('dataTransfer');

	var feeds_draggable = '.box-content > .feed',
	    box_dropzone = '.box-content';

	$('.box').on('dragstart', feeds_draggable, function(e) {
		e.dataTransfer.effectAllowed = 'move';
		e.dataTransfer.setData('html', e.target.outerHTML);
		e.dataTransfer.setData('feed-id', e.target.getAttribute('data-feed-id'));
	});
	$('.box').on('dragend', feeds_draggable, function(e) {
		var parent = e.target.parentNode;
		parent.removeChild(e.target);
		
	});

	$('.box').on('dragenter', box_dropzone, function(e) {
		$(e.target).addClass('drag-hover');
	});
	$('.box').on('dragleave', box_dropzone, function(e) {
		$(e.target).removeClass('drag-hover');
	});
	$('.box').on('dragover', box_dropzone, function(e) {
		e.dataTransfer.dropEffect = "move";

		return false;
	});
	$('.box').on('drop', box_dropzone, function(e) {
		var feed_id = e.dataTransfer.getData('feed-id'),
		    cat_id = e.target.parentNode.getAttribute('data-cat-id');

		$.ajax({
			type: 'POST',
			url: './?c=feed&a=move',
			data : {
				f_id: feed_id,
				c_id: cat_id
			}
		});

		$(e.target).after(e.dataTransfer.getData('html'));
		$(e.target).removeClass('drag-hover');
		return false;
	});
}


if (document.readyState && document.readyState !== 'loading') {
	init_draggable();
} else if (document.addEventListener) {
	document.addEventListener('DOMContentLoaded', function () {
		init_draggable();
	}, false);
}