OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/net/network_connect_delegate_chromeos.h" | 5 #include "chrome/browser/chromeos/net/network_connect_delegate_chromeos.h" |
6 | 6 |
7 #include "ash/common/session/session_state_delegate.h" | |
8 #include "ash/common/wm_shell.h" | |
9 #include "ash/shell.h" | |
10 #include "chrome/browser/chromeos/enrollment_dialog_view.h" | 7 #include "chrome/browser/chromeos/enrollment_dialog_view.h" |
| 8 #include "chrome/browser/chromeos/login/lock/screen_locker.h" |
11 #include "chrome/browser/chromeos/net/network_state_notifier.h" | 9 #include "chrome/browser/chromeos/net/network_state_notifier.h" |
12 #include "chrome/browser/chromeos/sim_dialog_delegate.h" | 10 #include "chrome/browser/chromeos/sim_dialog_delegate.h" |
13 #include "chrome/browser/ui/ash/system_tray_client.h" | 11 #include "chrome/browser/ui/ash/system_tray_client.h" |
14 #include "chrome/browser/ui/webui/chromeos/mobile_setup_dialog.h" | 12 #include "chrome/browser/ui/webui/chromeos/mobile_setup_dialog.h" |
15 | 13 |
| 14 namespace chromeos { |
| 15 |
16 namespace { | 16 namespace { |
17 | 17 |
18 bool IsUIAvailable() { | 18 bool IsUIAvailable() { |
19 return ash::WmShell::HasInstance() && | 19 // UI is available when screen is unlocked. |
20 !ash::WmShell::Get()->GetSessionStateDelegate()->IsScreenLocked(); | 20 return !ScreenLocker::default_screen_locker() || |
21 } | 21 !ScreenLocker::default_screen_locker()->locked(); |
22 | |
23 gfx::NativeWindow GetNativeWindow() { | |
24 int container_id = SystemTrayClient::GetDialogParentContainerId(); | |
25 return ash::Shell::GetContainer(ash::Shell::GetPrimaryRootWindow(), | |
26 container_id); | |
27 } | 22 } |
28 | 23 |
29 } // namespace | 24 } // namespace |
30 | 25 |
31 namespace chromeos { | |
32 | |
33 NetworkConnectDelegateChromeOS::NetworkConnectDelegateChromeOS() | 26 NetworkConnectDelegateChromeOS::NetworkConnectDelegateChromeOS() |
34 : network_state_notifier_(new NetworkStateNotifier()) {} | 27 : network_state_notifier_(new NetworkStateNotifier()) {} |
35 | 28 |
36 NetworkConnectDelegateChromeOS::~NetworkConnectDelegateChromeOS() {} | 29 NetworkConnectDelegateChromeOS::~NetworkConnectDelegateChromeOS() {} |
37 | 30 |
38 void NetworkConnectDelegateChromeOS::ShowNetworkConfigure( | 31 void NetworkConnectDelegateChromeOS::ShowNetworkConfigure( |
39 const std::string& network_id) { | 32 const std::string& network_id) { |
40 if (!IsUIAvailable()) | 33 if (!IsUIAvailable()) |
41 return; | 34 return; |
42 SystemTrayClient::Get()->ShowNetworkConfigure(network_id); | 35 SystemTrayClient::Get()->ShowNetworkConfigure(network_id); |
43 } | 36 } |
44 | 37 |
45 void NetworkConnectDelegateChromeOS::ShowNetworkSettings( | 38 void NetworkConnectDelegateChromeOS::ShowNetworkSettings( |
46 const std::string& network_id) { | 39 const std::string& network_id) { |
47 if (!IsUIAvailable()) | 40 if (!IsUIAvailable()) |
48 return; | 41 return; |
49 SystemTrayClient::Get()->ShowNetworkSettings(network_id); | 42 SystemTrayClient::Get()->ShowNetworkSettings(network_id); |
50 } | 43 } |
51 | 44 |
52 bool NetworkConnectDelegateChromeOS::ShowEnrollNetwork( | 45 bool NetworkConnectDelegateChromeOS::ShowEnrollNetwork( |
53 const std::string& network_id) { | 46 const std::string& network_id) { |
54 if (!IsUIAvailable()) | 47 if (!IsUIAvailable()) |
55 return false; | 48 return false; |
56 return enrollment::CreateEnrollmentDialog(network_id, GetNativeWindow()); | 49 return enrollment::CreateEnrollmentDialog(network_id, |
| 50 nullptr /* owning_window */); |
57 } | 51 } |
58 | 52 |
59 void NetworkConnectDelegateChromeOS::ShowMobileSimDialog() { | 53 void NetworkConnectDelegateChromeOS::ShowMobileSimDialog() { |
60 if (!IsUIAvailable()) | 54 if (!IsUIAvailable()) |
61 return; | 55 return; |
62 SimDialogDelegate::ShowDialog(GetNativeWindow(), | 56 SimDialogDelegate::ShowDialog(nullptr /* owning_window */, |
63 SimDialogDelegate::SIM_DIALOG_UNLOCK); | 57 SimDialogDelegate::SIM_DIALOG_UNLOCK); |
64 } | 58 } |
65 | 59 |
66 void NetworkConnectDelegateChromeOS::ShowMobileSetupDialog( | 60 void NetworkConnectDelegateChromeOS::ShowMobileSetupDialog( |
67 const std::string& network_id) { | 61 const std::string& network_id) { |
68 if (!IsUIAvailable()) | 62 if (!IsUIAvailable()) |
69 return; | 63 return; |
70 MobileSetupDialog::ShowByNetworkId(network_id); | 64 MobileSetupDialog::ShowByNetworkId(network_id); |
71 } | 65 } |
72 | 66 |
73 void NetworkConnectDelegateChromeOS::ShowNetworkConnectError( | 67 void NetworkConnectDelegateChromeOS::ShowNetworkConnectError( |
74 const std::string& error_name, | 68 const std::string& error_name, |
75 const std::string& network_id) { | 69 const std::string& network_id) { |
76 network_state_notifier_->ShowNetworkConnectError(error_name, network_id); | 70 network_state_notifier_->ShowNetworkConnectError(error_name, network_id); |
77 } | 71 } |
78 | 72 |
79 void NetworkConnectDelegateChromeOS::ShowMobileActivationError( | 73 void NetworkConnectDelegateChromeOS::ShowMobileActivationError( |
80 const std::string& network_id) { | 74 const std::string& network_id) { |
81 network_state_notifier_->ShowMobileActivationError(network_id); | 75 network_state_notifier_->ShowMobileActivationError(network_id); |
82 } | 76 } |
83 | 77 |
84 } // namespace chromeos | 78 } // namespace chromeos |
OLD | NEW |