[Libreoffice-commits] online.git: loleaflet/src
Marco Cecchetti
marco.cecchetti at collabora.com
Tue May 16 11:21:06 UTC 2017
loleaflet/src/layer/tile/CalcTileLayer.js | 36 ++++++++++++++++++++++--------
1 file changed, 27 insertions(+), 9 deletions(-)
New commits:
commit 647556b442f037ca71b4cc4efd871c559b748a53
Author: Marco Cecchetti <marco.cecchetti at collabora.com>
Date: Tue Apr 25 18:57:30 2017 +0200
loleaflet: misplaced comment mark on inserting/deleting/resizing row/col
Change-Id: Ib95870905d1bfc613ba454c7126501b3533e4ba5
Reviewed-on: https://gerrit.libreoffice.org/36982
Reviewed-by: Jan Holesovsky <kendy at collabora.com>
Tested-by: Jan Holesovsky <kendy at collabora.com>
diff --git a/loleaflet/src/layer/tile/CalcTileLayer.js b/loleaflet/src/layer/tile/CalcTileLayer.js
index c154d7a4..cb82396d 100644
--- a/loleaflet/src/layer/tile/CalcTileLayer.js
+++ b/loleaflet/src/layer/tile/CalcTileLayer.js
@@ -13,7 +13,7 @@ L.CalcTileLayer = L.TileLayer.extend({
},
newAnnotation: function (comment) {
- var annotations = this._annotations[this._partNames[this._selectedPart]];
+ var annotations = this._annotations[this._selectedPart];
var annotation;
for (var key in annotations) {
if (this._cellCursor.contains(annotations[key]._annotation._data.cellPos)) {
@@ -72,7 +72,7 @@ L.CalcTileLayer = L.TileLayer.extend({
value: id
}
};
- var tab = id.substring(0, id.indexOf('.'));
+ var tab = this._selectedPart;
this._map.sendUnoCommand('.uno:DeleteNote', comment);
this._annotations[tab][id].closePopup();
this._map.focus();
@@ -92,14 +92,15 @@ L.CalcTileLayer = L.TileLayer.extend({
},
showAnnotations: function () {
- var annotations = this._annotations[this._partNames[this._selectedPart]];
+ var annotations = this._annotations[this._selectedPart];
for (var key in annotations) {
this.showAnnotation(annotations[key]);
}
},
hideAnnotations: function (part) {
- var annotations = this._annotations[this._partNames[part]];
+
+ var annotations = this._annotations[part];
for (var key in annotations) {
this.hideAnnotation(annotations[key]);
}
@@ -175,7 +176,7 @@ L.CalcTileLayer = L.TileLayer.extend({
_onMessage: function (textMsg, img) {
if (textMsg.startsWith('comment:')) {
var obj = JSON.parse(textMsg.substring('comment:'.length + 1));
- obj.comment.tab = obj.comment.id.substring(0, obj.comment.id.indexOf('.'));
+ obj.comment.tab = parseInt(obj.comment.tab);
if (obj.comment.action === 'Add') {
obj.comment.cellPos = L.LOUtil.stringToBounds(obj.comment.cellPos);
obj.comment.cellPos = L.latLngBounds(this._twipsToLatLng(obj.comment.cellPos.getBottomLeft()),
@@ -184,7 +185,7 @@ L.CalcTileLayer = L.TileLayer.extend({
this._annotations[obj.comment.tab] = {};
}
this._annotations[obj.comment.tab][obj.comment.id] = this.createAnnotation(obj.comment);
- if (obj.comment.tab === this._partNames[this._selectedPart]) {
+ if (obj.comment.tab === this._selectedPart) {
this.showAnnotation(this._annotations[obj.comment.tab][obj.comment.id]);
}
} else if (obj.comment.action === 'Remove') {
@@ -205,8 +206,10 @@ L.CalcTileLayer = L.TileLayer.extend({
}
} else if (textMsg.startsWith('invalidateheader: column')) {
this._map.fire('updaterowcolumnheaders', {x: this._map._getTopLeftPoint().x, y: 0, offset: {x: undefined, y: 0}});
+ this._map._socket.sendMessage('commandvalues command=.uno:ViewAnnotationsPosition');
} else if (textMsg.startsWith('invalidateheader: row')) {
this._map.fire('updaterowcolumnheaders', {x: 0, y: this._map._getTopLeftPoint().y, offset: {x: 0, y: undefined}});
+ this._map._socket.sendMessage('commandvalues command=.uno:ViewAnnotationsPosition');
} else {
L.TileLayer.prototype._onMessage.call(this, textMsg, img);
}
@@ -436,7 +439,7 @@ L.CalcTileLayer = L.TileLayer.extend({
this.clearAnnotations();
for (var index in values.comments) {
comment = values.comments[index];
- comment.tab = comment.id.substring(0, comment.id.indexOf('.'));
+ comment.tab = parseInt(comment.tab);
comment.cellPos = L.LOUtil.stringToBounds(comment.cellPos);
comment.cellPos = L.latLngBounds(this._twipsToLatLng(comment.cellPos.getBottomLeft()),
this._twipsToLatLng(comment.cellPos.getTopRight()));
@@ -446,8 +449,23 @@ L.CalcTileLayer = L.TileLayer.extend({
this._annotations[comment.tab][comment.id] = this.createAnnotation(comment);
}
this.showAnnotations();
- }
- else {
+ } else if (values.commentsPos) {
+ var comment;
+ this.hideAnnotations();
+ for (var index in values.commentsPos) {
+ comment = values.commentsPos[index];
+ comment.tab = parseInt(comment.tab);
+ comment.cellPos = L.LOUtil.stringToBounds(comment.cellPos);
+ comment.cellPos = L.latLngBounds(this._twipsToLatLng(comment.cellPos.getBottomLeft()),
+ this._twipsToLatLng(comment.cellPos.getTopRight()));
+ var annotation = this._annotations[comment.tab][comment.id];
+ if (annotation) {
+ annotation.setLatLngBounds(comment.cellPos);
+ annotation.mark.setLatLng(comment.cellPos.getNorthEast());
+ }
+ }
+ this.showAnnotations();
+ } else {
L.TileLayer.prototype._onCommandValuesMsg.call(this, textMsg);
}
},
More information about the Libreoffice-commits
mailing list