Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(127)

Unified Diff: ash/system/network/tray_network.cc

Issue 10824142: Support toggling Wi-Fi with keyboard shortcut. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ash/system/network/tray_network.h ('k') | chrome/browser/chromeos/system/ash_system_tray_delegate.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ash/system/network/tray_network.cc
diff --git a/ash/system/network/tray_network.cc b/ash/system/network/tray_network.cc
index 65ece0826b7f62664c17978588f72bf00b92c293..db6bc2adccde1bda684eb97178eb2f5bd30047cf 100644
--- a/ash/system/network/tray_network.cc
+++ b/ash/system/network/tray_network.cc
@@ -197,11 +197,22 @@ class NetworkDefaultView : public TrayItemMore {
DISALLOW_COPY_AND_ASSIGN(NetworkDefaultView);
};
-class NetworkDetailedView : public TrayDetailsView,
- public views::ButtonListener,
- public ViewClickListener {
+class NetworkDetailedView : public TrayDetailsView {
public:
- explicit NetworkDetailedView(user::LoginStatus login)
+ NetworkDetailedView() {}
+
+ virtual ~NetworkDetailedView() {}
+
+ virtual TrayNetwork::DetailedViewType GetViewType() const = 0;
+
+ virtual void Update() = 0;
+};
+
+class NetworkListDetailedView : public NetworkDetailedView,
+ public views::ButtonListener,
+ public ViewClickListener {
+ public:
+ NetworkListDetailedView(user::LoginStatus login)
: login_(login),
airplane_(NULL),
info_icon_(NULL),
@@ -220,7 +231,7 @@ class NetworkDetailedView : public TrayDetailsView,
Update();
}
- virtual ~NetworkDetailedView() {
+ virtual ~NetworkListDetailedView() {
if (info_bubble_)
info_bubble_->GetWidget()->CloseNow();
}
@@ -247,7 +258,12 @@ class NetworkDetailedView : public TrayDetailsView,
Update();
}
- void Update() {
+ // Overridden from NetworkDetailedView:
+ virtual TrayNetwork::DetailedViewType GetViewType() const OVERRIDE {
+ return TrayNetwork::LIST_VIEW;
+ }
+
+ virtual void Update() OVERRIDE {
UpdateHeaderButtons();
UpdateNetworkEntries();
UpdateNetworkExtra();
@@ -611,7 +627,44 @@ class NetworkDetailedView : public TrayDetailsView,
views::BubbleDelegateView* info_bubble_;
- DISALLOW_COPY_AND_ASSIGN(NetworkDetailedView);
+ DISALLOW_COPY_AND_ASSIGN(NetworkListDetailedView);
+};
+
+class NetworkWifiDetailedView : public NetworkDetailedView {
+ public:
+ explicit NetworkWifiDetailedView(bool wifi_enabled) {
+ SetLayoutManager(new views::BoxLayout(views::BoxLayout::kHorizontal,
+ kTrayPopupPaddingHorizontal,
+ 10,
+ kTrayPopupPaddingBetweenItems));
+ ui::ResourceBundle& bundle = ui::ResourceBundle::GetSharedInstance();
+ views::ImageView* image = new views::ImageView;
+ const int image_id = wifi_enabled ?
+ IDR_AURA_UBER_TRAY_WIFI_ENABLED : IDR_AURA_UBER_TRAY_WIFI_DISABLED;
+ image->SetImage(bundle.GetImageNamed(image_id).ToImageSkia());
+ AddChildView(image);
+
+ const int string_id = wifi_enabled ?
+ IDS_ASH_STATUS_TRAY_NETWORK_WIFI_ENABLED:
+ IDS_ASH_STATUS_TRAY_NETWORK_WIFI_DISABLED;
+ views::Label* label =
+ new views::Label(bundle.GetLocalizedString(string_id));
+ label->SetMultiLine(true);
+ label->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
+ AddChildView(label);
+ }
+
+ virtual ~NetworkWifiDetailedView() {}
+
+ // Overridden from NetworkDetailedView:
+ virtual TrayNetwork::DetailedViewType GetViewType() const OVERRIDE {
+ return TrayNetwork::WIFI_VIEW;
+ }
+
+ virtual void Update() OVERRIDE {}
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(NetworkWifiDetailedView);
};
class NetworkErrorView : public views::View,
@@ -715,7 +768,8 @@ TrayNetwork::TrayNetwork()
default_(NULL),
detailed_(NULL),
notification_(NULL),
- errors_(new tray::NetworkErrors()) {
+ errors_(new tray::NetworkErrors()),
+ request_wifi_view_(false) {
}
TrayNetwork::~TrayNetwork() {
@@ -735,7 +789,14 @@ views::View* TrayNetwork::CreateDefaultView(user::LoginStatus status) {
views::View* TrayNetwork::CreateDetailedView(user::LoginStatus status) {
CHECK(detailed_ == NULL);
- detailed_ = new tray::NetworkDetailedView(status);
+ if (request_wifi_view_) {
+ SystemTrayDelegate* delegate = Shell::GetInstance()->tray_delegate();
+ // The Wi-Fi state is not toggled yet at this point.
+ detailed_ = new tray::NetworkWifiDetailedView(!delegate->GetWifiEnabled());
+ request_wifi_view_ = false;
+ } else {
+ detailed_ = new tray::NetworkListDetailedView(status);
+ }
return detailed_;
}
@@ -805,6 +866,13 @@ void TrayNetwork::ClearNetworkError(ErrorType error_type) {
ShowNotificationView();
}
+void TrayNetwork::OnWillToggleWifi() {
+ if (!detailed_ || detailed_->GetViewType() == WIFI_VIEW) {
+ request_wifi_view_ = true;
+ PopupDetailedView(kTrayPopupAutoCloseDelayForTextInSeconds, false);
+ }
+}
+
void TrayNetwork::LinkClicked(ErrorType error_type) {
tray::NetworkErrors::ErrorMap::const_iterator iter =
errors()->messages().find(error_type);
« no previous file with comments | « ash/system/network/tray_network.h ('k') | chrome/browser/chromeos/system/ash_system_tray_delegate.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698