[Libreoffice-commits] online.git: loleaflet/src
Pranav Kant
pranavk at collabora.co.uk
Wed Apr 19 13:45:58 UTC 2017
loleaflet/src/layer/AnnotationManager.js | 15 ++++++++++++---
loleaflet/src/map/Map.js | 2 ++
2 files changed, 14 insertions(+), 3 deletions(-)
New commits:
commit 4a8caa40e88561cfeb046c83da29b144c287016b
Author: Pranav Kant <pranavk at collabora.co.uk>
Date: Wed Apr 19 19:13:25 2017 +0530
loleaflet: Select and deselect comment upon mouse click
Make comment overlays clickable and when clicked select the
corresponding annotation. Also deselect when clicked where there is no
comment overlay.
Change-Id: Id9236862eec86b7508978ad8fe803455e03adbe2
diff --git a/loleaflet/src/layer/AnnotationManager.js b/loleaflet/src/layer/AnnotationManager.js
index d29b2d46..b3f2d74c 100644
--- a/loleaflet/src/layer/AnnotationManager.js
+++ b/loleaflet/src/layer/AnnotationManager.js
@@ -47,20 +47,23 @@ L.AnnotationManager = L.Class.extend({
adjustComment: function(comment) {
var rectangles, color, viewId;
+ comment.trackchange = false;
+ rectangles = L.PolyUtil.rectanglesToPolygons(L.LOUtil.stringToRectangles(comment.textRange || comment.anchorPos), this._map._docLayer);
comment.anchorPos = L.LOUtil.stringToBounds(comment.anchorPos);
comment.anchorPix = this._map._docLayer._twipsToPixels(comment.anchorPos.min);
- comment.trackchange = false;
- rectangles = L.PolyUtil.rectanglesToPolygons(L.LOUtil.stringToRectangles(comment.textRange), this._map._docLayer);
viewId = this._map.getViewId(comment.author);
color = viewId >= 0 ? L.LOUtil.rgbToHex(this._map.getViewColor(viewId)) : '#43ACE8';
if (rectangles.length > 0) {
comment.textSelected = L.polygon(rectangles, {
- pointerEvents: 'none',
+ interactive: true,
fillColor: color,
fillOpacity: 0.25,
weight: 2,
opacity: 0.25
});
+ comment.textSelected.on('click', function() {
+ this.selectById(comment.id);
+ }, this);
}
},
@@ -178,6 +181,12 @@ L.AnnotationManager = L.Class.extend({
}
},
+ selectById: function(commentId) {
+ var idx = this.getRootIndexOf(commentId);
+ this._selected = this._items[idx];
+ this.update();
+ },
+
update: function () {
if (this._selected) {
var point0, point1, point2;
diff --git a/loleaflet/src/map/Map.js b/loleaflet/src/map/Map.js
index c76d4393..af9f7233 100644
--- a/loleaflet/src/map/Map.js
+++ b/loleaflet/src/map/Map.js
@@ -979,6 +979,8 @@ L.Map = L.Evented.extend({
if (type === 'click' && this._permission === 'edit') {
this._textArea.blur();
this._textArea.focus();
+ if (this._docLayer && this._docLayer._annotations && this._docLayer._annotations.unselect)
+ this._docLayer._annotations.unselect();
}
// we need to keep track if we have entered/left the map
More information about the Libreoffice-commits
mailing list