Final cleanup
This commit is contained in:
parent
aab78db8b8
commit
001b4a3179
2 changed files with 20 additions and 13 deletions
|
@ -113,4 +113,5 @@ module.exports =
|
||||||
binding.showErrorBox args...
|
binding.showErrorBox args...
|
||||||
|
|
||||||
# Mark standard asynchronous functions.
|
# Mark standard asynchronous functions.
|
||||||
v8Util.setHiddenValue f, 'asynchronous', true for k, f of module.exports
|
for api in ['showMessageBox', 'showOpenDialog', 'showSaveDialog']
|
||||||
|
v8Util.setHiddenValue module.exports[api], 'asynchronous', true
|
||||||
|
|
|
@ -4,12 +4,12 @@
|
||||||
|
|
||||||
#include "atom/browser/ui/message_box.h"
|
#include "atom/browser/ui/message_box.h"
|
||||||
|
|
||||||
#include <map>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <commctrl.h>
|
#include <commctrl.h>
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
#include "atom/browser/native_window_views.h"
|
#include "atom/browser/native_window_views.h"
|
||||||
#include "base/callback.h"
|
#include "base/callback.h"
|
||||||
#include "base/strings/string_util.h"
|
#include "base/strings/string_util.h"
|
||||||
|
@ -76,17 +76,18 @@ int ShowMessageBoxUTF16(HWND parent,
|
||||||
const base::string16& message,
|
const base::string16& message,
|
||||||
const base::string16& detail,
|
const base::string16& detail,
|
||||||
const gfx::ImageSkia& icon) {
|
const gfx::ImageSkia& icon) {
|
||||||
TASKDIALOG_FLAGS flags = TDF_SIZE_TO_CONTENT | // show all content.
|
TASKDIALOG_FLAGS flags = TDF_SIZE_TO_CONTENT; // show all content.
|
||||||
TDF_USE_COMMAND_LINKS; // custom buttons as links.
|
|
||||||
if (cancel_id != 0)
|
if (cancel_id != 0)
|
||||||
flags |= TDF_ALLOW_DIALOG_CANCELLATION; // allow dialog to be cancelled.
|
flags |= TDF_ALLOW_DIALOG_CANCELLATION; // allow dialog to be cancelled.
|
||||||
|
|
||||||
TASKDIALOGCONFIG config = { 0 };
|
TASKDIALOGCONFIG config = { 0 };
|
||||||
config.cbSize = sizeof(config);
|
config.cbSize = sizeof(config);
|
||||||
config.hwndParent = parent;
|
config.hwndParent = parent;
|
||||||
config.hInstance = GetModuleHandle(NULL);
|
config.hInstance = GetModuleHandle(NULL);
|
||||||
config.dwFlags = flags;
|
config.dwFlags = flags;
|
||||||
config.pszWindowTitle = title.c_str();
|
|
||||||
|
if (!title.empty())
|
||||||
|
config.pszWindowTitle = title.c_str();
|
||||||
|
|
||||||
base::win::ScopedHICON hicon;
|
base::win::ScopedHICON hicon;
|
||||||
if (!icon.isNull()) {
|
if (!icon.isNull()) {
|
||||||
|
@ -121,8 +122,11 @@ int ShowMessageBoxUTF16(HWND parent,
|
||||||
std::map<int, int> id_map;
|
std::map<int, int> id_map;
|
||||||
std::vector<TASKDIALOG_BUTTON> dialog_buttons;
|
std::vector<TASKDIALOG_BUTTON> dialog_buttons;
|
||||||
MapToCommonID(buttons, &id_map, &config.dwCommonButtons, &dialog_buttons);
|
MapToCommonID(buttons, &id_map, &config.dwCommonButtons, &dialog_buttons);
|
||||||
config.pButtons = &dialog_buttons.front();
|
if (dialog_buttons.size() > 0) {
|
||||||
config.cButtons = dialog_buttons.size();
|
config.pButtons = &dialog_buttons.front();
|
||||||
|
config.cButtons = dialog_buttons.size();
|
||||||
|
config.dwFlags |= TDF_USE_COMMAND_LINKS; // custom buttons as links.
|
||||||
|
}
|
||||||
|
|
||||||
int id = 0;
|
int id = 0;
|
||||||
TaskDialogIndirect(&config, &id, NULL, NULL);
|
TaskDialogIndirect(&config, &id, NULL, NULL);
|
||||||
|
@ -207,6 +211,8 @@ void ShowMessageBox(NativeWindow* parent,
|
||||||
}
|
}
|
||||||
|
|
||||||
void ShowErrorBox(const base::string16& title, const base::string16& content) {
|
void ShowErrorBox(const base::string16& title, const base::string16& content) {
|
||||||
|
ShowMessageBoxUTF16(NULL, MESSAGE_BOX_TYPE_ERROR, {}, 0, L"Error", title,
|
||||||
|
content, gfx::ImageSkia());
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
Loading…
Reference in a new issue