support chat v3
This commit is contained in:
SDE
2023-08-17 15:04:07 +03:00
parent 4db864ea7b
commit 00f99ce667
3 changed files with 100 additions and 61 deletions

View File

@@ -5,6 +5,35 @@ from asgiref.sync import async_to_sync, sync_to_async
from channels.layers import get_channel_layer
from django.template.loader import render_to_string
def send_to_support_managers_list_tickets_wo_manager(ticket, required_beep=False):
from.funcs import get_tickets_wo_manager
# рассылаем всем менеджерам сообщение
Dict = {
'ticket': ticket,
'tickets_wo_manager': get_tickets_wo_manager()
}
tickets_wo_manager_html = render_to_string('widgets/w_tickets_wo_manager.html', Dict)
group_name = 'support_managers'
Dict = {
'type': 'update_chat',
'tickets_wo_manager_html': tickets_wo_manager_html,
'required_beep': required_beep,
'group_name': group_name,
}
channel_layer = get_channel_layer()
async_to_sync(channel_layer.group_send)(
group_name,
Dict
)
# ---------------------
return True
def get_tickets_wo_manager_html(ticket, user, data):
from .funcs import get_tickets_wo_manager
@@ -45,7 +74,6 @@ class ChatConsumer(WebsocketConsumer):
def connect(self):
print('ws connect')
self.room_group_name = 'test'
async_to_sync(self.channel_layer.group_add)(
f'user_{self.scope["user"].id}',
@@ -86,7 +114,9 @@ class ChatConsumer(WebsocketConsumer):
'cur_user': sender,
'required_beep': False,
})
send_msg(data)
res = send_msg(data)
if not res['msg'] or type(res['msg']) == str:
data.update({'bad_manager': True})
ticket = None
@@ -98,6 +128,9 @@ class ChatConsumer(WebsocketConsumer):
)
msgs.update(status='seen')
if 'required_update_tickets_list_wo_managers' in res and res['required_update_tickets_list_wo_managers']:
send_to_support_managers_list_tickets_wo_manager(ticket, required_beep=False)
Dict = get_update_chat_Dict(data)