Compare commits

..

No commits in common. "af81562606546457249035a43e77a39fc6d79557" and "f5b5887616c7f84ac3e38ffaffa8f6f927eac87e" have entirely different histories.

3 changed files with 57 additions and 80 deletions

View File

@ -1,10 +1,6 @@
# mpv-youtube-queue # mpv-youtube-queue
<div align="center"> A Lua script that implements the YouTube 'Add to Queue' functionality in MPV
A Lua script that implements the YouTube 'Add to Queue' functionality for mpv
</div>
![mpv-youtube-queue image](.assets/mpv-youtube-queue.png) ![mpv-youtube-queue image](.assets/mpv-youtube-queue.png)
@ -17,7 +13,6 @@ A Lua script that implements the YouTube 'Add to Queue' functionality for mpv
- Edit the order of videos in the queue - Edit the order of videos in the queue
- Open the URL or channel page of the currently playing video in a new browser tab - Open the URL or channel page of the currently playing video in a new browser tab
- Download the currently playing video - Download the currently playing video
- Download a video in the queue
## Notes ## Notes
@ -47,23 +42,21 @@ This script requires the following software to be installed on the system
- `add_to_queue - ctrl+a`: Add a video in the clipboard to the queue - `add_to_queue - ctrl+a`: Add a video in the clipboard to the queue
- `download_current_video - ctrl+d`: Download the currently playing video - `download_current_video - ctrl+d`: Download the currently playing video
- `download_selected_video - ctrl+D`: Download the currently selected video - `move_cursor_down - ctrl+DOWN`: Move the cursor down one row in the queue
in the queue - `move_cursor_up - ctrl+UP`- Move the cursor up one row in the queue
- `move_video - ctrl+m`: Mark/move the selected video in the queue - `move_video - ctrl+m`: Mark/move the selected video in the queue
- `play_next_in_queue - ctrl+n`: Play the next video in the queue
- `open_video_in_browser - ctrl+o`: Open the currently playing video in the browser
- `open_channel_in_browser - ctrl+O`: Open the channel page for the currently - `open_channel_in_browser - ctrl+O`: Open the channel page for the currently
playing video in the browser playing video in the browser
- `open_video_in_browser - ctrl+o`: Open the currently playing video in the browser
- `play_next_in_queue - ctrl+n`: Play the next video in the queue
- `play_previous_in_queue - ctrl+p`: Play the previous video in the queue - `play_previous_in_queue - ctrl+p`: Play the previous video in the queue
- `play_selected_video - ctrl+ENTER`: Play the currently selected video in
the queue
- `print_current_video - ctrl+P`: Print the name and channel of the currently - `print_current_video - ctrl+P`: Print the name and channel of the currently
playing video to the OSD playing video to the OSD
- `print_queue - ctrl+q`: Print the contents of the queue to the OSD - `print_queue - ctrl+q`: Print the contents of the queue to the OSD
- `remove_from_queue - ctrl+x`: Remove the currently selected video from the - `remove_from_queue - ctrl+x`: Remove the currently selected video from the
queue queue
- `move_cursor_up - ctrl+UP`- Move the cursor up one row in the queue
- `move_cursor_down - ctrl+DOWN`: Move the cursor down one row in the queue
- `play_selected_video - ctrl+ENTER`: Play the currently selected video in
the queue
### Default Option ### Default Option
@ -82,7 +75,6 @@ This script requires the following software to be installed on the system
- `show_errors - yes`: Show error messages on the OSD - `show_errors - yes`: Show error messages on the OSD
- `ytdlp_output_template - %(uploader)s/%(title)s.%(ext)s`: The [yt-dlp output - `ytdlp_output_template - %(uploader)s/%(title)s.%(ext)s`: The [yt-dlp output
template string](https://github.com/yt-dlp/yt-dlp#output-template) template string](https://github.com/yt-dlp/yt-dlp#output-template)
- Full default path is: `~/videos/YouTube/<uploader>/<title>.<ext>`
## License ## License

View File

@ -1,17 +1,14 @@
add_to_queue=ctrl+a add_to_queue=ctrl+a
download_current_video=ctrl+d move_cursor_down=ctrl+DOWN
download_selected_video=ctrl+D move_cursor_up=ctrl+UP
move_video=ctrl+m
play_next_in_queue=ctrl+n
open_video_in_browser=ctrl+o
open_channel_in_browser=ctrl+O open_channel_in_browser=ctrl+O
open_video_in_browser=ctrl+o
play_next_in_queue=ctrl+n
play_previous_in_queue=ctrl+p play_previous_in_queue=ctrl+p
play_selected_video=ctrl+ENTER
print_current_video=ctrl+P print_current_video=ctrl+P
print_queue=ctrl+q print_queue=ctrl+q
remove_from_queue=ctrl+x remove_from_queue=ctrl+x
move_cursor_up=ctrl+UP
move_cursor_down=ctrl+DOWN
play_selected_video=ctrl+ENTER
browser=firefox browser=firefox
clipboard_command=xclip -o clipboard_command=xclip -o
cursor_icon=➤ cursor_icon=➤
@ -24,4 +21,3 @@ font_name=JetBrains Mono
font_size=12 font_size=12
marked_icon=⇅ marked_icon=⇅
show_errors=yes show_errors=yes
ytdlp_output_template=%(uploader)s/%(title)s.%(ext)s

View File

@ -28,30 +28,29 @@ local styleOff = mp.get_property("osd-ass-cc/1")
local options = { local options = {
add_to_queue = "ctrl+a", add_to_queue = "ctrl+a",
download_current_video = "ctrl+d", download_current_video = "ctrl+d",
download_selected_video = "ctrl+D", move_cursor_down = "ctrl+DOWN",
move_cursor_up = "ctrl+UP",
move_video = "ctrl+m", move_video = "ctrl+m",
play_next_in_queue = "ctrl+n",
open_video_in_browser = "ctrl+o",
open_channel_in_browser = "ctrl+O", open_channel_in_browser = "ctrl+O",
open_video_in_browser = "ctrl+o",
play_next_in_queue = "ctrl+n",
play_previous_in_queue = "ctrl+p", play_previous_in_queue = "ctrl+p",
play_selected_video = "ctrl+ENTER",
print_current_video = "ctrl+P", print_current_video = "ctrl+P",
print_queue = "ctrl+q", print_queue = "ctrl+q",
remove_from_queue = "ctrl+x", remove_from_queue = "ctrl+x",
move_cursor_up = "ctrl+UP",
move_cursor_down = "ctrl+DOWN",
play_selected_video = "ctrl+ENTER",
browser = "firefox",
clipboard_command = "xclip -o", clipboard_command = "xclip -o",
browser = "firefox",
cursor_icon = "", cursor_icon = "",
display_limit = 6, marked_icon = "",
download_directory = "~/videos/YouTube", download_directory = "~/videos/YouTube",
download_quality = "720p", download_format_str = "%(uploader)s/%(title)s.%(ext)s",
downloader = "curl", downloader = "curl",
download_quality = "720p",
font_name = "JetBrains Mono", font_name = "JetBrains Mono",
font_size = 12, font_size = 12,
marked_icon = "", display_limit = 6,
show_errors = false, show_errors = false
ytdlp_output_template = "%(uploader)s/%(title)s.%(ext)s"
} }
mp.options.read_options(options, "mpv-youtube-queue") mp.options.read_options(options, "mpv-youtube-queue")
@ -453,54 +452,46 @@ function YouTubeQueue.play_previous_video()
sleep(MSG_DURATION) sleep(MSG_DURATION)
end end
function YouTubeQueue.download_video_at(idx) function YouTubeQueue.download_current_video()
if current_video and current_video ~= "" then
local o = options local o = options
local v = video_queue[idx] local v = current_video
local q = o.download_quality:sub(1, -2) local q = o.download_quality:sub(1, -2)
local dl_dir = expanduser(o.download_directory) local dl_dir = expanduser(o.download_directory)
local command = 'yt-dlp -f \'bestvideo[height<=' .. q .. local command = 'yt-dlp -f \'bestvideo[height<=' .. q ..
']+bestaudio/best[height<=' .. q .. ']\' -o "' .. dl_dir .. ']+bestaudio/best[height<=' .. q .. ']\' -o "' ..
"/" .. options.ytdlp_output_template .. dl_dir .. "/" .. options.download_format_str ..
'" --downloader ' .. o.downloader .. ' ' .. v.video_url '" --downloader ' .. o.downloader .. ' ' ..
v.video_url
-- Run the download command -- Run the download command
local handle = io.popen(command) local handle = io.popen(command)
if handle == nil then if handle == nil then
print_osd_message("Error starting download.", MSG_DURATION, style.error) print_osd_message("Error starting download.", MSG_DURATION,
style.error)
return return
end end
print_osd_message("Starting download for " .. v.video_name, MSG_DURATION) print_osd_message("Starting download for " .. v.video_name, MSG_DURATION)
local result = handle:read("*a") local result = handle:read("*a")
handle:close() handle:close()
if result == nil then if result == nil then
print_osd_message("Error starting download.", MSG_DURATION, style.error) print_osd_message("Error starting download.", MSG_DURATION,
style.error)
return return
end end
if result then if result then
print_osd_message("Finished downloading " .. v.video_name, MSG_DURATION) print_osd_message("Finished downloading " .. v.video_name,
MSG_DURATION)
else else
print_osd_message("Error downloading " .. v.video_name, MSG_DURATION, print_osd_message("Error downloading " .. v.video_name,
style.error) MSG_DURATION, style.error)
end end
end
function YouTubeQueue.download_current_video()
if current_video ~= nil and current_video ~= "" then
YouTubeQueue.download_video_at(index)
else else
print_osd_message("No video to download.", MSG_DURATION, style.error) print_osd_message("No video to download.", MSG_DURATION, style.error)
end end
end end
function YouTubeQueue.download_selected_video()
if selected_index == 1 and current_video == nil then
print_osd_message("No video to download.", MSG_DURATION, style.error)
return
end
YouTubeQueue.download_video_at(selected_index)
end
function YouTubeQueue.remove_from_queue() function YouTubeQueue.remove_from_queue()
if index == selected_index then if index == selected_index then
print_osd_message("Cannot remove current video", MSG_DURATION, print_osd_message("Cannot remove current video", MSG_DURATION,
@ -564,8 +555,6 @@ mp.add_key_binding(options.open_channel_in_browser, "open_channel_in_browser",
open_channel_in_browser) open_channel_in_browser)
mp.add_key_binding(options.download_current_video, "download_current_video", mp.add_key_binding(options.download_current_video, "download_current_video",
YouTubeQueue.download_current_video) YouTubeQueue.download_current_video)
mp.add_key_binding(options.download_selected_video, "download_selected_video",
YouTubeQueue.download_selected_video)
mp.add_key_binding(options.move_video, "move_video", mp.add_key_binding(options.move_video, "move_video",
YouTubeQueue.mark_and_move_video) YouTubeQueue.mark_and_move_video)
mp.add_key_binding(options.remove_from_queue, "delete_video", mp.add_key_binding(options.remove_from_queue, "delete_video",