chat v2
This commit is contained in:
SDE
2023-08-11 16:50:51 +03:00
parent 9c9c1c024c
commit 198dac6ad0
4 changed files with 37 additions and 24 deletions

View File

@@ -51,6 +51,8 @@ def update_chat_ajax(request):
last_message_modifiedDT = None
required_beep = False
try:
data = json.loads(request.body)
@@ -70,7 +72,7 @@ def update_chat_ajax(request):
if 'receiver' in data and data['receiver']:
receiver = User.objects.get(id=data['receiver'])
res_Dict.update({'cur_receiver': receiver})
context_Dict.update({'cur_receiver': receiver})
if ticket:
@@ -86,30 +88,39 @@ def update_chat_ajax(request):
'blocks/profile/b_list_of_tickets_support_chat.html', context_Dict, request=request)
res_Dict.update({'tickets_list_html': tickets_list_html})
else:
# если есть получатель - получаем сообщения чата
if receiver:
msgs = get_msgs_for_chat_w_users(sender, receiver)
context_Dict.update({'messages': msgs})
chat_html = render_to_string(tpl_name, context_Dict, request=request)
res_Dict.update({'chat_html': chat_html})
# получаем правую панель с получателями
receivers = get_chat_receivers_for_user(request.user)
receivers, unread_msgs_count = get_chat_receivers_for_user(request.user, receiver)
if unread_msgs_count:
required_beep = True
context_Dict.update({'receivers': receivers})
users_list_html = render_to_string(
'blocks/profile/b_list_of_users_messenger.html', context_Dict, request=request)
res_Dict.update({'users_list_html': users_list_html})
res_Dict.update({
'users_list_html': users_list_html,
'unread_msgs_count': unread_msgs_count
})
if not msgs or (request.user != msgs[0].receiver) or (not msgs and not last_message_modifiedDT) or (msgs and last_message_modifiedDT and msgs[0].modifiedDT <= last_message_modifiedDT):
Dict.update({
'required_beep': False
})
return JsonResponse(Dict, status=200)
# если есть получатель - получаем сообщения чата
if receiver:
msgs = get_msgs_for_chat_w_users(sender, receiver)
if msgs and msgs.filter(status='sended'):
context_Dict.update({'messages': msgs})
chat_html = render_to_string(tpl_name, context_Dict, request=request)
res_Dict.update({'chat_html': chat_html})
required_beep = True
# if not msgs or (request.user != msgs[0].receiver) or (not msgs and not last_message_modifiedDT) or (msgs and last_message_modifiedDT and msgs[0].modifiedDT <= last_message_modifiedDT):
# Dict.update({
# 'required_beep': False
# })
# return JsonResponse(Dict, status=200)
res_Dict.update({
'required_beep': True,
'required_beep': required_beep,
})
return JsonResponse(res_Dict, status=200)
@@ -206,7 +217,7 @@ def send_msg_ajax(request):
else:
msgs = get_msgs_for_chat_w_users(sender, receiver)
receivers = get_chat_receivers_for_user(request.user)
receivers, unread_msgs_count = get_chat_receivers_for_user(request.user)
res_Dict.update({