forked from MapComplete/MapComplete
		
	
		
			
	
	
		
			43 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
		
		
			
		
	
	
			43 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
|  | <script lang="ts"> | ||
|  |   import { Store, UIEventSource } from "../../../Logic/UIEventSource"; | ||
|  |   import type { MapProperties } from "../../../Models/MapProperties"; | ||
|  |   import { Map as MlMap } from "maplibre-gl"; | ||
|  |   import { MapLibreAdaptor } from "../../Map/MapLibreAdaptor"; | ||
|  |   import MaplibreMap from "../../Map/MaplibreMap.svelte"; | ||
|  |   import Svg from "../../../Svg"; | ||
|  |   import ToSvelte from "../../Base/ToSvelte.svelte"; | ||
|  |   import DragInvitation from "../../Base/DragInvitation.svelte"; | ||
|  | 
 | ||
|  |   /** | ||
|  |    * A visualisation to pick a direction on a map background | ||
|  |    */ | ||
|  |   export let value: UIEventSource<{lon: number, lat: number}>; | ||
|  |   export let mapProperties: Partial<MapProperties> & { readonly location: UIEventSource<{ lon: number; lat: number }> }; | ||
|  |   /** | ||
|  |    * Called when setup is done, cna be used to add layrs to the map | ||
|  |    */ | ||
|  |   export let onCreated : (value: Store<{lon: number, lat: number}> , map: Store<MlMap>, mapProperties: MapProperties ) => void | ||
|  |    | ||
|  |   let map: UIEventSource<MlMap> = new UIEventSource<MlMap>(undefined); | ||
|  |   let mla = new MapLibreAdaptor(map, mapProperties); | ||
|  |   mla.allowMoving.setData(true) | ||
|  |   mla.allowZooming.setData(true) | ||
|  | 
 | ||
|  |   if(onCreated){ | ||
|  |     onCreated(value, map, mla) | ||
|  |   } | ||
|  | </script> | ||
|  | 
 | ||
|  | <div class="relative h-32 cursor-pointer overflow-hidden"> | ||
|  |   <div class="w-full h-full absolute top-0 left-0 cursor-pointer"> | ||
|  |     <MaplibreMap {map} attribution={false}></MaplibreMap> | ||
|  |   </div> | ||
|  | 
 | ||
|  |   <div class="w-full h-full absolute top-0 left-0 p-8 pointer-events-none opacity-50"> | ||
|  |       <ToSvelte construct={() => Svg.move_arrows_svg().SetClass("h-full")}></ToSvelte> | ||
|  |   </div> | ||
|  |    | ||
|  |   <DragInvitation></DragInvitation> | ||
|  | 
 | ||
|  | </div> |