diff --git a/crates/tek/src/groovebox.rs b/crates/tek/src/groovebox.rs index 3a1a24f4..ad2316a5 100644 --- a/crates/tek/src/groovebox.rs +++ b/crates/tek/src/groovebox.rs @@ -38,30 +38,38 @@ pub enum GrooveboxFocus { audio!(|self:GrooveboxTui,_client,_process|Control::Continue); has_clock!(|self:GrooveboxTui|&self.sequencer.clock); -render!(|self:GrooveboxTui|Fill::wh(lay!([ - &self.size, - Fill::wh(Align::s(Fixed::h(2, GrooveboxStatus::from(self)))), - Tui::shrink_y(2, col!([ - Fixed::h(2, row!([ - Fixed::wh(5, 2, PlayPause(self.clock().is_rolling())), - Fixed::h(2, TransportView::from((self, self.sequencer.player.play_phrase().as_ref().map(|(_,p)| - p.as_ref().map(|p|p.read().unwrap().color) - ).flatten().clone(), true))), - ])), - Tui::push_x(20, Fixed::h(1, row!([ - PhraseSelector::play_phrase(&self.sequencer.player), - PhraseSelector::next_phrase(&self.sequencer.player), - ]))), - row!([ - Tui::pull_y(1, Tui::shrink_y(0, Fill::h(Fixed::w(20, &self.sampler)))), - Fill::wh(&self.sequencer), - ]), +render!(|self:GrooveboxTui|{ + let w = self.size.w(); + let phrase_w = if w > 60 { 20 } else if w > 40 { 15 } else { 10 }; + let pool_w = if self.sequencer.phrases.visible { phrase_w } else { 0 }; + let sampler_w = 24; + Fill::wh(lay!([ + &self.size, + Fill::wh(Align::s(Fixed::h(2, GrooveboxStatus::from(self)))), + Tui::shrink_y(2, col!([ + Fixed::h(2, row!([ + Fixed::wh(5, 2, PlayPause(self.clock().is_rolling())), + Fixed::h(2, TransportView::from((self, self.sequencer.player.play_phrase().as_ref().map(|(_,p)| + p.as_ref().map(|p|p.read().unwrap().color) + ).flatten().clone(), true))), + ])), + Tui::push_x(sampler_w, Fixed::h(1, row!([ + PhraseSelector::play_phrase(&self.sequencer.player), + PhraseSelector::next_phrase(&self.sequencer.player), + ]))), + row!([ + Tui::pull_y(1, Tui::shrink_y(0, Fill::h(Fixed::w(sampler_w, &self.sampler)))), + Tui::split_n(false, 1, + MidiEditStatus(&self.sequencer.editor), + Tui::split_w(false, pool_w, + Tui::pull_y(1, Fill::h(Align::e(PoolView(&self.sequencer.phrases)))), + Fill::wh(&self.sequencer.editor) + ) + ), + ]), + ])) ])) -]))); - //Bsp::n( - //Fill::wh(lay!([ - //])), -//))); +}); pub enum GrooveboxCommand { Sequencer(SequencerCommand), diff --git a/crates/tek/src/lib.rs b/crates/tek/src/lib.rs index be8099fb..934eb858 100644 --- a/crates/tek/src/lib.rs +++ b/crates/tek/src/lib.rs @@ -15,6 +15,8 @@ pub use self::jack::*; pub mod midi; pub(crate) use self::midi::*; +pub mod piano_h; pub(crate) use self::piano_h::*; + pub mod transport; pub(crate) use self::transport::*; pub use self::transport::TransportTui; diff --git a/crates/tek/src/tui/piano_h.rs b/crates/tek/src/piano_h.rs similarity index 100% rename from crates/tek/src/tui/piano_h.rs rename to crates/tek/src/piano_h.rs diff --git a/crates/tek/src/tui/piano_h/piano_h_cursor.rs b/crates/tek/src/piano_h/piano_h_cursor.rs similarity index 100% rename from crates/tek/src/tui/piano_h/piano_h_cursor.rs rename to crates/tek/src/piano_h/piano_h_cursor.rs diff --git a/crates/tek/src/tui/piano_h/piano_h_keys.rs b/crates/tek/src/piano_h/piano_h_keys.rs similarity index 100% rename from crates/tek/src/tui/piano_h/piano_h_keys.rs rename to crates/tek/src/piano_h/piano_h_keys.rs diff --git a/crates/tek/src/tui/piano_h/piano_h_notes.rs b/crates/tek/src/piano_h/piano_h_notes.rs similarity index 100% rename from crates/tek/src/tui/piano_h/piano_h_notes.rs rename to crates/tek/src/piano_h/piano_h_notes.rs diff --git a/crates/tek/src/tui/piano_h/piano_h_time.rs b/crates/tek/src/piano_h/piano_h_time.rs similarity index 100% rename from crates/tek/src/tui/piano_h/piano_h_time.rs rename to crates/tek/src/piano_h/piano_h_time.rs diff --git a/crates/tek/src/tui/piano_v.rs b/crates/tek/src/piano_v.rs similarity index 100% rename from crates/tek/src/tui/piano_v.rs rename to crates/tek/src/piano_v.rs diff --git a/crates/tek/src/sampler.rs b/crates/tek/src/sampler.rs index 0caa6a45..c394b28e 100644 --- a/crates/tek/src/sampler.rs +++ b/crates/tek/src/sampler.rs @@ -1,5 +1,4 @@ -use crate::{*, tui::piano_h::PianoHorizontalKeys}; - +use crate::*; use KeyCode::Char; use std::fs::File; use symphonia::{ diff --git a/crates/tek/src/sequencer.rs b/crates/tek/src/sequencer.rs index 7b24dc5d..7e6bfc60 100644 --- a/crates/tek/src/sequencer.rs +++ b/crates/tek/src/sequencer.rs @@ -62,7 +62,11 @@ render!(|self: SequencerTui|{ PhraseSelector::play_phrase(&self.player), PhraseSelector::next_phrase(&self.player), ]).when(self.selectors);; - Tui::min_y(15, with_size(with_status(col!([ toolbar, play_queue, editor, ])))) + Tui::min_y(15, with_size(with_status(col!([ + toolbar, + play_queue, + editor, + ])))) }); audio!(|self:SequencerTui, client, scope|{ // Start profiling cycle diff --git a/crates/tek/src/tui.rs b/crates/tek/src/tui.rs index 726f6ce7..737ef479 100644 --- a/crates/tek/src/tui.rs +++ b/crates/tek/src/tui.rs @@ -15,7 +15,6 @@ mod tui_border; pub(crate) use self::tui_border::*; /////////////////////////////////////////////////////// pub mod file_browser; pub(crate) use self::file_browser::*; -pub mod piano_h; pub(crate) use self::piano_h::*; ////////////////////////////////////////////////////////