From 8eab177eed8568e9e14fcf8c02b436543fd887ee Mon Sep 17 00:00:00 2001 From: David Manthey Date: Mon, 4 Apr 2022 14:58:32 -0400 Subject: [PATCH] Fix a range check. Move some repeated code outside of a function loop. Ensure the annotation layer remains on top. --- .../web_client/views/imageViewerWidget/geojs.js | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/girder_annotation/girder_large_image_annotation/web_client/views/imageViewerWidget/geojs.js b/girder_annotation/girder_large_image_annotation/web_client/views/imageViewerWidget/geojs.js index d50817afa..5adc4dbf5 100644 --- a/girder_annotation/girder_large_image_annotation/web_client/views/imageViewerWidget/geojs.js +++ b/girder_annotation/girder_large_image_annotation/web_client/views/imageViewerWidget/geojs.js @@ -147,11 +147,11 @@ var GeojsImageViewerWidgetExtension = function (viewer) { pixelmapData = valuesWithBoundaries; } layerParams.data = pixelmapData; + const categoryMap = pixelmapElement.categories; + const boundaries = pixelmapElement.boundaries; layerParams.style = { color: (d, i) => { - const categoryMap = pixelmapElement.categories; - const boundaries = pixelmapElement.boundaries; - if (d < 0 || d > categoryMap.length) { + if (d < 0 || d >= categoryMap.length) { console.warn(`No category found at index ${d} in the category map.`); return 'rgba(0, 0, 0, 0)'; } @@ -390,11 +390,9 @@ var GeojsImageViewerWidgetExtension = function (viewer) { } const params = this._generateOverlayLayerParams(response, overlayItemId, overlay); const layerType = (overlay.type === 'pixelmap') ? 'pixelmap' : 'osm'; - const overlayLayer = this.viewer.createLayer(layerType, params); const proj = this._getOverlayTransformProjString(overlay); - - overlayLayer.id(overlay.id); - overlayLayer.gcs(proj); + const overlayLayer = this.viewer.createLayer(layerType, Object.assign({}, params, {id: overlay.id, gcs: proj})); + this.annotationLayer.moveToTop(); this.trigger('g:drawOverlayAnnotation', overlay, overlayLayer); const featureEvents = geo.event.feature; overlayLayer.geoOn(