mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Added typing notifications and related preferences
This commit is contained in:
parent
a7c7768778
commit
8b1653f707
@ -66,6 +66,7 @@ static gboolean _cmd_tiny(const char * const inp, struct cmd_help_t help);
|
|||||||
static gboolean _cmd_close(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_close(const char * const inp, struct cmd_help_t help);
|
||||||
static gboolean _cmd_set_beep(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_set_beep(const char * const inp, struct cmd_help_t help);
|
||||||
static gboolean _cmd_set_notify(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_set_notify(const char * const inp, struct cmd_help_t help);
|
||||||
|
static gboolean _cmd_set_typing(const char * const inp, struct cmd_help_t help);
|
||||||
static gboolean _cmd_set_flash(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_set_flash(const char * const inp, struct cmd_help_t help);
|
||||||
static gboolean _cmd_set_showsplash(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_set_showsplash(const char * const inp, struct cmd_help_t help);
|
||||||
static gboolean _cmd_set_chlog(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_set_chlog(const char * const inp, struct cmd_help_t help);
|
||||||
@ -207,6 +208,19 @@ static struct cmd_t setting_commands[] =
|
|||||||
"Config file value : notify=true|false",
|
"Config file value : notify=true|false",
|
||||||
NULL } } },
|
NULL } } },
|
||||||
|
|
||||||
|
{ "/typing",
|
||||||
|
_cmd_set_typing,
|
||||||
|
{ "/typing on|off", "Enable/disable typing notifications.",
|
||||||
|
{ "/typing on|off",
|
||||||
|
"--------------",
|
||||||
|
"Switch the typing notifications on or off for incoming messages",
|
||||||
|
"If desktop notifications are also enabled you will receive them",
|
||||||
|
"for typing notifications also.",
|
||||||
|
"",
|
||||||
|
"Config file section : [ui]",
|
||||||
|
"Config file value : typing=true|false",
|
||||||
|
NULL } } },
|
||||||
|
|
||||||
{ "/flash",
|
{ "/flash",
|
||||||
_cmd_set_flash,
|
_cmd_set_flash,
|
||||||
{ "/flash on|off", "Enable/disable screen flash notifications.",
|
{ "/flash on|off", "Enable/disable screen flash notifications.",
|
||||||
@ -696,6 +710,24 @@ _cmd_set_notify(const char * const inp, struct cmd_help_t help)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
_cmd_set_typing(const char * const inp, struct cmd_help_t help)
|
||||||
|
{
|
||||||
|
if (strcmp(inp, "/typing on") == 0) {
|
||||||
|
cons_show("Incoming typing notifications enabled.");
|
||||||
|
prefs_set_typing(TRUE);
|
||||||
|
} else if (strcmp(inp, "/typing off") == 0) {
|
||||||
|
cons_show("Incoming typing notifications disabled.");
|
||||||
|
prefs_set_typing(FALSE);
|
||||||
|
} else {
|
||||||
|
char usage[strlen(help.usage + 8)];
|
||||||
|
sprintf(usage, "Usage: %s", help.usage);
|
||||||
|
cons_show(usage);
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_cmd_set_flash(const char * const inp, struct cmd_help_t help)
|
_cmd_set_flash(const char * const inp, struct cmd_help_t help)
|
||||||
{
|
{
|
||||||
|
18
src/jabber.c
18
src/jabber.c
@ -259,18 +259,22 @@ _jabber_message_handler(xmpp_conn_t * const conn,
|
|||||||
|
|
||||||
// if no message, check for chatstates
|
// if no message, check for chatstates
|
||||||
if (body == NULL) {
|
if (body == NULL) {
|
||||||
if (xmpp_stanza_get_child_by_name(stanza, "active") != NULL) {
|
|
||||||
// active
|
if (prefs_get_typing()) {
|
||||||
} else if (xmpp_stanza_get_child_by_name(stanza, "composing") != NULL) {
|
if (xmpp_stanza_get_child_by_name(stanza, "active") != NULL) {
|
||||||
// composing
|
// active
|
||||||
char *from = xmpp_stanza_get_attribute(stanza, "from");
|
} else if (xmpp_stanza_get_child_by_name(stanza, "composing") != NULL) {
|
||||||
cons_show(from);
|
// composing
|
||||||
cons_show("is composing a message");
|
char *from = xmpp_stanza_get_attribute(stanza, "from");
|
||||||
|
win_show_typing(from);
|
||||||
|
win_page_off();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// message body recieved
|
||||||
char *type = xmpp_stanza_get_attribute(stanza, "type");
|
char *type = xmpp_stanza_get_attribute(stanza, "type");
|
||||||
if(strcmp(type, "error") == 0)
|
if(strcmp(type, "error") == 0)
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -206,6 +206,19 @@ prefs_set_notify(gboolean value)
|
|||||||
_save_prefs();
|
_save_prefs();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
prefs_get_typing(void)
|
||||||
|
{
|
||||||
|
return g_key_file_get_boolean(prefs, "ui", "typing", NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
prefs_set_typing(gboolean value)
|
||||||
|
{
|
||||||
|
g_key_file_set_boolean(prefs, "ui", "typing", value);
|
||||||
|
_save_prefs();
|
||||||
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
prefs_get_flash(void)
|
prefs_get_flash(void)
|
||||||
{
|
{
|
||||||
|
@ -35,6 +35,8 @@ gboolean prefs_get_beep(void);
|
|||||||
void prefs_set_beep(gboolean value);
|
void prefs_set_beep(gboolean value);
|
||||||
gboolean prefs_get_notify(void);
|
gboolean prefs_get_notify(void);
|
||||||
void prefs_set_notify(gboolean value);
|
void prefs_set_notify(gboolean value);
|
||||||
|
gboolean prefs_get_typing(void);
|
||||||
|
void prefs_set_typing(gboolean value);
|
||||||
gboolean prefs_get_flash(void);
|
gboolean prefs_get_flash(void);
|
||||||
void prefs_set_flash(gboolean value);
|
void prefs_set_flash(gboolean value);
|
||||||
gboolean prefs_get_chlog(void);
|
gboolean prefs_get_chlog(void);
|
||||||
|
1
src/ui.h
1
src/ui.h
@ -60,6 +60,7 @@ void title_bar_set_status(jabber_presence_t status);
|
|||||||
int win_close_win(void);
|
int win_close_win(void);
|
||||||
int win_in_chat(void);
|
int win_in_chat(void);
|
||||||
char *win_get_recipient(void);
|
char *win_get_recipient(void);
|
||||||
|
void win_show_typing(const char * const from);
|
||||||
void win_show_incomming_msg(const char * const from, const char * const message);
|
void win_show_incomming_msg(const char * const from, const char * const message);
|
||||||
void win_show_outgoing_msg(const char * const from, const char * const to,
|
void win_show_outgoing_msg(const char * const from, const char * const to,
|
||||||
const char * const message);
|
const char * const message);
|
||||||
|
@ -64,10 +64,12 @@ static void _current_window_refresh(void);
|
|||||||
static void _win_switch_if_active(const int i);
|
static void _win_switch_if_active(const int i);
|
||||||
static void _win_show_time(WINDOW *win);
|
static void _win_show_time(WINDOW *win);
|
||||||
static void _win_show_user(WINDOW *win, const char * const user, const int colour);
|
static void _win_show_user(WINDOW *win, const char * const user, const int colour);
|
||||||
|
static void _win_show_typing(WINDOW *win, const char * const short_from);
|
||||||
static void _win_show_message(WINDOW *win, const char * const message);
|
static void _win_show_message(WINDOW *win, const char * const message);
|
||||||
static void _show_status_string(WINDOW *win, const char * const from,
|
static void _show_status_string(WINDOW *win, const char * const from,
|
||||||
const char * const show, const char * const status, const char * const pre,
|
const char * const show, const char * const status, const char * const pre,
|
||||||
const char * const default_show);
|
const char * const default_show);
|
||||||
|
static void _cons_show_typing(const char * const short_from);
|
||||||
static void _cons_show_incoming_message(const char * const short_from,
|
static void _cons_show_incoming_message(const char * const short_from,
|
||||||
const int win_index);
|
const int win_index);
|
||||||
static void _win_handle_switch(const int * const ch);
|
static void _win_handle_switch(const int * const ch);
|
||||||
@ -75,7 +77,8 @@ static void _win_handle_page(const int * const ch);
|
|||||||
static void _win_resize_all(void);
|
static void _win_resize_all(void);
|
||||||
|
|
||||||
#ifdef HAVE_LIBNOTIFY
|
#ifdef HAVE_LIBNOTIFY
|
||||||
static void _win_notify(char * short_from);
|
static void _win_notify_message(char * short_from);
|
||||||
|
static void _win_notify_typing(char * short_from);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -180,6 +183,44 @@ win_get_recipient(void)
|
|||||||
return recipient;
|
return recipient;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
win_show_typing(const char * const from)
|
||||||
|
{
|
||||||
|
char from_cpy[strlen(from) + 1];
|
||||||
|
strcpy(from_cpy, from);
|
||||||
|
char *short_from = strtok(from_cpy, "/");
|
||||||
|
|
||||||
|
int win_index = _find_prof_win_index(short_from);
|
||||||
|
|
||||||
|
// no chat window for user
|
||||||
|
if (win_index == NUM_WINS) {
|
||||||
|
_cons_show_typing(short_from);
|
||||||
|
|
||||||
|
// have chat window but not currently in it
|
||||||
|
} else if (win_index != _curr_prof_win) {
|
||||||
|
WINDOW *win = _wins[win_index].win;
|
||||||
|
_win_show_time(win);
|
||||||
|
_win_show_typing(win, short_from);
|
||||||
|
_cons_show_typing(short_from);
|
||||||
|
status_bar_new(win_index);
|
||||||
|
dirty = TRUE;
|
||||||
|
|
||||||
|
// in chat window with user
|
||||||
|
} else {
|
||||||
|
WINDOW *win = _wins[win_index].win;
|
||||||
|
_win_show_time(win);
|
||||||
|
_win_show_typing(win, short_from);
|
||||||
|
|
||||||
|
status_bar_active(win_index);
|
||||||
|
dirty = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_LIBNOTIFY
|
||||||
|
if (prefs_get_notify())
|
||||||
|
_win_notify_typing(short_from);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
win_show_incomming_msg(const char * const from, const char * const message)
|
win_show_incomming_msg(const char * const from, const char * const message)
|
||||||
{
|
{
|
||||||
@ -211,19 +252,48 @@ win_show_incomming_msg(const char * const from, const char * const message)
|
|||||||
beep();
|
beep();
|
||||||
#ifdef HAVE_LIBNOTIFY
|
#ifdef HAVE_LIBNOTIFY
|
||||||
if (prefs_get_notify())
|
if (prefs_get_notify())
|
||||||
_win_notify(short_from);
|
_win_notify_message(short_from);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_LIBNOTIFY
|
#ifdef HAVE_LIBNOTIFY
|
||||||
static void
|
static void
|
||||||
_win_notify(char * short_from)
|
_win_notify_message(char * short_from)
|
||||||
{
|
{
|
||||||
notify_init("Profanity");
|
notify_init("Profanity");
|
||||||
|
|
||||||
|
char message[strlen(short_from) + 1 + 10];
|
||||||
|
sprintf(message, "%s: message.", short_from);
|
||||||
|
|
||||||
// create a new notification
|
// create a new notification
|
||||||
NotifyNotification *incoming;
|
NotifyNotification *incoming;
|
||||||
incoming = notify_notification_new("Profanity", short_from, NULL);
|
incoming = notify_notification_new("Profanity", message, NULL);
|
||||||
|
|
||||||
|
// set the timeout of the notification to 10 secs
|
||||||
|
notify_notification_set_timeout(incoming, 10000);
|
||||||
|
|
||||||
|
// 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_NORMAL);
|
||||||
|
|
||||||
|
GError *error = NULL;
|
||||||
|
notify_notification_show(incoming, &error);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_win_notify_typing(char * short_from)
|
||||||
|
{
|
||||||
|
notify_init("Profanity");
|
||||||
|
|
||||||
|
char message[strlen(short_from) + 1 + 11];
|
||||||
|
sprintf(message, "%s: typing...", short_from);
|
||||||
|
|
||||||
|
// create a new notification
|
||||||
|
NotifyNotification *incoming;
|
||||||
|
incoming = notify_notification_new("Profanity", message, NULL);
|
||||||
|
|
||||||
// set the timeout of the notification to 10 secs
|
// set the timeout of the notification to 10 secs
|
||||||
notify_notification_set_timeout(incoming, 10000);
|
notify_notification_set_timeout(incoming, 10000);
|
||||||
@ -359,6 +429,11 @@ cons_prefs(void)
|
|||||||
else
|
else
|
||||||
cons_show("Desktop notifications : OFF");
|
cons_show("Desktop notifications : OFF");
|
||||||
|
|
||||||
|
if (prefs_get_typing())
|
||||||
|
cons_show("Typing notifications : ON");
|
||||||
|
else
|
||||||
|
cons_show("Typing notifications : OFF");
|
||||||
|
|
||||||
if (prefs_get_showsplash())
|
if (prefs_get_showsplash())
|
||||||
cons_show("Splash screen : ON");
|
cons_show("Splash screen : ON");
|
||||||
else
|
else
|
||||||
@ -669,12 +744,16 @@ _win_show_user(WINDOW *win, const char * const user, const int colour)
|
|||||||
wattroff(win, COLOR_PAIR(2));
|
wattroff(win, COLOR_PAIR(2));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_win_show_typing(WINDOW *win, const char * const short_from)
|
||||||
|
{
|
||||||
|
wprintw(win, "%s is typing...\n", short_from);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_win_show_message(WINDOW *win, const char * const message)
|
_win_show_message(WINDOW *win, const char * const message)
|
||||||
{
|
{
|
||||||
// wattroff(win, A_BOLD);
|
|
||||||
wprintw(win, "%s\n", message);
|
wprintw(win, "%s\n", message);
|
||||||
// wattron(win, A_BOLD);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -740,6 +819,14 @@ _show_status_string(WINDOW *win, const char * const from,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_cons_show_typing(const char * const short_from)
|
||||||
|
{
|
||||||
|
_win_show_time(_cons_win);
|
||||||
|
wattron(_cons_win, COLOR_PAIR(7));
|
||||||
|
wprintw(_cons_win, "!! %s is typing a message...\n", short_from);
|
||||||
|
wattroff(_cons_win, COLOR_PAIR(7));
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_cons_show_incoming_message(const char * const short_from, const int win_index)
|
_cons_show_incoming_message(const char * const short_from, const int win_index)
|
||||||
|
Loading…
Reference in New Issue
Block a user