From ab3db8a4ca89293ce0928177e8845d622f13755f Mon Sep 17 00:00:00 2001 From: Vidhu Kant Sharma Date: Wed, 15 Jun 2022 12:59:22 +0530 Subject: added pretty template for TextInput --- cmd/search.go | 18 ++++++++++++------ cmd/status.go | 43 ++++++++++++++++++++++++++++++++++++------- 2 files changed, 48 insertions(+), 13 deletions(-) (limited to 'cmd') diff --git a/cmd/search.go b/cmd/search.go index 28be82c..453f13d 100644 --- a/cmd/search.go +++ b/cmd/search.go @@ -19,10 +19,10 @@ along with this program. If not, see . package cmd import ( + "strings" "github.com/spf13/cobra" "github.com/MikunoNaka/macli/ui" - "strings" - "fmt" + "github.com/MikunoNaka/macli/mal" ) var searchCmd = &cobra.Command { @@ -32,6 +32,7 @@ var searchCmd = &cobra.Command { -- help/description to be added later `, Run: func(cmd *cobra.Command, args []string) { + mal.Init() // needs to be manually called else it won't let you login // read searchInput from command searchInput := strings.Join(args, " ") mangaMode, _ := cmd.Flags().GetBool("manga") @@ -45,22 +46,27 @@ var searchCmd = &cobra.Command { } func searchManga(searchInput string) { + mangaIsAdded := false if searchInput == "" { - searchInput = ui.TextInput("Search Manga:", "Search can't be blank.") + searchInput = ui.TextInput("Search Manga: ", "Search can't be blank.") + } + manga := ui.MangaSearch("Select Manga:", searchInput) + if manga.MyListStatus.Status != "" { + mangaIsAdded = true } - fmt.Printf("You typed in \"%s\" but macli doesn't search manga yet.\n", searchInput) + ui.MangaActionMenu(mangaIsAdded)(manga) } func searchAnime(searchInput string) { animeIsAdded := false if searchInput == "" { - searchInput = ui.TextInput("Search Anime", "Search can't be blank.") + searchInput = ui.TextInput("Search Anime: ", "Search can't be blank.") } anime := ui.AnimeSearch("Select Anime:", searchInput) if anime.MyListStatus.Status != "" { animeIsAdded = true } - ui.ActionMenu(animeIsAdded)(anime) + ui.AnimeActionMenu(animeIsAdded)(anime) } func init() { diff --git a/cmd/status.go b/cmd/status.go index d1b45c2..048bd70 100644 --- a/cmd/status.go +++ b/cmd/status.go @@ -1,7 +1,21 @@ /* -Copyright © 2022 NAME HERE +macli - Unofficial CLI-Based MyAnimeList Client +Copyright © 2022 Vidhu Kant Sharma +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 . */ + package cmd import ( @@ -21,6 +35,7 @@ var statusCmd = &cobra.Command{ -- help/description to be added later `, Run: func(cmd *cobra.Command, args []string) { + mal.Init() // needs to be manually called else it won't let you login searchInput := strings.Join(args, " ") statusInput, err := cmd.Flags().GetString("status") @@ -34,8 +49,7 @@ var statusCmd = &cobra.Command{ } if mangaMode { - // setMangaStatus(statusInput, searchInput) - fmt.Println("Manga mode coming soon") + setMangaStatus(statusInput, searchInput) } else { setAnimeStatus(statusInput, searchInput) } @@ -45,16 +59,31 @@ var statusCmd = &cobra.Command{ func setAnimeStatus(statusInput, searchInput string) { if searchInput == "" { - searchInput = ui.TextInput("Search Anime To Update", "Search can't be blank.") + searchInput = ui.TextInput("Search Anime To Update: ", "Search can't be blank.") } anime := ui.AnimeSearch("Select Anime:", searchInput) if statusInput == "" { - ui.StatusMenu(anime) + ui.AnimeStatusMenu(anime) + } else { + mal.SetAnimeStatus(anime.Id, statusInput) + fmt.Printf("Successfully set \"%s\" to \"%s\"\n", anime.Title, statusInput) + } +} + +func setMangaStatus(statusInput, searchInput string) { + if searchInput == "" { + searchInput = ui.TextInput("Search Manga To Update: ", "Search can't be blank.") + } + + manga := ui.MangaSearch("Select Manga:", searchInput) + + if statusInput == "" { + ui.MangaStatusMenu(manga) } else { - mal.SetStatus(anime.Id, statusInput) - fmt.Printf("Successfully set \"%s\" to \"%s\"", anime.Title, statusInput) + mal.SetAnimeStatus(manga.Id, statusInput) + fmt.Printf("Successfully set \"%s\" to \"%s\"\n", manga.Title, statusInput) } } -- cgit v1.2.3