feat(commands/voice/queue): use paginators for list
This commit is contained in:
parent
19c7bc477f
commit
1a1272956c
@ -1,7 +1,11 @@
|
|||||||
import math
|
import itertools
|
||||||
|
|
||||||
|
import disnake
|
||||||
|
import disnake_paginator
|
||||||
|
|
||||||
import arguments
|
import arguments
|
||||||
import commands
|
import commands
|
||||||
|
import constants
|
||||||
import utils
|
import utils
|
||||||
import youtubedl
|
import youtubedl
|
||||||
from state import client, players
|
from state import client, players
|
||||||
@ -66,37 +70,10 @@ async def queue_or_play(message):
|
|||||||
type=int,
|
type=int,
|
||||||
help="remove queued songs by queuer",
|
help="remove queued songs by queuer",
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
|
||||||
"-d",
|
|
||||||
"--duration",
|
|
||||||
action="store_true",
|
|
||||||
help="print duration of queued songs",
|
|
||||||
)
|
|
||||||
parser.add_argument(
|
|
||||||
"-p",
|
|
||||||
"--page",
|
|
||||||
type=int,
|
|
||||||
default=1,
|
|
||||||
help="print the specified page of the queue",
|
|
||||||
)
|
|
||||||
if not (args := await parser.parse_args(message, tokens)):
|
if not (args := await parser.parse_args(message, tokens)):
|
||||||
return
|
return
|
||||||
|
|
||||||
if args.duration:
|
if args.clear:
|
||||||
queued_songs = players[message.guild.id].queue
|
|
||||||
formatted_duration = utils.format_duration(
|
|
||||||
sum(
|
|
||||||
[
|
|
||||||
queued.player.duration if queued.player.duration else 0
|
|
||||||
for queued in queued_songs
|
|
||||||
]
|
|
||||||
)
|
|
||||||
)
|
|
||||||
await utils.reply(
|
|
||||||
message,
|
|
||||||
f"queue is **{formatted_duration or '0 seconds'}** long (**{len(queued_songs)}** queued)",
|
|
||||||
)
|
|
||||||
elif args.clear:
|
|
||||||
players[message.guild.id].queue.clear()
|
players[message.guild.id].queue.clear()
|
||||||
await utils.add_check_reaction(message)
|
await utils.add_check_reaction(message)
|
||||||
return
|
return
|
||||||
@ -116,7 +93,7 @@ async def queue_or_play(message):
|
|||||||
targets.append(queued)
|
targets.append(queued)
|
||||||
continue
|
continue
|
||||||
if q := args.remove_queuer:
|
if q := args.remove_queuer:
|
||||||
if q == queued.queuer:
|
if q == queued.trigger_message.author.id:
|
||||||
targets.append(queued)
|
targets.append(queued)
|
||||||
if not args.remove_multiple:
|
if not args.remove_multiple:
|
||||||
targets = targets[:1]
|
targets = targets[:1]
|
||||||
@ -141,7 +118,7 @@ async def queue_or_play(message):
|
|||||||
)
|
)
|
||||||
return
|
return
|
||||||
|
|
||||||
queued = youtubedl.QueuedSong(player, message.author.id)
|
queued = youtubedl.QueuedSong(player, message)
|
||||||
|
|
||||||
if args.now or args.next:
|
if args.now or args.next:
|
||||||
players[message.guild.id].queue_add_front(queued)
|
players[message.guild.id].queue_add_front(queued)
|
||||||
@ -162,45 +139,52 @@ async def queue_or_play(message):
|
|||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
if tokens[0].lower() == "play":
|
if tokens[0].lower() == "play":
|
||||||
message.guild.voice_client.resume()
|
await resume(message)
|
||||||
await utils.reply(
|
|
||||||
message,
|
|
||||||
"resumed!",
|
|
||||||
)
|
|
||||||
else:
|
else:
|
||||||
args.page = max(
|
if players[message.guild.id].queue:
|
||||||
min(args.page, math.ceil(len(players[message.guild.id].queue) / 10)), 1
|
formatted_duration = utils.format_duration(
|
||||||
)
|
sum(
|
||||||
queue_list = lambda: "\n".join(
|
|
||||||
[
|
[
|
||||||
f"**{i + 1}.** {queued.format(with_queuer=True, hide_preview=True)}"
|
queued.player.duration if queued.player.duration else 0
|
||||||
for i, queued in list(enumerate(players[message.guild.id].queue))[
|
for queued in players[message.guild.id].queue
|
||||||
(args.page - 1) * 10 : args.page * 10
|
|
||||||
]
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
currently_playing = (
|
|
||||||
lambda: f"**0.** {'(paused) ' if message.guild.voice_client.is_paused() else ''} {players[message.guild.id].current.format(with_queuer=True)}"
|
|
||||||
)
|
)
|
||||||
if (
|
|
||||||
not players[message.guild.id].queue
|
def embed(description):
|
||||||
and not message.guild.voice_client.source
|
e = disnake.Embed(
|
||||||
):
|
title="Queued",
|
||||||
await utils.reply(
|
description=description,
|
||||||
message,
|
color=constants.EMBED_COLOR,
|
||||||
"nothing is playing or queued!",
|
|
||||||
)
|
)
|
||||||
elif not players[message.guild.id].queue:
|
if formatted_duration:
|
||||||
await utils.reply(message, currently_playing())
|
e.set_footer(text=f"{formatted_duration} long")
|
||||||
elif not message.guild.voice_client.source:
|
return e
|
||||||
await utils.reply(
|
|
||||||
message,
|
await disnake_paginator.ButtonPaginator(
|
||||||
queue_list(),
|
invalid_user_function=utils.invalid_user_handler,
|
||||||
|
color=constants.EMBED_COLOR,
|
||||||
|
segments=list(
|
||||||
|
map(
|
||||||
|
embed,
|
||||||
|
[
|
||||||
|
"\n\n".join(
|
||||||
|
[
|
||||||
|
f"**{i + 1}.** {queued.format(show_queuer=True, hide_preview=True, multiline=True)}"
|
||||||
|
for i, queued in batch
|
||||||
|
]
|
||||||
)
|
)
|
||||||
|
for batch in itertools.batched(
|
||||||
|
enumerate(players[message.guild.id].queue), 10
|
||||||
|
)
|
||||||
|
],
|
||||||
|
)
|
||||||
|
),
|
||||||
|
).start(disnake_paginator.wrappers.MessageInteractionWrapper(message))
|
||||||
else:
|
else:
|
||||||
await utils.reply(
|
await utils.reply(
|
||||||
message,
|
message,
|
||||||
currently_playing() + "\n" + queue_list(),
|
"nothing is queued!",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -337,7 +321,9 @@ def play_next(message, once=False):
|
|||||||
message.channel.send(f"error while trying to play: `{e}`")
|
message.channel.send(f"error while trying to play: `{e}`")
|
||||||
)
|
)
|
||||||
return
|
return
|
||||||
client.loop.create_task(message.channel.send(f"**0.** {queued.format()}"))
|
client.loop.create_task(
|
||||||
|
message.channel.send(f"**0.** {queued.format(show_queuer=True)}")
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def ensure_joined(message):
|
async def ensure_joined(message):
|
||||||
|
6
utils.py
6
utils.py
@ -33,8 +33,10 @@ async def add_check_reaction(message):
|
|||||||
await message.add_reaction("✅")
|
await message.add_reaction("✅")
|
||||||
|
|
||||||
|
|
||||||
async def reply(message, *args):
|
async def reply(message, *args, **kwargs):
|
||||||
await message.reply(*args, allowed_mentions=disnake.AllowedMentions.none())
|
await message.reply(
|
||||||
|
*args, **kwargs, allowed_mentions=disnake.AllowedMentions.none()
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def invalid_user_handler(interaction):
|
async def invalid_user_handler(interaction):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user