forked from MapComplete/MapComplete
		
	Small performance issues, improvement of #579
This commit is contained in:
		
							parent
							
								
									4fd30d1a62
								
							
						
					
					
						commit
						ee962f4ba3
					
				
					 2 changed files with 17 additions and 9 deletions
				
			
		|  | @ -281,10 +281,12 @@ export class UIEventSource<T> { | ||||||
|      * @param f: The transforming function |      * @param f: The transforming function | ||||||
|      * @param extraSources: also trigger the update if one of these sources change |      * @param extraSources: also trigger the update if one of these sources change | ||||||
|      * @param g: a 'backfunction to let the sync run in two directions. (data of the new UIEVEntSource, currentData) => newData |      * @param g: a 'backfunction to let the sync run in two directions. (data of the new UIEVEntSource, currentData) => newData | ||||||
|  |      * @param allowUnregister: if set, the update will be halted if no listeners are registered | ||||||
|      */ |      */ | ||||||
|     public map<J>(f: ((t: T) => J), |     public map<J>(f: ((t: T) => J), | ||||||
|                   extraSources: UIEventSource<any>[] = [], |                   extraSources: UIEventSource<any>[] = [], | ||||||
|                   g: ((j: J, t: T) => T) = undefined): UIEventSource<J> { |                   g: ((j: J, t: T) => T) = undefined, | ||||||
|  |                   allowUnregister = false): UIEventSource<J> { | ||||||
|         const self = this; |         const self = this; | ||||||
| 
 | 
 | ||||||
|         const stack = new Error().stack.split("\n"); |         const stack = new Error().stack.split("\n"); | ||||||
|  | @ -297,6 +299,7 @@ export class UIEventSource<T> { | ||||||
| 
 | 
 | ||||||
|         const update = function () { |         const update = function () { | ||||||
|             newSource.setData(f(self.data)); |             newSource.setData(f(self.data)); | ||||||
|  |             return allowUnregister && newSource._callbacks.length === 0 | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         this.addCallback(update); |         this.addCallback(update); | ||||||
|  |  | ||||||
|  | @ -145,7 +145,8 @@ export default class ShowDataLayer { | ||||||
|             pointToLayer: (feature, latLng) => self.pointToLayer(feature, latLng), |             pointToLayer: (feature, latLng) => self.pointToLayer(feature, latLng), | ||||||
|             onEachFeature: (feature, leafletLayer) => self.postProcessFeature(feature, leafletLayer) |             onEachFeature: (feature, leafletLayer) => self.postProcessFeature(feature, leafletLayer) | ||||||
|         }); |         }); | ||||||
| 
 |          | ||||||
|  |         const selfLayer = this.geoLayer; | ||||||
|         const allFeats = this._features.features.data; |         const allFeats = this._features.features.data; | ||||||
|         for (const feat of allFeats) { |         for (const feat of allFeats) { | ||||||
|             if (feat === undefined) { |             if (feat === undefined) { | ||||||
|  | @ -153,12 +154,11 @@ export default class ShowDataLayer { | ||||||
|             } |             } | ||||||
|             try { |             try { | ||||||
|                 if (feat.geometry.type === "LineString") { |                 if (feat.geometry.type === "LineString") { | ||||||
|                     const self = this; |  | ||||||
|                     const coords = L.GeoJSON.coordsToLatLngs(feat.geometry.coordinates) |                     const coords = L.GeoJSON.coordsToLatLngs(feat.geometry.coordinates) | ||||||
|                     const tagsSource = this.allElements?.addOrGetElement(feat) ?? new UIEventSource<any>(feat.properties); |                     const tagsSource = this.allElements?.addOrGetElement(feat) ?? new UIEventSource<any>(feat.properties); | ||||||
|                     let offsettedLine; |                     let offsettedLine; | ||||||
|                     tagsSource |                     tagsSource | ||||||
|                         .map(tags => this._layerToShow.lineRendering[feat.lineRenderingIndex].GenerateLeafletStyle(tags)) |                         .map(tags => this._layerToShow.lineRendering[feat.lineRenderingIndex].GenerateLeafletStyle(tags), [], undefined, true) | ||||||
|                         .withEqualityStabilized((a, b) => { |                         .withEqualityStabilized((a, b) => { | ||||||
|                             if (a === b) { |                             if (a === b) { | ||||||
|                                 return true |                                 return true | ||||||
|  | @ -176,6 +176,9 @@ export default class ShowDataLayer { | ||||||
|                             offsettedLine = L.polyline(coords, lineStyle); |                             offsettedLine = L.polyline(coords, lineStyle); | ||||||
|                             this.postProcessFeature(feat, offsettedLine) |                             this.postProcessFeature(feat, offsettedLine) | ||||||
|                             offsettedLine.addTo(this.geoLayer) |                             offsettedLine.addTo(this.geoLayer) | ||||||
|  |                              | ||||||
|  |                             // If 'self.geoLayer' is not the same as the layer the feature is added to, we can safely remove this callback
 | ||||||
|  |                             return self.geoLayer !== selfLayer | ||||||
|                         }) |                         }) | ||||||
|                 } else { |                 } else { | ||||||
|                     this.geoLayer.addData(feat); |                     this.geoLayer.addData(feat); | ||||||
|  | @ -186,11 +189,13 @@ export default class ShowDataLayer { | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (options.zoomToFeatures ?? false) { |         if (options.zoomToFeatures ?? false) { | ||||||
|             try { |             if(this.geoLayer.getLayers().length > 0){ | ||||||
|                 const bounds = this.geoLayer.getBounds() |                 try { | ||||||
|                 mp.fitBounds(bounds, {animate: false}) |                     const bounds = this.geoLayer.getBounds() | ||||||
|             } catch (e) { |                     mp.fitBounds(bounds, {animate: false}) | ||||||
|                 console.debug("Invalid bounds", e) |                 } catch (e) { | ||||||
|  |                     console.debug("Invalid bounds", e) | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue