diff options
author | Vidhu Kant Sharma <vidhukant@vidhukant.xyz> | 2022-09-30 16:13:40 +0530 |
---|---|---|
committer | Vidhu Kant Sharma <vidhukant@vidhukant.xyz> | 2022-09-30 16:13:40 +0530 |
commit | 6aaea4225d531a7b3ff5e21d12d35a7361aaf43b (patch) | |
tree | 43aa01caff1741f52a95988c7eed82feee79df46 | |
parent | e1bd26b9ad73cd0758ba77373c1cd07f72f47a65 (diff) |
looking for config file systemwidw
-rw-r--r-- | cmd/1 | 136 | ||||
-rw-r--r-- | cmd/list.go | 2 | ||||
-rw-r--r-- | cmd/root.go | 4 | ||||
-rw-r--r-- | cmd/seasonals.go | 1 |
4 files changed, 138 insertions, 5 deletions
@@ -0,0 +1,136 @@ +/* +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/list.go b/cmd/list.go index 9cc0559..16916a9 100644 --- a/cmd/list.go +++ b/cmd/list.go @@ -73,7 +73,6 @@ var listCmd = &cobra.Command{ } else { ui.AnimeList(mal.AnimeList(user, status, sort, conf.IncludeNSFW)) } - }, } @@ -84,7 +83,6 @@ func init() { listCmd.Flags().StringP("sort", "", "list_score", "Sort the list") listCmd.Flags().BoolVarP(&mangaMode, "manga", "m", false, "Use manga mode") listCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)") - listCmd.Flags().IntVarP(&mal.SearchLength, "list-length", "n", 15, "Amount of list items to load (default: all)") listCmd.Flags().IntP("results-length", "n", 10, "Amount of results to load") listCmd.Flags().IntP("results-offset", "o", 0, "Offset for the results") diff --git a/cmd/root.go b/cmd/root.go index 7b379a3..413e6f2 100644 --- a/cmd/root.go +++ b/cmd/root.go @@ -54,8 +54,8 @@ func initConfig() { viper.SetConfigName("macli") //viper.SetConfigType("yaml") viper.AddConfigPath(".") - // viper.AddConfigPath("$HOME/.config/macli") - // viper.AddConfigPath("/etc/macli") + viper.AddConfigPath("$HOME/.config") + viper.AddConfigPath("/etc") // dont show error if file not found // macli doesnt need a config file to work properly diff --git a/cmd/seasonals.go b/cmd/seasonals.go index 3ea5012..2b7a3e0 100644 --- a/cmd/seasonals.go +++ b/cmd/seasonals.go @@ -27,7 +27,6 @@ import ( "github.com/MikunoNaka/macli/mal" "github.com/spf13/cobra" - "github.com/spf13/viper" ) // statusCmd represents the status command |