| 
									
										
										
										
											2023-09-28 23:50:27 +02:00
										 |  |  | <script lang="ts"> | 
					
						
							| 
									
										
										
										
											2023-10-16 14:27:05 +02:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Shows information about how much images are uploaded for the given feature | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Either pass in a store with tags or a featureId. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2023-09-25 02:11:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-16 14:27:05 +02:00
										 |  |  |   import type { SpecialVisualizationState } from "../SpecialVisualization" | 
					
						
							|  |  |  |   import { Store } from "../../Logic/UIEventSource" | 
					
						
							| 
									
										
										
										
											2025-04-07 02:53:21 +02:00
										 |  |  |   import type { NoteId, OsmTags, OsmId } from "../../Models/OsmFeature" | 
					
						
							| 
									
										
										
										
											2023-10-16 14:27:05 +02:00
										 |  |  |   import Translations from "../i18n/Translations" | 
					
						
							|  |  |  |   import Tr from "../Base/Tr.svelte" | 
					
						
							|  |  |  |   import Loading from "../Base/Loading.svelte" | 
					
						
							| 
									
										
										
										
											2024-03-11 16:35:15 +01:00
										 |  |  |   import UploadFailedMessage from "./UploadFailedMessage.svelte" | 
					
						
							| 
									
										
										
										
											2023-09-25 02:11:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-16 14:27:05 +02:00
										 |  |  |   export let state: SpecialVisualizationState | 
					
						
							| 
									
										
										
										
											2023-12-07 21:57:20 +01:00
										 |  |  |   export let tags: Store<OsmTags> = undefined | 
					
						
							| 
									
										
										
										
											2025-04-07 02:53:21 +02:00
										 |  |  |   export let featureId: OsmId | NoteId | "*" = tags?.data?.id ?? "*" | 
					
						
							| 
									
										
										
										
											2023-12-19 22:08:00 +01:00
										 |  |  |   if (featureId === undefined) { | 
					
						
							| 
									
										
										
										
											2023-12-07 21:57:20 +01:00
										 |  |  |     throw "No tags or featureID given" | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2023-10-16 14:27:05 +02:00
										 |  |  |   export let showThankYou: boolean = true | 
					
						
							| 
									
										
										
										
											2025-04-07 02:53:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /* | 
					
						
							|  |  |  |   Number of images uploaded succesfully | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function getCount(input: Store<string[]>): Store<number> { | 
					
						
							|  |  |  |     if (featureId == "*") { | 
					
						
							|  |  |  |       return input.map(inp => inp.length) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return input.map(success => success.filter(item => item === featureId).length) | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let successfull = getCount(state.imageUploadManager.successfull) | 
					
						
							|  |  |  |   /* Number of failed uploads */ | 
					
						
							|  |  |  |   let failed = getCount(state.imageUploadManager.fails) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let pending = getCount(state.imageUploadManager.queued) | 
					
						
							| 
									
										
										
										
											2023-10-16 14:27:05 +02:00
										 |  |  |   const t = Translations.t.image | 
					
						
							| 
									
										
										
										
											2024-03-11 16:35:15 +01:00
										 |  |  |   const debugging = state.featureSwitches.featureSwitchIsDebugging | 
					
						
							|  |  |  |   let dismissed = 0 | 
					
						
							| 
									
										
										
										
											2025-04-07 02:53:21 +02:00
										 |  |  |   failed.addCallbackAndRun(failed => { | 
					
						
							|  |  |  |     dismissed = Math.min(failed, dismissed) | 
					
						
							|  |  |  |   }) | 
					
						
							| 
									
										
										
										
											2023-09-25 02:11:42 +02:00
										 |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-11 16:35:15 +01:00
										 |  |  | {#if $debugging} | 
					
						
							| 
									
										
										
										
											2024-04-13 02:40:21 +02:00
										 |  |  |   <div class="low-interaction"> | 
					
						
							| 
									
										
										
										
											2025-04-07 02:53:21 +02:00
										 |  |  |     Pending {$pending} Done {$successfull} Err {$failed} | 
					
						
							| 
									
										
										
										
											2024-04-13 02:40:21 +02:00
										 |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2024-03-11 16:35:15 +01:00
										 |  |  | {/if} | 
					
						
							| 
									
										
										
										
											2025-04-07 02:53:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | {#if $pending - $failed > 0} | 
					
						
							|  |  |  |   <div class="alert"> | 
					
						
							|  |  |  |     <Loading> | 
					
						
							|  |  |  |       {#if $pending - $failed === 1} | 
					
						
							| 
									
										
										
										
											2024-04-13 02:40:21 +02:00
										 |  |  |         <Tr t={t.upload.one.uploading} /> | 
					
						
							| 
									
										
										
										
											2025-04-07 02:53:21 +02:00
										 |  |  |       {:else if $pending - $failed > 1} | 
					
						
							|  |  |  |         <Tr t={t.upload.multiple.uploading.Subs({count: $pending})} /> | 
					
						
							|  |  |  |       {/if} | 
					
						
							| 
									
										
										
										
											2023-09-25 02:13:24 +02:00
										 |  |  |     </Loading> | 
					
						
							| 
									
										
										
										
											2025-04-07 02:53:21 +02:00
										 |  |  |   </div> | 
					
						
							|  |  |  | {/if} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {#if $failed > dismissed} | 
					
						
							|  |  |  |   <UploadFailedMessage failed={$failed} on:click={() => (dismissed = $failed)} /> | 
					
						
							|  |  |  | {/if} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {#if showThankYou} | 
					
						
							|  |  |  |   {#if $successfull === 1} | 
					
						
							|  |  |  |     <Tr cls="thanks" t={t.upload.one.done} /> | 
					
						
							|  |  |  |   {:else if $successfull > 1} | 
					
						
							|  |  |  |     <Tr cls="thanks" t={t.upload.multiple.done.Subs({count: $successfull})} /> | 
					
						
							| 
									
										
										
										
											2023-09-25 02:13:24 +02:00
										 |  |  |   {/if} | 
					
						
							|  |  |  | {/if} |