MapComplete/UI/BigComponents/StateIndicator.svelte

42 lines
1.1 KiB
Svelte
Raw Normal View History

<script lang="ts">
2023-06-15 16:12:46 +02:00
import ThemeViewState from "../../Models/ThemeViewState"
import Translations from "../i18n/Translations"
import Tr from "../Base/Tr.svelte"
import Loading from "../Base/Loading.svelte"
2023-06-15 16:12:46 +02:00
export let state: ThemeViewState
/**
* Gives the contributor some feedback based on the current state:
* - is data loading?
* - Is all data hidden due to filters?
* - Is no data in view?
*/
2023-06-15 16:12:46 +02:00
let dataIsLoading = state.dataIsLoading
let currentState = state.hasDataInView
currentState.data === ""
const t = Translations.t.centerMessage
</script>
2023-06-15 16:12:46 +02:00
{#if $currentState === "has-visible-features"}
2023-06-15 16:12:46 +02:00
<!-- don't show anything -->
{:else if $currentState === "zoom-to-low"}
2023-06-15 16:12:46 +02:00
<div class="alert w-fit p-4">
<Tr t={t.zoomIn} />
</div>
{:else if $currentState === "all-filtered-away"}
2023-06-15 16:12:46 +02:00
<div class="alert w-fit p-4">
<Tr t={t.allFilteredAway} />
</div>
{:else if $dataIsLoading}
2023-06-15 16:12:46 +02:00
<div class="alert w-fit p-4">
<Loading>
<Tr t={Translations.t.centerMessage.loadingData} />
</Loading>
</div>
{:else if $currentState === "no-data"}
2023-06-15 16:12:46 +02:00
<div class="alert w-fit p-4">
<Tr t={t.noData} />
</div>
{/if}