1
0
Fork 0
mirror of synced 2024-05-14 17:33:48 +12:00

Fixes problem with new file dialog

This commit is contained in:
Rafał Mikrut 2023-02-19 12:18:51 +01:00
parent 27410bcd45
commit c6c4230699
3 changed files with 76 additions and 76 deletions

View file

@ -1,7 +1,7 @@
use std::path::{Path, PathBuf}; use std::path::{Path, PathBuf};
use gtk4::prelude::*; use gtk4::prelude::*;
use gtk4::{FileChooserNative, ResponseType, TreePath}; use gtk4::{ResponseType, TreePath};
use crate::flg; use crate::flg;
use crate::gui_structs::gui_data::GuiData; use crate::gui_structs::gui_data::GuiData;
@ -25,7 +25,7 @@ pub fn connect_button_move(gui_data: &GuiData) {
let preview_path = gui_data.preview_path.clone(); let preview_path = gui_data.preview_path.clone();
let file_dialog_move_to_folder = gui_data.file_dialog_move_to_folder.clone(); let file_dialog_move_to_folder = gui_data.file_dialog_move_to_folder.clone();
buttons_move.connect_clicked(move |_| { file_dialog_move_to_folder.connect_response(move |file_chooser, response_type| {
let nb_number = notebook_main.current_page().unwrap(); let nb_number = notebook_main.current_page().unwrap();
let tree_view = &main_tree_views[nb_number as usize]; let tree_view = &main_tree_views[nb_number as usize];
let nb_object = &NOTEBOOKS_INFO[nb_number as usize]; let nb_object = &NOTEBOOKS_INFO[nb_number as usize];
@ -36,49 +36,10 @@ pub fn connect_button_move(gui_data: &GuiData) {
if number_of_selected_items == 0 { if number_of_selected_items == 0 {
return; return;
} }
move_things(
tree_view,
nb_object.column_name,
nb_object.column_path,
nb_object.column_header,
nb_object.column_selection,
&entry_info,
&text_view_errors,
&file_dialog_move_to_folder,
);
match &nb_object.notebook_type { reset_text_view(&text_view_errors);
NotebookMainEnum::SimilarImages | NotebookMainEnum::Duplicate => {
if nb_object.notebook_type == NotebookMainEnum::SimilarImages {
image_preview_similar_images.hide();
} else {
image_preview_duplicates.hide();
}
*preview_path.borrow_mut() = String::new();
}
_ => {}
}
});
}
// TODO add progress bar if response_type == ResponseType::Accept {
fn move_things(
tree_view: &gtk4::TreeView,
column_file_name: i32,
column_path: i32,
column_header: Option<i32>,
column_selection: i32,
entry_info: &gtk4::Entry,
text_view_errors: &gtk4::TextView,
file_dialog_move_to_folder: &FileChooserNative,
) {
reset_text_view(text_view_errors);
let entry_info = entry_info.clone();
let text_view_errors = text_view_errors.clone();
let tree_view = tree_view.clone();
file_dialog_move_to_folder.connect_response(move |file_chooser, response_type| {
if response_type == ResponseType::Ok {
let mut folders: Vec<PathBuf> = Vec::new(); let mut folders: Vec<PathBuf> = Vec::new();
let g_files = file_chooser.files(); let g_files = file_chooser.files();
for index in 0..g_files.n_items() { for index in 0..g_files.n_items() {
@ -102,23 +63,45 @@ fn move_things(
); );
} else { } else {
let folder = folders[0].clone(); let folder = folders[0].clone();
if let Some(column_header) = column_header { if let Some(column_header) = nb_object.column_header {
move_with_tree( move_with_tree(
&tree_view, tree_view,
column_file_name, nb_object.column_name,
column_path, nb_object.column_path,
column_header, column_header,
column_selection, nb_object.column_selection,
&folder, &folder,
&entry_info, &entry_info,
&text_view_errors, &text_view_errors,
); );
} else { } else {
move_with_list(&tree_view, column_file_name, column_path, column_selection, &folder, &entry_info, &text_view_errors); move_with_list(
tree_view,
nb_object.column_name,
nb_object.column_path,
nb_object.column_selection,
&folder,
&entry_info,
&text_view_errors,
);
} }
} }
} }
// file_chooser.close(); match &nb_object.notebook_type {
NotebookMainEnum::SimilarImages | NotebookMainEnum::Duplicate => {
if nb_object.notebook_type == NotebookMainEnum::SimilarImages {
image_preview_similar_images.hide();
} else {
image_preview_duplicates.hide();
}
*preview_path.borrow_mut() = String::new();
}
_ => {}
}
});
buttons_move.connect_clicked(move |_| {
file_dialog_move_to_folder.show();
}); });
} }

