blob: 72a0cf54534d545644c1ea933a0f72109eb7d4a9 (
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
77
78
79
80
81
82
83
84
|
// 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 ASH_POPUP_MESSAGE_H_
#define ASH_POPUP_MESSAGE_H_
#include "ash/ash_export.h"
#include "base/basictypes.h"
#include "base/strings/string16.h"
#include "ui/gfx/rect.h"
#include "ui/views/bubble/bubble_border.h"
namespace views {
class BubbleDelegateView;
class Widget;
}
namespace ash {
// PopupMessage shows a message to the user. Since the user is not able to
// dismiss it, the calling code needs to explictly close and destroy it.
class ASH_EXPORT PopupMessage {
public:
enum IconType {
ICON_WARNING,
ICON_NONE
};
// Creates a message pointing towards |anchor| with the requested
// |arrow_orientation|. The message contains an optional |caption| which is
// drawn in bold and an optional |message| together with an optional icon of
// shape |message_type|. If a component in |size_override| is not 0 the value
// is the used as output size. If |arrow_offset| is not 0, the number is the
// arrow offset in pixels from the border.
//
// Here is the layout (arrow given as TOP_LEFT):
// |--------|
// | Anchor |
// |--------|
// |-arrow_offset---^
// +-------------------------------------------------+
// -| |-
// icon | [!] Caption in bold which can be multi line | caption_label
// -| |-
// | Message text which can be multi line | message_label
// | as well. |
// | |-
// +-------------------------------------------------+
PopupMessage(const base::string16& caption,
const base::string16& message,
IconType message_type,
views::View* anchor,
views::BubbleBorder::Arrow arrow,
const gfx::Size& size_override,
int arrow_offset);
// If the message was not explicitly closed before, it closes the message
// without animation.
virtual ~PopupMessage();
// Closes the message with a fade out animation.
void Close();
private:
class MessageBubble;
void CancelHidingAnimation();
MessageBubble* view_;
views::Widget* widget_;
// Variables of the construction time.
views::View* anchor_;
base::string16 caption_;
base::string16 message_;
IconType message_type_;
views::BubbleBorder::Arrow arrow_orientation_;
DISALLOW_COPY_AND_ASSIGN(PopupMessage);
};
} // namespace ash
#endif // ASH_POPUP_MESSAGE_H_
|