0.3.27
support chat v3
This commit is contained in:
@@ -77,7 +77,7 @@ def get_update_chat_Dict(data):
|
||||
if ticket:
|
||||
msgs = get_messages_for_ticket(ticket)
|
||||
# если меньше 3 сообщений значит выведена не полная форма - требуется другой шаблон
|
||||
if len(msgs) < 3 and data['receiver'] == data['cur_user']:
|
||||
if 'bad_manager' in data and len(msgs) < 3 and data['receiver'] == data['cur_user']:
|
||||
tpl_name = 'blocks/profile/b_support_chat.html'
|
||||
required_full_support_chat_html = True
|
||||
|
||||
@@ -107,6 +107,7 @@ def send_msg(data):
|
||||
from AuthApp.models import User
|
||||
res_Dict = {}
|
||||
msg = None
|
||||
required_update_tickets_list_wo_managers = False
|
||||
|
||||
try:
|
||||
if type(data) == str:
|
||||
@@ -127,6 +128,7 @@ def send_msg(data):
|
||||
|
||||
# если только что манагер присоединился к тикету
|
||||
if ticket:
|
||||
required_update_tickets_list_wo_managers = True
|
||||
if not ticket.manager:
|
||||
if sender.is_staff:
|
||||
ticket.manager = sender
|
||||
@@ -135,23 +137,27 @@ def send_msg(data):
|
||||
|
||||
ticket.save()
|
||||
|
||||
# создаем сообщение на базе темы и сообщения введенных пользователем при создании тикета
|
||||
kwargs = {
|
||||
'sender': ticket.owner,
|
||||
'receiver': ticket.manager,
|
||||
'text': ticket.text,
|
||||
'group': ticket,
|
||||
}
|
||||
|
||||
kwargs.update({'group': ticket})
|
||||
|
||||
msg = Message.objects.create(**kwargs)
|
||||
Message.objects.filter(id=msg.id).update(modifiedDT=ticket.createDT, createDT=ticket.createDT)
|
||||
# ------------------------
|
||||
|
||||
else:
|
||||
if not sender in (ticket.owner, ticket.manager) or not receiver in (ticket.owner, ticket.manager):
|
||||
return {
|
||||
'msg': None,
|
||||
'required_update_tickets_list_wo_managers': required_update_tickets_list_wo_managers
|
||||
}
|
||||
|
||||
res_Dict.update({
|
||||
'ticket': ticket,
|
||||
# 'cur_receiver': receiver,
|
||||
# 'messages': get_messages_for_ticket(ticket),
|
||||
# 'text': data['text'],
|
||||
# 'modifiedDT': msg.modifiedDT
|
||||
})
|
||||
|
||||
msg_create_kwargs.update({
|
||||
@@ -167,39 +173,38 @@ def send_msg(data):
|
||||
'text': data['text']
|
||||
})
|
||||
|
||||
session_data = {
|
||||
'for_save_to_session': {
|
||||
'user_alerts': {
|
||||
'new_message': True
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
receiver.user_profile.add_node_to_json_data(session_data, save=True)
|
||||
|
||||
msg = Message.objects.create(**msg_create_kwargs)
|
||||
|
||||
if ticket:
|
||||
msgs = get_messages_for_ticket(ticket)
|
||||
else:
|
||||
msgs = get_msgs_for_chat_w_users(sender, receiver)
|
||||
|
||||
receivers, unread_msgs_count = get_chat_receivers_for_user(sender)
|
||||
|
||||
res_Dict.update({
|
||||
'messages': msgs,
|
||||
'cur_receiver': receiver,
|
||||
'receivers': receivers,
|
||||
'text': data['text'],
|
||||
'modifiedDT': msgs[0].modifiedDT
|
||||
})
|
||||
|
||||
html = render_to_string(tpl_name, res_Dict)
|
||||
return {'html': html, 'sender': data['sender']}
|
||||
# if ticket:
|
||||
# msgs = get_messages_for_ticket(ticket)
|
||||
# else:
|
||||
# msgs = get_msgs_for_chat_w_users(sender, receiver)
|
||||
#
|
||||
# receivers, unread_msgs_count = get_chat_receivers_for_user(sender)
|
||||
#
|
||||
# res_Dict.update({
|
||||
# 'messages': msgs,
|
||||
# 'cur_receiver': receiver,
|
||||
# 'receivers': receivers,
|
||||
# 'text': data['text'],
|
||||
# 'modifiedDT': msgs[0].modifiedDT
|
||||
# })
|
||||
#
|
||||
# html = render_to_string(tpl_name, res_Dict)
|
||||
# return {'html': html, 'sender': data['sender']}
|
||||
return {
|
||||
'msg': msg,
|
||||
'required_update_tickets_list_wo_managers': required_update_tickets_list_wo_managers
|
||||
}
|
||||
|
||||
except Exception as e:
|
||||
msg = f'send_msg_ajax Error = {str(e)}'
|
||||
return {'error': msg}
|
||||
print(msg)
|
||||
# return {'error': msg}
|
||||
return {
|
||||
'msg': msg,
|
||||
'required_update_tickets_list_wo_managers': required_update_tickets_list_wo_managers
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user