forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			62 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import LayoutConfig from "../../../Models/ThemeConfig/LayoutConfig"
 | 
						|
import { WritableFeatureSource } from "../FeatureSource"
 | 
						|
import { ImmutableStore, Store, UIEventSource } from "../../UIEventSource"
 | 
						|
import { Feature, Point } from "geojson"
 | 
						|
import { TagUtils } from "../../Tags/TagUtils"
 | 
						|
import BaseUIElement from "../../../UI/BaseUIElement"
 | 
						|
import { Utils } from "../../../Utils"
 | 
						|
 | 
						|
/**
 | 
						|
 * Highly specialized feature source.
 | 
						|
 * Based on a lon/lat UIEVentSource, will generate the corresponding feature with the correct properties
 | 
						|
 */
 | 
						|
export class LastClickFeatureSource implements WritableFeatureSource {
 | 
						|
    public readonly features: UIEventSource<Feature[]> = new UIEventSource<Feature[]>([])
 | 
						|
 | 
						|
    /**
 | 
						|
     * Must be public: passed as tags into the selected view
 | 
						|
     */
 | 
						|
    public properties: Record<string, string>
 | 
						|
 | 
						|
    constructor(location: Store<{ lon: number; lat: number }>, layout: LayoutConfig) {
 | 
						|
        const allPresets: BaseUIElement[] = []
 | 
						|
        for (const layer of layout.layers)
 | 
						|
            for (let i = 0; i < (layer.presets ?? []).length; i++) {
 | 
						|
                const preset = layer.presets[i]
 | 
						|
                const tags = new ImmutableStore(TagUtils.KVtoProperties(preset.tags))
 | 
						|
                const { html } = layer.mapRendering[0].RenderIcon(tags, false, {
 | 
						|
                    noSize: true,
 | 
						|
                    includeBadges: false,
 | 
						|
                })
 | 
						|
                allPresets.push(html)
 | 
						|
            }
 | 
						|
 | 
						|
        const renderings = Utils.Dedup(
 | 
						|
            allPresets.map((uiElem) =>
 | 
						|
                Utils.runningFromConsole ? "" : uiElem.ConstructElement().innerHTML
 | 
						|
            )
 | 
						|
        )
 | 
						|
 | 
						|
        const properties = {
 | 
						|
            lastclick: "yes",
 | 
						|
            id: "last_click",
 | 
						|
            has_note_layer: layout.layers.some((l) => l.id === "note") ? "yes" : "no",
 | 
						|
            has_presets: layout.layers.some((l) => l.presets?.length > 0) ? "yes" : "no",
 | 
						|
            renderings: renderings.join(""),
 | 
						|
            number_of_presets: "" + renderings.length,
 | 
						|
            first_preset: renderings[0],
 | 
						|
        }
 | 
						|
        this.properties = properties
 | 
						|
        location.addCallbackAndRunD(({ lon, lat }) => {
 | 
						|
            const point = <Feature<Point>>{
 | 
						|
                type: "Feature",
 | 
						|
                properties,
 | 
						|
                geometry: {
 | 
						|
                    type: "Point",
 | 
						|
                    coordinates: [lon, lat],
 | 
						|
                },
 | 
						|
            }
 | 
						|
            this.features.setData([point])
 | 
						|
        })
 | 
						|
    }
 | 
						|
}
 |