View file

@ -1,7 +1,7 @@
use std::path::PathBuf; use std::path::PathBuf;
use gtk4::prelude::*; use gtk4::prelude::*;
use gtk4::{FileChooserNative, Orientation, ResponseType, TreeView, Window}; use gtk4::{FileChooserNative, Notebook, Orientation, ResponseType, TreeView, Window};
#[cfg(target_family = "windows")] #[cfg(target_family = "windows")]
use czkawka_core::common::Common; use czkawka_core::common::Common;
@ -9,6 +9,7 @@ use czkawka_core::common::Common;
use crate::flg; use crate::flg;
use crate::gui_structs::gui_data::GuiData; use crate::gui_structs::gui_data::GuiData;
use crate::help_functions::{check_if_value_is_in_list_store, get_list_store, ColumnsExcludedDirectory, ColumnsIncludedDirectory}; use crate::help_functions::{check_if_value_is_in_list_store, get_list_store, ColumnsExcludedDirectory, ColumnsIncludedDirectory};
use crate::notebook_enums::{to_notebook_upper_enum, NotebookUpperEnum};
pub fn connect_selection_of_directories(gui_data: &GuiData) { pub fn connect_selection_of_directories(gui_data: &GuiData) {
// Add manually directory // Add manually directory
@ -31,22 +32,35 @@ pub fn connect_selection_of_directories(gui_data: &GuiData) {
} }
// Add included directory // Add included directory
{ {
let tree_view_included_directories = gui_data.upper_notebook.tree_view_included_directories.clone();
let buttons_add_included_directory = gui_data.upper_notebook.buttons_add_included_directory.clone(); let buttons_add_included_directory = gui_data.upper_notebook.buttons_add_included_directory.clone();
let file_dialog_include_exclude_folder_selection = gui_data.file_dialog_include_exclude_folder_selection.clone(); let file_dialog_include_exclude_folder_selection = gui_data.file_dialog_include_exclude_folder_selection.clone();
buttons_add_included_directory.connect_clicked(move |_| { buttons_add_included_directory.connect_clicked(move |_| {
add_chosen_directories(&file_dialog_include_exclude_folder_selection, &tree_view_included_directories, false); file_dialog_include_exclude_folder_selection.show();
file_dialog_include_exclude_folder_selection.set_title(&flg!("include_folders_dialog_title"));
}); });
} }
// Add excluded directory // Add excluded directory
{ {
let tree_view_excluded_directories = gui_data.upper_notebook.tree_view_excluded_directories.clone();
let buttons_add_excluded_directory = gui_data.upper_notebook.buttons_add_excluded_directory.clone(); let buttons_add_excluded_directory = gui_data.upper_notebook.buttons_add_excluded_directory.clone();
let file_dialog_include_exclude_folder_selection = gui_data.file_dialog_include_exclude_folder_selection.clone(); let file_dialog_include_exclude_folder_selection = gui_data.file_dialog_include_exclude_folder_selection.clone();
buttons_add_excluded_directory.connect_clicked(move |_| { buttons_add_excluded_directory.connect_clicked(move |_| {
add_chosen_directories(&file_dialog_include_exclude_folder_selection, &tree_view_excluded_directories, true); file_dialog_include_exclude_folder_selection.show();
file_dialog_include_exclude_folder_selection.set_title(&flg!("exclude_folders_dialog_title"));
}); });
} }
// Conect
{
let notebook_upper = gui_data.upper_notebook.notebook_upper.clone();
let tree_view_included_directories = gui_data.upper_notebook.tree_view_included_directories.clone();
let tree_view_excluded_directories = gui_data.upper_notebook.tree_view_excluded_directories.clone();
let file_dialog_include_exclude_folder_selection = gui_data.file_dialog_include_exclude_folder_selection.clone();
connect_file_dialog(
&file_dialog_include_exclude_folder_selection,
tree_view_included_directories,
tree_view_excluded_directories,
notebook_upper,
);
}
// Remove Excluded Folder // Remove Excluded Folder
{ {
let buttons_remove_excluded_directory = gui_data.upper_notebook.buttons_remove_excluded_directory.clone(); let buttons_remove_excluded_directory = gui_data.upper_notebook.buttons_remove_excluded_directory.clone();
@ -79,19 +93,22 @@ pub fn connect_selection_of_directories(gui_data: &GuiData) {
} }
} }
fn add_chosen_directories(file_dialog_include_exclude_folder_selection: &FileChooserNative, tree_view: &TreeView, excluded_items: bool) { fn connect_file_dialog(file_dialog_include_exclude_folder_selection: &FileChooserNative, include_tree_view: TreeView, exclude_tree_view: TreeView, notebook_upper: Notebook) {
let folders_to = if excluded_items {
flg!("exclude_folders_dialog_title")
} else {
flg!("include_folders_dialog_title")
};
file_dialog_include_exclude_folder_selection.show();
file_dialog_include_exclude_folder_selection.set_title(&folders_to);
let tree_view = tree_view.clone();
file_dialog_include_exclude_folder_selection.connect_response(move |file_chooser, response_type| { file_dialog_include_exclude_folder_selection.connect_response(move |file_chooser, response_type| {
if response_type == ResponseType::Accept { if response_type == ResponseType::Accept {
let excluded_items;
let tree_view = match to_notebook_upper_enum(notebook_upper.current_page().unwrap()) {
NotebookUpperEnum::IncludedDirectories => {
excluded_items = false;
&include_tree_view
}
NotebookUpperEnum::ExcludedDirectories => {
excluded_items = true;
&exclude_tree_view
}
_ => panic!(),
};
let mut folders: Vec<PathBuf> = Vec::new(); let mut folders: Vec<PathBuf> = Vec::new();
let g_files = file_chooser.files(); let g_files = file_chooser.files();
for index in 0..g_files.n_items() { for index in 0..g_files.n_items() {
@ -104,7 +121,7 @@ fn add_chosen_directories(file_dialog_include_exclude_folder_selection: &FileCho
} }
} }
let list_store = get_list_store(&tree_view); let list_store = get_list_store(tree_view);
if excluded_items { if excluded_items {
for file_entry in &folders { for file_entry in &folders {

View file

@ -57,15 +57,15 @@ pub enum NotebookUpperEnum {
ItemsConfiguration, ItemsConfiguration,
} }
// pub fn to_notebook_upper_enum(notebook_number: u32) -> NotebookUpperEnum { pub fn to_notebook_upper_enum(notebook_number: u32) -> NotebookUpperEnum {
// match notebook_number { match notebook_number {
// 0 => NotebookUpperEnum::IncludedDirectories, 0 => NotebookUpperEnum::IncludedDirectories,
// 1 => NotebookUpperEnum::ExcludedDirectories, 1 => NotebookUpperEnum::ExcludedDirectories,
// 2 => NotebookUpperEnum::ItemsConfiguration, 2 => NotebookUpperEnum::ItemsConfiguration,
// _ => panic!("Invalid Upper Notebook Tab"), _ => panic!("Invalid Upper Notebook Tab"),
// } }
// } }
//
// pub fn get_all_upper_tabs() -> [NotebookUpperEnum; NUMBER_OF_NOTEBOOK_UPPER_TABS] { // pub fn get_all_upper_tabs() -> [NotebookUpperEnum; NUMBER_OF_NOTEBOOK_UPPER_TABS] {
// [to_notebook_upper_enum(0), to_notebook_upper_enum(1), to_notebook_upper_enum(2)] // [to_notebook_upper_enum(0), to_notebook_upper_enum(1), to_notebook_upper_enum(2)]
// } // }