summaryrefslogtreecommitdiff
path: root/program
diff options
context:
space:
mode:
authoralecpl <alec@alec.pl>2009-04-09 19:38:50 +0000
committeralecpl <alec@alec.pl>2009-04-09 19:38:50 +0000
commit432a614ab6e01ea5bd8876a267de67a9ee3fd544 (patch)
tree772062997376953c057a07cfdcf0e6b963bd0206 /program
parentf65a7cb8c384e88cf4b21c74e42a03f53b999e40 (diff)
- Fix drag&drop with scrolling on IE (#1485786)
Diffstat (limited to 'program')
-rw-r--r--program/js/app.js11
-rw-r--r--program/js/list.js2
2 files changed, 11 insertions, 2 deletions
diff --git a/program/js/app.js b/program/js/app.js
index 51cce5df3..7f60de544 100644
--- a/program/js/app.js
+++ b/program/js/app.js
@@ -53,7 +53,6 @@ function rcube_webmail()
this.env.bin_path = './bin/';
this.env.blankpage = 'program/blank.gif';
-
// set environment variable(s)
this.set_env = function(p, value)
{
@@ -1182,6 +1181,9 @@ function rcube_webmail()
this.drag_start = function(list)
{
+ this.initialBodyScrollTop = bw.ie ? 0 : window.pageYOffset;
+ this.initialMailBoxScrollTop = document.getElementById("mailboxlist-container").scrollTop;
+
var model = this.task == 'mail' ? this.env.mailboxes : this.env.address_sources;
this.drag_active = true;
@@ -1213,10 +1215,17 @@ function rcube_webmail()
{
if (this.gui_objects.folderlist && this.env.folder_coords)
{
+ // offsets to compensate for scrolling while dragging a message
+ var boffset = bw.ie ? -document.documentElement.scrollTop : this.initialBodyScrollTop;
+ var moffset = this.initialMailBoxScrollTop-document.getElementById('mailboxlist-container').scrollTop;
+ var toffset = -moffset-boffset;
+
var li, pos, mouse;
mouse = rcube_event.get_mouse_pos(e);
pos = this.env.folderlist_coords;
+ mouse.y += toffset;
+
// if mouse pointer is outside of folderlist
if (mouse.x < pos.x1 || mouse.x >= pos.x2
|| mouse.y < pos.y1 || mouse.y >= pos.y2)
diff --git a/program/js/list.js b/program/js/list.js
index 1fe493ca9..7bae7a5f6 100644
--- a/program/js/list.js
+++ b/program/js/list.js
@@ -774,7 +774,7 @@ drag_mouse_move: function(e)
if (this.drag_active && this.draglayer)
{
var pos = rcube_event.get_mouse_pos(e);
- this.draglayer.move(pos.x+20, pos.y-5);
+ this.draglayer.move(pos.x+20, bw.ie ? pos.y-5+document.documentElement.scrollTop : pos.y-5);
this.trigger_event('dragmove', e);
}