mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Show current window in status bar
This commit is contained in:
parent
2625630ff3
commit
6ff7177b9b
@ -596,6 +596,7 @@ ui_switch_win(const int i)
|
|||||||
|
|
||||||
if (i == 1) {
|
if (i == 1) {
|
||||||
title_bar_title();
|
title_bar_title();
|
||||||
|
status_bar_current(1);
|
||||||
status_bar_active(1);
|
status_bar_active(1);
|
||||||
} else {
|
} else {
|
||||||
PContact contact = roster_get_contact(new_current->from);
|
PContact contact = roster_get_contact(new_current->from);
|
||||||
@ -608,7 +609,8 @@ ui_switch_win(const int i)
|
|||||||
} else {
|
} else {
|
||||||
title_bar_set_recipient(new_current->from);
|
title_bar_set_recipient(new_current->from);
|
||||||
}
|
}
|
||||||
title_bar_draw();;
|
title_bar_draw();
|
||||||
|
status_bar_current(i);
|
||||||
status_bar_active(i);
|
status_bar_active(i);
|
||||||
}
|
}
|
||||||
wins_refresh_current();
|
wins_refresh_current();
|
||||||
@ -628,6 +630,7 @@ ui_next_win(void)
|
|||||||
|
|
||||||
if (i == 1) {
|
if (i == 1) {
|
||||||
title_bar_title();
|
title_bar_title();
|
||||||
|
status_bar_current(1);
|
||||||
status_bar_active(1);
|
status_bar_active(1);
|
||||||
} else {
|
} else {
|
||||||
PContact contact = roster_get_contact(new_current->from);
|
PContact contact = roster_get_contact(new_current->from);
|
||||||
@ -640,7 +643,8 @@ ui_next_win(void)
|
|||||||
} else {
|
} else {
|
||||||
title_bar_set_recipient(new_current->from);
|
title_bar_set_recipient(new_current->from);
|
||||||
}
|
}
|
||||||
title_bar_draw();;
|
title_bar_draw();
|
||||||
|
status_bar_current(i);
|
||||||
status_bar_active(i);
|
status_bar_active(i);
|
||||||
}
|
}
|
||||||
wins_refresh_current();
|
wins_refresh_current();
|
||||||
@ -659,6 +663,7 @@ ui_previous_win(void)
|
|||||||
|
|
||||||
if (i == 1) {
|
if (i == 1) {
|
||||||
title_bar_title();
|
title_bar_title();
|
||||||
|
status_bar_current(1);
|
||||||
status_bar_active(1);
|
status_bar_active(1);
|
||||||
} else {
|
} else {
|
||||||
PContact contact = roster_get_contact(new_current->from);
|
PContact contact = roster_get_contact(new_current->from);
|
||||||
@ -671,7 +676,8 @@ ui_previous_win(void)
|
|||||||
} else {
|
} else {
|
||||||
title_bar_set_recipient(new_current->from);
|
title_bar_set_recipient(new_current->from);
|
||||||
}
|
}
|
||||||
title_bar_draw();;
|
title_bar_draw();
|
||||||
|
status_bar_current(i);
|
||||||
status_bar_active(i);
|
status_bar_active(i);
|
||||||
}
|
}
|
||||||
wins_refresh_current();
|
wins_refresh_current();
|
||||||
@ -689,6 +695,7 @@ ui_close_current(void)
|
|||||||
int current_index = wins_get_current_num();
|
int current_index = wins_get_current_num();
|
||||||
status_bar_inactive(current_index);
|
status_bar_inactive(current_index);
|
||||||
wins_close_current();
|
wins_close_current();
|
||||||
|
status_bar_current(1);
|
||||||
status_bar_active(1);
|
status_bar_active(1);
|
||||||
title_bar_title();
|
title_bar_title();
|
||||||
}
|
}
|
||||||
@ -697,6 +704,7 @@ void
|
|||||||
ui_close_win(int index)
|
ui_close_win(int index)
|
||||||
{
|
{
|
||||||
wins_close_by_num(index);
|
wins_close_by_num(index);
|
||||||
|
status_bar_current(1);
|
||||||
status_bar_active(1);
|
status_bar_active(1);
|
||||||
title_bar_title();
|
title_bar_title();
|
||||||
|
|
||||||
|
@ -39,12 +39,14 @@ static WINDOW *status_bar;
|
|||||||
static char *message = NULL;
|
static char *message = NULL;
|
||||||
// 1 2 3 4 5 6 7 8 9 0 >
|
// 1 2 3 4 5 6 7 8 9 0 >
|
||||||
static char _active[34] = "[ ][ ][ ][ ][ ][ ][ ][ ][ ][ ][ ]";
|
static char _active[34] = "[ ][ ][ ][ ][ ][ ][ ][ ][ ][ ][ ]";
|
||||||
|
static char *bracket = "- -";
|
||||||
static int is_active[12];
|
static int is_active[12];
|
||||||
static GHashTable *remaining_active;
|
static GHashTable *remaining_active;
|
||||||
static int is_new[12];
|
static int is_new[12];
|
||||||
static GHashTable *remaining_new;
|
static GHashTable *remaining_new;
|
||||||
static int dirty;
|
static int dirty;
|
||||||
static GDateTime *last_time;
|
static GDateTime *last_time;
|
||||||
|
static int current;
|
||||||
|
|
||||||
static void _status_bar_update_time(void);
|
static void _status_bar_update_time(void);
|
||||||
static void _update_win_statuses(void);
|
static void _update_win_statuses(void);
|
||||||
@ -66,11 +68,13 @@ create_status_bar(void)
|
|||||||
}
|
}
|
||||||
remaining_active = g_hash_table_new_full(g_direct_hash, g_direct_equal, NULL, NULL);
|
remaining_active = g_hash_table_new_full(g_direct_hash, g_direct_equal, NULL, NULL);
|
||||||
remaining_new = g_hash_table_new_full(g_direct_hash, g_direct_equal, NULL, NULL);
|
remaining_new = g_hash_table_new_full(g_direct_hash, g_direct_equal, NULL, NULL);
|
||||||
|
current = 1;
|
||||||
|
|
||||||
status_bar = newwin(1, cols, rows-2, 0);
|
status_bar = newwin(1, cols, rows-2, 0);
|
||||||
wbkgd(status_bar, COLOUR_STATUS_TEXT);
|
wbkgd(status_bar, COLOUR_STATUS_TEXT);
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 34, _active);
|
mvwprintw(status_bar, 0, cols - 34, _active);
|
||||||
|
mvwprintw(status_bar, 0, cols - 34 + ((current - 1) * 3), bracket);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
if (last_time != NULL)
|
if (last_time != NULL)
|
||||||
@ -116,6 +120,7 @@ status_bar_resize(void)
|
|||||||
werase(status_bar);
|
werase(status_bar);
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 34, _active);
|
mvwprintw(status_bar, 0, cols - 34, _active);
|
||||||
|
mvwprintw(status_bar, 0, cols - 34 + ((current - 1) * 3), bracket);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
_update_win_statuses();
|
_update_win_statuses();
|
||||||
@ -143,6 +148,23 @@ status_bar_set_all_inactive(void)
|
|||||||
g_hash_table_remove_all(remaining_new);
|
g_hash_table_remove_all(remaining_new);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
status_bar_current(int i)
|
||||||
|
{
|
||||||
|
if (i == 0) {
|
||||||
|
current = 10;
|
||||||
|
} else if (i > 10) {
|
||||||
|
current = 11;
|
||||||
|
} else {
|
||||||
|
current = i;
|
||||||
|
}
|
||||||
|
int cols = getmaxx(stdscr);
|
||||||
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
mvwprintw(status_bar, 0, cols - 34, _active);
|
||||||
|
mvwprintw(status_bar, 0, cols - 34 + ((current - 1) * 3), bracket);
|
||||||
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
status_bar_inactive(const int win)
|
status_bar_inactive(const int win)
|
||||||
{
|
{
|
||||||
@ -263,6 +285,7 @@ status_bar_print_message(const char * const msg)
|
|||||||
|
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 34, _active);
|
mvwprintw(status_bar, 0, cols - 34, _active);
|
||||||
|
mvwprintw(status_bar, 0, cols - 34 + ((current - 1) * 3), bracket);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
_update_win_statuses();
|
_update_win_statuses();
|
||||||
@ -291,6 +314,7 @@ status_bar_clear(void)
|
|||||||
|
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 34, _active);
|
mvwprintw(status_bar, 0, cols - 34, _active);
|
||||||
|
mvwprintw(status_bar, 0, cols - 34 + ((current - 1) * 3), bracket);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
dirty = TRUE;
|
dirty = TRUE;
|
||||||
@ -310,6 +334,7 @@ status_bar_clear_message(void)
|
|||||||
|
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 34, _active);
|
mvwprintw(status_bar, 0, cols - 34, _active);
|
||||||
|
mvwprintw(status_bar, 0, cols - 34 + ((current - 1) * 3), bracket);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
_update_win_statuses();
|
_update_win_statuses();
|
||||||
|
@ -228,6 +228,7 @@ void status_bar_active(const int win);
|
|||||||
void status_bar_new(const int win);
|
void status_bar_new(const int win);
|
||||||
void status_bar_update_time(void);
|
void status_bar_update_time(void);
|
||||||
void status_bar_set_all_inactive(void);
|
void status_bar_set_all_inactive(void);
|
||||||
|
void status_bar_current(int i);
|
||||||
|
|
||||||
// input window actions
|
// input window actions
|
||||||
wint_t inp_get_char(char *input, int *size);
|
wint_t inp_get_char(char *input, int *size);
|
||||||
|
Loading…
Reference in New Issue
Block a user