From 4cb1d73a8358f660056156b5632e8c41659eb6e0 Mon Sep 17 00:00:00 2001 From: Dominik Heidler Date: Sat, 16 Apr 2016 16:29:32 +0200 Subject: Make tray icon configurable using /tray cmd --- src/command/command.c | 15 +++++++++++++++ src/command/commands.c | 21 +++++++++++++++++++++ src/command/commands.h | 3 +++ 3 files changed, 39 insertions(+) (limited to 'src/command') diff --git a/src/command/command.c b/src/command/command.c index 191415ae..e94d3406 100644 --- a/src/command/command.c +++ b/src/command/command.c @@ -1253,6 +1253,21 @@ static struct cmd_t command_defs[] = CMD_NOEXAMPLES }, +#ifdef HAVE_GTK + { "/tray", + cmd_tray, parse_args, 1, 1, &cons_tray_setting, + CMD_TAGS( + CMD_TAG_UI) + CMD_SYN( + "/tray on|off") + CMD_DESC( + "Display an icon in the tray that will indicate new messages.") + CMD_ARGS( + { "on|off", "Enable or disable tray icon." }) + CMD_NOEXAMPLES + }, +#endif + { "/intype", cmd_intype, parse_args, 1, 1, &cons_intype_setting, CMD_TAGS( diff --git a/src/command/commands.c b/src/command/commands.c index 8d32237b..b2795a43 100644 --- a/src/command/commands.c +++ b/src/command/commands.c @@ -77,6 +77,9 @@ #include "ui/ui.h" #include "window_list.h" #include "event/client_events.h" +#ifdef HAVE_GTK +#include "tray.h" +#endif static void _update_presence(const resource_presence_t presence, const char *const show, gchar **args); @@ -5525,6 +5528,24 @@ cmd_flash(ProfWin *window, const char *const command, gchar **args) return _cmd_set_boolean_preference(args[0], command, "Screen flash", PREF_FLASH); } +#ifdef HAVE_GTK +gboolean +cmd_tray(ProfWin *window, const char *const command, gchar **args) +{ + gboolean old = prefs_get_boolean(PREF_TRAY); + gboolean ret = _cmd_set_boolean_preference(args[0], command, "Tray icon", PREF_TRAY); + gboolean new = prefs_get_boolean(PREF_TRAY); + if (old != new) { + if (new) { + create_tray(); + } else { + destroy_tray(); + } + } + return ret; +} +#endif + gboolean cmd_intype(ProfWin *window, const char *const command, gchar **args) { diff --git a/src/command/commands.h b/src/command/commands.h index 3e1a4592..34c9cc49 100644 --- a/src/command/commands.h +++ b/src/command/commands.h @@ -89,6 +89,9 @@ gboolean cmd_lastactivity(ProfWin *window, const char *const command, gchar **ar gboolean cmd_disconnect(ProfWin *window, const char *const command, gchar **args); gboolean cmd_dnd(ProfWin *window, const char *const command, gchar **args); gboolean cmd_flash(ProfWin *window, const char *const command, gchar **args); +#ifdef HAVE_GTK +gboolean cmd_tray(ProfWin *window, const char *const command, gchar **args); +#endif gboolean cmd_gone(ProfWin *window, const char *const command, gchar **args); gboolean cmd_grlog(ProfWin *window, const char *const command, gchar **args); gboolean cmd_group(ProfWin *window, const char *const command, gchar **args); -- cgit 1.4.1-2-gfad0