| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/status/data_promo_notification.h" | 5 #include "chrome/browser/chromeos/status/data_promo_notification.h" |
| 6 | 6 |
| 7 #include "ash/shell.h" | 7 #include "ash/shell.h" |
| 8 #include "ash/shell_window_ids.h" | 8 #include "ash/shell_window_ids.h" |
| 9 #include "ash/system/chromeos/network/network_connect.h" | 9 #include "ash/system/chromeos/network/network_connect.h" |
| 10 #include "ash/system/chromeos/network/network_observer.h" | |
| 11 #include "ash/system/tray/system_tray.h" | 10 #include "ash/system/tray/system_tray.h" |
| 12 #include "ash/system/tray/system_tray_notifier.h" | 11 #include "ash/system/tray/system_tray_notifier.h" |
| 13 #include "base/prefs/pref_registry_simple.h" | 12 #include "base/prefs/pref_registry_simple.h" |
| 14 #include "base/prefs/pref_service.h" | 13 #include "base/prefs/pref_service.h" |
| 15 #include "base/strings/utf_string_conversions.h" | 14 #include "base/strings/utf_string_conversions.h" |
| 16 #include "chrome/browser/browser_process.h" | 15 #include "chrome/browser/browser_process.h" |
| 17 #include "chrome/browser/chromeos/login/helper.h" | 16 #include "chrome/browser/chromeos/login/helper.h" |
| 18 #include "chrome/browser/chromeos/mobile_config.h" | 17 #include "chrome/browser/chromeos/mobile_config.h" |
| 19 #include "chrome/browser/profiles/profile.h" | 18 #include "chrome/browser/profiles/profile.h" |
| 20 #include "chrome/browser/profiles/profile_manager.h" | 19 #include "chrome/browser/profiles/profile_manager.h" |
| 21 #include "chrome/browser/ui/browser.h" | 20 #include "chrome/browser/ui/browser.h" |
| 22 #include "chrome/browser/ui/browser_finder.h" | 21 #include "chrome/browser/ui/browser_finder.h" |
| 23 #include "chrome/browser/ui/browser_list.h" | 22 #include "chrome/browser/ui/browser_list.h" |
| 24 #include "chrome/browser/ui/singleton_tabs.h" | 23 #include "chrome/browser/ui/singleton_tabs.h" |
| 25 #include "chrome/common/pref_names.h" | 24 #include "chrome/common/pref_names.h" |
| 26 #include "chromeos/login/login_state.h" | 25 #include "chromeos/login/login_state.h" |
| 27 #include "chromeos/network/device_state.h" | 26 #include "chromeos/network/device_state.h" |
| 28 #include "chromeos/network/network_connection_handler.h" | 27 #include "chromeos/network/network_connection_handler.h" |
| 29 #include "chromeos/network/network_event_log.h" | 28 #include "chromeos/network/network_event_log.h" |
| 30 #include "chromeos/network/network_state.h" | 29 #include "chromeos/network/network_state.h" |
| 31 #include "chromeos/network/network_state_handler.h" | 30 #include "chromeos/network/network_state_handler.h" |
| 32 #include "grit/ash_strings.h" | 31 #include "grit/ash_resources.h" |
| 33 #include "grit/generated_resources.h" | 32 #include "grit/generated_resources.h" |
| 34 #include "grit/theme_resources.h" | 33 #include "grit/theme_resources.h" |
| 35 #include "third_party/cros_system_api/dbus/service_constants.h" | 34 #include "third_party/cros_system_api/dbus/service_constants.h" |
| 36 #include "ui/base/l10n/l10n_util.h" | 35 #include "ui/base/l10n/l10n_util.h" |
| 37 #include "ui/base/resource/resource_bundle.h" | 36 #include "ui/base/resource/resource_bundle.h" |
| 37 #include "ui/message_center/message_center.h" |
| 38 #include "ui/message_center/notification.h" |
| 38 #include "ui/views/view.h" | 39 #include "ui/views/view.h" |
| 39 #include "ui/views/widget/widget.h" | 40 #include "ui/views/widget/widget.h" |
| 40 | 41 |
| 41 namespace chromeos { | 42 namespace chromeos { |
| 42 | 43 |
| 43 namespace { | 44 namespace { |
| 44 | 45 |
| 45 // Time in milliseconds to delay showing of promo | 46 // Time in milliseconds to delay showing of promo |
| 46 // notification when Chrome window is not on screen. | 47 // notification when Chrome window is not on screen. |
| 47 const int kPromoShowDelayMs = 10000; | 48 const int kPromoShowDelayMs = 10000; |
| (...skipping 15 matching lines...) Expand all Loading... |
| 63 Profile* profile = ProfileManager::GetDefaultProfileOrOffTheRecord(); | 64 Profile* profile = ProfileManager::GetDefaultProfileOrOffTheRecord(); |
| 64 PrefService* prefs = profile->GetPrefs(); | 65 PrefService* prefs = profile->GetPrefs(); |
| 65 prefs->SetBoolean(pref_name, value); | 66 prefs->SetBoolean(pref_name, value); |
| 66 } | 67 } |
| 67 | 68 |
| 68 void SetIntegerLocalPref(const char* pref_name, int value) { | 69 void SetIntegerLocalPref(const char* pref_name, int value) { |
| 69 PrefService* prefs = g_browser_process->local_state(); | 70 PrefService* prefs = g_browser_process->local_state(); |
| 70 prefs->SetInteger(pref_name, value); | 71 prefs->SetInteger(pref_name, value); |
| 71 } | 72 } |
| 72 | 73 |
| 73 // Returns prefs::kShow3gPromoNotification or false | 74 // Returns prefs::kShow3gPromoNotification or false if no active browser. |
| 74 // if there's no active browser. | |
| 75 bool ShouldShow3gPromoNotification() { | 75 bool ShouldShow3gPromoNotification() { |
| 76 return GetBooleanPref(prefs::kShow3gPromoNotification); | 76 return GetBooleanPref(prefs::kShow3gPromoNotification); |
| 77 } | 77 } |
| 78 | 78 |
| 79 void SetShow3gPromoNotification(bool value) { | 79 void SetShow3gPromoNotification(bool value) { |
| 80 SetBooleanPref(prefs::kShow3gPromoNotification, value); | 80 SetBooleanPref(prefs::kShow3gPromoNotification, value); |
| 81 } | 81 } |
| 82 | 82 |
| 83 // Returns prefs::kCarrierDealPromoShown which is number of times | 83 // Returns prefs::kCarrierDealPromoShown which is number of times |
| 84 // carrier deal notification has been shown to users on this machine. | 84 // carrier deal notification has been shown to users on this machine. |
| 85 int GetCarrierDealPromoShown() { | 85 int GetCarrierDealPromoShown() { |
| 86 return GetIntegerLocalPref(prefs::kCarrierDealPromoShown); | 86 return GetIntegerLocalPref(prefs::kCarrierDealPromoShown); |
| 87 } | 87 } |
| 88 | 88 |
| 89 void SetCarrierDealPromoShown(int value) { | 89 void SetCarrierDealPromoShown(int value) { |
| 90 SetIntegerLocalPref(prefs::kCarrierDealPromoShown, value); | 90 SetIntegerLocalPref(prefs::kCarrierDealPromoShown, value); |
| 91 } | 91 } |
| 92 | 92 |
| 93 const chromeos::MobileConfig::Carrier* GetCarrier( | 93 const chromeos::MobileConfig::Carrier* GetCarrier( |
| 94 const NetworkState* cellular) { | 94 const NetworkState* cellular) { |
| 95 const DeviceState* device = NetworkHandler::Get()->network_state_handler()-> | 95 const DeviceState* device = NetworkHandler::Get()->network_state_handler()-> |
| 96 GetDeviceState(cellular->device_path()); | 96 GetDeviceState(cellular->device_path()); |
| 97 std::string carrier_id = device->home_provider_id(); | 97 std::string carrier_id = device ? device->home_provider_id() : ""; |
| 98 if (carrier_id.empty()) { | 98 if (carrier_id.empty()) { |
| 99 NET_LOG_ERROR("Empty carrier ID with a cellular device", device->path()); | 99 NET_LOG_ERROR("Empty carrier ID for cellular network", |
| 100 device ? device->path(): "No device"); |
| 100 return NULL; | 101 return NULL; |
| 101 } | 102 } |
| 102 | 103 |
| 103 chromeos::MobileConfig* config = chromeos::MobileConfig::GetInstance(); | 104 chromeos::MobileConfig* config = chromeos::MobileConfig::GetInstance(); |
| 104 if (!config->IsReady()) | 105 if (!config->IsReady()) |
| 105 return NULL; | 106 return NULL; |
| 106 | 107 |
| 107 return config->GetCarrier(carrier_id); | 108 return config->GetCarrier(carrier_id); |
| 108 } | 109 } |
| 109 | 110 |
| 110 const chromeos::MobileConfig::CarrierDeal* GetCarrierDeal( | 111 const chromeos::MobileConfig::CarrierDeal* GetCarrierDeal( |
| 111 const chromeos::MobileConfig::Carrier* carrier) { | 112 const chromeos::MobileConfig::Carrier* carrier) { |
| 112 const chromeos::MobileConfig::CarrierDeal* deal = carrier->GetDefaultDeal(); | 113 const chromeos::MobileConfig::CarrierDeal* deal = carrier->GetDefaultDeal(); |
| 113 if (deal) { | 114 if (deal) { |
| 114 // Check deal for validity. | 115 // Check deal for validity. |
| 115 int carrier_deal_promo_pref = GetCarrierDealPromoShown(); | 116 int carrier_deal_promo_pref = GetCarrierDealPromoShown(); |
| 116 if (carrier_deal_promo_pref >= deal->notification_count()) | 117 if (carrier_deal_promo_pref >= deal->notification_count()) |
| 117 return NULL; | 118 return NULL; |
| 118 const std::string locale = g_browser_process->GetApplicationLocale(); | 119 const std::string locale = g_browser_process->GetApplicationLocale(); |
| 119 std::string deal_text = deal->GetLocalizedString(locale, | 120 std::string deal_text = deal->GetLocalizedString(locale, |
| 120 "notification_text"); | 121 "notification_text"); |
| 121 NET_LOG_DEBUG("Carrier Deal Found", deal_text); | 122 NET_LOG_DEBUG("Carrier Deal Found", deal_text); |
| 122 if (deal_text.empty()) | 123 if (deal_text.empty()) |
| 123 return NULL; | 124 return NULL; |
| 124 } | 125 } |
| 125 return deal; | 126 return deal; |
| 126 } | 127 } |
| 127 | 128 |
| 128 ash::NetworkObserver::NetworkType NetworkTypeForNetwork( | 129 void NotificationClicked(const std::string& service_path, |
| 129 const NetworkState* network) { | 130 const std::string& info_url) { |
| 130 DCHECK(network); | 131 if (info_url.empty()) |
| 131 const std::string& technology = network->network_technology(); | 132 ash::network_connect::ShowNetworkSettings(service_path); |
| 132 return (technology == flimflam::kNetworkTechnologyLte || | 133 |
| 133 technology == flimflam::kNetworkTechnologyLteAdvanced) | 134 Browser* browser = chrome::FindOrCreateTabbedBrowser( |
| 134 ? ash::NetworkObserver::NETWORK_CELLULAR_LTE | 135 ProfileManager::GetDefaultProfileOrOffTheRecord(), |
| 135 : ash::NetworkObserver::NETWORK_CELLULAR; | 136 chrome::HOST_DESKTOP_TYPE_ASH); |
| 137 if (!browser) |
| 138 return; |
| 139 chrome::ShowSingletonTab(browser, GURL(info_url)); |
| 136 } | 140 } |
| 137 | 141 |
| 138 } // namespace | 142 } // namespace |
| 139 | 143 |
| 140 //////////////////////////////////////////////////////////////////////////////// | 144 //////////////////////////////////////////////////////////////////////////////// |
| 141 // DataPromoNotification | 145 // DataPromoNotification |
| 142 | 146 |
| 143 DataPromoNotification::DataPromoNotification() | 147 DataPromoNotification::DataPromoNotification() |
| 144 : check_for_promo_(true), | 148 : check_for_promo_(true), |
| 145 cellular_activating_(false), | |
| 146 weak_ptr_factory_(this) { | 149 weak_ptr_factory_(this) { |
| 147 UpdateCellularActivating(); | |
| 148 NetworkHandler::Get()->network_state_handler()->AddObserver(this, FROM_HERE); | 150 NetworkHandler::Get()->network_state_handler()->AddObserver(this, FROM_HERE); |
| 149 } | 151 } |
| 150 | 152 |
| 151 DataPromoNotification::~DataPromoNotification() { | 153 DataPromoNotification::~DataPromoNotification() { |
| 152 if (NetworkHandler::IsInitialized()) { | 154 if (NetworkHandler::IsInitialized()) { |
| 153 NetworkHandler::Get()->network_state_handler()->RemoveObserver( | 155 NetworkHandler::Get()->network_state_handler()->RemoveObserver( |
| 154 this, FROM_HERE); | 156 this, FROM_HERE); |
| 155 } | 157 } |
| 156 CloseNotification(); | |
| 157 } | 158 } |
| 158 | 159 |
| 159 void DataPromoNotification::RegisterPrefs(PrefRegistrySimple* registry) { | 160 void DataPromoNotification::RegisterPrefs(PrefRegistrySimple* registry) { |
| 160 // Carrier deal notification shown count defaults to 0. | 161 // Carrier deal notification shown count defaults to 0. |
| 161 registry->RegisterIntegerPref(prefs::kCarrierDealPromoShown, 0); | 162 registry->RegisterIntegerPref(prefs::kCarrierDealPromoShown, 0); |
| 162 } | 163 } |
| 163 | 164 |
| 164 void DataPromoNotification::NetworkPropertiesUpdated( | 165 void DataPromoNotification::NetworkPropertiesUpdated( |
| 165 const NetworkState* network) { | 166 const NetworkState* network) { |
| 166 if (!network || network->type() != flimflam::kTypeCellular) | 167 if (!network || network->type() != flimflam::kTypeCellular) |
| 167 return; | 168 return; |
| 168 ShowOptionalMobileDataPromoNotification(); | 169 ShowOptionalMobileDataPromoNotification(); |
| 169 UpdateCellularActivating(); | |
| 170 } | 170 } |
| 171 | 171 |
| 172 void DataPromoNotification::DefaultNetworkChanged(const NetworkState* network) { | 172 void DataPromoNotification::DefaultNetworkChanged(const NetworkState* network) { |
| 173 // Call NetworkPropertiesUpdated in case the Cellular network became the | 173 // Call NetworkPropertiesUpdated in case the Cellular network became the |
| 174 // default network. | 174 // default network. |
| 175 NetworkPropertiesUpdated(network); | 175 NetworkPropertiesUpdated(network); |
| 176 } | 176 } |
| 177 | 177 |
| 178 void DataPromoNotification::NotificationLinkClicked( | |
| 179 ash::NetworkObserver::MessageType message_type, | |
| 180 size_t link_index) { | |
| 181 const NetworkState* cellular = | |
| 182 NetworkHandler::Get()->network_state_handler()-> | |
| 183 FirstNetworkByType(flimflam::kTypeCellular); | |
| 184 std::string service_path = cellular ? cellular->path() : ""; | |
| 185 if (message_type == ash::NetworkObserver::ERROR_OUT_OF_CREDITS) { | |
| 186 ash::network_connect::ShowNetworkSettings(service_path); | |
| 187 ash::Shell::GetInstance()->system_tray_notifier()-> | |
| 188 NotifyClearNetworkMessage(message_type); | |
| 189 } | |
| 190 if (message_type != ash::NetworkObserver::MESSAGE_DATA_PROMO) | |
| 191 return; | |
| 192 | |
| 193 // If we have a deal info URL defined that means that there are | |
| 194 // two links in the bubble. Let the user close it manually then giving the | |
| 195 // ability to navigate to the second link. | |
| 196 if (deal_info_url_.empty()) | |
| 197 CloseNotification(); | |
| 198 | |
| 199 std::string deal_url_to_open; | |
| 200 if (link_index == 0) { | |
| 201 if (!deal_topup_url_.empty()) { | |
| 202 deal_url_to_open = deal_topup_url_; | |
| 203 } else { | |
| 204 ash::network_connect::ShowNetworkSettings(service_path); | |
| 205 return; | |
| 206 } | |
| 207 } else if (link_index == 1) { | |
| 208 deal_url_to_open = deal_info_url_; | |
| 209 } | |
| 210 | |
| 211 if (!deal_url_to_open.empty()) { | |
| 212 Browser* browser = chrome::FindOrCreateTabbedBrowser( | |
| 213 ProfileManager::GetDefaultProfileOrOffTheRecord(), | |
| 214 chrome::HOST_DESKTOP_TYPE_ASH); | |
| 215 if (!browser) | |
| 216 return; | |
| 217 chrome::ShowSingletonTab(browser, GURL(deal_url_to_open)); | |
| 218 } | |
| 219 } | |
| 220 | |
| 221 void DataPromoNotification::UpdateCellularActivating() { | |
| 222 // We only care about the first (default) cellular network. | |
| 223 const NetworkState* cellular = | |
| 224 NetworkHandler::Get()->network_state_handler()-> | |
| 225 FirstNetworkByType(flimflam::kTypeCellular); | |
| 226 if (!cellular) | |
| 227 return; | |
| 228 | |
| 229 std::string activation_state = cellular->activation_state(); | |
| 230 if (activation_state == flimflam::kActivationStateActivating) { | |
| 231 cellular_activating_ = true; | |
| 232 } else if (cellular_activating_ && | |
| 233 activation_state == flimflam::kActivationStateActivated) { | |
| 234 cellular_activating_ = false; | |
| 235 ash::Shell::GetInstance()->system_tray_notifier()-> | |
| 236 NotifySetNetworkMessage( | |
| 237 NULL, | |
| 238 ash::NetworkObserver::MESSAGE_DATA_PROMO, | |
| 239 NetworkTypeForNetwork(cellular), | |
| 240 l10n_util::GetStringUTF16(IDS_NETWORK_CELLULAR_ACTIVATED_TITLE), | |
| 241 l10n_util::GetStringFUTF16(IDS_NETWORK_CELLULAR_ACTIVATED, | |
| 242 UTF8ToUTF16((cellular->name()))), | |
| 243 std::vector<string16>()); | |
| 244 } | |
| 245 } | |
| 246 | |
| 247 void DataPromoNotification::ShowOptionalMobileDataPromoNotification() { | 178 void DataPromoNotification::ShowOptionalMobileDataPromoNotification() { |
| 248 // Display a one-time notification for authenticated users on first use | 179 // Display a one-time notification for authenticated users on first use |
| 249 // of Mobile Data connection or if there is a carrier deal defined | 180 // of Mobile Data connection or if there is a carrier deal defined |
| 250 // show that even if user has already seen generic promo. | 181 // show that even if user has already seen generic promo. |
| 251 if (!check_for_promo_ || !LoginState::Get()->IsUserAuthenticated()) | 182 if (!check_for_promo_ || !LoginState::Get()->IsUserAuthenticated()) |
| 252 return; | 183 return; |
| 253 const NetworkState* default_network = | 184 const NetworkState* default_network = |
| 254 NetworkHandler::Get()->network_state_handler()->DefaultNetwork(); | 185 NetworkHandler::Get()->network_state_handler()->DefaultNetwork(); |
| 255 if (!default_network || default_network->type() != flimflam::kTypeCellular) | 186 if (!default_network || default_network->type() != flimflam::kTypeCellular) |
| 256 return; | 187 return; |
| 257 // When requesting a network connection, do not show the notification. | 188 // When requesting a network connection, do not show the notification. |
| 258 if (NetworkHandler::Get()->network_connection_handler()-> | 189 if (NetworkHandler::Get()->network_connection_handler()-> |
| 259 HasPendingConnectRequest()) | 190 HasPendingConnectRequest()) |
| 260 return; | 191 return; |
| 261 | 192 |
| 262 std::string deal_text; | |
| 263 int carrier_deal_promo_pref = kNotificationCountPrefDefault; | 193 int carrier_deal_promo_pref = kNotificationCountPrefDefault; |
| 264 const MobileConfig::CarrierDeal* deal = NULL; | 194 const MobileConfig::CarrierDeal* deal = NULL; |
| 265 const MobileConfig::Carrier* carrier = GetCarrier(default_network); | 195 const MobileConfig::Carrier* carrier = GetCarrier(default_network); |
| 266 if (carrier) | 196 if (carrier) |
| 267 deal = GetCarrierDeal(carrier); | 197 deal = GetCarrierDeal(carrier); |
| 268 deal_info_url_.clear(); | 198 |
| 269 deal_topup_url_.clear(); | 199 string16 message = l10n_util::GetStringUTF16(IDS_3G_NOTIFICATION_MESSAGE); |
| 200 std::string info_url; |
| 270 if (deal) { | 201 if (deal) { |
| 271 carrier_deal_promo_pref = GetCarrierDealPromoShown(); | 202 carrier_deal_promo_pref = GetCarrierDealPromoShown(); |
| 272 const std::string locale = g_browser_process->GetApplicationLocale(); | 203 const std::string locale = g_browser_process->GetApplicationLocale(); |
| 273 deal_text = deal->GetLocalizedString(locale, "notification_text"); | 204 std::string deal_text = |
| 274 deal_info_url_ = deal->info_url(); | 205 deal->GetLocalizedString(locale, "notification_text"); |
| 275 deal_topup_url_ = carrier->top_up_url(); | 206 message = UTF8ToUTF16(deal_text + "\n\n") + message; |
| 207 info_url = deal->info_url(); |
| 208 if (info_url.empty() && carrier) |
| 209 info_url = carrier->top_up_url(); |
| 276 } else if (!ShouldShow3gPromoNotification()) { | 210 } else if (!ShouldShow3gPromoNotification()) { |
| 277 check_for_promo_ = false; | 211 check_for_promo_ = false; |
| 278 return; | 212 return; |
| 279 } | 213 } |
| 280 | 214 |
| 281 string16 message = l10n_util::GetStringUTF16(IDS_3G_NOTIFICATION_MESSAGE); | 215 int icon_id; |
| 282 if (!deal_text.empty()) | 216 if (default_network->network_technology() == flimflam::kNetworkTechnologyLte) |
| 283 message = UTF8ToUTF16(deal_text + "\n\n") + message; | 217 icon_id = IDR_AURA_UBER_TRAY_NOTIFICATION_LTE; |
| 218 else |
| 219 icon_id = IDR_AURA_UBER_TRAY_NOTIFICATION_3G; |
| 220 const gfx::Image& icon = |
| 221 ui::ResourceBundle::GetSharedInstance().GetImageNamed(icon_id); |
| 284 | 222 |
| 285 // Use deal URL if it's defined or general "Network Settings" URL. | 223 message_center::MessageCenter::Get()->AddNotification( |
| 286 int link_message_id; | 224 message_center::Notification::CreateSystemNotification( |
| 287 if (deal_topup_url_.empty()) | 225 ash::network_connect::kNetworkActivateNotificationId, |
| 288 link_message_id = IDS_OFFLINE_NETWORK_SETTINGS; | 226 base::string16() /* title */, |
| 289 else | 227 message, |
| 290 link_message_id = IDS_STATUSBAR_NETWORK_VIEW_ACCOUNT; | 228 icon, |
| 229 base::Bind(&NotificationClicked, |
| 230 default_network->path(), info_url))); |
| 291 | 231 |
| 292 ash::NetworkObserver::NetworkType type = | |
| 293 NetworkTypeForNetwork(default_network); | |
| 294 | |
| 295 std::vector<string16> links; | |
| 296 links.push_back(l10n_util::GetStringUTF16(link_message_id)); | |
| 297 if (!deal_info_url_.empty()) | |
| 298 links.push_back(l10n_util::GetStringUTF16(IDS_LEARN_MORE)); | |
| 299 ash::Shell::GetInstance()->system_tray_notifier()->NotifySetNetworkMessage( | |
| 300 this, ash::NetworkObserver::MESSAGE_DATA_PROMO, | |
| 301 type, string16(), message, links); | |
| 302 check_for_promo_ = false; | 232 check_for_promo_ = false; |
| 303 SetShow3gPromoNotification(false); | 233 SetShow3gPromoNotification(false); |
| 304 if (carrier_deal_promo_pref != kNotificationCountPrefDefault) | 234 if (carrier_deal_promo_pref != kNotificationCountPrefDefault) |
| 305 SetCarrierDealPromoShown(carrier_deal_promo_pref + 1); | 235 SetCarrierDealPromoShown(carrier_deal_promo_pref + 1); |
| 306 } | 236 } |
| 307 | 237 |
| 308 void DataPromoNotification::CloseNotification() { | |
| 309 ash::Shell::GetInstance()->system_tray_notifier()->NotifyClearNetworkMessage( | |
| 310 ash::NetworkObserver::MESSAGE_DATA_PROMO); | |
| 311 } | |
| 312 | |
| 313 } // namespace chromeos | 238 } // namespace chromeos |
| OLD | NEW |