From e61698cc5b428ff80a1fe3e2da18c047df47b1d3 Mon Sep 17 00:00:00 2001 From: Vidhu Kant Sharma Date: Thu, 30 Jun 2022 18:36:25 +0530 Subject: added chapters command --- cmd/chapters.go | 68 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ cmd/episodes.go | 2 +- cmd/status.go | 2 +- 3 files changed, 70 insertions(+), 2 deletions(-) create mode 100644 cmd/chapters.go (limited to 'cmd') diff --git a/cmd/chapters.go b/cmd/chapters.go new file mode 100644 index 0000000..c28bb8f --- /dev/null +++ b/cmd/chapters.go @@ -0,0 +1,68 @@ +/* +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 ( + "fmt" + "strings" + "github.com/MikunoNaka/macli/ui" + "github.com/MikunoNaka/macli/mal" + + "github.com/spf13/cobra" +) + +// statusCmd represents the status command +var chaptersCmd = &cobra.Command{ + Use: "chapters", + Short: "Set the number of chapters read", + Long: "Set the number of chapters read" + + "\n" + + "Example Usage:\n" + + " - \x1b[33m`macli chapters `\x1b[0m For interactive prompt (anime-name can be omitted)\n" + + " - \x1b[33m`macli chapters -s 4 `\x1b[0m to set the chapters to 4\n" + + " - \x1b[33m`macli chapters -s +1 `\x1b[0m to increment the chapters by 1\n" + + " - \x1b[33m`macli chapters -s -2 `\x1b[0m to decrement the chapters by 2\n", + Run: func(cmd *cobra.Command, args []string) { + searchInput := strings.Join(args, " ") + if searchInput == "" { + searchInput = ui.TextInput("Search Manga To Set Chapters For: ", "Search can't be blank.") + } + + chInput, err := cmd.Flags().GetString("set-value") + if err != nil { + fmt.Println("Error while reading --set-value flag.", err.Error()) + } + + manga := ui.MangaSearch("Select Manga:", searchInput) + mangaData := mal.GetMangaData(manga.Id, []string{"my_list_status"}) + prevChRead := mangaData.MyListStatus.ChaptersRead + + if chInput == "" { + ui.ChapterInput(manga) + } else { + resp := mal.SetChapters(manga.Id, prevChRead, chInput) + fmt.Println(ui.CreateChapterUpdateConfirmationMessage(manga.Title, prevChRead, resp.ChaptersRead)) + } + }, +} + +func init() { + rootCmd.AddCommand(chaptersCmd) + chaptersCmd.Flags().StringP("set-value", "s", "", "Number of chapters") +} diff --git a/cmd/episodes.go b/cmd/episodes.go index eac501a..203e6e3 100644 --- a/cmd/episodes.go +++ b/cmd/episodes.go @@ -66,5 +66,5 @@ var episodesCmd = &cobra.Command{ func init() { rootCmd.AddCommand(episodesCmd) - episodesCmd.Flags().StringP("set-value", "s", "", "status to be set") + episodesCmd.Flags().StringP("set-value", "s", "", "Number of episodes") } diff --git a/cmd/status.go b/cmd/status.go index dcf177c..94e8d1d 100644 --- a/cmd/status.go +++ b/cmd/status.go @@ -90,5 +90,5 @@ func setMangaStatus(statusInput, searchInput string) { func init() { rootCmd.AddCommand(statusCmd) - statusCmd.Flags().StringP("status", "s", "", "status to be set") + statusCmd.Flags().StringP("set-value", "s", "", "status to be set") } -- cgit v1.2.3