From 23e699234a570c031572bed029ff63b5a2eaed3a Mon Sep 17 00:00:00 2001 From: rabite Date: Fri, 1 Feb 2019 14:36:48 +0100 Subject: add flaceholder for empty dir --- src/file_browser.rs | 41 ++++++++++++++++++++++++++--------------- 1 file changed, 26 insertions(+), 15 deletions(-) (limited to 'src/file_browser.rs') diff --git a/src/file_browser.rs b/src/file_browser.rs index 0211f01..1f2493b 100644 --- a/src/file_browser.rs +++ b/src/file_browser.rs @@ -38,32 +38,34 @@ impl FileBrowser { } pub fn enter_dir(&mut self) { - let fileview = self.columns.get_main_widget(); + let file = self.selected_file(); - let path = fileview.selected_file().path(); - match Files::new_from_path(&path) { + match file.read_dir() { Ok(files) => { - std::env::set_current_dir(path).unwrap(); + std::env::set_current_dir(&file.path).unwrap(); let view = ListView::new(files); self.columns.push_widget(view); self.update_preview(); - } - Err(_) => { - //self.show_status(&format!("Can't open this path: {}", err)); + }, + Err(ref err) if err.description() == "placeholder".to_string() => + self.show_status("No! Can't open this!"), + _ => { let status = std::process::Command::new("xdg-open") - .args(dbg!(path.file_name())) + .args(dbg!(file.path.file_name())) .status(); + match status { - Ok(status) => { - self.show_status(&format!("\"{}\" exited with {}", "xdg-open", status)) - } - Err(err) => { - self.show_status(&format!("Can't run this \"{}\": {}", "xdg-open", err)) - } + Ok(status) => + self.show_status(&format!("\"{}\" exited with {}", + "xdg-open", status)), + Err(err) => + self.show_status(&format!("Can't run this \"{}\": {}", + "xdg-open", err)) + } } - }; + } } pub fn go_back(&mut self) { @@ -87,6 +89,7 @@ impl FileBrowser { } pub fn update_preview(&mut self) { + if self.columns.get_main_widget().content.len() == 0 { return } let file = self.columns.get_main_widget().selected_file().clone(); let preview = &mut self.columns.preview; preview.set_file(&file); @@ -103,6 +106,14 @@ impl FileBrowser { self.columns.get_main_widget().content.directory.clone() } + pub fn selected_file(&self) -> &File { + self.main_column().selected_file() + } + + pub fn main_column(&self) -> &ListView { + self.columns.get_main_widget() + } + pub fn quit_with_dir(&self) { let cwd = self.cwd().path; -- cgit v1.2.3