Index: components/arc/notification/arc_notification_item.h |
diff --git a/components/arc/notification/arc_notification_item.h b/components/arc/notification/arc_notification_item.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..a105be8b5e0f167596893927ad7eb20f16bb5e04 |
--- /dev/null |
+++ b/components/arc/notification/arc_notification_item.h |
@@ -0,0 +1,69 @@ |
+// Copyright 2015 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 COMPONENTS_ARC_NOTIFICATION_ARC_NOTIFICATION_ITEM_H_ |
+#define COMPONENTS_ARC_NOTIFICATION_ARC_NOTIFICATION_ITEM_H_ |
+ |
+#include <string> |
+ |
+#include "base/macros.h" |
+#include "base/memory/weak_ptr.h" |
+#include "components/arc/notification/arc_notification_manager.h" |
+#include "components/signin/core/account_id/account_id.h" |
+#include "third_party/skia/include/core/SkBitmap.h" |
+#include "ui/message_center/message_center.h" |
+ |
+namespace arc { |
+ |
+class ArcNotificationItem { |
+ public: |
+ ArcNotificationItem(ArcNotificationManager* manager, |
+ message_center::MessageCenter* message_center, |
+ const ArcNotificationData& data, |
+ const AccountId& profile_id); |
+ ~ArcNotificationItem(); |
+ |
+ void UpdateWithArcNotificationData(const ArcNotificationData& data); |
+ |
+ // Methods called from ArcNotificationManager: |
+ void OnClosedFromAndroid(); |
+ |
+ // Methods called from ArcNotificationItemDelegate: |
+ void Close(bool by_user); |
+ void Click(); |
+ |
+ private: |
+ void OnImageDecoded(const SkBitmap& bitmap); |
+ |
+ ArcNotificationManager* const manager_; |
+ message_center::MessageCenter* const message_center_; |
+ const AccountId profile_id_; |
+ |
+ std::string notification_key_; |
hidehiko
2015/12/22 08:51:27
nit: maybe "const" for consistency?
yoshiki
2015/12/22 10:13:54
Done.
|
+ std::string notification_id_; |
+ |
+ // Stores on-going notification data during the image decoding. |
+ // This property will be removed after removing async task of image decoding. |
+ scoped_ptr<message_center::Notification> notification_; |
+ |
+ // The flag to indicate that the removing is initiated by the manager and we |
+ // don't need to notify a remove event to the manager. |
+ // This is true only when: |
+ // (1) the notification is being removed |
+ // (2) the removing is initiated by manager |
+ bool being_removed_by_manager_ = false; |
+ |
+ // Stores the latest notification data which is newer than the on-going data. |
+ // If the on-going data is either none or the latest, this is null. |
+ // This property will be removed after removing async task of image decoding. |
+ ArcNotificationDataPtr newer_data_; |
+ |
+ base::WeakPtrFactory<ArcNotificationItem> weak_ptr_factory_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(ArcNotificationItem); |
+}; |
+ |
+} // namespace arc |
+ |
+#endif // COMPONENTS_ARC_NOTIFICATION_ARC_NOTIFICATION_ITEM_H_ |