2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Supporting macOS Dark Mode
  
						 
					
						
							
								
									
										
										
										
											2018-11-08 11:16:47 +11:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In macOS 10.14 Mojave, Apple introduced a new [system-wide dark mode ](https://developer.apple.com/design/human-interface-guidelines/macos/visual-design/dark-mode/ )
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								for all macOS computers.  If your Electron app has a dark mode, you can make it follow the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								system-wide dark mode setting using [the `nativeTheme` api ](../api/native-theme.md ).
							 
						 
					
						
							
								
									
										
										
										
											2018-11-08 11:16:47 +11:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								In macOS 10.15 Catalina, Apple introduced a new "automatic" dark mode option for all macOS computers.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In order for the `nativeTheme.shouldUseDarkColors`  and `Tray`  APIs to work correctly in this mode on
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Catalina, you need to either have `NSRequiresAquaSystemAppearance`  set to `false`  in your
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`Info.plist`  file, or be on Electron `>=7.0.0` . Both [Electron Packager][electron-packager] and 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[Electron Forge][electron-forge] have a [`darwinDarkModeSupport`  option][packager-darwindarkmode-api]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to automate the `Info.plist`  changes during app build time.
							 
						 
					
						
							
								
									
										
										
										
											2018-11-08 11:16:47 +11:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Automatically updating the native interfaces
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-11 14:30:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								"Native Interfaces" include the file picker, window border, dialogs, context menus, and more; basically,
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								anything where the UI comes from macOS and not your app. As of Electron 7.0.0, the default behavior
							 
						 
					
						
							
								
									
										
										
										
											2020-08-11 14:30:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								is to opt into this automatic theming from the OS. If you wish to opt-out and are using Electron
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  8.0.0, you must set the `NSRequiresAquaSystemAppearance`  key in the `Info.plist`  file to `true` . 
						 
					
						
							
								
									
										
										
										
											2020-08-11 14:30:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Please note that Electron 8.0.0 and above will not let your opt-out of this theming, due to the use
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								of the macOS 10.14 SDK.
							 
						 
					
						
							
								
									
										
										
										
											2018-12-01 02:02:36 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-11-08 11:16:47 +11:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								## Automatically updating your own interfaces
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If your app has its own dark mode, you should toggle it on and off in sync with the system's dark
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								mode setting. You can do this by listening for the theme updated event on Electron's `nativeTheme`  module.
							 
						 
					
						
							
								
									
										
										
										
											2018-11-08 11:16:47 +11:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								For example:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```javascript
							 
						 
					
						
							
								
									
										
										
										
											2019-12-18 07:13:35 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const { nativeTheme } = require('electron')
							 
						 
					
						
							
								
									
										
										
										
											2018-11-08 11:16:47 +11:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-31 06:49:48 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								nativeTheme.on('updated', function theThemeHasChanged () {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  updateMyAppTheme(nativeTheme.shouldUseDarkColors)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
									
										
										
										
											2018-11-08 11:16:47 +11:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 13:19:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[electron-forge]: https://www.electronforge.io/
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[electron-packager]: https://github.com/electron/electron-packager
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[packager-darwindarkmode-api]: https://electron.github.io/electron-packager/master/interfaces/electronpackager.options.html#darwindarkmodesupport