| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/chromeos/dom_ui/network_menu_ui.h" | 5 #include "chrome/browser/chromeos/dom_ui/network_menu_ui.h" |
| 6 | 6 |
| 7 #include "base/values.h" | 7 #include "base/values.h" |
| 8 #include "base/string_number_conversions.h" | 8 #include "base/string_number_conversions.h" |
| 9 #include "base/string_util.h" | 9 #include "base/string_util.h" |
| 10 #include "chrome/app/chrome_command_ids.h" | 10 #include "chrome/app/chrome_command_ids.h" |
| 11 #include "chrome/browser/browser_thread.h" | 11 #include "chrome/browser/browser_thread.h" |
| 12 #include "chrome/browser/chromeos/status/network_menu.h" | 12 #include "chrome/browser/chromeos/status/network_menu.h" |
| 13 #include "chrome/browser/chromeos/views/native_menu_webui.h" | 13 #include "chrome/browser/chromeos/views/native_menu_webui.h" |
| 14 #include "chrome/browser/chromeos/views/webui_menu_widget.h" | 14 #include "chrome/browser/chromeos/views/webui_menu_widget.h" |
| 15 #include "chrome/browser/dom_ui/web_ui_theme_source.h" | 15 #include "chrome/browser/dom_ui/web_ui_theme_source.h" |
| 16 #include "chrome/browser/profiles/profile.h" | |
| 17 #include "chrome/browser/tab_contents/tab_contents.h" | 16 #include "chrome/browser/tab_contents/tab_contents.h" |
| 18 #include "chrome/common/url_constants.h" | 17 #include "chrome/common/url_constants.h" |
| 19 #include "googleurl/src/gurl.h" | 18 #include "googleurl/src/gurl.h" |
| 20 #include "grit/browser_resources.h" | 19 #include "grit/browser_resources.h" |
| 21 #include "grit/generated_resources.h" | 20 #include "grit/generated_resources.h" |
| 22 #include "ui/base/l10n/l10n_util.h" | 21 #include "ui/base/l10n/l10n_util.h" |
| 23 #include "views/controls/menu/menu_2.h" | 22 #include "views/controls/menu/menu_2.h" |
| 24 | 23 |
| 25 namespace { | 24 namespace { |
| 26 | 25 |
| (...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 111 ALLOW_THIS_IN_INITIALIZER_LIST( | 110 ALLOW_THIS_IN_INITIALIZER_LIST( |
| 112 CreateMenuUIHTMLSource(new NetworkMenuSourceDelegate(), | 111 CreateMenuUIHTMLSource(new NetworkMenuSourceDelegate(), |
| 113 chrome::kChromeUINetworkMenu, | 112 chrome::kChromeUINetworkMenu, |
| 114 "NetworkMenu", | 113 "NetworkMenu", |
| 115 IDR_NETWORK_MENU_JS, | 114 IDR_NETWORK_MENU_JS, |
| 116 IDR_NETWORK_MENU_CSS))) { | 115 IDR_NETWORK_MENU_CSS))) { |
| 117 NetworkMenuHandler* handler = new NetworkMenuHandler(); | 116 NetworkMenuHandler* handler = new NetworkMenuHandler(); |
| 118 AddMessageHandler((handler)->Attach(this)); | 117 AddMessageHandler((handler)->Attach(this)); |
| 119 | 118 |
| 120 // Set up chrome://theme/ source. | 119 // Set up chrome://theme/ source. |
| 121 WebUIThemeSource* theme = new WebUIThemeSource(contents->profile()); | 120 WebUIThemeSource* theme = new WebUIThemeSource(GetProfile()); |
| 122 contents->profile()->GetChromeURLDataManager()->AddDataSource(theme); | 121 BrowserThread::PostTask( |
| 122 BrowserThread::IO, FROM_HERE, |
| 123 NewRunnableMethod( |
| 124 ChromeURLDataManager::GetInstance(), |
| 125 &ChromeURLDataManager::AddDataSource, |
| 126 make_scoped_refptr(theme))); |
| 123 } | 127 } |
| 124 | 128 |
| 125 bool NetworkMenuUI::ModelAction(const ui::MenuModel* model, | 129 bool NetworkMenuUI::ModelAction(const ui::MenuModel* model, |
| 126 const ListValue* values) { | 130 const ListValue* values) { |
| 127 const NetworkMenu* network_menu = static_cast<const NetworkMenu*>(model); | 131 const NetworkMenu* network_menu = static_cast<const NetworkMenu*>(model); |
| 128 std::string action; | 132 std::string action; |
| 129 bool success = values->GetString(0, &action); | 133 bool success = values->GetString(0, &action); |
| 130 bool close_menu = true; | 134 bool close_menu = true; |
| 131 if (!success) { | 135 if (!success) { |
| 132 LOG(WARNING) << "ModelAction called with no arguments from: " | 136 LOG(WARNING) << "ModelAction called with no arguments from: " |
| (...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 189 } | 193 } |
| 190 | 194 |
| 191 views::Menu2* NetworkMenuUI::CreateMenu2(ui::MenuModel* model) { | 195 views::Menu2* NetworkMenuUI::CreateMenu2(ui::MenuModel* model) { |
| 192 views::Menu2* menu = new views::Menu2(model); | 196 views::Menu2* menu = new views::Menu2(model); |
| 193 NativeMenuWebUI::SetMenuURL( | 197 NativeMenuWebUI::SetMenuURL( |
| 194 menu, GURL(StringPrintf("chrome://%s", chrome::kChromeUINetworkMenu))); | 198 menu, GURL(StringPrintf("chrome://%s", chrome::kChromeUINetworkMenu))); |
| 195 return menu; | 199 return menu; |
| 196 } | 200 } |
| 197 | 201 |
| 198 } // namespace chromeos | 202 } // namespace chromeos |
| OLD | NEW |