| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | <script lang="ts"> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // All the relevant links | 
					
						
							|  |  |  |   import ThemeViewState from "../../Models/ThemeViewState" | 
					
						
							|  |  |  |   import Translations from "../i18n/Translations" | 
					
						
							|  |  |  |   import { CogIcon, EyeIcon, HeartIcon } from "@rgossiaux/svelte-heroicons/solid" | 
					
						
							|  |  |  |   import Page from "../Base/Page.svelte" | 
					
						
							|  |  |  |   import PrivacyPolicy from "./PrivacyPolicy.svelte" | 
					
						
							|  |  |  |   import Tr from "../Base/Tr.svelte" | 
					
						
							|  |  |  |   import If from "../Base/If.svelte" | 
					
						
							|  |  |  |   import CommunityIndexView from "./CommunityIndexView.svelte" | 
					
						
							|  |  |  |   import Community from "../../assets/svg/Community.svelte" | 
					
						
							|  |  |  |   import LoginToggle from "../Base/LoginToggle.svelte" | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |   import { CloseButton, Sidebar } from "flowbite-svelte" | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |   import HotkeyTable from "./HotkeyTable.svelte" | 
					
						
							|  |  |  |   import { Utils } from "../../Utils" | 
					
						
							|  |  |  |   import Constants from "../../Models/Constants" | 
					
						
							|  |  |  |   import Mastodon from "../../assets/svg/Mastodon.svelte" | 
					
						
							|  |  |  |   import Liberapay from "../../assets/svg/Liberapay.svelte" | 
					
						
							|  |  |  |   import DocumentMagnifyingGlass from "@babeard/svelte-heroicons/outline/DocumentMagnifyingGlass" | 
					
						
							|  |  |  |   import DocumentChartBar from "@babeard/svelte-heroicons/outline/DocumentChartBar" | 
					
						
							|  |  |  |   import OpenIdEditor from "./OpenIdEditor.svelte" | 
					
						
							|  |  |  |   import OpenJosm from "../Base/OpenJosm.svelte" | 
					
						
							|  |  |  |   import MapillaryLink from "./MapillaryLink.svelte" | 
					
						
							|  |  |  |   import Github from "../../assets/svg/Github.svelte" | 
					
						
							|  |  |  |   import Bug from "../../assets/svg/Bug.svelte" | 
					
						
							|  |  |  |   import Add from "../../assets/svg/Add.svelte" | 
					
						
							|  |  |  |   import CopyrightPanel from "./CopyrightPanel.svelte" | 
					
						
							|  |  |  |   import CopyrightAllIcons from "./CopyrightAllIcons.svelte" | 
					
						
							|  |  |  |   import LanguagePicker from "../InputElement/LanguagePicker.svelte" | 
					
						
							|  |  |  |   import LoginButton from "../Base/LoginButton.svelte" | 
					
						
							|  |  |  |   import SelectedElementView from "./SelectedElementView.svelte" | 
					
						
							|  |  |  |   import LayerConfig from "../../Models/ThemeConfig/LayerConfig" | 
					
						
							|  |  |  |   import type { LayerConfigJson } from "../../Models/ThemeConfig/Json/LayerConfigJson" | 
					
						
							|  |  |  |   import usersettings from "../../assets/generated/layers/usersettings.json" | 
					
						
							|  |  |  |   import UserRelatedState from "../../Logic/State/UserRelatedState" | 
					
						
							|  |  |  |   import ArrowDownTray from "@babeard/svelte-heroicons/mini/ArrowDownTray" | 
					
						
							|  |  |  |   import DownloadPanel from "../DownloadFlow/DownloadPanel.svelte" | 
					
						
							|  |  |  |   import Favourites from "../Favourites/Favourites.svelte" | 
					
						
							|  |  |  |   import ReviewsOverview from "../Reviews/ReviewsOverview.svelte" | 
					
						
							|  |  |  |   import Share from "@babeard/svelte-heroicons/solid/Share" | 
					
						
							|  |  |  |   import ShareScreen from "./ShareScreen.svelte" | 
					
						
							|  |  |  |   import FilterPage from "./FilterPage.svelte" | 
					
						
							|  |  |  |   import RasterLayerOverview from "../Map/RasterLayerOverview.svelte" | 
					
						
							|  |  |  |   import ThemeIntroPanel from "./ThemeIntroPanel.svelte" | 
					
						
							|  |  |  |   import Marker from "../Map/Marker.svelte" | 
					
						
							|  |  |  |   import LogoutButton from "../Base/LogoutButton.svelte" | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  |   import { BoltIcon } from "@babeard/svelte-heroicons/mini" | 
					
						
							|  |  |  |   import Copyright from "../../assets/svg/Copyright.svelte" | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |   import Pencil from "../../assets/svg/Pencil.svelte" | 
					
						
							|  |  |  |   import Squares2x2 from "@babeard/svelte-heroicons/mini/Squares2x2" | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export let state: ThemeViewState | 
					
						
							|  |  |  |   let userdetails = state.osmConnection.userDetails | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let usersettingslayer = new LayerConfig(<LayerConfigJson>usersettings, "usersettings", true) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let layout = state.layout | 
					
						
							|  |  |  |   let featureSwitches = state.featureSwitches | 
					
						
							|  |  |  |   let showHome = featureSwitches.featureSwitchBackToThemeOverview | 
					
						
							|  |  |  |   let pg = state.guistate.pageStates | 
					
						
							|  |  |  |   export let onlyLink: boolean | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |   const t = Translations.t.general.menu | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  | <div class="flex flex-col p-2 sm:p-3 low-interaction gap-y-2 sm:gap-y-3 h-screen overflow-y-auto"> | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |   <div class="flex justify-between"> | 
					
						
							|  |  |  |     <h2> | 
					
						
							|  |  |  |       <Tr t={t.title}/> | 
					
						
							|  |  |  |     </h2> | 
					
						
							|  |  |  |     <CloseButton on:click={() => {pg.menu.set(false)}} /> | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  |   {#if $showHome} | 
					
						
							|  |  |  |     <a class="flex button primary" href={Utils.HomepageLink()}> | 
					
						
							|  |  |  |       <Squares2x2 class="h-10 w-10" /> | 
					
						
							|  |  |  |       {#if Utils.isIframe} | 
					
						
							|  |  |  |         <Tr t={Translations.t.general.seeIndex} /> | 
					
						
							|  |  |  |       {:else} | 
					
						
							|  |  |  |         <Tr t={Translations.t.general.backToIndex} /> | 
					
						
							|  |  |  |       {/if} | 
					
						
							|  |  |  |     </a> | 
					
						
							|  |  |  |   {/if} | 
					
						
							| 
									
										
										
										
											2024-08-31 12:29:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   <!-- User related: avatar, settings, favourits, logout --> | 
					
						
							|  |  |  |   <div class="sidebar-unit"> | 
					
						
							|  |  |  |     <LoginToggle {state}> | 
					
						
							|  |  |  |       <LoginButton osmConnection={state.osmConnection} slot="not-logged-in"></LoginButton> | 
					
						
							|  |  |  |       <div class="flex gap-x-4 items-center"> | 
					
						
							|  |  |  |         {#if $userdetails.img} | 
					
						
							|  |  |  |           <img src={$userdetails.img} class="rounded-full w-14 h-14" /> | 
					
						
							|  |  |  |         {/if} | 
					
						
							|  |  |  |         <b>{$userdetails.name}</b> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </LoginToggle> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <Page {onlyLink} shown={pg.usersettings}> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       <svelte:fragment slot="header"> | 
					
						
							|  |  |  |         <CogIcon/> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <Tr t={UserRelatedState.usersettingsConfig.title.GetRenderValue({})} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <!-- All shown components are set by 'usersettings.json', which happily uses some special visualisations created specifically for it --> | 
					
						
							|  |  |  |       <LoginToggle {state}> | 
					
						
							|  |  |  |         <div class="flex flex-col" slot="not-logged-in"> | 
					
						
							|  |  |  |           <LanguagePicker availableLanguages={layout.language} /> | 
					
						
							|  |  |  |           <Tr cls="alert" t={Translations.t.userinfo.notLoggedIn} /> | 
					
						
							|  |  |  |           <LoginButton clss="primary" osmConnection={state.osmConnection} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <SelectedElementView | 
					
						
							|  |  |  |           highlightedRendering={state.guistate.highlightedUserSetting} | 
					
						
							|  |  |  |           layer={usersettingslayer} | 
					
						
							|  |  |  |           selectedElement={{ | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |                 type: "Feature", | 
					
						
							|  |  |  |                 properties: { id: "settings" }, | 
					
						
							|  |  |  |                 geometry: { type: "Point", coordinates: [0, 0] }, | 
					
						
							|  |  |  |               }} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |           {state} | 
					
						
							|  |  |  |           tags={state.userRelatedState.preferencesAsTags} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       </LoginToggle> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     </Page> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <LoginToggle {state}> | 
					
						
							|  |  |  |       <Page {onlyLink} shown={pg.favourites}> | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |         <svelte:fragment slot="header"> | 
					
						
							|  |  |  |           <HeartIcon /> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |           <Tr t={Translations.t.favouritePoi.tab} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |         </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <h3> | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |           <Tr t={Translations.t.favouritePoi.title} /> | 
					
						
							|  |  |  |         </h3> | 
					
						
							|  |  |  |         <div> | 
					
						
							|  |  |  |           <Favourites {state} /> | 
					
						
							|  |  |  |           <h3> | 
					
						
							|  |  |  |             <Tr t={Translations.t.reviews.your_reviews} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  |           </h3> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |           <ReviewsOverview {state} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       </Page> | 
					
						
							|  |  |  |       <div class="self-end"> | 
					
						
							|  |  |  |         <LogoutButton osmConnection={state.osmConnection} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     </LoginToggle> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <LanguagePicker /> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |   <!-- Theme related: documentation links, download, ... --> | 
					
						
							|  |  |  |   <div class="sidebar-unit"> | 
					
						
							|  |  |  |     <h3> | 
					
						
							|  |  |  |       <Tr t={t.aboutCurrentThemeTitle} /> | 
					
						
							|  |  |  |     </h3> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <Page {onlyLink} shown={pg.about_theme}> | 
					
						
							|  |  |  |       <div slot="link" class="flex"> | 
					
						
							|  |  |  |         <Marker icons={layout.icon} size="h-6 w-6 mr-2" /> | 
					
						
							|  |  |  |         <Tr t={t.showIntroduction} /> | 
					
						
							|  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       <svelte:fragment  slot="header"> | 
					
						
							|  |  |  |         <Marker icons={layout.icon} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <Tr t={layout.title} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <ThemeIntroPanel {state} /> | 
					
						
							|  |  |  |     </Page> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <FilterPage {onlyLink} {state} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <RasterLayerOverview {onlyLink} {state} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <Page {onlyLink} shown={pg.share}> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       <svelte:fragment slot="header"> | 
					
						
							|  |  |  |         <Share/> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <Tr t={Translations.t.general.sharescreen.title} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <ShareScreen {state} /> | 
					
						
							|  |  |  |     </Page> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     {#if state.featureSwitches.featureSwitchEnableExport} | 
					
						
							|  |  |  |       <Page {onlyLink} shown={pg.download}> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |         <svelte:fragment slot="header"> | 
					
						
							|  |  |  |           <ArrowDownTray  /> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |           <Tr t={Translations.t.general.download.title} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |         </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <DownloadPanel {state} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  |       </Page> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     {/if} | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     {#if layout.official} | 
					
						
							|  |  |  |       <a | 
					
						
							|  |  |  |         class="flex" | 
					
						
							|  |  |  |         href={"https://github.com/pietervdvn/MapComplete/blob/develop/Docs/Themes/" + | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         layout.id + | 
					
						
							|  |  |  |         ".md"} | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         target="_blank" | 
					
						
							|  |  |  |       > | 
					
						
							|  |  |  |         <DocumentMagnifyingGlass class="h-6 w-6" /> | 
					
						
							|  |  |  |         <Tr | 
					
						
							|  |  |  |           t={Translations.t.general.attribution.openThemeDocumentation.Subs({ | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |           name: layout.title, | 
					
						
							|  |  |  |         })} | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         /> | 
					
						
							|  |  |  |       </a> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <a class="flex" href={Utils.OsmChaLinkFor(31, layout.id)} target="_blank"> | 
					
						
							|  |  |  |         <DocumentChartBar class="h-6 w-6" /> | 
					
						
							|  |  |  |         <Tr t={Translations.t.general.attribution.openOsmcha.Subs({ theme: layout.title })} /> | 
					
						
							|  |  |  |       </a> | 
					
						
							|  |  |  |     {/if} | 
					
						
							|  |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |   <!-- Other links and tools for the given location: open iD/JOSM; community index, ... --> | 
					
						
							|  |  |  |   <div class="sidebar-unit"> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <h3> | 
					
						
							|  |  |  |       <Tr t={t.moreUtilsTitle} /> | 
					
						
							|  |  |  |     </h3> | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <Page {onlyLink} shown={pg.community_index}> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       <svelte:fragment slot="header"> | 
					
						
							|  |  |  |         <Community/> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <Tr t={Translations.t.communityIndex.title} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <CommunityIndexView location={state.mapProperties.location} /> | 
					
						
							|  |  |  |     </Page> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <If condition={featureSwitches.featureSwitchEnableLogin}> | 
					
						
							|  |  |  |       <OpenIdEditor mapProperties={state.mapProperties} /> | 
					
						
							|  |  |  |       <OpenJosm {state} /> | 
					
						
							|  |  |  |       <MapillaryLink large={false} mapProperties={state.mapProperties} /> | 
					
						
							|  |  |  |     </If> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |   <!-- About MC: various outward links, legal info, ... --> | 
					
						
							|  |  |  |   <div class="sidebar-unit"> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <h3> | 
					
						
							|  |  |  |       <Tr t={Translations.t.general.menu.aboutMapComplete} /> | 
					
						
							|  |  |  |     </h3> | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |     <a | 
					
						
							|  |  |  |       class="flex" | 
					
						
							|  |  |  |       href={window.location.protocol + "//" + window.location.host + "/studio.html"} | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       <Pencil class="mr-2 h-6 w-6" /> | 
					
						
							|  |  |  |       <Tr t={Translations.t.general.morescreen.createYourOwnTheme} /> | 
					
						
							|  |  |  |     </a> | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |     <div class="hidden-on-mobile w-full"> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <Page {onlyLink} shown={pg.hotkeys}> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |         <svelte:fragment  slot="header"> | 
					
						
							|  |  |  |           <BoltIcon /> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |           <Tr t={ Translations.t.hotkeyDocumentation.title} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |         </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <HotkeyTable /> | 
					
						
							|  |  |  |       </Page> | 
					
						
							|  |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <a class="flex" href="https://github.com/pietervdvn/MapComplete/" target="_blank"> | 
					
						
							|  |  |  |       <Github class="h-6 w-6" /> | 
					
						
							|  |  |  |       <Tr t={Translations.t.general.attribution.gotoSourceCode} /> | 
					
						
							|  |  |  |     </a> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <a class="flex" href="https://github.com/pietervdvn/MapComplete/issues" target="_blank"> | 
					
						
							|  |  |  |       <Bug class="h-6 w-6" /> | 
					
						
							|  |  |  |       <Tr t={Translations.t.general.attribution.openIssueTracker} /> | 
					
						
							|  |  |  |     </a> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <a class="flex" href="https://en.osm.town/@MapComplete" target="_blank"> | 
					
						
							|  |  |  |       <Mastodon class="h-6 w-6" /> | 
					
						
							|  |  |  |       <Tr t={Translations.t.general.attribution.followOnMastodon} /> | 
					
						
							|  |  |  |     </a> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <a class="flex" href="https://liberapay.com/pietervdvn/" target="_blank"> | 
					
						
							|  |  |  |       <Liberapay class="h-6 w-6" /> | 
					
						
							|  |  |  |       <Tr t={Translations.t.general.attribution.donate} /> | 
					
						
							|  |  |  |     </a> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <Page {onlyLink} shown={pg.copyright}> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       <svelte:fragment slot="header"> | 
					
						
							|  |  |  |         <Copyright /> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <Tr t={Translations.t.general.attribution.attributionTitle} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <CopyrightPanel {state} /> | 
					
						
							|  |  |  |     </Page> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <Page {onlyLink} shown={pg.copyright_icons}> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       <svelte:fragment slot="header" > | 
					
						
							|  |  |  |         <Copyright/> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <Tr t={ Translations.t.general.attribution.iconAttribution.title} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <CopyrightAllIcons {state} /> | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     </Page> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <Page {onlyLink} shown={pg.privacy}> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       <svelte:fragment slot="header"> | 
					
						
							|  |  |  |         <EyeIcon /> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         <Tr t={Translations.t.privacy.title} /> | 
					
						
							| 
									
										
										
										
											2024-09-02 11:46:45 +02:00
										 |  |  |       </svelte:fragment> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |       <PrivacyPolicy {state} /> | 
					
						
							|  |  |  |     </Page> | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     <div class="subtle self-end"> | 
					
						
							|  |  |  |       {Constants.vNumber} | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  | </div> | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |     :global(.sidebar-unit) { | 
					
						
							|  |  |  |         display: flex; | 
					
						
							|  |  |  |         flex-direction: column; | 
					
						
							|  |  |  |         row-gap: 0.25rem; | 
					
						
							|  |  |  |         background: var(--background-color); | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         padding: 0.5rem; | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |         border-radius: 0.5rem; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |     :global(.sidebar-unit > h3) { | 
					
						
							|  |  |  |         margin-top: 0; | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         margin-bottom: 0.5rem; | 
					
						
							|  |  |  |         padding: 0.25rem; | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-08-29 16:19:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     :global(.sidebar-button svg, .sidebar-button img) { | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |         width: 1.5rem; | 
					
						
							|  |  |  |         height: 1.5rem; | 
					
						
							|  |  |  |         margin-right: 0.5rem; | 
					
						
							|  |  |  |         flex-shrink: 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     :global(.sidebar-button .weblate-link > svg) { | 
					
						
							|  |  |  |         width: 0.75rem; | 
					
						
							|  |  |  |         height: 0.75rem; | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |         flex-shrink: 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |     :global(.sidebar-button, .sidebar-unit > a) { | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |         display: flex; | 
					
						
							|  |  |  |         align-items: center; | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |         border-radius: 0.25rem !important; | 
					
						
							|  |  |  |         padding: 0.4rem 0.75rem !important; | 
					
						
							|  |  |  |         text-decoration: none !important; | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |         width: 100%; | 
					
						
							|  |  |  |         text-align: start; | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  |     :global(.sidebar-button > svg , .sidebar-button > img, .sidebar-unit a > img, .sidebar-unit > a svg) { | 
					
						
							|  |  |  |         margin-right: 0.5rem; | 
					
						
							|  |  |  |         flex-shrink: 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     :global(.sidebar-button:hover, .sidebar-unit > a:hover) { | 
					
						
							|  |  |  |         background: var(--low-interaction-background) !important; | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 23:11:59 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  | </style> |