diff options
Diffstat (limited to 'src/searches/Branch.vala')
-rw-r--r-- | src/searches/Branch.vala | 137 |
1 files changed, 0 insertions, 137 deletions
diff --git a/src/searches/Branch.vala b/src/searches/Branch.vala deleted file mode 100644 index 3b54acf..0000000 --- a/src/searches/Branch.vala +++ /dev/null @@ -1,137 +0,0 @@ -/* Copyright 2016 Software Freedom Conservancy Inc. - * - * This software is licensed under the GNU LGPL (version 2.1 or later). - * See the COPYING file in this distribution. - */ - -public class Searches.Branch : Sidebar.Branch { - private Gee.HashMap<SavedSearch, Searches.SidebarEntry> entry_map = - new Gee.HashMap<SavedSearch, Searches.SidebarEntry>(); - - public Branch() { - base (new Searches.Header(), - Sidebar.Branch.Options.HIDE_IF_EMPTY - | Sidebar.Branch.Options.AUTO_OPEN_ON_NEW_CHILD - | Sidebar.Branch.Options.STARTUP_EXPAND_TO_FIRST_CHILD, - comparator); - - // seed the branch with existing searches - foreach (SavedSearch search in SavedSearchTable.get_instance().get_all()) - on_saved_search_added(search); - - // monitor collection for future events - SavedSearchTable.get_instance().search_added.connect(on_saved_search_added); - SavedSearchTable.get_instance().search_removed.connect(on_saved_search_removed); - } - - ~Branch() { - SavedSearchTable.get_instance().search_added.disconnect(on_saved_search_added); - SavedSearchTable.get_instance().search_removed.disconnect(on_saved_search_removed); - } - - public Searches.SidebarEntry? get_entry_for_saved_search(SavedSearch search) { - return entry_map.get(search); - } - - private static int comparator(Sidebar.Entry a, Sidebar.Entry b) { - if (a == b) - return 0; - - return SavedSearch.compare_names(((Searches.SidebarEntry) a).for_saved_search(), - ((Searches.SidebarEntry) b).for_saved_search()); - } - - private void on_saved_search_added(SavedSearch search) { - debug("search added"); - Searches.SidebarEntry entry = new Searches.SidebarEntry(search); - entry_map.set(search, entry); - graft(get_root(), entry); - } - - private void on_saved_search_removed(SavedSearch search) { - debug("search removed"); - Searches.SidebarEntry? entry = entry_map.get(search); - assert(entry != null); - - bool is_removed = entry_map.unset(search); - assert(is_removed); - - prune(entry); - } -} - -public class Searches.Header : Sidebar.Header, Sidebar.Contextable { - private Gtk.Builder builder; - private Gtk.Menu? context_menu = null; - - public Header() { - base (_("Saved Searches")); - setup_context_menu(); - } - - private void setup_context_menu() { - this.builder = new Gtk.Builder (); - try { - this.builder.add_from_resource(Resources.get_ui("search_sidebar_context.ui")); - var model = builder.get_object ("popup-menu") as GLib.MenuModel; - this.context_menu = new Gtk.Menu.from_model (model); - } catch (Error error) { - AppWindow.error_message("Error loading UI resource: %s".printf( - error.message)); - Application.get_instance().panic(); - } - } - - public Gtk.Menu? get_sidebar_context_menu(Gdk.EventButton? event) { - return context_menu; - } -} - -public class Searches.SidebarEntry : Sidebar.SimplePageEntry, Sidebar.RenameableEntry, - Sidebar.DestroyableEntry { - private static string single_search_icon = "edit-find"; - - private SavedSearch search; - - public SidebarEntry(SavedSearch search) { - this.search = search; - } - - internal static void init() { - } - - internal static void terminate() { - } - - public SavedSearch for_saved_search() { - return search; - } - - public override string get_sidebar_name() { - return search.get_name(); - } - - public override string? get_sidebar_icon() { - return single_search_icon; - } - - protected override Page create_page() { - return new SavedSearchPage(search); - } - - public bool is_user_renameable() { - return true; - } - - public void rename(string new_name) { - if (!SavedSearchTable.get_instance().exists(new_name)) - AppWindow.get_command_manager().execute(new RenameSavedSearchCommand(search, new_name)); - else if (new_name != search.get_name()) - AppWindow.error_message(Resources.rename_search_exists_message(new_name)); - } - - public void destroy_source() { - if (Dialogs.confirm_delete_saved_search(search)) - AppWindow.get_command_manager().execute(new DeleteSavedSearchCommand(search)); - } -} |