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 |