From eaaeda34ab2440544229416728a42d0cf98187a2 Mon Sep 17 00:00:00 2001 From: Scott Kang Date: Tue, 2 May 2023 16:48:47 +0800 Subject: [PATCH] fix: isPopupVisible logic for AzureMapHtmlMarker --- __mocks__/azure-maps-control.js | 1 + package.json | 2 +- .../AzureMapHtmlMarker.test.tsx | 8 ++++---- .../AzureMapHtmlMarker/AzureMapHtmlMarker.tsx | 17 +++++++++-------- 4 files changed, 15 insertions(+), 13 deletions(-) diff --git a/__mocks__/azure-maps-control.js b/__mocks__/azure-maps-control.js index cc0955c..1c93dd7 100644 --- a/__mocks__/azure-maps-control.js +++ b/__mocks__/azure-maps-control.js @@ -67,6 +67,7 @@ module.exports = { isOpen: jest.fn(() => true), open: jest.fn(() => false), togglePopup: jest.fn(), + setOptions: jest.fn(), close: jest.fn() } })) diff --git a/package.json b/package.json index 4ad028c..c36f163 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "react-azure-maps", - "version": "0.4.6", + "version": "0.4.7", "description": "React Wrapper for Azure Maps", "keywords": [ "react", diff --git a/src/components/AzureMapMarkers/AzureMapHtmlMarker/AzureMapHtmlMarker.test.tsx b/src/components/AzureMapMarkers/AzureMapHtmlMarker/AzureMapHtmlMarker.test.tsx index ad2ebfb..851c8c2 100644 --- a/src/components/AzureMapMarkers/AzureMapHtmlMarker/AzureMapHtmlMarker.test.tsx +++ b/src/components/AzureMapMarkers/AzureMapHtmlMarker/AzureMapHtmlMarker.test.tsx @@ -2,7 +2,7 @@ import { render } from '@testing-library/react' import { Map, Popup } from 'azure-maps-control' import React from 'react' import { AzureMapsContext } from '../../../contexts/AzureMapContext' -import AzureMaphtmlMarker from './AzureMapHtmlMarker' +import AzureMapHtmlMarker from './AzureMapHtmlMarker' import { IAzureMapHtmlMarker } from '../../../types' import atlas from 'azure-maps-control' @@ -23,7 +23,7 @@ const wrapWithAzureMapContext = (props: IAzureMapHtmlMarker) => { mapRef }} > - + ) } @@ -81,13 +81,13 @@ describe('AzureMaphtmlMarker tests', () => { expect(markerRef.setOptions).toHaveBeenCalledWith({ htmlContent: '
' }) }) - it('should close marker popup', () => { + it('should open marker popup', () => { render(wrapWithAzureMapContext({ isPopupVisible: true, markerContent:
})) // Currently we only check if getOptions get called @TODO expect(markerRef.getOptions).toHaveBeenCalled() }) - it('should open marker popup', () => { + it('should close marker popup', () => { render(wrapWithAzureMapContext({ isPopupVisible: false, markerContent:
})) // Currently we only check if getOptions get called @TODO expect(markerRef.getOptions).toHaveBeenCalled() diff --git a/src/components/AzureMapMarkers/AzureMapHtmlMarker/AzureMapHtmlMarker.tsx b/src/components/AzureMapMarkers/AzureMapHtmlMarker/AzureMapHtmlMarker.tsx index bdd8ae2..2aae52c 100644 --- a/src/components/AzureMapMarkers/AzureMapHtmlMarker/AzureMapHtmlMarker.tsx +++ b/src/components/AzureMapMarkers/AzureMapHtmlMarker/AzureMapHtmlMarker.tsx @@ -16,7 +16,7 @@ const AzureMapHtmlMarker = memo( ) const { mapRef } = useContext(AzureMapsContext) - useCheckRefMount(mapRef, true, mref => { + useCheckRefMount(mapRef, true, (mref) => { mref.markers.add(markerRef) events && events.forEach(({ eventName, callback }) => { @@ -38,13 +38,14 @@ const AzureMapHtmlMarker = memo( useEffect(() => { if (markerRef && markerRef.getOptions().popup && mapRef) { - const isMarkerPopupOpen = markerRef.getOptions().popup?.isOpen() - if (isMarkerPopupOpen && isPopupVisible) { - markerRef.getOptions().popup?.close() - } else if (isMarkerPopupOpen !== undefined) { - markerRef.getOptions().popup?.open() - } else if ((isPopupVisible && isMarkerPopupOpen) || isPopupVisible) { - markerRef.togglePopup() + const popupRef = markerRef.getOptions().popup + if (isPopupVisible) { + popupRef?.setOptions({ + position: markerRef.getOptions().position + }) + popupRef?.open(mapRef) + } else { + popupRef?.close() } } }, [isPopupVisible, options, mapRef])