| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | # powerSaveBlocker
 | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-21 15:39:12 -07:00
										 |  |  | > Block the system from entering low-power (sleep) mode.
 | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-23 11:20:56 -08:00
										 |  |  | Process: [Main](../glossary.md#main-process) | 
					
						
							| 
									
										
										
										
											2016-11-03 10:26:00 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | For example: | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```javascript | 
					
						
							| 
									
										
										
										
											2016-07-25 18:39:25 -07:00
										 |  |  | const {powerSaveBlocker} = require('electron') | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-25 18:39:25 -07:00
										 |  |  | const id = powerSaveBlocker.start('prevent-display-sleep') | 
					
						
							|  |  |  | console.log(powerSaveBlocker.isStarted(id)) | 
					
						
							| 
									
										
										
										
											2015-06-22 10:23:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-25 18:39:25 -07:00
										 |  |  | powerSaveBlocker.stop(id) | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | ## Methods
 | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | The `powerSaveBlocker` module has the following methods: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### `powerSaveBlocker.start(type)`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * `type` String - Power save blocker type. | 
					
						
							| 
									
										
										
										
											2015-06-24 12:49:43 +08:00
										 |  |  |   * `prevent-app-suspension` - Prevent the application from being suspended. | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  |     Keeps system active but allows screen to be turned off.  Example use cases: | 
					
						
							|  |  |  |     downloading a file or playing audio. | 
					
						
							| 
									
										
										
										
											2016-08-22 11:17:05 -07:00
										 |  |  |   * `prevent-display-sleep` - Prevent the display from going to sleep. Keeps | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  |     system and screen active.  Example use case: playing video. | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-25 12:59:30 +13:00
										 |  |  | Returns `Integer` - The blocker ID that is assigned to this power blocker | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-01 16:21:29 -07:00
										 |  |  | Starts preventing the system from entering lower-power mode. Returns an integer | 
					
						
							|  |  |  | identifying the power save blocker. | 
					
						
							| 
									
										
										
										
											2015-06-22 10:23:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-11 21:08:01 -05:00
										 |  |  | **Note:** `prevent-display-sleep` has higher precedence over | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | `prevent-app-suspension`. Only the highest precedence type takes effect. In | 
					
						
							| 
									
										
										
										
											2015-09-01 16:21:29 -07:00
										 |  |  | other words, `prevent-display-sleep` always takes precedence over | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | `prevent-app-suspension`. | 
					
						
							| 
									
										
										
										
											2015-06-22 10:23:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-24 12:49:43 +08:00
										 |  |  | For example, an API calling A requests for `prevent-app-suspension`, and | 
					
						
							|  |  |  | another calling B requests for `prevent-display-sleep`. `prevent-display-sleep` | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | will be used until B stops its request. After that, `prevent-app-suspension` | 
					
						
							|  |  |  | is used. | 
					
						
							| 
									
										
										
										
											2015-06-22 10:23:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | ### `powerSaveBlocker.stop(id)`
 | 
					
						
							| 
									
										
										
										
											2015-06-22 10:23:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | * `id` Integer - The power save blocker id returned by `powerSaveBlocker.start`. | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-22 10:23:58 +08:00
										 |  |  | Stops the specified power save blocker. | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-28 21:44:13 -07:00
										 |  |  | ### `powerSaveBlocker.isStarted(id)`
 | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-22 10:23:58 +08:00
										 |  |  | * `id` Integer - The power save blocker id returned by `powerSaveBlocker.start`. | 
					
						
							| 
									
										
										
										
											2015-06-21 21:14:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-25 12:59:30 +13:00
										 |  |  | Returns `Boolean` - Whether the corresponding `powerSaveBlocker` has started. |