summaryrefslogtreecommitdiffstats
path: root/codebase/sources/ext/dhtmlxscheduler_outerdrag.js
blob: 61c2bc716f95c7627665015d7d78af98f3f30b3a (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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
@license
dhtmlxScheduler v.4.4.0 Stardard

This software is covered by GPL license. You also can obtain Commercial or Enterprise license to use it in non-GPL project - please contact sales@dhtmlx.com. Usage without proper license is prohibited.

(c) Dinamenta, UAB.
*/
// lame old code doesn't provide raw event object
scheduler.attachEvent("onTemplatesReady", function() {
	var dragger = (new dhtmlDragAndDropObject());
	var old = dragger.stopDrag;
	var last_event;
	dragger.stopDrag = function(e) {
		last_event = e || event;
		return old.apply(this, arguments);
	};

	function on_drop(sourceHtmlObject, dhtmlObject, targetHtmlObject, targetHtml) {

		if (scheduler.checkEvent("onBeforeExternalDragIn") && !scheduler.callEvent("onBeforeExternalDragIn", [sourceHtmlObject, dhtmlObject, targetHtmlObject, targetHtml, last_event]))
			return;

		var temp = scheduler.attachEvent("onEventCreated", function (id) {
			if (!scheduler.callEvent("onExternalDragIn", [id, sourceHtmlObject, last_event])) {
				this._drag_mode = this._drag_id = null;
				this.deleteEvent(id);
			}
		});

		var action_data = scheduler.getActionData(last_event);
		var event_data = {
			start_date: new Date(action_data.date)
		};

		// custom views, need to assign section id, fix dates
		if (scheduler.matrix && scheduler.matrix[scheduler._mode]) {
			var view_options = scheduler.matrix[scheduler._mode];
			event_data[view_options.y_property] = action_data.section;

			var pos = scheduler._locate_cell_timeline(last_event);
			event_data.start_date = view_options._trace_x[pos.x];
			event_data.end_date = scheduler.date.add(event_data.start_date, view_options.x_step, view_options.x_unit);
		}
		if (scheduler._props && scheduler._props[scheduler._mode]) {
			event_data[scheduler._props[scheduler._mode].map_to] = action_data.section;
		}

		scheduler.addEventNow(event_data);

		scheduler.detachEvent(temp);
	}

	dragger.addDragLanding(scheduler._els["dhx_cal_data"][0], {
		_drag: function(sourceHtmlObject, dhtmlObject, targetHtmlObject, targetHtml) {
			on_drop(sourceHtmlObject, dhtmlObject, targetHtmlObject, targetHtml);
		},
		_dragIn: function(htmlObject, shtmlObject) {
			return htmlObject;
		},
		_dragOut: function(htmlObject) {
			return this;
		}
	});

	if(dhtmlx.DragControl) {
		dhtmlx.DragControl.addDrop(scheduler._els["dhx_cal_data"][0], {
			onDrop: function (source, target, d, e) {
				var sourceDhtmlx = dhtmlx.DragControl.getMaster(source);
				last_event = e;
				on_drop(source, sourceDhtmlx, target, e.target || e.srcElement);
			},

			onDragIn: function (source, target, e) {
				return target;
			}
		}, true);
	}
});