This commit is contained in:
rabite 2019-02-07 15:14:41 +01:00
parent aca9eaf68e
commit 626ba13239
3 changed files with 156 additions and 1 deletions

View File

@ -8,12 +8,23 @@ use crate::files::{File, Files};
use crate::listview::ListView;
use crate::miller_columns::MillerColumns;
use crate::widget::Widget;
use crate::tabview::Tabbable;
#[derive(PartialEq)]
pub struct FileBrowser {
pub columns: MillerColumns<ListView<Files>>,
}
impl Tabbable<FileBrowser> for FileBrowser {
fn new_tab(&self) -> Self {
FileBrowser::new().unwrap()
}
fn on_next_tab(&mut self) {
self.update_preview();
}
}
impl FileBrowser {
pub fn new() -> Result<FileBrowser, Box<Error>> {
let cwd = std::env::current_dir().unwrap();

View File

@ -29,6 +29,7 @@ mod widget;
mod win_main;
mod window;
mod hbox;
mod tabview;
use window::Window;
@ -40,8 +41,10 @@ fn main() {
let filebrowser = crate::file_browser::FileBrowser::new().unwrap();
let mut tabview = crate::tabview::TabView::new();
tabview.push_widget(filebrowser);
let mut win = Window::new(filebrowser);
let mut win = Window::new(tabview);
win.draw();
win.handle_input();

141
src/tabview.rs Normal file
View File

@ -0,0 +1,141 @@
use termion::event::Key;
use crate::coordinates::{Coordinates, Position, Size};
use crate::widget::Widget;
pub trait Tabbable<T: Widget> {
fn new_tab(&self) -> T;
fn on_next_tab(&mut self);
}
#[derive(PartialEq)]
pub struct TabView<T> where T: Widget {
widgets: Vec<T>,
active: usize,
coordinates: Coordinates
}
impl<T> TabView<T> where T: Widget + Tabbable<T> {
pub fn new() -> Self {
Self {
widgets: vec![],
active: 0,
coordinates: Coordinates::new()
}
}
pub fn push_widget(&mut self, widget: T) {
self.widgets.push(widget);
self.refresh();
}
pub fn pop_widget(&mut self) -> Option<T> {
let widget = self.widgets.pop();
self.refresh();
widget
}
pub fn active_widget(&self) -> &T {
&self.widgets[self.active]
}
pub fn active_widget_mut(&mut self) -> &mut T {
&mut self.widgets[self.active]
}
pub fn new_tab(&mut self) {
let tab = self.active_widget().new_tab();
self.push_widget(tab);
self.active += 1;
}
pub fn close_tab(&mut self) {
if self.active == 0 { return }
if self.active + 1 >= self.widgets.len() { self.active -= 1 }
self.pop_widget();
}
pub fn next_tab(&mut self) {
if self.active + 1 == self.widgets.len() {
self.active = 0;
} else {
self.active += 1
}
self.active_widget_mut().on_next_tab();
}
}
impl<T> Widget for TabView<T> where T: Widget + Tabbable<T> + PartialEq {
fn render_header(&self) -> String {
let xsize = self.get_coordinates().xsize();
let header = self.active_widget().render_header();
let mut nums_length = 0;
let tabnums = (0..self.widgets.len()).map(|num| {
nums_length += format!("{} ", num).len();
if num == self.active {
format!(" {}{}{}{}",
crate::term::invert(),
num,
crate::term::reset(),
crate::term::header_color())
} else {
format!(" {}", num)
}
}).collect::<String>();
let nums_pos = xsize - nums_length as u16;
format!("{}{}{}{}",
header,
crate::term::header_color(),
crate::term::goto_xy(nums_pos, 1),
tabnums)
}
fn render_footer(&self) -> String {
self.active_widget().render_footer()
}
fn refresh(&mut self) {
self.active_widget_mut().refresh();
}
fn get_drawlist(&self) -> String {
self.active_widget().get_drawlist()
}
fn get_size(&self) -> &Size {
&self.coordinates.size
}
fn get_position(&self) -> &Position {
&self.coordinates.position
}
fn set_size(&mut self, size: Size) {
self.coordinates.size = size;
}
fn set_position(&mut self, position: Position) {
self.coordinates.position = position;
}
fn get_coordinates(&self) -> &Coordinates {
&self.coordinates
}
fn set_coordinates(&mut self, coordinates: &Coordinates) {
if self.coordinates == *coordinates {
return;
}
self.coordinates = coordinates.clone();
self.refresh();
}
fn on_key(&mut self, key: Key) {
match key {
Key::Ctrl('t') => self.new_tab(),
Key::Ctrl('w') => self.close_tab(),
Key::Char('\t') => self.next_tab(),
_ => self.active_widget_mut().on_key(key)
}
}
}