| Index: ui/views/bubble/info_bubble.cc
|
| diff --git a/chrome/browser/ui/views/autofill/info_bubble.cc b/ui/views/bubble/info_bubble.cc
|
| similarity index 53%
|
| rename from chrome/browser/ui/views/autofill/info_bubble.cc
|
| rename to ui/views/bubble/info_bubble.cc
|
| index ecc7bc152cf3f8c21a847705eee0453baec543ad..0b633c919269133c1d5b3c1c278c1731edc027e8 100644
|
| --- a/chrome/browser/ui/views/autofill/info_bubble.cc
|
| +++ b/ui/views/bubble/info_bubble.cc
|
| @@ -2,23 +2,18 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| -#include "chrome/browser/ui/views/autofill/info_bubble.h"
|
| +#include "ui/views/bubble/info_bubble.h"
|
|
|
| -#include "base/i18n/rtl.h"
|
| -#include "base/macros.h"
|
| #include "ui/gfx/geometry/point.h"
|
| #include "ui/gfx/geometry/rect.h"
|
| #include "ui/gfx/geometry/size.h"
|
| -#include "ui/gfx/text_constants.h"
|
| #include "ui/views/bubble/bubble_border.h"
|
| #include "ui/views/bubble/bubble_frame_view.h"
|
| -#include "ui/views/controls/combobox/combobox.h"
|
| #include "ui/views/controls/label.h"
|
| #include "ui/views/layout/fill_layout.h"
|
| -#include "ui/views/layout/layout_constants.h"
|
| #include "ui/views/widget/widget.h"
|
|
|
| -namespace autofill {
|
| +namespace views {
|
|
|
| namespace {
|
|
|
| @@ -31,10 +26,10 @@ const int kInfoBubbleVerticalMargin = 12;
|
|
|
| } // namespace
|
|
|
| -class InfoBubbleFrame : public views::BubbleFrameView {
|
| +class InfoBubbleFrame : public BubbleFrameView {
|
| public:
|
| explicit InfoBubbleFrame(const gfx::Insets& content_margins)
|
| - : views::BubbleFrameView(gfx::Insets(), content_margins) {}
|
| + : BubbleFrameView(gfx::Insets(), content_margins) {}
|
| ~InfoBubbleFrame() override {}
|
|
|
| gfx::Rect GetAvailableScreenBounds(const gfx::Rect& rect) const override {
|
| @@ -52,24 +47,17 @@ class InfoBubbleFrame : public views::BubbleFrameView {
|
| DISALLOW_COPY_AND_ASSIGN(InfoBubbleFrame);
|
| };
|
|
|
| -InfoBubble::InfoBubble(views::View* anchor,
|
| - const base::string16& message)
|
| - : anchor_(anchor),
|
| - frame_(NULL),
|
| - align_to_anchor_edge_(false),
|
| - preferred_width_(233),
|
| - show_above_anchor_(false) {
|
| +InfoBubble::InfoBubble(View* anchor, const base::string16& message)
|
| + : anchor_(anchor), frame_(nullptr), preferred_width_(0) {
|
| DCHECK(anchor_);
|
| SetAnchorView(anchor_);
|
|
|
| - set_margins(gfx::Insets(kInfoBubbleVerticalMargin,
|
| - kInfoBubbleHorizontalMargin,
|
| - kInfoBubbleVerticalMargin,
|
| - kInfoBubbleHorizontalMargin));
|
| + set_margins(
|
| + gfx::Insets(kInfoBubbleVerticalMargin, kInfoBubbleHorizontalMargin));
|
| set_can_activate(false);
|
|
|
| - SetLayoutManager(new views::FillLayout);
|
| - views::Label* label = new views::Label(message);
|
| + SetLayoutManager(new FillLayout);
|
| + Label* label = new Label(message);
|
| label->SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| label->SetMultiLine(true);
|
| AddChildView(label);
|
| @@ -78,71 +66,44 @@ InfoBubble::InfoBubble(views::View* anchor,
|
| InfoBubble::~InfoBubble() {}
|
|
|
| void InfoBubble::Show() {
|
| - // TODO(dbeam): currently we assume that combobox menus always show downward
|
| - // (which isn't true). If the invalid combobox is low enough on the screen,
|
| - // its menu will actually show upward and obscure the bubble. Figure out when
|
| - // this might happen and adjust |show_above_anchor_| accordingly. This is not
|
| - // that big of deal because it rarely happens in practice.
|
| - if (show_above_anchor_)
|
| - set_arrow(views::BubbleBorder::vertical_mirror(arrow()));
|
| -
|
| - widget_ = views::BubbleDialogDelegateView::CreateBubble(this);
|
| -
|
| - if (align_to_anchor_edge_) {
|
| - // The frame adjusts its arrow before the bubble's alignment can be changed.
|
| - // Set the created bubble border back to the original arrow and re-adjust.
|
| - frame_->bubble_border()->set_arrow(arrow());
|
| - SetAlignment(views::BubbleBorder::ALIGN_EDGE_TO_ANCHOR_EDGE);
|
| - }
|
| + widget_ = BubbleDialogDelegateView::CreateBubble(this);
|
|
|
| UpdatePosition();
|
| }
|
|
|
| void InfoBubble::Hide() {
|
| - views::Widget* widget = GetWidget();
|
| + Widget* widget = GetWidget();
|
| if (widget && !widget->IsClosed())
|
| widget->Close();
|
| }
|
|
|
| -void InfoBubble::UpdatePosition() {
|
| - if (!widget_)
|
| - return;
|
| -
|
| - if (!anchor_->GetVisibleBounds().IsEmpty()) {
|
| - SizeToContents();
|
| - widget_->SetVisibilityChangedAnimationsEnabled(true);
|
| - widget_->ShowInactive();
|
| - } else {
|
| - widget_->SetVisibilityChangedAnimationsEnabled(false);
|
| - widget_->Hide();
|
| - }
|
| -}
|
| -
|
| -views::NonClientFrameView* InfoBubble::CreateNonClientFrameView(
|
| - views::Widget* widget) {
|
| +NonClientFrameView* InfoBubble::CreateNonClientFrameView(Widget* widget) {
|
| DCHECK(!frame_);
|
| frame_ = new InfoBubbleFrame(margins());
|
| frame_->set_available_bounds(anchor_widget()->GetWindowBoundsInScreen());
|
| - frame_->SetBubbleBorder(std::unique_ptr<views::BubbleBorder>(
|
| - new views::BubbleBorder(arrow(), shadow(), color())));
|
| + frame_->SetBubbleBorder(std::unique_ptr<BubbleBorder>(
|
| + new BubbleBorder(arrow(), shadow(), color())));
|
| return frame_;
|
| }
|
|
|
| gfx::Size InfoBubble::GetPreferredSize() const {
|
| + if (preferred_width_ == 0)
|
| + return BubbleDialogDelegateView::GetPreferredSize();
|
| +
|
| int pref_width = preferred_width_;
|
| pref_width -= frame_->GetInsets().width();
|
| pref_width -= 2 * kBubbleBorderVisibleWidth;
|
| return gfx::Size(pref_width, GetHeightForWidth(pref_width));
|
| }
|
|
|
| -void InfoBubble::OnWidgetDestroyed(views::Widget* widget) {
|
| +void InfoBubble::OnWidgetDestroyed(Widget* widget) {
|
| if (widget == widget_)
|
| - widget_ = NULL;
|
| + widget_ = nullptr;
|
| }
|
|
|
| -void InfoBubble::OnWidgetBoundsChanged(views::Widget* widget,
|
| +void InfoBubble::OnWidgetBoundsChanged(Widget* widget,
|
| const gfx::Rect& new_bounds) {
|
| - views::BubbleDialogDelegateView::OnWidgetBoundsChanged(widget, new_bounds);
|
| + BubbleDialogDelegateView::OnWidgetBoundsChanged(widget, new_bounds);
|
| if (anchor_widget() == widget)
|
| frame_->set_available_bounds(widget->GetWindowBoundsInScreen());
|
| }
|
| @@ -151,4 +112,18 @@ int InfoBubble::GetDialogButtons() const {
|
| return ui::DIALOG_BUTTON_NONE;
|
| }
|
|
|
| -} // namespace autofill
|
| +void InfoBubble::UpdatePosition() {
|
| + if (!widget_)
|
| + return;
|
| +
|
| + if (!anchor_->GetVisibleBounds().IsEmpty()) {
|
| + SizeToContents();
|
| + widget_->SetVisibilityChangedAnimationsEnabled(true);
|
| + widget_->ShowInactive();
|
| + } else {
|
| + widget_->SetVisibilityChangedAnimationsEnabled(false);
|
| + widget_->Hide();
|
| + }
|
| +}
|
| +
|
| +} // namespace views
|
|
|