[Libreoffice-commits] online.git: bundled/include kit/ChildSession.cpp kit/KitHelper.hpp loleaflet/dist loleaflet/src tools/KitClient.cpp

Marco Cecchetti marco.cecchetti at collabora.com
Tue Apr 3 19:42:45 UTC 2018


 bundled/include/LibreOfficeKit/LibreOfficeKitEnums.h |   11 ++-
 kit/ChildSession.cpp                                 |    3 
 kit/KitHelper.hpp                                    |    2 
 loleaflet/dist/images/drop-down-button.svg           |    4 +
 loleaflet/dist/spreadsheet.css                       |   10 ++
 loleaflet/src/layer/marker/Icon.js                   |   15 ++--
 loleaflet/src/layer/tile/TileLayer.js                |   66 +++++++++++++++++++
 tools/KitClient.cpp                                  |    1 
 8 files changed, 105 insertions(+), 7 deletions(-)

New commits:
commit 89f37b5dd52882674c4e5f2339d365cfe338543d
Author: Marco Cecchetti <marco.cecchetti at collabora.com>
Date:   Mon Mar 19 14:08:10 2018 +0100

    calc: drop down button marker
    
    Change-Id: Ic069ad40e6749f43709760e7f4f0d96b39d5a4ce
    Reviewed-on: https://gerrit.libreoffice.org/51598
    Reviewed-by: Marco Cecchetti <mrcekets at gmail.com>
    Tested-by: Marco Cecchetti <mrcekets at gmail.com>

diff --git a/bundled/include/LibreOfficeKit/LibreOfficeKitEnums.h b/bundled/include/LibreOfficeKit/LibreOfficeKitEnums.h
index 020bbff90..300d91e1c 100644
--- a/bundled/include/LibreOfficeKit/LibreOfficeKitEnums.h
+++ b/bundled/include/LibreOfficeKit/LibreOfficeKitEnums.h
@@ -570,6 +570,15 @@ typedef enum
     LOK_CALLBACK_WINDOW = 36,
 
     /**
+     * When for the current cell is defined a validity list we need to show
+     * a drop down button in the form of a marker.
+     *
+     * The payload format is: "x, y, visible" where x, y are the current
+     * cell cursor coordinates and visible is set to 0 or 1.
+     */
+    LOK_CALLBACK_VALIDITY_LIST_BUTTON = 37,
+
+    /**
      * Notification that the clipboard contents have changed.
      * Typically fired in response to copying to clipboard.
      *
@@ -578,7 +587,7 @@ typedef enum
      * in the future the contents might be included for
      * convenience.
      */
-    LOK_CALLBACK_CLIPBOARD_CHANGED = 37,
+    LOK_CALLBACK_CLIPBOARD_CHANGED = 38,
 }
 LibreOfficeKitCallbackType;
 
diff --git a/kit/ChildSession.cpp b/kit/ChildSession.cpp
index 710c079b5..04ec7d93f 100644
--- a/kit/ChildSession.cpp
+++ b/kit/ChildSession.cpp
@@ -1548,6 +1548,9 @@ void ChildSession::loKitCallback(const int type, const std::string& payload)
     case LOK_CALLBACK_WINDOW:
         sendTextFrame("window: " + payload);
         break;
+    case LOK_CALLBACK_VALIDITY_LIST_BUTTON:
+        sendTextFrame("validitylistbutton: " + payload);
+        break;
     default:
         LOG_ERR("Unknown callback event (" << type << "): " << payload);
     }
diff --git a/kit/KitHelper.hpp b/kit/KitHelper.hpp
index 6dd1a0f41..bc4e2350e 100644
--- a/kit/KitHelper.hpp
+++ b/kit/KitHelper.hpp
@@ -117,6 +117,8 @@ namespace LOKitHelper
             return "CELL_ADDRESS";
         case LOK_CALLBACK_WINDOW:
             return "WINDOW";
+        case LOK_CALLBACK_VALIDITY_LIST_BUTTON:
+            return "VALIDITY_LIST_BUTTON";
        }
 
         return std::to_string(type);
diff --git a/loleaflet/dist/images/drop-down-button.svg b/loleaflet/dist/images/drop-down-button.svg
new file mode 100644
index 000000000..f17c44443
--- /dev/null
+++ b/loleaflet/dist/images/drop-down-button.svg
@@ -0,0 +1,4 @@
+<svg xmlns="http://www.w3.org/2000/svg" width="11px" height="11px">
+  <path style="fill:#2d2d2d" d="m 2.5011982,3.0013922 5.9508648,0 -2.8796134,5.9972113 z" />
+  <path style="fill:#2d2d2d;fill-rule:evenodd;" d="M 0,0 11,0 11,11 0,11 Z m 1,1 9,0 0,9 -9,0 z"/>
+</svg>
diff --git a/loleaflet/dist/spreadsheet.css b/loleaflet/dist/spreadsheet.css
index ed5086321..01f0b0bd2 100644
--- a/loleaflet/dist/spreadsheet.css
+++ b/loleaflet/dist/spreadsheet.css
@@ -190,3 +190,13 @@
 .spreadsheet-header-row-resize {
 	cursor: row-resize;
 	}
