forked from MapComplete/MapComplete
		
	
		
			
	
	
		
			52 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
		
		
			
		
	
	
			52 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
|  | <script lang="ts"> | ||
|  |   import { onMount } from "svelte" | ||
|  |   import { Store } from "../../Logic/UIEventSource" | ||
|  |   import BaseUIElement from "../BaseUIElement" | ||
|  |   import Img from "./Img" | ||
|  |   import Translations from "../i18n/Translations" | ||
|  | 
 | ||
|  |   export let imageUrl: string | BaseUIElement | ||
|  |   export let message: string | BaseUIElement | ||
|  |   export let options: { url?: string | Store<string>; newTab?: boolean; imgSize?: string, extraClasses?: string } | ||
|  | 
 | ||
|  |   let element: HTMLElement | ||
|  |   let href = typeof options?.url == "string" ? options.url : "" | ||
|  | 
 | ||
|  |   onMount(() => { | ||
|  |     if (typeof options?.url != "string" && options?.url != undefined) { | ||
|  |       options.url.addCallbackAndRun((data) => { | ||
|  |         href = data | ||
|  |       }) | ||
|  |     } | ||
|  | 
 | ||
|  |     let img: BaseUIElement | ||
|  |     const imgClasses = "block justify-center flex-none mr-4 " + (options?.imgSize ?? "h-11 w-11") | ||
|  |     if ((imageUrl ?? "") === "") { | ||
|  |       img = undefined | ||
|  |     } else if (typeof imageUrl === "string") { | ||
|  |       img = new Img(imageUrl)?.SetClass(imgClasses) | ||
|  |     } else { | ||
|  |       img = imageUrl?.SetClass(imgClasses) | ||
|  |     } | ||
|  |     if (img != undefined) element.appendChild(img.ConstructElement()) | ||
|  | 
 | ||
|  |     let msg = Translations.W(message)?.SetClass("block text-ellipsis no-images flex-shrink") | ||
|  |     element.appendChild(msg.ConstructElement()) | ||
|  |   }) | ||
|  | </script> | ||
|  | 
 | ||
|  | {#if options?.url == undefined} | ||
|  |   <span bind:this={element} class="{options.extraClasses}"/> | ||
|  | {:else} | ||
|  |   <a {href} class="no-underline" bind:this={element} target={options?.newTab ? "_blank" : ""} /> | ||
|  | {/if} | ||
|  | 
 | ||
|  | <style lang="scss"> | ||
|  |   span, | ||
|  |   a { | ||
|  |     @apply flex p-3 my-2 rounded-lg hover:shadow-xl transition-colors transition-shadow; | ||
|  |     @apply items-center w-full; | ||
|  |     @apply bg-subtle text-black hover:bg-unsubtle; | ||
|  |   } | ||
|  | </style> |