forked from MapComplete/MapComplete
58 lines
1.9 KiB
Svelte
58 lines
1.9 KiB
Svelte
<script lang="ts">
|
|
/**
|
|
* The comparison tool loads json-data from a speficied URL, eventually post-processes it
|
|
* and compares it with the current object
|
|
*/
|
|
import Loading from "../Base/Loading.svelte"
|
|
import type { SpecialVisualizationState } from "../SpecialVisualization"
|
|
import { Store, UIEventSource } from "../../Logic/UIEventSource"
|
|
import ComparisonTable from "./ComparisonTable.svelte"
|
|
import LayerConfig from "../../Models/ThemeConfig/LayerConfig"
|
|
import type { Feature } from "geojson"
|
|
import type { OsmTags } from "../../Models/OsmFeature"
|
|
import Translations from "../i18n/Translations"
|
|
import Tr from "../Base/Tr.svelte"
|
|
import AccordionSingle from "../Flowbite/AccordionSingle.svelte"
|
|
import GlobeAlt from "@babeard/svelte-heroicons/mini/GlobeAlt"
|
|
|
|
export let externalData: Store<
|
|
| { success: { content: Record<string, string> } }
|
|
| { error: string }
|
|
| undefined
|
|
| null /* null if no URL is found, undefined if loading*/
|
|
>
|
|
export let state: SpecialVisualizationState
|
|
export let tags: UIEventSource<OsmTags>
|
|
export let layer: LayerConfig
|
|
export let feature: Feature
|
|
export let readonly = false
|
|
export let sourceUrl: Store<string>
|
|
|
|
export let collapsed : boolean
|
|
</script>
|
|
|
|
{#if !$sourceUrl}
|
|
<!-- empty block -->
|
|
{:else if $externalData === undefined}
|
|
<Loading />
|
|
{:else if $externalData["error"] !== undefined}
|
|
<div class="subtle italic low-interaction p-2 px-4 rounded">
|
|
<Tr t={Translations.t.external.error} />
|
|
</div>
|
|
{:else if $externalData["success"] !== undefined}
|
|
<AccordionSingle>
|
|
<span slot="header" class="flex">
|
|
<GlobeAlt class="w-6 h-6"/>
|
|
<Tr t={Translations.t.external.title}/>
|
|
</span>
|
|
<ComparisonTable
|
|
externalProperties={$externalData["success"]}
|
|
{state}
|
|
{feature}
|
|
{layer}
|
|
{tags}
|
|
{readonly}
|
|
sourceUrl={$sourceUrl}
|
|
/>
|
|
</AccordionSingle>
|
|
{/if}
|