import { Store, UIEventSource } from "../Logic/UIEventSource" import BaseUIElement from "./BaseUIElement" import ThemeConfig from "../Models/ThemeConfig/ThemeConfig" import { FeatureSource, IndexedFeatureSource, WritableFeatureSource, } from "../Logic/FeatureSource/FeatureSource" import { OsmConnection } from "../Logic/Osm/OsmConnection" import { Changes } from "../Logic/Osm/Changes" import { ExportableMap, MapProperties } from "../Models/MapProperties" import LayerState from "../Logic/State/LayerState" import { Feature, Geometry, Point, Polygon } from "geojson" import FullNodeDatabaseSource from "../Logic/FeatureSource/TiledFeatureSource/FullNodeDatabaseSource" import { GeoIndexedStoreForLayer } from "../Logic/FeatureSource/Actors/GeoIndexedStore" import LayerConfig from "../Models/ThemeConfig/LayerConfig" import FeatureSwitchState from "../Logic/State/FeatureSwitchState" import { MenuState } from "../Models/MenuState" import OsmObjectDownloader from "../Logic/Osm/OsmObjectDownloader" import { ImageUploadManager } from "../Logic/ImageProviders/ImageUploadManager" import FavouritesFeatureSource from "../Logic/FeatureSource/Sources/FavouritesFeatureSource" import { ProvidedImage } from "../Logic/ImageProviders/ImageProvider" import GeoLocationHandler from "../Logic/Actors/GeoLocationHandler" import ThemeSource from "../Logic/FeatureSource/Sources/ThemeSource" import { Map as MlMap } from "maplibre-gl" import ShowDataLayer from "./Map/ShowDataLayer" import { CombinedFetcher } from "../Logic/Web/NearbyImagesSearch" import SearchState from "../Logic/State/SearchState" import UserRelatedState from "../Logic/State/UserRelatedState" import FeaturePropertiesStore from "../Logic/FeatureSource/Actors/FeaturePropertiesStore" /** * The state needed to render a special Visualisation. */ export interface SpecialVisualizationState { readonly guistate: MenuState readonly theme: ThemeConfig readonly featureSwitches: FeatureSwitchState readonly layerState: LayerState readonly featureProperties: FeaturePropertiesStore readonly indexedFeatures: IndexedFeatureSource & ThemeSource /** * Some features will create a new element that should be displayed. * These can be injected by appending them to this featuresource (and pinging it) */ readonly newFeatures: WritableFeatureSource readonly historicalUserLocations: WritableFeatureSource> readonly osmConnection: OsmConnection readonly featureSwitchUserbadge: Store readonly featureSwitchIsTesting: Store readonly changes: Changes readonly osmObjectDownloader: OsmObjectDownloader /** * State of the main map */ readonly mapProperties: MapProperties & ExportableMap readonly selectedElement: UIEventSource readonly currentView: FeatureSource> readonly favourites: FavouritesFeatureSource /** * If data is currently being fetched from external sources */ readonly dataIsLoading: Store /** * Only needed for 'ReplaceGeometryAction' */ readonly fullNodeDatabase?: FullNodeDatabaseSource readonly perLayer: ReadonlyMap readonly userRelatedState: UserRelatedState readonly imageUploadManager: ImageUploadManager readonly previewedImage: UIEventSource readonly nearbyImageSearcher: CombinedFetcher readonly geolocation: GeoLocationHandler readonly geocodedImages: UIEventSource readonly searchState: SearchState getMatchingLayer(properties: Record): LayerConfig | undefined showCurrentLocationOn(map: Store): ShowDataLayer reportError(message: string | Error | XMLHttpRequest, extramessage?: string): Promise } export interface SpecialVisualization { readonly funcName: string readonly docs: string | BaseUIElement readonly example?: string readonly needsUrls?: string[] | ((args: string[]) => string | string[]) /** * Indicates that this special visualisation will make requests to the 'alLNodesDatabase' and that it thus should be included */ readonly needsNodeDatabase?: boolean readonly args: { name: string defaultValue?: string doc: string required?: false | boolean }[] readonly getLayerDependencies?: (argument: string[]) => string[] structuredExamples?(): { feature: Feature>; args: string[] }[] constr( state: SpecialVisualizationState, tagSource: UIEventSource>, argument: string[], feature: Feature, layer: LayerConfig ): BaseUIElement } export type RenderingSpecification = | string | { func: SpecialVisualization args: string[] style: string }