2013-09-09 15:35:57 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# dialog
  
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-04-21 15:39:12 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  Display native system dialogs for opening and saving files, alerting, etc.
  
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-11-23 11:20:56 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Process: [Main ](../glossary.md#main-process )
							 
						 
					
						
							
								
									
										
										
										
											2016-11-03 10:26:00 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-07-01 16:53:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								An example of showing a dialog to select multiple files:
							 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-20 23:50:08 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2018-09-14 02:10:51 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const { dialog } = require('electron')
							 
						 
					
						
							
								
									
										
										
										
											2019-07-01 16:53:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								console.log(dialog.showOpenDialog({ properties: ['openFile', 'multiSelections'] }))
							 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Methods
  
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `dialog`  module has the following methods:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### `dialog.showOpenDialogSync([window, ]options)`
  
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `window`  [BaseWindow ](base-window.md ) (optional) 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `options`  Object 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `title`  string (optional)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `defaultPath`  string (optional)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `buttonLabel`  string (optional) - Custom label for the confirmation button, when
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    left empty the default label will be used.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `filters`  [FileFilter[]](structures/file-filter.md) (optional)
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `properties`  string[]& #32 ; (optional) - Contains which features the dialog should
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    use. The following values are supported:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `openFile`  - Allow files to be selected.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `openDirectory`  - Allow directories to be selected.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `multiSelections`  - Allow multiple paths to be selected.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `showHiddenFiles`  - Show hidden files in dialog.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `createDirectory`  _macOS_  - Allow creating new directories from dialog.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `promptToCreate`  _Windows_  - Prompt for creation if the file path entered
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      in the dialog does not exist. This does not actually create the file at
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      the path but allows non-existent paths to be returned that should be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      created by the application.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `noResolveAliases`  _macOS_  - Disable the automatic alias (symlink) path
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      resolution. Selected aliases will now return the alias path instead of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      their target path.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `treatPackageAsDirectory`  _macOS_  - Treat packages, such as `.app`  folders,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      as a directory instead of a file.
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 08:48:22 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    *  `dontAddToRecent`  _Windows_  - Do not add the item being opened to the recent documents list.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `message`  string (optional) _macOS_  - Message to display above input
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    boxes.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `securityScopedBookmarks`  boolean (optional) _macOS_  _mas_  - Create [security scoped bookmarks ](https://developer.apple.com/library/content/documentation/Security/Conceptual/AppSandboxDesignGuide/AppSandboxInDepth/AppSandboxInDepth.html#//apple_ref/doc/uid/TP40011183-CH3-SW16 ) when packaged for the Mac App Store.
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Returns `string[] | undefined` , the file paths chosen by the user; if the dialog is cancelled it returns `undefined` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-16 09:24:17 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `window`  argument allows the dialog to attach itself to a parent window, making it modal.
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `filters`  specifies an array of file types that can be displayed or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								selected when you want to limit the user to a specific type. For example:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-20 23:50:08 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  filters: [
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    { name: 'Images', extensions: ['jpg', 'png', 'gif'] },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    { name: 'Movies', extensions: ['mkv', 'avi', 'mp4'] },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    { name: 'Custom File Type', extensions: ['as'] },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    { name: 'All Files', extensions: ['*'] }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `extensions`  array should contain extensions without wildcards or dots (e.g.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`'png'`  is good but `'.png'`  and `'*.png'`  are bad). To show all files, use the 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`'*'`  wildcard (no other wildcard is supported). 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-05-09 17:46:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  [!NOTE]
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  On Windows and Linux an open dialog can not be both a file selector
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  and a directory selector, so if you set `properties` to
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  `['openFile', 'openDirectory']` on these platforms, a directory selector will be
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  shown.
  
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js @ts -type={mainWindow:Electron.BaseWindow}
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								dialog.showOpenDialogSync(mainWindow, {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  properties: ['openFile', 'openDirectory']
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-05-09 17:46:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  [!NOTE]
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  On Linux `defaultPath` is not supported when using portal file chooser
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  dialogs unless the portal backend is version 4 or higher. You can use `--xdg-portal-required-version`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  [command-line switch](./command-line-switches.md#--xdg-portal-required-versionversion)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  to force gtk or kde dialogs.
  
						 
					
						
							
								
									
										
										
										
											2024-11-15 23:31:33 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### `dialog.showOpenDialog([window, ]options)`
  
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `window`  [BaseWindow ](base-window.md ) (optional) 
						 
					
						
							
								
									
										
										
										
											2015-12-17 18:40:52 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `options`  Object 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `title`  string (optional)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `defaultPath`  string (optional)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `buttonLabel`  string (optional) - Custom label for the confirmation button, when
							 
						 
					
						
							
								
									
										
										
										
											2016-05-16 10:09:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    left empty the default label will be used.
							 
						 
					
						
							
								
									
										
										
										
											2016-11-21 00:49:11 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `filters`  [FileFilter[]](structures/file-filter.md) (optional)
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `properties`  string[]& #32 ; (optional) - Contains which features the dialog should
							 
						 
					
						
							
								
									
										
										
										
											2017-02-02 08:30:02 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    use. The following values are supported:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `openFile`  - Allow files to be selected.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `openDirectory`  - Allow directories to be selected.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `multiSelections`  - Allow multiple paths to be selected.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `showHiddenFiles`  - Show hidden files in dialog.
							 
						 
					
						
							
								
									
										
										
										
											2017-11-29 11:38:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    *  `createDirectory`  _macOS_  - Allow creating new directories from dialog.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `promptToCreate`  _Windows_  - Prompt for creation if the file path entered
							 
						 
					
						
							
								
									
										
										
										
											2017-02-02 08:30:02 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      in the dialog does not exist. This does not actually create the file at
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      the path but allows non-existent paths to be returned that should be
							 
						 
					
						
							
								
									
										
										
										
											2017-11-29 11:38:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      created by the application.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `noResolveAliases`  _macOS_  - Disable the automatic alias (symlink) path
							 
						 
					
						
							
								
									
										
										
										
											2017-11-29 11:58:24 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      resolution. Selected aliases will now return the alias path instead of
							 
						 
					
						
							
								
									
										
										
										
											2017-11-29 11:38:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      their target path.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `treatPackageAsDirectory`  _macOS_  - Treat packages, such as `.app`  folders,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      as a directory instead of a file.
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 08:48:22 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    *  `dontAddToRecent`  _Windows_  - Do not add the item being opened to the recent documents list.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `message`  string (optional) _macOS_  - Message to display above input
							 
						 
					
						
							
								
									
										
										
										
											2017-03-31 15:08:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    boxes.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `securityScopedBookmarks`  boolean (optional) _macOS_  _mas_  - Create [security scoped bookmarks ](https://developer.apple.com/library/content/documentation/Security/Conceptual/AppSandboxDesignGuide/AppSandboxInDepth/AppSandboxInDepth.html#//apple_ref/doc/uid/TP40011183-CH3-SW16 ) when packaged for the Mac App Store.
							 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-23 00:22:51 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Returns `Promise<Object>`  - Resolve with an object containing the following:
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `canceled`  boolean - whether or not the dialog was canceled. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `filePaths`  string[] - An array of file paths chosen by the user. If the dialog is cancelled this will be an empty array. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `bookmarks`  string[]& #32 ; (optional) _macOS_  _mas_  - An array matching the `filePaths`  array of base64 encoded strings which contains security scoped bookmark data. `securityScopedBookmarks`  must be enabled for this to be populated. (For return values, see [table here ](#bookmarks-array ).) 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `window`  argument allows the dialog to attach itself to a parent window, making it modal.
							 
						 
					
						
							
								
									
										
										
										
											2016-12-06 22:23:14 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-08-06 15:00:31 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `filters`  specifies an array of file types that can be displayed or
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								selected when you want to limit the user to a specific type. For example:
							 
						 
					
						
							
								
									
										
										
										
											2014-08-06 15:00:31 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-20 23:50:08 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2014-08-06 15:00:31 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  filters: [
							 
						 
					
						
							
								
									
										
										
										
											2018-09-14 02:10:51 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    { name: 'Images', extensions: ['jpg', 'png', 'gif'] },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    { name: 'Movies', extensions: ['mkv', 'avi', 'mp4'] },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    { name: 'Custom File Type', extensions: ['as'] },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    { name: 'All Files', extensions: ['*'] }
							 
						 
					
						
							
								
									
										
										
										
											2015-06-09 17:59:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  ]
							 
						 
					
						
							
								
									
										
										
										
											2014-08-06 15:00:31 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-09-02 09:19:18 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-08-22 05:09:37 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `extensions`  array should contain extensions without wildcards or dots (e.g.
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`'png'`  is good but `'.png'`  and `'*.png'`  are bad). To show all files, use the 
						 
					
						
							
								
									
										
										
										
											2015-08-22 05:09:37 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`'*'`  wildcard (no other wildcard is supported). 
						 
					
						
							
								
									
										
										
										
											2014-08-06 15:00:31 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-05-09 17:46:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  [!NOTE]
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  On Windows and Linux an open dialog can not be both a file selector
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  and a directory selector, so if you set `properties` to
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  `['openFile', 'openDirectory']` on these platforms, a directory selector will be
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  shown.
  
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js @ts -type={mainWindow:Electron.BaseWindow}
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								dialog.showOpenDialog(mainWindow, {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  properties: ['openFile', 'openDirectory']
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}).then(result => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  console.log(result.canceled)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  console.log(result.filePaths)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}).catch(err => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  console.log(err)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-05-09 17:46:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  [!NOTE]
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  On Linux `defaultPath` is not supported when using portal file chooser
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  dialogs unless the portal backend is version 4 or higher. You can use `--xdg-portal-required-version`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  [command-line switch](./command-line-switches.md#--xdg-portal-required-versionversion)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  to force gtk or kde dialogs.
  
						 
					
						
							
								
									
										
										
										
											2024-11-15 23:31:33 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### `dialog.showSaveDialogSync([window, ]options)`
  
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `window`  [BaseWindow ](base-window.md ) (optional) 
						 
					
						
							
								
									
										
										
										
											2015-12-17 18:40:52 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `options`  Object 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `title`  string (optional) - The dialog title. Cannot be displayed on some _Linux_  desktop environments.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `defaultPath`  string (optional) - Absolute directory path, absolute file
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 02:11:58 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    path, or file name to use by default.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `buttonLabel`  string (optional) - Custom label for the confirmation button, when
							 
						 
					
						
							
								
									
										
										
										
											2016-05-16 10:09:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    left empty the default label will be used.
							 
						 
					
						
							
								
									
										
										
										
											2016-12-13 17:42:47 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `filters`  [FileFilter[]](structures/file-filter.md) (optional)
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `message`  string (optional) _macOS_  - Message to display above text fields.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `nameFieldLabel`  string (optional) _macOS_  - Custom label for the text
							 
						 
					
						
							
								
									
										
										
										
											2017-02-09 11:29:10 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    displayed in front of the filename text field.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `showsTagField`  boolean (optional) _macOS_  - Show the tags input box,
							 
						 
					
						
							
								
									
										
										
										
											2017-02-09 11:29:10 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    defaults to `true` .
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `properties`  string[]& #32 ; (optional)
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 13:40:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    *  `showHiddenFiles`  - Show hidden files in dialog.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `createDirectory`  _macOS_  - Allow creating new directories from dialog.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `treatPackageAsDirectory`  _macOS_  - Treat packages, such as `.app`  folders,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      as a directory instead of a file.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `showOverwriteConfirmation`  _Linux_  - Sets whether the user will be presented a confirmation dialog if the user types a file name that already exists.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `dontAddToRecent`  _Windows_  - Do not add the item being saved to the recent documents list.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `securityScopedBookmarks`  boolean (optional) _macOS_  _mas_  - Create a [security scoped bookmark ](https://developer.apple.com/library/content/documentation/Security/Conceptual/AppSandboxDesignGuide/AppSandboxInDepth/AppSandboxInDepth.html#//apple_ref/doc/uid/TP40011183-CH3-SW16 ) when packaged for the Mac App Store. If this option is enabled and the file doesn't already exist a blank file will be created at the chosen path.
							 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-04-23 11:29:14 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Returns `string` , the path of the file chosen by the user; if the dialog is cancelled it returns an empty string.
							 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `window`  argument allows the dialog to attach itself to a parent window, making it modal.
							 
						 
					
						
							
								
									
										
										
										
											2016-12-06 22:23:14 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-08-06 15:00:31 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `filters`  specifies an array of file types that can be displayed, see
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`dialog.showOpenDialog`  for an example. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### `dialog.showSaveDialog([window, ]options)`
  
						 
					
						
							
								
									
										
										
										
											2019-03-05 13:48:20 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `window`  [BaseWindow ](base-window.md ) (optional) 
						 
					
						
							
								
									
										
										
										
											2019-03-05 13:48:20 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `options`  Object 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `title`  string (optional) - The dialog title. Cannot be displayed on some _Linux_  desktop environments.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `defaultPath`  string (optional) - Absolute directory path, absolute file
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 13:48:20 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    path, or file name to use by default.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `buttonLabel`  string (optional) - Custom label for the confirmation button, when
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 13:48:20 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    left empty the default label will be used.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `filters`  [FileFilter[]](structures/file-filter.md) (optional)
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `message`  string (optional) _macOS_  - Message to display above text fields.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `nameFieldLabel`  string (optional) _macOS_  - Custom label for the text
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 13:48:20 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    displayed in front of the filename text field.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `showsTagField`  boolean (optional) _macOS_  - Show the tags input box, defaults to `true` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `properties`  string[]& #32 ; (optional)
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 13:40:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    *  `showHiddenFiles`  - Show hidden files in dialog.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `createDirectory`  _macOS_  - Allow creating new directories from dialog.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `treatPackageAsDirectory`  _macOS_  - Treat packages, such as `.app`  folders,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      as a directory instead of a file.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `showOverwriteConfirmation`  _Linux_  - Sets whether the user will be presented a confirmation dialog if the user types a file name that already exists.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  `dontAddToRecent`  _Windows_  - Do not add the item being saved to the recent documents list.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `securityScopedBookmarks`  boolean (optional) _macOS_  _mas_  - Create a [security scoped bookmark ](https://developer.apple.com/library/content/documentation/Security/Conceptual/AppSandboxDesignGuide/AppSandboxInDepth/AppSandboxInDepth.html#//apple_ref/doc/uid/TP40011183-CH3-SW16 ) when packaged for the Mac App Store. If this option is enabled and the file doesn't already exist a blank file will be created at the chosen path.
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 13:48:20 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns `Promise<Object>`  - Resolve with an object containing the following:
							 
						 
					
						
							
								
									
										
										
										
											2020-11-05 14:12:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `canceled`  boolean - whether or not the dialog was canceled. 
						 
					
						
							
								
									
										
										
										
											2024-04-23 11:29:14 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `filePath`  string - If the dialog is canceled, this will be an empty string. 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `bookmark`  string (optional) _macOS_  _mas_  - Base64 encoded string which contains the security scoped bookmark data for the saved file. `securityScopedBookmarks`  must be enabled for this to be present. (For return values, see [table here ](#bookmarks-array ).) 
						 
					
						
							
								
									
										
										
										
											2019-03-05 13:48:20 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `window`  argument allows the dialog to attach itself to a parent window, making it modal.
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 13:48:20 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `filters`  specifies an array of file types that can be displayed, see
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`dialog.showOpenDialog`  for an example. 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-05-09 17:46:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  [!NOTE]
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  On macOS, using the asynchronous version is recommended to avoid issues when
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  expanding and collapsing the dialog.
  
						 
					
						
							
								
									
										
										
										
											2019-02-04 09:56:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-02-27 10:32:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### `dialog.showMessageBoxSync([window, ]options)`
  
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `window`  [BaseWindow ](base-window.md ) (optional) 
						 
					
						
							
								
									
										
										
										
											2015-12-17 18:40:52 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `options`  Object 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `message`  string - Content of the message box.
							 
						 
					
						
							
								
									
										
										
										
											2023-05-17 10:33:30 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `type`  string (optional) - Can be `none` , `info` , `error` , `question`  or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  `warning` . On Windows, `question`  displays the same icon as `info` , unless
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  you set an icon using the `icon`  option. On macOS, both `warning`  and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  `error`  display the same warning icon.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `buttons`  string[]& #32 ; (optional) - Array of texts for buttons. On Windows, an empty array
							 
						 
					
						
							
								
									
										
										
										
											2016-05-19 18:32:43 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    will result in one button labeled "OK".
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 21:46:20 +11:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `defaultId`  Integer (optional) - Index of the button in the buttons array which will
							 
						 
					
						
							
								
									
										
										
										
											2016-01-10 19:15:40 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    be selected by default when the message box opens.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `title`  string (optional) - Title of the message box, some platforms will not show it.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `detail`  string (optional) - Extra information of the message.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `icon`  ([NativeImage ](native-image.md ) | string) (optional)
							 
						 
					
						
							
								
									
										
										
										
											2021-09-23 12:56:14 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `textWidth`  Integer (optional) _macOS_  - Custom width of the text in the message box.
							 
						 
					
						
							
								
									
										
										
										
											2017-02-24 23:56:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `cancelId`  Integer (optional) - The index of the button to be used to cancel the dialog, via
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    the `Esc`  key. By default this is assigned to the first button with "cancel" or "no" as the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    label. If no such labeled buttons exist and this option is not set, `0`  will be used as the
							 
						 
					
						
							
								
									
										
										
										
											2019-04-30 07:08:33 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return value.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `noLink`  boolean (optional) - On Windows Electron will try to figure out which one of
							 
						 
					
						
							
								
									
										
										
										
											2015-07-23 17:20:43 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    the `buttons`  are common buttons (like "Cancel" or "Yes"), and show the
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    others as command links in the dialog. This can make the dialog appear in
							 
						 
					
						
							
								
									
										
										
										
											2015-07-23 17:20:43 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    the style of modern Windows apps. If you don't like this behavior, you can
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    set `noLink`  to `true` .
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `normalizeAccessKeys`  boolean (optional) - Normalize the keyboard access keys
							 
						 
					
						
							
								
									
										
										
										
											2017-03-31 15:08:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    across platforms. Default is `false` . Enabling this assumes `&`  is used in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    the button labels for the placement of the keyboard shortcut access key
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    and labels will be converted so they work correctly on each platform, `&` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    characters are removed on macOS, converted to `_`  on Linux, and left
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    untouched on Windows. For example, a button label of `Vie&w`  will be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    converted to `Vie_w`  on Linux and `View`  on macOS and can be selected
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    via `Alt-W`  on Windows and Linux.
							 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Returns `Integer`  - the index of the clicked button.
							 
						 
					
						
							
								
									
										
										
										
											2016-11-05 19:42:45 +11:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Shows a message box, it will block the process until the message box is closed.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								It returns the index of the clicked button.
							 
						 
					
						
							
								
									
										
										
										
											2013-08-14 15:43:35 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `window`  argument allows the dialog to attach itself to a parent window, making it modal.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If `window`  is not shown dialog will not be attached to it. In such case it will be displayed as an independent window.
							 
						 
					
						
							
								
									
										
										
										
											2016-12-06 22:23:14 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### `dialog.showMessageBox([window, ]options)`
  
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `window`  [BaseWindow ](base-window.md ) (optional) 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `options`  Object 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `message`  string - Content of the message box.
							 
						 
					
						
							
								
									
										
										
										
											2023-05-17 10:33:30 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `type`  string (optional) - Can be `none` , `info` , `error` , `question`  or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  `warning` . On Windows, `question`  displays the same icon as `info` , unless
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  you set an icon using the `icon`  option. On macOS, both `warning`  and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  `error`  display the same warning icon.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `buttons`  string[]& #32 ; (optional) - Array of texts for buttons. On Windows, an empty array
							 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    will result in one button labeled "OK".
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `defaultId`  Integer (optional) - Index of the button in the buttons array which will
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    be selected by default when the message box opens.
							 
						 
					
						
							
								
									
										
										
										
											2021-07-15 07:59:27 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `signal`  AbortSignal (optional) - Pass an instance of [AbortSignal][] to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    optionally close the message box, the message box will behave as if it was
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    cancelled by the user. On macOS, `signal`  does not work with message boxes
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    that do not have a parent window, since those message boxes run
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    synchronously due to platform limitations.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `title`  string (optional) - Title of the message box, some platforms will not show it.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `detail`  string (optional) - Extra information of the message.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `checkboxLabel`  string (optional) - If provided, the message box will
							 
						 
					
						
							
								
									
										
										
										
											2019-04-30 07:08:33 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    include a checkbox with the given label.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `checkboxChecked`  boolean (optional) - Initial checked state of the
							 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    checkbox. `false`  by default.
							 
						 
					
						
							
								
									
										
										
										
											2022-01-12 19:30:15 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `icon`  ([NativeImage ](native-image.md ) | string) (optional)
							 
						 
					
						
							
								
									
										
										
										
											2021-09-23 12:56:14 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `textWidth`  Integer (optional) _macOS_  - Custom width of the text in the message box.
							 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `cancelId`  Integer (optional) - The index of the button to be used to cancel the dialog, via
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    the `Esc`  key. By default this is assigned to the first button with "cancel" or "no" as the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    label. If no such labeled buttons exist and this option is not set, `0`  will be used as the
							 
						 
					
						
							
								
									
										
										
										
											2019-04-30 07:08:33 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return value.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `noLink`  boolean (optional) - On Windows Electron will try to figure out which one of
							 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    the `buttons`  are common buttons (like "Cancel" or "Yes"), and show the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    others as command links in the dialog. This can make the dialog appear in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    the style of modern Windows apps. If you don't like this behavior, you can
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    set `noLink`  to `true` .
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `normalizeAccessKeys`  boolean (optional) - Normalize the keyboard access keys
							 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    across platforms. Default is `false` . Enabling this assumes `&`  is used in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    the button labels for the placement of the keyboard shortcut access key
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    and labels will be converted so they work correctly on each platform, `&` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    characters are removed on macOS, converted to `_`  on Linux, and left
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    untouched on Windows. For example, a button label of `Vie&w`  will be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    converted to `Vie_w`  on Linux and `View`  on macOS and can be selected
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    via `Alt-W`  on Windows and Linux.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns `Promise<Object>`  - resolves with a promise containing the following properties:
							 
						 
					
						
							
								
									
										
										
										
											2020-11-05 14:12:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `response`  number - The index of the clicked button. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `checkboxChecked`  boolean - The checked state of the checkbox if 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  `checkboxLabel`  was set. Otherwise `false` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-23 03:35:00 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Shows a message box.
							 
						 
					
						
							
								
									
										
										
										
											2019-03-12 11:06:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `window`  argument allows the dialog to attach itself to a parent window, making it modal.
							 
						 
					
						
							
								
									
										
										
										
											2015-01-04 21:56:45 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### `dialog.showErrorBox(title, content)`
  
						 
					
						
							
								
									
										
										
										
											2015-01-04 21:56:45 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `title`  string - The title to display in the error box. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `content`  string - The text content to display in the error box. 
						 
					
						
							
								
									
										
										
										
											2016-08-25 10:52:19 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Displays a modal dialog that shows an error message.
							 
						 
					
						
							
								
									
										
										
										
											2015-01-04 21:56:45 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-08-25 05:46:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This API can be called safely before the `ready`  event the `app`  module emits,
							 
						 
					
						
							
								
									
										
										
										
											2017-11-29 11:58:24 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								it is usually used to report errors in early stage of startup. If called
							 
						 
					
						
							
								
									
										
										
										
											2015-11-12 21:20:09 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								before the app `ready` event on Linux, the message will be emitted to stderr,
							 
						 
					
						
							
								
									
										
										
										
											2015-10-31 16:04:01 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								and no GUI dialog will appear.
							 
						 
					
						
							
								
									
										
										
										
											2016-03-26 18:12:25 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### `dialog.showCertificateTrustDialog([window, ]options)` _macOS_ _Windows_
  
						 
					
						
							
								
									
										
										
										
											2019-03-14 17:02:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `window`  [BaseWindow ](base-window.md ) (optional) 
						 
					
						
							
								
									
										
										
										
											2019-03-14 17:02:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `options`  Object 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `certificate`  [Certificate ](structures/certificate.md ) - The certificate to trust/import.
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `message`  string - The message to display to the user.
							 
						 
					
						
							
								
									
										
										
										
											2019-03-14 17:02:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns `Promise<void>`  - resolves when the certificate trust dialog is shown.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								On macOS, this displays a modal dialog that shows a message and certificate
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								information, and gives the user the option of trusting/importing the
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								certificate. If you provide a `window`  argument the dialog will be
							 
						 
					
						
							
								
									
										
										
										
											2019-03-14 17:02:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								attached to the parent window, making it modal.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								On Windows the options are more limited, due to the Win32 APIs used:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-03-05 05:54:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  The `message`  argument is not used, as the OS provides its own confirmation 
						 
					
						
							
								
									
										
										
										
											2017-04-27 15:12:30 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   dialog.
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  The `window`  argument is ignored since it is not possible to make 
						 
					
						
							
								
									
										
										
										
											2017-04-29 19:35:49 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   this confirmation dialog modal.
							 
						 
					
						
							
								
									
										
										
										
											2017-04-04 10:49:10 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-22 17:17:39 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Bookmarks array
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-12-09 11:44:43 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`showOpenDialog`  and `showSaveDialog`  resolve to an object with a `bookmarks`  field. This field is an array of Base64 encoded strings that contain the [security scoped bookmark ](https://developer.apple.com/library/content/documentation/Security/Conceptual/AppSandboxDesignGuide/AppSandboxInDepth/AppSandboxInDepth.html#//apple_ref/doc/uid/TP40011183-CH3-SW16 ) data for the saved file. The `securityScopedBookmarks`  option must be enabled for this to be present. 
						 
					
						
							
								
									
										
										
										
											2020-01-22 17:17:39 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| Build Type | securityScopedBookmarks boolean | Return Type | Return Value                   |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								|------------|---------------------------------|:-----------:|--------------------------------|
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| macOS mas  | True                            |   Success   | `['LONGBOOKMARKSTRING']`        |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| macOS mas  | True                            |    Error    | `['']`  (array of empty string) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| macOS mas  | False                           |      NA     | `[]`  (empty array)             |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| non mas    | any                             |      NA     | `[]`  (empty array)             |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-26 18:12:25 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Sheets
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-06-18 15:26:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								On macOS, dialogs are presented as sheets attached to a window if you provide
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								a [`BaseWindow` ](base-window.md ) reference in the `window`  parameter, or modals if no
							 
						 
					
						
							
								
									
										
										
										
											2016-03-26 18:12:25 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								window is provided.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-16 16:49:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								You can call `BaseWindow.getCurrentWindow().setSheetOffset(offset)`  to change
							 
						 
					
						
							
								
									
										
										
										
											2016-04-18 22:39:12 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								the offset from the window frame where sheets are attached.
							 
						 
					
						
							
								
									
										
										
										
											2021-07-15 07:59:27 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[AbortSignal]: https://nodejs.org/api/globals.html#globals_class_abortsignal