From a1ca24b9f32f11142bcbff9c6f03cf3d67e9d4a4 Mon Sep 17 00:00:00 2001 From: Alexei Bezborodov Date: Fri, 24 Nov 2023 13:44:43 +0300 Subject: [PATCH] =?UTF-8?q?=D0=92=20=D0=BC=D0=BE=D0=B4=D1=83=D0=BB=D0=B5?= =?UTF-8?q?=20=D0=B2=D1=81=D0=B5=20=D0=B7=D0=B0=D0=BA=D0=B0=D0=B7=D1=8B=20?= =?UTF-8?q?=D0=BF=D0=BE=D1=8F=D0=B2=D0=B8=D0=BB=D0=B8=D1=81=D1=8C=20=D0=BA?= =?UTF-8?q?=D0=BD=D0=BE=D0=BF=D0=BA=D0=B8=20'=D0=B8=D0=BD=D1=84=D0=BE?= =?UTF-8?q?=D1=80=D0=BC=D0=B0=D1=86=D0=B8=D1=8F=20=D0=BE=20=D0=BF=D0=BE?= =?UTF-8?q?=D0=BB=D1=8C=D0=B7=D0=BE=D0=B2=D0=B0=D1=82=D0=B5=D0=BB=D0=B5'?= =?UTF-8?q?=20=D0=B8=20'=D0=BE=D1=82=D0=BF=D1=80=D0=B0=D0=B2=D0=B8=D1=82?= =?UTF-8?q?=D1=8C=20=D1=81=D0=BE=D0=BE=D0=B1=D1=89=D0=B5=D0=BD=D0=B8=D0=B5?= =?UTF-8?q?=20=D0=BF=D0=BE=D0=BB=D1=8C=D0=B7=D0=BE=D0=B2=D0=B0=D1=82=D0=B5?= =?UTF-8?q?=D0=BB=D1=8E'=20#18?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- bot_modules/all_orders.py | 36 ++++++++++++++++++++++++++++++++++++ bot_modules/users.py | 2 +- 2 files changed, 37 insertions(+), 1 deletion(-) diff --git a/bot_modules/all_orders.py b/bot_modules/all_orders.py index 350745a..8ad17d4 100644 --- a/bot_modules/all_orders.py +++ b/bot_modules/all_orders.py @@ -5,8 +5,12 @@ from bot_sys import bot_bd, keyboard, user_access, bd_table from bot_modules import mod_table_operate, mod_simple_message, orders, access_utils +from bot_modules import users, user_message from template import bd_item_select, bd_item_view, bd_item +from enum import Enum +from enum import auto + # --------------------------------------------------------- # БД module_name = 'all_orders' @@ -18,6 +22,10 @@ init_access = f'{user_access.user_access_group_new}=-' # --------------------------------------------------------- # Сообщения и кнопки +class ButtonNames(Enum): + SHOW_USER_INFO = auto() + SEND_USER_MESSAGE = auto() + button_names = {} button_names.update(orders.button_names) button_names.pop(mod_table_operate.ButtonNames.ADD) @@ -26,6 +34,8 @@ cur_button_names = { mod_simple_message.ButtonNames.START: "‍🛒 Все заказы", mod_table_operate.ButtonNames.LIST: "📃 Список текущих заказов", orders.ButtonNames.LIST_ALL: "📃 Список всех заказов", + ButtonNames.SHOW_USER_INFO: "👤 Информация о пользователе", + ButtonNames.SEND_USER_MESSAGE: "📨 Отправить сообщение пользователю", mod_table_operate.ButtonNames.EDIT: "🛠 Редактировать заказ", mod_table_operate.EditButton(bd_table.TableFieldDestiny.PHOTO_PAY): "☐ Загрузить чек по оплате заказа", mod_table_operate.EditButton(bd_table.TableFieldDestiny.PHOTO): "☐ Изменить изображение в заказе", @@ -161,3 +171,29 @@ class ModuleAllOrders(orders.ModuleOrders): None ) + def GetViewItemInlineKeyboard(self, a_Message, a_UserGroups, a_ItemID): + table_name = self.m_Table.GetName() + key_name = self.GetKeyFieldName() + cur_item = mod_table_operate.GetCurItem(self.m_Bot, table_name, key_name, a_ItemID) + + user_id = None + user_id_field_index = self.m_Table.GetFieldIDByDestiny(bd_table.TableFieldDestiny.USER_ID) + if user_id_field_index and cur_item and cur_item[user_id_field_index]: + user_id = cur_item[user_id_field_index] + + if not user_id: + return None + cur_buttons = [] + users_mod = self.GetModule(users.module_name) + if users_mod: + cur_buttons += [ + keyboard.InlineButtonWithAccess(self.GetButton(ButtonNames.SHOW_USER_INFO), users_mod.GetShowPrefix(), user_id, users_mod.GetAccess(), user_access.AccessMode.VIEW), + ] + user_message_mod = self.GetModule(user_message.module_name) + if user_message_mod: + cur_buttons += [ + keyboard.InlineButtonWithAccess(self.GetButton(ButtonNames.SEND_USER_MESSAGE), user_message_mod.GetAddPrefix(), user_id, user_message_mod.GetAccess(), user_access.AccessMode.ADD), + ] + if len(cur_buttons) == 0: + return None + return keyboard.MakeInlineKeyboardButtons(self.m_Bot, cur_buttons, a_UserGroups) diff --git a/bot_modules/users.py b/bot_modules/users.py index 5ae44e5..d9ce746 100644 --- a/bot_modules/users.py +++ b/bot_modules/users.py @@ -66,7 +66,7 @@ messages = { Пользователь: #{name_field} ID: #{key_name} -Имя: #{name_field} +Имя: @#{name_field} Имя1: #{name1_field} Имя2: #{name2_field} Код языка: #{language_code_field}