diff --git a/src/MapComponent.jsx b/src/MapComponent.jsx index e946599..73d2b9b 100644 --- a/src/MapComponent.jsx +++ b/src/MapComponent.jsx @@ -1,42 +1,85 @@ import React, { useEffect, useRef, useState } from "react"; +import { useNavigate } from 'react-router-dom'; -const MapComponent = ( {cafes} ) => { +const MapComponent = ({ cafes }) => { const mapRef = useRef(null); - const defaultLocation = { lat: 42.0451, lng: -87.6877 }; // Default to a location, e.g., Chicago - + const defaultLocation = { lat: 42.0451, lng: -87.6877 }; + const [map, setMap] = useState(null); + const navigate = useNavigate(); useEffect(() => { if (!mapRef.current) return; - // Initialize map - const map = new window.google.maps.Map(mapRef.current, { - center: defaultLocation, - zoom: 14, - mapId: 'ae95546a5be3631', - disableDefaultUI: true, - }); + const initMap = async () => { + const { Map } = await window.google.maps.importLibrary("maps"); + const { AdvancedMarkerElement } = await window.google.maps.importLibrary("marker"); - // Add markers for each cafe - cafes.forEach((cafe) => { - const marker = new window.google.maps.Marker({ - position: { lat: cafe.lat, lng: cafe.lng }, - map: map, - title: cafe.name, + const newMap = new Map(mapRef.current, { + center: defaultLocation, + zoom: 14, + mapId: 'ae95546a5be3631', + disableDefaultUI: true, }); - // Info window with cafe name - const infoWindow = new window.google.maps.InfoWindow({ - content: `
${cafe.name}
`, - }); + setMap(newMap); + }; + + initMap(); + }, []); + + useEffect(() => { + if (!map || !cafes.length) return; - // Show info window on marker click - marker.addListener("click", () => { - infoWindow.open(map, marker); + const bounds = new window.google.maps.LatLngBounds(); + const geocoder = new window.google.maps.Geocoder(); + + cafes.forEach((cafe) => { + geocoder.geocode({ address: cafe.vicinity }, (results, status) => { + if (status === 'OK' && results[0]) { + const position = results[0].geometry.location; + + const marker = new window.google.maps.marker.AdvancedMarkerElement({ + map, + position, + title: cafe.name, + }); + + const infoWindowContent = ` +
+ ${cafe.name} +
+ +
+ `; + + const infoWindow = new window.google.maps.InfoWindow({ + content: infoWindowContent, + }); + + marker.addListener("click", () => { + infoWindow.open(map, marker); + + // We need to wait for the InfoWindow to be added to the DOM + setTimeout(() => { + const button = document.getElementById(`goto-${cafe.placeId}`); + if (button) { + button.addEventListener('click', () => { + navigate(`/cafe/${cafe.placeId}`); + }); + } + }, 0); + }); + + bounds.extend(position); + map.fitBounds(bounds); + } else { + console.error(`Geocoding failed for ${cafe.name}: ${status}`); + } }); }); - }, []); + }, [cafes, map, navigate]); return
; }; -export default MapComponent; +export default MapComponent; \ No newline at end of file diff --git a/src/pages/LandingPage.jsx b/src/pages/LandingPage.jsx index 0ed5ef1..690386a 100644 --- a/src/pages/LandingPage.jsx +++ b/src/pages/LandingPage.jsx @@ -36,18 +36,11 @@ const LandingPage = () => { console.log(cafes); }, [cafes]); - const cafesMap = [ - { name: "Cafe Blue", lat: 42.046, lng: -87.688 }, - { name: "Green Bean Cafe", lat: 42.048, lng: -87.684 }, - { name: "Java Lounge", lat: 42.044, lng: -87.690 }, - ]; - return (
- {/* Integrate MapComponent with hardcoded data */}
- +
);