MapComplete/src/UI/BigComponents/ThemeButton.svelte

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

81 lines
2.7 KiB
Svelte
Raw Normal View History

2023-02-03 22:28:11 +01:00
<script lang="ts">
import { ImmutableStore, Store } from "../../Logic/UIEventSource"
import { OsmConnection } from "../../Logic/Osm/OsmConnection"
import type { MinimalThemeInformation } from "../../Models/ThemeConfig/ThemeConfig"
import Tr from "../Base/Tr.svelte"
2023-07-28 01:02:31 +02:00
import Translations from "../i18n/Translations"
import Marker from "../Map/Marker.svelte"
2025-01-22 02:26:02 +01:00
import { AndroidPolyfill } from "../../Logic/Web/AndroidPolyfill"
2023-02-03 22:28:11 +01:00
2024-10-19 14:44:55 +02:00
export let theme: MinimalThemeInformation & { isOfficial?: boolean }
let isCustom: boolean = theme.id.startsWith("https://") || theme.id.startsWith("http://")
export let state: { layoutToUse?: { id: string }; osmConnection: OsmConnection }
2023-10-30 13:44:27 +01:00
$: title = Translations.T(
theme.title,
!isCustom && !theme.mustHaveLanguage ? "themes:" + theme.id + ".title" : undefined
)
$: description = Translations.T(theme.shortDescription)
2023-02-03 22:28:11 +01:00
2025-01-22 02:26:02 +01:00
function createUrlDirect(
layout: { id: string; definition?: string },
isCustom: boolean,
2025-01-22 02:26:02 +01:00
isAndroid: boolean,
state?: { layoutToUse?: { id } }
2025-01-22 02:26:02 +01:00
): string {
if (layout === undefined) {
return undefined
}
if (layout.id === undefined) {
console.error("ID is undefined for layout", layout)
return undefined
}
2023-02-03 22:28:11 +01:00
if (layout.id === state?.layoutToUse?.id) {
return undefined
}
2023-02-03 22:28:11 +01:00
let path = window.location.pathname
// Path starts with a '/' and contains everything, e.g. '/dir/dir/page.html'
path = path.substr(0, path.lastIndexOf("/"))
// Path will now contain '/dir/dir', or empty string in case of nothing
if (path === "") {
path = "."
}
2023-02-03 22:28:11 +01:00
let linkPrefix = `${path}/${layout.id.toLowerCase()}.html?`
if (
2025-01-22 02:26:02 +01:00
!isAndroid && (
location.hostname === "localhost" ||
location.hostname === "127.0.0.1" ||
2025-01-22 02:26:02 +01:00
location.port === "1234")
) {
// Redirect to 'theme.html?layout=* instead of 'layout.html'. This is probably a debug run, where the routing does not work
linkPrefix = `${path}/theme.html?layout=${layout.id}&`
}
if (isCustom) {
linkPrefix = `${path}/theme.html?userlayout=${layout.id}&`
}
2023-02-03 22:28:11 +01:00
let hash = ""
if (layout.definition !== undefined) {
hash = "#" + btoa(JSON.stringify(layout.definition))
2023-02-03 22:28:11 +01:00
}
2025-01-22 02:26:02 +01:00
return `${linkPrefix}${hash}`
}
2025-01-22 02:26:02 +01:00
let href = AndroidPolyfill.inAndroid.map(isAndroid => createUrlDirect(theme, isCustom, isAndroid, state))
2023-02-03 22:28:11 +01:00
</script>
2024-10-19 14:44:55 +02:00
<a class="low-interaction my-1 flex w-full items-center text-ellipsis rounded p-1" href={$href}>
<Marker icons={theme.icon} size="block h-8 w-8 sm:h-11 sm:w-11 m-1 sm:mx-2 md:mx-4 shrink-0" />
2024-10-19 14:44:55 +02:00
<span class="flex flex-col overflow-hidden text-ellipsis text-xl font-bold">
<Tr cls="" t={title} />
<Tr cls="subtle text-base" t={description} />
<slot />
</span>
</a>