aboutsummaryrefslogtreecommitdiff
path: root/modern/src/mapManager.js
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2020-09-13 15:59:21 -0700
committerAnton Tananaev <anton.tananaev@gmail.com>2020-09-13 15:59:21 -0700
commit6ef7e13621d746482ad906955675541fdd7f0705 (patch)
tree6ed1a28163bd0d7bfeb71c8dac686ad984cb1d88 /modern/src/mapManager.js
parent0c53e226ef1b5ea4f40f0768d20809fac473dccc (diff)
downloadetbsa-traccar-web-6ef7e13621d746482ad906955675541fdd7f0705.tar.gz
etbsa-traccar-web-6ef7e13621d746482ad906955675541fdd7f0705.tar.bz2
etbsa-traccar-web-6ef7e13621d746482ad906955675541fdd7f0705.zip
Add marker callback
Diffstat (limited to 'modern/src/mapManager.js')
-rw-r--r--modern/src/mapManager.js37
1 files changed, 34 insertions, 3 deletions
diff --git a/modern/src/mapManager.js b/modern/src/mapManager.js
index 9c2915b..7c7e292 100644
--- a/modern/src/mapManager.js
+++ b/modern/src/mapManager.js
@@ -40,7 +40,11 @@ const loadIcon = (key, background, url) => {
});
};
-const addLayer = (id, source, icon, text) => {
+const layerClickCallbacks = {};
+const layerMouseEnterCallbacks = {};
+const layerMauseLeaveCallbacks = {};
+
+const addLayer = (id, source, icon, text, onClick) => {
const layer = {
'id': id,
'type': 'symbol',
@@ -66,6 +70,33 @@ const addLayer = (id, source, icon, text) => {
}
}
map.addLayer(layer);
+
+ layerClickCallbacks[id] = onClick;
+ map.on('click', id, onClick);
+
+ layerMouseEnterCallbacks[id] = () => {
+ map.getCanvas().style.cursor = 'pointer';
+ };
+ map.on('mouseenter', id, layerMouseEnterCallbacks[id]);
+
+ layerMauseLeaveCallbacks[id] = () => {
+ map.getCanvas().style.cursor = '';
+ };
+ map.on('mouseleave', id, layerMauseLeaveCallbacks[id]);
+}
+
+const removeLayer = (id, source) => {
+ map.off('click', id, layerClickCallbacks[id]);
+ delete layerClickCallbacks[id];
+
+ map.off('mouseenter', id, layerMouseEnterCallbacks[id]);
+ delete layerMouseEnterCallbacks[id];
+
+ map.off('mouseleave', id, layerMauseLeaveCallbacks[id]);
+ delete layerMauseLeaveCallbacks[id];
+
+ map.removeLayer(id);
+ map.removeSource(source);
}
const calculateBounds = features => {
@@ -138,8 +169,7 @@ const map = new mapboxgl.Map({
map.addControl(new mapboxgl.NavigationControl());
map.on('load', () => {
-
- loadImage('images/background.svg').then((background) => {
+ loadImage('images/background.svg').then(background => {
Promise.all([
loadIcon('icon-marker', background, 'images/icon/marker.svg')
]).then(() => {
@@ -157,5 +187,6 @@ export default {
map,
registerListener,
addLayer,
+ removeLayer,
calculateBounds,
};