| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/ui/views/external_protocol_dialog.h" | 5 #include "chrome/browser/ui/views/external_protocol_dialog.h" |
| 6 | 6 |
| 7 #include "base/metrics/histogram.h" | 7 #include "base/metrics/histogram.h" |
| 8 #include "base/string_util.h" | 8 #include "base/string_util.h" |
| 9 #include "base/threading/thread.h" | 9 #include "base/threading/thread.h" |
| 10 #include "base/threading/thread_restrictions.h" | 10 #include "base/threading/thread_restrictions.h" |
| 11 #include "base/utf_string_conversions.h" | 11 #include "base/utf_string_conversions.h" |
| 12 #include "base/win/registry.h" | 12 #include "base/win/registry.h" |
| 13 #include "chrome/browser/external_protocol/external_protocol_handler.h" | 13 #include "chrome/browser/external_protocol/external_protocol_handler.h" |
| 14 #include "chrome/browser/tab_contents/tab_util.h" | 14 #include "chrome/browser/tab_contents/tab_util.h" |
| 15 #include "content/public/browser/web_contents.h" | 15 #include "content/public/browser/web_contents.h" |
| 16 #include "content/public/browser/web_contents_view.h" |
| 16 #include "grit/chromium_strings.h" | 17 #include "grit/chromium_strings.h" |
| 17 #include "grit/generated_resources.h" | 18 #include "grit/generated_resources.h" |
| 18 #include "ui/base/l10n/l10n_util.h" | 19 #include "ui/base/l10n/l10n_util.h" |
| 19 #include "ui/base/text/text_elider.h" | 20 #include "ui/base/text/text_elider.h" |
| 20 #include "ui/views/controls/message_box_view.h" | 21 #include "ui/views/controls/message_box_view.h" |
| 21 #include "ui/views/widget/widget.h" | 22 #include "ui/views/widget/widget.h" |
| 22 | 23 |
| 23 using content::WebContents; | 24 using content::WebContents; |
| 24 | 25 |
| 25 namespace { | 26 namespace { |
| (...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 148 message_text += l10n_util::GetStringUTF16(IDS_EXTERNAL_PROTOCOL_WARNING); | 149 message_text += l10n_util::GetStringUTF16(IDS_EXTERNAL_PROTOCOL_WARNING); |
| 149 | 150 |
| 150 views::MessageBoxView::InitParams params(message_text); | 151 views::MessageBoxView::InitParams params(message_text); |
| 151 params.message_width = kMessageWidth; | 152 params.message_width = kMessageWidth; |
| 152 message_box_view_ = new views::MessageBoxView(params); | 153 message_box_view_ = new views::MessageBoxView(params); |
| 153 message_box_view_->SetCheckBoxLabel( | 154 message_box_view_->SetCheckBoxLabel( |
| 154 l10n_util::GetStringUTF16(IDS_EXTERNAL_PROTOCOL_CHECKBOX_TEXT)); | 155 l10n_util::GetStringUTF16(IDS_EXTERNAL_PROTOCOL_CHECKBOX_TEXT)); |
| 155 | 156 |
| 156 HWND root_hwnd; | 157 HWND root_hwnd; |
| 157 if (web_contents_) { | 158 if (web_contents_) { |
| 158 root_hwnd = GetAncestor(web_contents_->GetContentNativeView(), GA_ROOT); | 159 root_hwnd = GetAncestor(web_contents_->GetView()->GetContentNativeView(), |
| 160 GA_ROOT); |
| 159 } else { | 161 } else { |
| 160 // Dialog is top level if we don't have a web_contents associated with us. | 162 // Dialog is top level if we don't have a web_contents associated with us. |
| 161 root_hwnd = NULL; | 163 root_hwnd = NULL; |
| 162 } | 164 } |
| 163 | 165 |
| 164 views::Widget::CreateWindowWithParent(this, root_hwnd)->Show(); | 166 views::Widget::CreateWindowWithParent(this, root_hwnd)->Show(); |
| 165 } | 167 } |
| 166 | 168 |
| 167 // static | 169 // static |
| 168 std::wstring ExternalProtocolDialog::GetApplicationForProtocol( | 170 std::wstring ExternalProtocolDialog::GetApplicationForProtocol( |
| (...skipping 12 matching lines...) Expand all Loading... |
| 181 std::wstring parameters = url_spec.substr(split_offset + 1, | 183 std::wstring parameters = url_spec.substr(split_offset + 1, |
| 182 url_spec.length() - 1); | 184 url_spec.length() - 1); |
| 183 std::wstring application_to_launch; | 185 std::wstring application_to_launch; |
| 184 if (cmd_key.ReadValue(NULL, &application_to_launch) == ERROR_SUCCESS) { | 186 if (cmd_key.ReadValue(NULL, &application_to_launch) == ERROR_SUCCESS) { |
| 185 ReplaceSubstringsAfterOffset(&application_to_launch, 0, L"%1", parameters); | 187 ReplaceSubstringsAfterOffset(&application_to_launch, 0, L"%1", parameters); |
| 186 return application_to_launch; | 188 return application_to_launch; |
| 187 } else { | 189 } else { |
| 188 return std::wstring(); | 190 return std::wstring(); |
| 189 } | 191 } |
| 190 } | 192 } |
| OLD | NEW |