Add status indicator for showing ignored messages

weechat-hashes
C. McEnroe 2020-04-15 15:54:55 -04:00
parent 9bc52d7238
commit 470dee97c3
1 changed files with 10 additions and 3 deletions

13
ui.c
View File

@ -434,9 +434,10 @@ static void statusUpdate(void) {
int truncUnread, truncScroll; int truncUnread, truncScroll;
char buf[256]; char buf[256];
snprintf( snprintf(
buf, sizeof(buf), "\3%d%s %u %s %n(\3%02d%d\3%d) %n[%d] ", buf, sizeof(buf), "\3%d%s %u%s %s %n(\3%02d%d\3%d) %n[%d] ",
idColors[window->id], (num == windows.show ? "\26" : ""), idColors[window->id], (num == windows.show ? "\26" : ""),
num, idNames[window->id], num, (window->ignore ? "" : "-"),
idNames[window->id],
&truncUnread, (window->heat > Warm ? White : idColors[window->id]), &truncUnread, (window->heat > Warm ? White : idColors[window->id]),
window->unreadWarm, window->unreadWarm,
idColors[window->id], idColors[window->id],
@ -864,6 +865,12 @@ void uiCloseNum(uint num) {
if (num < windows.len) windowClose(num); if (num < windows.len) windowClose(num);
} }
static void toggleIgnore(struct Window *window) {
window->ignore ^= true;
reflow(window);
statusUpdate();
}
static void showAuto(void) { static void showAuto(void) {
static uint swap; static uint swap;
if (windows.swap != swap) { if (windows.swap != swap) {
@ -903,7 +910,7 @@ static void keyCode(int code) {
break; case KeyFocusOut: mark(window); break; case KeyFocusOut: mark(window);
break; case KeyMetaEnter: edit(id, EditInsert, L'\n'); break; case KeyMetaEnter: edit(id, EditInsert, L'\n');
break; case KeyMetaMinus: window->ignore ^= true; reflow(window); break; case KeyMetaMinus: toggleIgnore(window);
break; case KeyMetaSlash: windowShow(windows.swap); break; case KeyMetaSlash: windowShow(windows.swap);
break; case KeyMetaGt: windowScroll(window, -WindowLines); break; case KeyMetaGt: windowScroll(window, -WindowLines);