Index: ui/message_center/notification.h |
diff --git a/ui/message_center/notification.h b/ui/message_center/notification.h |
index 5f7ee12a4523e48ca4464f154fe476220176a1af..c6c43b9f517047fccb8d33bf962879c2fb1b7869 100644 |
--- a/ui/message_center/notification.h |
+++ b/ui/message_center/notification.h |
@@ -32,16 +32,45 @@ struct MESSAGE_CENTER_EXPORT ButtonInfo { |
ButtonInfo(const string16& title); |
}; |
+class MESSAGE_CENTER_EXPORT RichNotificationData { |
+ public: |
+ RichNotificationData(); |
+ RichNotificationData(const RichNotificationData& other); |
+ ~RichNotificationData(); |
+ |
+ int priority; |
+ bool never_timeout; |
+ base::Time timestamp; |
+ string16 expanded_message; |
+ gfx::Image image; |
+ std::vector<NotificationItem> items; |
+ std::vector<ButtonInfo> buttons; |
+}; |
+ |
class MESSAGE_CENTER_EXPORT Notification { |
public: |
Notification(NotificationType type, |
const std::string& id, |
const string16& title, |
const string16& message, |
+ const gfx::Image& icon, |
const string16& display_source, |
const std::string& extension_id, |
const DictionaryValue* optional_fields, // May be NULL. |
NotificationDelegate* delegate); // May be NULL. |
+ |
+ Notification(NotificationType type, |
+ const std::string& id, |
+ const string16& title, |
+ const string16& message, |
+ const gfx::Image& icon, |
+ const string16& display_source, |
+ const std::string& extension_id, |
+ const RichNotificationData& optional_fields, |
+ NotificationDelegate* delegate); |
+ |
+ Notification(const Notification& other); |
+ Notification& operator=(const Notification& other); |
virtual ~Notification(); |
// Copies the internal on-memory state from |base|, i.e. shown_as_popup, |
@@ -52,26 +81,37 @@ class MESSAGE_CENTER_EXPORT Notification { |
const std::string& id() const { return id_; } |
const string16& title() const { return title_; } |
const string16& message() const { return message_; } |
+ |
+ // A display string for the source of the notification. |
const string16& display_source() const { return display_source_; } |
const std::string& extension_id() const { return extension_id_; } |
+ void set_extension_id(const std::string& extension_id) { |
+ extension_id_ = extension_id; |
+ } |
// Begin unpacked values from optional_fields. |
- int priority() const { return priority_; } |
- base::Time timestamp() const { return timestamp_; } |
- const string16& expanded_message() const { return expanded_message_; } |
- const std::vector<NotificationItem>& items() const { return items_; } |
+ int priority() const { return optional_fields_.priority; } |
+ base::Time timestamp() const { return optional_fields_.timestamp; } |
+ const string16& expanded_message() const { |
+ return optional_fields_.expanded_message; |
+ } |
+ const std::vector<NotificationItem>& items() const { |
+ return optional_fields_.items; |
+ } |
// End unpacked values. |
// Images fetched asynchronously. |
const gfx::Image& icon() const { return icon_; } |
void set_icon(const gfx::Image& icon) { icon_ = icon; } |
- const gfx::Image& image() const { return image_; } |
- void set_image(const gfx::Image& image) { image_ = image; } |
+ const gfx::Image& image() const { return optional_fields_.image; } |
+ void set_image(const gfx::Image& image) { optional_fields_.image = image; } |
// Buttons, with icons fetched asynchronously. |
- const std::vector<ButtonInfo>& buttons() const { return buttons_; } |
- bool SetButtonIcon(size_t index, const gfx::Image& icon); |
+ const std::vector<ButtonInfo>& buttons() const { |
+ return optional_fields_.buttons; |
+ } |
+ void SetButtonIcon(size_t index, const gfx::Image& icon); |
bool shown_as_popup() const { return shown_as_popup_; } |
void set_shown_as_popup(bool shown_as_popup) { |
@@ -90,38 +130,56 @@ class MESSAGE_CENTER_EXPORT Notification { |
// The notification with lesser serial_number is considered 'older'. |
unsigned serial_number() { return serial_number_; } |
- bool never_timeout() const { return never_timeout_; } |
- NotificationDelegate* delegate() { return delegate_.get(); } |
+ // Marks this explicitly to prevent the timeout dismiss of notification. |
+ // This is used by webkit notifications to keep the existing behavior. |
+ void set_never_timeout(bool never_timeout) { |
+ optional_fields_.never_timeout = never_timeout; |
+ } |
- private: |
- // Unpacks the provided |optional_fields| and applies the values to override |
- // the notification's data members. |
- void ApplyOptionalFields(const DictionaryValue* optional_fields); |
+ bool never_timeout() const { return optional_fields_.never_timeout; } |
+ NotificationDelegate* delegate() const { return delegate_.get(); } |
+ const RichNotificationData& rich_notification_data() const { |
+ return optional_fields_; |
+ } |
+ |
+ // Delegate actions. |
+ void Display() const { delegate()->Display(); } |
+ void Error() const { delegate()->Error(); } |
+ bool HasClickedListener() const { return delegate()->HasClickedListener(); } |
+ void Click() const { delegate()->Click(); } |
+ void ButtonClick(int index) const { delegate()->ButtonClick(index); } |
+ void Close(bool by_user) const { delegate()->Close(by_user); } |
+ protected: |
+ // The type of notification we'd like displayed. |
NotificationType type_; |
+ |
std::string id_; |
string16 title_; |
string16 message_; |
+ |
+ // Image data for the associated icon, used by Ash when available. |
+ gfx::Image icon_; |
+ |
+ // The display string for the source of the notification. Could be |
+ // the same as origin_url_, or the name of an extension. |
string16 display_source_; |
+ |
+ private: |
+ // Unpacks the provided |optional_fields| and applies the values to override |
+ // the notification's data members. |
+ void ApplyOptionalFields(const DictionaryValue* optional_fields); |
+ |
std::string extension_id_; |
- int priority_; |
- base::Time timestamp_; |
unsigned serial_number_; |
- string16 expanded_message_; |
- std::vector<NotificationItem> items_; |
- gfx::Image icon_; |
- gfx::Image image_; |
- std::vector<ButtonInfo> buttons_; |
+ RichNotificationData optional_fields_; |
bool shown_as_popup_; // True if this has been shown as a popup. |
bool is_read_; // True if this has been seen in the message center. |
bool is_expanded_; // True if this has been expanded in the message center. |
- bool never_timeout_; // True if it doesn't timeout when it appears as a toast. |
// A proxy object that allows access back to the JavaScript object that |
// represents the notification, for firing events. |
scoped_refptr<NotificationDelegate> delegate_; |
- |
- DISALLOW_COPY_AND_ASSIGN(Notification); |
}; |
} // namespace message_center |