• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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.
4 
5 #ifndef UI_MESSAGE_CENTER_NOTIFICATION_H_
6 #define UI_MESSAGE_CENTER_NOTIFICATION_H_
7 
8 #include <string>
9 #include <vector>
10 
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"
19 
20 namespace message_center {
21 
22 struct MESSAGE_CENTER_EXPORT NotificationItem {
23   base::string16 title;
24   base::string16 message;
25 
26   NotificationItem(const base::string16& title, const base::string16& message);
27 };
28 
29 struct MESSAGE_CENTER_EXPORT ButtonInfo {
30   base::string16 title;
31   gfx::Image icon;
32 
33   ButtonInfo(const base::string16& title);
34 };
35 
36 class MESSAGE_CENTER_EXPORT RichNotificationData {
37  public:
38   RichNotificationData();
39   RichNotificationData(const RichNotificationData& other);
40   ~RichNotificationData();
41 
42   int priority;
43   bool never_timeout;
44   base::Time timestamp;
45   base::string16 context_message;
46   gfx::Image image;
47   gfx::Image small_image;
48   std::vector<NotificationItem> items;
49   int progress;
50   std::vector<ButtonInfo> buttons;
51   bool should_make_spoken_feedback_for_popup_updates;
52   bool clickable;
53 };
54 
55 class MESSAGE_CENTER_EXPORT Notification {
56  public:
57   Notification(NotificationType type,
58                const std::string& id,
59                const base::string16& title,
60                const base::string16& message,
61                const gfx::Image& icon,
62                const base::string16& display_source,
63                const NotifierId& notifier_id,
64                const RichNotificationData& optional_fields,
65                NotificationDelegate* delegate);
66 
67   Notification(const Notification& other);
68 
69   virtual ~Notification();
70 
71   // Copies the internal on-memory state from |base|, i.e. shown_as_popup,
72   // is_read, and never_timeout.
73   void CopyState(Notification* base);
74 
type()75   NotificationType type() const { return type_; }
set_type(NotificationType type)76   void set_type(NotificationType type) { type_ = type; }
77 
78   // Uniquely identifies a notification in the message center. For
79   // notification front ends that support multiple profiles, this id should
80   // identify a unique profile + frontend_notification_id combination. You can
81   // Use this id against the MessageCenter interface but not the
82   // NotificationUIManager interface.
id()83   const std::string& id() const { return id_; }
84 
title()85   const base::string16& title() const { return title_; }
set_title(const base::string16 & title)86   void set_title(const base::string16& title) { title_ = title; }
87 
message()88   const base::string16& message() const { return message_; }
set_message(const base::string16 & message)89   void set_message(const base::string16& message) { message_ = message; }
90 
91   // A display string for the source of the notification.
display_source()92   const base::string16& display_source() const { return display_source_; }
93 
notifier_id()94   const NotifierId& notifier_id() const { return notifier_id_; }
95 
set_profile_id(const std::string & profile_id)96   void set_profile_id(const std::string& profile_id) {
97     notifier_id_.profile_id = profile_id;
98   }
99 
100   // Begin unpacked values from optional_fields.
priority()101   int priority() const { return optional_fields_.priority; }
set_priority(int priority)102   void set_priority(int priority) { optional_fields_.priority = priority; }
103 
timestamp()104   base::Time timestamp() const { return optional_fields_.timestamp; }
set_timestamp(const base::Time & timestamp)105   void set_timestamp(const base::Time& timestamp) {
106     optional_fields_.timestamp = timestamp;
107   }
108 
context_message()109   const base::string16& context_message() const {
110     return optional_fields_.context_message;
111   }
set_context_message(const base::string16 & context_message)112   void set_context_message(const base::string16& context_message) {
113     optional_fields_.context_message = context_message;
114   }
115 
items()116   const std::vector<NotificationItem>& items() const {
117     return optional_fields_.items;
118   }
set_items(const std::vector<NotificationItem> & items)119   void set_items(const std::vector<NotificationItem>& items) {
120     optional_fields_.items = items;
121   }
122 
progress()123   int progress() const { return optional_fields_.progress; }
set_progress(int progress)124   void set_progress(int progress) { optional_fields_.progress = progress; }
125   // End unpacked values.
126 
127   // Images fetched asynchronously.
icon()128   const gfx::Image& icon() const { return icon_; }
set_icon(const gfx::Image & icon)129   void set_icon(const gfx::Image& icon) { icon_ = icon; }
130 
image()131   const gfx::Image& image() const { return optional_fields_.image; }
set_image(const gfx::Image & image)132   void set_image(const gfx::Image& image) { optional_fields_.image = image; }
133 
small_image()134   const gfx::Image& small_image() const { return optional_fields_.small_image; }
set_small_image(const gfx::Image & image)135   void set_small_image(const gfx::Image& image) {
136     optional_fields_.small_image = image;
137   }
138 
139   // Buttons, with icons fetched asynchronously.
buttons()140   const std::vector<ButtonInfo>& buttons() const {
141     return optional_fields_.buttons;
142   }
set_buttons(const std::vector<ButtonInfo> & buttons)143   void set_buttons(const std::vector<ButtonInfo>& buttons) {
144     optional_fields_.buttons = buttons;
145   }
146   void SetButtonIcon(size_t index, const gfx::Image& icon);
147 
shown_as_popup()148   bool shown_as_popup() const { return shown_as_popup_; }
set_shown_as_popup(bool shown_as_popup)149   void set_shown_as_popup(bool shown_as_popup) {
150     shown_as_popup_ = shown_as_popup;
151   }
152 
153   // Read status in the message center.
154   bool IsRead() const;
set_is_read(bool read)155   void set_is_read(bool read) { is_read_ = read; }
156 
157   // Used to keep the order of notifications with the same timestamp.
158   // The notification with lesser serial_number is considered 'older'.
serial_number()159   unsigned serial_number() { return serial_number_; }
160 
161   // Marks this explicitly to prevent the timeout dismiss of notification.
162   // This is used by webkit notifications to keep the existing behavior.
set_never_timeout(bool never_timeout)163   void set_never_timeout(bool never_timeout) {
164     optional_fields_.never_timeout = never_timeout;
165   }
166 
never_timeout()167   bool never_timeout() const { return optional_fields_.never_timeout; }
168 
clickable()169   bool clickable() const { return optional_fields_.clickable; }
set_clickable(bool clickable)170   void set_clickable(bool clickable) {
171     optional_fields_.clickable = clickable;
172   }
173 
delegate()174   NotificationDelegate* delegate() const { return delegate_.get(); }
175 
rich_notification_data()176   const RichNotificationData& rich_notification_data() const {
177     return optional_fields_;
178   }
179 
180   // Set the priority to SYSTEM. The system priority user needs to call this
181   // method explicitly, to avoid setting it accidentally.
182   void SetSystemPriority();
183 
184   // Delegate actions.
Display()185   void Display() const { delegate()->Display(); }
Error()186   void Error() const { delegate()->Error(); }
HasClickedListener()187   bool HasClickedListener() const { return delegate()->HasClickedListener(); }
Click()188   void Click() const { delegate()->Click(); }
ButtonClick(int index)189   void ButtonClick(int index) const { delegate()->ButtonClick(index); }
Close(bool by_user)190   void Close(bool by_user) const { delegate()->Close(by_user); }
191 
192   // Helper method to create a simple system notification. |click_callback|
193   // will be invoked when the notification is clicked.
194   static scoped_ptr<Notification> CreateSystemNotification(
195       const std::string& notification_id,
196       const base::string16& title,
197       const base::string16& message,
198       const gfx::Image& icon,
199       const std::string& system_component_id,
200       const base::Closure& click_callback);
201 
202  protected:
203   Notification& operator=(const Notification& other);
204 
205   // The type of notification we'd like displayed.
206   NotificationType type_;
207 
208   std::string id_;
209   base::string16 title_;
210   base::string16 message_;
211 
212   // Image data for the associated icon, used by Ash when available.
213   gfx::Image icon_;
214 
215   // The display string for the source of the notification.  Could be
216   // the same as origin_url_, or the name of an extension.
217   base::string16 display_source_;
218 
219  private:
220   NotifierId notifier_id_;
221   unsigned serial_number_;
222   RichNotificationData optional_fields_;
223   bool shown_as_popup_;  // True if this has been shown as a popup.
224   bool is_read_;  // True if this has been seen in the message center.
225 
226   // A proxy object that allows access back to the JavaScript object that
227   // represents the notification, for firing events.
228   scoped_refptr<NotificationDelegate> delegate_;
229 };
230 
231 }  // namespace message_center
232 
233 #endif  // UI_MESSAGE_CENTER_NOTIFICATION_H_
234