diff --git a/src/lib/viewers/image/ImageBaseViewer.js b/src/lib/viewers/image/ImageBaseViewer.js index 5100f8aeb..380fc99f3 100644 --- a/src/lib/viewers/image/ImageBaseViewer.js +++ b/src/lib/viewers/image/ImageBaseViewer.js @@ -373,10 +373,12 @@ class ImageBaseViewer extends BaseViewer { if (!this.isPannable && this.isZoomable) { // If the mouse up was not due to panning, and the image is zoomable, then zoom in. this.zoom('in'); + this.emitMetric('zoom', 'inClick'); } else if (!this.didPan) { // If the mouse up was not due to ending of panning, then assume it was a regular // click mouse up. In that case reset the image size, mimicking single-click-unzoom. this.zoom('reset'); + this.emitMetric('zoom', 'resetClick'); } } } diff --git a/src/lib/viewers/image/__tests__/ImageBaseViewer-test.js b/src/lib/viewers/image/__tests__/ImageBaseViewer-test.js index 07847bd01..64aba2fd0 100644 --- a/src/lib/viewers/image/__tests__/ImageBaseViewer-test.js +++ b/src/lib/viewers/image/__tests__/ImageBaseViewer-test.js @@ -313,6 +313,7 @@ describe('lib/viewers/image/ImageBaseViewer', () => { describe('handleMouseUp()', () => { beforeEach(() => { + stubs.emitMetric = sandbox.stub(imageBase, 'emitMetric'); stubs.pan = sandbox.stub(imageBase, 'stopPanning'); stubs.zoom = sandbox.stub(imageBase, 'zoom'); imageBase.isPanning = false; @@ -335,6 +336,7 @@ describe('lib/viewers/image/ImageBaseViewer', () => { event.metaKey = 'blah'; imageBase.handleMouseUp(event); expect(stubs.zoom).to.not.have.been.called; + expect(stubs.emitMetric).to.not.have.been.called; }); it('should zoom in if zoomable but not pannable', () => { @@ -349,6 +351,7 @@ describe('lib/viewers/image/ImageBaseViewer', () => { imageBase.isZoomable = true; imageBase.handleMouseUp(event); expect(stubs.zoom).to.have.been.calledWith('in'); + expect(stubs.emitMetric).to.be.calledWith('zoom', 'inClick'); }); it('should reset zoom if mouseup was not due to end of panning', () => { @@ -364,6 +367,7 @@ describe('lib/viewers/image/ImageBaseViewer', () => { imageBase.didPan = false; imageBase.handleMouseUp(event); expect(stubs.zoom).to.have.been.calledWith('reset'); + expect(stubs.emitMetric).to.be.calledWith('zoom', 'resetClick'); }); it('should not zoom if mouse up was due to end of panning', () => {