/react-globe

Create beautiful and interactive React + ThreeJS globe visualizations with ease.

Primary LanguageTypeScriptMIT LicenseMIT

🌎 react-globe

Create beautiful and interactive React + ThreeJS globe visualizations with ease.

image

Features

  • ✨ Beautiful and complete with clouds, backgrounds and lighting.
  • ✌️ Incredibly simple to use and configure.
  • 📍 Render interactive markers on the globe using simple data.
  • 🎞 Easy globe animations and marker transitions.
  • ⚛️ Modern Javascript + build tools.

Install

yarn add react-globe

Note that react-globe requires react >= 16.8.0 and three >= 0.102.0 as peer dependencies.

Examples

Documented Examples

View all documented examples and gallery of react-globe applications at https://react-globe.netlify.com/.

Local Examples

You can also run the examples locally:

git clone git@github.com:chrisrzhou/react-globe

cd react-globe
yarn && yarn dev

Basic Example (no props)

image

Edit react-globe-simple

Interactive Example (with markers)

image

Edit react-globe-interactive

Custom Marker Renderer Example

image

Edit react-globe-interactive

Google Globe Trends

image

Link to app

Contributing

The code is written in typescript, linted with eslint + prettier, and bundled with rollup. Examples and documentations are built with docz.

Feel free to contribute by submitting a pull request.

Main Dependencies

  • react
  • three
  • three-glow-mesh
  • three-orbitcontrols
  • three.interaction
  • es6-tween
  • tippy.js

Codebase Overview

  • ReactGlobe.tsx: Core React component exposing relevant props controlling the Globe instance.
  • Globe.ts: Primary ThreeJS rendering logic written as a Globe class.
  • Tooltip.ts: Tooltip component powered by tippy.js.
  • types.ts: Typescript types.
  • defaults.ts: Default options and constants.
  • utils.ts: Various simple functions to compute derived data.
  • /textures: Default globe, clouds and background textures.