react-google-maps

@vis.gl/react-google-maps

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "react-google-maps" with this command: npx skills add horuz-ai/claude-plugins/horuz-ai-claude-plugins-react-google-maps

@vis.gl/react-google-maps

Official React library for Google Maps JavaScript API, maintained by vis.gl with Google sponsorship.

Quick Start

import { APIProvider, Map, AdvancedMarker, Pin } from '@vis.gl/react-google-maps';

function App() { return ( <APIProvider apiKey={process.env.NEXT_PUBLIC_GOOGLE_MAPS_API_KEY!}> <Map style={{ width: '100%', height: '400px' }} defaultCenter={{ lat: 18.4655, lng: -66.1057 }} defaultZoom={12} mapId="YOUR_MAP_ID" // Required for AdvancedMarker > <AdvancedMarker position={{ lat: 18.4655, lng: -66.1057 }}> <Pin background="#0f9d58" borderColor="#006425" glyphColor="#60d98f" /> </AdvancedMarker> </Map> </APIProvider> ); }

Installation

npm install @vis.gl/react-google-maps

Key Exports

// Components import { APIProvider, // Wraps app, loads Maps JS API Map, // Map container AdvancedMarker, // Modern marker (requires mapId) Pin, // Customizable pin for AdvancedMarker InfoWindow, // Popup windows MapControl, // Custom controls on map Marker, // Legacy marker (deprecated) } from '@vis.gl/react-google-maps';

// Hooks import { useMap, // Access google.maps.Map instance useMapsLibrary, // Load additional libraries (places, geocoding, drawing) useAdvancedMarkerRef, // Connect marker to InfoWindow useApiIsLoaded, // Check if API is loaded } from '@vis.gl/react-google-maps';

// Enums import { ControlPosition, // For MapControl positioning CollisionBehavior, // For marker collision handling } from '@vis.gl/react-google-maps';

Critical Requirements

  • mapId is required for AdvancedMarker - Create one at Google Cloud Console > Maps > Map Styles

  • APIProvider must wrap all map components - Place at app root or layout level

  • Circle, Polygon, Polyline are NOT exported - See references/geometry-components.md for implementations

  • places.Autocomplete is deprecated (March 2025) - Use AutocompleteService with custom UI instead

Reference Files

Read these files based on the task:

Task Reference File

Map, Marker, InfoWindow, Pin details references/components-api.md

useMap, useMapsLibrary, hooks references/hooks-api.md

Circle, Polygon, Polyline references/geometry-components.md

Places Autocomplete, Geocoding references/places-autocomplete.md

Draggable markers + real-time sync, controlled maps references/patterns.md

Common Patterns

Marker with InfoWindow

const MarkerWithInfo = ({ position }: { position: google.maps.LatLngLiteral }) => { const [markerRef, marker] = useAdvancedMarkerRef(); const [open, setOpen] = useState(false);

return ( <> <AdvancedMarker ref={markerRef} position={position} onClick={() => setOpen(true)} /> {open && ( <InfoWindow anchor={marker} onClose={() => setOpen(false)}> <p>Hello!</p> </InfoWindow> )} </> ); };

Draggable Marker with Real-Time Circle Sync

const DraggableWithCircle = () => { const [position, setPosition] = useState({ lat: 18.4655, lng: -66.1057 });

return ( <> <AdvancedMarker position={position} draggable onDrag={(e) => { // Updates DURING drag for real-time sync if (e.latLng) setPosition({ lat: e.latLng.lat(), lng: e.latLng.lng() }); }} /> <Circle center={position} radius={1000} /> {/* Follows marker in real-time */} </> ); };

Custom Map Control

<Map {...props}> <MapControl position={ControlPosition.TOP_LEFT}> <button onClick={handleClick}>Custom Button</button> </MapControl> </Map>

TypeScript Types

// Position types type LatLngLiteral = { lat: number; lng: number }; type LatLngAltitudeLiteral = { lat: number; lng: number; altitude: number };

// Event types type MapMouseEvent = google.maps.MapMouseEvent; type AdvancedMarkerClickEvent = google.maps.marker.AdvancedMarkerClickEvent;

// Library types (from useMapsLibrary) type PlacesLibrary = google.maps.PlacesLibrary; type GeocodingLibrary = google.maps.GeocodingLibrary; type DrawingLibrary = google.maps.DrawingLibrary;

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

website-cloner

No summary provided by upstream source.

Repository SourceNeeds Review
General

linear-method

No summary provided by upstream source.

Repository SourceNeeds Review
General

pptx

No summary provided by upstream source.

Repository SourceNeeds Review