forked from MapComplete/MapComplete
		
	Stabilize popups in ShowDataLayer
This commit is contained in:
		
							parent
							
								
									087d5cdbef
								
							
						
					
					
						commit
						bedc576313
					
				
					 3 changed files with 30 additions and 21 deletions
				
			
		|  | @ -34,9 +34,19 @@ export default class SelectedFeatureHandler { | ||||||
|             }else{ |             }else{ | ||||||
|                 // we search the element to select
 |                 // we search the element to select
 | ||||||
|                 const feature = state.allElements.ContainingFeatures.get(h) |                 const feature = state.allElements.ContainingFeatures.get(h) | ||||||
|                 if(feature !== undefined){ |                 if(feature === undefined){ | ||||||
|                     state.selectedElement.setData(feature) |                     return; | ||||||
|                 } |                 } | ||||||
|  |                 const currentlySeleced = state.selectedElement.data | ||||||
|  |                 if(currentlySeleced === undefined){ | ||||||
|  |                     state.selectedElement.setData(feature) | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 if(currentlySeleced.properties?.id === feature.properties.id){ | ||||||
|  |                     // We already have the right feature
 | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 state.selectedElement.setData(feature) | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ import {Utils} from "../Utils"; | ||||||
| 
 | 
 | ||||||
| export default class Constants { | export default class Constants { | ||||||
| 
 | 
 | ||||||
|     public static vNumber = "0.10.1-rc0"; |     public static vNumber = "0.10.1-rc1"; | ||||||
|     public static ImgurApiKey = '7070e7167f0a25a' |     public static ImgurApiKey = '7070e7167f0a25a' | ||||||
|     public static readonly mapillary_client_token_v3 = 'TXhLaWthQ1d4RUg0czVxaTVoRjFJZzowNDczNjUzNmIyNTQyYzI2' |     public static readonly mapillary_client_token_v3 = 'TXhLaWthQ1d4RUg0czVxaTVoRjFJZzowNDczNjUzNmIyNTQyYzI2' | ||||||
|     public static readonly mapillary_client_token_v4 = "MLY|4441509239301885|b40ad2d3ea105435bd40c7e76993ae85" |     public static readonly mapillary_client_token_v4 = "MLY|4441509239301885|b40ad2d3ea105435bd40c7e76993ae85" | ||||||
|  |  | ||||||
|  | @ -85,11 +85,11 @@ export default class ShowDataLayer { | ||||||
| 
 | 
 | ||||||
|             if (feature.id !== feature.properties.id) { |             if (feature.id !== feature.properties.id) { | ||||||
|                 // Probably a feature which has renamed
 |                 // Probably a feature which has renamed
 | ||||||
|  |                 // the feature might have as id 'node/-1' and as 'feature.properties.id' = 'the newly assigned id'. That is no good too
 | ||||||
|                 console.log("Not opening the popup for", feature, "as probably renamed") |                 console.log("Not opening the popup for", feature, "as probably renamed") | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (selected.geometry.type === feature.geometry.type  // If a feature is rendered both as way and as point, opening one popup might trigger the other to open, which might trigger the one to open again
 |             if (selected.geometry.type === feature.geometry.type  // If a feature is rendered both as way and as point, opening one popup might trigger the other to open, which might trigger the one to open again
 | ||||||
|                 && feature.id === feature.properties.id // the feature might have as id 'node/-1' and as 'feature.properties.id' = 'the newly assigned id'. That is no good too
 |  | ||||||
|             ) { |             ) { | ||||||
|                 console.log("Opening popup of feature", feature) |                 console.log("Opening popup of feature", feature) | ||||||
|                 leafletLayer.openPopup() |                 leafletLayer.openPopup() | ||||||
|  | @ -221,10 +221,11 @@ export default class ShowDataLayer { | ||||||
| 
 | 
 | ||||||
|         let infobox: FeatureInfoBox = undefined; |         let infobox: FeatureInfoBox = undefined; | ||||||
| 
 | 
 | ||||||
|         const id = `popup-${feature.properties.id}-${this._cleanCount}` |         const id = `popup-${feature.properties.id}-${feature.geometry.type}-${this._cleanCount}` | ||||||
|         popup.setContent(`<div style='height: 65vh' id='${id}'>Rendering</div>`) |         popup.setContent(`<div style='height: 65vh' id='${id}'>Popup for ${feature.properties.id} ${feature.geometry.type}</div>`) | ||||||
| 
 | 
 | ||||||
|         leafletLayer.on("popupopen", () => { |         leafletLayer.on("popupopen", () => { | ||||||
|  |             console.trace(`Opening the popup for ${feature.properties.id} ${feature.geometry.type}`) | ||||||
|             if (infobox === undefined) { |             if (infobox === undefined) { | ||||||
|                 const tags = State.state.allElements.getEventSourceById(feature.properties.id); |                 const tags = State.state.allElements.getEventSourceById(feature.properties.id); | ||||||
|                 infobox = new FeatureInfoBox(tags, layer); |                 infobox = new FeatureInfoBox(tags, layer); | ||||||
|  | @ -236,20 +237,18 @@ export default class ShowDataLayer { | ||||||
|                     } |                     } | ||||||
|                 }); |                 }); | ||||||
|             } |             } | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|             infobox.AttachTo(id) |             infobox.AttachTo(id) | ||||||
|             infobox.Activate(); |             infobox.Activate(); | ||||||
|  |             State.state.selectedElement.setData(feature) | ||||||
| 
 | 
 | ||||||
|              |  | ||||||
|             if(State.state.selectedElement.data?.properties?.id !== feature.properties.id){ |  | ||||||
|                // x State.state.selectedElement.setData(feature)
 |  | ||||||
|             } |  | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         // Add the feature to the index to open the popup when needed
 |         // Add the feature to the index to open the popup when needed
 | ||||||
|         this.leafletLayersPerId.set(feature.properties.id+feature.geometry.type, {feature: feature, leafletlayer: leafletLayer}) |         this.leafletLayersPerId.set(feature.properties.id + feature.geometry.type, { | ||||||
|  |             feature: feature, | ||||||
|  |             leafletlayer: leafletLayer | ||||||
|  |         }) | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue