1.1.5 Улучшены взаимодействия с командами
This commit is contained in:
@@ -15,5 +15,4 @@ help_cmd = CommandHandler(
|
|||||||
callbackdata="keywords",
|
callbackdata="keywords",
|
||||||
keyboard=get_help_kb,
|
keyboard=get_help_kb,
|
||||||
text_msg="Привет! Это команда помощи. Тут ты можешь узнать, как пользоваться ботом.",
|
text_msg="Привет! Это команда помощи. Тут ты можешь узнать, как пользоваться ботом.",
|
||||||
#media="", path_to_media=""
|
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -17,13 +17,13 @@ __all__ = ("CommandHandler",)
|
|||||||
|
|
||||||
# Класс-шаблон для команд
|
# Класс-шаблон для команд
|
||||||
class CommandHandler:
|
class CommandHandler:
|
||||||
def __init__(self, text_msg, name: str, keywords: list, func = None, chat_action: bool = False,
|
def __init__(self, name: str, keywords: list, func=None, text_msg: str = None, chat_action: bool = False,
|
||||||
description: str = "Описание команды", tg_links: bool = False,
|
description: str = "Описание команды", tg_links: bool = False,
|
||||||
keyboard=None, prefix=BotVar.prefix, callbackdata=None,
|
keyboard=None, prefix=BotVar.prefix, callbackdata=None,
|
||||||
ignore_case: bool = True, activate_keywoards: bool = True,
|
ignore_case: bool = True, activate_keywoards: bool = True,
|
||||||
activate_commands: bool = True, activate_callback: bool = True,
|
activate_commands: bool = True, activate_callback: bool = True,
|
||||||
media: str = "message", path_to_media=None, parse_mode: str = BotVar.parse_mode,
|
media: str = "message", path_to_media=None, parse_mode: str = BotVar.parse_mode,
|
||||||
disable_notification: bool = False):
|
disable_notification: bool = False, protect: bool = True, ):
|
||||||
|
|
||||||
self.router = Router(name=f"{name}_router")
|
self.router = Router(name=f"{name}_router")
|
||||||
self.name = name
|
self.name = name
|
||||||
@@ -38,6 +38,7 @@ class CommandHandler:
|
|||||||
self.disable_notification = disable_notification
|
self.disable_notification = disable_notification
|
||||||
|
|
||||||
self.media = media.lower()
|
self.media = media.lower()
|
||||||
|
self.protect = protect
|
||||||
self.func = func
|
self.func = func
|
||||||
|
|
||||||
# Поддержка до 10 медиафайлов через список
|
# Поддержка до 10 медиафайлов через список
|
||||||
@@ -78,22 +79,7 @@ class CommandHandler:
|
|||||||
reply_markup=self.keyboard() if self.keyboard else None,
|
reply_markup=self.keyboard() if self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification,
|
disable_notification=self.disable_notification,
|
||||||
)
|
has_protected_content=self.protect,
|
||||||
if self.chat_action:
|
|
||||||
await message.bot.send_chat_action(
|
|
||||||
chat_id=message.chat.id,
|
|
||||||
action=ChatAction.TYPING,
|
|
||||||
)
|
|
||||||
elif self.media == "quiz":
|
|
||||||
# Отправка викторины (quiz)
|
|
||||||
await message.reply_poll(
|
|
||||||
question=self.text_msg, # Текст сообщения используется как вопрос викторины
|
|
||||||
options=["Вариант 1", "Вариант 2"], # Заглушка, варианты нужно задавать отдельно
|
|
||||||
is_anonymous=True,
|
|
||||||
type="quiz",
|
|
||||||
correct_option_id=0, # Первый вариант по умолчанию правильный
|
|
||||||
reply_markup=self.keyboard() if self.keyboard else None,
|
|
||||||
disable_notification=self.disable_notification
|
|
||||||
)
|
)
|
||||||
if self.chat_action:
|
if self.chat_action:
|
||||||
await message.bot.send_chat_action(
|
await message.bot.send_chat_action(
|
||||||
@@ -117,14 +103,16 @@ class CommandHandler:
|
|||||||
|
|
||||||
await message.reply_media_group(
|
await message.reply_media_group(
|
||||||
media=media_group,
|
media=media_group,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
has_protected_content=self.protect,
|
||||||
|
|
||||||
)
|
)
|
||||||
# Отправка клавиатуры отдельным сообщением, если есть
|
# Отправка клавиатуры отдельным сообщением, если есть
|
||||||
if self.keyboard:
|
if self.keyboard:
|
||||||
await message.reply(
|
await message.reply(
|
||||||
text=" ",
|
text=" ",
|
||||||
reply_markup=self.keyboard(),
|
reply_markup=self.keyboard(),
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
)
|
)
|
||||||
if self.chat_action:
|
if self.chat_action:
|
||||||
await message.bot.send_chat_action(
|
await message.bot.send_chat_action(
|
||||||
@@ -144,7 +132,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
await message.reply_photo(
|
await message.reply_photo(
|
||||||
@@ -152,7 +141,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
if self.chat_action and is_last:
|
if self.chat_action and is_last:
|
||||||
await message.bot.send_chat_action(
|
await message.bot.send_chat_action(
|
||||||
@@ -167,7 +157,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
await message.reply_animation(
|
await message.reply_animation(
|
||||||
@@ -175,7 +166,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
if self.chat_action and is_last:
|
if self.chat_action and is_last:
|
||||||
await message.bot.send_chat_action(
|
await message.bot.send_chat_action(
|
||||||
@@ -190,7 +182,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
await message.reply_video(
|
await message.reply_video(
|
||||||
@@ -198,7 +191,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
if self.chat_action and is_last:
|
if self.chat_action and is_last:
|
||||||
await message.bot.send_chat_action(
|
await message.bot.send_chat_action(
|
||||||
@@ -213,7 +207,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
await message.reply_video_note(
|
await message.reply_video_note(
|
||||||
@@ -221,7 +216,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
if self.chat_action and is_last:
|
if self.chat_action and is_last:
|
||||||
await message.bot.send_chat_action(
|
await message.bot.send_chat_action(
|
||||||
@@ -236,7 +232,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
await message.reply_audio(
|
await message.reply_audio(
|
||||||
@@ -244,7 +241,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
if self.chat_action and is_last:
|
if self.chat_action and is_last:
|
||||||
await message.bot.send_chat_action(
|
await message.bot.send_chat_action(
|
||||||
@@ -259,7 +257,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
await message.reply_document(
|
await message.reply_document(
|
||||||
@@ -267,7 +266,8 @@ class CommandHandler:
|
|||||||
caption=self.text_msg if is_last else None,
|
caption=self.text_msg if is_last else None,
|
||||||
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
parse_mode=self.parse_mode,
|
parse_mode=self.parse_mode,
|
||||||
disable_notification=self.disable_notification
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
)
|
)
|
||||||
if self.chat_action and is_last:
|
if self.chat_action and is_last:
|
||||||
await message.bot.send_chat_action(
|
await message.bot.send_chat_action(
|
||||||
@@ -275,6 +275,23 @@ class CommandHandler:
|
|||||||
action=ChatAction.UPLOAD_DOCUMENT,
|
action=ChatAction.UPLOAD_DOCUMENT,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
elif self.media == "dice":
|
||||||
|
await message.reply_dice(
|
||||||
|
emoji="🎲", # Эмодзи кубика как стандартное значение, если нет URL
|
||||||
|
caption=self.text_msg if is_last else None,
|
||||||
|
reply_markup=self.keyboard() if is_last and self.keyboard else None,
|
||||||
|
parse_mode=self.parse_mode,
|
||||||
|
disable_notification=self.disable_notification,
|
||||||
|
protect_content=self.protect,
|
||||||
|
)
|
||||||
|
|
||||||
|
if self.chat_action and is_last:
|
||||||
|
await message.bot.send_chat_action(
|
||||||
|
chat_id=message.chat.id,
|
||||||
|
action=ChatAction.CHOOSE_STICKER,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
# Проверка на ошибку
|
# Проверка на ошибку
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
Logs.error(log_type=self.log_type, user=username(message), text=f"Ошибка команды: {e}")
|
Logs.error(log_type=self.log_type, text=f"Ошибка команды: {e}")
|
||||||
|
|||||||
Reference in New Issue
Block a user