forked from MapComplete/MapComplete
43 lines
1.3 KiB
TypeScript
43 lines
1.3 KiB
TypeScript
import * as L from "leaflet"
|
|
import TilesourceConfig from "../../Models/ThemeConfig/TilesourceConfig"
|
|
import { UIEventSource } from "../../Logic/UIEventSource"
|
|
import ShowOverlayLayer from "./ShowOverlayLayer"
|
|
|
|
// TODO port this to maplibre!
|
|
export default class ShowOverlayLayerImplementation {
|
|
public static Implement() {
|
|
ShowOverlayLayer.implementation = ShowOverlayLayerImplementation.AddToMap
|
|
}
|
|
|
|
public static AddToMap(
|
|
config: TilesourceConfig,
|
|
leafletMap: UIEventSource<any>,
|
|
isShown: UIEventSource<boolean> = undefined
|
|
) {
|
|
leafletMap.map((leaflet) => {
|
|
if (leaflet === undefined) {
|
|
return
|
|
}
|
|
|
|
const tileLayer = L.tileLayer(config.source, {
|
|
attribution: "",
|
|
maxZoom: config.maxzoom,
|
|
minZoom: config.minzoom,
|
|
// @ts-ignore
|
|
wmts: false,
|
|
})
|
|
|
|
if (isShown === undefined) {
|
|
tileLayer.addTo(leaflet)
|
|
}
|
|
|
|
isShown?.addCallbackAndRunD((isShown) => {
|
|
if (isShown) {
|
|
tileLayer.addTo(leaflet)
|
|
} else {
|
|
leaflet.removeLayer(tileLayer)
|
|
}
|
|
})
|
|
})
|
|
}
|
|
}
|