Compare commits
3 Commits
master
...
adminpanel
Author | SHA1 | Date |
---|---|---|
Fynjy | 0e474650e5 | 1 year ago |
Anton | a1261ab9b9 | 1 year ago |
Anton | 92afd8cb28 | 1 year ago |
23 changed files with 216 additions and 686 deletions
@ -1,8 +1,29 @@
|
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<title>Отправка сообщений</title> |
||||
</head> |
||||
<body> |
||||
|
||||
<form method="post"> |
||||
{% csrf_token %} |
||||
<div><label for="message">Сообщение:</label></div> |
||||
<div><pre> |
||||
<textarea id="message" name="message" cols="50" rows="10" placeholder="Введите сообщение"></textarea> |
||||
</pre></div> |
||||
<div><button type="submit">Отправить сообщение</button></div> |
||||
</form> |
||||
<div> |
||||
<label for="message">Сообщение:</label> |
||||
</div> |
||||
<div> |
||||
<textarea id="message" name="message" cols="50" rows="10" placeholder="Введите сообщение" class="markdownx"></textarea> |
||||
</div> |
||||
<div> |
||||
<button type="submit">Отправить сообщение</button> |
||||
</div> |
||||
</form> |
||||
|
||||
<p> |
||||
Пример разметки<br> |
||||
<br> |
||||
<strong>• *Жирный текст* </strong><br> |
||||
<code>• `номер карты` При нажатии пользователем на текст, заключенный в ``, автоматически копируется</code><br> |
||||
<i>• _курсив_</i><br> |
||||
</p> |
||||
</body> |
||||
</html> |
@ -1,143 +0,0 @@
|
||||
# -*- 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, interfaces |
||||
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], parse_mode=interfaces.ParseMode.HTML.value): |
||||
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