forked from MapComplete/MapComplete
		
	UX: improve messages when images are failing
This commit is contained in:
		
							parent
							
								
									6563476c65
								
							
						
					
					
						commit
						6201a2bdf1
					
				
					 4 changed files with 71 additions and 43 deletions
				
			
		|  | @ -777,10 +777,6 @@ video { | ||||||
|   float: left; |   float: left; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .m-8 { |  | ||||||
|   margin: 2rem; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .m-4 { | .m-4 { | ||||||
|   margin: 1rem; |   margin: 1rem; | ||||||
| } | } | ||||||
|  | @ -793,6 +789,10 @@ video { | ||||||
|   margin: 0px; |   margin: 0px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .m-8 { | ||||||
|  |   margin: 2rem; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .m-2 { | .m-2 { | ||||||
|   margin: 0.5rem; |   margin: 0.5rem; | ||||||
| } | } | ||||||
|  | @ -896,6 +896,10 @@ video { | ||||||
|   margin-right: 4rem; |   margin-right: 4rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .mb-4 { | ||||||
|  |   margin-bottom: 1rem; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .mt-4 { | .mt-4 { | ||||||
|   margin-top: 1rem; |   margin-top: 1rem; | ||||||
| } | } | ||||||
|  | @ -928,10 +932,6 @@ video { | ||||||
|   margin-right: 0.25rem; |   margin-right: 0.25rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .mb-4 { |  | ||||||
|   margin-bottom: 1rem; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .ml-1 { | .ml-1 { | ||||||
|   margin-left: 0.25rem; |   margin-left: 0.25rem; | ||||||
| } | } | ||||||
|  | @ -972,10 +972,6 @@ video { | ||||||
|   margin-left: -1.5rem; |   margin-left: -1.5rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .mr-3 { |  | ||||||
|   margin-right: 0.75rem; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .mt-12 { | .mt-12 { | ||||||
|   margin-top: 3rem; |   margin-top: 3rem; | ||||||
| } | } | ||||||
|  | @ -1606,14 +1602,14 @@ video { | ||||||
|   word-break: break-all; |   word-break: break-all; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .rounded-full { |  | ||||||
|   border-radius: 9999px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .rounded { | .rounded { | ||||||
|   border-radius: 0.25rem; |   border-radius: 0.25rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .rounded-full { | ||||||
|  |   border-radius: 9999px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .rounded-xl { | .rounded-xl { | ||||||
|   border-radius: 0.75rem; |   border-radius: 0.75rem; | ||||||
| } | } | ||||||
|  | @ -1819,6 +1815,10 @@ video { | ||||||
|   padding: 1rem; |   padding: 1rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .p-0 { | ||||||
|  |   padding: 0px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .p-2 { | .p-2 { | ||||||
|   padding: 0.5rem; |   padding: 0.5rem; | ||||||
| } | } | ||||||
|  | @ -1831,10 +1831,6 @@ video { | ||||||
|   padding: 0.125rem; |   padding: 0.125rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .p-0 { |  | ||||||
|   padding: 0px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .p-12 { | .p-12 { | ||||||
|   padding: 3rem; |   padding: 3rem; | ||||||
| } | } | ||||||
|  | @ -1941,6 +1937,11 @@ video { | ||||||
|   line-height: 1.75rem; |   line-height: 1.75rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .text-xs { | ||||||
|  |   font-size: 0.75rem; | ||||||
|  |   line-height: 1rem; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .text-base { | .text-base { | ||||||
|   font-size: 1rem; |   font-size: 1rem; | ||||||
|   line-height: 1.5rem; |   line-height: 1.5rem; | ||||||
|  | @ -1951,11 +1952,6 @@ video { | ||||||
|   line-height: 1.75rem; |   line-height: 1.75rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .text-xs { |  | ||||||
|   font-size: 0.75rem; |  | ||||||
|   line-height: 1rem; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .text-3xl { | .text-3xl { | ||||||
|   font-size: 1.875rem; |   font-size: 1.875rem; | ||||||
|   line-height: 2.25rem; |   line-height: 2.25rem; | ||||||
|  |  | ||||||
|  | @ -101,7 +101,6 @@ export class ImageUploadManager { | ||||||
|             "osmid:" + tags.id, |             "osmid:" + tags.id, | ||||||
|         ].join("\n") |         ].join("\n") | ||||||
| 
 | 
 | ||||||
|         console.log("Upload done, creating ") |  | ||||||
|         const action = await this.uploadImageWithLicense( |         const action = await this.uploadImageWithLicense( | ||||||
|             featureId, |             featureId, | ||||||
|             title, |             title, | ||||||
|  | @ -110,6 +109,9 @@ export class ImageUploadManager { | ||||||
|             targetKey, |             targetKey, | ||||||
|             tags?.data?.["_orig_theme"] |             tags?.data?.["_orig_theme"] | ||||||
|         ) |         ) | ||||||
|  |         if (!action) { | ||||||
|  |             return | ||||||
|  |         } | ||||||
|         if (!isNaN(Number(featureId))) { |         if (!isNaN(Number(featureId))) { | ||||||
|             // This is a map note
 |             // This is a map note
 | ||||||
|             const url = action._url |             const url = action._url | ||||||
|  | @ -145,6 +147,7 @@ export class ImageUploadManager { | ||||||
|             } catch (e) { |             } catch (e) { | ||||||
|                 console.error("Could again not upload image due to", e) |                 console.error("Could again not upload image due to", e) | ||||||
|                 this.increaseCountFor(this._uploadFailed, featureId) |                 this.increaseCountFor(this._uploadFailed, featureId) | ||||||
|  |                 return undefined | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         console.log("Uploading done, creating action for", featureId) |         console.log("Uploading done, creating action for", featureId) | ||||||
|  |  | ||||||
							
								
								
									
										29
									
								
								src/UI/Image/UploadFailedMessage.svelte
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								src/UI/Image/UploadFailedMessage.svelte
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,29 @@ | ||||||
|  | <script lang="ts"> | ||||||
|  | 
 | ||||||
|  |   import Tr from "../Base/Tr.svelte" | ||||||
|  |   import Translations from "../i18n/Translations" | ||||||
|  |   import { XCircleIcon } from "@babeard/svelte-heroicons/solid" | ||||||
|  | 
 | ||||||
|  |   export let failed: number | ||||||
|  |   const t = Translations.t.image | ||||||
|  | 
 | ||||||
|  | </script> | ||||||
|  | <div class="alert flex"> | ||||||
|  | 
 | ||||||
|  |   <div class="flex flex-col items-start"> | ||||||
|  |     {#if failed === 1} | ||||||
|  |       <Tr t={t.upload.one.failed} /> | ||||||
|  |     {:else} | ||||||
|  |       <Tr t={t.upload.multiple.someFailed.Subs({ count: failed })} /> | ||||||
|  |     {/if} | ||||||
|  |     <Tr cls="text-normal" t={t.upload.failReasons} /> | ||||||
|  |     <Tr cls="text-xs" t={t.upload.failReasonsAdvanced} /> | ||||||
|  |   </div> | ||||||
|  |   <button | ||||||
|  |     class="mt-2 h-fit shrink-0 rounded-full border-none p-0 pointer-events-auto" | ||||||
|  |     on:click | ||||||
|  |     style="border: 0 !important; padding: 0 !important;" | ||||||
|  |   > | ||||||
|  |     <XCircleIcon aria-hidden={true} class="h-8 w-8" /> | ||||||
|  |   </button> | ||||||
|  | </div> | ||||||
|  | @ -11,6 +11,8 @@ | ||||||
|   import Translations from "../i18n/Translations" |   import Translations from "../i18n/Translations" | ||||||
|   import Tr from "../Base/Tr.svelte" |   import Tr from "../Base/Tr.svelte" | ||||||
|   import Loading from "../Base/Loading.svelte" |   import Loading from "../Base/Loading.svelte" | ||||||
|  |   import { XCircleIcon } from "@babeard/svelte-heroicons/solid" | ||||||
|  |   import UploadFailedMessage from "./UploadFailedMessage.svelte" | ||||||
| 
 | 
 | ||||||
|   export let state: SpecialVisualizationState |   export let state: SpecialVisualizationState | ||||||
|   export let tags: Store<OsmTags> = undefined |   export let tags: Store<OsmTags> = undefined | ||||||
|  | @ -22,19 +24,22 @@ | ||||||
|   const { uploadStarted, uploadFinished, retried, failed } = |   const { uploadStarted, uploadFinished, retried, failed } = | ||||||
|     state.imageUploadManager.getCountsFor(featureId) |     state.imageUploadManager.getCountsFor(featureId) | ||||||
|   const t = Translations.t.image |   const t = Translations.t.image | ||||||
|  |   const debugging = state.featureSwitches.featureSwitchIsDebugging | ||||||
|  |   let dismissed = 0 | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| {#if $uploadStarted === 1} | {#if $debugging} | ||||||
|  |   <div class="low-interaction">Started {$uploadStarted} Done {$uploadFinished} Retry {$retried} Err {$failed}</div> | ||||||
|  | {/if} | ||||||
|  | {#if dismissed === $uploadStarted} | ||||||
|  |   <!-- We don't show anything as we ignore this number of failed items--> | ||||||
|  | {:else if $uploadStarted === 1} | ||||||
|   {#if $uploadFinished === 1} |   {#if $uploadFinished === 1} | ||||||
|     {#if showThankYou} |     {#if showThankYou} | ||||||
|       <Tr cls="thanks" t={t.upload.one.done} /> |       <Tr cls="thanks" t={t.upload.one.done} /> | ||||||
|     {/if} |     {/if} | ||||||
|   {:else if $failed === 1} |   {:else if $failed === 1} | ||||||
|     <div class="alert flex flex-col"> |     <UploadFailedMessage failed={$failed} on:click={() => dismissed = $failed}/> | ||||||
|       <Tr cls="self-center" t={t.upload.one.failed} /> |  | ||||||
|       <Tr t={t.upload.failReasons} /> |  | ||||||
|       <Tr t={t.upload.failReasonsAdvanced} /> |  | ||||||
|     </div> |  | ||||||
|   {:else if $retried === 1} |   {:else if $retried === 1} | ||||||
|     <Loading cls="alert"> |     <Loading cls="alert"> | ||||||
|       <Tr t={t.upload.one.retrying} /> |       <Tr t={t.upload.one.retrying} /> | ||||||
|  | @ -45,8 +50,10 @@ | ||||||
|     </Loading> |     </Loading> | ||||||
|   {/if} |   {/if} | ||||||
| {:else if $uploadStarted > 1} | {:else if $uploadStarted > 1} | ||||||
|   {#if $uploadFinished + $failed === $uploadStarted && $uploadFinished > 0} |   {#if $uploadFinished + $failed === $uploadStarted} | ||||||
|     {#if showThankYou} |     {#if $uploadFinished === 0} | ||||||
|  |       <!-- pass --> | ||||||
|  |     {:else if showThankYou} | ||||||
|       <Tr cls="thanks" t={t.upload.multiple.done.Subs({ count: $uploadFinished })} /> |       <Tr cls="thanks" t={t.upload.multiple.done.Subs({ count: $uploadFinished })} /> | ||||||
|     {/if} |     {/if} | ||||||
|   {:else if $uploadFinished === 0} |   {:else if $uploadFinished === 0} | ||||||
|  | @ -64,14 +71,7 @@ | ||||||
|     </Loading> |     </Loading> | ||||||
|   {/if} |   {/if} | ||||||
|   {#if $failed > 0} |   {#if $failed > 0} | ||||||
|     <div class="alert flex flex-col"> |      | ||||||
|       {#if $failed === 1} |    <UploadFailedMessage failed={$failed} on:click={() => dismissed = $failed}/> | ||||||
|         <Tr cls="self-center" t={t.upload.one.failed} /> |  | ||||||
|       {:else} |  | ||||||
|         <Tr cls="self-center" t={t.upload.multiple.someFailed.Subs({ count: $failed })} /> |  | ||||||
|       {/if} |  | ||||||
|       <Tr t={t.upload.failReasons} /> |  | ||||||
|       <Tr t={t.upload.failReasonsAdvanced} /> |  | ||||||
|     </div> |  | ||||||
|   {/if} |   {/if} | ||||||
| {/if} | {/if} | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue