Алексей Безбородов
1 year ago
3 changed files with 177 additions and 13 deletions
@ -0,0 +1,143 @@
|
||||
# -*- coding: utf8 -*- |
||||
# Общественное достояние, 2023, Алексей Безбородов (Alexei Bezborodov) <AlexeiBv+mirocod_platform_bot@narod.ru> |
||||
|
||||
# Сообщения пользователю |
||||
|
||||
from bot_sys import bot_bd, keyboard, user_access, bd_table, bot_subscribes, bot_messages |
||||
from bot_modules import mod_table_operate, mod_simple_message, users |
||||
|
||||
# --------------------------------------------------------- |
||||
# БД |
||||
module_name = 'user_messge' |
||||
|
||||
table_name = module_name |
||||
key_name = 'userMessageID' |
||||
desc_field = 'messageText' |
||||
access_field = 'catAccess' |
||||
create_datetime_field = 'catCreateDateTime' |
||||
parent_id_field = users.key_name |
||||
|
||||
table = bd_table.Table(table_name, [ |
||||
bd_table.TableField(key_name, bd_table.TableFieldDestiny.KEY, bd_table.TableFieldType.INT), |
||||
bd_table.TableField(desc_field, bd_table.TableFieldDestiny.DESC, bd_table.TableFieldType.STR), |
||||
bd_table.TableField(access_field, bd_table.TableFieldDestiny.ACCESS, bd_table.TableFieldType.STR), |
||||
bd_table.TableField(create_datetime_field, bd_table.TableFieldDestiny.CREATE_DATE, bd_table.TableFieldType.STR), |
||||
bd_table.TableField(parent_id_field, bd_table.TableFieldDestiny.PARENT_ID, bd_table.TableFieldType.INT), |
||||
]) |
||||
|
||||
init_access = f'{user_access.user_access_group_new}=-' |
||||
|
||||
# --------------------------------------------------------- |
||||
# Сообщения и кнопки |
||||
|
||||
button_names = { |
||||
mod_simple_message.ButtonNames.START: "📩 Сообщения для польователей", |
||||
mod_table_operate.ButtonNames.LIST: "📃 Список отправленных сообщений", |
||||
mod_table_operate.ButtonNames.ADD: "📨 Отправить сообщение", |
||||
mod_table_operate.ButtonNames.EDIT: "🛠 Редактировать сообщение", |
||||
mod_table_operate.EditButton(bd_table.TableFieldDestiny.DESC): "𝌴 Изменить описание в категории", |
||||
mod_table_operate.EditButton(bd_table.TableFieldDestiny.ACCESS): "✋ Изменить доступ к категории", |
||||
mod_table_operate.ButtonNames.DEL: "❌ Удалить отправленное сообщение", |
||||
} |
||||
|
||||
messages = { |
||||
mod_simple_message.Messages.START: f''' |
||||
<b>{button_names[mod_simple_message.ButtonNames.START]}</b> |
||||
|
||||
''', |
||||
mod_table_operate.Messages.SELECT: ''' |
||||
Пожалуйста, выберите сообщение: |
||||
''', |
||||
mod_table_operate.Messages.ERROR_FIND: ''' |
||||
❌ Ошибка, сообщение не найдено |
||||
''', |
||||
mod_table_operate.Messages.OPEN: f''' |
||||
<b>Категория: </b> |
||||
|
||||
Пользоватеель: #{parent_id_field} |
||||
|
||||
Текст сообщения: #{desc_field} |
||||
|
||||
Время создания: #{create_datetime_field} |
||||
''', |
||||
mod_table_operate.CreateMessage(bd_table.TableFieldDestiny.DESC): ''' |
||||
Отправка сообщения |
||||
|
||||
Введите текст сообщения: |
||||
''', |
||||
mod_table_operate.Messages.SUCCESS_CREATE: f'''✅ Сообщение успешно отправлено пользователю!''', |
||||
mod_table_operate.Messages.START_EDIT: ''' |
||||
Пожалуйста, выберите действие: |
||||
''', |
||||
mod_table_operate.Messages.SELECT_TO_EDIT: ''' |
||||
Выберите проект, который вы хотите отредактировать. |
||||
''', |
||||
mod_table_operate.EditMessage(bd_table.TableFieldDestiny.DESC): f''' |
||||
Текущий текст сообщения: |
||||
#{desc_field} |
||||
|
||||
Введите новый текст: |
||||
''', |
||||
mod_table_operate.EditMessage(bd_table.TableFieldDestiny.ACCESS): f''' |
||||
Текущий доступ к сообщению: |
||||
#{access_field} |
||||
|
||||
{user_access.user_access_readme} |
||||
|
||||
Введите новую строку доступа: |
||||
''', |
||||
mod_table_operate.Messages.SUCCESS_EDIT: '''✅ Сообщение успешно отредактировано!''', |
||||
mod_table_operate.Messages.SELECT_TO_DELETE: ''' |
||||
Выберите категорию, которую вы хотите удалить. |
||||
''', |
||||
mod_table_operate.Messages.SUCCESS_DELETE: '''✅ Сообщение успешно удалёно!''', |
||||
} |
||||
|
||||
messages_subscribes = { |
||||
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_ADD):f'''Сообщение создано''', |
||||
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_EDIT):f'''Сообщение отредактировано''', |
||||
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_DEL):f'''Сообщение удалено''', |
||||
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ITEM_EDIT):f'''Сообщение отредактировано #item_id''', |
||||
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ITEM_DEL):f'''Сообщение удалено #item_id''', |
||||
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_ADD_WITH_PARENT):f'''Сообщение создано''', |
||||
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_EDIT_WITH_PARENT):f'''Сообщение отредактировано''', |
||||
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_DEL_WITH_PARENT):f'''Сообщение удалено''', |
||||
} |
||||
|
||||
messages.update(messages_subscribes) |
||||
|
||||
class ModuleUserMessage(mod_table_operate.TableOperateModule): |
||||
def __init__(self, a_ParentModName, a_ChildModName, a_ChildModuleNameList, a_EditModuleNameList, a_Bot, a_ModuleAgregator, a_BotMessages, a_BotButtons, a_BotSubscribes, a_Log): |
||||
super().__init__(table, messages, button_names, a_ParentModName, a_ChildModName, init_access, init_access, a_ChildModuleNameList, a_EditModuleNameList, a_Bot, a_ModuleAgregator, a_BotMessages, a_BotButtons, a_BotSubscribes, a_Log) |
||||
|
||||
def GetName(self): |
||||
return module_name |
||||
|
||||
async def AddBDItemFunc(self, a_ItemData, a_UserID): |
||||
res, error = await super().AddBDItemFunc(a_ItemData, a_UserID) |
||||
desc_field = self.m_Table.GetFieldNameByDestiny(bd_table.TableFieldDestiny.DESC) |
||||
user_id_field = self.m_Table.GetFieldNameByDestiny(bd_table.TableFieldDestiny.PARENT_ID) |
||||
|
||||
if not await self.SendMessageToUser(bot_messages.MakeBotMessage(a_ItemData[desc_field]), a_ItemData[user_id_field]): |
||||
return None, '❌ Ошибка отправки сообщения' |
||||
return res, error |
||||
|
||||
def GetStartButtons(self, a_Message, a_UserGroups): |
||||
return [ |
||||
[mod_table_operate.ButtonNames.ADD, user_access.AccessMode.ADD], |
||||
[mod_table_operate.ButtonNames.LIST, user_access.AccessMode.VIEW], |
||||
[mod_table_operate.ButtonNames.EDIT, user_access.AccessMode.EDIT], |
||||
[mod_table_operate.ButtonNames.DEL, user_access.AccessMode.DELETE], |
||||
] |
||||
|
||||
def GetButtonNameAndKeyValueAndAccess(self, a_Item): |
||||
key_name_id = self.GetKeyFieldID() |
||||
date_field_id = self.m_Table.GetFieldIDByDestiny(bd_table.TableFieldDestiny.CREATE_DATE) |
||||
access_field_id = self.m_Table.GetFieldIDByDestiny(bd_table.TableFieldDestiny.ACCESS) |
||||
assert key_name_id != None |
||||
assert date_field_id != None |
||||
assert access_field_id != None |
||||
return \ |
||||
a_Item[date_field_id],\ |
||||
a_Item[key_name_id],\ |
||||
a_Item[access_field_id] |
Loading…
Reference in new issue