forked from MapComplete/MapComplete
		
	Fix duplicate building upload in GRB theme (hopefully), remove type from method name, improve typing and error messages
This commit is contained in:
		
							parent
							
								
									fc483ed547
								
							
						
					
					
						commit
						b8a631f368
					
				
					 11 changed files with 49 additions and 26 deletions
				
			
		|  | @ -22,7 +22,7 @@ | ||||||
|             ] |             ] | ||||||
|           }, |           }, | ||||||
|           "icon": { |           "icon": { | ||||||
|             "render": "addSmall:#000", |             "render": "addSmall", | ||||||
|             "mappings": [ |             "mappings": [ | ||||||
|               { |               { | ||||||
|                 "if": "detach=yes", |                 "if": "detach=yes", | ||||||
|  |  | ||||||
							
								
								
									
										5
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										5
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							|  | @ -1,12 +1,12 @@ | ||||||
| { | { | ||||||
|   "name": "mapcomplete", |   "name": "mapcomplete", | ||||||
|   "version": "0.36.9", |   "version": "0.36.11", | ||||||
|   "lockfileVersion": 2, |   "lockfileVersion": 2, | ||||||
|   "requires": true, |   "requires": true, | ||||||
|   "packages": { |   "packages": { | ||||||
|     "": { |     "": { | ||||||
|       "name": "mapcomplete", |       "name": "mapcomplete", | ||||||
|       "version": "0.36.9", |       "version": "0.36.11", | ||||||
|       "license": "GPL-3.0-or-later", |       "license": "GPL-3.0-or-later", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@rgossiaux/svelte-headlessui": "^1.0.2", |         "@rgossiaux/svelte-headlessui": "^1.0.2", | ||||||
|  | @ -15,6 +15,7 @@ | ||||||
|         "@turf/boolean-intersects": "^6.5.0", |         "@turf/boolean-intersects": "^6.5.0", | ||||||
|         "@turf/buffer": "^6.5.0", |         "@turf/buffer": "^6.5.0", | ||||||
|         "@turf/collect": "^6.5.0", |         "@turf/collect": "^6.5.0", | ||||||
|  |         "@turf/difference": "^6.5.0", | ||||||
|         "@turf/distance": "^6.5.0", |         "@turf/distance": "^6.5.0", | ||||||
|         "@turf/length": "^6.5.0", |         "@turf/length": "^6.5.0", | ||||||
|         "@turf/turf": "^6.5.0", |         "@turf/turf": "^6.5.0", | ||||||
|  |  | ||||||
|  | @ -103,6 +103,7 @@ | ||||||
|     "@turf/boolean-intersects": "^6.5.0", |     "@turf/boolean-intersects": "^6.5.0", | ||||||
|     "@turf/buffer": "^6.5.0", |     "@turf/buffer": "^6.5.0", | ||||||
|     "@turf/collect": "^6.5.0", |     "@turf/collect": "^6.5.0", | ||||||
|  |     "@turf/difference": "^6.5.0", | ||||||
|     "@turf/distance": "^6.5.0", |     "@turf/distance": "^6.5.0", | ||||||
|     "@turf/length": "^6.5.0", |     "@turf/length": "^6.5.0", | ||||||
|     "@turf/turf": "^6.5.0", |     "@turf/turf": "^6.5.0", | ||||||
|  |  | ||||||
|  | @ -264,7 +264,8 @@ class ClosestNObjectFunc implements ExtraFunction { | ||||||
|             const bbox = GeoOperations.bbox( |             const bbox = GeoOperations.bbox( | ||||||
|                 GeoOperations.buffer(GeoOperations.bbox(feature), maxDistance) |                 GeoOperations.buffer(GeoOperations.bbox(feature), maxDistance) | ||||||
|             ) |             ) | ||||||
|             allFeatures = params.getFeaturesWithin(name, new BBox(bbox.geometry.coordinates)) |             const coors = <[number, number][]>bbox.geometry.coordinates | ||||||
|  |             allFeatures = params.getFeaturesWithin(name, new BBox(coors)) | ||||||
|         } else { |         } else { | ||||||
|             allFeatures = [features] |             allFeatures = [features] | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -39,8 +39,8 @@ export default class FeatureSourceMerger implements IndexedFeatureSource { | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     protected addData(featuress: Feature[][]) { |     protected addData(sources: Feature[][]) { | ||||||
|         featuress = Utils.NoNull(featuress) |         sources = Utils.NoNull(sources) | ||||||
|         let somethingChanged = false |         let somethingChanged = false | ||||||
|         const all: Map<string, Feature> = new Map() |         const all: Map<string, Feature> = new Map() | ||||||
|         const unseen = new Set<string>() |         const unseen = new Set<string>() | ||||||
|  | @ -51,7 +51,7 @@ export default class FeatureSourceMerger implements IndexedFeatureSource { | ||||||
|             unseen.add(oldValue.properties.id) |             unseen.add(oldValue.properties.id) | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         for (const features of featuress) { |         for (const features of sources) { | ||||||
|             for (const f of features) { |             for (const f of features) { | ||||||
|                 const id = f.properties.id |                 const id = f.properties.id | ||||||
|                 unseen.delete(id) |                 unseen.delete(id) | ||||||
|  |  | ||||||
|  | @ -6,7 +6,7 @@ import FeatureSourceMerger from "../Sources/FeatureSourceMerger" | ||||||
| 
 | 
 | ||||||
| /*** | /*** | ||||||
|  * A tiled source which dynamically loads the required tiles at a fixed zoom level. |  * A tiled source which dynamically loads the required tiles at a fixed zoom level. | ||||||
|  * A single featureSource will be initiliased for every tile in view; which will alter be merged into this featureSource |  * A single featureSource will be initialized for every tile in view; which will later be merged into this featureSource | ||||||
|  */ |  */ | ||||||
| export default class DynamicTileSource extends FeatureSourceMerger { | export default class DynamicTileSource extends FeatureSourceMerger { | ||||||
|     constructor( |     constructor( | ||||||
|  |  | ||||||
|  | @ -153,7 +153,7 @@ export class GeoOperations { | ||||||
|                     continue |                     continue | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 const intersection = GeoOperations.calculateInstersection( |                 const intersection = GeoOperations.calculateIntersection( | ||||||
|                     feature, |                     feature, | ||||||
|                     otherFeature, |                     otherFeature, | ||||||
|                     featureBBox |                     featureBBox | ||||||
|  | @ -184,7 +184,7 @@ export class GeoOperations { | ||||||
| 
 | 
 | ||||||
|                 // Calculate the surface area of the intersection
 |                 // Calculate the surface area of the intersection
 | ||||||
| 
 | 
 | ||||||
|                 const intersection = this.calculateInstersection(feature, otherFeature, featureBBox) |                 const intersection = this.calculateIntersection(feature, otherFeature, featureBBox) | ||||||
|                 if (intersection === null) { |                 if (intersection === null) { | ||||||
|                     continue |                     continue | ||||||
|                 } |                 } | ||||||
|  | @ -1029,7 +1029,7 @@ export class GeoOperations { | ||||||
|      * Returns 0 if both are linestrings |      * Returns 0 if both are linestrings | ||||||
|      * Returns null if the features are not intersecting |      * Returns null if the features are not intersecting | ||||||
|      */ |      */ | ||||||
|     private static calculateInstersection( |     private static calculateIntersection( | ||||||
|         feature, |         feature, | ||||||
|         otherFeature, |         otherFeature, | ||||||
|         featureBBox: BBox, |         featureBBox: BBox, | ||||||
|  | @ -1099,7 +1099,7 @@ export class GeoOperations { | ||||||
|                 return null |                 return null | ||||||
|             } |             } | ||||||
|             if (otherFeature.geometry.type === "LineString") { |             if (otherFeature.geometry.type === "LineString") { | ||||||
|                 return this.calculateInstersection( |                 return this.calculateIntersection( | ||||||
|                     otherFeature, |                     otherFeature, | ||||||
|                     feature, |                     feature, | ||||||
|                     otherFeatureBBox, |                     otherFeatureBBox, | ||||||
|  | @ -1119,6 +1119,19 @@ export class GeoOperations { | ||||||
|                     // See https://github.com/Turfjs/turf/pull/2238
 |                     // See https://github.com/Turfjs/turf/pull/2238
 | ||||||
|                     return null |                     return null | ||||||
|                 } |                 } | ||||||
|  |                 if (e.message.indexOf("SweepLine tree") >= 0) { | ||||||
|  |                     console.log("Applying fallback intersection...") | ||||||
|  |                     const intersection = turf.intersect( | ||||||
|  |                         turf.truncate(feature), | ||||||
|  |                         turf.truncate(otherFeature) | ||||||
|  |                     ) | ||||||
|  |                     if (intersection == null) { | ||||||
|  |                         return null | ||||||
|  |                     } | ||||||
|  |                     return turf.area(intersection) // in m²
 | ||||||
|  |                     // Another workaround: https://github.com/Turfjs/turf/issues/2258
 | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|                 throw e |                 throw e | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -274,17 +274,20 @@ export default class MetaTagging { | ||||||
|                     console.warn( |                     console.warn( | ||||||
|                         "Could not calculate a " + |                         "Could not calculate a " + | ||||||
|                             (isStrict ? "strict " : "") + |                             (isStrict ? "strict " : "") + | ||||||
|                             " calculated tag for key " + |                             "calculated tag for key", | ||||||
|                             key + |                         key, | ||||||
|                             " defined by " + |                         "for feature", | ||||||
|                             code + |                         feat.properties.id, | ||||||
|                             " (in layer" + |                         " defined by", | ||||||
|  |                         code, | ||||||
|  |                         "(in layer", | ||||||
|                         layerId + |                         layerId + | ||||||
|                             ") due to \n" + |                             ") due to \n" + | ||||||
|                             e + |                             e + | ||||||
|                             "\n. Are you the theme creator? Doublecheck your code. Note that the metatags might not be stable on new features", |                             "\n. Are you the theme creator? Doublecheck your code. Note that the metatags might not be stable on new features", | ||||||
|                         e, |                         e, | ||||||
|                         e.stack |                         e.stack, | ||||||
|  |                         { feat } | ||||||
|                     ) |                     ) | ||||||
|                     MetaTagging.errorPrintCount++ |                     MetaTagging.errorPrintCount++ | ||||||
|                     if (MetaTagging.errorPrintCount == MetaTagging.stopErrorOutputAt) { |                     if (MetaTagging.errorPrintCount == MetaTagging.stopErrorOutputAt) { | ||||||
|  |  | ||||||
|  | @ -148,7 +148,6 @@ export class Changes { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public applyChanges(changes: ChangeDescription[]) { |     public applyChanges(changes: ChangeDescription[]) { | ||||||
|         console.log("Received changes:", changes) |  | ||||||
|         this.pendingChanges.data.push(...changes) |         this.pendingChanges.data.push(...changes) | ||||||
|         this.pendingChanges.ping() |         this.pendingChanges.ping() | ||||||
|         this.allChanges.data.push(...changes) |         this.allChanges.data.push(...changes) | ||||||
|  | @ -191,7 +190,6 @@ export class Changes { | ||||||
|                 } |                 } | ||||||
|                 // This is a new object that should be created
 |                 // This is a new object that should be created
 | ||||||
|                 states.set(id, "created") |                 states.set(id, "created") | ||||||
|                 console.log("Creating object for changeDescription", change) |  | ||||||
|                 let osmObj: OsmObject = undefined |                 let osmObj: OsmObject = undefined | ||||||
|                 switch (change.type) { |                 switch (change.type) { | ||||||
|                     case "node": |                     case "node": | ||||||
|  | @ -255,7 +253,6 @@ export class Changes { | ||||||
|                         const nlon = Utils.Round7(change.changes.lon) |                         const nlon = Utils.Round7(change.changes.lon) | ||||||
|                         const n = <OsmNode>obj |                         const n = <OsmNode>obj | ||||||
|                         if (n.lat !== nlat || n.lon !== nlon) { |                         if (n.lat !== nlat || n.lon !== nlon) { | ||||||
|                             console.log("Node moved:", n.lat, nlat, n.lon, nlon) |  | ||||||
|                             n.lat = nlat |                             n.lat = nlat | ||||||
|                             n.lon = nlon |                             n.lon = nlon | ||||||
|                             changed = true |                             changed = true | ||||||
|  | @ -443,7 +440,6 @@ export class Changes { | ||||||
|             objects.forEach((obj) => SimpleMetaTagger.removeBothTagging(obj.tags)) |             objects.forEach((obj) => SimpleMetaTagger.removeBothTagging(obj.tags)) | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         console.log("Got the fresh objects!", objects, "pending: ", pending) |  | ||||||
|         if (pending.length == 0) { |         if (pending.length == 0) { | ||||||
|             console.log("No pending changes...") |             console.log("No pending changes...") | ||||||
|             return true |             return true | ||||||
|  | @ -528,9 +524,7 @@ export class Changes { | ||||||
|         await this._changesetHandler.UploadChangeset( |         await this._changesetHandler.UploadChangeset( | ||||||
|             (csId, remappings) => { |             (csId, remappings) => { | ||||||
|                 if (remappings.size > 0) { |                 if (remappings.size > 0) { | ||||||
|                     console.log("Rewriting pending changes from", pending, "with", remappings) |  | ||||||
|                     pending = pending.map((ch) => ChangeDescriptionTools.rewriteIds(ch, remappings)) |                     pending = pending.map((ch) => ChangeDescriptionTools.rewriteIds(ch, remappings)) | ||||||
|                     console.log("Result is", pending) |  | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 const changes: { |                 const changes: { | ||||||
|  |  | ||||||
|  | @ -30,6 +30,7 @@ | ||||||
|   import Direction_gradient from "../../assets/svg/Direction_gradient.svelte" |   import Direction_gradient from "../../assets/svg/Direction_gradient.svelte" | ||||||
|   import Mastodon from "../../assets/svg/Mastodon.svelte" |   import Mastodon from "../../assets/svg/Mastodon.svelte" | ||||||
|   import Party from "../../assets/svg/Party.svelte" |   import Party from "../../assets/svg/Party.svelte" | ||||||
|  |   import AddSmall from "../../assets/svg/AddSmall.svelte" | ||||||
| 
 | 
 | ||||||
|   /** |   /** | ||||||
|    * Renders a single icon. |    * Renders a single icon. | ||||||
|  | @ -111,6 +112,8 @@ | ||||||
|     <Mastodon {color} class={clss} /> |     <Mastodon {color} class={clss} /> | ||||||
|   {:else if icon === "party"} |   {:else if icon === "party"} | ||||||
|     <Party {color} class={clss} /> |     <Party {color} class={clss} /> | ||||||
|  |   {:else if icon === "addSmall"} | ||||||
|  |     <AddSmall {color} class={clss} /> | ||||||
|   {:else} |   {:else} | ||||||
|     <img class={clss ?? "h-full w-full"} src={icon} aria-hidden="true" alt="" /> |     <img class={clss ?? "h-full w-full"} src={icon} aria-hidden="true" alt="" /> | ||||||
|   {/if} |   {/if} | ||||||
|  |  | ||||||
|  | @ -159,7 +159,7 @@ class ApplyButton extends UIElement { | ||||||
|     private async Run() { |     private async Run() { | ||||||
|         try { |         try { | ||||||
|             console.log("Applying auto-action on " + this.target_feature_ids.length + " features") |             console.log("Applying auto-action on " + this.target_feature_ids.length + " features") | ||||||
| 
 |             const appliedOn: string[] = [] | ||||||
|             for (let i = 0; i < this.target_feature_ids.length; i++) { |             for (let i = 0; i < this.target_feature_ids.length; i++) { | ||||||
|                 const targetFeatureId = this.target_feature_ids[i] |                 const targetFeatureId = this.target_feature_ids[i] | ||||||
|                 const feature = this.state.indexedFeatures.featuresById.data.get(targetFeatureId) |                 const feature = this.state.indexedFeatures.featuresById.data.get(targetFeatureId) | ||||||
|  | @ -190,6 +190,7 @@ class ApplyButton extends UIElement { | ||||||
|                         specialRendering.args |                         specialRendering.args | ||||||
|                     ) |                     ) | ||||||
|                 } |                 } | ||||||
|  |                 appliedOn.push(targetFeatureId) | ||||||
|                 if (i % 50 === 0) { |                 if (i % 50 === 0) { | ||||||
|                     await this.state.changes.flushChanges("Auto button: intermediate save") |                     await this.state.changes.flushChanges("Auto button: intermediate save") | ||||||
|                 } |                 } | ||||||
|  | @ -198,6 +199,12 @@ class ApplyButton extends UIElement { | ||||||
|             console.log("Flushing changes...") |             console.log("Flushing changes...") | ||||||
|             await this.state.changes.flushChanges("Auto button: done") |             await this.state.changes.flushChanges("Auto button: done") | ||||||
|             this.buttonState.setData("done") |             this.buttonState.setData("done") | ||||||
|  |             console.log( | ||||||
|  |                 "Applied changes onto", | ||||||
|  |                 appliedOn.length, | ||||||
|  |                 "items, unique IDs:", | ||||||
|  |                 new Set(appliedOn).size | ||||||
|  |             ) | ||||||
|         } catch (e) { |         } catch (e) { | ||||||
|             console.error("Error while running autoApply: ", e) |             console.error("Error while running autoApply: ", e) | ||||||
|             this.buttonState.setData({ error: e }) |             this.buttonState.setData({ error: e }) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue