refactor(indexers_handler): Use the new handle_table_events macro
This commit is contained in:
@@ -92,7 +92,7 @@ pub const DEFAULT_KEYBINDINGS: KeyBindings = KeyBindings {
|
|||||||
desc: "search",
|
desc: "search",
|
||||||
},
|
},
|
||||||
settings: KeyBinding {
|
settings: KeyBinding {
|
||||||
key: Key::Char('s'),
|
key: Key::Char('S'),
|
||||||
desc: "settings",
|
desc: "settings",
|
||||||
},
|
},
|
||||||
filter: KeyBinding {
|
filter: KeyBinding {
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ mod test {
|
|||||||
#[case(DEFAULT_KEYBINDINGS.clear, Key::Char('c'), "clear")]
|
#[case(DEFAULT_KEYBINDINGS.clear, Key::Char('c'), "clear")]
|
||||||
#[case(DEFAULT_KEYBINDINGS.auto_search, Key::Char('S'), "auto search")]
|
#[case(DEFAULT_KEYBINDINGS.auto_search, Key::Char('S'), "auto search")]
|
||||||
#[case(DEFAULT_KEYBINDINGS.search, Key::Char('s'), "search")]
|
#[case(DEFAULT_KEYBINDINGS.search, Key::Char('s'), "search")]
|
||||||
#[case(DEFAULT_KEYBINDINGS.settings, Key::Char('s'), "settings")]
|
#[case(DEFAULT_KEYBINDINGS.settings, Key::Char('S'), "settings")]
|
||||||
#[case(DEFAULT_KEYBINDINGS.filter, Key::Char('f'), "filter")]
|
#[case(DEFAULT_KEYBINDINGS.filter, Key::Char('f'), "filter")]
|
||||||
#[case(DEFAULT_KEYBINDINGS.sort, Key::Char('o'), "sort")]
|
#[case(DEFAULT_KEYBINDINGS.sort, Key::Char('o'), "sort")]
|
||||||
#[case(DEFAULT_KEYBINDINGS.edit, Key::Char('e'), "edit")]
|
#[case(DEFAULT_KEYBINDINGS.edit, Key::Char('e'), "edit")]
|
||||||
|
|||||||
@@ -340,6 +340,11 @@ mod test_utils {
|
|||||||
app.data.radarr_data.collection_movies.set_items(vec![$crate::models::radarr_models::CollectionMovie::default()]);
|
app.data.radarr_data.collection_movies.set_items(vec![$crate::models::radarr_models::CollectionMovie::default()]);
|
||||||
app.data.radarr_data.indexers.set_items(vec![$crate::models::servarr_models::Indexer::default()]);
|
app.data.radarr_data.indexers.set_items(vec![$crate::models::servarr_models::Indexer::default()]);
|
||||||
app.data.radarr_data.root_folders.set_items(vec![$crate::models::servarr_models::RootFolder::default()]);
|
app.data.radarr_data.root_folders.set_items(vec![$crate::models::servarr_models::RootFolder::default()]);
|
||||||
|
let mut movie_details_modal = $crate::models::servarr_data::radarr::modals::MovieDetailsModal::default();
|
||||||
|
movie_details_modal
|
||||||
|
.movie_history
|
||||||
|
.set_items(vec![$crate::models::radarr_models::MovieHistoryItem::default()]);
|
||||||
|
app.data.radarr_data.movie_details_modal = Some(movie_details_modal);
|
||||||
let mut series_history = $crate::models::stateful_table::StatefulTable::default();
|
let mut series_history = $crate::models::stateful_table::StatefulTable::default();
|
||||||
series_history.set_items(vec![
|
series_history.set_items(vec![
|
||||||
$crate::models::sonarr_models::SonarrHistoryItem::default(),
|
$crate::models::sonarr_models::SonarrHistoryItem::default(),
|
||||||
|
|||||||
@@ -515,6 +515,7 @@ mod tests {
|
|||||||
#[test]
|
#[test]
|
||||||
fn test_indexer_settings_key() {
|
fn test_indexer_settings_key() {
|
||||||
let mut app = App::default();
|
let mut app = App::default();
|
||||||
|
app.data.sonarr_data.indexers.set_items(vec![Indexer::default()]);
|
||||||
app.push_navigation_stack(ActiveSonarrBlock::Indexers.into());
|
app.push_navigation_stack(ActiveSonarrBlock::Indexers.into());
|
||||||
app
|
app
|
||||||
.data
|
.data
|
||||||
|
|||||||
@@ -1,17 +1,21 @@
|
|||||||
|
use crate::models::HorizontallyScrollableText;
|
||||||
use crate::app::key_binding::DEFAULT_KEYBINDINGS;
|
use crate::app::key_binding::DEFAULT_KEYBINDINGS;
|
||||||
use crate::app::App;
|
use crate::app::App;
|
||||||
use crate::event::Key;
|
use crate::event::Key;
|
||||||
|
use crate::handle_table_events;
|
||||||
use crate::handlers::sonarr_handlers::handle_change_tab_left_right_keys;
|
use crate::handlers::sonarr_handlers::handle_change_tab_left_right_keys;
|
||||||
use crate::handlers::sonarr_handlers::indexers::edit_indexer_handler::EditIndexerHandler;
|
use crate::handlers::sonarr_handlers::indexers::edit_indexer_handler::EditIndexerHandler;
|
||||||
use crate::handlers::sonarr_handlers::indexers::edit_indexer_settings_handler::IndexerSettingsHandler;
|
use crate::handlers::sonarr_handlers::indexers::edit_indexer_settings_handler::IndexerSettingsHandler;
|
||||||
use crate::handlers::sonarr_handlers::indexers::test_all_indexers_handler::TestAllIndexersHandler;
|
use crate::handlers::sonarr_handlers::indexers::test_all_indexers_handler::TestAllIndexersHandler;
|
||||||
use crate::handlers::{handle_clear_errors, handle_prompt_toggle, KeyEventHandler};
|
use crate::handlers::{handle_clear_errors, handle_prompt_toggle, KeyEventHandler};
|
||||||
|
use crate::handlers::table_handler::TableHandlingProps;
|
||||||
use crate::models::servarr_data::sonarr::sonarr_data::{
|
use crate::models::servarr_data::sonarr::sonarr_data::{
|
||||||
ActiveSonarrBlock, EDIT_INDEXER_NZB_SELECTION_BLOCKS, EDIT_INDEXER_TORRENT_SELECTION_BLOCKS,
|
ActiveSonarrBlock, EDIT_INDEXER_NZB_SELECTION_BLOCKS, EDIT_INDEXER_TORRENT_SELECTION_BLOCKS,
|
||||||
INDEXERS_BLOCKS, INDEXER_SETTINGS_SELECTION_BLOCKS,
|
INDEXERS_BLOCKS, INDEXER_SETTINGS_SELECTION_BLOCKS,
|
||||||
};
|
};
|
||||||
use crate::models::BlockSelectionState;
|
use crate::models::BlockSelectionState;
|
||||||
use crate::models::Scrollable;
|
use crate::models::Scrollable;
|
||||||
|
use crate::models::servarr_models::Indexer;
|
||||||
use crate::network::sonarr_network::SonarrEvent;
|
use crate::network::sonarr_network::SonarrEvent;
|
||||||
|
|
||||||
mod edit_indexer_handler;
|
mod edit_indexer_handler;
|
||||||
@@ -29,22 +33,30 @@ pub(super) struct IndexersHandler<'a, 'b> {
|
|||||||
context: Option<ActiveSonarrBlock>,
|
context: Option<ActiveSonarrBlock>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<'a, 'b> IndexersHandler<'a, 'b> {
|
||||||
|
handle_table_events!(self, indexers, self.app.data.sonarr_data.indexers, Indexer);
|
||||||
|
}
|
||||||
|
|
||||||
impl<'a, 'b> KeyEventHandler<'a, 'b, ActiveSonarrBlock> for IndexersHandler<'a, 'b> {
|
impl<'a, 'b> KeyEventHandler<'a, 'b, ActiveSonarrBlock> for IndexersHandler<'a, 'b> {
|
||||||
fn handle(&mut self) {
|
fn handle(&mut self) {
|
||||||
match self.active_sonarr_block {
|
let indexers_table_handling_props = TableHandlingProps::new(ActiveSonarrBlock::Indexers.into());
|
||||||
_ if EditIndexerHandler::accepts(self.active_sonarr_block) => {
|
|
||||||
EditIndexerHandler::with(self.key, self.app, self.active_sonarr_block, self.context)
|
if !self.handle_indexers_table_events(indexers_table_handling_props) {
|
||||||
.handle()
|
match self.active_sonarr_block {
|
||||||
|
_ if EditIndexerHandler::accepts(self.active_sonarr_block) => {
|
||||||
|
EditIndexerHandler::with(self.key, self.app, self.active_sonarr_block, self.context)
|
||||||
|
.handle()
|
||||||
|
}
|
||||||
|
_ if IndexerSettingsHandler::accepts(self.active_sonarr_block) => {
|
||||||
|
IndexerSettingsHandler::with(self.key, self.app, self.active_sonarr_block, self.context)
|
||||||
|
.handle()
|
||||||
|
}
|
||||||
|
_ if TestAllIndexersHandler::accepts(self.active_sonarr_block) => {
|
||||||
|
TestAllIndexersHandler::with(self.key, self.app, self.active_sonarr_block, self.context)
|
||||||
|
.handle()
|
||||||
|
}
|
||||||
|
_ => self.handle_key_event(),
|
||||||
}
|
}
|
||||||
_ if IndexerSettingsHandler::accepts(self.active_sonarr_block) => {
|
|
||||||
IndexerSettingsHandler::with(self.key, self.app, self.active_sonarr_block, self.context)
|
|
||||||
.handle()
|
|
||||||
}
|
|
||||||
_ if TestAllIndexersHandler::accepts(self.active_sonarr_block) => {
|
|
||||||
TestAllIndexersHandler::with(self.key, self.app, self.active_sonarr_block, self.context)
|
|
||||||
.handle()
|
|
||||||
}
|
|
||||||
_ => self.handle_key_event(),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user