anipy-cli 3.1.1__tar.gz → 3.1.3__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of anipy-cli might be problematic. Click here for more details.
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/PKG-INFO +2 -2
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/pyproject.toml +2 -2
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/__init__.py +1 -1
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/arg_parser.py +1 -1
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/clis/history_cli.py +7 -3
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/menus/menu.py +35 -2
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/prompts.py +13 -3
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/README.md +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/cli.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/clis/__init__.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/clis/base_cli.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/clis/binge_cli.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/clis/default_cli.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/clis/download_cli.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/clis/mal_cli.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/clis/seasonal_cli.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/colors.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/config.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/discord.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/mal_proxy.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/menus/__init__.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/menus/base_menu.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/menus/mal_menu.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/menus/seasonal_menu.py +0 -0
- {anipy_cli-3.1.1 → anipy_cli-3.1.3}/src/anipy_cli/util.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: anipy-cli
|
|
3
|
-
Version: 3.1.
|
|
3
|
+
Version: 3.1.3
|
|
4
4
|
Summary: Watch and Download anime from the comfort of your Terminal
|
|
5
5
|
Home-page: https://sdaqo.github.io/anipy-cli
|
|
6
6
|
License: GPL-3.0
|
|
@@ -14,7 +14,7 @@ Classifier: Programming Language :: Python :: 3.9
|
|
|
14
14
|
Classifier: Programming Language :: Python :: 3.10
|
|
15
15
|
Classifier: Programming Language :: Python :: 3.11
|
|
16
16
|
Classifier: Programming Language :: Python :: 3.12
|
|
17
|
-
Requires-Dist: anipy-api (>=3.1.
|
|
17
|
+
Requires-Dist: anipy-api (>=3.1.3,<4.0.0)
|
|
18
18
|
Requires-Dist: appdirs (>=1.4.4,<2.0.0)
|
|
19
19
|
Requires-Dist: inquirerpy (>=0.3.4,<0.4.0)
|
|
20
20
|
Requires-Dist: pypresence (>=4.3.0,<5.0.0)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
[tool.poetry]
|
|
2
2
|
name = "anipy-cli"
|
|
3
|
-
version = "3.1.
|
|
3
|
+
version = "3.1.3"
|
|
4
4
|
description = "Watch and Download anime from the comfort of your Terminal"
|
|
5
5
|
authors = ["sdaqo <sdaqo.dev@protonmail.com>"]
|
|
6
6
|
license = "GPL-3.0"
|
|
@@ -20,7 +20,7 @@ yaspin = "^3.0.2"
|
|
|
20
20
|
inquirerpy = "^0.3.4"
|
|
21
21
|
appdirs = "^1.4.4"
|
|
22
22
|
pypresence = "^4.3.0"
|
|
23
|
-
anipy-api = "^3.1.
|
|
23
|
+
anipy-api = "^3.1.3"
|
|
24
24
|
|
|
25
25
|
[tool.poetry.scripts]
|
|
26
26
|
anipy-cli = "anipy_cli.cli:run_cli"
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
__appname__ = "anipy-cli"
|
|
2
|
-
__version__ = "3.1.
|
|
2
|
+
__version__ = "3.1.3"
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
from typing import TYPE_CHECKING, Optional
|
|
2
2
|
|
|
3
|
+
from InquirerPy.base.control import Choice
|
|
3
4
|
from anipy_api.anime import Anime
|
|
4
5
|
from anipy_api.locallist import LocalList, LocalListEntry
|
|
5
6
|
from InquirerPy import inquirer
|
|
@@ -42,7 +43,10 @@ class HistoryCli(CliBase):
|
|
|
42
43
|
|
|
43
44
|
entry = inquirer.fuzzy( # type: ignore
|
|
44
45
|
message="Select History Entry:",
|
|
45
|
-
choices=
|
|
46
|
+
choices=[
|
|
47
|
+
Choice(value=h, name=f"{n + 1}. {repr(h)}")
|
|
48
|
+
for n, h in enumerate(history)
|
|
49
|
+
],
|
|
46
50
|
long_instruction="To cancel this prompt press ctrl+z",
|
|
47
51
|
mandatory=False,
|
|
48
52
|
).execute()
|
|
@@ -50,8 +54,8 @@ class HistoryCli(CliBase):
|
|
|
50
54
|
if entry is None:
|
|
51
55
|
return False
|
|
52
56
|
|
|
53
|
-
self.history_entry = entry
|
|
54
|
-
self.anime = Anime.from_local_list_entry(
|
|
57
|
+
self.history_entry = LocalListEntry.from_dict(entry)
|
|
58
|
+
self.anime = Anime.from_local_list_entry(self.history_entry)
|
|
55
59
|
|
|
56
60
|
def process(self):
|
|
57
61
|
assert self.anime is not None
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import sys
|
|
2
2
|
from typing import TYPE_CHECKING, List
|
|
3
3
|
|
|
4
|
+
from InquirerPy import inquirer
|
|
5
|
+
from InquirerPy.base.control import Choice
|
|
4
6
|
from anipy_api.download import Downloader
|
|
5
|
-
from anipy_api.provider import LanguageTypeEnum
|
|
7
|
+
from anipy_api.provider import LanguageTypeEnum, ProviderStream
|
|
6
8
|
from anipy_api.locallist import LocalList
|
|
7
9
|
|
|
8
10
|
from anipy_cli.colors import colors, cprint
|
|
@@ -15,7 +17,7 @@ from anipy_cli.prompts import pick_episode_prompt, search_show_prompt
|
|
|
15
17
|
if TYPE_CHECKING:
|
|
16
18
|
from anipy_api.anime import Anime
|
|
17
19
|
from anipy_api.player import PlayerBase
|
|
18
|
-
from anipy_api.provider import Episode
|
|
20
|
+
from anipy_api.provider import Episode
|
|
19
21
|
|
|
20
22
|
from anipy_cli.arg_parser import CliArgs
|
|
21
23
|
|
|
@@ -53,6 +55,7 @@ class Menu(MenuBase):
|
|
|
53
55
|
MenuOption("Select from history", self.selec_hist, "h"),
|
|
54
56
|
MenuOption("Search for Anime", self.search, "a"),
|
|
55
57
|
MenuOption("Add to seasonals", self.add_seasonal, "t"),
|
|
58
|
+
MenuOption("Change video quality", self.change_quality, "v"),
|
|
56
59
|
MenuOption("Print Video Info", self.video_info, "i"),
|
|
57
60
|
MenuOption("Download Episode", self.download_video, "d"),
|
|
58
61
|
MenuOption("Quit", self.quit, "q"),
|
|
@@ -168,6 +171,36 @@ class Menu(MenuBase):
|
|
|
168
171
|
)
|
|
169
172
|
cprint(colors.GREEN, "Anime added to seasonals!")
|
|
170
173
|
|
|
174
|
+
def change_quality(self):
|
|
175
|
+
with DotSpinner(
|
|
176
|
+
"Extracting streams for ",
|
|
177
|
+
colors.BLUE,
|
|
178
|
+
f"{self.anime.name} ({self.lang})",
|
|
179
|
+
" Episode ",
|
|
180
|
+
self.stream.episode,
|
|
181
|
+
"...",
|
|
182
|
+
):
|
|
183
|
+
streams = self.anime.get_videos(self.stream.episode, self.lang)
|
|
184
|
+
streams.reverse()
|
|
185
|
+
|
|
186
|
+
stream = inquirer.select( # type: ignore
|
|
187
|
+
message="Select Stream:",
|
|
188
|
+
choices=[
|
|
189
|
+
Choice(value=s, name=f"{s.resolution}p - {s.url}") for s in streams
|
|
190
|
+
],
|
|
191
|
+
long_instruction="To skip this prompt press ctrl+z",
|
|
192
|
+
mandatory=False,
|
|
193
|
+
).execute()
|
|
194
|
+
|
|
195
|
+
if stream is None:
|
|
196
|
+
return
|
|
197
|
+
|
|
198
|
+
stream = ProviderStream(**stream)
|
|
199
|
+
self.options.quality = stream.resolution
|
|
200
|
+
self.stream = stream
|
|
201
|
+
self.player.play_title(self.anime, self.stream)
|
|
202
|
+
self.print_options()
|
|
203
|
+
|
|
171
204
|
def download_video(self):
|
|
172
205
|
config = Config()
|
|
173
206
|
with DotSpinner("Starting Download...") as s:
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import time
|
|
2
2
|
from typing import TYPE_CHECKING, Optional, List, Tuple
|
|
3
3
|
from InquirerPy import inquirer
|
|
4
|
+
from InquirerPy.base.control import Choice
|
|
4
5
|
from anipy_api.provider import (
|
|
5
6
|
BaseProvider,
|
|
6
7
|
FilterCapabilities,
|
|
@@ -72,7 +73,9 @@ def search_show_prompt(
|
|
|
72
73
|
|
|
73
74
|
anime = inquirer.fuzzy( # type: ignore
|
|
74
75
|
message="Select Show:",
|
|
75
|
-
choices=
|
|
76
|
+
choices=[
|
|
77
|
+
Choice(value=r, name=f"{n + 1}. {repr(r)}") for n, r in enumerate(results)
|
|
78
|
+
],
|
|
76
79
|
long_instruction=(
|
|
77
80
|
"\nS = Anime is available in sub\n"
|
|
78
81
|
"D = Anime is available in dub\n"
|
|
@@ -118,8 +121,15 @@ def season_search_prompt(provider: "BaseProvider") -> Optional["Anime"]:
|
|
|
118
121
|
|
|
119
122
|
anime = inquirer.fuzzy( # type: ignore
|
|
120
123
|
message="Select Show:",
|
|
121
|
-
choices=
|
|
122
|
-
|
|
124
|
+
choices=[
|
|
125
|
+
Choice(value=r, name=f"{n + 1}. {repr(r)}") for n, r in enumerate(results)
|
|
126
|
+
],
|
|
127
|
+
long_instruction=(
|
|
128
|
+
"\nS = Anime is available in sub\n"
|
|
129
|
+
"D = Anime is available in dub\n"
|
|
130
|
+
"First two letters indicate the provider\n"
|
|
131
|
+
"To skip this prompt press ctrl+z"
|
|
132
|
+
),
|
|
123
133
|
mandatory=False,
|
|
124
134
|
).execute()
|
|
125
135
|
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|