| 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
|
|
|