| 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/browser_actions_container.h" | 5 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/compiler_specific.h" | 9 #include "base/compiler_specific.h" |
| 10 #include "base/stl_util.h" | 10 #include "base/stl_util.h" |
| 11 #include "chrome/browser/extensions/extension_message_bubble_controller.h" | 11 #include "chrome/browser/extensions/extension_message_bubble_controller.h" |
| 12 #include "chrome/browser/extensions/tab_helper.h" | 12 #include "chrome/browser/extensions/tab_helper.h" |
| 13 #include "chrome/browser/profiles/profile.h" | 13 #include "chrome/browser/profiles/profile.h" |
| 14 #include "chrome/browser/ui/browser.h" | 14 #include "chrome/browser/ui/browser.h" |
| 15 #include "chrome/browser/ui/layout_constants.h" | 15 #include "chrome/browser/ui/layout_constants.h" |
| 16 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 16 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
| 17 #include "chrome/browser/ui/toolbar/toolbar_action_view_controller.h" | 17 #include "chrome/browser/ui/toolbar/toolbar_action_view_controller.h" |
| 18 #include "chrome/browser/ui/toolbar/toolbar_actions_bar.h" | 18 #include "chrome/browser/ui/toolbar/toolbar_actions_bar.h" |
| 19 #include "chrome/browser/ui/toolbar/toolbar_actions_model.h" | 19 #include "chrome/browser/ui/toolbar/toolbar_actions_model.h" |
| 20 #include "chrome/browser/ui/view_ids.h" | 20 #include "chrome/browser/ui/view_ids.h" |
| 21 #include "chrome/browser/ui/views/extensions/browser_action_drag_data.h" | 21 #include "chrome/browser/ui/views/extensions/browser_action_drag_data.h" |
| 22 #include "chrome/browser/ui/views/extensions/extension_message_bubble_view.h" | |
| 23 #include "chrome/browser/ui/views/frame/browser_view.h" | 22 #include "chrome/browser/ui/views/frame/browser_view.h" |
| 24 #include "chrome/browser/ui/views/toolbar/app_menu_button.h" | 23 #include "chrome/browser/ui/views/toolbar/app_menu_button.h" |
| 25 #include "chrome/browser/ui/views/toolbar/toolbar_actions_bar_bubble_views.h" | 24 #include "chrome/browser/ui/views/toolbar/toolbar_actions_bar_bubble_views.h" |
| 26 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" | 25 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" |
| 27 #include "chrome/common/extensions/command.h" | 26 #include "chrome/common/extensions/command.h" |
| 28 #include "chrome/grit/generated_resources.h" | 27 #include "chrome/grit/generated_resources.h" |
| 29 #include "extensions/common/feature_switch.h" | 28 #include "extensions/common/feature_switch.h" |
| 30 #include "grit/theme_resources.h" | 29 #include "grit/theme_resources.h" |
| 31 #include "third_party/skia/include/core/SkColor.h" | 30 #include "third_party/skia/include/core/SkColor.h" |
| 32 #include "ui/accessibility/ax_view_state.h" | 31 #include "ui/accessibility/ax_view_state.h" |
| (...skipping 287 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 320 action_view->visible() ? action_view : GetOverflowReferenceView(); | 319 action_view->visible() ? action_view : GetOverflowReferenceView(); |
| 321 } else { | 320 } else { |
| 322 anchor_view = BrowserView::GetBrowserViewForBrowser(browser_) | 321 anchor_view = BrowserView::GetBrowserViewForBrowser(browser_) |
| 323 ->toolbar() | 322 ->toolbar() |
| 324 ->app_menu_button(); | 323 ->app_menu_button(); |
| 325 } | 324 } |
| 326 } else { | 325 } else { |
| 327 anchor_view = this; | 326 anchor_view = this; |
| 328 } | 327 } |
| 329 | 328 |
| 330 // TODO(devlin): Clean up this type-specific mess. | 329 ToolbarActionsBarBubbleViews* bubble = |
| 331 if (controller->IsExtensionMessageBubble()) { | 330 new ToolbarActionsBarBubbleViews(anchor_view, std::move(controller)); |
| 332 extensions::ExtensionMessageBubbleView* bubble = | 331 views::BubbleDelegateView::CreateBubble(bubble); |
| 333 new extensions::ExtensionMessageBubbleView( | 332 active_bubble_ = bubble; |
| 334 anchor_view, views::BubbleBorder::TOP_RIGHT, std::move(controller)); | 333 active_bubble_->GetWidget()->AddObserver(this); |
| 335 views::BubbleDelegateView::CreateBubble(bubble); | 334 bubble->Show(); |
| 336 active_bubble_ = bubble; | |
| 337 active_bubble_->GetWidget()->AddObserver(this); | |
| 338 bubble->Show(); | |
| 339 } else { | |
| 340 ToolbarActionsBarBubbleViews* bubble = | |
| 341 new ToolbarActionsBarBubbleViews(anchor_view, std::move(controller)); | |
| 342 views::BubbleDelegateView::CreateBubble(bubble); | |
| 343 active_bubble_ = bubble; | |
| 344 active_bubble_->GetWidget()->AddObserver(this); | |
| 345 bubble->Show(); | |
| 346 } | |
| 347 } | 335 } |
| 348 | 336 |
| 349 void BrowserActionsContainer::OnWidgetClosing(views::Widget* widget) { | 337 void BrowserActionsContainer::OnWidgetClosing(views::Widget* widget) { |
| 350 ClearActiveBubble(widget); | 338 ClearActiveBubble(widget); |
| 351 } | 339 } |
| 352 | 340 |
| 353 void BrowserActionsContainer::OnWidgetDestroying(views::Widget* widget) { | 341 void BrowserActionsContainer::OnWidgetDestroying(views::Widget* widget) { |
| 354 ClearActiveBubble(widget); | 342 ClearActiveBubble(widget); |
| 355 } | 343 } |
| 356 | 344 |
| (...skipping 403 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 760 views::Painter::CreateImageGridPainter(kWarningImages)); | 748 views::Painter::CreateImageGridPainter(kWarningImages)); |
| 761 } | 749 } |
| 762 | 750 |
| 763 void BrowserActionsContainer::ClearActiveBubble(views::Widget* widget) { | 751 void BrowserActionsContainer::ClearActiveBubble(views::Widget* widget) { |
| 764 DCHECK(active_bubble_); | 752 DCHECK(active_bubble_); |
| 765 DCHECK_EQ(active_bubble_->GetWidget(), widget); | 753 DCHECK_EQ(active_bubble_->GetWidget(), widget); |
| 766 widget->RemoveObserver(this); | 754 widget->RemoveObserver(this); |
| 767 active_bubble_ = nullptr; | 755 active_bubble_ = nullptr; |
| 768 toolbar_actions_bar_->OnBubbleClosed(); | 756 toolbar_actions_bar_->OnBubbleClosed(); |
| 769 } | 757 } |
| OLD | NEW |