summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAntónio Fernandes <antoniof@gnome.org>2022-08-01 00:04:31 +0100
committerAntónio Fernandes <antoniof@gnome.org>2022-08-01 02:13:19 +0100
commitac9524fbd6148fb26f2e081c408696d6fdeb9008 (patch)
tree71903048bf480576af36fdc618ce0b55ee7809a3
parent31d1b3381d4562a96c724efc570f9099bf42b199 (diff)
downloadnautilus-wip/antoniof/three-menus-no-more.tar.gz
toolbar-view-menu.ui: Move into files-view.uiwip/antoniof/three-menus-no-more
This is not used by the toolbar anymore and this is much simpler.
-rw-r--r--po/POTFILES.in1
-rw-r--r--src/nautilus-files-view.c17
-rw-r--r--src/resources/nautilus.gresource.xml1
-rw-r--r--src/resources/ui/nautilus-files-view.ui60
-rw-r--r--src/resources/ui/nautilus-toolbar-view-menu.ui63
5 files changed, 63 insertions, 79 deletions
diff --git a/po/POTFILES.in b/po/POTFILES.in
index ab1b37ba2..c3542b022 100644
--- a/po/POTFILES.in
+++ b/po/POTFILES.in
@@ -88,7 +88,6 @@ src/resources/ui/nautilus-properties-window.ui
src/resources/ui/nautilus-rename-file-popover.ui
src/resources/ui/nautilus-search-popover.ui
src/resources/ui/nautilus-toolbar.ui
-src/resources/ui/nautilus-toolbar-view-menu.ui
src/resources/ui/nautilus-window.ui
src/gtk/nautilusgtkplacesview.c
src/gtk/nautilusgtkplacesviewrow.c
diff --git a/src/nautilus-files-view.c b/src/nautilus-files-view.c
index 360105dd3..7049440db 100644
--- a/src/nautilus-files-view.c
+++ b/src/nautilus-files-view.c
@@ -247,6 +247,8 @@ typedef struct
GtkWidget *stack;
GtkWidget *sort_menu_button;
+ GMenuModel *sort_menu;
+
GtkWidget *scrolled_window;
/* Empty states */
@@ -258,8 +260,6 @@ typedef struct
guint floating_bar_set_passthrough_timeout_id;
GtkWidget *floating_bar;
- GMenuModel *sort_menu;
-
/* Exposed menus, for the path bar etc. */
GMenuModel *extensions_background_menu;
GMenuModel *templates_menu;
@@ -3301,8 +3301,6 @@ nautilus_files_view_finalize (GObject *object)
/* We don't own the slot, so no unref */
priv->slot = NULL;
- g_clear_object (&priv->sort_menu);
-
g_hash_table_destroy (priv->non_ready_files);
g_hash_table_destroy (priv->pending_reveal);
@@ -9491,6 +9489,7 @@ nautilus_files_view_class_init (NautilusFilesViewClass *klass)
"/org/gnome/nautilus/ui/nautilus-files-view.ui");
gtk_widget_class_bind_template_child_private (widget_class, NautilusFilesView, sort_menu_button);
+ gtk_widget_class_bind_template_child_private (widget_class, NautilusFilesView, sort_menu);
gtk_widget_class_bind_template_child_private (widget_class, NautilusFilesView, overlay);
gtk_widget_class_bind_template_child_private (widget_class, NautilusFilesView, stack);
gtk_widget_class_bind_template_child_private (widget_class, NautilusFilesView, empty_view_page);
@@ -9545,7 +9544,6 @@ static void
nautilus_files_view_init (NautilusFilesView *view)
{
NautilusFilesViewPrivate *priv;
- GtkBuilder *builder;
NautilusDirectory *scripts_directory;
NautilusDirectory *templates_directory;
GtkEventController *controller;
@@ -9578,10 +9576,6 @@ nautilus_files_view_init (NautilusFilesView *view)
priv = nautilus_files_view_get_instance_private (view);
- /* Toolbar menu */
- builder = gtk_builder_new_from_resource ("/org/gnome/nautilus/ui/nautilus-toolbar-view-menu.ui");
- priv->sort_menu = G_MENU_MODEL (g_object_ref (gtk_builder_get_object (builder, "sort_section")));
-
g_signal_connect (view,
"end-file-changes",
G_CALLBACK (on_end_file_changes),
@@ -9595,14 +9589,9 @@ nautilus_files_view_init (NautilusFilesView *view)
G_CALLBACK (on_parent_changed),
NULL);
- g_object_unref (builder);
-
g_type_ensure (NAUTILUS_TYPE_FLOATING_BAR);
gtk_widget_init_template (GTK_WIDGET (view));
- gtk_menu_button_set_menu_model (GTK_MENU_BUTTON (priv->sort_menu_button),
- priv->sort_menu);
-
controller = gtk_event_controller_scroll_new (GTK_EVENT_CONTROLLER_SCROLL_VERTICAL |
GTK_EVENT_CONTROLLER_SCROLL_DISCRETE);
gtk_widget_add_controller (priv->scrolled_window, controller);
diff --git a/src/resources/nautilus.gresource.xml b/src/resources/nautilus.gresource.xml
index 3a6abce9a..69dc9ee6f 100644
--- a/src/resources/nautilus.gresource.xml
+++ b/src/resources/nautilus.gresource.xml
@@ -6,7 +6,6 @@
<file>ui/nautilus-app-chooser.ui</file>
<file>ui/nautilus-pathbar-context-menu.ui</file>
<file>ui/nautilus-toolbar.ui</file>
- <file>ui/nautilus-toolbar-view-menu.ui</file>
<file>ui/nautilus-column-chooser.ui</file>
<file>ui/nautilus-list-view-column-editor.ui</file>
<file>ui/nautilus-create-folder-dialog.ui</file>
diff --git a/src/resources/ui/nautilus-files-view.ui b/src/resources/ui/nautilus-files-view.ui
index db5e68779..767183dc3 100644
--- a/src/resources/ui/nautilus-files-view.ui
+++ b/src/resources/ui/nautilus-files-view.ui
@@ -12,6 +12,7 @@
<property name="halign">start</property>
<property name="valign">start</property>
<property name="always-show-arrow">true</property>
+ <property name="menu-model">sort_menu</property>
<property name="label">Sort</property>
<style>
<class name="caption-heading"/>
@@ -52,4 +53,63 @@
</object>
</child>
</template>
+ <menu id="sort_menu">
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('name',false)</attribute>
+ <attribute name="label" translatable="yes" context="Sort Criterion" comments="This is used to sort by name in the toolbar view menu">_A-Z</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ </item>
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('name',true)</attribute>
+ <attribute name="label" translatable="yes" context="Sort Criterion" comments="This is used to sort by name, in descending order in the toolbar view menu">_Z-A</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ </item>
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('modification date',true)</attribute>
+ <attribute name="label" translatable="yes">Last _Modified</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ </item>
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('modification date',false)</attribute>
+ <attribute name="label" translatable="yes">_First Modified</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ </item>
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('size',true)</attribute>
+ <attribute name="label" translatable="yes">_Size</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ </item>
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('type',false)</attribute>
+ <attribute name="label" translatable="yes">_Type</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ </item>
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('trashed',true)</attribute>
+ <attribute name="label" translatable="yes">Last _Trashed</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ <attribute name="nautilus-menu-item">last_trashed</attribute>
+ </item>
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('recency',true)</attribute>
+ <attribute name="label" translatable="yes">Recency</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ <attribute name="nautilus-menu-item">recency</attribute>
+ </item>
+ <item>
+ <attribute name="action">view.sort</attribute>
+ <attribute name="target" type="(sb)">('search_relevance',true)</attribute>
+ <attribute name="label" translatable="yes">Relevance</attribute>
+ <attribute name="hidden-when">action-disabled</attribute>
+ <attribute name="nautilus-menu-item">relevance</attribute>
+ </item>
+ </menu>
</interface>
diff --git a/src/resources/ui/nautilus-toolbar-view-menu.ui b/src/resources/ui/nautilus-toolbar-view-menu.ui
deleted file mode 100644
index 03c6e8e8d..000000000
--- a/src/resources/ui/nautilus-toolbar-view-menu.ui
+++ /dev/null
@@ -1,63 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<interface>
- <requires lib="gtk" version="4.0"/>
- <menu id="sort_section">
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('name',false)</attribute>
- <attribute name="label" translatable="yes" context="Sort Criterion" comments="This is used to sort by name in the toolbar view menu">_A-Z</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- </item>
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('name',true)</attribute>
- <attribute name="label" translatable="yes" context="Sort Criterion" comments="This is used to sort by name, in descending order in the toolbar view menu">_Z-A</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- </item>
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('modification date',true)</attribute>
- <attribute name="label" translatable="yes">Last _Modified</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- </item>
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('modification date',false)</attribute>
- <attribute name="label" translatable="yes">_First Modified</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- </item>
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('size',true)</attribute>
- <attribute name="label" translatable="yes">_Size</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- </item>
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('type',false)</attribute>
- <attribute name="label" translatable="yes">_Type</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- </item>
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('trashed',true)</attribute>
- <attribute name="label" translatable="yes">Last _Trashed</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- <attribute name="nautilus-menu-item">last_trashed</attribute>
- </item>
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('recency',true)</attribute>
- <attribute name="label" translatable="yes">Recency</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- <attribute name="nautilus-menu-item">recency</attribute>
- </item>
- <item>
- <attribute name="action">view.sort</attribute>
- <attribute name="target" type="(sb)">('search_relevance',true)</attribute>
- <attribute name="label" translatable="yes">Relevance</attribute>
- <attribute name="hidden-when">action-disabled</attribute>
- <attribute name="nautilus-menu-item">relevance</attribute>
- </item>
- </menu>
-</interface>