mac: Implement async ShowMessageBox.
This commit is contained in:
parent
bfe59480e3
commit
b70722feb6
1 changed files with 57 additions and 9 deletions
|
@ -11,16 +11,48 @@
|
||||||
#include "browser/native_window.h"
|
#include "browser/native_window.h"
|
||||||
#include "browser/ui/nsalert_synchronous_sheet_mac.h"
|
#include "browser/ui/nsalert_synchronous_sheet_mac.h"
|
||||||
|
|
||||||
|
@interface ModalDelegate : NSObject {
|
||||||
|
@private
|
||||||
|
atom::MessageBoxCallback callback_;
|
||||||
|
NSAlert* alert_;
|
||||||
|
}
|
||||||
|
- (id)initWithCallback:(const atom::MessageBoxCallback&)callback
|
||||||
|
andAlert:(NSAlert*)alert;
|
||||||
|
@end
|
||||||
|
|
||||||
|
@implementation ModalDelegate
|
||||||
|
|
||||||
|
- (id)initWithCallback:(const atom::MessageBoxCallback&)callback
|
||||||
|
andAlert:(NSAlert*)alert {
|
||||||
|
if ((self = [super init])) {
|
||||||
|
callback_ = callback;
|
||||||
|
alert_ = alert;
|
||||||
|
}
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)alertDidEnd:(NSAlert*)alert
|
||||||
|
returnCode:(NSInteger)returnCode
|
||||||
|
contextInfo:(void*)contextInfo {
|
||||||
|
callback_.Run(returnCode);
|
||||||
|
[alert_ release];
|
||||||
|
[self release];
|
||||||
|
}
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
int ShowMessageBox(NativeWindow* parent_window,
|
namespace {
|
||||||
MessageBoxType type,
|
|
||||||
const std::vector<std::string>& buttons,
|
NSAlert* CreateNSAlert(NativeWindow* parent_window,
|
||||||
const std::string& title,
|
MessageBoxType type,
|
||||||
const std::string& message,
|
const std::vector<std::string>& buttons,
|
||||||
const std::string& detail) {
|
const std::string& title,
|
||||||
|
const std::string& message,
|
||||||
|
const std::string& detail) {
|
||||||
// Ignore the title; it's the window title on other platforms and ignorable.
|
// Ignore the title; it's the window title on other platforms and ignorable.
|
||||||
NSAlert* alert = [[[NSAlert alloc] init] autorelease];
|
NSAlert* alert = [[NSAlert alloc] init];
|
||||||
[alert setMessageText:base::SysUTF8ToNSString(message)];
|
[alert setMessageText:base::SysUTF8ToNSString(message)];
|
||||||
[alert setInformativeText:base::SysUTF8ToNSString(detail)];
|
[alert setInformativeText:base::SysUTF8ToNSString(detail)];
|
||||||
|
|
||||||
|
@ -41,6 +73,21 @@ int ShowMessageBox(NativeWindow* parent_window,
|
||||||
[button setTag:i];
|
[button setTag:i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return alert;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
int ShowMessageBox(NativeWindow* parent_window,
|
||||||
|
MessageBoxType type,
|
||||||
|
const std::vector<std::string>& buttons,
|
||||||
|
const std::string& title,
|
||||||
|
const std::string& message,
|
||||||
|
const std::string& detail) {
|
||||||
|
NSAlert* alert = CreateNSAlert(
|
||||||
|
parent_window, type, buttons, title, message, detail);
|
||||||
|
[alert autorelease];
|
||||||
|
|
||||||
if (parent_window)
|
if (parent_window)
|
||||||
return [alert runModalSheetForWindow:parent_window->GetNativeWindow()];
|
return [alert runModalSheetForWindow:parent_window->GetNativeWindow()];
|
||||||
else
|
else
|
||||||
|
@ -54,8 +101,9 @@ void ShowMessageBox(NativeWindow* parent_window,
|
||||||
const std::string& message,
|
const std::string& message,
|
||||||
const std::string& detail,
|
const std::string& detail,
|
||||||
const MessageBoxCallback& callback) {
|
const MessageBoxCallback& callback) {
|
||||||
callback.Run(ShowMessageBox(
|
NSAlert* alert = CreateNSAlert(
|
||||||
parent_window, type, buttons, title, message, detail));
|
parent_window, type, buttons, title, message, detail);
|
||||||
|
[[ModalDelegate alloc] initWithCallback:callback andAlert:alert];
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
Loading…
Reference in a new issue