forked from MapComplete/MapComplete
		
	Fix #1961, add test
This commit is contained in:
		
							parent
							
								
									23e563cdb7
								
							
						
					
					
						commit
						ad411f0943
					
				
					 3 changed files with 54 additions and 5 deletions
				
			
		|  | @ -2,12 +2,12 @@ import ChangeTagAction from "./ChangeTagAction" | |||
| import { Tag } from "../../Tags/Tag" | ||||
| import OsmChangeAction from "./OsmChangeAction" | ||||
| import { ChangeDescription } from "./ChangeDescription" | ||||
| import { Store } from "../../UIEventSource" | ||||
| import { Store, UIEventSource } from "../../UIEventSource" | ||||
| 
 | ||||
| export default class LinkImageAction extends OsmChangeAction { | ||||
|     private readonly _proposedKey: "image" | "mapillary" | "wiki_commons" | string | ||||
|     public readonly _url: string | ||||
|     private readonly _currentTags: Store<Record<string, string>> | ||||
|     private readonly _currentTags: UIEventSource<Record<string, string>> | ||||
|     private readonly _meta: { theme: string; changeType: "add-image" | "link-image" } | ||||
| 
 | ||||
|     /** | ||||
|  | @ -23,7 +23,7 @@ export default class LinkImageAction extends OsmChangeAction { | |||
|         elementId: string, | ||||
|         proposedKey: "image" | "mapillary" | "wiki_commons" | string, | ||||
|         url: string, | ||||
|         currentTags: Store<Record<string, string>>, | ||||
|         currentTags: UIEventSource<Record<string, string>>, | ||||
|         meta: { | ||||
|             theme: string | ||||
|             changeType: "add-image" | "link-image" | ||||
|  | @ -51,6 +51,10 @@ export default class LinkImageAction extends OsmChangeAction { | |||
|             currentTags, | ||||
|             this._meta | ||||
|         ) | ||||
|         this._currentTags.data[key] = url | ||||
|         this._currentTags.ping() | ||||
|         return tagChangeAction.CreateChangeDescriptions() | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ | |||
|     id: Object.values(image.osmTags)[0], | ||||
|   } | ||||
| 
 | ||||
|   function applyLink(isLinked: boolean) { | ||||
|   async function applyLink(isLinked: boolean) { | ||||
|     console.log("Applying linked image", isLinked, targetValue) | ||||
|     const currentTags = tags.data | ||||
|     const key = Object.keys(image.osmTags)[0] | ||||
|  | @ -44,7 +44,7 @@ | |||
|         theme: tags.data._orig_theme ?? state.layout.id, | ||||
|         changeType: "link-image", | ||||
|       }) | ||||
|       state.changes.applyAction(action) | ||||
|       await state.changes.applyAction(action) | ||||
|     } else { | ||||
|       for (const k in currentTags) { | ||||
|         const v = currentTags[k] | ||||
|  |  | |||
							
								
								
									
										45
									
								
								test/Logic/ActionInteraction.spec.ts
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								test/Logic/ActionInteraction.spec.ts
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,45 @@ | |||
| import { ExtraFuncParams, ExtraFunctions } from "../../src/Logic/ExtraFunctions" | ||||
| import { OsmFeature } from "../../src/Models/OsmFeature" | ||||
| import { describe, expect, it } from "vitest" | ||||
| import { Feature } from "geojson" | ||||
| import { OsmConnection } from "../../src/Logic/Osm/OsmConnection" | ||||
| import { ImmutableStore, UIEventSource } from "../../src/Logic/UIEventSource" | ||||
| import { Changes } from "../../src/Logic/Osm/Changes" | ||||
| import LinkImageAction from "../../src/Logic/Osm/Actions/LinkImageAction" | ||||
| import FeaturePropertiesStore from "../../src/Logic/FeatureSource/Actors/FeaturePropertiesStore" | ||||
| 
 | ||||
| describe("Changes", () => { | ||||
|     it("should correctly apply the image tag if an image gets linked in between", async () => { | ||||
|         const dryRun = new ImmutableStore(true) | ||||
|         const osmConnection = new OsmConnection({ dryRun }) | ||||
|         const changes = new Changes({ osmConnection, dryRun }) | ||||
|         const id = "node/42" | ||||
|         const tags = new UIEventSource({ id, "amenity": "shop" }) | ||||
|         const addImage = new LinkImageAction(id, "image", "https://example.org/uploaded_image", tags, { | ||||
|             theme: "test", | ||||
|             changeType: "add-image", | ||||
|         }) | ||||
|         const linkImage = new LinkImageAction(id, "image", "https://example.org/image_to_link", tags, { | ||||
|             theme: "test", | ||||
|             changeType: "link-image", | ||||
|         }) | ||||
| 
 | ||||
|         await changes.applyAction(linkImage) | ||||
|         await changes.applyAction(addImage) | ||||
| 
 | ||||
|         const data = tags.data | ||||
|         expect(data["image:0"]).toBe("https://example.org/uploaded_image") | ||||
|         expect(data["image"]).toBe("https://example.org/image_to_link") | ||||
| 
 | ||||
|         const pending = changes.pendingChanges.data | ||||
| 
 | ||||
|         const change0 = pending[0].tags[0] | ||||
|         expect(change0.k).toBe("image") | ||||
|         expect(change0.v).toBe("https://example.org/image_to_link") | ||||
| 
 | ||||
|         const change1 = pending[1].tags[0] | ||||
|         expect(change1.k).toBe("image:0") | ||||
|         expect(change1.v).toBe("https://example.org/uploaded_image") | ||||
| 
 | ||||
|     }) | ||||
| }) | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue