blob: 47fd2f95df37452c96b883b6d2a9dff9609ef98f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
// Copyright 2013 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.
#ifndef CHROME_BROWSER_UI_VIEWS_AUTOFILL_INFO_BUBBLE_H_
#define CHROME_BROWSER_UI_VIEWS_AUTOFILL_INFO_BUBBLE_H_
#include "base/compiler_specific.h"
#include "base/macros.h"
#include "base/strings/string16.h"
#include "ui/gfx/geometry/insets.h"
#include "ui/views/bubble/bubble_delegate.h"
namespace autofill {
class InfoBubbleFrame;
// Class to create and manage an information bubble for errors or tooltips.
class InfoBubble : public views::BubbleDelegateView {
public:
InfoBubble(views::View* anchor, const base::string16& message);
~InfoBubble() override;
// Shows the bubble. |widget_| will be NULL until this is called.
void Show();
// Hides and closes the bubble.
void Hide();
// Updates the position of the bubble.
void UpdatePosition();
// views::BubbleDelegateView:
views::NonClientFrameView* CreateNonClientFrameView(
views::Widget* widget) override;
gfx::Size GetPreferredSize() const override;
void OnWidgetDestroyed(views::Widget* widget) override;
void OnWidgetBoundsChanged(views::Widget* widget,
const gfx::Rect& new_bounds) override;
views::View* anchor() { return anchor_; }
const views::View* anchor() const { return anchor_; }
void set_align_to_anchor_edge(bool align_to_anchor_edge) {
align_to_anchor_edge_ = align_to_anchor_edge;
}
void set_preferred_width(int preferred_width) {
preferred_width_ = preferred_width;
}
void set_show_above_anchor(bool show_above_anchor) {
show_above_anchor_ = show_above_anchor;
}
private:
views::Widget* widget_; // Weak, may be NULL.
views::View* const anchor_; // Weak.
InfoBubbleFrame* frame_; // Weak, owned by widget.
// Whether the bubble should align its border to the anchor's edge rather than
// horizontally centering the arrow on |anchor_|'s midpoint. Default is false.
bool align_to_anchor_edge_;
// The width this bubble prefers to be. Default is 0 (no preference).
int preferred_width_;
// Whether the bubble should be shown above the anchor (default is below).
bool show_above_anchor_;
DISALLOW_COPY_AND_ASSIGN(InfoBubble);
};
} // namespace autofill
#endif // CHROME_BROWSER_UI_VIEWS_AUTOFILL_INFO_BUBBLE_H_
|