forked from MapComplete/MapComplete
		
	UX: improve display if OSM.org is down
This commit is contained in:
		
							parent
							
								
									d4dc5f3548
								
							
						
					
					
						commit
						a55bd55b46
					
				
					 6 changed files with 101 additions and 59 deletions
				
			
		|  | @ -5,7 +5,7 @@ | |||
|   import { Translation } from "../i18n/Translation" | ||||
|   import Translations from "../i18n/Translations" | ||||
|   import Tr from "./Tr.svelte" | ||||
|   import { ImmutableStore, UIEventSource } from "../../Logic/UIEventSource" | ||||
|   import { ImmutableStore, Store, UIEventSource } from "../../Logic/UIEventSource" | ||||
|   import Invalid from "../../assets/svg/Invalid.svelte" | ||||
|   import ArrowPath from "@babeard/svelte-heroicons/mini/ArrowPath" | ||||
| 
 | ||||
|  | @ -21,6 +21,10 @@ | |||
|    * Only show the 'successful' state, don't show loading or error messages | ||||
|    */ | ||||
|   export let silentFail: boolean = false | ||||
|   /** | ||||
|    * If set and the OSM-api  fails, do _not_ show any error messages nor the successful state, just hide | ||||
|    */ | ||||
|   export let hiddenFail: boolean = false | ||||
|   let loadingStatus = state?.osmConnection?.loadingStatus ?? new ImmutableStore("logged-in") | ||||
|   let badge = state?.featureSwitches?.featureSwitchEnableLogin ?? new ImmutableStore(true) | ||||
|   const t = Translations.t.general | ||||
|  | @ -30,7 +34,7 @@ | |||
|     unknown: t.loginFailedUnreachableMode, | ||||
|     readonly: t.loginFailedReadonlyMode, | ||||
|   } | ||||
|   const apiState = | ||||
|   const apiState: Store<string> = | ||||
|     state?.osmConnection?.apiIsOnline ?? new ImmutableStore<OsmServiceState>("online") | ||||
| </script> | ||||
| 
 | ||||
|  | @ -39,19 +43,21 @@ | |||
|     <slot name="loading"> | ||||
|       <Loading /> | ||||
|     </slot> | ||||
|   {:else if !silentFail && $loadingStatus === "error"} | ||||
|     <slot name="error"> | ||||
|       <div class="alert flex flex-col items-center"> | ||||
|         <div class="max-w-64 flex items-center"> | ||||
|           <Invalid class="m-2 h-8 w-8 shrink-0" /> | ||||
|           <Tr t={offlineModes[$apiState] ?? t.loginFailedUnreachableMode} /> | ||||
|   {:else if !silentFail && ($loadingStatus === "error" || $apiState === "readonly" || $apiState === "offline")} | ||||
|     {#if !hiddenFail} | ||||
|       <slot name="error"> | ||||
|         <div class="alert flex flex-col items-center"> | ||||
|           <div class="max-w-64 flex items-center"> | ||||
|             <Invalid class="m-2 h-8 w-8 shrink-0" /> | ||||
|             <Tr t={offlineModes[$apiState] ?? t.loginFailedUnreachableMode} /> | ||||
|           </div> | ||||
|           <button class="h-fit" on:click={() => state.osmConnection.AttemptLogin()}> | ||||
|             <ArrowPath class="h-6 w-6" /> | ||||
|             <Tr t={t.retry} /> | ||||
|           </button> | ||||
|         </div> | ||||
|         <button class="h-fit" on:click={() => state.osmConnection.AttemptLogin()}> | ||||
|           <ArrowPath class="h-6 w-6" /> | ||||
|           <Tr t={t.retry} /> | ||||
|         </button> | ||||
|       </div> | ||||
|     </slot> | ||||
|       </slot> | ||||
|     {/if} | ||||
|   {:else if $loadingStatus === "logged-in"} | ||||
|     <slot /> | ||||
|   {:else if !silentFail && $loadingStatus === "not-attempted"} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue