Seperate linux's implementation of message box
This commit is contained in:
parent
7bcbad925e
commit
1ff00281f3
3 changed files with 66 additions and 43 deletions
63
atom/browser/ui/message_box_gtk.cc
Normal file
63
atom/browser/ui/message_box_gtk.cc
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
// Copyright (c) 2015 GitHub, Inc.
|
||||||
|
// Use of this source code is governed by the MIT license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#include "atom/browser/ui/message_box.h"
|
||||||
|
|
||||||
|
#include <gtk/gtk.h>
|
||||||
|
|
||||||
|
#include "atom/browser/browser.h"
|
||||||
|
#include "base/callback.h"
|
||||||
|
#include "base/strings/utf_string_conversions.h"
|
||||||
|
|
||||||
|
#define ANSI_FOREGROUND_RED "\x1b[31m"
|
||||||
|
#define ANSI_FOREGROUND_BLACK "\x1b[30m"
|
||||||
|
#define ANSI_TEXT_BOLD "\x1b[1m"
|
||||||
|
#define ANSI_BACKGROUND_GRAY "\x1b[47m"
|
||||||
|
#define ANSI_RESET "\x1b[0m"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
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,
|
||||||
|
const gfx::ImageSkia& icon) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ShowMessageBox(NativeWindow* parent_window,
|
||||||
|
MessageBoxType type,
|
||||||
|
const std::vector<std::string>& buttons,
|
||||||
|
const std::string& title,
|
||||||
|
const std::string& message,
|
||||||
|
const std::string& detail,
|
||||||
|
const gfx::ImageSkia& icon,
|
||||||
|
const MessageBoxCallback& callback) {
|
||||||
|
callback.Run(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ShowErrorBox(const base::string16& title, const base::string16& content) {
|
||||||
|
if (Browser::Get()->is_ready()) {
|
||||||
|
GtkWidget* dialog = gtk_message_dialog_new(
|
||||||
|
NULL, GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK,
|
||||||
|
"%s", base::UTF16ToUTF8(title).c_str());
|
||||||
|
gtk_message_dialog_format_secondary_text(
|
||||||
|
GTK_MESSAGE_DIALOG(dialog),
|
||||||
|
"%s", base::UTF16ToUTF8(content).c_str());
|
||||||
|
gtk_dialog_run(GTK_DIALOG(dialog));
|
||||||
|
gtk_widget_destroy(dialog);
|
||||||
|
} else {
|
||||||
|
fprintf(stderr,
|
||||||
|
ANSI_TEXT_BOLD ANSI_BACKGROUND_GRAY
|
||||||
|
ANSI_FOREGROUND_RED "%s\n"
|
||||||
|
ANSI_FOREGROUND_BLACK "%s"
|
||||||
|
ANSI_RESET "\n",
|
||||||
|
base::UTF16ToUTF8(title).c_str(),
|
||||||
|
base::UTF16ToUTF8(content).c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace atom
|
|
@ -4,10 +4,6 @@
|
||||||
|
|
||||||
#include "atom/browser/ui/message_box.h"
|
#include "atom/browser/ui/message_box.h"
|
||||||
|
|
||||||
#if defined(USE_X11)
|
|
||||||
#include <gtk/gtk.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "atom/browser/native_window.h"
|
#include "atom/browser/native_window.h"
|
||||||
#include "base/callback.h"
|
#include "base/callback.h"
|
||||||
#include "base/message_loop/message_loop.h"
|
#include "base/message_loop/message_loop.h"
|
||||||
|
@ -26,21 +22,10 @@
|
||||||
#include "ui/views/widget/widget_delegate.h"
|
#include "ui/views/widget/widget_delegate.h"
|
||||||
#include "ui/wm/core/shadow_types.h"
|
#include "ui/wm/core/shadow_types.h"
|
||||||
|
|
||||||
#if defined(USE_X11)
|
|
||||||
#include "atom/browser/browser.h"
|
|
||||||
#include "ui/views/window/native_frame_view.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
#include "ui/base/win/message_box_win.h"
|
#include "ui/base/win/message_box_win.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define ANSI_FOREGROUND_RED "\x1b[31m"
|
|
||||||
#define ANSI_FOREGROUND_BLACK "\x1b[30m"
|
|
||||||
#define ANSI_TEXT_BOLD "\x1b[1m"
|
|
||||||
#define ANSI_BACKGROUND_GRAY "\x1b[47m"
|
|
||||||
#define ANSI_RESET "\x1b[0m"
|
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -276,13 +261,8 @@ ui::ModalType MessageDialog::GetModalType() const {
|
||||||
|
|
||||||
views::NonClientFrameView* MessageDialog::CreateNonClientFrameView(
|
views::NonClientFrameView* MessageDialog::CreateNonClientFrameView(
|
||||||
views::Widget* widget) {
|
views::Widget* widget) {
|
||||||
if (!parent_) {
|
if (!parent_)
|
||||||
#if defined(USE_X11)
|
|
||||||
return new views::NativeFrameView(widget);
|
|
||||||
#else
|
|
||||||
return NULL;
|
return NULL;
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create a bubble style frame like Chrome.
|
// Create a bubble style frame like Chrome.
|
||||||
views::BubbleFrameView* frame = new views::BubbleFrameView(gfx::Insets());
|
views::BubbleFrameView* frame = new views::BubbleFrameView(gfx::Insets());
|
||||||
|
@ -390,28 +370,7 @@ void ShowMessageBox(NativeWindow* parent_window,
|
||||||
}
|
}
|
||||||
|
|
||||||
void ShowErrorBox(const base::string16& title, const base::string16& content) {
|
void ShowErrorBox(const base::string16& title, const base::string16& content) {
|
||||||
#if defined(OS_WIN)
|
|
||||||
ui::MessageBox(NULL, content, title, MB_OK | MB_ICONERROR | MB_TASKMODAL);
|
ui::MessageBox(NULL, content, title, MB_OK | MB_ICONERROR | MB_TASKMODAL);
|
||||||
#elif defined(USE_X11)
|
|
||||||
if (Browser::Get()->is_ready()) {
|
|
||||||
GtkWidget* dialog = gtk_message_dialog_new(
|
|
||||||
NULL, GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK,
|
|
||||||
"%s", base::UTF16ToUTF8(title).c_str());
|
|
||||||
gtk_message_dialog_format_secondary_text(
|
|
||||||
GTK_MESSAGE_DIALOG(dialog),
|
|
||||||
"%s", base::UTF16ToUTF8(content).c_str());
|
|
||||||
gtk_dialog_run(GTK_DIALOG(dialog));
|
|
||||||
gtk_widget_destroy(dialog);
|
|
||||||
} else {
|
|
||||||
fprintf(stderr,
|
|
||||||
ANSI_TEXT_BOLD ANSI_BACKGROUND_GRAY
|
|
||||||
ANSI_FOREGROUND_RED "%s\n"
|
|
||||||
ANSI_FOREGROUND_BLACK "%s"
|
|
||||||
ANSI_RESET "\n",
|
|
||||||
base::UTF16ToUTF8(title).c_str(),
|
|
||||||
base::UTF16ToUTF8(content).c_str());
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
|
@ -175,8 +175,9 @@
|
||||||
'atom/browser/ui/file_dialog_mac.mm',
|
'atom/browser/ui/file_dialog_mac.mm',
|
||||||
'atom/browser/ui/file_dialog_win.cc',
|
'atom/browser/ui/file_dialog_win.cc',
|
||||||
'atom/browser/ui/message_box.h',
|
'atom/browser/ui/message_box.h',
|
||||||
|
'atom/browser/ui/message_box_gtk.cc',
|
||||||
'atom/browser/ui/message_box_mac.mm',
|
'atom/browser/ui/message_box_mac.mm',
|
||||||
'atom/browser/ui/message_box_views.cc',
|
'atom/browser/ui/message_box_win.cc',
|
||||||
'atom/browser/ui/tray_icon.cc',
|
'atom/browser/ui/tray_icon.cc',
|
||||||
'atom/browser/ui/tray_icon.h',
|
'atom/browser/ui/tray_icon.h',
|
||||||
'atom/browser/ui/tray_icon_gtk.cc',
|
'atom/browser/ui/tray_icon_gtk.cc',
|
||||||
|
|
Loading…
Add table
Reference in a new issue