From db5f6b6b5017e9a513e5bb9c5d56f868a8955d3c Mon Sep 17 00:00:00 2001 From: Hanbyul Jo Date: Wed, 7 Feb 2024 13:49:59 -0500 Subject: [PATCH 1/3] Add manual movement for geocoder result --- .../common/map/controls/geocoder.tsx | 35 +++++++++++++++++-- 1 file changed, 32 insertions(+), 3 deletions(-) diff --git a/app/scripts/components/common/map/controls/geocoder.tsx b/app/scripts/components/common/map/controls/geocoder.tsx index edf0b5649..fdd9b46b9 100644 --- a/app/scripts/components/common/map/controls/geocoder.tsx +++ b/app/scripts/components/common/map/controls/geocoder.tsx @@ -1,15 +1,44 @@ +import { useCallback } from 'react'; import MapboxGeocoder from '@mapbox/mapbox-gl-geocoder'; import { useControl } from 'react-map-gl'; + +function getZoomFromBbox(bbox: [number, number, number, number]): number { + const latMax = Math.max(bbox[3], bbox[1]); + const lngMax = Math.max(bbox[2], bbox[0]); + const latMin = Math.min(bbox[3], bbox[1]); + const lngMin = Math.min(bbox[2], bbox[0]); + const maxDiff = Math.max(latMax - latMin, lngMax - lngMin); + if (maxDiff < 360 / Math.pow(2, 20)) { + return 21; +} else { + const zoomLevel = Math.floor(-1*( (Math.log(maxDiff)/Math.log(2)) - (Math.log(360)/Math.log(2)))); + if (zoomLevel < 1) return 1; + else return zoomLevel; + } +} + export default function GeocoderControl() { + + const handleGeocoderResult = useCallback((map) => ({ result }) => { + const zoom = result.bbox? getZoomFromBbox(result.bbox): 14; + map.flyTo({ + center: result.center, + zoom + }); + }, []); + useControl( - () => { - return new MapboxGeocoder({ + ({ map }) => { + const geocoder = new MapboxGeocoder({ accessToken: process.env.MAPBOX_TOKEN, marker: false, - collapsed: true + collapsed: true, + flyTo: false }); + geocoder.on('result', handleGeocoderResult(map)); + return geocoder; }, { position: 'top-right' From 6923b800e2725947ae514a350c4b637ae8b93ca6 Mon Sep 17 00:00:00 2001 From: Hanbyul Jo Date: Wed, 7 Feb 2024 14:01:11 -0500 Subject: [PATCH 2/3] Add comment --- app/scripts/components/common/map/controls/geocoder.tsx | 3 +++ 1 file changed, 3 insertions(+) diff --git a/app/scripts/components/common/map/controls/geocoder.tsx b/app/scripts/components/common/map/controls/geocoder.tsx index fdd9b46b9..b79f45831 100644 --- a/app/scripts/components/common/map/controls/geocoder.tsx +++ b/app/scripts/components/common/map/controls/geocoder.tsx @@ -22,6 +22,7 @@ function getZoomFromBbox(bbox: [number, number, number, number]): number { export default function GeocoderControl() { const handleGeocoderResult = useCallback((map) => ({ result }) => { + // Pass arbiturary number for zoom if there is no bbox const zoom = result.bbox? getZoomFromBbox(result.bbox): 14; map.flyTo({ center: result.center, @@ -35,6 +36,8 @@ export default function GeocoderControl() { accessToken: process.env.MAPBOX_TOKEN, marker: false, collapsed: true, + // Because of Mapbox issue: https://github.com/mapbox/mapbox-gl-js/issues/12565 + // We are doing manual centering for now flyTo: false }); geocoder.on('result', handleGeocoderResult(map)); From c0a948665d43fa7b2b29a371628822b18750d4f0 Mon Sep 17 00:00:00 2001 From: Hanbyul Jo Date: Wed, 7 Feb 2024 14:07:20 -0500 Subject: [PATCH 3/3] Put geocoder workaround for current explore map --- .../components/common/map/controls/geocoder.tsx | 11 ++++++----- app/scripts/components/common/mapbox/map.tsx | 13 +++++++++++-- 2 files changed, 17 insertions(+), 7 deletions(-) diff --git a/app/scripts/components/common/map/controls/geocoder.tsx b/app/scripts/components/common/map/controls/geocoder.tsx index b79f45831..603c0931b 100644 --- a/app/scripts/components/common/map/controls/geocoder.tsx +++ b/app/scripts/components/common/map/controls/geocoder.tsx @@ -3,8 +3,7 @@ import MapboxGeocoder from '@mapbox/mapbox-gl-geocoder'; import { useControl } from 'react-map-gl'; - -function getZoomFromBbox(bbox: [number, number, number, number]): number { +export function getZoomFromBbox(bbox: [number, number, number, number]): number { const latMax = Math.max(bbox[3], bbox[1]); const lngMax = Math.max(bbox[2], bbox[0]); const latMin = Math.min(bbox[3], bbox[1]); @@ -21,7 +20,9 @@ function getZoomFromBbox(bbox: [number, number, number, number]): number { export default function GeocoderControl() { - const handleGeocoderResult = useCallback((map) => ({ result }) => { + const handleGeocoderResult = useCallback((map, geocoder) => ({ result }) => { + geocoder.clear(); + geocoder._inputEl.blur(); // Pass arbiturary number for zoom if there is no bbox const zoom = result.bbox? getZoomFromBbox(result.bbox): 14; map.flyTo({ @@ -29,7 +30,7 @@ export default function GeocoderControl() { zoom }); }, []); - + useControl( ({ map }) => { const geocoder = new MapboxGeocoder({ @@ -40,7 +41,7 @@ export default function GeocoderControl() { // We are doing manual centering for now flyTo: false }); - geocoder.on('result', handleGeocoderResult(map)); + geocoder.on('result', handleGeocoderResult(map, geocoder)); return geocoder; }, { diff --git a/app/scripts/components/common/mapbox/map.tsx b/app/scripts/components/common/mapbox/map.tsx index 9bb3cfa69..a6d508f33 100644 --- a/app/scripts/components/common/mapbox/map.tsx +++ b/app/scripts/components/common/mapbox/map.tsx @@ -28,6 +28,7 @@ import MapCoords from './map-coords'; import { useMapStyle } from './layers/styles'; import { BasemapId, Option } from './map-options/basemaps'; +import { getZoomFromBbox } from '$components/common/map/controls/geocoder'; import { round } from '$utils/format'; mapboxgl.accessToken = process.env.MAPBOX_TOKEN ?? ''; @@ -146,13 +147,21 @@ export function SimpleMap(props: SimpleMapProps): ReactElement { const geocoderControl = new MapboxGeocoder({ accessToken: mapboxgl.accessToken, marker: false, - collapsed: true + collapsed: true, + // Because of Mapbox issue: https://github.com/mapbox/mapbox-gl-js/issues/12565 + // We are doing manual centering for now + flyTo: false }) as MapboxGeocoder & { _inputEl: HTMLInputElement }; // Close the geocoder when the result is selected. - geocoderControl.on('result', () => { + geocoderControl.on('result', ({ result }) => { geocoderControl.clear(); geocoderControl._inputEl.blur(); + const zoom = result.bbox? getZoomFromBbox(result.bbox): 14; + mapRef.current?.flyTo({ + center: result.center, + zoom + }); }); mbMap.addControl(geocoderControl, 'top-left');