| 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 "ash/system/user/tray_user.h" | 5 #include "ash/system/user/tray_user.h" |
| 6 | 6 |
| 7 #include "ash/common/ash_switches.h" | 7 #include "ash/common/ash_switches.h" |
| 8 #include "ash/common/session/session_state_delegate.h" | 8 #include "ash/common/session/session_state_delegate.h" |
| 9 #include "ash/common/shelf/wm_shelf_util.h" | 9 #include "ash/common/shelf/wm_shelf_util.h" |
| 10 #include "ash/common/system/tray/system_tray_delegate.h" | 10 #include "ash/common/system/tray/system_tray_delegate.h" |
| (...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 152 (need_label != (label_ != nullptr))) { | 152 (need_label != (label_ != nullptr))) { |
| 153 layout_view_->RemoveAllChildViews(true); | 153 layout_view_->RemoveAllChildViews(true); |
| 154 if (need_label) { | 154 if (need_label) { |
| 155 label_ = new views::Label; | 155 label_ = new views::Label; |
| 156 SetupLabelForTray(label_); | 156 SetupLabelForTray(label_); |
| 157 layout_view_->AddChildView(label_); | 157 layout_view_->AddChildView(label_); |
| 158 } else { | 158 } else { |
| 159 label_ = nullptr; | 159 label_ = nullptr; |
| 160 } | 160 } |
| 161 if (need_avatar) { | 161 if (need_avatar) { |
| 162 avatar_ = new tray::RoundedImageView(kTrayAvatarCornerRadius, true); | 162 avatar_ = new tray::RoundedImageView(kTrayRoundedBorderRadius, true); |
| 163 layout_view_->AddChildView(avatar_); | 163 layout_view_->AddChildView(avatar_); |
| 164 } else { | 164 } else { |
| 165 avatar_ = nullptr; | 165 avatar_ = nullptr; |
| 166 } | 166 } |
| 167 } | 167 } |
| 168 | 168 |
| 169 if (delegate->IsUserSupervised()) { | 169 if (delegate->IsUserSupervised()) { |
| 170 label_->SetText( | 170 label_->SetText( |
| 171 l10n_util::GetStringUTF16(IDS_ASH_STATUS_TRAY_SUPERVISED_LABEL)); | 171 l10n_util::GetStringUTF16(IDS_ASH_STATUS_TRAY_SUPERVISED_LABEL)); |
| 172 } else if (status == LoginStatus::GUEST) { | 172 } else if (status == LoginStatus::GUEST) { |
| 173 label_->SetText(l10n_util::GetStringUTF16(IDS_ASH_STATUS_TRAY_GUEST_LABEL)); | 173 label_->SetText(l10n_util::GetStringUTF16(IDS_ASH_STATUS_TRAY_GUEST_LABEL)); |
| 174 } | 174 } |
| 175 | 175 |
| 176 if (avatar_) { | 176 if (avatar_) { |
| 177 avatar_->SetCornerRadii(0, kTrayAvatarCornerRadius, kTrayAvatarCornerRadius, | 177 avatar_->SetCornerRadii(0, kTrayRoundedBorderRadius, |
| 178 0); | 178 kTrayRoundedBorderRadius, 0); |
| 179 avatar_->SetBorder(views::Border::NullBorder()); | 179 avatar_->SetBorder(views::Border::NullBorder()); |
| 180 } | 180 } |
| 181 UpdateAvatarImage(status); | 181 UpdateAvatarImage(status); |
| 182 | 182 |
| 183 // Update layout after setting label_ and avatar_ with new login status. | 183 // Update layout after setting label_ and avatar_ with new login status. |
| 184 UpdateLayoutOfItem(); | 184 UpdateLayoutOfItem(); |
| 185 } | 185 } |
| 186 | 186 |
| 187 void TrayUser::UpdateAfterShelfAlignmentChange(ShelfAlignment alignment) { | 187 void TrayUser::UpdateAfterShelfAlignmentChange(ShelfAlignment alignment) { |
| 188 // Inactive users won't have a layout. | 188 // Inactive users won't have a layout. |
| 189 if (!layout_view_) | 189 if (!layout_view_) |
| 190 return; | 190 return; |
| 191 if (IsHorizontalAlignment(alignment)) { | 191 if (IsHorizontalAlignment(alignment)) { |
| 192 if (avatar_) { | 192 if (avatar_) { |
| 193 avatar_->SetBorder(views::Border::NullBorder()); | 193 avatar_->SetBorder(views::Border::NullBorder()); |
| 194 avatar_->SetCornerRadii(0, kTrayAvatarCornerRadius, | 194 avatar_->SetCornerRadii(0, kTrayRoundedBorderRadius, |
| 195 kTrayAvatarCornerRadius, 0); | 195 kTrayRoundedBorderRadius, 0); |
| 196 } | 196 } |
| 197 if (label_) { | 197 if (label_) { |
| 198 // If label_ hasn't figured out its size yet, do that first. | 198 // If label_ hasn't figured out its size yet, do that first. |
| 199 if (label_->GetContentsBounds().height() == 0) | 199 if (label_->GetContentsBounds().height() == 0) |
| 200 label_->SizeToPreferredSize(); | 200 label_->SizeToPreferredSize(); |
| 201 int height = label_->GetContentsBounds().height(); | 201 int height = label_->GetContentsBounds().height(); |
| 202 int vertical_pad = (kTrayItemSize - height) / 2; | 202 int vertical_pad = (kTrayItemSize - height) / 2; |
| 203 int remainder = height % 2; | 203 int remainder = height % 2; |
| 204 label_->SetBorder(views::Border::CreateEmptyBorder( | 204 label_->SetBorder(views::Border::CreateEmptyBorder( |
| 205 vertical_pad + remainder, | 205 vertical_pad + remainder, |
| 206 kTrayLabelItemHorizontalPaddingBottomAlignment, vertical_pad, | 206 kTrayLabelItemHorizontalPaddingBottomAlignment, vertical_pad, |
| 207 kTrayLabelItemHorizontalPaddingBottomAlignment)); | 207 kTrayLabelItemHorizontalPaddingBottomAlignment)); |
| 208 } | 208 } |
| 209 layout_view_->SetLayoutManager(new views::BoxLayout( | 209 layout_view_->SetLayoutManager(new views::BoxLayout( |
| 210 views::BoxLayout::kHorizontal, 0, 0, kUserLabelToIconPadding)); | 210 views::BoxLayout::kHorizontal, 0, 0, kUserLabelToIconPadding)); |
| 211 } else { | 211 } else { |
| 212 if (avatar_) { | 212 if (avatar_) { |
| 213 avatar_->SetBorder(views::Border::NullBorder()); | 213 avatar_->SetBorder(views::Border::NullBorder()); |
| 214 avatar_->SetCornerRadii(0, 0, kTrayAvatarCornerRadius, | 214 avatar_->SetCornerRadii(0, 0, kTrayRoundedBorderRadius, |
| 215 kTrayAvatarCornerRadius); | 215 kTrayRoundedBorderRadius); |
| 216 } | 216 } |
| 217 if (label_) { | 217 if (label_) { |
| 218 label_->SetBorder(views::Border::CreateEmptyBorder( | 218 label_->SetBorder(views::Border::CreateEmptyBorder( |
| 219 kTrayLabelItemVerticalPaddingVerticalAlignment, | 219 kTrayLabelItemVerticalPaddingVerticalAlignment, |
| 220 kTrayLabelItemHorizontalPaddingBottomAlignment, | 220 kTrayLabelItemHorizontalPaddingBottomAlignment, |
| 221 kTrayLabelItemVerticalPaddingVerticalAlignment, | 221 kTrayLabelItemVerticalPaddingVerticalAlignment, |
| 222 kTrayLabelItemHorizontalPaddingBottomAlignment)); | 222 kTrayLabelItemHorizontalPaddingBottomAlignment)); |
| 223 } | 223 } |
| 224 layout_view_->SetLayoutManager(new views::BoxLayout( | 224 layout_view_->SetLayoutManager(new views::BoxLayout( |
| 225 views::BoxLayout::kVertical, 0, 0, kUserLabelToIconPadding)); | 225 views::BoxLayout::kVertical, 0, 0, kUserLabelToIconPadding)); |
| (...skipping 24 matching lines...) Expand all Loading... |
| 250 SessionStateDelegate* session_state_delegate = | 250 SessionStateDelegate* session_state_delegate = |
| 251 WmShell::Get()->GetSessionStateDelegate(); | 251 WmShell::Get()->GetSessionStateDelegate(); |
| 252 if (!avatar_ || | 252 if (!avatar_ || |
| 253 user_index_ >= session_state_delegate->NumberOfLoggedInUsers()) | 253 user_index_ >= session_state_delegate->NumberOfLoggedInUsers()) |
| 254 return; | 254 return; |
| 255 | 255 |
| 256 const user_manager::UserInfo* user_info = | 256 const user_manager::UserInfo* user_info = |
| 257 session_state_delegate->GetUserInfo(user_index_); | 257 session_state_delegate->GetUserInfo(user_index_); |
| 258 CHECK(user_info); | 258 CHECK(user_info); |
| 259 avatar_->SetImage(user_info->GetImage(), | 259 avatar_->SetImage(user_info->GetImage(), |
| 260 gfx::Size(kTrayAvatarSize, kTrayAvatarSize)); | 260 gfx::Size(kTrayItemSize, kTrayItemSize)); |
| 261 | 261 |
| 262 // Unit tests might come here with no images for some users. | 262 // Unit tests might come here with no images for some users. |
| 263 if (avatar_->size().IsEmpty()) | 263 if (avatar_->size().IsEmpty()) |
| 264 avatar_->SetSize(gfx::Size(kTrayAvatarSize, kTrayAvatarSize)); | 264 avatar_->SetSize(gfx::Size(kTrayItemSize, kTrayItemSize)); |
| 265 } | 265 } |
| 266 | 266 |
| 267 void TrayUser::UpdateLayoutOfItem() { | 267 void TrayUser::UpdateLayoutOfItem() { |
| 268 UpdateAfterShelfAlignmentChange(system_tray()->shelf_alignment()); | 268 UpdateAfterShelfAlignmentChange(system_tray()->shelf_alignment()); |
| 269 } | 269 } |
| 270 | 270 |
| 271 } // namespace ash | 271 } // namespace ash |
| OLD | NEW |