How to create a countries map with your own data

This tutorial shows how to join the MapTiler Countries dataset with your own custom data and make a choropleth map. MapTiler Countries is a dataset that primarily contains data about administrative divisions of a world based on countries and their territories.

  1. Copy the following code, paste it into your favorite text editor, and save it as a .html file.

  2. Replace YOUR_MAPTILER_API_KEY_HERE with your actual MapTiler API key.

  3. The next it’s up to you. You can start the map in a different place by modifying the starting position and starting zoom, and you can change the look of the map to any of our styles, or yours, by updating the style. See what’s available here.

  4. Install the npm package.

  5. Include the CSS file.

    If you have a bundler that can handle CSS, you can import the CSS or include it with a <link> in the head of the document via the CDN

  6. Include the following code in your JavaScript file (Example: app.js).

  7. Add event handler for map load event. You will add code to create a vector source and a vector layer in this handler.

  8. Create vector source. The following snippet creates vector source for the MapTiler Countries dataset.

  9. Get the id of the first symbol layer. We want to include the vector layer below the map labels. That means we need to know the id of the first symbol layer so we can include the vector layer before this layer.

  10. Add the vector layer. We need to include firsSymbolId to the map.addLayer function to display the vector under the maps labels

  11. Filter the data to only show the countries. Add a filter to the layer to only display level 0 items.

  12. Prepare your data. Each feature in the dataset has its own identification for pairing. You need to mark your data with the same identifiers as is stored by features. We will use the iso_n3 identifier for countries. Alternatively, you can use one of the properties: name, country codes (ISO A2), or wiki data-id. Check out the Countries dataset schema to see the available fields.

  13. Join the data to coresponding features. Use querySourceFeatures to get all features from the layer for visualization. We are also filtering for all countries with ['==', 'level', 0] using style expressions. The second part of the following code goes throw these features and adds attributes from our data array (vizData) to relevant features.

  14. Create a function that validates that the country dataset is loaded to call the setStates function.

  15. Add event handler for map data event. Call the afterLoad function

  16. Create a choropleth map based on the population attribute. Change the fill-color property of the layer.

  17. Display a popup when clicking on the vector layer and show the information of the age attribute.

  18. To make our map more user friendly, we will change the cursor when hovering over a geometry in the vector layer to indicate to the user that they can click on it.

Learn more

Get more details about this tutorial on Join MapTiler Countries with your own custom data and make a choropleth map

Check out the tutorials How to use and filter data for MapTiler Countries and How to display an interactive choropleth map legend control.

Visit the MapTiler Countries schema to know how it is organized into different thematic layers and which attribute and values each layer contains.

Read the following How-tos related to choropleth maps:

How to style a choropleth map in Edit Tool

Prepare GeoJSON with attributes for choropleth map and upload GeoJSON to MapTiler Cloud

An extension of MapLibre GL JS