| Index: chrome/browser/jsmessage_box_handler_win.cc
|
| diff --git a/chrome/browser/jsmessage_box_handler_win.cc b/chrome/browser/jsmessage_box_handler_win.cc
|
| deleted file mode 100644
|
| index 5184dd6ccc4895bc7fb315e0a887a5801795481b..0000000000000000000000000000000000000000
|
| --- a/chrome/browser/jsmessage_box_handler_win.cc
|
| +++ /dev/null
|
| @@ -1,213 +0,0 @@
|
| -// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
|
| -// Use of this source code is governed by a BSD-style license that can be
|
| -// found in the LICENSE file.
|
| -
|
| -#include "chrome/browser/jsmessage_box_handler_win.h"
|
| -
|
| -#include "base/string_util.h"
|
| -#include "chrome/browser/app_modal_dialog_queue.h"
|
| -#include "chrome/browser/browser_process.h"
|
| -#include "chrome/browser/profile.h"
|
| -#include "chrome/browser/tab_contents/web_contents.h"
|
| -#include "chrome/common/gfx/text_elider.h"
|
| -#include "chrome/common/l10n_util.h"
|
| -#include "chrome/common/message_box_flags.h"
|
| -#include "chrome/common/notification_service.h"
|
| -#include "chrome/common/notification_type.h"
|
| -#include "chrome/common/pref_names.h"
|
| -#include "chrome/common/pref_service.h"
|
| -#include "chrome/views/controls/message_box_view.h"
|
| -#include "chrome/views/window/window.h"
|
| -#include "grit/generated_resources.h"
|
| -
|
| -void RunJavascriptMessageBox(WebContents* web_contents,
|
| - const GURL& frame_url,
|
| - int dialog_flags,
|
| - const std::wstring& message_text,
|
| - const std::wstring& default_prompt_text,
|
| - bool display_suppress_checkbox,
|
| - IPC::Message* reply_msg) {
|
| - JavascriptMessageBoxHandler* handler =
|
| - new JavascriptMessageBoxHandler(web_contents, frame_url, dialog_flags,
|
| - message_text, default_prompt_text,
|
| - display_suppress_checkbox, reply_msg);
|
| - AppModalDialogQueue::AddDialog(handler);
|
| -}
|
| -
|
| -JavascriptMessageBoxHandler::JavascriptMessageBoxHandler(
|
| - WebContents* web_contents,
|
| - const GURL& frame_url,
|
| - int dialog_flags,
|
| - const std::wstring& message_text,
|
| - const std::wstring& default_prompt_text,
|
| - bool display_suppress_checkbox,
|
| - IPC::Message* reply_msg)
|
| - : web_contents_(web_contents),
|
| - frame_url_(frame_url),
|
| - reply_msg_(reply_msg),
|
| - dialog_flags_(dialog_flags),
|
| - dialog_(NULL),
|
| - message_box_view_(new MessageBoxView(
|
| - dialog_flags | MessageBox::kAutoDetectAlignment,
|
| - message_text, default_prompt_text)) {
|
| - DCHECK(message_box_view_);
|
| - DCHECK(reply_msg_);
|
| -
|
| - if (display_suppress_checkbox) {
|
| - message_box_view_->SetCheckBoxLabel(
|
| - l10n_util::GetString(IDS_JAVASCRIPT_MESSAGEBOX_SUPPRESS_OPTION));
|
| - }
|
| -
|
| - // Make sure we get navigation notifications so we know when our parent
|
| - // contents will disappear or navigate to a different page.
|
| - registrar_.Add(this, NotificationType::NAV_ENTRY_COMMITTED,
|
| - NotificationService::AllSources());
|
| - registrar_.Add(this, NotificationType::TAB_CONTENTS_DESTROYED,
|
| - NotificationService::AllSources());
|
| -}
|
| -
|
| -JavascriptMessageBoxHandler::~JavascriptMessageBoxHandler() {
|
| -}
|
| -
|
| -//////////////////////////////////////////////////////////////////////////////
|
| -// JavascriptMessageBoxHandler, views::DialogDelegate implementation:
|
| -
|
| -int JavascriptMessageBoxHandler::GetDialogButtons() const {
|
| - int dialog_buttons = 0;
|
| - if (dialog_flags_ & MessageBox::kFlagHasOKButton)
|
| - dialog_buttons = DIALOGBUTTON_OK;
|
| -
|
| - if (dialog_flags_ & MessageBox::kFlagHasCancelButton)
|
| - dialog_buttons |= DIALOGBUTTON_CANCEL;
|
| -
|
| - return dialog_buttons;
|
| -}
|
| -
|
| -std::wstring JavascriptMessageBoxHandler::GetWindowTitle() const {
|
| - if (!frame_url_.has_host() || !web_contents_)
|
| - return l10n_util::GetString(IDS_JAVASCRIPT_MESSAGEBOX_DEFAULT_TITLE);
|
| -
|
| - // We really only want the scheme, hostname, and port.
|
| - GURL::Replacements replacements;
|
| - replacements.ClearUsername();
|
| - replacements.ClearPassword();
|
| - replacements.ClearPath();
|
| - replacements.ClearQuery();
|
| - replacements.ClearRef();
|
| - GURL clean_url = frame_url_.ReplaceComponents(replacements);
|
| -
|
| - // TODO(brettw) it should be easier than this to do the correct language
|
| - // handling without getting the accept language from the profile.
|
| - std::wstring base_address = gfx::ElideUrl(clean_url, ChromeFont(), 0,
|
| - web_contents_->profile()->GetPrefs()->GetString(prefs::kAcceptLanguages));
|
| - // Force URL to have LTR directionality.
|
| - if (l10n_util::GetTextDirection() == l10n_util::RIGHT_TO_LEFT)
|
| - l10n_util::WrapStringWithLTRFormatting(&base_address);
|
| - return l10n_util::GetStringF(IDS_JAVASCRIPT_MESSAGEBOX_TITLE, base_address);
|
| -}
|
| -
|
| -void JavascriptMessageBoxHandler::WindowClosing() {
|
| - dialog_ = NULL;
|
| -
|
| - if (message_box_view_->IsCheckBoxSelected() && web_contents_)
|
| - web_contents_->set_suppress_javascript_messages(true);
|
| -}
|
| -
|
| -void JavascriptMessageBoxHandler::DeleteDelegate() {
|
| - delete this;
|
| -}
|
| -
|
| -bool JavascriptMessageBoxHandler::Cancel() {
|
| - // We need to do this before WM_DESTROY (WindowClosing()) as any parent frame
|
| - // will receive it's activation messages before this dialog receives
|
| - // WM_DESTROY. The parent frame would then try to activate any modal dialogs
|
| - // that were still open in the ModalDialogQueue, which would send activation
|
| - // back to this one. The framework should be improved to handle this, so this
|
| - // is a temporary workaround.
|
| - AppModalDialogQueue::ShowNextDialog();
|
| -
|
| - if (web_contents_) {
|
| - web_contents_->OnJavaScriptMessageBoxClosed(reply_msg_, false,
|
| - EmptyWString());
|
| - }
|
| - return true;
|
| -}
|
| -
|
| -bool JavascriptMessageBoxHandler::Accept() {
|
| - AppModalDialogQueue::ShowNextDialog();
|
| -
|
| - if (web_contents_) {
|
| - web_contents_->OnJavaScriptMessageBoxClosed(
|
| - reply_msg_, true, message_box_view_->GetInputText());
|
| - }
|
| - return true;
|
| -}
|
| -
|
| -//////////////////////////////////////////////////////////////////////////////
|
| -// JavascriptMessageBoxHandler, views::AppModalDialogDelegate
|
| -// implementation:
|
| -
|
| -void JavascriptMessageBoxHandler::ShowModalDialog() {
|
| - // If the WebContents that created this dialog navigated away before this
|
| - // dialog became visible, simply show the next dialog if any.
|
| - if (!web_contents_) {
|
| - AppModalDialogQueue::ShowNextDialog();
|
| - delete this;
|
| - return;
|
| - }
|
| -
|
| - web_contents_->Activate();
|
| - HWND root_hwnd = GetAncestor(web_contents_->GetNativeView(), GA_ROOT);
|
| - dialog_ = views::Window::CreateChromeWindow(root_hwnd, gfx::Rect(), this);
|
| - dialog_->Show();
|
| -}
|
| -
|
| -void JavascriptMessageBoxHandler::ActivateModalDialog() {
|
| - // Ensure that the dialog is visible and at the top of the z-order. These
|
| - // conditions may not be true if the dialog was opened on a different virtual
|
| - // desktop to the one the browser window is on.
|
| - dialog_->Show();
|
| - dialog_->Activate();
|
| -}
|
| -
|
| -///////////////////////////////////////////////////////////////////////////////
|
| -// JavascriptMessageBoxHandler, views::WindowDelegate implementation:
|
| -
|
| -views::View* JavascriptMessageBoxHandler::GetContentsView() {
|
| - return message_box_view_;
|
| -}
|
| -
|
| -views::View* JavascriptMessageBoxHandler::GetInitiallyFocusedView() {
|
| - if (message_box_view_->text_box())
|
| - return message_box_view_->text_box();
|
| - return views::AppModalDialogDelegate::GetInitiallyFocusedView();
|
| -}
|
| -
|
| -///////////////////////////////////////////////////////////////////////////////
|
| -// JavascriptMessageBoxHandler, private:
|
| -
|
| -void JavascriptMessageBoxHandler::Observe(NotificationType type,
|
| - const NotificationSource& source,
|
| - const NotificationDetails& details) {
|
| - if (!web_contents_)
|
| - return;
|
| -
|
| - bool web_contents_gone = false;
|
| -
|
| - if (type == NotificationType::NAV_ENTRY_COMMITTED &&
|
| - Source<NavigationController>(source).ptr() == web_contents_->controller())
|
| - web_contents_gone = true;
|
| -
|
| - if (type == NotificationType::TAB_CONTENTS_DESTROYED &&
|
| - Source<TabContents>(source).ptr() ==
|
| - static_cast<TabContents*>(web_contents_))
|
| - web_contents_gone = true;
|
| -
|
| - if (web_contents_gone) {
|
| - web_contents_ = NULL;
|
| -
|
| - // If the dialog is visible close it.
|
| - if (dialog_)
|
| - dialog_->Close();
|
| - }
|
| -}
|
|
|