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