aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--cmd/episodes.go68
-rw-r--r--mal/episodes.go33
-rw-r--r--ui/episodes.go12
3 files changed, 101 insertions, 12 deletions
diff --git a/cmd/episodes.go b/cmd/episodes.go
new file mode 100644
index 0000000..5c8b6e0
--- /dev/null
+++ b/cmd/episodes.go
@@ -0,0 +1,68 @@
+/*
+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"
+ "strings"
+ "github.com/MikunoNaka/macli/ui"
+ "github.com/MikunoNaka/macli/mal"
+
+ "github.com/spf13/cobra"
+)
+
+// statusCmd represents the status command
+var episodesCmd = &cobra.Command{
+ Use: "episodes",
+ Short: "Set an anime/manga's status",
+ Long: "Set an anime's status\n" +
+ "\n" +
+ "Example Usage:\n" +
+ " - \x1b[33m`macli status <anime-name>`\x1b[0m For interactive prompt (anime-name can be omitted)\n" +
+ " - \x1b[33m`macli status -s \x1b[34mwatching|plan_to_watch|dropped|on_hold|completed\x1b[33m <anime-name>`\x1b[0m to specify status from command\n",
+ Run: func(cmd *cobra.Command, args []string) {
+ searchInput := strings.Join(args, " ")
+ if searchInput == "" {
+ searchInput = ui.TextInput("Search Anime To Set Episodes For: ", "Search can't be blank.")
+ }
+
+ epInput, err := cmd.Flags().GetString("set-value")
+ if err != nil {
+ fmt.Println("Error while reading --set-value flag.", err.Error())
+ }
+
+ anime := ui.AnimeSearch("Select Anime:", searchInput)
+ animeData := mal.GetAnimeData(anime.Id, []string{"my_list_status"})
+ prevEpWatched := animeData.MyListStatus.EpWatched
+
+ if epInput == "" {
+ ui.EpisodeInput(anime)
+ } else {
+ resp := mal.SetEpisodes(anime.Id, prevEpWatched, epInput)
+ fmt.Println(ui.CreateEpisodeUpdateConfirmationMessage(anime.Title, prevEpWatched, resp.EpWatched))
+ }
+
+
+ },
+}
+
+func init() {
+ rootCmd.AddCommand(episodesCmd)
+ episodesCmd.Flags().StringP("set-value", "s", "", "status to be set")
+}
diff --git a/mal/episodes.go b/mal/episodes.go
index 255f8b0..c0ac116 100644
--- a/mal/episodes.go
+++ b/mal/episodes.go
@@ -22,26 +22,36 @@ import (
"fmt"
"os"
"strconv"
+ a "github.com/MikunoNaka/MAL2Go/v2/user/anime"
+ m "github.com/MikunoNaka/MAL2Go/v2/user/manga"
)
-func SetEpisodes(animeId int, ep string) {
- epValue, err := strconv.Atoi(ep)
+func SetEpisodes(animeId, prevValue int, ep string) a.UpdateResponse {
+ epInt, err := strconv.Atoi(ep)
if err != nil {
fmt.Println("Error while parsing episode input", err)
os.Exit(1)
}
- sign := ep[0:1]
- if sign == "+" || sign == "-" {
- fmt.Printf("Cannot increment/decrement watched episodes by %d\n. Currently that doesn't wokr", epValue)
- os.Exit(2)
+ var epValue int
+ switch ep[0:1] {
+ case "+", "-":
+ // works both for increment and decrement
+ epValue = prevValue + epInt
+ default:
+ epValue = epInt
}
- userAnimeClient.SetWatchedEpisodes(animeId, epValue)
+ res, err := userAnimeClient.SetWatchedEpisodes(animeId, epValue)
+ if err != nil {
+ fmt.Println("MyAnimeList returned error while updating episodes:", err)
+ os.Exit(1)
+ }
+ return res
}
-func SetChapters(mangaId int, ch string) {
+func SetChapters(mangaId, prevValue int, ch string) m.UpdateResponse {
chValue, err := strconv.Atoi(ch)
if err != nil {
fmt.Println("Error while parsing chapter input", err)
@@ -54,5 +64,10 @@ func SetChapters(mangaId int, ch string) {
os.Exit(2)
}
- userMangaClient.SetChaptersRead(mangaId, chValue)
+ res, err := userMangaClient.SetChaptersRead(mangaId, chValue)
+ if err != nil {
+ fmt.Println("MyAnimeList returned error while updating chapters:", err)
+ os.Exit(1)
+ }
+ return res
}
diff --git a/ui/episodes.go b/ui/episodes.go
index 277d52f..748482b 100644
--- a/ui/episodes.go
+++ b/ui/episodes.go
@@ -29,6 +29,12 @@ import (
p "github.com/manifoldco/promptui"
)
+// very short name I know
+func CreateEpisodeUpdateConfirmationMessage(title string, prevEpNum, epNum int) string {
+ return fmt.Sprintf("Set Episodes Watched for \x1b[35m%s\x1b[0m from \x1b[1;36m%d\x1b[0m to \x1b[1;33m%d\x1b[0m.", title, prevEpNum, epNum)
+}
+
+
func EpisodeInput(anime a.Anime) {
// fetch number of total episodes, number of watched episodes from the API
animeData := mal.GetAnimeData(anime.Id, []string{"num_episodes", "my_list_status"})
@@ -60,8 +66,8 @@ func EpisodeInput(anime a.Anime) {
os.Exit(1)
}
- // TODO: read resp and show confirmation message
- mal.SetEpisodes(anime.Id, res)
+ resp := mal.SetEpisodes(anime.Id, epWatchedNum, res)
+ fmt.Println(CreateEpisodeUpdateConfirmationMessage(anime.Title, epWatchedNum, resp.EpWatched))
}
func ChapterInput(manga m.Manga) {
@@ -96,5 +102,5 @@ func ChapterInput(manga m.Manga) {
}
// TODO: read resp and show confirmation message
- mal.SetChapters(manga.Id, res)
+ mal.SetChapters(manga.Id, chReadNum, res)
}