aboutsummaryrefslogtreecommitdiff
path: root/cmd
diff options
context:
space:
mode:
authorVidhu Kant Sharma <vidhukant@vidhukant.xyz>2022-06-15 12:59:22 +0530
committerVidhu Kant Sharma <vidhukant@vidhukant.xyz>2022-06-15 12:59:22 +0530
commitab3db8a4ca89293ce0928177e8845d622f13755f (patch)
treee5331856b39b43cfea422f806aa046b0925e92e4 /cmd
parent5eb7a3cd41826fccdc432d049dd85a31b4b56073 (diff)
added pretty template for TextInput
Diffstat (limited to 'cmd')
-rw-r--r--cmd/search.go18
-rw-r--r--cmd/status.go43
2 files changed, 48 insertions, 13 deletions
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 <http://www.gnu.org/licenses/>.
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 <EMAIL ADDRESS>
+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 (
@@ -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)
}
}