| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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/arc/arc_play_store_enabled_preference_handler.
h" | 5 #include "chrome/browser/chromeos/arc/arc_play_store_enabled_preference_handler.
h" |
| 6 | 6 |
| 7 #include "ash/shelf/shelf_model.h" | |
| 8 #include "ash/shell.h" | |
| 9 #include "base/bind.h" | 7 #include "base/bind.h" |
| 10 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 11 #include "base/logging.h" | 9 #include "base/logging.h" |
| 12 #include "chrome/browser/chromeos/arc/arc_auth_notification.h" | 10 #include "chrome/browser/chromeos/arc/arc_auth_notification.h" |
| 13 #include "chrome/browser/chromeos/arc/arc_optin_uma.h" | 11 #include "chrome/browser/chromeos/arc/arc_optin_uma.h" |
| 14 #include "chrome/browser/chromeos/arc/arc_session_manager.h" | 12 #include "chrome/browser/chromeos/arc/arc_session_manager.h" |
| 15 #include "chrome/browser/chromeos/arc/arc_util.h" | 13 #include "chrome/browser/chromeos/arc/arc_util.h" |
| 16 #include "chrome/browser/prefs/pref_service_syncable_util.h" | 14 #include "chrome/browser/prefs/pref_service_syncable_util.h" |
| 17 #include "chrome/browser/profiles/profile.h" | 15 #include "chrome/browser/profiles/profile.h" |
| 18 #include "chrome/browser/ui/app_list/arc/arc_app_utils.h" | 16 #include "chrome/browser/ui/app_list/arc/arc_app_utils.h" |
| 17 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller.h" |
| 19 #include "chrome/common/pref_names.h" | 18 #include "chrome/common/pref_names.h" |
| 20 #include "chromeos/chromeos_switches.h" | 19 #include "chromeos/chromeos_switches.h" |
| 21 #include "components/arc/arc_util.h" | 20 #include "components/arc/arc_util.h" |
| 22 #include "components/sync_preferences/pref_service_syncable.h" | 21 #include "components/sync_preferences/pref_service_syncable.h" |
| 23 #include "content/public/browser/browser_thread.h" | 22 #include "content/public/browser/browser_thread.h" |
| 24 | 23 |
| 25 namespace arc { | 24 namespace arc { |
| 26 | 25 |
| 27 ArcPlayStoreEnabledPreferenceHandler::ArcPlayStoreEnabledPreferenceHandler( | 26 ArcPlayStoreEnabledPreferenceHandler::ArcPlayStoreEnabledPreferenceHandler( |
| 28 Profile* profile, | 27 Profile* profile, |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 75 arc_session_manager_->RequestArcDataRemoval(); | 74 arc_session_manager_->RequestArcDataRemoval(); |
| 76 } | 75 } |
| 77 | 76 |
| 78 // ArcAuthNotification may need to be shown. | 77 // ArcAuthNotification may need to be shown. |
| 79 PrefServiceSyncableFromProfile(profile_)->AddObserver(this); | 78 PrefServiceSyncableFromProfile(profile_)->AddObserver(this); |
| 80 OnIsSyncingChanged(); | 79 OnIsSyncingChanged(); |
| 81 } | 80 } |
| 82 | 81 |
| 83 void ArcPlayStoreEnabledPreferenceHandler::OnPreferenceChanged() { | 82 void ArcPlayStoreEnabledPreferenceHandler::OnPreferenceChanged() { |
| 84 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | 83 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| 85 | |
| 86 const bool is_play_store_enabled = IsArcPlayStoreEnabledForProfile(profile_); | 84 const bool is_play_store_enabled = IsArcPlayStoreEnabledForProfile(profile_); |
| 87 if (!IsArcPlayStoreEnabledPreferenceManagedForProfile(profile_)) { | 85 if (!IsArcPlayStoreEnabledPreferenceManagedForProfile(profile_)) { |
| 88 // Update UMA only for non-Managed cases. | 86 // Update UMA only for non-Managed cases. |
| 89 UpdateOptInActionUMA(is_play_store_enabled ? OptInActionType::OPTED_IN | 87 UpdateOptInActionUMA(is_play_store_enabled ? OptInActionType::OPTED_IN |
| 90 : OptInActionType::OPTED_OUT); | 88 : OptInActionType::OPTED_OUT); |
| 91 | 89 |
| 92 if (!is_play_store_enabled) { | 90 if (!is_play_store_enabled) { |
| 93 // Remove the pinned Play Store icon launcher in Shelf. | 91 // Remove the pinned Play Store icon launcher in Shelf. |
| 94 // This is only for non-Managed cases. In managed cases, it is expected | 92 // This is only for non-Managed cases. In managed cases, it is expected |
| 95 // to be "disabled" rather than "removed", so keep it here. | 93 // to be "disabled" rather than "removed", so keep it here. |
| 96 auto* shelf_model = ash::Shell::HasInstance() | 94 auto* chrome_launcher_controller = ChromeLauncherController::instance(); |
| 97 ? ash::Shell::Get()->shelf_model() | 95 if (chrome_launcher_controller) |
| 98 : nullptr; | 96 chrome_launcher_controller->UnpinAppWithID(kPlayStoreAppId); |
| 99 if (shelf_model) | |
| 100 shelf_model->UnpinAppWithID(kPlayStoreAppId); | |
| 101 } | 97 } |
| 102 } | 98 } |
| 103 | 99 |
| 104 // Hide auth notification if it was opened before and arc.enabled pref was | 100 // Hide auth notification if it was opened before and arc.enabled pref was |
| 105 // explicitly set to true or false. | 101 // explicitly set to true or false. |
| 106 if (profile_->GetPrefs()->HasPrefPath(prefs::kArcEnabled)) | 102 if (profile_->GetPrefs()->HasPrefPath(prefs::kArcEnabled)) |
| 107 ArcAuthNotification::Hide(); | 103 ArcAuthNotification::Hide(); |
| 108 | 104 |
| 109 UpdateArcSessionManager(); | 105 UpdateArcSessionManager(); |
| 110 | 106 |
| (...skipping 26 matching lines...) Expand all Loading... |
| 137 // TODO(hidehiko): Extract kEnableArcOOBEOptIn check as a utility method. | 133 // TODO(hidehiko): Extract kEnableArcOOBEOptIn check as a utility method. |
| 138 if (!base::CommandLine::ForCurrentProcess()->HasSwitch( | 134 if (!base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 139 chromeos::switches::kEnableArcOOBEOptIn) && | 135 chromeos::switches::kEnableArcOOBEOptIn) && |
| 140 profile_->IsNewProfile() && | 136 profile_->IsNewProfile() && |
| 141 !profile_->GetPrefs()->HasPrefPath(prefs::kArcEnabled)) { | 137 !profile_->GetPrefs()->HasPrefPath(prefs::kArcEnabled)) { |
| 142 ArcAuthNotification::Show(profile_); | 138 ArcAuthNotification::Show(profile_); |
| 143 } | 139 } |
| 144 } | 140 } |
| 145 | 141 |
| 146 } // namespace arc | 142 } // namespace arc |
| OLD | NEW |