Show all buttons as custom buttons when noLink is specified
This commit is contained in:
parent
cc2a9f617d
commit
6c44553456
1 changed files with 11 additions and 5 deletions
|
@ -123,7 +123,12 @@ int ShowMessageBoxUTF16(HWND parent,
|
||||||
// and custom buttons in pButtons.
|
// and custom buttons in pButtons.
|
||||||
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);
|
if (options & MESSAGE_BOX_NO_LINK) {
|
||||||
|
for (size_t i = 0; i < buttons.size(); ++i)
|
||||||
|
dialog_buttons.push_back({i + kIDStart, buttons[i].c_str()});
|
||||||
|
} else {
|
||||||
|
MapToCommonID(buttons, &id_map, &config.dwCommonButtons, &dialog_buttons);
|
||||||
|
}
|
||||||
if (dialog_buttons.size() > 0) {
|
if (dialog_buttons.size() > 0) {
|
||||||
config.pButtons = &dialog_buttons.front();
|
config.pButtons = &dialog_buttons.front();
|
||||||
config.cButtons = dialog_buttons.size();
|
config.cButtons = dialog_buttons.size();
|
||||||
|
@ -146,13 +151,14 @@ void RunMessageBoxInNewThread(base::Thread* thread,
|
||||||
MessageBoxType type,
|
MessageBoxType type,
|
||||||
const std::vector<std::string>& buttons,
|
const std::vector<std::string>& buttons,
|
||||||
int cancel_id,
|
int cancel_id,
|
||||||
|
int options,
|
||||||
const std::string& title,
|
const std::string& title,
|
||||||
const std::string& message,
|
const std::string& message,
|
||||||
const std::string& detail,
|
const std::string& detail,
|
||||||
const gfx::ImageSkia& icon,
|
const gfx::ImageSkia& icon,
|
||||||
const MessageBoxCallback& callback) {
|
const MessageBoxCallback& callback) {
|
||||||
int result = ShowMessageBox(parent, type, buttons, cancel_id, title, message,
|
int result = ShowMessageBox(parent, type, buttons, cancel_id, options, title,
|
||||||
detail, icon);
|
message, detail, icon);
|
||||||
content::BrowserThread::PostTask(
|
content::BrowserThread::PostTask(
|
||||||
content::BrowserThread::UI, FROM_HERE, base::Bind(callback, result));
|
content::BrowserThread::UI, FROM_HERE, base::Bind(callback, result));
|
||||||
content::BrowserThread::DeleteSoon(
|
content::BrowserThread::DeleteSoon(
|
||||||
|
@ -212,8 +218,8 @@ void ShowMessageBox(NativeWindow* parent,
|
||||||
unretained->message_loop()->PostTask(
|
unretained->message_loop()->PostTask(
|
||||||
FROM_HERE,
|
FROM_HERE,
|
||||||
base::Bind(&RunMessageBoxInNewThread, base::Unretained(unretained),
|
base::Bind(&RunMessageBoxInNewThread, base::Unretained(unretained),
|
||||||
parent, type, buttons, cancel_id, title, message, detail, icon,
|
parent, type, buttons, cancel_id, options, title, message,
|
||||||
callback));
|
detail, icon, callback));
|
||||||
}
|
}
|
||||||
|
|
||||||
void ShowErrorBox(const base::string16& title, const base::string16& content) {
|
void ShowErrorBox(const base::string16& title, const base::string16& content) {
|
||||||
|
|
Loading…
Reference in a new issue