0.7.3 Добавлены ссылки и стандартный баннер
(баннер чей-то, для тестов)
This commit is contained in:
@@ -1,20 +1,16 @@
|
|||||||
# BotCode/keyboards/inline_kb/start_inline_kb.py
|
# BotCode/keyboards/inline_kb/start_inline_kb.py
|
||||||
# Создания инлайн-клавиатуры на команду: /start
|
# Создание инлайн-клавиатуры на команду: /start
|
||||||
|
|
||||||
from aiogram.types import InlineKeyboardMarkup
|
from BotLibrary import BaseInlineKeyboard
|
||||||
from aiogram.utils.keyboard import InlineKeyboardBuilder
|
|
||||||
|
|
||||||
# Создание роутера и настройка экспорта
|
# Настройка экспорта в модули
|
||||||
__all__ = ("get_start_kb",)
|
__all__ = ("get_start_kb",)
|
||||||
|
|
||||||
# Функция создания клавиатуры на команду: /actor
|
# Функция создания клавиатуры
|
||||||
def get_start_kb() -> InlineKeyboardMarkup:
|
def get_start_kb(row_width : int = 1):
|
||||||
ikb = InlineKeyboardBuilder()
|
buttons = [
|
||||||
|
("Я Новичок!", None, "novice_cbd"),
|
||||||
# Добавляем кнопки, группируя их по строкам
|
("Где я?", None, "where_i_am_cbd"),
|
||||||
ikb.button(text="Посмотреть инфо-канал", url="https://t.me/laveilinfo")
|
("Мне уже известен этот феномен..", None, "menu"),
|
||||||
ikb.button(text="Отправить анкету", url="https://t.me/laveilinfo")
|
]
|
||||||
ikb.button(text="Предложить союз", url="https://t.me/laveilinfo")
|
return BaseInlineKeyboard(buttons, row_width=row_width).get_keyboard()
|
||||||
|
|
||||||
ikb.adjust(1)
|
|
||||||
return ikb.as_markup()
|
|
||||||
|
|||||||
@@ -1,17 +1,23 @@
|
|||||||
# BotCode/routers/commands/user_cmd/start_cmd.py
|
# BotCode/routers/commands/user_cmd/start_cmd.py
|
||||||
# # Работа с командой /start, для запуска бота
|
# Работа с командой /start, для запуска бота
|
||||||
|
|
||||||
from BotLibrary import CommandHandler
|
from BotLibrary import CommandHandler
|
||||||
from BotCode.keyboards import get_start_kb
|
from BotCode.keyboards import get_start_kb
|
||||||
|
user = "2"
|
||||||
# Создание команды /start с нужными параметрами
|
# Создание команды /start
|
||||||
start_cmd = CommandHandler(
|
start_cmd = CommandHandler(
|
||||||
name="start",
|
name="start",
|
||||||
description="Добро пожаловать!",
|
description="Добро пожаловать!",
|
||||||
keywords=["start", "старт", "запуск", "пуск", "on", "вкл", "с", "s", "ы",
|
keywords=["start", "старт", "запуск", "пуск", "on", "вкл", "с", "s", "ы",
|
||||||
"ыефке", "cnfhn", "pfgecr", "gecr", "щт", "drk", "restart", "куыефке"],
|
"ыефке", "cnfhn", "pfgecr", "gecr", "щт", "drk", "restart", "куыефке"],
|
||||||
callbackdata="keywords",
|
callbackdata="keywords",
|
||||||
text_msg="Старт!",
|
|
||||||
keyboard=get_start_kb,
|
keyboard=get_start_kb,
|
||||||
media="file", path_to_media="https://gdb.voanews.com/455403fe-91ea-4abe-8d29-3862282ec56b_cx0_cy9_cw0_w408_r1_s.jpg",
|
media="photo",
|
||||||
|
path_to_media="ProjectsFiles/media/Banners/start_banner.jpg",
|
||||||
|
tg_links=True,
|
||||||
|
text_msg=f"""
|
||||||
|
Здравствуй, <b><a href="tg://user?id==<users>">дорогой Путник</a></b>.
|
||||||
|
Мое имя - <i>Эми</i>! Я - ваш <i>путеводитель</i> в этом прекрасном месте!
|
||||||
|
Вы <b>готовы</b> отправиться в этот дивный мир?
|
||||||
|
""",
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -3,3 +3,4 @@
|
|||||||
|
|
||||||
# Экспортирование модулей во внешние слои проекта
|
# Экспортирование модулей во внешние слои проекта
|
||||||
from .user_cmd_class import *
|
from .user_cmd_class import *
|
||||||
|
from .keyboards_sample import *
|
||||||
31
BotLibrary/samples/keyboards_sample.py
Normal file
31
BotLibrary/samples/keyboards_sample.py
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
# BotCode/keyboards/inline_kb/base_inline_kb.py
|
||||||
|
# Базовый класс для создания инлайн-клавиатур
|
||||||
|
|
||||||
|
from aiogram.types import InlineKeyboardMarkup
|
||||||
|
from aiogram.utils.keyboard import InlineKeyboardBuilder
|
||||||
|
from typing import List, Tuple, Optional
|
||||||
|
|
||||||
|
|
||||||
|
class BaseInlineKeyboard:
|
||||||
|
def __init__(self, buttons: List[Tuple[str, Optional[str], Optional[str]]], row_width: int = 1):
|
||||||
|
"""
|
||||||
|
:param buttons: список кнопок в формате (текст, url, callback_data).
|
||||||
|
:param row_width: количество кнопок в строке.
|
||||||
|
"""
|
||||||
|
self.buttons = buttons
|
||||||
|
self.row_width = row_width
|
||||||
|
|
||||||
|
def get_keyboard(self) -> InlineKeyboardMarkup:
|
||||||
|
"""
|
||||||
|
Создаёт инлайн-клавиатуру.
|
||||||
|
:return: объект InlineKeyboardMarkup
|
||||||
|
"""
|
||||||
|
ikb = InlineKeyboardBuilder()
|
||||||
|
for text, url, callback_data in self.buttons:
|
||||||
|
if url:
|
||||||
|
ikb.button(text=text, url=url)
|
||||||
|
elif callback_data:
|
||||||
|
ikb.button(text=text, callback_data=callback_data)
|
||||||
|
|
||||||
|
ikb.adjust(self.row_width)
|
||||||
|
return ikb.as_markup()
|
||||||
@@ -15,8 +15,8 @@ __all__ = ("CommandHandler", )
|
|||||||
|
|
||||||
# Класс-шаблон для команд
|
# Класс-шаблон для команд
|
||||||
class CommandHandler:
|
class CommandHandler:
|
||||||
def __init__(self, name: str, keywords : list, chat_action : bool = False,
|
def __init__(self, text_msg, name: str, keywords : list, chat_action : bool = False,
|
||||||
description: str = "Описание команды", text_msg : str = "Сообщение",
|
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,
|
||||||
@@ -38,6 +38,7 @@ class CommandHandler:
|
|||||||
|
|
||||||
self.media = media.lower()
|
self.media = media.lower()
|
||||||
self.path_to_media = path_to_media
|
self.path_to_media = path_to_media
|
||||||
|
self.tg_links = tg_links
|
||||||
if callbackdata == "keywords":
|
if callbackdata == "keywords":
|
||||||
self.callbackdata = keywords
|
self.callbackdata = keywords
|
||||||
else:
|
else:
|
||||||
@@ -57,6 +58,8 @@ class CommandHandler:
|
|||||||
"""Основной хэндлер команды."""
|
"""Основной хэндлер команды."""
|
||||||
try:
|
try:
|
||||||
url : bool = valid_url(self.path_to_media)
|
url : bool = valid_url(self.path_to_media)
|
||||||
|
if self.tg_links:
|
||||||
|
self.text_msg = self.text_msg.replace("<users>", str(message.from_user.id))
|
||||||
|
|
||||||
Logs.info(log_type=self.log_type, user=username(message), text=f"использовал(а) команду /{self.name}")
|
Logs.info(log_type=self.log_type, user=username(message), text=f"использовал(а) команду /{self.name}")
|
||||||
if self.media == "message":
|
if self.media == "message":
|
||||||
|
|||||||
BIN
ProjectsFiles/media/Banners/start_banner.jpg
Normal file
BIN
ProjectsFiles/media/Banners/start_banner.jpg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 188 KiB |
Reference in New Issue
Block a user