+ gen mode
This commit is contained in:
@@ -25,9 +25,11 @@ async def add_char(message: Message, state: FSMContext, dao: DAO):
|
||||
await message.answer("Кайф, теперь напиши ее имя")
|
||||
|
||||
|
||||
@router.callback_query(States.char_wait_name)
|
||||
@router.message(States.char_wait_name)
|
||||
async def new_char_name(message: Message, state: FSMContext, dao: DAO):
|
||||
await state.set_data({"name": message.text})
|
||||
data = await state.get_data()
|
||||
data["name"] = message.text
|
||||
await state.set_data(data)
|
||||
await state.set_state(States.char_wait_bio)
|
||||
await message.answer("А теперь напиши био. Хоть чуть чуть.")
|
||||
|
||||
@@ -37,7 +39,7 @@ async def new_char_name(message: Message, state: FSMContext, dao: DAO):
|
||||
async def new_char_bio(message: Message, state: FSMContext, dao: DAO, bot: Bot):
|
||||
# Получаем все накопленные данные
|
||||
data = await state.get_data()
|
||||
file_id = data["file_id"]
|
||||
file_id = data["photo"]
|
||||
name = data["name"]
|
||||
bio = message.text
|
||||
|
||||
@@ -64,9 +66,9 @@ async def new_char_bio(message: Message, state: FSMContext, dao: DAO, bot: Bot):
|
||||
await message.answer_photo(
|
||||
photo=BufferedInputFile(photo_bytes, filename="char.png"),
|
||||
caption=(
|
||||
"🎉 **Персонаж создан!**\n\n"
|
||||
f"👤 **Имя:** {char.name}\n"
|
||||
f"📝 **Био:** {char.character_bio}"
|
||||
"🎉 <b>Персонаж создан!</b>\n\n"
|
||||
f"👤 <b>Имя:</b> {char.name}\n"
|
||||
f"📝 <b>Био:</b> {char.character_bio}"
|
||||
)
|
||||
)
|
||||
await wait_msg.delete()
|
||||
@@ -79,10 +81,51 @@ async def new_char_bio(message: Message, state: FSMContext, dao: DAO, bot: Bot):
|
||||
# Не сбрасываем стейт, даем возможность попробовать ввести био снова или начать заново
|
||||
|
||||
|
||||
@router.message(Command("chars"))
|
||||
async def get_chars(message: Message, state: FSMContext, dao: DAO):
|
||||
wait_msg = await message.answer("Ищем персонажей")
|
||||
chars = await dao.chars.get_all_characters()
|
||||
keyboards = []
|
||||
if len(chars) > 0:
|
||||
for char in chars:
|
||||
keyboards.append(InlineKeyboardButton(text=char.name, callback_data=f'char_info_{char.id}'))
|
||||
keyboard = InlineKeyboardMarkup(inline_keyboard=[keyboards])
|
||||
else:
|
||||
keyboard = InlineKeyboardMarkup(
|
||||
inline_keyboard=[[InlineKeyboardButton(text="Персонажей нет", callback_data=f'no_chars')]])
|
||||
await message.answer("Сейчас есть такие персонажи:", reply_markup=keyboard)
|
||||
await wait_msg.delete()
|
||||
|
||||
|
||||
@router.callback_query(F.data.startswith("char_info_"))
|
||||
async def get_char_info(callback_query: CallbackQuery, state: FSMContext, dao: DAO):
|
||||
await callback_query.message.delete()
|
||||
wait_msg = await callback_query.message.answer("Ищем инфу о персонаже")
|
||||
char = await dao.chars.get_character(callback_query.data.split("_")[-1])
|
||||
if char is None:
|
||||
await callback_query.message.answer("Информация о персонаже не найдена")
|
||||
await get_chars(callback_query.message, state, dao)
|
||||
await wait_msg.delete()
|
||||
return
|
||||
keyboard = InlineKeyboardMarkup(inline_keyboard=[
|
||||
[InlineKeyboardButton(text="Запросить фото в документе", callback_data=f'char_photo_file_{char.id}')]])
|
||||
await callback_query.message.answer_photo(photo=BufferedInputFile(char.character_image, f"photo_{char.id}.png"), caption=f"👤 <b>Имя:</b> {char.name}\n"
|
||||
f"📝 <b>Био:</b> {char.character_bio}",
|
||||
reply_markup=keyboard)
|
||||
|
||||
await wait_msg.delete()
|
||||
|
||||
|
||||
@router.callback_query(F.data.startswith("char_photo_file"))
|
||||
async def get_char_info_photo_file(callback_query: CallbackQuery, state: FSMContext, dao: DAO):
|
||||
char = await dao.chars.get_character(callback_query.data.split("_")[-1])
|
||||
await callback_query.message.answer_document(BufferedInputFile(char.character_image, f"photo_{char.id}.png"))
|
||||
|
||||
|
||||
# 4. Хендлер-помощник (если отправили команду без файла)
|
||||
@router.message(Command("add_char"))
|
||||
async def add_char_help(message: Message):
|
||||
await message.answer(
|
||||
"ℹ️ **Как добавить персонажа:**\n"
|
||||
"Прикрепите фото (файлом/документом) и добавьте в подпись команду `/add_char`."
|
||||
)
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user