Skip to content

Commit

Permalink
Mark current dark mode context menu item
Browse files Browse the repository at this point in the history
  • Loading branch information
AntonKhorev committed May 10, 2024
1 parent b84f3af commit 1f83a30
Showing 1 changed file with 21 additions and 0 deletions.
21 changes: 21 additions & 0 deletions vendor/assets/leaflet/leaflet.osm.js
Original file line number Diff line number Diff line change
Expand Up @@ -56,13 +56,18 @@ L.OSM.colorSchemeWatcher = {
text: menuItem.text,
callback: function () {
watcher.darkFilter = menuItem.filter;
watcher._managedContextMenuElements.forEach(function (menuElement) {
watcher._updateContextMenuElement(menuElement);
});
if (watcher._prefersDarkScheme()) {
watcher._watchedLayers.forEach(function (watchedLayer) {
watcher._updateLayerDarkScheme(watchedLayer);
});
}
}
});
watcher._decorateContextMenuElement(menuElement, menuItem);
watcher._updateContextMenuElement(menuElement);
watcher._managedContextMenuElements.push(menuElement);
if (!prefersDarkScheme) {
menuElement.hidden = true;
Expand All @@ -87,6 +92,22 @@ L.OSM.colorSchemeWatcher = {
return matchMedia("(prefers-color-scheme: dark)").matches;
},

_decorateContextMenuElement: function (menuElement, menuItem) {
menuElement.dataset.filter = menuItem.filter;
var radio = document.createElement('input');
radio.type = 'radio';
radio.tabIndex = -1;
radio.classList.add('leaflet-contextmenu-icon');
radio.style.pointerEvents = 'none';
radio.style.transform = 'scale(80%)';
menuElement.prepend(radio, " ");
},
_updateContextMenuElement: function (menuElement) {
if ('filter' in menuElement.dataset) {
menuElement.firstChild.checked = menuElement.dataset.filter === this.darkFilter;
}
},

_switchLayerToDarkScheme: function (layer) {
if (layer.options.darkUrl) {
layer.setUrl(layer.options.darkUrl);
Expand Down

0 comments on commit 1f83a30

Please sign in to comment.