[Libreoffice-commits] online.git: loleaflet/src
Jan Holesovsky
kendy at collabora.com
Wed Apr 11 15:55:25 UTC 2018
loleaflet/src/control/Control.LokDialog.js | 26 +++++++++++++++++++++++---
1 file changed, 23 insertions(+), 3 deletions(-)
New commits:
commit 63ad36e67c8f8435c49f63c05357e647248780e5
Author: Jan Holesovsky <kendy at collabora.com>
Date: Mon Mar 26 23:01:00 2018 +0200
lokdialog: Position the tunneled context menus correctly.
Change-Id: Iae8e6819ffd46cab64bf99ef5c793810949644c4
Reviewed-on: https://gerrit.libreoffice.org/51954
Reviewed-by: pranavk <pranavk at collabora.co.uk>
Tested-by: pranavk <pranavk at collabora.co.uk>
diff --git a/loleaflet/src/control/Control.LokDialog.js b/loleaflet/src/control/Control.LokDialog.js
index 8ffd62e60..743a14c0a 100644
--- a/loleaflet/src/control/Control.LokDialog.js
+++ b/loleaflet/src/control/Control.LokDialog.js
@@ -91,8 +91,12 @@ L.Control.LokDialog = L.Control.extend({
if (e.action === 'created') {
var width = parseInt(e.size.split(',')[0]);
var height = parseInt(e.size.split(',')[1]);
+
if (e.winType === 'dialog') {
- this._launchDialog(this._toDlgPrefix(e.id), width, height, e.title);
+ var left = (e.position != null)? parseInt(e.position.split(',')[0]): null;
+ var top = (e.position != null)? parseInt(e.position.split(',')[1]): null;
+
+ this._launchDialog(this._toDlgPrefix(e.id), left, top, width, height, e.title);
this._sendPaintWindow(e.id, this._createRectStr(e.id));
} else if (e.winType === 'child') {
if (!this._isOpen(e.parentId))
@@ -136,7 +140,7 @@ L.Control.LokDialog = L.Control.extend({
// FIXME: we don't really have to destroy and launch the dialog again but do it for
// now because the size sent to us previously in 'created' cb is not correct
$('#' + strDlgId).remove();
- this._launchDialog(strDlgId, width, height, this._dialogs[parseInt(e.id)].title);
+ this._launchDialog(strDlgId, null, null, width, height, this._dialogs[parseInt(e.id)].title);
this._sendPaintWindow(e.id, this._createRectStr(e.id));
} else if (e.action === 'cursor_invalidate') {
if (this._isOpen(e.id) && !!e.rectangle) {
@@ -225,7 +229,7 @@ L.Control.LokDialog = L.Control.extend({
this._dialogs[dlgId].input.focus();
},
- _launchDialog: function(strDlgId, width, height, title) {
+ _launchDialog: function(strDlgId, leftTwips, topTwips, width, height, title) {
var dialogContainer = L.DomUtil.create('div', 'lokdialog', document.body);
L.DomUtil.setStyle(dialogContainer, 'padding', '0px');
L.DomUtil.setStyle(dialogContainer, 'margin', '0px');
@@ -249,6 +253,22 @@ L.Control.LokDialog = L.Control.extend({
that._onDialogClose(that._toRawDlgId(strDlgId), true);
}
});
+
+ if (leftTwips != null && topTwips != null) {
+ // magic to re-calculate the position in twips to absolute pixel
+ // position inside the #document-container
+ var pixels = this._map._docLayer._twipsToPixels(new L.Point(leftTwips, topTwips));
+ var origin = this._map.getPixelOrigin();
+ var panePos = this._map._getMapPanePos();
+
+ var left = pixels.x + panePos.x - origin.x;
+ var top = pixels.y + panePos.y - origin.y;
+
+ if (left >= 0 && top >= 0) {
+ $(dialogContainer).dialog('option', 'position', { my: 'left top', at: 'left+' + left + ' top+' + top, of: '#document-container' });
+ }
+ }
+
// don't show the dialog surround until we have the dialog content
$(dialogContainer).parent().hide();
More information about the Libreoffice-commits
mailing list