+
+.spreadsheet-drop-down-marker {
+	margin-left: 0px;
+	margin-top: 0px;
+	width: 18px;
+	height: 17px;
+	background-image: url('../images/drop-down-button.svg');
+	background-size: 100% 100%;
+	background-repeat: no-repeat;
+	}
diff --git a/loleaflet/src/layer/marker/Icon.js b/loleaflet/src/layer/marker/Icon.js
index 58d5fd3c1..856995b23 100644
--- a/loleaflet/src/layer/marker/Icon.js
+++ b/loleaflet/src/layer/marker/Icon.js
@@ -47,10 +47,10 @@ L.Icon = L.Class.extend({
 	},
 
 	_setIconStyles: function (img, name) {
-		var options = this.options,
-		    size = L.point(options[name + 'Size']),
-		    anchor = L.point(name === 'shadow' && options.shadowAnchor || options.iconAnchor ||
-		            size && size.divideBy(2, true));
+		var options = this.options;
+		var size = L.point(options[name + 'Size']);
+		var anchor = L.point(name === 'shadow' && options.shadowAnchor || options.iconAnchor ||
+		            size && size.x !== undefined && size.y !== undefined && size.divideBy(2, true));
 
 		img.className = 'leaflet-marker-' + name + ' ' + (options.className || '');
 
@@ -60,9 +60,12 @@ L.Icon = L.Class.extend({
 		}
 
 		if (size) {
-			img.style.width  = size.x + 'px';
-			img.style.height = size.y + 'px';
+			if (size.x !== undefined)
+				img.style.width  = size.x + 'px';
+			if (size.y !== undefined)
+				img.style.height = size.y + 'px';
 		}
+
 	},
 
 	_createImg: function (src, el) {
diff --git a/loleaflet/src/layer/tile/TileLayer.js b/loleaflet/src/layer/tile/TileLayer.js
index 59ce81d2c..cc8fe0071 100644
--- a/loleaflet/src/layer/tile/TileLayer.js
+++ b/loleaflet/src/layer/tile/TileLayer.js
@@ -145,6 +145,14 @@ L.TileLayer = L.GridLayer.extend({
 			});
 		}, this));
 
+		this._dropDownButton = L.marker(new L.LatLng(0, 0), {
+			icon: L.divIcon({
+				className: 'spreadsheet-drop-down-marker',
+				iconSize: null
+			}),
+			interactive: false
+		});
+
 		this._emptyTilesCount = 0;
 		this._msgQueue = [];
 		this._toolbarCommandValues = {};
@@ -488,6 +496,9 @@ L.TileLayer = L.GridLayer.extend({
 		else if (textMsg.startsWith('editor:')) {
 			this._updateEditor(textMsg);
 		}
+		else if (textMsg.startsWith('validitylistbutton:')) {
+			this._onValidityListButtonMsg(textMsg);
+		}
 	},
 
 	toggleTileDebugMode: function() {
@@ -1828,6 +1839,7 @@ L.TileLayer = L.GridLayer.extend({
 
 			if (this._cellCursorMarker) {
 				this._map.removeLayer(this._cellCursorMarker);
+				this._map.removeLayer(this._dropDownButton);
 			}
 			this._cellCursorMarker = L.rectangle(this._cellCursor, {
 				pointerEvents: 'none',
@@ -1839,10 +1851,64 @@ L.TileLayer = L.GridLayer.extend({
 				return;
 			}
 			this._map.addLayer(this._cellCursorMarker);
+
+			this._addDropDownMarker();
 		}
 		else if (this._cellCursorMarker) {
 			this._map.removeLayer(this._cellCursorMarker);
 		}
+		this._removeDropDownMarker();
+	},
+
+	_onValidityListButtonMsg: function(textMsg) {
+		var strXY = textMsg.match(/\d+/g);
+		var validatedCell = new L.Point(parseInt(strXY[0]), parseInt(strXY[1]));
+		var show = parseInt(strXY[2]) === 1;
+		if (show) {
+			if (this._validatedCellXY && !this._validatedCellXY.equals(validatedCell)) {
+				this._validatedCellXY = null;
+				this._removeDropDownMarker();
+			}
+			this._validatedCellXY = validatedCell;
+			this._addDropDownMarker();
+		}
+		else if (this._validatedCellXY && this._validatedCellXY.equals(validatedCell)) {
+			this._validatedCellXY = null;
+			this._removeDropDownMarker();
+		}
+	},
+
+	_addDropDownMarker: function () {
+		if (this._validatedCellXY && this._cellCursorXY && this._validatedCellXY.equals(this._cellCursorXY)) {
+			var pos = this._cellCursor.getNorthEast();
+			var cellCursorHeightPx = this._twipsToPixels(this._cellCursorTwips.getSize()).y;
+			var dropDownMarker = this._getDropDownMarker(cellCursorHeightPx);
+			dropDownMarker.setLatLng(pos);
+			this._map.addLayer(dropDownMarker);
+		}
+	},
+
+	_removeDropDownMarker: function () {
+		if (!this._validatedCellXY && this._dropDownButton)
+			this._map.removeLayer(this._dropDownButton);
+	},
+
+	_getDropDownMarker: function (height) {
+		if (height) {
+			var maxHeight = 27; // it matches the max height of the same control in core
+			var topMargin = 0;
+			if (height > maxHeight) {
+				topMargin = height - maxHeight;
+				height = maxHeight;
+			}
+			var icon =  L.divIcon({
+				className: 'spreadsheet-drop-down-marker',
+				iconSize: [undefined, height],
+				iconAnchor: [0, -topMargin]
+			});
+			this._dropDownButton.setIcon(icon);
+		}
+		return this._dropDownButton;
 	},
 
 	// Update text selection handlers.
diff --git a/tools/KitClient.cpp b/tools/KitClient.cpp
index c2261223b..bc756b1d7 100644
--- a/tools/KitClient.cpp
+++ b/tools/KitClient.cpp
@@ -80,6 +80,7 @@ extern "C"
             CASE(CELL_ADDRESS);
             CASE(RULER_UPDATE);
             CASE(WINDOW);
+            CASE(VALIDITY_LIST_BUTTON);
             CASE(CLIPBOARD_CHANGED);
 #undef CASE
         }


More information about the Libreoffice-commits mailing list