X-Git-Url: https://git.distorted.org.uk/~mdw/disorder/blobdiff_plain/d64e1d92acaf5a00908f630848f1f308574847ea..21fbc5f0250dbf954a098c488807a85749965700:/disobedience/disobedience.c?ds=inline diff --git a/disobedience/disobedience.c b/disobedience/disobedience.c index 96bf5c6..95949f6 100644 --- a/disobedience/disobedience.c +++ b/disobedience/disobedience.c @@ -44,6 +44,9 @@ GtkWidget *report_label; /** @brief Main tab group */ GtkWidget *tabs; +/** @brief Mini-mode widget for playing track */ +GtkWidget *playing_mini; + /** @brief Main client */ disorder_eclient *client; @@ -100,6 +103,10 @@ const char *server_version; /** @brief Parsed server version */ long server_version_bytes; +static GtkWidget *queue; + +static GtkWidget *notebook_box; + static void check_rtp_address(const char *event, void *eventdata, void *callbackdata); @@ -154,7 +161,7 @@ static GtkWidget *notebook(void) { * produces not too dreadful appearance */ gtk_widget_set_style(tabs, tool_style); g_signal_connect(tabs, "switch-page", G_CALLBACK(tab_switched), 0); - gtk_notebook_append_page(GTK_NOTEBOOK(tabs), queue_widget(), + gtk_notebook_append_page(GTK_NOTEBOOK(tabs), queue = queue_widget(), gtk_label_new("Queue")); gtk_notebook_append_page(GTK_NOTEBOOK(tabs), recent_widget(), gtk_label_new("Recent")); @@ -165,6 +172,20 @@ static GtkWidget *notebook(void) { return tabs; } +static void main_minimode(const char attribute((unused)) *event, + void attribute((unused)) *evendata, + void attribute((unused)) *callbackdata) { + if(full_mode) { + gtk_widget_show(tabs); + gtk_widget_hide(playing_mini); + /* Show the queue (bit confusing otherwise!) */ + gtk_notebook_set_current_page(GTK_NOTEBOOK(tabs), 0); + } else { + gtk_widget_hide(tabs); + gtk_widget_show(playing_mini); + } +} + /** @brief Create and populate the main window */ static void make_toplevel_window(void) { GtkWidget *const vbox = gtk_vbox_new(FALSE, 1); @@ -191,13 +212,22 @@ static void make_toplevel_window(void) { FALSE, /* expand */ FALSE, /* fill */ 0); - gtk_container_add(GTK_CONTAINER(vbox), notebook()); + playing_mini = playing_widget(); + gtk_box_pack_start(GTK_BOX(vbox), + playing_mini, + FALSE, + FALSE, + 0); + notebook_box = gtk_vbox_new(FALSE, 0); + gtk_container_add(GTK_CONTAINER(notebook_box), notebook()); + gtk_container_add(GTK_CONTAINER(vbox), notebook_box); gtk_box_pack_end(GTK_BOX(vbox), rb, FALSE, /* expand */ FALSE, /* fill */ 0); gtk_widget_set_style(toplevel, tool_style); + event_register("mini-mode-changed", main_minimode, 0); } static void userinfo_rights_completed(void attribute((unused)) *v, @@ -477,6 +507,7 @@ int main(int argc, char **argv) { /* reset styles now everything has its name */ gtk_rc_reset_styles(gtk_settings_get_for_screen(gdk_screen_get_default())); gtk_widget_show_all(toplevel); + gtk_widget_hide(playing_mini); /* issue a NOP every so often */ g_timeout_add_full(G_PRIORITY_LOW, 2000/*interval, ms*/,