aboutsummaryrefslogtreecommitdiff
path: root/src/ui.rs
diff options
context:
space:
mode:
authorkrolxon <krolyxon@tutanota.com>2024-04-24 15:49:40 +0530
committerkrolxon <krolyxon@tutanota.com>2024-04-24 15:49:40 +0530
commit9e2b51c8e698d8216f680b61dd3908d2f1823b38 (patch)
tree8e2b067a1a8513dc2ce6feb2bdf02b08c9940784 /src/ui.rs
parent044101b29091eab34f5bb11ad8929db266826705 (diff)
use tabs instead of layouts
Diffstat (limited to 'src/ui.rs')
-rwxr-xr-xsrc/ui.rs58
1 files changed, 40 insertions, 18 deletions
diff --git a/src/ui.rs b/src/ui.rs
index 5a52003..624e302 100755
--- a/src/ui.rs
+++ b/src/ui.rs
@@ -1,6 +1,7 @@
-use crate::app::{App, AppResult};
+use crate::app::{App, AppResult, SelectedTab};
use ratatui::{
prelude::*,
+ style::palette::tailwind,
widgets::{block::Title, *},
};
@@ -12,25 +13,45 @@ pub fn render(app: &mut App, frame: &mut Frame) {
// - https://github.com/ratatui-org/ratatui/tree/master/examples
// Layout
- let main_layout = Layout::default()
+ let layout = Layout::default()
.direction(Direction::Vertical)
- .constraints(vec![Constraint::Percentage(93), Constraint::Percentage(7)])
+ .constraints(vec![
+ Constraint::Percentage(5),
+ Constraint::Percentage(88),
+ Constraint::Percentage(7),
+ ])
.split(frame.size());
-
- let outer_layout = Layout::default()
- .direction(Direction::Horizontal)
- .constraints(vec![Constraint::Percentage(50), Constraint::Percentage(50)])
- .split(main_layout[0]);
-
- let inner_layout = Layout::default()
- .direction(Direction::Vertical)
- .constraints(vec![Constraint::Percentage(50), Constraint::Percentage(50)])
- .split(outer_layout[1]);
-
- draw_song_list(frame, app, outer_layout[0]);
- draw_queue(frame, app, inner_layout[0]);
- draw_playlists(frame, app, inner_layout[1]);
- draw_progress_bar(frame, app, main_layout[1]);
+ //
+ // let outer_layout = Layout::default()
+ // .direction(Direction::Horizontal)
+ // .constraints(vec![Constraint::Percentage(50), Constraint::Percentage(50)])
+ // .split(main_layout[1]);
+ //
+ // let inner_layout = Layout::default()
+ // .direction(Direction::Vertical)
+ // .constraints(vec![Constraint::Percentage(50), Constraint::Percentage(50)])
+ // .split(outer_layout[1]);
+
+ // draw_song_list(frame, app, outer_layout[0]);
+ // draw_queue(frame, app, inner_layout[0]);
+ // draw_playlists(frame, app, inner_layout[1]);
+ draw_progress_bar(frame, app, layout[2]);
+
+ let highlight_style = (Color::default(), tailwind::YELLOW.c700);
+ let tab = Tabs::new(vec!["Songs List", "Play Queue", "Playlists"])
+ .block(Block::default().title("Tabs").borders(Borders::ALL))
+ .style(Style::default().white())
+ .highlight_style(highlight_style)
+ .divider(" ")
+ .select(app.selected_tab.clone() as usize)
+ .padding("", "");
+ frame.render_widget(tab, layout[0]);
+
+ match app.selected_tab {
+ SelectedTab::SongList => draw_song_list(frame, app, layout[1]),
+ SelectedTab::Queue => draw_queue(frame, app, layout[1]),
+ SelectedTab::Playlists => draw_playlists(frame, app, layout[1]),
+ }
}
/// draws list of songs
@@ -98,6 +119,7 @@ fn draw_progress_bar(frame: &mut Frame, app: &mut App, size: Rect) {
let title = Block::default()
.title(Title::from(format!("{}: ", state).red().bold()))
.title(Title::from(song.green().bold()));
+ // .title(Title::from(app.conn.conn.status().unwrap_or_default().volume.to_string().yellow())).title_alignment(Alignment::Right);
let progress_bar = LineGauge::default()
.block(title.borders(Borders::ALL))
.gauge_style(