diff options
Diffstat (limited to 'src/ui')
-rw-r--r-- | src/ui/console.c | 5 | ||||
-rw-r--r-- | src/ui/mucwin.c | 3 | ||||
-rw-r--r-- | src/ui/occupantswin.c | 74 | ||||
-rw-r--r-- | src/ui/win_types.h | 1 | ||||
-rw-r--r-- | src/ui/window.c | 5 |
5 files changed, 78 insertions, 10 deletions
diff --git a/src/ui/console.c b/src/ui/console.c index 190adeea..a2f5db60 100644 --- a/src/ui/console.c +++ b/src/ui/console.c @@ -1255,6 +1255,11 @@ cons_occupants_setting(void) else cons_show("Occupant jids (/occupants) : hide"); + if (prefs_get_boolean(PREF_OCCUPANTS_OFFLINE)) + cons_show("Occupants offline (/occupants) : show"); + else + cons_show("Occupants offline (/occupants) : hide"); + if (prefs_get_boolean(PREF_OCCUPANTS_WRAP)) cons_show("Occupants wrap (/occupants) : ON"); else diff --git a/src/ui/mucwin.c b/src/ui/mucwin.c index 808567f4..a3300ab4 100644 --- a/src/ui/mucwin.c +++ b/src/ui/mucwin.c @@ -34,6 +34,7 @@ * */ +#include "ui.h" #define _GNU_SOURCE 1 #include <string.h> @@ -67,6 +68,8 @@ mucwin_new(const char* const barejid) } #endif + // Force redraw here to show correct offline users; before this point muc_members returns a wrong list + ui_redraw_all_room_rosters(); return mucwin; } diff --git a/src/ui/occupantswin.c b/src/ui/occupantswin.c index 3bb95485..f72d1567 100644 --- a/src/ui/occupantswin.c +++ b/src/ui/occupantswin.c @@ -42,12 +42,15 @@ #include "ui/window_list.h" static void -_occuptantswin_occupant(ProfLayoutSplit* layout, Occupant* occupant, gboolean showjid) +_occuptantswin_occupant(ProfLayoutSplit* layout, GList* item, gboolean showjid, gboolean isoffline) { int colour = 0; //init to workaround compiler warning theme_item_t presence_colour = THEME_ROSTER_ONLINE; //init to workaround compiler warning + Occupant* occupant = item->data; - if (prefs_get_boolean(PREF_OCCUPANTS_COLOR_NICK)) { + if (isoffline) { + wattron(layout->subwin, theme_attrs(THEME_ROSTER_OFFLINE)); + } else if (prefs_get_boolean(PREF_OCCUPANTS_COLOR_NICK)) { colour = theme_hash_attrs(occupant->nick); wattron(layout->subwin, colour); @@ -79,12 +82,18 @@ _occuptantswin_occupant(ProfLayoutSplit* layout, Occupant* occupant, gboolean sh gboolean wrap = prefs_get_boolean(PREF_OCCUPANTS_WRAP); - g_string_append(msg, occupant->nick); + if (isoffline) { + Jid* jid = jid_create(item->data); + g_string_append(msg, jid->barejid); + jid_destroy(jid); + } else { + g_string_append(msg, occupant->nick); + } win_sub_newline_lazy(layout->subwin); win_sub_print(layout->subwin, msg->str, FALSE, wrap, current_indent); g_string_free(msg, TRUE); - if (showjid && occupant->jid) { + if (showjid && !isoffline && occupant->jid) { GString* msg = g_string_new(spaces->str); g_string_append(msg, " "); @@ -96,7 +105,9 @@ _occuptantswin_occupant(ProfLayoutSplit* layout, Occupant* occupant, gboolean sh g_string_free(spaces, TRUE); - if (prefs_get_boolean(PREF_OCCUPANTS_COLOR_NICK)) { + if (isoffline) { + wattroff(layout->subwin, theme_attrs(THEME_ROSTER_OFFLINE)); + } else if (prefs_get_boolean(PREF_OCCUPANTS_COLOR_NICK)) { wattroff(layout->subwin, colour); } else { wattroff(layout->subwin, theme_attrs(presence_colour)); @@ -124,6 +135,8 @@ occupantswin_occupants(const char* const roomjid) if (prefs_get_boolean(PREF_MUC_PRIVILEGES)) { + GList* online_occupants = { NULL }; + GString* role = g_string_new(prefix->str); g_string_append(role, "Moderators"); @@ -136,9 +149,10 @@ occupantswin_occupants(const char* const roomjid) while (roster_curr) { Occupant* occupant = roster_curr->data; if (occupant->role == MUC_ROLE_MODERATOR) { - _occuptantswin_occupant(layout, occupant, mucwin->showjid); + _occuptantswin_occupant(layout, roster_curr, mucwin->showjid, false); } roster_curr = g_list_next(roster_curr); + online_occupants = g_list_append(online_occupants, occupant->jid); } role = g_string_new(prefix->str); @@ -153,9 +167,10 @@ occupantswin_occupants(const char* const roomjid) while (roster_curr) { Occupant* occupant = roster_curr->data; if (occupant->role == MUC_ROLE_PARTICIPANT) { - _occuptantswin_occupant(layout, occupant, mucwin->showjid); + _occuptantswin_occupant(layout, roster_curr, mucwin->showjid, false); } roster_curr = g_list_next(roster_curr); + online_occupants = g_list_append(online_occupants, occupant->jid); } role = g_string_new(prefix->str); @@ -170,10 +185,50 @@ occupantswin_occupants(const char* const roomjid) while (roster_curr) { Occupant* occupant = roster_curr->data; if (occupant->role == MUC_ROLE_VISITOR) { - _occuptantswin_occupant(layout, occupant, mucwin->showjid); + _occuptantswin_occupant(layout, roster_curr, mucwin->showjid, false); } roster_curr = g_list_next(roster_curr); + online_occupants = g_list_append(online_occupants, occupant->jid); + } + + if (mucwin->showoffline) { + GList* members = muc_members(roomjid); + // offline_occupants is used to display the same account on multiple devices once + GList* offline_occupants = { NULL }; + + role = g_string_new(prefix->str); + g_string_append(role, "Offline"); + + wattron(layout->subwin, theme_attrs(THEME_OCCUPANTS_HEADER)); + win_sub_newline_lazy(layout->subwin); + win_sub_print(layout->subwin, role->str, TRUE, FALSE, 0); + wattroff(layout->subwin, theme_attrs(THEME_OCCUPANTS_HEADER)); + g_string_free(role, TRUE); + roster_curr = members; + while (roster_curr) { + Jid* jid = jid_create(roster_curr->data); + gboolean found = false; + GList* iter = online_occupants; + for (; iter != NULL; iter = iter->next) { + if (strstr(iter->data, jid->barejid)) { + found = true; + break; + } + } + + if (!found && g_list_index(offline_occupants, jid->barejid) == -1) { + _occuptantswin_occupant(layout, roster_curr, mucwin->showjid, true); + offline_occupants = g_list_append(offline_occupants, jid->barejid); + } + + jid_destroy(jid); + roster_curr = g_list_next(roster_curr); + } + g_list_free(members); + g_list_free(offline_occupants); } + g_list_free(online_occupants); + } else { GString* role = g_string_new(prefix->str); g_string_append(role, "Occupants\n"); @@ -186,8 +241,7 @@ occupantswin_occupants(const char* const roomjid) GList* roster_curr = occupants; while (roster_curr) { - Occupant* occupant = roster_curr->data; - _occuptantswin_occupant(layout, occupant, mucwin->showjid); + _occuptantswin_occupant(layout, roster_curr, mucwin->showjid, false); roster_curr = g_list_next(roster_curr); } } diff --git a/src/ui/win_types.h b/src/ui/win_types.h index 7beaca5f..e740b543 100644 --- a/src/ui/win_types.h +++ b/src/ui/win_types.h @@ -187,6 +187,7 @@ typedef struct prof_muc_win_t gboolean unread_mentions; gboolean unread_triggers; gboolean showjid; + gboolean showoffline; gboolean is_omemo; unsigned long memcheck; char* enctext; diff --git a/src/ui/window.c b/src/ui/window.c index 8afb23f4..b6676774 100644 --- a/src/ui/window.c +++ b/src/ui/window.c @@ -203,6 +203,11 @@ win_create_muc(const char* const roomjid) } else { new_win->showjid = FALSE; } + if (prefs_get_boolean(PREF_OCCUPANTS_OFFLINE)) { + new_win->showoffline = TRUE; + } else { + new_win->showoffline = FALSE; + } new_win->enctext = NULL; new_win->message_char = NULL; new_win->is_omemo = FALSE; |