forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			51 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
			
		
		
	
	
			51 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>
 |