import FeatureSource, {Tiled} from "../../Logic/FeatureSource/FeatureSource"; import {UIEventSource} from "../../Logic/UIEventSource"; import {Utils} from "../../Utils"; import LayerConfig from "../../Models/ThemeConfig/LayerConfig"; import ShowDataLayer from "./ShowDataLayer"; import StaticFeatureSource from "../../Logic/FeatureSource/Sources/StaticFeatureSource"; import {GeoOperations} from "../../Logic/GeoOperations"; import {Tiles} from "../../Models/TileRange"; export default class ShowTileInfo { public static readonly styling = new LayerConfig({ id: "tileinfo_styling", title: { render: "Tile {z}/{x}/{y}" }, tagRenderings: [ "all_tags" ], source: { osmTags: "tileId~*" }, color: {"render": "#3c3"}, width: { "render": "1" }, label: { render: "
{count}
" } }, "tileinfo", true) constructor(options: { source: FeatureSource & Tiled, leafletMap: UIEventSource, layer?: LayerConfig, doShowLayer?: UIEventSource }) { const source = options.source const metaFeature: UIEventSource = source.features.map(features => { const bbox = source.bbox const [z, x, y] = Tiles.tile_from_index(source.tileIndex) const box = { "type": "Feature", "properties": { "z": z, "x": x, "y": y, "tileIndex": source.tileIndex, "source": source.name, "count": features.length, tileId: source.name + "/" + source.tileIndex }, "geometry": { "type": "Polygon", "coordinates": [ [ [bbox.minLon, bbox.minLat], [bbox.minLon, bbox.maxLat], [bbox.maxLon, bbox.maxLat], [bbox.maxLon, bbox.minLat], [bbox.minLon, bbox.minLat] ] ] } } const center = GeoOperations.centerpoint(box) return [box, center] }) new ShowDataLayer({ layerToShow: ShowTileInfo.styling, features: new StaticFeatureSource(metaFeature, false), leafletMap: options.leafletMap, doShowLayer: options.doShowLayer }) } }