| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  | <script lang="ts"> | 
					
						
							| 
									
										
										
										
											2023-10-30 13:44:27 +01:00
										 |  |  |   import { Utils } from "../Utils" | 
					
						
							|  |  |  |   import { Store, UIEventSource } from "../Logic/UIEventSource" | 
					
						
							|  |  |  |   import Loading from "./Base/Loading.svelte" | 
					
						
							|  |  |  |   import { OsmConnection } from "../Logic/Osm/OsmConnection" | 
					
						
							| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-30 13:44:27 +01:00
										 |  |  |   const osmConnection = new OsmConnection({ | 
					
						
							|  |  |  |     attemptLogin: true, | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  |   let loggedInContributor: Store<string> = osmConnection.userDetails.map((ud) => ud.name) | 
					
						
							|  |  |  |   export let source = | 
					
						
							|  |  |  |     "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/picture-leaderboard.json" | 
					
						
							|  |  |  |   let data: Store< | 
					
						
							|  |  |  |     | undefined | 
					
						
							|  |  |  |     | { | 
					
						
							| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  |         leaderboard: { | 
					
						
							| 
									
										
										
										
											2023-10-30 13:44:27 +01:00
										 |  |  |           rank: number | 
					
						
							|  |  |  |           name: string | 
					
						
							|  |  |  |           account: string | 
					
						
							|  |  |  |           nrOfImages: number | 
					
						
							|  |  |  |         }[] | 
					
						
							|  |  |  |         median: number | 
					
						
							|  |  |  |         totalAuthors: number | 
					
						
							| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  |         byLicense: { | 
					
						
							| 
									
										
										
										
											2023-10-30 13:44:27 +01:00
										 |  |  |           license: string | 
					
						
							|  |  |  |           total: number | 
					
						
							|  |  |  |           authors: string[] | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  |         date: string | 
					
						
							| 
									
										
										
										
											2023-10-30 13:44:27 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |   > = UIEventSource.FromPromise(Utils.downloadJsonCached(source)) | 
					
						
							| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <h1>Contributed images with MapComplete: leaderboard</h1> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {#if $data} | 
					
						
							|  |  |  |   <table> | 
					
						
							|  |  |  |     <tr> | 
					
						
							|  |  |  |       <th>Rank</th> | 
					
						
							|  |  |  |       <th>Contributor</th> | 
					
						
							|  |  |  |       <th>Number of images contributed</th> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |     {#each $data.leaderboard as contributor} | 
					
						
							|  |  |  |       <tr> | 
					
						
							|  |  |  |         <td> | 
					
						
							|  |  |  |           {contributor.rank} | 
					
						
							|  |  |  |         </td> | 
					
						
							|  |  |  |         <td> | 
					
						
							|  |  |  |           {#if $loggedInContributor === contributor.name} | 
					
						
							| 
									
										
										
										
											2023-10-30 13:44:27 +01:00
										 |  |  |             <a class="thanks" href={contributor.account}>{contributor.name}</a> | 
					
						
							| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  |           {:else} | 
					
						
							| 
									
										
										
										
											2023-10-30 13:44:27 +01:00
										 |  |  |             <a href={contributor.account}>{contributor.name}</a> | 
					
						
							| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  |           {/if} | 
					
						
							|  |  |  |         </td> | 
					
						
							|  |  |  |         <td> | 
					
						
							| 
									
										
										
										
											2023-10-30 13:44:27 +01:00
										 |  |  |           <b>{contributor.nrOfImages}</b> | 
					
						
							|  |  |  |            total images | 
					
						
							| 
									
										
										
										
											2023-10-17 13:31:06 +02:00
										 |  |  |         </td> | 
					
						
							|  |  |  |       </tr> | 
					
						
							|  |  |  |     {/each} | 
					
						
							|  |  |  |   </table> | 
					
						
							|  |  |  |   Statistics generated on {$data.date} | 
					
						
							|  |  |  | {:else} | 
					
						
							|  |  |  |   <Loading /> | 
					
						
							|  |  |  | {/if} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <div> | 
					
						
							|  |  |  |   Logged in as {$loggedInContributor} | 
					
						
							|  |  |  | </div> |