third party plugins

Tailwind CSS Data Maps

Datamaps are customizable SVG visualizations for the web, providing interactive geospatial insights by converting raw data into visual formats.

Below are the comprehensively outlined steps you can follow to seamlessly integrate Datamaps JS with FlyonUI.

  • 1
    Step 1: Install Datamaps

    Install datamaps using npm.

    npm i datamaps

  • 2
    Step 2: Include Datamaps JavaScript

    To integrate Datamaps, add the following <script> tags near the end of your </body> section.

    <script src="../path/to/d3/d3.min.js"></script>
    <script src="../path/to/topojson/build/topojson.min.js"></script>
    <script src="../path/to/datamaps/dist/datamaps.world.min.js"></script>
    Since no custom CSS overrides are required, you can also use a CDN link.

    Add the following <script> tags near the end of your </body> section:

    <script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.3/d3.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/topojson/1.6.9/topojson.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/datamaps@0.5.9/dist/datamaps.all.min.js"></script>

  • 3
    Step 3: Initialize Datamaps

    Add the following JavaScript code to initialize Datamaps on a target element using its id, as shown in the Datamap example. Ensure this script is placed below the Datamaps JS library and in a location where TailwindCSS can monitor it, as mentioned in step 3.

    For additional options and configurations, refer to the Datamaps JS documentation .

    <script>
    
    (function () {
    // Dataset containing import and export data for various countries
    const dataSet = {
    CHN: { import: { value: '11,250', percent: '14.5', isGrown: true }, export: { value: '680', percent: '0.5', isGrown: true }, fillKey: 'MAJOR', short: 'cn' },
    DEU: { import: { value: '9,320', percent: '6.1', isGrown: true }, export: { value: '1,200', percent: '6.3', isGrown: true }, fillKey: 'MAJOR', short: 'de' },
    GBR: { import: { value: '5,050', percent: '8.9', isGrown: false }, export: { value: '2,150', percent: '3.7', isGrown: true }, fillKey: 'MAJOR', short: 'gb' },
    IND: { import: { value: '1,500', percent: '18.5', isGrown: false }, export: { value: '450', percent: '12.0', isGrown: true }, fillKey: 'MAJOR', short: 'in' },
    USA: { import: { value: '480', percent: '1.1', isGrown: false }, export: { value: '1,600', percent: '2.5', isGrown: true }, fillKey: 'MAJOR', short: 'us', customName: 'United States' },
    CAN: { import: { value: '2,500', percent: '22.0', isGrown: true }, export: { value: '600', percent: '13.0', isGrown: true }, fillKey: 'MAJOR', short: 'ca' },
    AUS: { import: { value: '1,350', percent: '12.0', isGrown: true }, export: { value: '330', percent: '10.0', isGrown: true }, fillKey: 'MAJOR', short: 'au' },
    FRA: { import: { value: '3,800', percent: '16.0', isGrown: true }, export: { value: '820', percent: '15.0', isGrown: true }, fillKey: 'MAJOR', short: 'fr' },
    JPN: { import: { value: '4,200', percent: '21.0', isGrown: true }, export: { value: '710', percent: '18.0', isGrown: false }, fillKey: 'MAJOR', short: 'jp' },
    ITA: { import: { value: '3,200', percent: '14.8', isGrown: false }, export: { value: '640', percent: '12.5', isGrown: true }, fillKey: 'MAJOR', short: 'it' },
    RUS: { import: { value: '5,600', percent: '19.5', isGrown: true }, export: { value: '1,000', percent: '10.5', isGrown: true }, fillKey: 'MAJOR', short: 'ru' },
    MEX: { import: { value: '2,750', percent: '17.5', isGrown: false }, export: { value: '520', percent: '9.2', isGrown: true }, fillKey: 'MAJOR', short: 'mx' },
    ZAF: { import: { value: '1,800', percent: '10.5', isGrown: true }, export: { value: '450', percent: '8.0', isGrown: true }, fillKey: 'MAJOR', short: 'za' }
    }
    
    // Initialize Datamap
    const dataMap = new Datamap({
    element: document.querySelector('#countries-datamap'), // HTML element to render the map
    projection: 'mercator', // Projection type
    responsive: true, // Enable responsiveness
    fills: {
    defaultFill: `oklch(var(--b2)/0.6)`,
    MAJOR: `oklch(var(--b3)/0.8)`
    },
    data: dataSet, // Country-specific data
    geographyConfig: {
    borderColor: `oklch(var(--bc)/0.5)`, // Border color for countries
    highlightFillColor: `oklch(var(--p)/0.2)`, // Highlight fill color on hover
    highlightBorderColor: `oklch(var(--p))`, // Highlight border color on hover
    popupTemplate: function (geo, data) {
    // Popup template for displaying country data
    const growUp = `<span class="icon-[tabler--trending-up] text-success size-4"></span>`
    const growDown = `<span class="icon-[tabler--trending-down] text-error size-4"></span>`
    return `
              <div class="bg-base-100 rounded-lg overflow-hidden shadow min-w-32 me-2">
                <div class="flex items-center gap-2 bg-base-300 p-2">
                  <div class="flex items-center">
                    <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/lipis/flag-icons@7.0.0/css/flag-icons.min.css"/>
                    <span class="fi fi-${data.short.toLowerCase()} h-4 w-5 rounded"></span>
                  </div>
                  <span class="text-sm font-medium text-base-content">${data.customName || geo.properties.name}</span>
                </div>
                <div class="p-2 space-y-1">
                  <div class="flex items-center justify-between text-xs gap-2">
                    <div class="text-base-content/80 text-nowrap">Import: <span class="font-medium">${
                      data.import.value
                    }M</span></div>
                    <span class="flex items-center gap-0.5 ${data.import.isGrown ? 'text-success' : 'text-error'}">${
                      data.import.percent
                    }${data.import.isGrown ? growUp : growDown}</span>
                  </div>
                  <div class="flex items-center justify-between text-xs gap-2">
                    <div class="text-base-content/80 text-nowrap">Export: <span class="font-medium">${
                      data.export.value
                    }</span>M</div>
                    <span class="flex items-center gap-0.5 ${data.export.isGrown ? 'text-success' : 'text-error'}">${
                      data.export.percent
                    }${data.export.isGrown ? growUp : growDown}</span>
                  </div>
                </div>
              </div>`
    }
    }
    })
    // Event listener for window resize to make Datamap responsive
    window.addEventListener('resize', function () {
    dataMap.resize()
    })
    })()
    </script>

The following example demonstrates the usage of a data map, initialized with the JavaScript code provided above.

<div id="countries-datamap"></div>