mapcomplete/UI/BigComponents/ContactLink.svelte

51 lines
1.7 KiB
Svelte
Raw Normal View History

<script lang="ts">
2023-02-03 15:13:05 +01:00
// A contact link indicates how a mapper can contact their local community
// The _properties_ of a community feature
2023-02-03 15:13:05 +01:00
import Locale from "../i18n/Locale.js"
import Translations from "../i18n/Translations"
import ToSvelte from "../Base/ToSvelte.svelte"
import * as native from "../../assets/language_native.json"
import { TypedTranslation } from "../i18n/Translation"
2023-02-03 15:13:05 +01:00
const availableTranslationTyped: TypedTranslation<{ native: string }> =
Translations.t.communityIndex.available
const availableTranslation = availableTranslationTyped.OnEveryLanguage((s, ln) =>
s.replace("{native}", native[ln] ?? ln)
)
export let country: { resources; nameEn: string }
let resources: {
id: string
resolved: Record<string, string>
languageCodes: string[]
type: string
}[] = []
$: resources = Array.from(Object.values(country?.resources ?? {}))
2023-02-03 15:13:05 +01:00
const language = Locale.language
</script>
<div>
{#if country?.nameEn}
<h3>{country?.nameEn}</h3>
{/if}
{#each resources as resource}
2023-06-14 20:44:01 +02:00
<div class="link-underline my-4 flex items-center">
<img
2023-06-14 20:44:01 +02:00
class="m-2 h-8 w-8"
src={`https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/community_index/${resource.type}.svg`}
/>
<div class="flex flex-col">
<a href={resource.resolved.url} target="_blank" rel="noreferrer nofollow" class="font-bold">
{resource.resolved.name ?? resource.resolved.url}
</a>
{resource.resolved?.description}
2023-02-03 15:13:05 +01:00
{#if resource.languageCodes?.indexOf($language) >= 0}
2023-05-14 03:24:13 +02:00
<div class="thanks w-fit">
2023-02-03 15:13:05 +01:00
<ToSvelte construct={() => availableTranslation.Clone()} />
2023-05-14 03:24:13 +02:00
</div>
{/if}
</div>
</div>
{/each}
</div>