Chromium Code Reviews| Index: chrome/browser/ui/cocoa/extensions/toolbar_actions_bar_bubble_views_presenter.mm |
| diff --git a/chrome/browser/ui/cocoa/extensions/toolbar_actions_bar_bubble_views_presenter.mm b/chrome/browser/ui/cocoa/extensions/toolbar_actions_bar_bubble_views_presenter.mm |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..8ed66a20a9618518cd34a90f12f5c0e64544ce90 |
| --- /dev/null |
| +++ b/chrome/browser/ui/cocoa/extensions/toolbar_actions_bar_bubble_views_presenter.mm |
| @@ -0,0 +1,55 @@ |
| +// Copyright 2017 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#import "chrome/browser/ui/cocoa/extensions/toolbar_actions_bar_bubble_views_presenter.h" |
| + |
| +#import <Cocoa/Cocoa.h> |
| + |
| +#include "chrome/browser/ui/cocoa/bubble_anchor_helper_views.h" |
| +#import "chrome/browser/ui/cocoa/extensions/browser_actions_controller.h" |
| +#include "chrome/browser/ui/toolbar/toolbar_actions_bar_bubble_delegate.h" |
| +#include "chrome/browser/ui/views/toolbar/toolbar_actions_bar_bubble_views.h" |
| +#import "ui/gfx/mac/coordinate_conversion.h" |
| +#include "ui/views/widget/widget.h" |
| + |
| +ToolbarActionsBarBubbleViewsPresenter::ToolbarActionsBarBubbleViewsPresenter( |
| + BrowserActionsController* owner) |
| + : owner_(owner), active_bubble_(nullptr) {} |
| + |
| +ToolbarActionsBarBubbleViewsPresenter:: |
| + ~ToolbarActionsBarBubbleViewsPresenter() { |
| + if (active_bubble_) |
|
Devlin
2017/03/09 02:49:48
When can this happen?
tapted
2017/03/09 10:24:16
Hm. good question. I don't think it can. Made a dc
|
| + active_bubble_->GetWidget()->RemoveObserver(this); |
| +} |
| + |
| +void ToolbarActionsBarBubbleViewsPresenter::PresentAt( |
| + std::unique_ptr<ToolbarActionsBarBubbleDelegate> delegate, |
| + NSWindow* parent_window, |
| + NSPoint point_in_screen, |
| + bool anchored_to_action_view) { |
| + gfx::Point views_point = gfx::ScreenPointFromNSPoint(point_in_screen); |
| + ToolbarActionsBarBubbleViews* bubble = new ToolbarActionsBarBubbleViews( |
| + nullptr, views_point, anchored_to_action_view, std::move(delegate)); |
| + bubble->set_parent_window([parent_window contentView]); |
| + active_bubble_ = bubble; |
| + views::BubbleDialogDelegateView::CreateBubble(bubble); |
| + bubble->GetWidget()->AddObserver(this); |
| + bubble->Show(); |
| + KeepBubbleAnchored(bubble); |
| +} |
| + |
| +void ToolbarActionsBarBubbleViewsPresenter::OnWidgetClosing( |
| + views::Widget* widget) { |
| + // OnWidgetClosing() gives an earlier signal than OnWidgetDestroying() but is |
| + // not called when the bubble is closed synchronously. Note the observer is |
| + // removed so it's impossible for both methods to be triggered. |
| + OnWidgetDestroying(widget); |
| +} |
| + |
| +void ToolbarActionsBarBubbleViewsPresenter::OnWidgetDestroying( |
| + views::Widget* widget) { |
| + active_bubble_ = nullptr; |
| + [owner_ bubbleWindowClosing:nil]; |
| + widget->RemoveObserver(this); |
| +} |