1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef UI_MESSAGE_CENTER_NOTIFICATION_H_
6 #define UI_MESSAGE_CENTER_NOTIFICATION_H_
11 #include "base/strings/string16.h"
12 #include "base/time/time.h"
13 #include "base/values.h"
14 #include "ui/gfx/image/image.h"
15 #include "ui/message_center/message_center_export.h"
16 #include "ui/message_center/notification_delegate.h"
17 #include "ui/message_center/notification_types.h"
18 #include "ui/message_center/notifier_settings.h"
21 namespace message_center
{
23 struct MESSAGE_CENTER_EXPORT NotificationItem
{
25 base::string16 message
;
27 NotificationItem(const base::string16
& title
, const base::string16
& message
);
30 struct MESSAGE_CENTER_EXPORT ButtonInfo
{
34 ButtonInfo(const base::string16
& title
);
37 class MESSAGE_CENTER_EXPORT RichNotificationData
{
39 RichNotificationData();
40 RichNotificationData(const RichNotificationData
& other
);
41 ~RichNotificationData();
46 base::string16 context_message
;
48 gfx::Image small_image
;
49 std::vector
<NotificationItem
> items
;
51 std::vector
<ButtonInfo
> buttons
;
52 bool should_make_spoken_feedback_for_popup_updates
;
54 std::vector
<int> vibration_pattern
;
58 class MESSAGE_CENTER_EXPORT Notification
{
60 Notification(NotificationType type
,
61 const std::string
& id
,
62 const base::string16
& title
,
63 const base::string16
& message
,
64 const gfx::Image
& icon
,
65 const base::string16
& display_source
,
66 const GURL
& origin_url
,
67 const NotifierId
& notifier_id
,
68 const RichNotificationData
& optional_fields
,
69 NotificationDelegate
* delegate
);
71 Notification(const std::string
& id
, const Notification
& other
);
73 Notification(const Notification
& other
);
75 virtual ~Notification();
77 // Copies the internal on-memory state from |base|, i.e. shown_as_popup,
78 // is_read, and never_timeout.
79 void CopyState(Notification
* base
);
81 NotificationType
type() const { return type_
; }
82 void set_type(NotificationType type
) { type_
= type
; }
84 // Uniquely identifies a notification in the message center. For
85 // notification front ends that support multiple profiles, this id should
86 // identify a unique profile + frontend_notification_id combination. You can
87 // Use this id against the MessageCenter interface but not the
88 // NotificationUIManager interface.
89 const std::string
& id() const { return id_
; }
91 const base::string16
& title() const { return title_
; }
92 void set_title(const base::string16
& title
) { title_
= title
; }
94 const base::string16
& message() const { return message_
; }
95 void set_message(const base::string16
& message
) { message_
= message
; }
97 // The origin URL of the script which requested the notification.
98 // Can be empty if the notification is requested by an extension or
100 const GURL
& origin_url() const { return origin_url_
; }
102 // A display string for the source of the notification.
103 const base::string16
& display_source() const { return display_source_
; }
105 const NotifierId
& notifier_id() const { return notifier_id_
; }
107 void set_profile_id(const std::string
& profile_id
) {
108 notifier_id_
.profile_id
= profile_id
;
111 // Begin unpacked values from optional_fields.
112 int priority() const { return optional_fields_
.priority
; }
113 void set_priority(int priority
) { optional_fields_
.priority
= priority
; }
115 // This vibration_pattern property currently has no effect on
116 // non-Android platforms.
117 const std::vector
<int>& vibration_pattern() const {
118 return optional_fields_
.vibration_pattern
;
120 void set_vibration_pattern(const std::vector
<int>& vibration_pattern
) {
121 optional_fields_
.vibration_pattern
= vibration_pattern
;
124 // This property currently has no effect on non-Android platforms.
125 bool silent() const { return optional_fields_
.silent
; }
126 void set_silent(bool silent
) { optional_fields_
.silent
= silent
; }
128 base::Time
timestamp() const { return optional_fields_
.timestamp
; }
129 void set_timestamp(const base::Time
& timestamp
) {
130 optional_fields_
.timestamp
= timestamp
;
133 const base::string16
context_message() const {
134 return optional_fields_
.context_message
;
137 void set_context_message(const base::string16
& context_message
) {
138 optional_fields_
.context_message
= context_message
;
141 // Decides if the notification origin should be used as a context message
142 bool UseOriginAsContextMessage() const;
144 const std::vector
<NotificationItem
>& items() const {
145 return optional_fields_
.items
;
147 void set_items(const std::vector
<NotificationItem
>& items
) {
148 optional_fields_
.items
= items
;
151 int progress() const { return optional_fields_
.progress
; }
152 void set_progress(int progress
) { optional_fields_
.progress
= progress
; }
153 // End unpacked values.
155 // Images fetched asynchronously.
156 const gfx::Image
& icon() const { return icon_
; }
157 void set_icon(const gfx::Image
& icon
) { icon_
= icon
; }
159 const gfx::Image
& image() const { return optional_fields_
.image
; }
160 void set_image(const gfx::Image
& image
) { optional_fields_
.image
= image
; }
162 const gfx::Image
& small_image() const { return optional_fields_
.small_image
; }
163 void set_small_image(const gfx::Image
& image
) {
164 optional_fields_
.small_image
= image
;
167 // Buttons, with icons fetched asynchronously.
168 const std::vector
<ButtonInfo
>& buttons() const {
169 return optional_fields_
.buttons
;
171 void set_buttons(const std::vector
<ButtonInfo
>& buttons
) {
172 optional_fields_
.buttons
= buttons
;
174 void SetButtonIcon(size_t index
, const gfx::Image
& icon
);
176 bool shown_as_popup() const { return shown_as_popup_
; }
177 void set_shown_as_popup(bool shown_as_popup
) {
178 shown_as_popup_
= shown_as_popup
;
181 // Read status in the message center.
183 void set_is_read(bool read
) { is_read_
= read
; }
185 // Used to keep the order of notifications with the same timestamp.
186 // The notification with lesser serial_number is considered 'older'.
187 unsigned serial_number() { return serial_number_
; }
189 // Marks this explicitly to prevent the timeout dismiss of notification.
190 // This is used by webkit notifications to keep the existing behavior.
191 void set_never_timeout(bool never_timeout
) {
192 optional_fields_
.never_timeout
= never_timeout
;
195 bool never_timeout() const { return optional_fields_
.never_timeout
; }
197 bool clickable() const { return optional_fields_
.clickable
; }
198 void set_clickable(bool clickable
) {
199 optional_fields_
.clickable
= clickable
;
202 NotificationDelegate
* delegate() const { return delegate_
.get(); }
204 const RichNotificationData
& rich_notification_data() const {
205 return optional_fields_
;
208 // Set the priority to SYSTEM. The system priority user needs to call this
209 // method explicitly, to avoid setting it accidentally.
210 void SetSystemPriority();
213 void Display() const { delegate()->Display(); }
214 bool HasClickedListener() const { return delegate()->HasClickedListener(); }
215 void Click() const { delegate()->Click(); }
216 void ButtonClick(int index
) const { delegate()->ButtonClick(index
); }
217 void Close(bool by_user
) const { delegate()->Close(by_user
); }
219 // Helper method to create a simple system notification. |click_callback|
220 // will be invoked when the notification is clicked.
221 static scoped_ptr
<Notification
> CreateSystemNotification(
222 const std::string
& notification_id
,
223 const base::string16
& title
,
224 const base::string16
& message
,
225 const gfx::Image
& icon
,
226 const std::string
& system_component_id
,
227 const base::Closure
& click_callback
);
230 Notification
& operator=(const Notification
& other
);
232 // The type of notification we'd like displayed.
233 NotificationType type_
;
236 base::string16 title_
;
237 base::string16 message_
;
239 // Image data for the associated icon, used by Ash when available.
242 // The display string for the source of the notification. Could be
243 // the same as origin_url_, or the name of an extension.
244 base::string16 display_source_
;
247 // The origin URL of the script which requested the notification.
248 // Can be empty if requested through a chrome app or extension or if
249 // it's a system notification.
251 NotifierId notifier_id_
;
252 unsigned serial_number_
;
253 RichNotificationData optional_fields_
;
254 bool shown_as_popup_
; // True if this has been shown as a popup.
255 bool is_read_
; // True if this has been seen in the message center.
257 // A proxy object that allows access back to the JavaScript object that
258 // represents the notification, for firing events.
259 scoped_refptr
<NotificationDelegate
> delegate_
;
262 } // namespace message_center
264 #endif // UI_MESSAGE_CENTER_NOTIFICATION_H_