diff options
author | Vidhu Kant Sharma <vidhukant@vidhukant.xyz> | 2022-10-02 20:46:50 +0530 |
---|---|---|
committer | Vidhu Kant Sharma <vidhukant@vidhukant.xyz> | 2022-10-02 20:46:50 +0530 |
commit | 8fb49796e37d2bf955d8ffa521f6bcda4f36b766 (patch) | |
tree | e0728f19a33c2f8f71767472c10767548ce99e94 /cmd | |
parent | e0da6a5205169f34671addd533739b6242d5eff3 (diff) |
Automatically select nth search result with --auto-select flag
Diffstat (limited to 'cmd')
-rw-r--r-- | cmd/1 | 136 | ||||
-rw-r--r-- | cmd/chapters.go | 2 | ||||
-rw-r--r-- | cmd/episodes.go | 2 | ||||
-rw-r--r-- | cmd/score.go | 2 | ||||
-rw-r--r-- | cmd/search.go | 2 | ||||
-rw-r--r-- | cmd/status.go | 2 | ||||
-rw-r--r-- | cmd/volumes.go | 2 |
7 files changed, 12 insertions, 136 deletions
@@ -1,136 +0,0 @@ -/* -macli - Unofficial CLI-Based MyAnimeList Client -Copyright © 2022 Vidhu Kant Sharma <vidhukant@vidhukant.xyz> - -This program is free software: you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation, either version 3 of the License, or -(at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program. If not, see <http://www.gnu.org/licenses/>. -*/ - -package cmd - -import ( - "fmt" - "os" - "strings" - - "github.com/MikunoNaka/macli/mal" - "github.com/MikunoNaka/macli/ui" - "github.com/MikunoNaka/macli/util" - a "github.com/MikunoNaka/MAL2Go/v4/anime" - m "github.com/MikunoNaka/MAL2Go/v4/manga" - "github.com/spf13/cobra" -) - -var searchCmd = &cobra.Command { - Use: "search", - Short: "Search for an anime/manga", - Long: "Search for an anime or a manga on MyAnimeList\n" + - "\n" + - "Example Usage:\n" + - "\t\x1b[33m`macli search <anime-name>`\x1b[0m searches for an anime\n" + - "\t\x1b[33m`macli search -m <manga-name>`\x1b[0m searches for a manga\n" + - "\t\x1b[33m`macli search`\x1b[0m interactively asks for an anime to search for (same for manga with -m/--manga flag)\n", - Run: func(cmd *cobra.Command, args []string) { - conf, err := util.BindSearchConfig(cmd.Flags()) - if err != nil { - fmt.Println("Error while parsing flags.", err.Error()) - os.Exit(1) - } - mal.SearchLength = conf.SearchLength - mal.SearchOffset = conf.SearchOffset - mal.SearchNSFW = conf.SearchNSFW - ui.PromptLength = conf.PromptLength - mal.Init() - - // read searchInput from command - searchInput := strings.Join(args, " ") - mangaMode, err := cmd.Flags().GetBool("manga") - if err != nil { - fmt.Println("Error while reading \x1b[33m--manga\x1b[0m flag.", err.Error()) - os.Exit(1) - } - - if mangaMode { - searchManga(searchInput) - } else { - searchAnime(searchInput) - } - }, -} - -func searchManga(searchInput string) { - var selectedManga m.Manga - mangaId := entryId - fields := []string{} - - if entryId < 1 { - if searchInput == "" { - searchInput = ui.TextInput("Search Manga: ", "Search can't be blank.") - } - manga := ui.MangaSearch("Select Manga:", searchInput) - mangaId = manga.Id - fields = []string{"my_list_status", "num_chapters"} - } - - selectedManga = mal.GetMangaData(mangaId, fields) - - if queryOnlyMode { - util.PrintManga(selectedManga) - os.Exit(0) - } - - if entryId > 1 { - fmt.Println("Selected: \x1b[35m" + selectedManga.Title + "\x1b[0m") - } - ui.MangaActionMenu(selectedManga.MyListStatus.Status != "")(selectedManga) -} - -func searchAnime(searchInput string) { - var selectedAnime a.Anime - animeId := entryId - fields := []string{} - - if entryId < 1 { - if searchInput == "" { - searchInput = ui.TextInput("Search Anime: ", "Search can't be blank.") - } - anime := ui.AnimeSearch("Select Anime:", searchInput) - animeId = anime.Id - fields = []string{"my_list_status", "num_episodes"} - } - - selectedAnime = mal.GetAnimeData(animeId, fields) - - if queryOnlyMode { - util.PrintAnime(selectedAnime) - os.Exit(0) - } - - if entryId > 1 { - fmt.Println("Selected: \x1b[35m" + selectedAnime.Title + "\x1b[0m") - } - ui.AnimeActionMenu(selectedAnime.MyListStatus.Status != "")(selectedAnime) -} - -func init() { - rootCmd.AddCommand(searchCmd) - searchCmd.Flags().BoolVarP(&mangaMode, "manga", "m", false, "Use manga mode") - searchCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)") - searchCmd.Flags().BoolVarP(&queryOnlyMode, "query", "q", false, "Query only (don't update data)") - searchCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)") - - searchCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt") - searchCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load") - searchCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results") - searchCmd.Flags().BoolP("search-nsfw", "", false, "Include NSFW-rated items in search results") -} diff --git a/cmd/chapters.go b/cmd/chapters.go index f8c3414..15e2169 100644 --- a/cmd/chapters.go +++ b/cmd/chapters.go @@ -50,6 +50,7 @@ var chaptersCmd = &cobra.Command{ mal.SearchLength = conf.SearchLength mal.SearchOffset = conf.SearchOffset mal.SearchNSFW = conf.SearchNSFW + mal.AutoSel = conf.AutoSel ui.PromptLength = conf.PromptLength mal.Init() @@ -104,6 +105,7 @@ func init() { chaptersCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)") chaptersCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)") + chaptersCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value") chaptersCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt") chaptersCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load") chaptersCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results") diff --git a/cmd/episodes.go b/cmd/episodes.go index fce4b2a..a2dbd4d 100644 --- a/cmd/episodes.go +++ b/cmd/episodes.go @@ -50,6 +50,7 @@ var episodesCmd = &cobra.Command{ mal.SearchLength = conf.SearchLength mal.SearchOffset = conf.SearchOffset mal.SearchNSFW = conf.SearchNSFW + mal.AutoSel = conf.AutoSel ui.PromptLength = conf.PromptLength mal.Init() @@ -104,6 +105,7 @@ func init() { episodesCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)") episodesCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)") + episodesCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value") episodesCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt") episodesCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load") episodesCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results") diff --git a/cmd/score.go b/cmd/score.go index a7a5aaa..57442fe 100644 --- a/cmd/score.go +++ b/cmd/score.go @@ -51,6 +51,7 @@ var scoreCmd = &cobra.Command{ mal.SearchLength = conf.SearchLength mal.SearchOffset = conf.SearchOffset mal.SearchNSFW = conf.SearchNSFW + mal.AutoSel = conf.AutoSel ui.PromptLength = conf.PromptLength mal.Init() @@ -174,6 +175,7 @@ func init() { scoreCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)") scoreCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)") + scoreCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value") scoreCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt") scoreCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load") scoreCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results") diff --git a/cmd/search.go b/cmd/search.go index 0961ffe..8413804 100644 --- a/cmd/search.go +++ b/cmd/search.go @@ -49,6 +49,7 @@ var searchCmd = &cobra.Command { mal.SearchLength = conf.SearchLength mal.SearchOffset = conf.SearchOffset mal.SearchNSFW = conf.SearchNSFW + mal.AutoSel = conf.AutoSel ui.PromptLength = conf.PromptLength mal.Init() @@ -129,6 +130,7 @@ func init() { searchCmd.Flags().BoolVarP(&queryOnlyMode, "query", "q", false, "Query only (don't update data)") searchCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)") + searchCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value") searchCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt") searchCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load") searchCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results") diff --git a/cmd/status.go b/cmd/status.go index 7c641e6..0c92249 100644 --- a/cmd/status.go +++ b/cmd/status.go @@ -48,6 +48,7 @@ var statusCmd = &cobra.Command{ } mal.SearchLength = conf.SearchLength mal.SearchOffset = conf.SearchOffset + mal.AutoSel = conf.AutoSel mal.SearchNSFW = conf.SearchNSFW ui.PromptLength = conf.PromptLength mal.Init() @@ -151,6 +152,7 @@ func init() { statusCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)") statusCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)") + statusCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value") statusCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt") statusCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load") statusCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results") diff --git a/cmd/volumes.go b/cmd/volumes.go index 6df1b69..f1cc108 100644 --- a/cmd/volumes.go +++ b/cmd/volumes.go @@ -49,6 +49,7 @@ var volumesCmd = &cobra.Command{ } mal.SearchLength = conf.SearchLength mal.SearchOffset = conf.SearchOffset + mal.AutoSel = conf.AutoSel mal.SearchNSFW = conf.SearchNSFW ui.PromptLength = conf.PromptLength mal.Init() @@ -104,6 +105,7 @@ func init() { volumesCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of manga (overrides search)") volumesCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)") + volumesCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value") volumesCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt") volumesCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load") volumesCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results") |