58 lines
1.7 KiB
Svelte
58 lines
1.7 KiB
Svelte
<script lang="ts">
|
|
/**
|
|
* Shows one or more wikidata info boxes or wikipedia articles in a tabbed component.
|
|
*/
|
|
import type { FullWikipediaDetails } from "../../Logic/Web/Wikipedia"
|
|
import Wikipedia from "../../Logic/Web/Wikipedia"
|
|
import Locale from "../i18n/Locale"
|
|
import { Store } from "../../Logic/UIEventSource"
|
|
import { Tab, TabGroup, TabList, TabPanel, TabPanels } from "@rgossiaux/svelte-headlessui"
|
|
import WikipediaTitle from "./WikipediaTitle.svelte"
|
|
import WikipediaArticle from "./WikipediaArticle.svelte"
|
|
import { onDestroy } from "svelte"
|
|
|
|
/**
|
|
* Either a wikidata item or a '<language>:<article>' link
|
|
*/
|
|
export let wikiIds: Store<string[]>
|
|
let wikipediaStores: Store<Store<FullWikipediaDetails>[]> = Locale.language.bind((language) =>
|
|
wikiIds.map((wikiIds) => wikiIds.map((id) => Wikipedia.fetchArticleAndWikidata(id, language)))
|
|
)
|
|
let _wikipediaStores
|
|
onDestroy(
|
|
wikipediaStores.addCallbackAndRunD((wikipediaStores) => {
|
|
_wikipediaStores = wikipediaStores
|
|
})
|
|
)
|
|
</script>
|
|
|
|
{#if _wikipediaStores !== undefined}
|
|
<TabGroup>
|
|
<TabList>
|
|
{#each _wikipediaStores as store (store.tag)}
|
|
<Tab class={({ selected }) => (selected ? "tab-selected" : "tab-unselected")}>
|
|
<WikipediaTitle wikipediaDetails={store} />
|
|
</Tab>
|
|
{/each}
|
|
</TabList>
|
|
<TabPanels>
|
|
{#each _wikipediaStores as store (store.tag)}
|
|
<TabPanel>
|
|
<WikipediaArticle wikipediaDetails={store} />
|
|
</TabPanel>
|
|
{/each}
|
|
</TabPanels>
|
|
</TabGroup>
|
|
{/if}
|
|
|
|
<style>
|
|
.tab-selected {
|
|
background-color: rgb(59 130 246);
|
|
color: rgb(255 255 255);
|
|
}
|
|
|
|
.tab-unselected {
|
|
background-color: rgb(255 255 255);
|
|
color: rgb(0 0 0);
|
|
}
|
|
</style>
|