From 18494c3701334bb64756f218095b6003039c8169 Mon Sep 17 00:00:00 2001 From: James Booth Date: Thu, 28 Jun 2012 23:29:46 +0100 Subject: Added desktop notification --- windows.c | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) (limited to 'windows.c') diff --git a/windows.c b/windows.c index 11bd97e4..76cb2781 100644 --- a/windows.c +++ b/windows.c @@ -25,6 +25,7 @@ #include #include +#include #include "ui.h" #include "util.h" @@ -67,6 +68,7 @@ static void _cons_show_incoming_message(const char * const short_from, static void _win_handle_switch(const int * const ch); static void _win_handle_page(const int * const ch); static void _win_resize_all(void); +static void _win_notify(char * short_from); void gui_init(void) { @@ -186,12 +188,36 @@ void win_show_incomming_msg(const char * const from, const char * const message) _cons_show_incoming_message(short_from, win_index); if (prefs_get_flash()) flash(); + + _win_notify(short_from); } if (prefs_get_beep()) beep(); } +static void _win_notify(char * short_from) +{ + notify_init("Profanity"); + + // create a new notification + NotifyNotification *incoming; + incoming = notify_notification_new("Profanity", short_from, NULL); + + // set the timeout of the notification to 3 secs + notify_notification_set_timeout(incoming, 3000); + + // set the category so as to tell what kind it is + char category[30] = "Incoming message"; + notify_notification_set_category(incoming, category); + + // set the urgency level of the notification + notify_notification_set_urgency (incoming, NOTIFY_URGENCY_CRITICAL); + + GError *error = NULL; + notify_notification_show(incoming, &error); +} + void win_show_outgoing_msg(const char * const from, const char * const to, const char * const message) { -- cgit 1.4.1-2-gfad0