[gnome-font-viewer/app-menu-no-more: 1/2] Stop using the app menu
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-font-viewer/app-menu-no-more: 1/2] Stop using the app menu
- Date: Thu, 1 Nov 2018 12:53:25 +0000 (UTC)
commit 3a4caae2c437770f7fc5fee8455084cd0595c5ae
Author: Matthias Clasen <mclasen redhat com>
Date: Fri Oct 12 18:06:53 2018 -0400
Stop using the app menu
Follow the app menu retirement initiative, and use a menu
inside the application window instead.
src/font-view-app-menu.ui | 6 +-----
src/font-view.c | 29 ++++++++++++++++++++---------
2 files changed, 21 insertions(+), 14 deletions(-)
---
diff --git a/src/font-view-app-menu.ui b/src/font-view-app-menu.ui
index 07d844a..0c4b21e 100644
--- a/src/font-view-app-menu.ui
+++ b/src/font-view-app-menu.ui
@@ -3,11 +3,7 @@
<section>
<item>
<attribute name="action">app.about</attribute>
- <attribute name="label" translatable="yes">About</attribute>
- </item>
- <item>
- <attribute name="action">app.quit</attribute>
- <attribute name="label" translatable="yes">Quit</attribute>
+ <attribute name="label" translatable="yes">About Fonts</attribute>
</item>
</section>
</menu>
diff --git a/src/font-view.c b/src/font-view.c
index 659fdba..52b11ca 100644
--- a/src/font-view.c
+++ b/src/font-view.c
@@ -72,6 +72,7 @@ struct _FontViewApplication {
GtkWidget *search_bar;
GtkWidget *search_entry;
GtkWidget *search_toggle;
+ GtkWidget *menu_button;
GtkTreeModel *model;
GtkTreeModel *filter_model;
@@ -887,6 +888,7 @@ font_view_application_do_open (FontViewApplication *self,
}
gtk_widget_hide (self->search_toggle);
+ gtk_widget_hide (self->menu_button);
uri = g_file_get_uri (file);
@@ -983,6 +985,7 @@ font_view_application_do_overview (FontViewApplication *self)
}
gtk_widget_show (self->search_toggle);
+ gtk_widget_show (self->menu_button);
font_view_ensure_model (self);
@@ -1138,6 +1141,8 @@ static void
ensure_window (FontViewApplication *self)
{
GtkWidget *window, *swin, *box, *image;
+ GtkBuilder *builder;
+ GMenuModel *menu;
if (self->main_window)
return;
@@ -1168,6 +1173,21 @@ ensure_window (FontViewApplication *self)
box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0);
gtk_stack_add_named (GTK_STACK (self->stack), box, "overview");
+ builder = gtk_builder_new ();
+ gtk_builder_add_from_resource (builder, "/org/gnome/font-viewer/font-view-app-menu.ui", NULL);
+ menu = G_MENU_MODEL (gtk_builder_get_object (builder, "app-menu"));
+
+ self->menu_button = gtk_menu_button_new ();
+ image = gtk_image_new_from_icon_name ("open-menu-symbolic", GTK_ICON_SIZE_BUTTON);
+ gtk_widget_show (image);
+ gtk_container_add (GTK_CONTAINER (self->menu_button), image);
+ gtk_menu_button_set_menu_model (GTK_MENU_BUTTON (self->menu_button), menu);
+ gtk_widget_set_no_show_all (self->menu_button, TRUE);
+ gtk_widget_show (self->menu_button);
+ gtk_header_bar_pack_end (GTK_HEADER_BAR (self->header), self->menu_button);
+
+ g_object_unref (builder);
+
self->search_bar = gtk_search_bar_new ();
gtk_container_add (GTK_CONTAINER (box), self->search_bar);
self->search_entry = gtk_search_entry_new ();
@@ -1208,8 +1228,6 @@ static void
font_view_application_startup (GApplication *application)
{
FontViewApplication *self = FONT_VIEW_APPLICATION (application);
- GtkBuilder *builder;
- GMenuModel *menu;
G_APPLICATION_CLASS (font_view_application_parent_class)->startup (application);
@@ -1218,13 +1236,6 @@ font_view_application_startup (GApplication *application)
g_action_map_add_action_entries (G_ACTION_MAP (self), action_entries,
G_N_ELEMENTS (action_entries), self);
- builder = gtk_builder_new ();
- gtk_builder_add_from_resource (builder, "/org/gnome/font-viewer/font-view-app-menu.ui", NULL);
- menu = G_MENU_MODEL (gtk_builder_get_object (builder, "app-menu"));
- gtk_application_set_app_menu (GTK_APPLICATION (self), menu);
-
- g_object_unref (builder);
- g_object_unref (menu);
}
static void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]