from config import IMG_4 from driver.veez import call_py from pytgcalls.types import Update from driver.queues import QUEUE, clear_queue, get_queue, pop_an_item from pytgcalls.types.input_stream import AudioPiped, AudioVideoPiped from pytgcalls.types.input_stream.quality import ( HighQualityAudio, HighQualityVideo, LowQualityVideo, MediumQualityVideo, ) from pytgcalls.types.stream import StreamAudioEnded, StreamVideoEnded async def skip_current_song(chat_id): if chat_id in QUEUE: chat_queue = get_queue(chat_id) if len(chat_queue) == 1: await call_py.leave_group_call(chat_id) clear_queue(chat_id) return 1 else: songname = chat_queue[1][0] url = chat_queue[1][1] link = chat_queue[1][2] type = chat_queue[1][3] Q = chat_queue[1][4] if type == "Audio": await call_py.change_stream( chat_id, AudioPiped( url, ), ) elif type == "Video": if Q == 720: hm = HighQualityVideo() elif Q == 480: hm = MediumQualityVideo() elif Q == 360: hm = LowQualityVideo() await call_py.change_stream( chat_id, AudioVideoPiped(url, HighQualityAudio(), hm) ) pop_an_item(chat_id) return [songname, link, type] else: return 0 async def skip_item(chat_id, h): if chat_id in QUEUE: chat_queue = get_queue(chat_id) try: x = int(h) songname = chat_queue[x][0] chat_queue.pop(x) return songname except Exception as e: print(e) return 0 else: return 0 @call_py.on_stream_end() async def on_end_handler(_, u: Update): if isinstance(u, StreamAudioEnded) or isinstance(u, StreamVideoEnded): chat_id = u.chat_id print(chat_id) op = await skip_current_song(chat_id) if op==1: await _.send_message(chat_id, "āŒ __Queues__ **is empty.**\n\n**ā€¢ userbot leaving voice chat**") else: await _.send_photo( chat_id, photo=f"{IMG_4}", caption=f"šŸ’” **Streaming next track**\n\nšŸ· **Name:** [{op[0]}]({op[1]})\nšŸ’­ **Chat:** `{chat_id}`\nšŸ’” **Status:** `Playing`", ) else: pass