forked from MapComplete/MapComplete
32 lines
1.1 KiB
Svelte
32 lines
1.1 KiB
Svelte
|
<script lang="ts">
|
||
|
|
||
|
import Translations from "../i18n/Translations"
|
||
|
import Svg from "../../Svg"
|
||
|
import {Store} from "../../Logic/UIEventSource";
|
||
|
import Tr from "../Base/Tr.svelte";
|
||
|
import ToSvelte from "../Base/ToSvelte.svelte";
|
||
|
|
||
|
/*
|
||
|
A subtleButton which opens mapillary in a new tab at the current location
|
||
|
*/
|
||
|
|
||
|
export let mapProperties: {
|
||
|
readonly zoom: Store<number>,
|
||
|
readonly location: Store<{ lon: number, lat: number }>
|
||
|
}
|
||
|
let location = mapProperties.location
|
||
|
let zoom = mapProperties.zoom
|
||
|
let mapillaryLink = `https://www.mapillary.com/app/?focus=map&lat=${
|
||
|
$location?.lat ?? 0
|
||
|
}&lng=${$location?.lon ?? 0}&z=${Math.max(($zoom ?? 2) - 1, 1)}`
|
||
|
|
||
|
</script>
|
||
|
|
||
|
<a class="flex button items-center" href={mapillaryLink} target="_blank">
|
||
|
<ToSvelte construct={() =>Svg.mapillary_black_svg().SetClass("w-12 h-12 m-2 mr-4 shrink-0")}/>
|
||
|
<div class="flex flex-col">
|
||
|
<Tr t={Translations.t.general.attribution.openMapillary}/>
|
||
|
<Tr cls="subtle" t={ Translations.t.general.attribution.mapillaryHelp}/>
|
||
|
</div>
|
||
|
</a>
|