| 
									
										
										
										
											2022-03-03 09:56:00 -08:00
										 |  |  | --- | 
					
						
							|  |  |  | title: Progress Bars | 
					
						
							|  |  |  | description: Provide progress information to users outside of a BrowserWindow. | 
					
						
							|  |  |  | slug: progress-bar | 
					
						
							|  |  |  | hide_title: true | 
					
						
							|  |  |  | --- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Progress Bars
 | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | ## Overview
 | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | A progress bar enables a window to provide progress information to the user | 
					
						
							|  |  |  | without the need of switching to the window itself. | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | On Windows, you can use a taskbar button to display a progress bar. | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-19 10:43:10 +02:00
										 |  |  |  | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | On macOS, the progress bar will be displayed as a part of the dock icon. | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-16 15:42:58 -07:00
										 |  |  |  | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | On Linux, the Unity graphical interface also has a similar feature that allows | 
					
						
							|  |  |  | you to specify the progress bar in the launcher. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-16 15:42:58 -07:00
										 |  |  |  | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | > NOTE: on Windows, each window can have its own progress bar, whereas on macOS
 | 
					
						
							|  |  |  | and Linux (Unity) there can be only one progress bar for the application. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ---- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | All three cases are covered by the same API - the | 
					
						
							|  |  |  | [`setProgressBar()`][setprogressbar] method available on an instance of | 
					
						
							|  |  |  | `BrowserWindow`. To indicate your progress, call this method with a number | 
					
						
							|  |  |  | between `0` and `1`. For example, if you have a long-running task that is | 
					
						
							|  |  |  | currently at 63% towards completion, you would call it as | 
					
						
							|  |  |  | `setProgressBar(0.63)`. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Setting the parameter to negative values (e.g. `-1`) will remove the progress | 
					
						
							| 
									
										
										
										
											2021-06-01 19:41:13 -07:00
										 |  |  | bar. Setting it to a value greater than `1` will indicate an indeterminate progress bar | 
					
						
							|  |  |  | in Windows or clamp to 100% in other operating systems. An indeterminate progress bar | 
					
						
							|  |  |  | remains active but does not show an actual percentage, and is used for situations when | 
					
						
							|  |  |  | you do not know how long an operation will take to complete. | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | See the [API documentation for more options and modes][setprogressbar]. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | ## Example
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-01 19:41:13 -07:00
										 |  |  | In this example, we add a progress bar to the main window that increments over time | 
					
						
							|  |  |  | using Node.js timers. | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-20 23:50:08 -08:00
										 |  |  | ```fiddle docs/fiddles/features/progress-bar | 
					
						
							|  |  |  | const { app, BrowserWindow } = require('electron/main') | 
					
						
							| 
									
										
										
										
											2021-06-01 19:41:13 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | let progressInterval | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-20 23:50:08 -08:00
										 |  |  | function createWindow () { | 
					
						
							| 
									
										
										
										
											2021-06-01 19:41:13 -07:00
										 |  |  |   const win = new BrowserWindow({ | 
					
						
							|  |  |  |     width: 800, | 
					
						
							|  |  |  |     height: 600 | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   win.loadFile('index.html') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const INCREMENT = 0.03 | 
					
						
							|  |  |  |   const INTERVAL_DELAY = 100 // ms | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let c = 0 | 
					
						
							|  |  |  |   progressInterval = setInterval(() => { | 
					
						
							|  |  |  |     // update progress bar to next value | 
					
						
							|  |  |  |     // values between 0 and 1 will show progress, >1 will show indeterminate or stick at 100% | 
					
						
							|  |  |  |     win.setProgressBar(c) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // increment or reset progress bar | 
					
						
							| 
									
										
										
										
											2023-11-20 23:50:08 -08:00
										 |  |  |     if (c < 2) { | 
					
						
							|  |  |  |       c += INCREMENT | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       c = (-INCREMENT * 5) // reset to a bit less than 0 to show reset state | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-06-01 19:41:13 -07:00
										 |  |  |   }, INTERVAL_DELAY) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | app.whenReady().then(createWindow) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // before the app is terminated, clear both timers | 
					
						
							|  |  |  | app.on('before-quit', () => { | 
					
						
							|  |  |  |   clearInterval(progressInterval) | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | app.on('window-all-closed', () => { | 
					
						
							|  |  |  |   if (process.platform !== 'darwin') { | 
					
						
							|  |  |  |     app.quit() | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | app.on('activate', () => { | 
					
						
							|  |  |  |   if (BrowserWindow.getAllWindows().length === 0) { | 
					
						
							|  |  |  |     createWindow() | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }) | 
					
						
							| 
									
										
										
										
											2018-02-19 17:17:11 -06:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-01 19:41:13 -07:00
										 |  |  | After launching the Electron application, the dock (macOS) or taskbar (Windows, Unity) | 
					
						
							|  |  |  | should show a progress bar that starts at zero and progresses through 100% to completion. | 
					
						
							|  |  |  | It should then show indeterminate (Windows) or pin to 100% (other operating systems) | 
					
						
							|  |  |  | briefly and then loop. | 
					
						
							| 
									
										
										
										
											2020-10-23 09:03:04 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | For macOS, the progress bar will also be indicated for your application | 
					
						
							|  |  |  | when using [Mission Control](https://support.apple.com/en-us/HT204100): | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  | 
					
						
							| 
									
										
										
										
											2020-10-19 18:46:27 -07:00
										 |  |  | [setprogressbar]: ../api/browser-window.md#winsetprogressbarprogress-options |