diff options
author | Patrick McDermott <pj@pehjota.net> | 2017-09-19 05:34:23 (EDT) |
---|---|---|
committer | Patrick McDermott <pj@pehjota.net> | 2017-09-19 05:34:23 (EDT) |
commit | 82896907ca9402fef0bc90ff1d1c8cdeb16c3c53 (patch) | |
tree | 543d4b1a3a066374967548d3dfc76256b4953681 /src | |
parent | 2ad6e3a956a674a62cd477e8320e4fdb98b92ff0 (diff) | |
download | marquee-82896907ca9402fef0bc90ff1d1c8cdeb16c3c53.zip marquee-82896907ca9402fef0bc90ff1d1c8cdeb16c3c53.tar.gz marquee-82896907ca9402fef0bc90ff1d1c8cdeb16c3c53.tar.bz2 |
src/window.c: Add tab popover/context menu
The buttons don't do anything yet.
Diffstat (limited to 'src')
-rw-r--r-- | src/window.c | 76 |
1 files changed, 75 insertions, 1 deletions
diff --git a/src/window.c b/src/window.c index 5c903c2..37c1f8f 100644 --- a/src/window.c +++ b/src/window.c @@ -26,6 +26,72 @@ #include "window.h" #include "tab.h" +#define NEW_BUTTON(BOX, I, NAME, TOOLTIP) \ + do { \ + buttons[I] = gtk_button_new_from_icon_name(NAME, \ + GTK_ICON_SIZE_BUTTON); \ + gtk_widget_set_tooltip_text(buttons[I], TOOLTIP); \ + gtk_box_pack_start(GTK_BOX(BOX ? all_tabs_button_box : \ + current_tab_button_box), buttons[I], \ + TRUE, FALSE, 0); \ + } while (0) + +static gboolean +tab_label_button_press_cb(GtkWidget *widget, GdkEvent *event, MqTab *tab) +{ + GtkWidget *current_tab_button_box; + GtkWidget *all_tabs_button_box; + GtkWidget *buttons[7]; + GtkWidget *button_rows_box; + GtkWidget *stack; + GtkWidget *popover; + + /* Make sure this is a right mouse button press event. */ + if (event->type != GDK_BUTTON_PRESS || event->button.button != 3) { + return FALSE; + } + + /* Set up button boxes. */ + current_tab_button_box = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); + all_tabs_button_box = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); + gtk_widget_set_halign(current_tab_button_box, GTK_ALIGN_CENTER); + gtk_widget_set_halign(all_tabs_button_box, GTK_ALIGN_CENTER); + + /* Set up buttons. */ + NEW_BUTTON(0, 0, "view-refresh", "Reload Tab"); + NEW_BUTTON(0, 1, "edit-copy", "Duplicate Tab"); + NEW_BUTTON(0, 2, "window-new", "Open Tab in New Window"); + NEW_BUTTON(0, 3, "window-close", "Close Tab"); + NEW_BUTTON(1, 4, "tab-new-symbolic", "New Tab"); + NEW_BUTTON(1, 5, "edit-undo", "Undo Close Tab"); + NEW_BUTTON(1, 6, "view-list-symbolic", "Tab List..."); + + /* Set up the button rows box. */ + button_rows_box = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); + gtk_box_pack_start(GTK_BOX(button_rows_box), current_tab_button_box, + TRUE, FALSE, 0); + gtk_box_pack_start(GTK_BOX(button_rows_box), all_tabs_button_box, + TRUE, FALSE, 0); + + /* Set up the stack. */ + stack = gtk_stack_new(); + gtk_stack_add_named(GTK_STACK(stack), button_rows_box, "buttons"); + gtk_stack_add_named(GTK_STACK(stack), gtk_label_new("Tab list"), + "tab_list"); + + /* Set up the popover. */ + popover = gtk_popover_new(widget); + gtk_container_add(GTK_CONTAINER(popover), stack); + + /* NB: gtk_popover_popup() is new in GTK+ 3.22. */ + gtk_widget_show_all(popover); + /* TODO: gtk_widget_hide() tab list */ + + return FALSE; +} + +#undef NEW_BUTTON + static void add_tab(MqWindow *window, gchar *uri, gint position) { @@ -33,6 +99,7 @@ add_tab(MqWindow *window, gchar *uri, gint position) GtkWidget *tab_label_label; GtkWidget *tab_label; MqTab *tab; + GtkWidget *tab_label_event_box; GtkWidget *tab_widget; tab_label_image = gtk_image_new_from_icon_name("text-x-generic", @@ -53,9 +120,16 @@ add_tab(MqWindow *window, gchar *uri, gint position) tab = mq_tab_new(uri, tab_label_image, tab_label_label); + tab_label_event_box = gtk_event_box_new(); + g_signal_connect(tab_label_event_box, "button-press-event", + G_CALLBACK(tab_label_button_press_cb), tab); + gtk_event_box_set_visible_window(GTK_EVENT_BOX(tab_label_event_box), + FALSE); + gtk_container_add(GTK_CONTAINER(tab_label_event_box), tab_label); + tab_widget = mq_tab_get_container(tab); position = gtk_notebook_insert_page(GTK_NOTEBOOK(window->notebook), - tab_widget, tab_label, position); + tab_widget, tab_label_event_box, position); gtk_notebook_set_tab_reorderable(GTK_NOTEBOOK(window->notebook), tab_widget, TRUE); gtk_notebook_set_tab_detachable(GTK_NOTEBOOK(window->notebook), |