0.1.35
chat routines
This commit is contained in:
@@ -8,20 +8,21 @@ def get_msgs_for_chat_w_users(user1, user2):
|
||||
Q(sender=user1) | Q(receiver=user1),
|
||||
Q(sender=user2) | Q(receiver=user2),
|
||||
group=None
|
||||
)
|
||||
).order_by('-modifiedDT')
|
||||
return msgs
|
||||
|
||||
def get_chat_receivers_for_user(user):
|
||||
receivers = Message.objects.filter(
|
||||
Q(sender=user) | Q(receiver=user),
|
||||
group=None
|
||||
).order_by('-modifiedDT').values('sender', 'receiver')
|
||||
).order_by('-modifiedDT')#.select_related('sender', 'receiver').values('sender', 'receiver').distinct()
|
||||
|
||||
receivers_list = []
|
||||
receivers_list.extend([item['sender'] for item in receivers if item['sender'] != user])
|
||||
receivers_list.extend([item['receiver'] for item in receivers if item['receiver'] != user])
|
||||
|
||||
return receivers_list
|
||||
receivers_list.extend((item.sender for item in receivers if item.sender != user))
|
||||
receivers_list.extend((item.receiver for item in receivers if item.receiver != user))
|
||||
|
||||
return list(set(receivers_list))
|
||||
|
||||
def get_messages_for_ticket(ticket):
|
||||
return ticket.rel_messages_for_group.filter(enable=True).order_by('-modifiedDT')
|
||||
|
||||
@@ -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)
|
||||
|
||||
Reference in New Issue
Block a user