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
        })
    }
}