aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCharles Kerr <charles.kerr@canonical.com>2016-02-01 18:05:45 -0600
committerRobert Tari <robert@tari.in>2021-06-30 02:03:35 +0200
commitb4ff1a2458802e3238d952c69f9dd664f013137b (patch)
tree8ec4e5d24a0aecc38a839bf8251f82928d5c31d4
parent1d0fd8903feb10941fc4d0ed387b0a1e2d8b35ae (diff)
downloadayatana-indicator-datetime-b4ff1a2458802e3238d952c69f9dd664f013137b.tar.gz
ayatana-indicator-datetime-b4ff1a2458802e3238d952c69f9dd664f013137b.tar.bz2
ayatana-indicator-datetime-b4ff1a2458802e3238d952c69f9dd664f013137b.zip
don't show calendar event notifications if com.ubuntu.calendar's notifications are blacklisted
-rw-r--r--include/datetime/settings.h1
-rw-r--r--src/snap.cpp17
2 files changed, 18 insertions, 0 deletions
diff --git a/include/datetime/settings.h b/include/datetime/settings.h
index 253a00a..d5e81c6 100644
--- a/include/datetime/settings.h
+++ b/include/datetime/settings.h
@@ -61,6 +61,7 @@ public:
core::Property<unsigned int> alarm_volume;
core::Property<unsigned int> alarm_duration;
core::Property<unsigned int> snooze_duration;
+ core::Property<std::set<std::pair<std::string,std::string>>> muted_apps;
};
} // namespace datetime
diff --git a/src/snap.cpp b/src/snap.cpp
index f0300af..934ad19 100644
--- a/src/snap.cpp
+++ b/src/snap.cpp
@@ -84,6 +84,12 @@ public:
appointment_func snooze,
appointment_func ok)
{
+ // If calendar notifications are muted, don't show them
+ if (!appointment.is_ubuntu_alarm() && calendar_events_are_muted()) {
+ g_debug("Skipping muted calendar event '%s' notification", appointment.summary.c_str());
+ return;
+ }
+
/* Alarms and calendar events are treated differently.
Alarms should require manual intervention to dismiss.
Calendar events are less urgent and shouldn't require manual
@@ -159,6 +165,17 @@ public:
private:
+ bool calendar_events_are_muted() const
+ {
+ for(const auto& app : m_settings->muted_apps.get()) {
+ if (app.first == "com.ubuntu.calendar") {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
static void on_sound_proxy_ready(GObject* /*source_object*/, GAsyncResult* res, gpointer gself)
{
GError * error;