@vnedyalk0v/react19-simple-maps
v2.0.2
Published
An svg map chart component built exclusively for React 19+ - Modern TypeScript-first library with cutting-edge React patterns
Maintainers
Readme
@vnedyalk0v/react19-simple-maps
Create interactive SVG maps in React with d3-geo and topojson using a TypeScript-first API for React 19+.
Modernized fork of react-simple-maps with React 19 support and TypeScript-first tooling.
Key Features
- React 19+ only (peer dependencies)
- ESM-only build with tree-shaking and type definitions
- TypeScript-first API with branded coordinate helpers
- Core components: ComposableMap, Geographies, Geography, ZoomableGroup, Marker, Annotation, Line, Sphere, Graticule
- Optional error boundary + Suspense fallback for geography loading
- Geography fetching utilities with validation (HTTPS-only default, private IP blocking, content-type/size checks) and optional SRI helpers
- Opt-in debug logging via
debugprop orREACT_SIMPLE_MAPS_DEBUG
Quick Links
Installation
From npm Registry (Recommended)
# npm
npm install @vnedyalk0v/react19-simple-maps
# yarn
yarn add @vnedyalk0v/react19-simple-maps
# pnpm
pnpm add @vnedyalk0v/react19-simple-mapsESM-only: This package only supports
importsyntax.require(...)is not supported.
From GitHub Packages (Alternative)
# Configure npm to use GitHub Packages for @vnedyalk0v scope
echo "@vnedyalk0v:registry=https://npm.pkg.github.com" >> ~/.npmrc
# Install from GitHub Packages
npm install @vnedyalk0v/react19-simple-mapsRequirements
- React: 19.0.0 or higher (peer dependency)
- React DOM: 19.0.0 or higher (peer dependency)
- Node.js: 18.0.0 or higher (development/build)
- TypeScript: 5.0.0 or higher (recommended)
Utilities Subpath
You can import helper utilities directly from the ./utils subpath:
import {
validateGeographyUrl,
configureSRI,
} from '@vnedyalk0v/react19-simple-maps/utils';Migration Notes (from react-simple-maps)
- Replace package + import path:
react-simple-maps→@vnedyalk0v/react19-simple-maps. - For TypeScript, use branded helpers like
createCoordinates()(or an explicit cast) forCoordinates. - Geography event handlers receive
(event, data)wheredataincludes geography info (centroid, bounds, etc.).
Quick Start
import React from 'react';
import {
ComposableMap,
Geographies,
Geography,
createCoordinates,
} from '@vnedyalk0v/react19-simple-maps';
const geoUrl = 'https://unpkg.com/world-atlas@2/countries-110m.json';
const MapChart = () => {
return (
<ComposableMap
projection="geoEqualEarth"
projectionConfig={{
scale: 147,
center: createCoordinates(0, 0),
}}
width={800}
height={500}
>
<Geographies geography={geoUrl}>
{({ geographies }) =>
geographies.map((geo) => (
<Geography
key={geo.rsmKey}
geography={geo}
style={{
default: { fill: '#D6D6DA', outline: 'none' },
hover: { fill: '#F53', outline: 'none' },
pressed: { fill: '#E42', outline: 'none' },
}}
/>
))
}
</Geographies>
</ComposableMap>
);
};
export default MapChart;Core Components
ComposableMap
The main wrapper component that provides SVG context and projection setup.
Common props:
projection- Map projection (string name or d3-geo projection function)projectionConfig- Configuration for built-in projectionswidth,height- SVG dimensionsclassName- CSS class namedebug- Enable opt-in debug logging (default:false)
Geographies
Renders geographic features from TopoJSON or GeoJSON data.
Notable props:
geography- URL string, TopoJSON object, or GeoJSON FeatureCollectionparseGeographies- Optional function to transform geography dataerrorBoundary- Enable built-in error boundary and Suspense fallbackonGeographyError,fallback- Error handling hooks whenerrorBoundaryis enabled
Geography
Individual geographic feature component with enhanced event handlers.
All event handlers receive (event, GeographyEventData) where GeographyEventData includes:
geography, centroid, bounds, and coordinates.
ZoomableGroup
Zoom and pan with both simple and advanced APIs.
import {
ZoomableGroup,
createZoomConfig,
} from '@vnedyalk0v/react19-simple-maps';
<ZoomableGroup
zoom={1}
center={createCoordinates(0, 0)}
{...createZoomConfig(0.5, 8)}
>
{/* Content */}
</ZoomableGroup>;Marker & Annotation
Use Marker for custom points and Annotation for callouts.
Additional Components
Line- Draw lines between coordinatesGraticule- Add coordinate grid linesSphere- Add map outline/backgroundGeographyErrorBoundary- Explicit error boundary wrapperMapWithMetadata- Wrapper that renders metadata and aComposableMap
TypeScript Support
Branded types help prevent coordinate mistakes:
import {
createCoordinates,
createLongitude,
createLatitude,
} from '@vnedyalk0v/react19-simple-maps';
const lon = createLongitude(-74.006);
const lat = createLatitude(40.7128);
const coords = createCoordinates(-74.006, 40.7128);Geography Utilities
Extract geographic data for interactions and labels:
import {
getGeographyCentroid,
getGeographyBounds,
getBestGeographyCoordinates,
} from '@vnedyalk0v/react19-simple-maps';Map Data Sources
Security Utilities
The ./utils subpath includes helpers for safer geography fetching. When you use URL-based geography data in Geographies, the internal fetch path applies URL validation, HTTPS-only defaults, response size checks, and optional SRI validation.
import {
configureGeographySecurity,
enableDevelopmentMode,
} from '@vnedyalk0v/react19-simple-maps/utils';
configureGeographySecurity({
TIMEOUT_MS: 5000,
MAX_RESPONSE_SIZE: 10 * 1024 * 1024,
});
if (process.env.NODE_ENV === 'development') {
enableDevelopmentMode(true); // allow HTTP localhost
}Debugging
Enable debug logging globally via environment variable or per map:
REACT_SIMPLE_MAPS_DEBUG=true<ComposableMap debug={true}>{/* Map content */}</ComposableMap>Development
npm install
npm run dev
npm run build
npm run test
npm run type-check
npm run lintPublishing
Changesets is configured for versioning and releases. The GitHub Actions workflow in .github/workflows/publish.yml runs on pushes to main and publishes to npm (and GitHub Packages) when configured with tokens.
License
MIT licensed. Original work Copyright (c) Richard Zimerman 2017. Fork maintenance Copyright (c) Georgi Nedyalkov 2025. See LICENSE for details.
