From 66f7825d3274e601a4858a64b42e7383908b03ad Mon Sep 17 00:00:00 2001
From: Christian Heller <c.heller@plomlompom.de>
Date: Mon, 11 Nov 2024 01:15:01 +0100
Subject: [PATCH] Browser: Reduce proliferation of SorterAndFiltererOrders.

---
 browser.py | 45 +++++++++++++++++++--------------------------
 1 file changed, 19 insertions(+), 26 deletions(-)

diff --git a/browser.py b/browser.py
index dbbff1d..eeb78f1 100755
--- a/browser.py
+++ b/browser.py
@@ -454,6 +454,7 @@ class GalleryConfig():
                  items_attrs: ItemsAttrs,
                  ) -> None:
         self.order = sort_order
+        self._tmp_order: Optional[SorterAndFiltererOrder] = None
         self._gallery_request_update = request_update
         self._gallery_update_settings = update_settings
         self._gallery_items_attrs = items_attrs
@@ -502,14 +503,14 @@ class GalleryConfig():
                 self._btn_show_dirs.set_active(False)
 
         def apply_config() -> None:
-            self.order.update_from_store(self._store)
-            for sorter in self.order:
-                sorter.widget.remove_css_class('temp')
+            if self._tmp_order:
+                self.order.sync_from(self._tmp_order)
+                self._tmp_order = None
+                self._gallery_request_update(build_grid=True)
             self._gallery_update_settings(
                     per_row=self._btn_per_row.get_value_as_int(),
                     by_1st=self._btn_by_1st.get_active(),
                     show_dirs=self._btn_show_dirs.get_active(),
-                    sort_order=self.order.copy(),
                     filter_inputs=self.filter_inputs.copy(),
                     recurse_dirs=self._btn_recurse.get_active())
             self._gallery_request_update(select=True)
@@ -586,31 +587,27 @@ class GalleryConfig():
 
     def move_sorter(self, direction: int) -> None:
         """Move selected item in sort order view, ensure temporary state."""
-        tmp_sort_order = SorterAndFiltererOrder.from_store(self._store)
+        tmp_order = self._tmp_order if self._tmp_order else self.order.copy()
         cur_idx = self._sort_sel.props.selected
         if direction == -1 and cur_idx > 0:
-            tmp_sort_order.switch_at(cur_idx, forward=False)
-        elif direction == 1 and cur_idx < (len(tmp_sort_order) - 1):
-            tmp_sort_order.switch_at(cur_idx, forward=True)
+            tmp_order.switch_at(cur_idx, forward=False)
+        elif direction == 1 and cur_idx < (len(tmp_order) - 1):
+            tmp_order.switch_at(cur_idx, forward=True)
         else:  # to catch movement beyond limits
             return
-        self.update_box(tmp_sort_order, cur_idx + direction)
+        if not self._tmp_order:
+            self._tmp_order = tmp_order
+            for sorter in self._tmp_order:
+                sorter.widget.add_css_class('temp')
+        self.update_box(cur_idx + direction)
         self._sort_sel.props.selected = cur_idx + direction
         for i in range(self._store.get_n_items()):
             sort_item: SorterAndFilterer = self._store.get_item(i)
             sort_item.widget.add_css_class('temp')
 
-    def sync_sorter(self, order: SorterAndFiltererOrder) -> None:
-        """Update .order and its dependencies from order."""
-        self.order.sync_from(order)
-        self.update_box()
-
-    def update_box(self,
-                   alt_order: Optional[SorterAndFiltererOrder] = None,
-                   cur_selection: int = 0
-                   ) -> None:
+    def update_box(self, cur_selection: int = 0) -> None:
         """Rebuild sorter listing in box from .order, or alt_order if set."""
-        sort_order = alt_order if alt_order else self.order
+        sort_order = self._tmp_order if self._tmp_order else self.order
         sort_order.into_store(self._store)
         self._sort_sel.props.selected = cur_selection
 
@@ -656,9 +653,9 @@ class VerticalLabel(Gtk.DrawingArea):
 class Gallery:
     """Representation of GalleryItems below a directory."""
     update_config_box: Callable
-    sync_sorter: Callable
 
     def __init__(self,
+                 sort_order: SorterAndFiltererOrder,
                  on_hit_item: Callable,
                  on_selection_change: Callable,
                  bookmarks_db: BookmarksDb,
@@ -667,7 +664,7 @@ class Gallery:
         self._on_hit_item = on_hit_item
         self._on_selection_change = on_selection_change
         self._bookmarks_db, self._cache_db = bookmarks_db, cache_db
-        self._sort_order = SorterAndFiltererOrder([])
+        self._sort_order = sort_order
         self._filter_inputs: FilterInputs = {}
         self._img_dir_path = ''
 
@@ -741,7 +738,6 @@ class Gallery:
                         show_dirs: Optional[bool] = None,
                         recurse_dirs: Optional[bool] = None,
                         img_dir_path: Optional[str] = None,
-                        sort_order: Optional[SorterAndFiltererOrder] = None,
                         filter_inputs: Optional[FilterInputs] = None
                         ) -> None:
         """Set Gallery setup fields, request appropriate updates."""
@@ -750,7 +746,6 @@ class Gallery:
                                (show_dirs, '_show_dirs'),
                                (recurse_dirs, '_recurse_dirs'),
                                (img_dir_path, '_img_dir_path'),
-                               (sort_order, '_sort_order'),
                                (filter_inputs, '_filter_inputs')]:
             if val is not None and getattr(self, attr_name) != val:
                 setattr(self, attr_name, val)
@@ -959,7 +954,6 @@ class Gallery:
                 for category in ('incl', 'semi', 'excl'):
                     final_values[category].sort()
                 self.items_attrs[attr_name] = final_values
-            self.sync_sorter(self._sort_order)
 
         def filter_entries(items_attrs: ItemsAttrs) -> list[GalleryItem]:
             entries_filtered: list[GalleryItem] = []
@@ -1239,6 +1233,7 @@ class MainWindow(Gtk.Window):
         super().__init__(**kwargs)
         self.app = app
         self.gallery = Gallery(
+                sort_order=self.app.sort_order,
                 on_hit_item=self.hit_gallery_item,
                 on_selection_change=self.update_metadata_on_gallery_selection,
                 bookmarks_db=self.app.bookmarks_db,
@@ -1251,7 +1246,6 @@ class MainWindow(Gtk.Window):
                 update_settings=self.gallery.update_settings,
                 items_attrs=self.gallery.items_attrs)
         self.gallery.update_config_box = self.conf.update_box
-        self.gallery.sync_sorter = self.conf.sync_sorter
         metadata_textview = Gtk.TextView(wrap_mode=Gtk.WrapMode.WORD_CHAR,
                                          editable=False)
         self.metadata = metadata_textview.get_buffer()
@@ -1298,7 +1292,6 @@ class MainWindow(Gtk.Window):
         # only now we're ready for actually running the gallery
         GLib.idle_add(lambda: self.gallery.update_settings(
             img_dir_path=self.app.img_dir_absolute,
-            sort_order=self.conf.order.copy(),
             filter_inputs=self.conf.filter_inputs.copy()))
 
     def on_focus_change(self) -> None:
-- 
2.30.2