chat routines
This commit is contained in:
SDE
2023-08-07 14:24:55 +03:00
parent 6bb2a4249e
commit ef2f2cc8e8
7 changed files with 74 additions and 41 deletions

View File

@@ -57,6 +57,8 @@ def send_msg_ajax(request):
data = json.loads(request.body)
ticket = None
tpl_name = 'blocks/profile/b_chats.html'
if data['text']:
@@ -67,13 +69,14 @@ def send_msg_ajax(request):
receiver = User.objects.get(id=data['receiver'])
# если только что манагер присоединился к тикету
if ticket and not ticket.manager:
if sender.is_staff:
ticket.manager = sender
else:
ticket.manager = receiver
if ticket:
if not ticket.manager:
if sender.is_staff:
ticket.manager = sender
else:
ticket.manager = receiver
ticket.save()
ticket.save()
kwargs = {
'sender': ticket.owner,
@@ -81,32 +84,45 @@ def send_msg_ajax(request):
'text': ticket.text,
}
if ticket:
kwargs.update({'group': ticket})
kwargs.update({'group': ticket})
msg = Message.objects.create(**kwargs)
Message.objects.filter(id=msg.id).update(modifiedDT=ticket.createDT, createDT=ticket.createDT)
# ------------
kwargs = {
'sender': sender,
'receiver': receiver,
'text': data['text']
}
res_Dict.update({
'ticket': ticket,
'cur_receiver': receiver,
'messages': get_messages_for_ticket(ticket),
'text': ticket.text,
'modifiedDT': ticket.modifiedDT
})
res_Dict.update(get_ticketsDict_for_staff(request.user))
if ticket:
kwargs.update({'group': ticket})
tpl_name = 'blocks/profile/b_support_chat.html'
msg = Message.objects.create(**kwargs)
else:
kwargs = {
'sender': sender,
'receiver': receiver,
'text': data['text']
}
msg = Message.objects.create(**kwargs)
receivers = get_chat_receivers_for_user(request.user)
msgs = get_msgs_for_chat_w_users(sender, receiver)
res_Dict.update({
'messages': msgs,
'cur_receiver': receiver,
'receivers': receivers,
'text': data['text'],
'modifiedDT': msgs[0].modifiedDT
})
res_Dict.update({
'ticket': ticket,
'messages': get_messages_for_ticket(ticket)
})
res_Dict.update(get_ticketsDict_for_staff(request.user))
tpl_name = 'blocks/profile/b_support_chat.html'
html = render_to_string(tpl_name, res_Dict, request=request)
return JsonResponse({'html': html}, status=200)