| OLD | NEW |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/app_modal_dialog.h" | 5 #include "chrome/browser/app_modal_dialog.h" |
| 6 | 6 |
| 7 #include "chrome/browser/app_modal_dialog_queue.h" | 7 #include "chrome/browser/app_modal_dialog_queue.h" |
| 8 #include "chrome/browser/tab_contents/tab_contents.h" | 8 #include "chrome/browser/tab_contents/tab_contents.h" |
| 9 #include "chrome/common/notification_service.h" | 9 #include "chrome/common/notification_service.h" |
| 10 #include "chrome/common/notification_type.h" | 10 #include "chrome/common/notification_type.h" |
| 11 #include "chrome/common/ipc_message.h" | 11 #include "chrome/common/ipc_message.h" |
| 12 | 12 |
| 13 AppModalDialog::AppModalDialog(TabContents* tab_contents, | 13 AppModalDialog::AppModalDialog(TabContents* tab_contents, |
| 14 const std::wstring& title, | 14 const std::wstring& title, |
| 15 int dialog_flags, | 15 int dialog_flags, |
| 16 const std::wstring& message_text, | 16 const std::wstring& message_text, |
| 17 const std::wstring& default_prompt_text, | 17 const std::wstring& default_prompt_text, |
| 18 bool display_suppress_checkbox, | 18 bool display_suppress_checkbox, |
| 19 bool is_before_unload_dialog, | 19 bool is_before_unload_dialog, |
| 20 IPC::Message* reply_msg) | 20 IPC::Message* reply_msg) |
| 21 : tab_contents_(tab_contents), | 21 : dialog_(NULL), |
| 22 tab_contents_(tab_contents), |
| 22 title_(title), | 23 title_(title), |
| 23 dialog_flags_(dialog_flags), | 24 dialog_flags_(dialog_flags), |
| 24 message_text_(message_text), | 25 message_text_(message_text), |
| 25 default_prompt_text_(default_prompt_text), | 26 default_prompt_text_(default_prompt_text), |
| 26 display_suppress_checkbox_(display_suppress_checkbox), | 27 display_suppress_checkbox_(display_suppress_checkbox), |
| 27 is_before_unload_dialog_(is_before_unload_dialog), | 28 is_before_unload_dialog_(is_before_unload_dialog), |
| 28 reply_msg_(reply_msg) { | 29 reply_msg_(reply_msg) { |
| 29 InitNotifications(); | 30 InitNotifications(); |
| 30 } | 31 } |
| 31 | 32 |
| (...skipping 23 matching lines...) Expand all Loading... |
| 55 registrar_.Add(this, NotificationType::NAV_ENTRY_COMMITTED, | 56 registrar_.Add(this, NotificationType::NAV_ENTRY_COMMITTED, |
| 56 NotificationService::AllSources()); | 57 NotificationService::AllSources()); |
| 57 registrar_.Add(this, NotificationType::TAB_CONTENTS_DESTROYED, | 58 registrar_.Add(this, NotificationType::TAB_CONTENTS_DESTROYED, |
| 58 NotificationService::AllSources()); | 59 NotificationService::AllSources()); |
| 59 } | 60 } |
| 60 | 61 |
| 61 void AppModalDialog::ShowModalDialog() { | 62 void AppModalDialog::ShowModalDialog() { |
| 62 // If the TabContents that created this dialog navigated away before this | 63 // If the TabContents that created this dialog navigated away before this |
| 63 // dialog became visible, simply show the next dialog if any. | 64 // dialog became visible, simply show the next dialog if any. |
| 64 if (!tab_contents_) { | 65 if (!tab_contents_) { |
| 65 AppModalDialogQueue::ShowNextDialog(); | 66 Singleton<AppModalDialogQueue>()->ShowNextDialog(); |
| 66 delete this; | 67 delete this; |
| 67 return; | 68 return; |
| 68 } | 69 } |
| 69 | 70 |
| 70 tab_contents_->Activate(); | 71 tab_contents_->Activate(); |
| 71 CreateAndShowDialog(); | 72 CreateAndShowDialog(); |
| 72 } | 73 } |
| 73 | 74 |
| 74 void AppModalDialog::OnCancel() { | 75 void AppModalDialog::OnCancel() { |
| 75 // We need to do this before WM_DESTROY (WindowClosing()) as any parent frame | 76 // We need to do this before WM_DESTROY (WindowClosing()) as any parent frame |
| 76 // will receive it's activation messages before this dialog receives | 77 // will receive it's activation messages before this dialog receives |
| 77 // WM_DESTROY. The parent frame would then try to activate any modal dialogs | 78 // WM_DESTROY. The parent frame would then try to activate any modal dialogs |
| 78 // that were still open in the ModalDialogQueue, which would send activation | 79 // that were still open in the ModalDialogQueue, which would send activation |
| 79 // back to this one. The framework should be improved to handle this, so this | 80 // back to this one. The framework should be improved to handle this, so this |
| 80 // is a temporary workaround. | 81 // is a temporary workaround. |
| 81 AppModalDialogQueue::ShowNextDialog(); | 82 Singleton<AppModalDialogQueue>()->ShowNextDialog(); |
| 82 | 83 |
| 83 if (tab_contents_) { | 84 if (tab_contents_) { |
| 84 tab_contents_->OnJavaScriptMessageBoxClosed(reply_msg_, false, | 85 tab_contents_->OnJavaScriptMessageBoxClosed(reply_msg_, false, |
| 85 std::wstring()); | 86 std::wstring()); |
| 86 } | 87 } |
| 87 } | 88 } |
| 88 | 89 |
| 89 void AppModalDialog::OnAccept(const std::wstring& prompt_text, | 90 void AppModalDialog::OnAccept(const std::wstring& prompt_text, |
| 90 bool suppress_js_messages) { | 91 bool suppress_js_messages) { |
| 91 AppModalDialogQueue::ShowNextDialog(); | 92 Singleton<AppModalDialogQueue>()->ShowNextDialog(); |
| 92 | 93 |
| 93 if (tab_contents_) { | 94 if (tab_contents_) { |
| 94 tab_contents_->OnJavaScriptMessageBoxClosed(reply_msg_, true, | 95 tab_contents_->OnJavaScriptMessageBoxClosed(reply_msg_, true, |
| 95 prompt_text); | 96 prompt_text); |
| 96 | 97 |
| 97 if (suppress_js_messages) | 98 if (suppress_js_messages) |
| 98 tab_contents()->set_suppress_javascript_messages(true); | 99 tab_contents()->set_suppress_javascript_messages(true); |
| 99 } | 100 } |
| 100 } | 101 } |
| 101 | 102 |
| 102 void AppModalDialog::OnClose() { | 103 void AppModalDialog::OnClose() { |
| 103 if (tab_contents_) { | 104 if (tab_contents_) { |
| 104 tab_contents_->OnJavaScriptMessageBoxWindowDestroyed(); | 105 tab_contents_->OnJavaScriptMessageBoxWindowDestroyed(); |
| 105 } | 106 } |
| 106 } | 107 } |
| OLD | NEW |