npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

mapbox-gl-compare-enhanced

v1.0.0

Published

Enhanced version of Mapbox GL Compare: Swipe and sync between two maps with improved compatibility for modern environments (Node.js, Vite, etc.)

Downloads

732

Readme

mapbox-gl-compare-enhanced

Enhanced version of Mapbox GL Compare: Swipe and sync between two maps with improved compatibility for modern environments (Node.js, Vite, etc.)

Swipe example

Map movements are synced with mapbox-gl-sync-move.

Usage

import 'mapbox-gl-compare-enhanced/dist/style.css'
import Compare from 'mapbox-gl-compare-enhanced'

const before = new mapboxgl.Map({
  container: 'before', // Container ID
  style: 'mapbox://styles/mapbox/light-v9'
});

const after = new mapboxgl.Map({
  container: 'after', // Container ID
  style: 'mapbox://styles/mapbox/dark-v9'
});

// A selector or reference to HTML element
const container = '#comparison-container';

new Compare(before, after, container, {
  mousemove: true, // Optional. Set to true to enable swiping during cursor movement.
  orientation: 'vertical' // Optional. Sets the orientation of swiper to horizontal or vertical, defaults to vertical
});

Methods

const compare = new Compare(before, after, container, {
  mousemove: true, // Optional. Set to true to enable swiping during cursor movement.
  orientation: 'vertical' // Optional. Sets the orientation of swiper to horizontal or vertical, defaults to vertical
});

// Get Current position - this will return the slider's current position, in pixels
console.log(compare.currentPosition);

// Set Position - this will set the slider at the specified (x) number of pixels from the left-edge or top-edge of viewport based on swiper orientation
compare.setSlider(x);

// Listen to slider movement - and return current position on each slideend
compare.on('slideend', (e) => {
  console.log(e.currentPosition);
});

// Remove - this will remove the compare control from the DOM and stop synchronizing the two maps
compare.remove();

Demo: https://www.mapbox.com/mapbox-gl-js/example/mapbox-gl-compare/

See API.md for a complete reference.

Developing

Install dependencies, start the development server, and open your browser:

npm install
npm start
open http://localhost:9966

You'll need a Mapbox access token stored in localStorage. Set it via:

localStorage.setItem('MapboxAccessToken', '<TOKEN HERE>');

Testing

Tests now utilize puppeteer for end-to-end testing. Ensure you have a valid MapboxAccessToken environment variable set:

export MapboxAccessToken="YOUR_ACCESS_TOKEN"

Run the tests:

npm test

Deploying

npm registry

To deploy to npm, follow these steps:

  1. Build the library:

    npm run build
  2. Update the version key in package.json.

  3. Update the CHANGELOG.md.

  4. Commit and push your changes:

    git commit -am "Release vX.X.X"
    git push
  5. Tag the release:

    git tag -a vX.X.X -m 'vX.X.X'
    git push --tags
  6. Publish to npm:

    npm publish
  7. Update the version number in the GL JS example.

mapbox cdn

Deploy the library to Mapbox's CDN:

aws s3 cp --acl public-read ./dist/mapbox-gl-compare.js s3://mapbox-gl-js/plugins/mapbox-gl-compare/v$(node --print --eval "require('./package.json').version")/mapbox-gl-compare.js
aws s3 cp --acl public-read ./dist/mapbox-gl-compare.css s3://mapbox-gl-js/plugins/mapbox-gl-compare/v$(node --print --eval "require('./package.json').version")/mapbox-gl-compare.css

Updated Features in v1.0.0

  • Refactored Codebase:

    • Migrated to ES modules and modern JavaScript practices.
    • Introduced Vite for faster and simpler builds.
    • Externalized mapbox-gl as a peer dependency for reduced package size.
  • Enhanced Testing:

    • Switched to puppeteer for robust end-to-end testing.
    • Comprehensive coverage for synchronization, slider movements, and clipping removal.
  • Documentation Updates:

    • Replaced inline comments with JSDoc.
    • Improved examples and guidelines in the API documentation.
  • Breaking Changes:

    • Requires Node.js version 22.11.0.
    • Removed deprecated circle.yml and replaced it with config.yml.