This repository has been archived on 2024-10-10. You can view files and clone it, but cannot push or open issues or pull requests.
TelegramBot/modules/search_name.py

103 lines
3.5 KiB
Python
Raw Permalink Normal View History

2023-08-28 16:41:20 +03:00
from typing import Union
from convopyro import listen_message
from pykeyboard import ReplyButton, ReplyKeyboard
from pyrogram.types import ForceReply, Message, ReplyKeyboardRemove
from classes.location import Location
from classes.pyroclient import PyroClient
2023-11-05 15:20:01 +02:00
from modules.database_api import col_locations
2023-08-28 16:41:20 +03:00
async def search_name(app: PyroClient, message: Message) -> Union[Location, None]:
2023-08-29 17:32:37 +03:00
user = await app.find_user(message.from_user)
2023-08-28 16:41:20 +03:00
location: Union[Location, None] = None
await message.reply_text(
2023-08-30 13:37:09 +03:00
app._("location_name", "messages", locale=user.locale),
2023-08-29 17:32:37 +03:00
reply_markup=ForceReply(
placeholder=app._("location_name", "force_replies", locale=user.locale)
),
2023-08-28 16:41:20 +03:00
)
while location is None:
2023-08-30 15:41:34 +03:00
app.contexts.append(message.from_user.id)
2023-08-28 16:41:20 +03:00
answer = await listen_message(app, message.chat.id, 300)
2023-08-30 15:41:34 +03:00
app.contexts.remove(message.from_user.id)
2023-08-28 16:41:20 +03:00
if answer is None or answer.text == "/cancel":
2023-08-29 17:32:37 +03:00
await message.reply_text(
app._("cancelled", "messages", locale=user.locale),
reply_markup=ReplyKeyboardRemove(),
)
2023-08-28 16:41:20 +03:00
return
if answer.text is None:
await message.reply_text(
2023-08-29 17:32:37 +03:00
app._("location_name_invalid", "messages", locale=user.locale).format(
cancel_notice=app._("cancel", "messages", locale=user.locale)
),
reply_markup=ForceReply(
placeholder=app._(
"location_name", "force_replies", locale=user.locale
)
),
2023-08-28 16:41:20 +03:00
)
continue
query = {"$text": {"$search": answer.text}}
locations = await col_locations.find(query).limit(6).to_list()
2023-08-28 16:41:20 +03:00
2023-08-30 15:04:36 +03:00
if len(locations) == 0 or locations is None:
2023-08-28 16:41:20 +03:00
await message.reply_text(
2023-08-29 17:32:37 +03:00
app._("location_name_empty", "messages", locale=user.locale).format(
cancel_notice=app._("cancel", "messages", locale=user.locale)
),
reply_markup=ForceReply(
placeholder=app._(
"location_name", "force_replies", locale=user.locale
)
),
2023-08-28 16:41:20 +03:00
)
continue
locations.reverse()
2023-08-28 16:41:20 +03:00
keyboard = ReplyKeyboard(resize_keyboard=True, row_width=2)
keyboard.add(*[ReplyButton(db_record["name"]) for db_record in locations])
await message.reply_text(
2023-08-29 17:32:37 +03:00
app._("location_select", "messages", locale=user.locale),
reply_markup=keyboard,
2023-08-28 16:41:20 +03:00
)
while True:
2023-08-30 15:41:34 +03:00
app.contexts.append(message.from_user.id)
2023-08-28 16:41:20 +03:00
answer = await listen_message(app, message.chat.id, 300)
2023-08-30 15:41:34 +03:00
app.contexts.remove(message.from_user.id)
2023-08-28 16:41:20 +03:00
if answer is None or answer.text == "/cancel":
await message.reply_text(
2023-08-29 17:32:37 +03:00
app._("cancelled", "messages", locale=user.locale),
reply_markup=ReplyKeyboardRemove(),
2023-08-28 16:41:20 +03:00
)
return
for db_record in locations:
if answer.text == db_record["name"]:
location = Location(**db_record)
if answer.text is None or location is None:
await answer.reply_text(
2023-08-29 17:32:37 +03:00
app._("selection_invalid", "messages", locale=user.locale).format(
cancel_notice=app._("cancel", "messages", locale=user.locale)
)
2023-08-28 16:41:20 +03:00
)
continue
break
return location