mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Unified desktop notification preferences
This commit is contained in:
parent
7ba66d7edb
commit
c71259c322
155
src/command.c
155
src/command.c
@ -71,12 +71,10 @@ 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);
|
||||||
static gboolean _cmd_set_history(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_set_history(const char * const inp, struct cmd_help_t help);
|
||||||
static gboolean _cmd_set_remind(const char * const inp, struct cmd_help_t help);
|
|
||||||
static gboolean _cmd_vercheck(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_vercheck(const char * const inp, struct cmd_help_t help);
|
||||||
static gboolean _cmd_away(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_away(const char * const inp, struct cmd_help_t help);
|
||||||
static gboolean _cmd_online(const char * const inp, struct cmd_help_t help);
|
static gboolean _cmd_online(const char * const inp, struct cmd_help_t help);
|
||||||
@ -221,40 +219,26 @@ static struct cmd_t setting_commands[] =
|
|||||||
|
|
||||||
{ "/notify",
|
{ "/notify",
|
||||||
_cmd_set_notify,
|
_cmd_set_notify,
|
||||||
{ "/notify on|off", "Desktop notifications for new messages.",
|
{ "/notify type value", "Control various desktop noficiations.",
|
||||||
{ "/notify on|off",
|
{ "/notify type value",
|
||||||
"--------------",
|
"------------------",
|
||||||
"Switch the message notifications on or off.",
|
"Settings for various desktop notifications where type is one of:",
|
||||||
"The notification will appear for all incoming messages.",
|
"message : Notificaitons for messages.",
|
||||||
"The desktop environment must support desktop notifications.",
|
" : on|off",
|
||||||
|
"remind : Notification reminders of unread messages.",
|
||||||
|
" : where value is the reminder period in seconds,",
|
||||||
|
" : use 0 to disable.",
|
||||||
|
"typing : Notifications when contacts are typing.",
|
||||||
|
" : on|off",
|
||||||
"",
|
"",
|
||||||
"Config file section : [ui]",
|
"Example : /notify message on (enable message notifications)",
|
||||||
"Config file value : notify=true|false",
|
"Example : /notify remind 10 (remind every 10 seconds)",
|
||||||
NULL } } },
|
"Example : /notify remind 0 (switch off reminders)",
|
||||||
|
"Example : /notify typing on (enable typing notifications)",
|
||||||
{ "/typing",
|
|
||||||
_cmd_set_typing,
|
|
||||||
{ "/typing on|off", "Show when contacts typing.",
|
|
||||||
{ "/typing on|off",
|
|
||||||
"--------------",
|
|
||||||
"Switch typing notifications on or off for incoming messages",
|
|
||||||
"If desktop notifications are also enabled you will receive them",
|
|
||||||
"for when users are typing a message to you.",
|
|
||||||
"",
|
"",
|
||||||
"Config file section : [ui]",
|
"Config file section : [notifications]",
|
||||||
"Config file value : typing=true|false",
|
"Config file value : message=on|off",
|
||||||
NULL } } },
|
"Config file value : typing=on|off",
|
||||||
|
|
||||||
{ "/remind",
|
|
||||||
_cmd_set_remind,
|
|
||||||
{ "/remind seconds", "Desktop notification reminder of unread messages.",
|
|
||||||
{ "/remind seconds",
|
|
||||||
"--------------",
|
|
||||||
"Set the period for new message reminders as desktop notifications.",
|
|
||||||
"The value is in seconds, a setting of 0 will disable the feature.",
|
|
||||||
"The desktop environment must support desktop notifications.",
|
|
||||||
"",
|
|
||||||
"Config file section : [ui]",
|
|
||||||
"Config file value : remind=seconds",
|
"Config file value : remind=seconds",
|
||||||
NULL } } },
|
NULL } } },
|
||||||
|
|
||||||
@ -847,15 +831,76 @@ _cmd_set_beep(const char * const inp, struct cmd_help_t help)
|
|||||||
static gboolean
|
static gboolean
|
||||||
_cmd_set_notify(const char * const inp, struct cmd_help_t help)
|
_cmd_set_notify(const char * const inp, struct cmd_help_t help)
|
||||||
{
|
{
|
||||||
return _cmd_set_boolean_preference(inp, help, "/notify",
|
char *kind = NULL;
|
||||||
"Desktop notifications", prefs_set_notify);
|
char *value = NULL;
|
||||||
|
|
||||||
|
// copy input
|
||||||
|
char inp_cpy[strlen(inp) + 1];
|
||||||
|
strcpy(inp_cpy, inp);
|
||||||
|
|
||||||
|
// get kind
|
||||||
|
strtok(inp_cpy, " ");
|
||||||
|
kind = strtok(NULL, " ");
|
||||||
|
if ((kind != NULL) && (strlen(inp) > (8 + strlen(kind) + 1))) {
|
||||||
|
if ((strcmp(kind, "message") != 0) &&
|
||||||
|
(strcmp(kind, "typing") != 0) &&
|
||||||
|
(strcmp(kind, "remind") != 0)) {
|
||||||
|
cons_show("Usage: %s", help.usage);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
} else {
|
||||||
|
// get value
|
||||||
|
value = strndup(inp+8+strlen(kind)+1, strlen(inp)-(8+strlen(kind)+1));
|
||||||
|
|
||||||
|
if (value != NULL) {
|
||||||
|
|
||||||
|
// set message setting
|
||||||
|
if (strcmp(kind, "message") == 0) {
|
||||||
|
if (strcmp(inp, "/notify message on") == 0) {
|
||||||
|
cons_show("Message notifications enabled.");
|
||||||
|
prefs_set_notify_message(TRUE);
|
||||||
|
} else if (strcmp(inp, "/notify message off") == 0) {
|
||||||
|
cons_show("Message notifications disabled.");
|
||||||
|
prefs_set_notify_message(FALSE);
|
||||||
|
} else {
|
||||||
|
cons_show("Usage: /notify message on|off");
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
// set typing setting
|
||||||
_cmd_set_typing(const char * const inp, struct cmd_help_t help)
|
} else if (strcmp(kind, "typing") == 0) {
|
||||||
{
|
if (strcmp(inp, "/notify typing on") == 0) {
|
||||||
return _cmd_set_boolean_preference(inp, help, "/typing",
|
cons_show("Typing notifications enabled.");
|
||||||
"Incoming typing notifications", prefs_set_typing);
|
prefs_set_notify_typing(TRUE);
|
||||||
|
} else if (strcmp(inp, "/notify typing off") == 0) {
|
||||||
|
cons_show("Typing notifications disabled.");
|
||||||
|
prefs_set_notify_typing(FALSE);
|
||||||
|
} else {
|
||||||
|
cons_show("Usage: /notify typing on|off");
|
||||||
|
}
|
||||||
|
|
||||||
|
} else { // remind
|
||||||
|
gint period = atoi(value);
|
||||||
|
|
||||||
|
prefs_set_notify_remind(period);
|
||||||
|
if (period == 0) {
|
||||||
|
cons_show("Message reminders disabled.");
|
||||||
|
} else if (period == 1) {
|
||||||
|
cons_show("Message reminder period set to 1 second.");
|
||||||
|
} else {
|
||||||
|
cons_show("Message reminder period set to %d seconds.", period);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
} else {
|
||||||
|
cons_show("Usage: %s", help.usage);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
cons_show("Usage: %s", help.usage);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
@ -898,34 +943,6 @@ _cmd_set_history(const char * const inp, struct cmd_help_t help)
|
|||||||
"Chat history", prefs_set_history);
|
"Chat history", prefs_set_history);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
|
||||||
_cmd_set_remind(const char * const inp, struct cmd_help_t help)
|
|
||||||
{
|
|
||||||
if ((strncmp(inp, "/remind ", 8) != 0) || (strlen(inp) < 9)) {
|
|
||||||
cons_show("Usage: %s", help.usage);
|
|
||||||
} else {
|
|
||||||
// copy input
|
|
||||||
char inp_cpy[strlen(inp) + 1];
|
|
||||||
strcpy(inp_cpy, inp);
|
|
||||||
|
|
||||||
// get period
|
|
||||||
strtok(inp_cpy, " ");
|
|
||||||
char *period_str = strtok(NULL, " ");
|
|
||||||
gint period = atoi(period_str);
|
|
||||||
|
|
||||||
prefs_set_remind(period);
|
|
||||||
if (period == 0) {
|
|
||||||
cons_show("Message reminders disabled.");
|
|
||||||
} else if (period == 1) {
|
|
||||||
cons_show("Message reminder period set to 1 second.");
|
|
||||||
} else {
|
|
||||||
cons_show("Message reminder period set to %d seconds.", period);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_cmd_away(const char * const inp, struct cmd_help_t help)
|
_cmd_away(const char * const inp, struct cmd_help_t help)
|
||||||
{
|
{
|
||||||
|
@ -290,7 +290,7 @@ _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 (prefs_get_typing()) {
|
if (prefs_get_notify_typing()) {
|
||||||
if (xmpp_stanza_get_child_by_name(stanza, "active") != NULL) {
|
if (xmpp_stanza_get_child_by_name(stanza, "active") != NULL) {
|
||||||
// active
|
// active
|
||||||
} else if (xmpp_stanza_get_child_by_name(stanza, "composing") != NULL) {
|
} else if (xmpp_stanza_get_child_by_name(stanza, "composing") != NULL) {
|
||||||
|
@ -236,28 +236,41 @@ prefs_set_beep(gboolean value)
|
|||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
prefs_get_notify(void)
|
prefs_get_notify_typing(void)
|
||||||
{
|
{
|
||||||
return g_key_file_get_boolean(prefs, "ui", "notify", NULL);
|
return g_key_file_get_boolean(prefs, "notifications", "typing", NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
prefs_set_notify(gboolean value)
|
prefs_set_notify_typing(gboolean value)
|
||||||
{
|
{
|
||||||
g_key_file_set_boolean(prefs, "ui", "notify", value);
|
g_key_file_set_boolean(prefs, "notifications", "typing", value);
|
||||||
_save_prefs();
|
_save_prefs();
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
prefs_get_typing(void)
|
prefs_get_notify_message(void)
|
||||||
{
|
{
|
||||||
return g_key_file_get_boolean(prefs, "ui", "typing", NULL);
|
return g_key_file_get_boolean(prefs, "notifications", "message", NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
prefs_set_typing(gboolean value)
|
prefs_set_notify_message(gboolean value)
|
||||||
{
|
{
|
||||||
g_key_file_set_boolean(prefs, "ui", "typing", value);
|
g_key_file_set_boolean(prefs, "notifications", "message", value);
|
||||||
|
_save_prefs();
|
||||||
|
}
|
||||||
|
|
||||||
|
gint
|
||||||
|
prefs_get_notify_remind(void)
|
||||||
|
{
|
||||||
|
return g_key_file_get_integer(prefs, "notifications", "remind", NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
prefs_set_notify_remind(gint value)
|
||||||
|
{
|
||||||
|
g_key_file_set_integer(prefs, "notifications", "remind", value);
|
||||||
_save_prefs();
|
_save_prefs();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -313,19 +326,6 @@ prefs_set_history(gboolean value)
|
|||||||
_save_prefs();
|
_save_prefs();
|
||||||
}
|
}
|
||||||
|
|
||||||
gint
|
|
||||||
prefs_get_remind(void)
|
|
||||||
{
|
|
||||||
return g_key_file_get_integer(prefs, "ui", "remind", NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
prefs_set_remind(gint value)
|
|
||||||
{
|
|
||||||
g_key_file_set_integer(prefs, "ui", "remind", value);
|
|
||||||
_save_prefs();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
prefs_add_login(const char *jid)
|
prefs_add_login(const char *jid)
|
||||||
{
|
{
|
||||||
|
@ -44,10 +44,6 @@ void prefs_reset_boolean_choice(void);
|
|||||||
|
|
||||||
gboolean prefs_get_beep(void);
|
gboolean prefs_get_beep(void);
|
||||||
void prefs_set_beep(gboolean value);
|
void prefs_set_beep(gboolean value);
|
||||||
gboolean prefs_get_notify(void);
|
|
||||||
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);
|
||||||
@ -56,11 +52,16 @@ gboolean prefs_get_history(void);
|
|||||||
void prefs_set_history(gboolean value);
|
void prefs_set_history(gboolean value);
|
||||||
gboolean prefs_get_showsplash(void);
|
gboolean prefs_get_showsplash(void);
|
||||||
void prefs_set_showsplash(gboolean value);
|
void prefs_set_showsplash(gboolean value);
|
||||||
gint prefs_get_remind(void);
|
|
||||||
void prefs_set_remind(gint value);
|
|
||||||
gboolean prefs_get_vercheck(void);
|
gboolean prefs_get_vercheck(void);
|
||||||
void prefs_set_vercheck(gboolean value);
|
void prefs_set_vercheck(gboolean value);
|
||||||
|
|
||||||
|
void prefs_set_notify_message(gboolean value);
|
||||||
|
gboolean prefs_get_notify_message(void);
|
||||||
|
void prefs_set_notify_typing(gboolean value);
|
||||||
|
gboolean prefs_get_notify_typing(void);
|
||||||
|
void prefs_set_notify_remind(gint period);
|
||||||
|
gint prefs_get_notify_remind(void);
|
||||||
|
|
||||||
void prefs_add_login(const char *jid);
|
void prefs_add_login(const char *jid);
|
||||||
|
|
||||||
NCURSES_COLOR_T prefs_get_bkgnd();
|
NCURSES_COLOR_T prefs_get_bkgnd();
|
||||||
|
@ -65,7 +65,7 @@ prof_run(const int disable_tls, char *log_level)
|
|||||||
|
|
||||||
gdouble elapsed = g_timer_elapsed(timer, NULL);
|
gdouble elapsed = g_timer_elapsed(timer, NULL);
|
||||||
|
|
||||||
gint remind_period = prefs_get_remind();
|
gint remind_period = prefs_get_notify_remind();
|
||||||
|
|
||||||
// 0 means to not remind
|
// 0 means to not remind
|
||||||
if (remind_period > 0 && elapsed >= remind_period) {
|
if (remind_period > 0 && elapsed >= remind_period) {
|
||||||
|
@ -241,7 +241,7 @@ win_show_typing(const char * const from)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_LIBNOTIFY
|
#ifdef HAVE_LIBNOTIFY
|
||||||
if (prefs_get_notify())
|
if (prefs_get_notify_typing())
|
||||||
_win_notify_typing(short_from);
|
_win_notify_typing(short_from);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -300,7 +300,7 @@ win_show_incomming_msg(const char * const from, const char * const message)
|
|||||||
if (prefs_get_beep())
|
if (prefs_get_beep())
|
||||||
beep();
|
beep();
|
||||||
#ifdef HAVE_LIBNOTIFY
|
#ifdef HAVE_LIBNOTIFY
|
||||||
if (prefs_get_notify())
|
if (prefs_get_notify_message())
|
||||||
_win_notify_message(short_from);
|
_win_notify_message(short_from);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -518,12 +518,12 @@ cons_prefs(void)
|
|||||||
else
|
else
|
||||||
cons_show("Terminal flash : OFF");
|
cons_show("Terminal flash : OFF");
|
||||||
|
|
||||||
if (prefs_get_notify())
|
if (prefs_get_notify_message())
|
||||||
cons_show("Message notifications : ON");
|
cons_show("Message notifications : ON");
|
||||||
else
|
else
|
||||||
cons_show("Message notifications : OFF");
|
cons_show("Message notifications : OFF");
|
||||||
|
|
||||||
if (prefs_get_typing())
|
if (prefs_get_notify_typing())
|
||||||
cons_show("Typing notifications : ON");
|
cons_show("Typing notifications : ON");
|
||||||
else
|
else
|
||||||
cons_show("Typing notifications : OFF");
|
cons_show("Typing notifications : OFF");
|
||||||
@ -548,7 +548,7 @@ cons_prefs(void)
|
|||||||
else
|
else
|
||||||
cons_show("Version checking : OFF");
|
cons_show("Version checking : OFF");
|
||||||
|
|
||||||
gint remind_period = prefs_get_remind();
|
gint remind_period = prefs_get_notify_remind();
|
||||||
if (remind_period == 0) {
|
if (remind_period == 0) {
|
||||||
cons_show("Message reminder period : OFF");
|
cons_show("Message reminder period : OFF");
|
||||||
} else if (remind_period == 1) {
|
} else if (remind_period == 1) {
|
||||||
|
Loading…
Reference in New Issue
Block a user