forked from mirrors/gecko-dev
		
	Bug 1758730 - Ensure no errors or warning show on search engine prefs; r=Standard8
The live language reloading triggers code that will run that assumes the view is visible, when in fact it may not be on the dom. This fixes that. In addition it fixes the error where the engine tries to update after it has been removed. Differential Revision: https://phabricator.services.mozilla.com/D141685
This commit is contained in:
		
							parent
							
								
									521ea00689
								
							
						
					
					
						commit
						c2f751983d
					
				
					 1 changed files with 9 additions and 5 deletions
				
			
		|  | @ -484,10 +484,17 @@ var gSearchPane = { | ||||||
| 
 | 
 | ||||||
|   remove(aEngine) { |   remove(aEngine) { | ||||||
|     let index = gEngineView._engineStore.removeEngine(aEngine); |     let index = gEngineView._engineStore.removeEngine(aEngine); | ||||||
|  |     if (!gEngineView.tree) { | ||||||
|  |       // Only update the selection if it's visible in the UI.
 | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     gEngineView.rowCountChanged(index, -1); |     gEngineView.rowCountChanged(index, -1); | ||||||
|     gEngineView.invalidate(); |     gEngineView.invalidate(); | ||||||
|  | 
 | ||||||
|     gEngineView.selection.select(Math.min(index, gEngineView.rowCount - 1)); |     gEngineView.selection.select(Math.min(index, gEngineView.rowCount - 1)); | ||||||
|     gEngineView.ensureRowIsVisible(gEngineView.currentIndex); |     gEngineView.ensureRowIsVisible(gEngineView.currentIndex); | ||||||
|  | 
 | ||||||
|     document.getElementById("engineList").focus(); |     document.getElementById("engineList").focus(); | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|  | @ -652,12 +659,9 @@ EngineStore.prototype = { | ||||||
|     let engineToUpdate = this._engines.findIndex( |     let engineToUpdate = this._engines.findIndex( | ||||||
|       e => e.originalEngine == newEngine |       e => e.originalEngine == newEngine | ||||||
|     ); |     ); | ||||||
|     if (engineToUpdate == -1) { |     if (engineToUpdate != -1) { | ||||||
|       console.error("Could not find engine to update"); |       this.engines[engineToUpdate] = this._cloneEngine(newEngine); | ||||||
|       return; |  | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     this.engines[engineToUpdate] = this._cloneEngine(newEngine); |  | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   moveEngine(aEngine, aNewIndex) { |   moveEngine(aEngine, aNewIndex) { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Greg Tatum
						Greg Tatum