mapcomplete/UI/Base/Minimap.ts

48 lines
1.6 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import BaseUIElement from "../BaseUIElement"
import Loc from "../../Models/Loc"
import BaseLayer from "../../Models/BaseLayer"
import { UIEventSource } from "../../Logic/UIEventSource"
import { BBox } from "../../Logic/BBox"
export interface MinimapOptions {
2022-09-08 21:40:48 +02:00
background?: UIEventSource<BaseLayer>
location?: UIEventSource<Loc>
bounds?: UIEventSource<BBox>
allowMoving?: boolean
leafletOptions?: any
attribution?: BaseUIElement | boolean
onFullyLoaded?: (leaflet: L.Map) => void
leafletMap?: UIEventSource<any>
lastClickLocation?: UIEventSource<{ lat: number; lon: number }>
addLayerControl?: boolean | false
}
export interface MinimapObj {
2022-09-08 21:40:48 +02:00
readonly leafletMap: UIEventSource<any>
readonly location: UIEventSource<Loc>
readonly bounds: UIEventSource<BBox>
2021-11-07 16:34:51 +01:00
installBounds(factor: number | BBox, showRange?: boolean): void
2022-09-12 20:14:03 +02:00
TakeScreenshot(format): Promise<string>
TakeScreenshot(format: "image"): Promise<string>
2022-10-27 01:50:41 +02:00
TakeScreenshot(format: "blob"): Promise<Blob>
2022-09-12 20:14:03 +02:00
TakeScreenshot(format?: "image" | "blob"): Promise<string | Blob>
}
export default class Minimap {
/**
* A stub implementation. The actual implementation is injected later on, but only in the browser.
* importing leaflet crashes node-ts, which is pretty annoying considering the fact that a lot of scripts use it
*/
2022-09-08 21:40:48 +02:00
private constructor() {}
2022-01-26 21:40:38 +01:00
/**
* Construct a minimap
*/
2022-09-08 21:40:48 +02:00
public static createMiniMap: (options?: MinimapOptions) => BaseUIElement & MinimapObj = (_) => {
throw "CreateMinimap hasn't been initialized yet. Please call MinimapImplementation.initialize()"
}
2022-09-08 21:40:48 +02:00
}