1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

Attention flag for groupchats

Attention flag for groupchat and display the windows via "/wins attention"
This commit is contained in:
DebXWoody 2021-05-29 09:30:13 +02:00
parent 3520645366
commit 6dd11f0fff
No known key found for this signature in database
GPG Key ID: CBD1B596579B7FFF
8 changed files with 80 additions and 3 deletions

View File

@ -1301,7 +1301,7 @@ cmd_wins_unread(ProfWin* window, const char* const command, gchar** args)
gboolean gboolean
cmd_wins_attention(ProfWin* window, const char* const command, gchar** args) cmd_wins_attention(ProfWin* window, const char* const command, gchar** args)
{ {
cons_show_wins(TRUE); cons_show_wins_attention();
return TRUE; return TRUE;
} }

View File

@ -506,6 +506,26 @@ cons_show_wins(gboolean unread)
cons_alert(NULL); cons_alert(NULL);
} }
void
cons_show_wins_attention() {
ProfWin* console = wins_get_console();
cons_show("");
GSList* window_strings = wins_create_summary_attention();
GSList* curr = window_strings;
while (curr) {
if (g_strstr_len(curr->data, strlen(curr->data), " unread") > 0) {
win_println(console, THEME_CMD_WINS_UNREAD, "-", "%s", curr->data);
} else {
win_println(console, THEME_DEFAULT, "-", "%s", curr->data);
}
curr = g_slist_next(curr);
}
g_slist_free_full(window_strings, free);
cons_alert(NULL);
}
void void
cons_show_room_invites(GList* invites) cons_show_room_invites(GList* invites)
{ {

View File

@ -36,6 +36,7 @@
#define _XOPEN_SOURCE_EXTENDED #define _XOPEN_SOURCE_EXTENDED
#include "config.h" #include "config.h"
#include <assert.h>
#include <stdio.h> #include <stdio.h>
#include <sys/select.h> #include <sys/select.h>
#include <stdlib.h> #include <stdlib.h>
@ -814,8 +815,15 @@ static int
_inp_rl_win_attention_handler(int count, int key) { _inp_rl_win_attention_handler(int count, int key) {
ProfWin* current = wins_get_current(); ProfWin* current = wins_get_current();
if ( current ) { if ( current ) {
ProfChatWin* chatwin = (ProfChatWin*)current; if (current->type == WIN_CHAT) {
chatwin->has_attention = !chatwin->has_attention; ProfChatWin* chatwin = (ProfChatWin*)current;
assert(chatwin->memcheck == PROFCHATWIN_MEMCHECK);
chatwin->has_attention = !chatwin->has_attention;
} else if (current->type == WIN_MUC) {
ProfMucWin* mucwin = (ProfMucWin*)current;
assert(mucwin->memcheck == PROFMUCWIN_MEMCHECK);
mucwin->has_attention = !mucwin->has_attention;
}
win_redraw(current); win_redraw(current);
} }
return 0; return 0;

View File

@ -256,6 +256,7 @@ void cons_show_contacts(GSList* list);
void cons_show_roster(GSList* list); void cons_show_roster(GSList* list);
void cons_show_roster_group(const char* const group, GSList* list); void cons_show_roster_group(const char* const group, GSList* list);
void cons_show_wins(gboolean unread); void cons_show_wins(gboolean unread);
void cons_show_wins_attention();
char* cons_get_string(ProfConsoleWin* conswin); char* cons_get_string(ProfConsoleWin* conswin);
void cons_show_status(const char* const barejid); void cons_show_status(const char* const barejid);
void cons_show_info(PContact pcontact); void cons_show_info(PContact pcontact);

View File

@ -197,6 +197,7 @@ typedef struct prof_muc_win_t
// For LMC // For LMC
char* last_message; char* last_message;
char* last_msg_id; char* last_msg_id;
gboolean has_attention;
} ProfMucWin; } ProfMucWin;
typedef struct prof_conf_win_t ProfConfWin; typedef struct prof_conf_win_t ProfConfWin;

View File

@ -213,6 +213,7 @@ win_create_muc(const char* const roomjid)
new_win->is_omemo = FALSE; new_win->is_omemo = FALSE;
new_win->last_message = NULL; new_win->last_message = NULL;
new_win->last_msg_id = NULL; new_win->last_msg_id = NULL;
new_win->has_attention = FALSE;
new_win->memcheck = PROFMUCWIN_MEMCHECK; new_win->memcheck = PROFMUCWIN_MEMCHECK;

View File

@ -1102,6 +1102,51 @@ wins_create_summary(gboolean unread)
return result; return result;
} }
GSList*
wins_create_summary_attention()
{
GSList* result = NULL;
GList* keys = g_hash_table_get_keys(windows);
keys = g_list_sort(keys, _wins_cmp_num);
GList* curr = keys;
while (curr) {
ProfWin* window = g_hash_table_lookup(windows, curr->data);
gboolean has_attention = FALSE;
if (window->type == WIN_CHAT) {
ProfChatWin* chatwin = (ProfChatWin*)window;
assert(chatwin->memcheck == PROFCHATWIN_MEMCHECK);
has_attention = chatwin->has_attention;
} else if (window->type == WIN_MUC) {
ProfMucWin* mucwin = (ProfMucWin*)window;
assert(mucwin->memcheck == PROFMUCWIN_MEMCHECK);
has_attention = mucwin->has_attention;
}
if ( has_attention) {
GString* line = g_string_new("");
int ui_index = GPOINTER_TO_INT(curr->data);
char* winstring = win_to_string(window);
if (!winstring) {
g_string_free(line, TRUE);
continue;
}
g_string_append_printf(line, "%d: %s", ui_index, winstring);
free(winstring);
result = g_slist_append(result, strdup(line->str));
g_string_free(line, TRUE);
}
curr = g_list_next(curr);
}
g_list_free(keys);
return result;
}
char* char*
win_autocomplete(const char* const search_str, gboolean previous, void* context) win_autocomplete(const char* const search_str, gboolean previous, void* context)
{ {

View File

@ -87,6 +87,7 @@ void wins_lost_connection(void);
void wins_reestablished_connection(void); void wins_reestablished_connection(void);
gboolean wins_tidy(void); gboolean wins_tidy(void);
GSList* wins_create_summary(gboolean unread); GSList* wins_create_summary(gboolean unread);
GSList* wins_create_summary_attention();
void wins_destroy(void); void wins_destroy(void);
GList* wins_get_nums(void); GList* wins_get_nums(void);
void wins_swap(int source_win, int target_win); void wins_swap(int source_win, int target_win);