Skip to content

Latest commit

 

History

History
59 lines (41 loc) · 2.56 KB

README.md

File metadata and controls

59 lines (41 loc) · 2.56 KB

🗺️ Travel App React

A React App that tracks users location , can search places using Mapbox API and can add new markers

A simple map application using React as frontend , Mapbox forward API for search coordinates and LeafletJS leaflet-logo for map tiles

⚠️ Note

Use mapRef to Initialize your Map. Ignore the functions present in leaflet documentation. Some methods like addLayer is not working in React v18.

const mapRef = useRef();

  const initializeMap = () => {
    mapRef.current = new L.map("map").setView([0, 0], 13);

    L.tileLayer(
      `https://api.mapbox.com/styles/v1/misixi/clcedh8kx000b14mr7776gtot/tiles/256/{z}/{x}/{y}@2x?access_token=${process.env.REACT_APP_API_KEY}`,
      {
        attribution:
          "© <a href='https://www.mapbox.com/about/maps/'>Mapbox</a> © <a href='http://www.openstreetmap.org/copyright'>OpenStreetMap</a> <strong><a href='https://www.mapbox.com/map-feedback/' target='_blank'>Improve this map</a></strong>",
      }
    ).addTo(mapRef.current);

    mapRef.current.on("moveend", () => {
      closeSearchResults();
    });
  };
  

Initialize your map everytime using useEffect(). The below method is important else, your app will crash after refresh

useEffect(() => {
    //init map
    var container = L.DomUtil.get("map");
    if (container != null) {
      container._leaflet_id = null;
    }
    initializeMap();

    getGeolocations();
  }, []);

📍 Use mouse to zoom and move the map layer

movement-zoom⌛ Please wait until GIF loads

Enable location access and toggle location mode

location-mode⌛ Please wait until GIF loads

🔍 Search for your desired location in the search bar

movement-zoom⌛ Please wait until GIF loads

🗾 Make sure that you have given access to your location in the browser and in your settings

movement-zoom⌛ Please wait until GIF loads