1
0
Fork 0
mirror of synced 2024-05-12 16:32:43 +12:00
czkawka/czkawka_gui/src/connect_things/connect_button_sort.rs
Rafał Mikrut f1c6e6da17
Add sort button (#894)
* Add sort button

* Update lofty and gtk-rs

* Fix bug with invalid music tags with reference folders

* Remove try at

* Fix loading of certain directories with disabled loading settings at start

* Change FileChooserDialog to FileChooserNative

* Any

* Copy Clone

* Popover sort basic

* Builder using

* Basic sorting

* Fix not working sorting by size

* Changelog
2023-02-19 10:21:14 +01:00

47 lines
2 KiB
Rust

use crate::gui_structs::gui_data::GuiData;
use crate::gui_structs::gui_popovers_sort::GuiSortPopovers;
use crate::help_functions::PopoverTypes;
use crate::notebook_enums::{to_notebook_main_enum, NotebookMainEnum};
use crate::notebook_info::NOTEBOOKS_INFO;
use gtk4::prelude::*;
pub fn connect_button_sort(gui_data: &GuiData) {
let popovers_sort = gui_data.popovers_sort.clone();
let notebook_main = gui_data.main_notebook.notebook_main.clone();
let gc_buttons_sort = gui_data.bottom_buttons.gc_buttons_sort.clone();
gc_buttons_sort.connect_pressed(move |_, _, _, _| {
show_required_popovers(&popovers_sort, &to_notebook_main_enum(notebook_main.current_page().unwrap()));
});
}
fn show_required_popovers(popovers_sort: &GuiSortPopovers, current_mode: &NotebookMainEnum) {
let buttons_popover_sort_file_name = popovers_sort.buttons_popover_sort_file_name.clone();
let buttons_popover_sort_size = popovers_sort.buttons_popover_sort_size.clone();
let buttons_popover_sort_folder_name = popovers_sort.buttons_popover_sort_folder_name.clone();
let buttons_popover_sort_full_name = popovers_sort.buttons_popover_sort_full_name.clone();
let buttons_popover_sort_selection = popovers_sort.buttons_popover_sort_selection.clone();
let arr = &NOTEBOOKS_INFO[*current_mode as usize].available_modes;
buttons_popover_sort_full_name.hide();
if arr.contains(&PopoverTypes::All) {
buttons_popover_sort_selection.show();
buttons_popover_sort_file_name.show();
buttons_popover_sort_folder_name.show();
// buttons_popover_sort_full_name.show(); // TODO, this needs to be handled a little different
} else {
buttons_popover_sort_selection.hide();
buttons_popover_sort_file_name.hide();
buttons_popover_sort_folder_name.hide();
// buttons_popover_sort_full_name.hide();
}
if arr.contains(&PopoverTypes::Size) {
buttons_popover_sort_size.show();
} else {
buttons_popover_sort_size.hide();
}
}