| Index: ui/app_list/app_list_menu.cc
|
| diff --git a/ui/app_list/app_list_menu.cc b/ui/app_list/app_list_menu.cc
|
| index 95d6ac38d91b3acc2f6355b56a68e241dd00d953..8546da3c891928b3b917d65e2633fa183a056c37 100644
|
| --- a/ui/app_list/app_list_menu.cc
|
| +++ b/ui/app_list/app_list_menu.cc
|
| @@ -4,6 +4,7 @@
|
|
|
| #include "ui/app_list/app_list_menu.h"
|
|
|
| +#include "grit/ui_resources.h"
|
| #include "grit/ui_strings.h"
|
| #include "ui/app_list/app_list_view_delegate.h"
|
| #include "ui/base/l10n/l10n_util.h"
|
| @@ -12,17 +13,40 @@
|
|
|
| namespace app_list {
|
|
|
| -AppListMenu::AppListMenu(AppListViewDelegate* delegate)
|
| +AppListMenu::AppListMenu(AppListViewDelegate* delegate,
|
| + const AppListModel::Users& users)
|
| : menu_model_(this),
|
| - delegate_(delegate) {
|
| + delegate_(delegate),
|
| + users_(users) {
|
| InitMenu();
|
| }
|
|
|
| AppListMenu::~AppListMenu() {}
|
|
|
| void AppListMenu::InitMenu() {
|
| - menu_model_.AddItem(CURRENT_USER, base::string16());
|
| - menu_model_.AddSeparator(ui::NORMAL_SEPARATOR);
|
| + // User selector menu section. We don't show the user selector if there is
|
| + // only 1 user.
|
| + if (users_.size() > 1) {
|
| + for (size_t i = 0; i < users_.size(); ++i) {
|
| +#if defined(OS_MACOSX)
|
| + menu_model_.AddRadioItem(SELECT_PROFILE + i,
|
| + users_[i].email.empty() ? users_[i].name
|
| + : users_[i].email,
|
| + 0 /* group_id */);
|
| +#elif defined(OS_WIN)
|
| + menu_model_.AddItem(SELECT_PROFILE + i, users_[i].name);
|
| + int menu_index = menu_model_.GetIndexOfCommandId(SELECT_PROFILE + i);
|
| + menu_model_.SetSublabel(menu_index, users_[i].email);
|
| + // Use custom check mark.
|
| + if (users_[i].active) {
|
| + ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance();
|
| + menu_model_.SetIcon(menu_index, gfx::Image(*rb.GetImageSkiaNamed(
|
| + IDR_APP_LIST_USER_INDICATOR)));
|
| + }
|
| +#endif
|
| + }
|
| + menu_model_.AddSeparator(ui::NORMAL_SEPARATOR);
|
| + }
|
|
|
| menu_model_.AddItem(SHOW_SETTINGS, l10n_util::GetStringUTF16(
|
| IDS_APP_LIST_OPEN_SETTINGS));
|
| @@ -35,7 +59,12 @@ void AppListMenu::InitMenu() {
|
| }
|
|
|
| bool AppListMenu::IsCommandIdChecked(int command_id) const {
|
| +#if defined(OS_MACOSX)
|
| + DCHECK_LT(static_cast<unsigned>(command_id) - SELECT_PROFILE, users_.size());
|
| + return users_[command_id - SELECT_PROFILE].active;
|
| +#else
|
| return false;
|
| +#endif
|
| }
|
|
|
| bool AppListMenu::IsCommandIdEnabled(int command_id) const {
|
| @@ -48,6 +77,11 @@ bool AppListMenu::GetAcceleratorForCommandId(int command_id,
|
| }
|
|
|
| void AppListMenu::ExecuteCommand(int command_id, int event_flags) {
|
| + if (command_id >= SELECT_PROFILE) {
|
| + delegate_->ShowForProfileByPath(
|
| + users_[command_id - SELECT_PROFILE].profile_path);
|
| + return;
|
| + }
|
| switch (command_id) {
|
| case CURRENT_USER:
|
| break; // Do nothing.
|
|
|