forked from MapComplete/MapComplete
		
	WIP: more features in inspector
This commit is contained in:
		
							parent
							
								
									c34300fae1
								
							
						
					
					
						commit
						552ea22275
					
				
					 19 changed files with 526 additions and 65 deletions
				
			
		
							
								
								
									
										95
									
								
								src/UI/History/History.svelte
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								src/UI/History/History.svelte
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,95 @@ | |||
| <script lang="ts"> | ||||
|   /** | ||||
|    * Shows a history of the object which focuses on changes made by a certain username | ||||
|    */ | ||||
|   import type { OsmId } from "../../Models/OsmFeature" | ||||
|   import OsmObjectDownloader from "../../Logic/Osm/OsmObjectDownloader" | ||||
|   import { UIEventSource } from "../../Logic/UIEventSource" | ||||
|   import Loading from "../Base/Loading.svelte" | ||||
|   import { HistoryUtils } from "./HistoryUtils" | ||||
|   import ToSvelte from "../Base/ToSvelte.svelte" | ||||
|   import LayerConfig from "../../Models/ThemeConfig/LayerConfig" | ||||
|   import Tr from "../Base/Tr.svelte" | ||||
| 
 | ||||
|   export let onlyShowChangesBy: string | ||||
|   export let id: OsmId | ||||
| 
 | ||||
|   let fullHistory = UIEventSource.FromPromise(new OsmObjectDownloader().downloadHistory(id)) | ||||
| 
 | ||||
|   let partOfLayer = fullHistory.mapD(history => history.map(step => ({ | ||||
|     step, | ||||
|     layer: HistoryUtils.determineLayer(step.tags) | ||||
|   }))) | ||||
|   let filteredHistory = partOfLayer.mapD(history => | ||||
|     history.filter(({ step }) => { | ||||
|       if (!onlyShowChangesBy) { | ||||
|         return true | ||||
|       } | ||||
|       console.log("Comparing ", step.tags["_last_edit:contributor"], onlyShowChangesBy, step.tags["_last_edit:contributor"] === onlyShowChangesBy) | ||||
|       return step.tags["_last_edit:contributor"] === onlyShowChangesBy | ||||
| 
 | ||||
|     })) | ||||
| 
 | ||||
|   let lastStep = filteredHistory.mapD(history => history.at(-1)) | ||||
| let l : LayerConfig | ||||
|   // l.title.GetRenderValue({}).Subs({}) | ||||
| </script> | ||||
| 
 | ||||
| {#if $lastStep?.layer} | ||||
|   <a href={"https://openstreetmap.org/" + $lastStep.step.tags.id} target="_blank"> | ||||
|   <h3 class="flex items-center gap-x-2"> | ||||
|   <div class="w-8 h-8 shrink-0 inline-block"> | ||||
|     <ToSvelte construct={$lastStep.layer?.defaultIcon($lastStep.step.tags)} /> | ||||
|   </div> | ||||
|   <Tr t={$lastStep.layer?.title?.GetRenderValue($lastStep.step.tags)?.Subs($lastStep.step.tags)}/> | ||||
|   </h3> | ||||
|   </a> | ||||
| {/if} | ||||
| 
 | ||||
| {#if !$filteredHistory} | ||||
|   <Loading>Loading history...</Loading> | ||||
| {:else if $filteredHistory.length === 0} | ||||
|   Only geometry changes found | ||||
| {:else} | ||||
|   <table class="w-full m-1"> | ||||
|     {#each $filteredHistory as { step, layer }} | ||||
| 
 | ||||
|       {#if step.version === 1} | ||||
|         <tr> | ||||
|           <td colspan="3"> | ||||
|             <h3> | ||||
|               Created by {step.tags["_last_edit:contributor"]} | ||||
|             </h3> | ||||
|           </td> | ||||
|         </tr> | ||||
|       {/if} | ||||
|       {#if HistoryUtils.tagHistoryDiff(step, $fullHistory).length === 0} | ||||
|         <tr> | ||||
|           <td class="font-bold justify-center flex w-full" colspan="3"> | ||||
|             Only changes in geometry | ||||
|           </td> | ||||
|         </tr> | ||||
|       {:else} | ||||
|         {#each HistoryUtils.tagHistoryDiff(step, $fullHistory) as diff} | ||||
|           <tr> | ||||
|             <td><a href={"https://osm.org/changeset/"+step.tags["_last_edit:changeset"]} | ||||
|                    target="_blank">{step.version}</a></td> | ||||
|             <td>{layer?.id ?? "Unknown layer"}</td> | ||||
|             {#if diff.oldValue === undefined} | ||||
|               <td>{diff.key}</td> | ||||
|               <td>{diff.value}</td> | ||||
|             {:else if diff.value === undefined } | ||||
|               <td>{diff.key}</td> | ||||
|               <td class="line-through"> {diff.value}</td> | ||||
|             {:else} | ||||
|               <td>{diff.key}</td> | ||||
|               <td><span class="line-through"> {diff.oldValue}</span> → {diff.value}</td> | ||||
|             {/if} | ||||
| 
 | ||||
| 
 | ||||
|           </tr> | ||||
|         {/each} | ||||
|       {/if} | ||||
|     {/each} | ||||
|   </table> | ||||
| {/if} | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue