| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/views/toolbar/app_menu_button.h" | 5 #include "chrome/browser/ui/views/toolbar/app_menu_button.h" |
| 6 | 6 |
| 7 #include "base/location.h" | 7 #include "base/location.h" |
| 8 #include "base/metrics/histogram_macros.h" | 8 #include "base/metrics/histogram_macros.h" |
| 9 #include "base/single_thread_task_runner.h" | 9 #include "base/single_thread_task_runner.h" |
| 10 #include "base/threading/thread_task_runner_handle.h" | 10 #include "base/threading/thread_task_runner_handle.h" |
| 11 #include "base/time/time.h" | 11 #include "base/time/time.h" |
| 12 #include "chrome/app/vector_icons/vector_icons.h" |
| 12 #include "chrome/browser/themes/theme_properties.h" | 13 #include "chrome/browser/themes/theme_properties.h" |
| 13 #include "chrome/browser/ui/browser.h" | 14 #include "chrome/browser/ui/browser.h" |
| 14 #include "chrome/browser/ui/browser_otr_state.h" | 15 #include "chrome/browser/ui/browser_otr_state.h" |
| 15 #include "chrome/browser/ui/layout_constants.h" | 16 #include "chrome/browser/ui/layout_constants.h" |
| 16 #include "chrome/browser/ui/toolbar/app_menu_model.h" | 17 #include "chrome/browser/ui/toolbar/app_menu_model.h" |
| 17 #include "chrome/browser/ui/views/extensions/browser_action_drag_data.h" | 18 #include "chrome/browser/ui/views/extensions/browser_action_drag_data.h" |
| 18 #include "chrome/browser/ui/views/toolbar/app_menu.h" | 19 #include "chrome/browser/ui/views/toolbar/app_menu.h" |
| 19 #include "chrome/browser/ui/views/toolbar/toolbar_button.h" | 20 #include "chrome/browser/ui/views/toolbar/toolbar_button.h" |
| 20 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" | 21 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" |
| 21 #include "chrome/grit/theme_resources.h" | 22 #include "chrome/grit/theme_resources.h" |
| 22 #include "extensions/common/feature_switch.h" | 23 #include "extensions/common/feature_switch.h" |
| 23 #include "ui/base/resource/resource_bundle.h" | 24 #include "ui/base/resource/resource_bundle.h" |
| 24 #include "ui/base/theme_provider.h" | 25 #include "ui/base/theme_provider.h" |
| 25 #include "ui/gfx/color_palette.h" | 26 #include "ui/gfx/color_palette.h" |
| 26 #include "ui/gfx/paint_vector_icon.h" | 27 #include "ui/gfx/paint_vector_icon.h" |
| 27 #include "ui/gfx/vector_icons_public.h" | |
| 28 #include "ui/keyboard/keyboard_controller.h" | 28 #include "ui/keyboard/keyboard_controller.h" |
| 29 #include "ui/views/controls/button/label_button_border.h" | 29 #include "ui/views/controls/button/label_button_border.h" |
| 30 #include "ui/views/controls/menu/menu_listener.h" | 30 #include "ui/views/controls/menu/menu_listener.h" |
| 31 #include "ui/views/metrics.h" | 31 #include "ui/views/metrics.h" |
| 32 | 32 |
| 33 // static | 33 // static |
| 34 bool AppMenuButton::g_open_app_immediately_for_testing = false; | 34 bool AppMenuButton::g_open_app_immediately_for_testing = false; |
| 35 | 35 |
| 36 AppMenuButton::AppMenuButton(ToolbarView* toolbar_view) | 36 AppMenuButton::AppMenuButton(ToolbarView* toolbar_view) |
| 37 : views::MenuButton(base::string16(), toolbar_view, false), | 37 : views::MenuButton(base::string16(), toolbar_view, false), |
| (...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 129 case AppMenuIconController::Severity::MEDIUM: | 129 case AppMenuIconController::Severity::MEDIUM: |
| 130 color = native_theme->GetSystemColor( | 130 color = native_theme->GetSystemColor( |
| 131 ui::NativeTheme::kColorId_AlertSeverityMedium); | 131 ui::NativeTheme::kColorId_AlertSeverityMedium); |
| 132 break; | 132 break; |
| 133 case AppMenuIconController::Severity::HIGH: | 133 case AppMenuIconController::Severity::HIGH: |
| 134 color = native_theme->GetSystemColor( | 134 color = native_theme->GetSystemColor( |
| 135 ui::NativeTheme::kColorId_AlertSeverityHigh); | 135 ui::NativeTheme::kColorId_AlertSeverityHigh); |
| 136 break; | 136 break; |
| 137 } | 137 } |
| 138 | 138 |
| 139 gfx::VectorIconId icon_id = gfx::VectorIconId::VECTOR_ICON_NONE; | 139 const gfx::VectorIcon* icon_id = nullptr; |
| 140 switch (type_) { | 140 switch (type_) { |
| 141 case AppMenuIconController::IconType::NONE: | 141 case AppMenuIconController::IconType::NONE: |
| 142 icon_id = gfx::VectorIconId::BROWSER_TOOLS; | 142 icon_id = &kBrowserToolsIcon; |
| 143 DCHECK_EQ(AppMenuIconController::Severity::NONE, severity_); | 143 DCHECK_EQ(AppMenuIconController::Severity::NONE, severity_); |
| 144 break; | 144 break; |
| 145 case AppMenuIconController::IconType::UPGRADE_NOTIFICATION: | 145 case AppMenuIconController::IconType::UPGRADE_NOTIFICATION: |
| 146 icon_id = gfx::VectorIconId::BROWSER_TOOLS_UPDATE; | 146 icon_id = &kBrowserToolsUpdateIcon; |
| 147 break; | 147 break; |
| 148 case AppMenuIconController::IconType::GLOBAL_ERROR: | 148 case AppMenuIconController::IconType::GLOBAL_ERROR: |
| 149 case AppMenuIconController::IconType::INCOMPATIBILITY_WARNING: | 149 case AppMenuIconController::IconType::INCOMPATIBILITY_WARNING: |
| 150 icon_id = gfx::VectorIconId::BROWSER_TOOLS_ERROR; | 150 icon_id = &kBrowserToolsErrorIcon; |
| 151 break; | 151 break; |
| 152 } | 152 } |
| 153 | 153 |
| 154 SetImage(views::Button::STATE_NORMAL, gfx::CreateVectorIcon(icon_id, color)); | 154 SetImage(views::Button::STATE_NORMAL, gfx::CreateVectorIcon(*icon_id, color)); |
| 155 } | 155 } |
| 156 | 156 |
| 157 void AppMenuButton::SetTrailingMargin(int margin) { | 157 void AppMenuButton::SetTrailingMargin(int margin) { |
| 158 margin_trailing_ = margin; | 158 margin_trailing_ = margin; |
| 159 UpdateThemedBorder(); | 159 UpdateThemedBorder(); |
| 160 InvalidateLayout(); | 160 InvalidateLayout(); |
| 161 } | 161 } |
| 162 | 162 |
| 163 const char* AppMenuButton::GetClassName() const { | 163 const char* AppMenuButton::GetClassName() const { |
| 164 return "AppMenuButton"; | 164 return "AppMenuButton"; |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 226 | 226 |
| 227 void AppMenuButton::OnDragExited() { | 227 void AppMenuButton::OnDragExited() { |
| 228 DCHECK(allow_extension_dragging_); | 228 DCHECK(allow_extension_dragging_); |
| 229 weak_factory_.InvalidateWeakPtrs(); | 229 weak_factory_.InvalidateWeakPtrs(); |
| 230 } | 230 } |
| 231 | 231 |
| 232 int AppMenuButton::OnPerformDrop(const ui::DropTargetEvent& event) { | 232 int AppMenuButton::OnPerformDrop(const ui::DropTargetEvent& event) { |
| 233 DCHECK(allow_extension_dragging_); | 233 DCHECK(allow_extension_dragging_); |
| 234 return ui::DragDropTypes::DRAG_MOVE; | 234 return ui::DragDropTypes::DRAG_MOVE; |
| 235 } | 235 } |
| OLD | NEW |