Index: chrome/browser/notifications/native_notification_display_service.h |
diff --git a/chrome/browser/notifications/native_notification_display_service.h b/chrome/browser/notifications/native_notification_display_service.h |
index 37989383a1d846ec7f50254d7cc3ece8e25acc9b..0cb5cd95e189107084b7e706af91b8f40b76e980 100644 |
--- a/chrome/browser/notifications/native_notification_display_service.h |
+++ b/chrome/browser/notifications/native_notification_display_service.h |
@@ -5,12 +5,17 @@ |
#ifndef CHROME_BROWSER_NOTIFICATIONS_NATIVE_NOTIFICATION_DISPLAY_SERVICE_H_ |
#define CHROME_BROWSER_NOTIFICATIONS_NATIVE_NOTIFICATION_DISPLAY_SERVICE_H_ |
+#include <map> |
+#include <memory> |
#include <set> |
#include <string> |
+ |
#include "base/macros.h" |
+#include "chrome/browser/notifications/notification_common.h" |
#include "chrome/browser/notifications/notification_display_service.h" |
class Notification; |
+class NotificationHandler; |
class NotificationPlatformBridge; |
class Profile; |
@@ -24,15 +29,38 @@ class NativeNotificationDisplayService : public NotificationDisplayService { |
~NativeNotificationDisplayService() override; |
// NotificationDisplayService implementation. |
- void Display(const std::string& notification_id, |
+ void Display(NotificationCommon::Type notification_type, |
+ const std::string& notification_id, |
const Notification& notification) override; |
- void Close(const std::string& notification_id) override; |
+ void Close(NotificationCommon::Type notification_type, |
+ const std::string& notification_id) override; |
bool GetDisplayed(std::set<std::string>* notifications) const override; |
+ |
Peter Beverloo
2016/07/05 23:44:17
micro nit: no new line (the comment at 31 starts a
Miguel Garcia
2016/07/07 11:02:29
Done.
|
bool SupportsNotificationCenter() const override; |
+ // Used by the notification bridge to propagate back events (click, close...) |
+ void ProcessNotificationOperation(NotificationCommon::Operation operation, |
+ NotificationCommon::Type notification_type, |
+ const std::string& origin, |
+ const std::string& notification_id, |
+ int action_index); |
+ |
+ // Registers an implementation object to handle notification operations |
+ // for |notification_type| |
+ void AddNotificationHandler(NotificationCommon::Type notification_type, |
+ std::unique_ptr<NotificationHandler> handler); |
+ |
+ // Removes an implementation added via |AddNotificationHandler| |
Peter Beverloo
2016/07/05 23:44:17
nit: finish the comments with periods on lines 41,
Miguel Garcia
2016/07/07 11:02:29
Done.
|
+ void RemoveNotificationHandler(NotificationCommon::Type notification_type); |
+ |
private: |
+ NotificationHandler* GetNotificationHandler( |
+ NotificationCommon::Type notification_type); |
+ |
Profile* profile_; |
NotificationPlatformBridge* notification_bridge_; |
+ std::map<NotificationCommon::Type, std::unique_ptr<NotificationHandler>> |
+ notification_handlers_; |
DISALLOW_COPY_AND_ASSIGN(NativeNotificationDisplayService); |
}; |