Chromium Code Reviews| 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/ui/webui/chromeos/login/hid_detection_screen_handler.h" | 5 #include "chrome/browser/ui/webui/chromeos/login/hid_detection_screen_handler.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
| 9 #include "base/macros.h" | 9 #include "base/macros.h" |
| 10 #include "base/metrics/histogram.h" | |
| 11 #include "base/prefs/pref_service.h" | |
| 10 #include "base/strings/string16.h" | 12 #include "base/strings/string16.h" |
| 11 #include "base/strings/string_number_conversions.h" | 13 #include "base/strings/string_number_conversions.h" |
| 12 #include "base/strings/utf_string_conversions.h" | 14 #include "base/strings/utf_string_conversions.h" |
| 15 #include "chrome/browser/browser_process.h" | |
| 13 #include "chrome/browser/ui/webui/chromeos/login/oobe_ui.h" | 16 #include "chrome/browser/ui/webui/chromeos/login/oobe_ui.h" |
| 17 #include "chrome/common/pref_names.h" | |
| 14 #include "device/bluetooth/bluetooth_adapter_factory.h" | 18 #include "device/bluetooth/bluetooth_adapter_factory.h" |
| 15 #include "grit/chromium_strings.h" | 19 #include "grit/chromium_strings.h" |
| 16 #include "grit/generated_resources.h" | 20 #include "grit/generated_resources.h" |
| 17 #include "ui/base/l10n/l10n_util.h" | 21 #include "ui/base/l10n/l10n_util.h" |
| 18 | 22 |
| 19 namespace { | 23 namespace { |
| 20 | 24 |
| 21 const char kJsScreenPath[] = "login.HIDDetectionScreen"; | 25 const char kJsScreenPath[] = "login.HIDDetectionScreen"; |
| 22 | 26 |
| 23 // Variants of pairing state. | 27 // Variants of pairing state. |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 60 | 64 |
| 61 namespace chromeos { | 65 namespace chromeos { |
| 62 | 66 |
| 63 HIDDetectionScreenHandler::HIDDetectionScreenHandler() | 67 HIDDetectionScreenHandler::HIDDetectionScreenHandler() |
| 64 : BaseScreenHandler(kJsScreenPath), | 68 : BaseScreenHandler(kJsScreenPath), |
| 65 delegate_(NULL), | 69 delegate_(NULL), |
| 66 show_on_init_(false), | 70 show_on_init_(false), |
| 67 mouse_is_pairing_(false), | 71 mouse_is_pairing_(false), |
| 68 keyboard_is_pairing_(false), | 72 keyboard_is_pairing_(false), |
| 69 switch_on_adapter_when_ready_(false), | 73 switch_on_adapter_when_ready_(false), |
| 70 skip_screen_if_devices_present_(true), | 74 first_time_screen_show_(true), |
| 71 weak_ptr_factory_(this) { | 75 weak_ptr_factory_(this) { |
| 72 } | 76 } |
| 73 | 77 |
| 74 HIDDetectionScreenHandler::~HIDDetectionScreenHandler() { | 78 HIDDetectionScreenHandler::~HIDDetectionScreenHandler() { |
| 75 if (adapter_.get()) | 79 if (adapter_.get()) |
| 76 adapter_->RemoveObserver(this); | 80 adapter_->RemoveObserver(this); |
| 77 input_service_proxy_.RemoveObserver(this); | 81 input_service_proxy_.RemoveObserver(this); |
| 78 if (delegate_) | 82 if (delegate_) |
| 79 delegate_->OnActorDestroyed(this); | 83 delegate_->OnActorDestroyed(this); |
| 80 } | 84 } |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 92 | 96 |
| 93 void HIDDetectionScreenHandler::FindDevicesError() { | 97 void HIDDetectionScreenHandler::FindDevicesError() { |
| 94 VLOG(1) << "Failed to start Bluetooth discovery."; | 98 VLOG(1) << "Failed to start Bluetooth discovery."; |
| 95 } | 99 } |
| 96 | 100 |
| 97 void HIDDetectionScreenHandler::Show() { | 101 void HIDDetectionScreenHandler::Show() { |
| 98 if (!page_is_ready()) { | 102 if (!page_is_ready()) { |
| 99 show_on_init_ = true; | 103 show_on_init_ = true; |
| 100 return; | 104 return; |
| 101 } | 105 } |
| 106 PrefService* const local_state = g_browser_process->local_state(); | |
| 107 int num_of_times_dialog_was_shown = local_state->GetInteger( | |
| 108 prefs::kTimesHIDDialogShown); | |
| 109 local_state->SetInteger(prefs::kTimesHIDDialogShown, | |
| 110 num_of_times_dialog_was_shown + 1); | |
| 111 | |
| 102 input_service_proxy_.AddObserver(this); | 112 input_service_proxy_.AddObserver(this); |
| 103 skip_screen_if_devices_present_ = true; | 113 first_time_screen_show_ = true; |
| 104 UpdateDevices(); | 114 UpdateDevices(); |
| 105 ShowScreen(OobeUI::kScreenHIDDetection, NULL); | 115 ShowScreen(OobeUI::kScreenHIDDetection, NULL); |
| 106 } | 116 } |
| 107 | 117 |
| 108 void HIDDetectionScreenHandler::Hide() { | 118 void HIDDetectionScreenHandler::Hide() { |
| 109 if (adapter_.get()) | 119 if (adapter_.get()) |
| 110 adapter_->RemoveObserver(this); | 120 adapter_->RemoveObserver(this); |
| 111 input_service_proxy_.RemoveObserver(this); | 121 input_service_proxy_.RemoveObserver(this); |
| 112 } | 122 } |
| 113 | 123 |
| 114 void HIDDetectionScreenHandler::SetDelegate(Delegate* delegate) { | 124 void HIDDetectionScreenHandler::SetDelegate(Delegate* delegate) { |
| 115 delegate_ = delegate; | 125 delegate_ = delegate; |
| 116 if (page_is_ready()) | 126 if (page_is_ready()) |
| 117 Initialize(); | 127 Initialize(); |
| 118 } | 128 } |
| 119 | 129 |
| 130 // static | |
|
ygorshenin1
2014/05/14 09:35:36
Move this method after OnInputDeviceRemoved() (fol
merkulova
2014/05/14 13:11:05
Done.
| |
| 131 void HIDDetectionScreenHandler::RegisterPrefs(PrefRegistrySimple* registry) { | |
| 132 registry->RegisterIntegerPref(prefs::kTimesHIDDialogShown, 0); | |
| 133 } | |
| 134 | |
| 120 void HIDDetectionScreenHandler::DeclareLocalizedValues( | 135 void HIDDetectionScreenHandler::DeclareLocalizedValues( |
| 121 LocalizedValuesBuilder* builder) { | 136 LocalizedValuesBuilder* builder) { |
| 122 builder->Add("hidDetectionContinue", IDS_HID_DETECTION_CONTINUE_BUTTON); | 137 builder->Add("hidDetectionContinue", IDS_HID_DETECTION_CONTINUE_BUTTON); |
| 123 builder->Add("hidDetectionInvitation", IDS_HID_DETECTION_INVITATION_TEXT); | 138 builder->Add("hidDetectionInvitation", IDS_HID_DETECTION_INVITATION_TEXT); |
| 124 builder->Add("hidDetectionPrerequisites", | 139 builder->Add("hidDetectionPrerequisites", |
| 125 IDS_HID_DETECTION_PRECONDITION_TEXT); | 140 IDS_HID_DETECTION_PRECONDITION_TEXT); |
| 126 builder->Add("hidDetectionMouseSearching", IDS_HID_DETECTION_SEARCHING_MOUSE); | 141 builder->Add("hidDetectionMouseSearching", IDS_HID_DETECTION_SEARCHING_MOUSE); |
| 127 builder->Add("hidDetectionKeyboardSearching", | 142 builder->Add("hidDetectionKeyboardSearching", |
| 128 IDS_HID_DETECTION_SEARCHING_KEYBOARD); | 143 IDS_HID_DETECTION_SEARCHING_KEYBOARD); |
| 129 builder->Add("hidDetectionUSBMouseConnected", | 144 builder->Add("hidDetectionUSBMouseConnected", |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 148 show_on_init_ = false; | 163 show_on_init_ = false; |
| 149 } | 164 } |
| 150 } | 165 } |
| 151 | 166 |
| 152 void HIDDetectionScreenHandler::RegisterMessages() { | 167 void HIDDetectionScreenHandler::RegisterMessages() { |
| 153 AddCallback( | 168 AddCallback( |
| 154 "HIDDetectionOnContinue", &HIDDetectionScreenHandler::HandleOnContinue); | 169 "HIDDetectionOnContinue", &HIDDetectionScreenHandler::HandleOnContinue); |
| 155 } | 170 } |
| 156 | 171 |
| 157 void HIDDetectionScreenHandler::HandleOnContinue() { | 172 void HIDDetectionScreenHandler::HandleOnContinue() { |
| 173 if (!first_time_screen_show_) { | |
| 174 // Continue button pressed. | |
| 175 int scenario_type; | |
| 176 if (!pointing_device_id_.empty() && !keyboard_device_id_.empty()) | |
| 177 scenario_type = hid::All_DEVICES_DETECTED; | |
| 178 else if (pointing_device_id_.empty()) | |
| 179 scenario_type = hid::KEYBOARD_DEVICE_ONLY_DETECTED; | |
| 180 else | |
| 181 scenario_type = hid::POINTING_DEVICE_ONLY_DETECTED; | |
| 182 | |
| 183 UMA_HISTOGRAM_ENUMERATION( | |
| 184 "HIDDetection.OOBEDevicesDetectedOnContinuePressed", | |
| 185 scenario_type, | |
| 186 hid::CONTINUE_SCENARIO_TYPE_SIZE); | |
| 187 } else { | |
| 188 // Screen not shown as devices were autodetected. | |
| 189 PrefService* local_state = g_browser_process->local_state(); | |
| 190 int num_of_times_dialog_was_shown = local_state->GetInteger( | |
| 191 prefs::kTimesHIDDialogShown); | |
| 192 local_state->SetInteger(prefs::kTimesHIDDialogShown, | |
|
ygorshenin1
2014/05/14 09:35:36
After discussion: could you please get rid of this
merkulova
2014/05/14 13:11:05
Done.
| |
| 193 num_of_times_dialog_was_shown - 1); | |
| 194 } | |
| 158 if (delegate_) | 195 if (delegate_) |
| 159 delegate_->OnExit(); | 196 delegate_->OnExit(); |
| 160 } | 197 } |
| 161 | 198 |
| 162 void HIDDetectionScreenHandler::InitializeAdapter( | 199 void HIDDetectionScreenHandler::InitializeAdapter( |
| 163 scoped_refptr<device::BluetoothAdapter> adapter) { | 200 scoped_refptr<device::BluetoothAdapter> adapter) { |
| 164 adapter_ = adapter; | 201 adapter_ = adapter; |
| 165 CHECK(adapter_.get()); | 202 CHECK(adapter_.get()); |
| 166 | 203 |
| 167 adapter_->AddObserver(this); | 204 adapter_->AddObserver(this); |
| (...skipping 197 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 365 pointing_device_connect_type_ = it->type; | 402 pointing_device_connect_type_ = it->type; |
| 366 SendPointingDeviceNotification(); | 403 SendPointingDeviceNotification(); |
| 367 } | 404 } |
| 368 if (keyboard_device_id_.empty() && it->is_keyboard) { | 405 if (keyboard_device_id_.empty() && it->is_keyboard) { |
| 369 keyboard_device_id_ = it->id; | 406 keyboard_device_id_ = it->id; |
| 370 keyboard_device_name_ = it->name; | 407 keyboard_device_name_ = it->name; |
| 371 keyboard_device_connect_type_ = it->type; | 408 keyboard_device_connect_type_ = it->type; |
| 372 SendKeyboardDeviceNotification(NULL); | 409 SendKeyboardDeviceNotification(NULL); |
| 373 } | 410 } |
| 374 } | 411 } |
| 375 // Skip screen if both devices are present and skip was requested. | 412 |
| 376 if (!pointing_device_id_.empty() && | 413 if (first_time_screen_show_) { |
| 377 !keyboard_device_id_.empty() && | 414 // Skip screen if both devices are present and it's first show. |
| 378 skip_screen_if_devices_present_) { | 415 bool all_devices_autodetected = !pointing_device_id_.empty() && |
| 379 HandleOnContinue(); | 416 !keyboard_device_id_.empty(); |
| 417 UMA_HISTOGRAM_BOOLEAN("HIDDetection.OOBEDialogShown", | |
| 418 !all_devices_autodetected); | |
| 419 if (all_devices_autodetected) | |
| 420 HandleOnContinue(); | |
| 380 } | 421 } |
| 381 // Skip requested only once on dialog show. | 422 |
| 382 skip_screen_if_devices_present_ = false; | 423 first_time_screen_show_ = false; |
| 383 if ((pointing_device_id_.empty() || keyboard_device_id_.empty()) && | 424 if ((pointing_device_id_.empty() || keyboard_device_id_.empty()) && |
| 384 adapter_) { | 425 adapter_) { |
| 385 if (!adapter_->IsPresent()) { | 426 if (!adapter_->IsPresent()) { |
| 386 // Switch on BT adapter later when it's available. | 427 // Switch on BT adapter later when it's available. |
| 387 switch_on_adapter_when_ready_ = true; | 428 switch_on_adapter_when_ready_ = true; |
| 388 } else if (!adapter_->IsPowered()) { | 429 } else if (!adapter_->IsPowered()) { |
| 389 adapter_->SetPowered( | 430 adapter_->SetPowered( |
| 390 true, | 431 true, |
| 391 base::Bind(&HIDDetectionScreenHandler::StartBTDiscoverySession, | 432 base::Bind(&HIDDetectionScreenHandler::StartBTDiscoverySession, |
| 392 weak_ptr_factory_.GetWeakPtr()), | 433 weak_ptr_factory_.GetWeakPtr()), |
| (...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 492 l10n_util::GetStringFUTF16( | 533 l10n_util::GetStringFUTF16( |
| 493 IDS_HID_DETECTION_PAIRED_BLUETOOTH_KEYBOARD, | 534 IDS_HID_DETECTION_PAIRED_BLUETOOTH_KEYBOARD, |
| 494 base::UTF8ToUTF16(keyboard_device_name_))); | 535 base::UTF8ToUTF16(keyboard_device_name_))); |
| 495 } else { | 536 } else { |
| 496 state_info.SetString("state", kUSBConnectedState); | 537 state_info.SetString("state", kUSBConnectedState); |
| 497 } | 538 } |
| 498 CallJS("setKeyboardDeviceState", state_info); | 539 CallJS("setKeyboardDeviceState", state_info); |
| 499 } | 540 } |
| 500 | 541 |
| 501 } // namespace chromeos | 542 } // namespace chromeos |
| OLD | NEW |