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/common/system/tray/label_tray_view.h" | 5 #include "ash/common/system/tray/label_tray_view.h" |
6 | 6 |
7 #include "ash/common/material_design/material_design_controller.h" | 7 #include "ash/common/material_design/material_design_controller.h" |
8 #include "ash/common/system/tray/hover_highlight_view.h" | 8 #include "ash/common/system/tray/hover_highlight_view.h" |
9 #include "ash/common/system/tray/tray_constants.h" | 9 #include "ash/common/system/tray/tray_constants.h" |
10 #include "ash/common/system/tray/view_click_listener.h" | 10 #include "ash/common/system/tray/view_click_listener.h" |
11 #include "ash/resources/vector_icons/vector_icons.h" | |
11 #include "grit/ash_resources.h" | 12 #include "grit/ash_resources.h" |
12 #include "ui/base/resource/resource_bundle.h" | 13 #include "ui/base/resource/resource_bundle.h" |
13 #include "ui/gfx/font.h" | 14 #include "ui/gfx/font.h" |
14 #include "ui/gfx/paint_vector_icon.h" | 15 #include "ui/gfx/paint_vector_icon.h" |
15 #include "ui/gfx/vector_icons_public.h" | |
16 #include "ui/views/border.h" | 16 #include "ui/views/border.h" |
17 #include "ui/views/controls/label.h" | 17 #include "ui/views/controls/label.h" |
18 #include "ui/views/layout/fill_layout.h" | 18 #include "ui/views/layout/fill_layout.h" |
19 | 19 |
20 namespace ash { | 20 namespace ash { |
21 | 21 |
22 namespace { | 22 namespace { |
23 | 23 |
24 // Maps a non-MD PNG resource id to its corresponding MD vector icon id. | 24 // Maps a non-MD PNG resource id to its corresponding MD vector icon id. |
tdanderson
2016/09/07 22:36:13
nit: "to its corresponding MD vector icon id" -> m
Evan Stade
2016/09/07 22:41:51
Done.
| |
25 // TODO(tdanderson): Remove this once material design is enabled by | 25 // TODO(tdanderson): Remove this once material design is enabled by |
26 // default. See crbug.com/614453. | 26 // default. See crbug.com/614453. |
27 gfx::VectorIconId ResourceIdToVectorIconId(int resource_id) { | 27 const gfx::VectorIcon& ResourceIdToVectorIcon(int resource_id) { |
28 gfx::VectorIconId vector_id = gfx::VectorIconId::VECTOR_ICON_NONE; | |
29 #if defined(OS_CHROMEOS) | 28 #if defined(OS_CHROMEOS) |
30 switch (resource_id) { | 29 switch (resource_id) { |
31 case IDR_AURA_UBER_TRAY_ENTERPRISE: | 30 case IDR_AURA_UBER_TRAY_ENTERPRISE: |
32 return gfx::VectorIconId::SYSTEM_MENU_BUSINESS; | 31 return kSystemMenuBusinessIcon; |
33 case IDR_AURA_UBER_TRAY_BUBBLE_SESSION_LENGTH_LIMIT: | 32 case IDR_AURA_UBER_TRAY_BUBBLE_SESSION_LENGTH_LIMIT: |
34 return gfx::VectorIconId::SYSTEM_MENU_TIMER; | 33 return kSystemMenuTimerIcon; |
35 case IDR_AURA_UBER_TRAY_CHILD_USER: | 34 case IDR_AURA_UBER_TRAY_CHILD_USER: |
36 return gfx::VectorIconId::SYSTEM_MENU_CHILD_USER; | 35 return kSystemMenuChildUserIcon; |
37 case IDR_AURA_UBER_TRAY_SUPERVISED_USER: | 36 case IDR_AURA_UBER_TRAY_SUPERVISED_USER: |
38 return gfx::VectorIconId::SYSTEM_MENU_SUPERVISED_USER; | 37 return kSystemMenuSupervisedUserIcon; |
39 default: | 38 default: |
40 NOTREACHED(); | 39 NOTREACHED(); |
41 break; | 40 break; |
42 } | 41 } |
43 #endif // defined(OS_CHROMEOS) | 42 #endif // defined(OS_CHROMEOS) |
44 | 43 |
45 return vector_id; | 44 return gfx::kNoneIcon; |
46 } | 45 } |
47 | 46 |
48 } // namespace | 47 } // namespace |
49 | 48 |
50 LabelTrayView::LabelTrayView(ViewClickListener* click_listener, | 49 LabelTrayView::LabelTrayView(ViewClickListener* click_listener, |
51 int icon_resource_id) | 50 int icon_resource_id) |
52 : click_listener_(click_listener), icon_resource_id_(icon_resource_id) { | 51 : click_listener_(click_listener), icon_resource_id_(icon_resource_id) { |
53 SetLayoutManager(new views::FillLayout()); | 52 SetLayoutManager(new views::FillLayout()); |
54 SetVisible(false); | 53 SetVisible(false); |
55 } | 54 } |
(...skipping 15 matching lines...) Expand all Loading... | |
71 } | 70 } |
72 } | 71 } |
73 | 72 |
74 views::View* LabelTrayView::CreateChildView( | 73 views::View* LabelTrayView::CreateChildView( |
75 const base::string16& message) const { | 74 const base::string16& message) const { |
76 HoverHighlightView* child = new HoverHighlightView(click_listener_); | 75 HoverHighlightView* child = new HoverHighlightView(click_listener_); |
77 if (icon_resource_id_) { | 76 if (icon_resource_id_) { |
78 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); | 77 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
79 gfx::ImageSkia icon = | 78 gfx::ImageSkia icon = |
80 MaterialDesignController::IsSystemTrayMenuMaterial() | 79 MaterialDesignController::IsSystemTrayMenuMaterial() |
81 ? gfx::CreateVectorIcon(ResourceIdToVectorIconId(icon_resource_id_), | 80 ? gfx::CreateVectorIcon(ResourceIdToVectorIcon(icon_resource_id_), |
82 kMenuIconColor) | 81 kMenuIconColor) |
83 : *rb.GetImageSkiaNamed(icon_resource_id_); | 82 : *rb.GetImageSkiaNamed(icon_resource_id_); |
84 child->AddIconAndLabel(icon, message, false /* highlight */); | 83 child->AddIconAndLabel(icon, message, false /* highlight */); |
85 child->SetBorder(views::Border::CreateEmptyBorder( | 84 child->SetBorder(views::Border::CreateEmptyBorder( |
86 0, kTrayPopupPaddingHorizontal, 0, kTrayPopupPaddingHorizontal)); | 85 0, kTrayPopupPaddingHorizontal, 0, kTrayPopupPaddingHorizontal)); |
87 child->text_label()->SetMultiLine(true); | 86 child->text_label()->SetMultiLine(true); |
88 child->text_label()->SizeToFit(kTrayNotificationContentsWidth); | 87 child->text_label()->SizeToFit(kTrayNotificationContentsWidth); |
89 } else { | 88 } else { |
90 child->AddLabel(message, gfx::ALIGN_LEFT, false /* highlight */); | 89 child->AddLabel(message, gfx::ALIGN_LEFT, false /* highlight */); |
91 child->text_label()->SetMultiLine(true); | 90 child->text_label()->SetMultiLine(true); |
92 child->text_label()->SizeToFit(kTrayNotificationContentsWidth + | 91 child->text_label()->SizeToFit(kTrayNotificationContentsWidth + |
93 kNotificationIconWidth); | 92 kNotificationIconWidth); |
94 } | 93 } |
95 child->text_label()->SetAllowCharacterBreak(true); | 94 child->text_label()->SetAllowCharacterBreak(true); |
96 child->SetExpandable(true); | 95 child->SetExpandable(true); |
97 child->SetVisible(true); | 96 child->SetVisible(true); |
98 return child; | 97 return child; |
99 } | 98 } |
100 | 99 |
101 } // namespace ash | 100 } // namespace ash |
OLD | NEW |