Almost kinda functional description box
This commit is contained in:
+8
-24
@@ -1,29 +1,13 @@
|
||||
use crate::app::App;
|
||||
use crate::app::key_binding::DEFAULT_KEYBINDINGS;
|
||||
use crate::app::{App, Route};
|
||||
use crate::event::Key;
|
||||
use crate::handlers::radarr_handler::handle_radarr_key_events;
|
||||
|
||||
mod radarr_handler;
|
||||
|
||||
pub async fn handle_key_events(key: Key, app: &mut App) {
|
||||
match key {
|
||||
_ if key == DEFAULT_KEYBINDINGS.up.key => handle_scroll_up(app).await,
|
||||
_ if key == DEFAULT_KEYBINDINGS.down.key => handle_scroll_down(app).await,
|
||||
_ if key == DEFAULT_KEYBINDINGS.submit.key => handle_submit(app).await,
|
||||
_ if key == DEFAULT_KEYBINDINGS.esc.key => handle_esc(app).await,
|
||||
_ => ()
|
||||
match *app.get_current_route() {
|
||||
Route::Radarr(active_radarr_block) => {
|
||||
handle_radarr_key_events(key, app, active_radarr_block).await
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
async fn handle_scroll_up(app: &mut App) {
|
||||
app.data.radarr_data.movies.scroll_up();
|
||||
}
|
||||
|
||||
async fn handle_scroll_down(app: &mut App) {
|
||||
app.data.radarr_data.movies.scroll_down();
|
||||
}
|
||||
|
||||
async fn handle_submit(app: &mut App) {
|
||||
todo!()
|
||||
}
|
||||
|
||||
async fn handle_esc(app: &mut App) {
|
||||
todo!()
|
||||
}
|
||||
@@ -0,0 +1,48 @@
|
||||
use crate::app::key_binding::DEFAULT_KEYBINDINGS;
|
||||
use crate::app::models::Scrollable;
|
||||
use crate::app::radarr::ActiveRadarrBlock;
|
||||
use crate::{App, Key};
|
||||
|
||||
pub async fn handle_radarr_key_events(
|
||||
key: Key,
|
||||
app: &mut App,
|
||||
active_radarr_block: ActiveRadarrBlock,
|
||||
) {
|
||||
match key {
|
||||
_ if key == DEFAULT_KEYBINDINGS.up.key => handle_scroll_up(app, active_radarr_block).await,
|
||||
_ if key == DEFAULT_KEYBINDINGS.down.key => handle_scroll_down(app, active_radarr_block).await,
|
||||
_ if key == DEFAULT_KEYBINDINGS.submit.key => handle_submit(app, active_radarr_block).await,
|
||||
_ if key == DEFAULT_KEYBINDINGS.esc.key => handle_esc(app, active_radarr_block).await,
|
||||
_ => (),
|
||||
}
|
||||
}
|
||||
|
||||
async fn handle_scroll_up(app: &mut App, active_radarr_block: ActiveRadarrBlock) {
|
||||
match active_radarr_block {
|
||||
ActiveRadarrBlock::Movies => app.data.radarr_data.movies.scroll_up(),
|
||||
ActiveRadarrBlock::MovieDetails => app.data.radarr_data.movie_details.scroll_up(),
|
||||
_ => (),
|
||||
}
|
||||
}
|
||||
|
||||
async fn handle_scroll_down(app: &mut App, active_radarr_block: ActiveRadarrBlock) {
|
||||
match active_radarr_block {
|
||||
ActiveRadarrBlock::Movies => app.data.radarr_data.movies.scroll_down(),
|
||||
ActiveRadarrBlock::MovieDetails => app.data.radarr_data.movie_details.scroll_down(),
|
||||
_ => (),
|
||||
}
|
||||
}
|
||||
|
||||
async fn handle_submit(app: &mut App, active_radarr_block: ActiveRadarrBlock) {
|
||||
match active_radarr_block {
|
||||
ActiveRadarrBlock::Movies => app.push_navigation_stack(ActiveRadarrBlock::MovieDetails.into()),
|
||||
_ => (),
|
||||
}
|
||||
}
|
||||
|
||||
async fn handle_esc(app: &mut App, active_radarr_block: ActiveRadarrBlock) {
|
||||
match active_radarr_block {
|
||||
ActiveRadarrBlock::MovieDetails => app.pop_navigation_stack(),
|
||||
_ => (),
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user