Added a comment about the fact that on Windows, the "question" message box uses the same icon as the "info" message box (Electron uses the task dialog API instead of the message box API). This is because Microsoft's API doesn't supply a default question icon (see `pszIcon` in https://msdn.microsoft.com/en-us/library/windows/desktop/bb760540(v=vs.85).aspx).
3.6 KiB
dialog
The dialog
module provides APIs to show native system dialogs, so web
applications can deliver the same user experience as native applications.
An example of showing a dialog to select multiple files and directories:
var win = ...; // window in which to show the dialog
var dialog = require('dialog');
console.log(dialog.showOpenDialog({ properties: [ 'openFile', 'openDirectory', 'multiSelections' ]}));
Note for OS X: If you want to present dialogs as sheets, the only thing you have to do is provide a BrowserWindow
reference in the browserWindow
parameter.
dialog.showOpenDialog([browserWindow], [options], [callback])
browserWindow
BrowserWindowoptions
Objecttitle
StringdefaultPath
Stringfilters
Arrayproperties
Array - Contains which features the dialog should use, can containopenFile
,openDirectory
,multiSelections
andcreateDirectory
callback
Function
On success, returns an array of file paths chosen by the user, otherwise
returns undefined
.
The filters
specifies an array of file types that can be displayed or
selected, an example is:
{
filters: [
{ name: 'Images', extensions: ['jpg', 'png', 'gif'] },
{ name: 'Movies', extensions: ['mkv', 'avi', 'mp4'] },
{ name: 'Custom File Type', extensions: ['as'] }
]
}
If a callback
is passed, the API call would be asynchronous and the result
would be passed via callback(filenames)
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.
dialog.showSaveDialog([browserWindow], [options], [callback])
browserWindow
BrowserWindowoptions
Objecttitle
StringdefaultPath
Stringfilters
Array
callback
Function
On success, returns the path of the file chosen by the user, otherwise returns
undefined
.
The filters
specifies an array of file types that can be displayed, see
dialog.showOpenDialog
for an example.
If a callback
is passed, the API call will be asynchronous and the result
will be passed via callback(filename)
dialog.showMessageBox([browserWindow], options, [callback])
browserWindow
BrowserWindowoptions
Objecttype
String - Can be"none"
,"info"
,"error"
,"question"
or"warning"
. On Windows, "question" displays the same icon as "info", unless if you set an icon using the "icon" optionbuttons
Array - Array of texts for buttonstitle
String - Title of the message box, some platforms will not show itmessage
String - Content of the message boxdetail
String - Extra information of the messageicon
NativeImagecancelId
Integer - The value will be returned when user cancels the dialog instead of clicking the buttons of the dialog. By default it is the index of the buttons that have "cancel" or "no" as label, or 0 if there is no such buttons. On OS X and Windows the index of "Cancel" button will always be used ascancelId
, not matter whether it is already specified.
callback
Function
Shows a message box, it will block until the message box is closed. It returns the index of the clicked button.
If a callback
is passed, the API call will be asynchronous and the result
will be passed via callback(response)
dialog.showErrorBox(title, content)
Runs a modal dialog that shows an error message.
This API can be called safely before the ready
event of app
module emits, it
is usually used to report errors in early stage of startup.