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. Install the npm package.

  3. 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

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

  5. Replace YOUR_MAPTILER_API_KEY_HERE with your actual MapTiler API key.

  6. The next is up to you. You can center your map wherever you desire (modifying the starting position) and set an appropriate zoom level (modifying the starting zoom) to match your users’ needs. Additionally, you can change the map’s look (by updating the source URL); choose from a range of visually appealing map styles from our extensive MapTiler standard maps, or create your own to truly differentiate your application.

  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

Related examples

An extension of MapLibre GL JS