diff options
-rw-r--r-- | src/tab-chrome.c | 19 | ||||
-rw-r--r-- | src/tab-chrome.h | 2 | ||||
-rw-r--r-- | src/tab.c | 7 | ||||
-rw-r--r-- | src/tab.h | 2 | ||||
-rw-r--r-- | src/window.c | 17 |
5 files changed, 21 insertions, 26 deletions
diff --git a/src/tab-chrome.c b/src/tab-chrome.c index e137ed9..ac48c1a 100644 --- a/src/tab-chrome.c +++ b/src/tab-chrome.c @@ -68,12 +68,9 @@ navigation_toolbar_new(MqTabChrome *chrome, gchar *uri) } MqTabChrome * -mq_tab_chrome_new(gchar *uri, GtkNotebook *notebook, GtkWidget *notebook_child) +mq_tab_chrome_new(gchar *uri, GtkWidget *tab_image, GtkWidget *tab_label) { MqTabChrome *chrome; - GtkWidget *tab_label; - GtkWidget *tab_label_image; - GtkWidget *tab_label_label; chrome = malloc(sizeof(*chrome)); @@ -81,20 +78,6 @@ mq_tab_chrome_new(gchar *uri, GtkNotebook *notebook, GtkWidget *notebook_child) gtk_grid_attach(GTK_GRID(chrome->container), navigation_toolbar_new(chrome, uri), 0, 0, 1, 1); - /* FIXME: Doesn't work, because notebook_child hasn't been inserted into - * notebook yet at this point. */ - tab_label = gtk_grid_new(); - tab_label_image = gtk_image_new_from_icon_name("text-x-generic", - GTK_ICON_SIZE_BUTTON); - gtk_grid_attach(GTK_GRID(tab_label), tab_label_image, - 0, 0, 1, 1); - tab_label_label = gtk_label_new("New tab"); - gtk_grid_attach(GTK_GRID(tab_label), tab_label_label, - 1, 0, 1, 1); - gtk_widget_show_all(tab_label); - - gtk_notebook_set_tab_label(notebook, notebook_child, tab_label); - return chrome; } diff --git a/src/tab-chrome.h b/src/tab-chrome.h index 2dec778..cea26d9 100644 --- a/src/tab-chrome.h +++ b/src/tab-chrome.h @@ -32,7 +32,7 @@ typedef struct { } MqTabChrome; MqTabChrome * -mq_tab_chrome_new(gchar *uri, GtkNotebook *notebook, GtkWidget *notebook_child); +mq_tab_chrome_new(gchar *uri, GtkWidget *tab_image, GtkWidget *tab_label); GtkWidget * mq_tab_chrome_get_container(MqTabChrome *chrome); @@ -28,18 +28,17 @@ #include "tab-body.h" MqTab * -mq_tab_new(gchar *uri, GtkNotebook *notebook) +mq_tab_new(gchar *uri, GtkWidget *tab_image, GtkWidget *tab_label) { MqTab *tab; tab = malloc(sizeof(*tab)); - tab->container = gtk_grid_new(); - - tab->chrome = mq_tab_chrome_new(uri, notebook, tab->container); + tab->chrome = mq_tab_chrome_new(uri, tab_image, tab_label); tab->body = mq_tab_body_new(uri); mq_tab_chrome_set_web_view(tab->chrome, mq_tab_body_get_web_view(tab->body)); + tab->container = gtk_grid_new(); gtk_grid_attach(GTK_GRID(tab->container), mq_tab_chrome_get_container(tab->chrome), 0, 0, 1, 1); @@ -34,7 +34,7 @@ typedef struct { } MqTab; MqTab * -mq_tab_new(gchar *uri, GtkNotebook *notebook); +mq_tab_new(gchar *uri, GtkWidget *tab_image, GtkWidget *tab_label); GtkWidget * mq_tab_get_container(MqTab *tab); diff --git a/src/window.c b/src/window.c index 2cecc0d..770d59d 100644 --- a/src/window.c +++ b/src/window.c @@ -29,14 +29,27 @@ static void add_tab(MqWindow *window, gchar *uri, gint position) { + GtkWidget *tab_label; + GtkWidget *tab_label_image; + GtkWidget *tab_label_label; MqTab *tab; GtkWidget *tab_widget; - tab = mq_tab_new(uri, GTK_NOTEBOOK(window->notebook)); + tab_label = gtk_grid_new(); + tab_label_image = gtk_image_new_from_icon_name("text-x-generic", + GTK_ICON_SIZE_BUTTON); + gtk_grid_attach(GTK_GRID(tab_label), tab_label_image, + 0, 0, 1, 1); + tab_label_label = gtk_label_new("New tab"); + gtk_grid_attach(GTK_GRID(tab_label), tab_label_label, + 1, 0, 1, 1); + gtk_widget_show_all(tab_label); + + tab = mq_tab_new(uri, tab_label_image, tab_label_label); tab_widget = mq_tab_get_container(tab); position = gtk_notebook_insert_page(GTK_NOTEBOOK(window->notebook), - tab_widget, NULL, position); + tab_widget, tab_label, position); gtk_notebook_set_tab_reorderable(GTK_NOTEBOOK(window->notebook), tab_widget, TRUE); gtk_notebook_set_tab_detachable(GTK_NOTEBOOK(window->notebook), |