35 lines
1.3 KiB
Svelte
35 lines
1.3 KiB
Svelte
|
<script lang="ts">
|
||
|
import { Translation } from "../i18n/Translation";
|
||
|
import SpecialVisualizations from "../SpecialVisualizations";
|
||
|
import { onDestroy } from "svelte";
|
||
|
import Locale from "../i18n/Locale";
|
||
|
import type { RenderingSpecification, SpecialVisualizationState } from "../SpecialVisualization";
|
||
|
import { Utils } from "../../Utils.js";
|
||
|
import type { Feature } from "geojson";
|
||
|
import { UIEventSource } from "../../Logic/UIEventSource.js";
|
||
|
import ToSvelte from "../Base/ToSvelte.svelte";
|
||
|
import FromHtml from "../Base/FromHtml.svelte";
|
||
|
|
||
|
/**
|
||
|
* The 'specialTranslation' renders a `Translation`-object, but interprets the special values as well
|
||
|
*/
|
||
|
export let t: Translation;
|
||
|
export let state: SpecialVisualizationState;
|
||
|
export let tags: UIEventSource<Record<string, string>>;
|
||
|
export let feature: Feature;
|
||
|
let txt: string;
|
||
|
onDestroy(Locale.language.addCallbackAndRunD(l => {
|
||
|
txt = t.textFor(l);
|
||
|
}));
|
||
|
let specs: RenderingSpecification[];
|
||
|
specs = SpecialVisualizations.constructSpecification(txt);
|
||
|
</script>
|
||
|
|
||
|
{#each specs as specpart}
|
||
|
{#if typeof specpart === "string"}
|
||
|
<FromHtml src= {Utils.SubstituteKeys(specpart, $tags)}></FromHtml>
|
||
|
{:else if $tags !== undefined }
|
||
|
<ToSvelte construct={specpart.func.constr(state, tags, specpart.args, feature)}></ToSvelte>
|
||
|
{/if}
|
||
|
{/each}
|