Gets the events interface for handling user interactions with geometries.
An EventsModule instance for registering event handlers.
Supported Events:
click: User clicks on a geometrycontextmenu: User right-clicks on a geometryhover: Mouse enters a geometrylong-hover: Mouse hovers over geometry for extended timeEvent Features:
show()Basic event handling:
geometries.events.on('click', (feature, lngLat) => {
console.log('Clicked:', feature.properties);
console.log('Location:', lngLat);
});
Multiple handlers:
// Highlight on hover
geometries.events.on('hover', (feature) => {
highlightGeometry(feature.id);
});
// Show details on click
geometries.events.on('click', (feature) => {
showDetailPanel(feature.properties);
});
// Context menu
geometries.events.on('contextmenu', (feature, lngLat) => {
showContextMenu(lngLat, feature);
});
Gets the source and layer identifiers for all sources managed by this module.
This property provides access to the MapLibre source and layer IDs that were created and are managed by this module. These IDs can be used to interact directly with MapLibre's API or to identify which layers belong to this module.
A record mapping each source name to its corresponding source ID and layer IDs. Each entry contains the MapLibre source identifier and an array of layer identifiers associated with that source.
The returned IDs are useful when you need to:
const ids = myModule.sourceAndLayerIDs;
console.log(ids);
// {
// mySource: {
// sourceID: 'my-source-id',
// layerIDs: ['layer-1', 'layer-2']
// }
// }
// Use with MapLibre API
const map = myModule.mapLibreMap;
ids.mySource.layerIDs.forEach(layerId => {
map.setLayoutProperty(layerId, 'visibility', 'visible');
});
Applies a configuration to this module.
This method updates the module's behavior and appearance based on the provided configuration. The configuration is stored internally and will be automatically reapplied if the map style changes.
The configuration object to apply to the module. Pass undefined to reset
the configuration to default values.
When a configuration is applied, the module updates its visual representation and behavior accordingly. The configuration persists across map style changes, ensuring consistent module behavior even when the map's base style is modified.
// Apply a new configuration
myModule.applyConfig({ visible: true, opacity: 0.8 });
// Reset to default configuration
myModule.applyConfig(undefined);
Updates the text/label configuration for displayed geometries.
New text configuration settings.
Removes all geometries from the map.
Retrieves a copy of the current module configuration.
This method returns a shallow copy of the configuration object that is currently
applied to the module. If no configuration has been applied, it returns undefined.
A shallow copy of the current configuration object, or undefined if no
configuration is currently applied. The returned object is a copy to prevent
unintended modifications to the internal state.
The returned configuration object is a shallow copy, which means that while the top-level properties are copied, any nested objects or arrays are still referenced from the original configuration. This is sufficient for most use cases but should be kept in mind when dealing with complex configurations.
// Apply a configuration
myModule.applyConfig({ visible: true, opacity: 0.8 });
// Later, retrieve the current configuration
const currentConfig = myModule.getConfig();
console.log(currentConfig); // { visible: true, opacity: 0.8 }
// When no config is applied
myModule.resetConfig();
console.log(myModule.getConfig()); // undefined
Positions the geometry layers relative to other map layers.
Layer positioning configuration.
Can be 'top' to place above all layers, or a specific layer ID.
Resets the configuration of this module to its default values.
This is a convenience method that clears any previously applied configuration
and restores the module to its initial state. This is equivalent to calling
applyConfig(undefined).
After calling this method, the module will behave as if no configuration was ever applied. Any custom settings, styling, or behavior modifications will be removed and replaced with default values.
// Apply some configuration
myModule.applyConfig({ visible: true, opacity: 0.5 });
// Later, reset to defaults
myModule.resetConfig();
Displays the given polygon geometries on the map.
Polygon features to display. Can be a single Feature, array of Features, or a FeatureCollection.
Behavior:
Feature Properties:
title: Used for labels if text config is setcolor: Override fill color per featureSingle polygon:
await geometries.show({
type: 'Feature',
geometry: {
type: 'Polygon',
coordinates: [[[4.88, 52.37], [4.89, 52.37], [4.89, 52.38], [4.88, 52.37]]]
},
properties: {
title: 'Amsterdam Center',
color: '#FF5733'
}
});
Multiple polygons:
await geometries.show({
type: 'FeatureCollection',
features: [
{ type: 'Feature', geometry: {...}, properties: {...} },
{ type: 'Feature', geometry: {...}, properties: {...} }
]
});
From search API response:
import { search } from '@tomtom-international/maps-sdk-js/services';
const result = await search.geometrySearch({
query: 'Amsterdam',
geometryList: [{ type: 'CIRCLE', position: [52.37, 4.89], radius: 5000 }]
});
if (result.results[0].dataSources?.geometry) {
await geometries.show(result.results[0].dataSources.geometry);
}
ProtectedwaitStaticgetMake sure the map is ready before create an instance of the module and any other interaction with the map
The TomTomMap instance.
Optionalconfig: GeometriesModuleConfigThe module optional configuration
Returns a promise with a new instance of this module
Configuration Options:
colorConfig: Fill color and opacity settingslineConfig: Border/outline stylingtextConfig: Label display configurationbeforeLayerConfig: Layer ordering (place above/below other layers)Multiple Instances: You can create multiple GeometriesModule instances on the same map, each managing different sets of geometries with different styles.
Geometries Module for displaying polygon areas with custom styling on the map.
This module enables visualization of geographic areas (polygons) with customizable colors, borders, and labels. Ideal for displaying search results, administrative boundaries, service areas, or any polygon-based geographic data.
Remarks
Features:
Data Format:
Styling:
Example
Basic usage:
Example
Custom styling:
Example
Multiple geometries with different colors:
Example
Event handling:
See
Geometries Guide