OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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/internet_options_handler.h" | 5 #include "chrome/browser/chromeos/dom_ui/internet_options_handler.h" |
6 | 6 |
7 #include <ctype.h> | 7 #include <ctype.h> |
8 | 8 |
9 #include <string> | 9 #include <string> |
10 #include <vector> | 10 #include <vector> |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
49 output.push_back(':'); | 49 output.push_back(':'); |
50 } | 50 } |
51 output.push_back(toupper(address[i])); | 51 output.push_back(toupper(address[i])); |
52 } | 52 } |
53 return output; | 53 return output; |
54 } | 54 } |
55 | 55 |
56 } // namespace | 56 } // namespace |
57 | 57 |
58 InternetOptionsHandler::InternetOptionsHandler() { | 58 InternetOptionsHandler::InternetOptionsHandler() { |
59 chromeos::CrosLibrary::Get()->GetNetworkLibrary()->AddObserver(this); | 59 chromeos::NetworkLibrary* netlib = |
| 60 chromeos::CrosLibrary::Get()->GetNetworkLibrary(); |
| 61 netlib->AddNetworkManagerObserver(this); |
| 62 netlib->AddCellularDataPlanObserver(this); |
| 63 MonitorActiveNetwork(netlib); |
60 } | 64 } |
61 | 65 |
62 InternetOptionsHandler::~InternetOptionsHandler() { | 66 InternetOptionsHandler::~InternetOptionsHandler() { |
63 chromeos::CrosLibrary::Get()->GetNetworkLibrary()->RemoveObserver(this); | 67 chromeos::NetworkLibrary *netlib = |
| 68 chromeos::CrosLibrary::Get()->GetNetworkLibrary(); |
| 69 netlib->RemoveNetworkManagerObserver(this); |
| 70 netlib->RemoveCellularDataPlanObserver(this); |
| 71 netlib->RemoveObserverForAllNetworks(this); |
64 } | 72 } |
65 | 73 |
66 void InternetOptionsHandler::GetLocalizedValues( | 74 void InternetOptionsHandler::GetLocalizedValues( |
67 DictionaryValue* localized_strings) { | 75 DictionaryValue* localized_strings) { |
68 DCHECK(localized_strings); | 76 DCHECK(localized_strings); |
69 // Internet page - ChromeOS | 77 // Internet page - ChromeOS |
70 localized_strings->SetString("internetPage", | 78 localized_strings->SetString("internetPage", |
71 l10n_util::GetStringUTF16(IDS_OPTIONS_INTERNET_TAB_LABEL)); | 79 l10n_util::GetStringUTF16(IDS_OPTIONS_INTERNET_TAB_LABEL)); |
72 | 80 |
73 localized_strings->SetString("wired_title", | 81 localized_strings->SetString("wired_title", |
(...skipping 276 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
350 | 358 |
351 void InternetOptionsHandler::BuyDataPlanCallback(const ListValue* args) { | 359 void InternetOptionsHandler::BuyDataPlanCallback(const ListValue* args) { |
352 if (!dom_ui_) | 360 if (!dom_ui_) |
353 return; | 361 return; |
354 Browser* browser = BrowserList::FindBrowserWithFeature( | 362 Browser* browser = BrowserList::FindBrowserWithFeature( |
355 dom_ui_->GetProfile(), Browser::FEATURE_TABSTRIP); | 363 dom_ui_->GetProfile(), Browser::FEATURE_TABSTRIP); |
356 if (browser) | 364 if (browser) |
357 browser->OpenMobilePlanTabAndActivate(); | 365 browser->OpenMobilePlanTabAndActivate(); |
358 } | 366 } |
359 | 367 |
360 void InternetOptionsHandler::NetworkChanged(chromeos::NetworkLibrary* cros) { | 368 void InternetOptionsHandler::RefreshNetworkData( |
361 if (!dom_ui_) | 369 chromeos::NetworkLibrary* cros) { |
362 return; | |
363 | |
364 DictionaryValue dictionary; | 370 DictionaryValue dictionary; |
365 dictionary.Set("wiredList", GetWiredList()); | 371 dictionary.Set("wiredList", GetWiredList()); |
366 dictionary.Set("wirelessList", GetWirelessList()); | 372 dictionary.Set("wirelessList", GetWirelessList()); |
367 dictionary.Set("rememberedList", GetRememberedList()); | 373 dictionary.Set("rememberedList", GetRememberedList()); |
368 dictionary.SetBoolean("wifiAvailable", cros->wifi_available()); | 374 dictionary.SetBoolean("wifiAvailable", cros->wifi_available()); |
369 dictionary.SetBoolean("wifiEnabled", cros->wifi_enabled()); | 375 dictionary.SetBoolean("wifiEnabled", cros->wifi_enabled()); |
370 dictionary.SetBoolean("cellularAvailable", cros->cellular_available()); | 376 dictionary.SetBoolean("cellularAvailable", cros->cellular_available()); |
371 dictionary.SetBoolean("cellularEnabled", cros->cellular_enabled()); | 377 dictionary.SetBoolean("cellularEnabled", cros->cellular_enabled()); |
372 dom_ui_->CallJavascriptFunction( | 378 dom_ui_->CallJavascriptFunction( |
373 L"options.InternetOptions.refreshNetworkData", dictionary); | 379 L"options.InternetOptions.refreshNetworkData", dictionary); |
374 } | 380 } |
375 | 381 |
376 void InternetOptionsHandler::CellularDataPlanChanged( | 382 void InternetOptionsHandler::OnNetworkManagerChanged( |
| 383 chromeos::NetworkLibrary* cros) { |
| 384 if (!dom_ui_) |
| 385 return; |
| 386 MonitorActiveNetwork(cros); |
| 387 RefreshNetworkData(cros); |
| 388 } |
| 389 |
| 390 void InternetOptionsHandler::OnNetworkChanged( |
| 391 chromeos::NetworkLibrary* cros, |
| 392 const chromeos::Network* network) { |
| 393 if (dom_ui_) |
| 394 RefreshNetworkData(cros); |
| 395 } |
| 396 |
| 397 // Add an observer for the active network, if any, so |
| 398 // that we can dynamically display the correct icon for |
| 399 // that network's signal strength. |
| 400 // TODO(ers) Ideally, on this page we'd monitor all networks for |
| 401 // signal strength changes, not just the active network. |
| 402 void InternetOptionsHandler::MonitorActiveNetwork( |
| 403 chromeos::NetworkLibrary* cros) { |
| 404 const chromeos::Network* network = cros->active_network(); |
| 405 if (active_network_.empty() || network == NULL || |
| 406 active_network_ != network->service_path()) { |
| 407 if (!active_network_.empty()) { |
| 408 cros->RemoveNetworkObserver(active_network_, this); |
| 409 } |
| 410 if (network != NULL) { |
| 411 cros->AddNetworkObserver(network->service_path(), this); |
| 412 } |
| 413 } |
| 414 if (network != NULL) |
| 415 active_network_ = network->service_path(); |
| 416 else |
| 417 active_network_ = ""; |
| 418 } |
| 419 |
| 420 void InternetOptionsHandler::OnCellularDataPlanChanged( |
377 chromeos::NetworkLibrary* obj) { | 421 chromeos::NetworkLibrary* obj) { |
378 if (!dom_ui_) | 422 if (!dom_ui_) |
379 return; | 423 return; |
380 chromeos::CellularNetwork* cellular = obj->cellular_network(); | 424 chromeos::CellularNetwork* cellular = obj->cellular_network(); |
381 if (!cellular) | 425 if (!cellular) |
382 return; | 426 return; |
383 const chromeos::CellularDataPlanList& plans = cellular->GetDataPlans(); | 427 const chromeos::CellularDataPlanList& plans = cellular->GetDataPlans(); |
384 DictionaryValue connection_plans; | 428 DictionaryValue connection_plans; |
385 ListValue* plan_list = new ListValue(); | 429 ListValue* plan_list = new ListValue(); |
386 for (chromeos::CellularDataPlanList::const_iterator iter = plans.begin(); | 430 for (chromeos::CellularDataPlanList::const_iterator iter = plans.begin(); |
(...skipping 556 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
943 false, | 987 false, |
944 chromeos::ACTIVATION_STATE_UNKNOWN)); | 988 chromeos::ACTIVATION_STATE_UNKNOWN)); |
945 } | 989 } |
946 | 990 |
947 const chromeos::CellularNetworkVector cellular_networks = | 991 const chromeos::CellularNetworkVector cellular_networks = |
948 cros->cellular_networks(); | 992 cros->cellular_networks(); |
949 for (chromeos::CellularNetworkVector::const_iterator it = | 993 for (chromeos::CellularNetworkVector::const_iterator it = |
950 cellular_networks.begin(); it != cellular_networks.end(); ++it) { | 994 cellular_networks.begin(); it != cellular_networks.end(); ++it) { |
951 SkBitmap icon = chromeos::NetworkMenu::IconForNetworkStrength( | 995 SkBitmap icon = chromeos::NetworkMenu::IconForNetworkStrength( |
952 (*it)->strength(), true); | 996 (*it)->strength(), true); |
953 SkBitmap badge = *rb.GetBitmapNamed(IDR_STATUSBAR_NETWORK_3G); | 997 SkBitmap badge = chromeos::NetworkMenu::BadgeForNetworkTechnology(*it); |
954 icon = chromeos::NetworkMenu::IconForDisplay(icon, badge); | 998 icon = chromeos::NetworkMenu::IconForDisplay(icon, badge); |
955 list->Append(GetNetwork( | 999 list->Append(GetNetwork( |
956 (*it)->service_path(), | 1000 (*it)->service_path(), |
957 icon, | 1001 icon, |
958 (*it)->name(), | 1002 (*it)->name(), |
959 (*it)->connecting(), | 1003 (*it)->connecting(), |
960 (*it)->connected(), | 1004 (*it)->connected(), |
961 chromeos::TYPE_CELLULAR, | 1005 chromeos::TYPE_CELLULAR, |
962 false, | 1006 false, |
963 (*it)->activation_state())); | 1007 (*it)->activation_state())); |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
999 icon, | 1043 icon, |
1000 (*it)->name(), | 1044 (*it)->name(), |
1001 (*it)->connecting(), | 1045 (*it)->connecting(), |
1002 (*it)->connected(), | 1046 (*it)->connected(), |
1003 chromeos::TYPE_WIFI, | 1047 chromeos::TYPE_WIFI, |
1004 true, | 1048 true, |
1005 chromeos::ACTIVATION_STATE_UNKNOWN)); | 1049 chromeos::ACTIVATION_STATE_UNKNOWN)); |
1006 } | 1050 } |
1007 return list; | 1051 return list; |
1008 } | 1052 } |
OLD | NEW |