Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Unified Diff: include/AdblockPlus/Notification.h

Issue 5797488346791936: Issue 1107 - Support notifications (Closed)
Patch Set: move MarkAsShown into Notification class and get rid of locale arg in Notification::GetTexts Created Jan. 22, 2015, 10:02 a.m.
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: include/AdblockPlus/Notification.h
diff --git a/include/AdblockPlus/Notification.h b/include/AdblockPlus/Notification.h
new file mode 100644
index 0000000000000000000000000000000000000000..e8b7078adba2b1e830cf16e8b2acca633b0149c2
--- /dev/null
+++ b/include/AdblockPlus/Notification.h
@@ -0,0 +1,67 @@
+/*
+ * This file is part of Adblock Plus <https://adblockplus.org/>,
+ * Copyright (C) 2006-2015 Eyeo GmbH
+ *
+ * Adblock Plus is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 3 as
+ * published by the Free Software Foundation.
+ *
+ * Adblock Plus is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef ADBLOCK_PLUS_NOTIFICATION_H
+#define ADBLOCK_PLUS_NOTIFICATION_H
+
+#include <string>
+#include <vector>
+#include <memory>
+
+namespace AdblockPlus
+{
+ class FilterEngine;
+ enum NotificationType
+ {
+ NOTIFICATION_TYPE_INFORMATION = 0,
Felix Dahlke 2015/01/22 10:25:25 Why explicitly assign the values here? We typicall
sergei 2015/01/22 14:08:15 fixed
+ NOTIFICATION_TYPE_QUESTION = 1,
Felix Dahlke 2015/01/22 10:25:25 No column aligning please :D
+ NOTIFICATION_TYPE_CRITICAL = 2
+ };
+
+ struct NotificationTexts
Felix Dahlke 2015/01/22 10:25:25 It's a single one, so "NotificationText"?
sergei 2015/01/22 14:08:15 Actually there were two fields and the plural form
Felix Dahlke 2015/01/22 14:36:31 Argh you're right, of course it's two. Should real
+ {
+ std::string title;
+ std::string message;
+ };
+
+ class Notification : public JsValue, public std::tr1::enable_shared_from_this<Notification>
+ {
+ friend class FilterEngine;
+ protected:
+ struct PrivateCtrArg{};
Felix Dahlke 2015/01/22 10:25:25 I still find this pattern highly obscure. We've go
sergei 2015/01/22 14:08:15 JIC, if the constructor is not public then std::ma
+ static std::tr1::shared_ptr<Notification> JsValueToNotification(const JsValuePtr& jsValue);
+ /// @param jsText is javascript object returned by getLocalizedTexts.
+ static NotificationTexts JsTextsToNotificationTexts(const JsValue& jsText);
+ public:
+ Notification(NotificationType type, const std::string& id, const JsValuePtr& jsValue, PrivateCtrArg);
+ Notification(const JsValuePtr& value, PrivateCtrArg);
+ std::string GetId() const;
Wladimir Palant 2015/01/22 10:47:20 I think this method should be removed. The ID is a
sergei 2015/01/22 14:08:15 removed
+ NotificationType GetType() const;
+ /**
+ * Localizes the texts of the supplied notification.
+ * @return the translated texts.
+ */
+ NotificationTexts GetTexts();
Wladimir Palant 2015/01/22 10:47:20 An explicit method here shouldn't be necessary. Th
sergei 2015/01/22 14:08:15 fixed
Felix Dahlke 2015/01/23 21:27:50 Missed this discussion before. I actually disagree
+ void SetTitle(const std::string& value);
+ void SetMessage(const std::string& value);
+ std::vector<std::string> GetUrlFilters() const;
+ void AddUrlFilter(const std::string& value);
Wladimir Palant 2015/01/22 10:47:20 The four methods above should be removed - as disc
sergei 2015/01/22 14:08:15 fixed
+ void MarkAsShown();
+ };
+}
+
+#endif

Powered by Google App Engine
This is Rietveld