mirror of
https://github.com/ksyasuda/aniwrapper.git
synced 2024-10-28 04:44:11 -07:00
Add option to browse recently updated anime (#6)
* add recently updated anime option * update aniwrapper menu ordering and increase columns to 2 * replace hardcoded base_url with variable
This commit is contained in:
parent
ba6c302022
commit
4828923abb
34
ani-cli
34
ani-cli
@ -877,7 +877,7 @@ parse_args() {
|
|||||||
is_download=0
|
is_download=0
|
||||||
is_resume=0
|
is_resume=0
|
||||||
is_autoplay=0
|
is_autoplay=0
|
||||||
while getopts 'ad:Hsvq:cf:t:T:CQ:D:Sp:r' OPT; do
|
while getopts 'ad:Hsvq:cf:t:T:CQ:D:Sp:rR' OPT; do
|
||||||
case "$OPT" in
|
case "$OPT" in
|
||||||
a)
|
a)
|
||||||
is_autoplay=1
|
is_autoplay=1
|
||||||
@ -890,6 +890,9 @@ parse_args() {
|
|||||||
r)
|
r)
|
||||||
is_resume=1
|
is_resume=1
|
||||||
;;
|
;;
|
||||||
|
R)
|
||||||
|
scrape=recent
|
||||||
|
;;
|
||||||
H)
|
H)
|
||||||
scrape=history
|
scrape=history
|
||||||
;;
|
;;
|
||||||
@ -1098,6 +1101,35 @@ main() {
|
|||||||
play_file "$video_path"
|
play_file "$video_path"
|
||||||
exit $?
|
exit $?
|
||||||
;;
|
;;
|
||||||
|
recent)
|
||||||
|
# get list of recently added anime from $BASE_URL
|
||||||
|
recently_updated="$(curl -s "$BASE_URL" | sed -nE 's_^[[:space:]]*<a href="/videos/([^"]*)">_\1_p')"
|
||||||
|
while read -r updated_episode; do
|
||||||
|
anime_name=$(printf "%s" "$updated_episode" | sed -E 's/\-episode\-.*//')
|
||||||
|
lg "ANIME NAME: $anime_name"
|
||||||
|
if ! check_db "search" "$anime_name"; then
|
||||||
|
stmt="SELECT COUNT(*) FROM watch_history WHERE anime_name = '$anime_name' AND episode_number = '${updated_episode##*-episode-}';"
|
||||||
|
lg "QUERY: $stmt"
|
||||||
|
if [[ "$(run_stmt "$stmt")" -ne 0 ]]; then
|
||||||
|
lg "$updated_episode watched before... adding to watched list"
|
||||||
|
[[ -z "$watched" ]] && watched="$cnt" || watched="$watched, $cnt"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
((++cnt))
|
||||||
|
done <<< "$recently_updated"
|
||||||
|
selection="$(rofi -dpi "$DPI" -dmenu -no-custom -config "$ROFI_CFG" \
|
||||||
|
-l 15 -a "$watched" -i -p "Enter selection" -async-pre-read 30 \
|
||||||
|
-window-title 'aniwrapper' <<< "$recently_updated")"
|
||||||
|
if [ -z "$selection" ]; then
|
||||||
|
die "No selection made"
|
||||||
|
fi
|
||||||
|
lg "SELECTION: $selection"
|
||||||
|
# get everything before -episode-
|
||||||
|
selection_id="${selection%%-episode-*}"
|
||||||
|
# get everything after -episode-
|
||||||
|
ep_choice_start="${selection##*-episode-}"
|
||||||
|
search_eps "$selection_id" "$ep_choice_start"
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
check_input
|
check_input
|
||||||
|
18
aniwrapper
18
aniwrapper
@ -27,8 +27,8 @@ IS_ALTERNATE_PLAYER=0
|
|||||||
VERBOSE=0
|
VERBOSE=0
|
||||||
SILENT=0
|
SILENT=0
|
||||||
|
|
||||||
quit="7. Quit"
|
quit="8. Quit"
|
||||||
options="1. Stream|2. Download|3. Continue|4. Play from File|5. Sync History|6. Choose Theme|$quit"
|
options="1. Stream|2. Download|3. Continue|4. Recently Updated|5. Play from File|6. Sync History|7. Choose Theme|$quit"
|
||||||
theme=default
|
theme=default
|
||||||
|
|
||||||
help_text() {
|
help_text() {
|
||||||
@ -332,8 +332,8 @@ main() {
|
|||||||
((SILENT != 1)) && lg "CONFIG DIR: $CFG_DIR"
|
((SILENT != 1)) && lg "CONFIG DIR: $CFG_DIR"
|
||||||
((SILENT != 1)) && lg "ROFI CFG: $CFG_FILE"
|
((SILENT != 1)) && lg "ROFI CFG: $CFG_FILE"
|
||||||
choice=$(echo "${options[@]}" | rofi -dpi "$DPI" -dmenu -no-custom -sep '|' \
|
choice=$(echo "${options[@]}" | rofi -dpi "$DPI" -dmenu -no-custom -sep '|' \
|
||||||
-theme-str 'listview {columns: 1;} window {width: 45%;}' \
|
-theme-str 'listview {columns: 2;} window {width: 45%;}' \
|
||||||
-config "$CFG_FILE" -l 7 -i -p "Aniwrapper" -window-title 'aniwrapper')
|
-config "$CFG_FILE" -l 4 -i -p "Aniwrapper" -window-title 'aniwrapper')
|
||||||
|
|
||||||
[ "$choice" == "$quit" ] && quit
|
[ "$choice" == "$quit" ] && quit
|
||||||
|
|
||||||
@ -353,6 +353,10 @@ main() {
|
|||||||
run -H
|
run -H
|
||||||
;;
|
;;
|
||||||
4.)
|
4.)
|
||||||
|
lg "Showing recently updated anime"
|
||||||
|
run -R
|
||||||
|
;;
|
||||||
|
5.)
|
||||||
lg "Play from file selected"
|
lg "Play from file selected"
|
||||||
IS_PLAY_FROM_FILE=1
|
IS_PLAY_FROM_FILE=1
|
||||||
span=$(printf '%s\n%s\n' "$(generate_span "Provide a path to a valid directory, or choose from the list below")" "$(generate_span "The program will begin searching for media files from the supplied directory")")
|
span=$(printf '%s\n%s\n' "$(generate_span "Provide a path to a valid directory, or choose from the list below")" "$(generate_span "The program will begin searching for media files from the supplied directory")")
|
||||||
@ -374,7 +378,7 @@ main() {
|
|||||||
fi
|
fi
|
||||||
exit $?
|
exit $?
|
||||||
;;
|
;;
|
||||||
5.)
|
6.)
|
||||||
lg "Sync history database"
|
lg "Sync history database"
|
||||||
IS_SYNC=1
|
IS_SYNC=1
|
||||||
roficmd="rofi -dpi $DPI -dmenu -config $CFG_FILE -l 0 -p"
|
roficmd="rofi -dpi $DPI -dmenu -config $CFG_FILE -l 0 -p"
|
||||||
@ -393,7 +397,7 @@ main() {
|
|||||||
quit
|
quit
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
6.)
|
7.)
|
||||||
[ -z "$THEMES" ] && die "No themes provided... exiting"
|
[ -z "$THEMES" ] && die "No themes provided... exiting"
|
||||||
theme_idx="$(get_theme_idx)"
|
theme_idx="$(get_theme_idx)"
|
||||||
lg "Theme index: $theme_idx"
|
lg "Theme index: $theme_idx"
|
||||||
@ -406,7 +410,7 @@ main() {
|
|||||||
set_theme "$theme"
|
set_theme "$theme"
|
||||||
main
|
main
|
||||||
;;
|
;;
|
||||||
7.)
|
8.)
|
||||||
quit
|
quit
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
|
Loading…
Reference in New Issue
Block a user