Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(240)

Side by Side Diff: chrome/browser/ui/app_list/app_list_view_delegate.cc

Issue 20656002: Add profile selector menu to app list. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rework Created 7 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/ui/app_list/app_list_view_delegate.h" 5 #include "chrome/browser/ui/app_list/app_list_view_delegate.h"
6 6
7 #include <vector>
8
7 #include "base/callback.h" 9 #include "base/callback.h"
8 #include "base/files/file_path.h" 10 #include "base/files/file_path.h"
11 #include "base/stl_util.h"
9 #include "chrome/browser/browser_process.h" 12 #include "chrome/browser/browser_process.h"
10 #include "chrome/browser/chrome_notification_types.h" 13 #include "chrome/browser/chrome_notification_types.h"
11 #include "chrome/browser/extensions/extension_service.h" 14 #include "chrome/browser/extensions/extension_service.h"
12 #include "chrome/browser/feedback/feedback_util.h" 15 #include "chrome/browser/feedback/feedback_util.h"
16 #include "chrome/browser/profiles/profile_info_cache.h"
13 #include "chrome/browser/profiles/profile_manager.h" 17 #include "chrome/browser/profiles/profile_manager.h"
14 #include "chrome/browser/ui/app_list/app_list_controller_delegate.h" 18 #include "chrome/browser/ui/app_list/app_list_controller_delegate.h"
15 #include "chrome/browser/ui/app_list/apps_model_builder.h" 19 #include "chrome/browser/ui/app_list/apps_model_builder.h"
16 #include "chrome/browser/ui/app_list/chrome_app_list_item.h" 20 #include "chrome/browser/ui/app_list/chrome_app_list_item.h"
17 #include "chrome/browser/ui/app_list/chrome_signin_delegate.h" 21 #include "chrome/browser/ui/app_list/chrome_signin_delegate.h"
18 #include "chrome/browser/ui/app_list/search/search_controller.h" 22 #include "chrome/browser/ui/app_list/search/search_controller.h"
19 #include "chrome/browser/ui/browser_finder.h" 23 #include "chrome/browser/ui/browser_finder.h"
20 #include "chrome/browser/ui/chrome_pages.h" 24 #include "chrome/browser/ui/chrome_pages.h"
21 #include "chrome/browser/ui/host_desktop.h" 25 #include "chrome/browser/ui/host_desktop.h"
22 #include "chrome/browser/ui/web_applications/web_app_ui.h" 26 #include "chrome/browser/ui/web_applications/web_app_ui.h"
23 #include "chrome/browser/web_applications/web_app.h" 27 #include "chrome/browser/web_applications/web_app.h"
24 #include "chrome/common/extensions/extension_constants.h" 28 #include "chrome/common/extensions/extension_constants.h"
25 #include "chrome/common/url_constants.h" 29 #include "chrome/common/url_constants.h"
26 #include "content/public/browser/browser_thread.h" 30 #include "content/public/browser/browser_thread.h"
27 #include "content/public/browser/notification_source.h" 31 #include "content/public/browser/notification_source.h"
28 #include "content/public/browser/page_navigator.h" 32 #include "content/public/browser/page_navigator.h"
29 #include "content/public/browser/user_metrics.h" 33 #include "content/public/browser/user_metrics.h"
34 #include "ui/app_list/search_box_model.h"
30 35
31 #if defined(USE_ASH) 36 #if defined(USE_ASH)
32 #include "chrome/browser/ui/ash/app_list/app_sync_ui_state_watcher.h" 37 #include "chrome/browser/ui/ash/app_list/app_sync_ui_state_watcher.h"
33 #endif 38 #endif
34 39
35 #if defined(OS_WIN) 40 #if defined(OS_WIN)
36 #include "chrome/browser/web_applications/web_app_win.h" 41 #include "chrome/browser/web_applications/web_app_win.h"
37 #endif 42 #endif
38 43
39 namespace { 44 namespace {
40 45
41 #if defined(OS_WIN) 46 #if defined(OS_WIN)
42 void CreateShortcutInWebAppDir( 47 void CreateShortcutInWebAppDir(
43 const base::FilePath& app_data_dir, 48 const base::FilePath& app_data_dir,
44 base::Callback<void(const base::FilePath&)> callback, 49 base::Callback<void(const base::FilePath&)> callback,
45 const ShellIntegration::ShortcutInfo& info) { 50 const ShellIntegration::ShortcutInfo& info) {
46 content::BrowserThread::PostTaskAndReplyWithResult( 51 content::BrowserThread::PostTaskAndReplyWithResult(
47 content::BrowserThread::FILE, 52 content::BrowserThread::FILE,
48 FROM_HERE, 53 FROM_HERE,
49 base::Bind(web_app::CreateShortcutInWebAppDir, app_data_dir, info), 54 base::Bind(web_app::CreateShortcutInWebAppDir, app_data_dir, info),
50 callback); 55 callback);
51 } 56 }
52 #endif 57 #endif
53 58
59 void PopulateUsers(const ProfileInfoCache& profile_info,
60 const base::FilePath& active_profile_path,
61 app_list::AppListModel::Users* users) {
62 const size_t count = profile_info.GetNumberOfProfiles();
63 for (size_t i = 0; i < count; ++i) {
64 app_list::AppListModel::User user;
65 user.name = profile_info.GetNameOfProfileAtIndex(i);
66 user.email = profile_info.GetUserNameOfProfileAtIndex(i);
67 user.profile_path = profile_info.GetPathOfProfileAtIndex(i);
68 user.active = active_profile_path == user.profile_path;
69 users->push_back(user);
70 }
71 }
72
54 } // namespace 73 } // namespace
55 74
56 AppListViewDelegate::AppListViewDelegate(AppListControllerDelegate* controller, 75 AppListViewDelegate::AppListViewDelegate(AppListControllerDelegate* controller,
57 Profile* profile) 76 Profile* profile)
58 : controller_(controller), 77 : controller_(controller),
59 profile_(profile), 78 profile_(profile),
60 model_(NULL) { 79 model_(NULL) {
61 DCHECK(profile_); 80 RegisterForNotifications();
62 registrar_.Add(this, chrome::NOTIFICATION_GOOGLE_SIGNIN_SUCCESSFUL,
63 content::Source<Profile>(profile_));
64 registrar_.Add(this, chrome::NOTIFICATION_GOOGLE_SIGNIN_FAILED,
65 content::Source<Profile>(profile_));
66 registrar_.Add(this, chrome::NOTIFICATION_GOOGLE_SIGNED_OUT,
67 content::Source<Profile>(profile_));
68 g_browser_process->profile_manager()->GetProfileInfoCache().AddObserver(this); 81 g_browser_process->profile_manager()->GetProfileInfoCache().AddObserver(this);
69 } 82 }
70 83
71 AppListViewDelegate::~AppListViewDelegate() { 84 AppListViewDelegate::~AppListViewDelegate() {
72 g_browser_process-> 85 g_browser_process->
73 profile_manager()->GetProfileInfoCache().RemoveObserver(this); 86 profile_manager()->GetProfileInfoCache().RemoveObserver(this);
74 } 87 }
75 88
76 void AppListViewDelegate::OnProfileChanged() { 89 void AppListViewDelegate::RegisterForNotifications() {
77 model_->SetSignedIn(!signin_delegate_->NeedSignin()); 90 registrar_.RemoveAll();
78 ProfileInfoCache& cache = 91 DCHECK(profile_);
79 g_browser_process->profile_manager()->GetProfileInfoCache();
80 // Populate the current user details.
81 size_t profile_index = cache.GetIndexOfProfileWithPath(profile_->GetPath());
82 // The profile won't exist in the cache if the current app list profile is
83 // being deleted.
84 if (profile_index == std::string::npos)
85 return;
86 92
87 model_->SetCurrentUser(cache.GetNameOfProfileAtIndex(profile_index), 93 registrar_.Add(this, chrome::NOTIFICATION_GOOGLE_SIGNIN_SUCCESSFUL,
88 cache.GetUserNameOfProfileAtIndex(profile_index)); 94 content::Source<Profile>(profile_));
95 registrar_.Add(this, chrome::NOTIFICATION_GOOGLE_SIGNIN_FAILED,
96 content::Source<Profile>(profile_));
97 registrar_.Add(this, chrome::NOTIFICATION_GOOGLE_SIGNED_OUT,
98 content::Source<Profile>(profile_));
89 } 99 }
90 100
91 void AppListViewDelegate::SetModel(app_list::AppListModel* model) { 101 void AppListViewDelegate::OnProfileChanged() {
92 if (model) { 102 model_->SetSignedIn(!GetSigninDelegate()->NeedSignin());
93 model_ = model;
94 apps_builder_.reset(new AppsModelBuilder(profile_,
95 model->apps(),
96 controller_.get()));
97 apps_builder_->Build();
98 103
99 search_controller_.reset(new app_list::SearchController( 104 // Populate the app list users.
100 profile_, model->search_box(), model->results(), controller_.get())); 105 app_list::AppListModel::Users users;
106 PopulateUsers(g_browser_process->profile_manager()->GetProfileInfoCache(),
107 profile_->GetPath(), &users);
108 model_->SetUsers(users);
109 }
101 110
102 signin_delegate_.reset(new ChromeSigninDelegate(profile_)); 111 void AppListViewDelegate::SetProfileByPath(const base::FilePath& profile_path) {
112 DCHECK(model_);
113
114 // The profile must be loaded before this is called.
115 profile_ =
116 g_browser_process->profile_manager()->GetProfileByPath(profile_path);
117 DCHECK(profile_);
118
119 RegisterForNotifications();
120
121 apps_builder_->SwitchProfile(profile_);
122
123 search_controller_.reset(new app_list::SearchController(
124 profile_, model_->search_box(), model_->results(), controller_.get()));
125
126 signin_delegate_->SetProfile(profile_);
103 127
104 #if defined(USE_ASH) 128 #if defined(USE_ASH)
105 app_sync_ui_state_watcher_.reset(new AppSyncUIStateWatcher(profile_, 129 app_sync_ui_state_watcher_.reset(new AppSyncUIStateWatcher(profile_,
106 model)); 130 model_));
107 #endif 131 #endif
108 OnProfileChanged(); 132 OnProfileChanged();
109 } else { 133
110 model_ = NULL; 134 // Update search results to show results for new profile.
111 apps_builder_.reset(); 135 if (!model_->search_box()->text().empty())
112 search_controller_.reset(); 136 StartSearch();
113 signin_delegate_.reset(); 137 }
138
139 void AppListViewDelegate::InitModel(app_list::AppListModel* model) {
140 DCHECK(!model_);
141 DCHECK(model);
142 model_ = model;
143
144 // Initialize apps model.
145 apps_builder_.reset(new AppsModelBuilder(profile_,
146 model->apps(),
147 controller_.get()));
148
149 search_controller_.reset(new app_list::SearchController(
150 profile_, model->search_box(), model->results(), controller_.get()));
151
152 signin_delegate_.reset(new ChromeSigninDelegate(profile_));
153
114 #if defined(USE_ASH) 154 #if defined(USE_ASH)
115 app_sync_ui_state_watcher_.reset(); 155 app_sync_ui_state_watcher_.reset(new AppSyncUIStateWatcher(profile_,
156 model));
116 #endif 157 #endif
117 } 158 // Initialize the profile information in the app list menu.
159 OnProfileChanged();
118 } 160 }
119 161
120 app_list::SigninDelegate* AppListViewDelegate::GetSigninDelegate() { 162 app_list::SigninDelegate* AppListViewDelegate::GetSigninDelegate() {
121 return signin_delegate_.get(); 163 return signin_delegate_.get();
122 } 164 }
123 165
124 void AppListViewDelegate::ActivateAppListItem( 166 void AppListViewDelegate::ActivateAppListItem(
125 app_list::AppListItemModel* item, 167 app_list::AppListItemModel* item,
126 int event_flags) { 168 int event_flags) {
127 content::RecordAction(content::UserMetricsAction("AppList_ClickOnApp")); 169 content::RecordAction(content::UserMetricsAction("AppList_ClickOnApp"));
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after
213 255
214 void AppListViewDelegate::OpenFeedback() { 256 void AppListViewDelegate::OpenFeedback() {
215 chrome::HostDesktopType desktop = chrome::GetHostDesktopTypeForNativeWindow( 257 chrome::HostDesktopType desktop = chrome::GetHostDesktopTypeForNativeWindow(
216 controller_->GetAppListWindow()); 258 controller_->GetAppListWindow());
217 Browser* browser = chrome::FindOrCreateTabbedBrowser( 259 Browser* browser = chrome::FindOrCreateTabbedBrowser(
218 profile_, desktop); 260 profile_, desktop);
219 chrome::ShowFeedbackPage(browser, std::string(), 261 chrome::ShowFeedbackPage(browser, std::string(),
220 chrome::kAppLauncherCategoryTag); 262 chrome::kAppLauncherCategoryTag);
221 } 263 }
222 264
265 void AppListViewDelegate::ShowForProfileByPath(
266 const base::FilePath& profile_path) {
267 controller_->ShowForProfileByPath(profile_path);
268 }
269
223 void AppListViewDelegate::Observe( 270 void AppListViewDelegate::Observe(
224 int type, 271 int type,
225 const content::NotificationSource& source, 272 const content::NotificationSource& source,
226 const content::NotificationDetails& details) { 273 const content::NotificationDetails& details) {
227 OnProfileChanged(); 274 OnProfileChanged();
228 } 275 }
229 276
277 void AppListViewDelegate::OnProfileAdded(const base::FilePath& profile_path) {
278 OnProfileChanged();
279 }
280
230 void AppListViewDelegate::OnProfileNameChanged( 281 void AppListViewDelegate::OnProfileNameChanged(
231 const base::FilePath& profile_path, 282 const base::FilePath& profile_path,
232 const base::string16& old_profile_name) { 283 const base::string16& old_profile_name) {
233 if (profile_->GetPath() != profile_path)
234 return;
xiyuan 2013/09/11 05:01:49 Why is this not needed?
calamity 2013/09/13 18:02:35 We need to remove this so that the menu updates on
235
236 OnProfileChanged(); 284 OnProfileChanged();
237 } 285 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698