Merge remote-tracking branch 'origin/main'

This commit is contained in:
2023-08-11 18:05:58 +03:00
8 changed files with 122 additions and 64 deletions

View File

@@ -31,7 +31,7 @@ def chats_ajax(request):
from ChatServiceApp.funcs import get_chat_receivers_for_user, get_msgs_for_chat_w_users from ChatServiceApp.funcs import get_chat_receivers_for_user, get_msgs_for_chat_w_users
receivers = get_chat_receivers_for_user(request.user) receivers, unread_msgs_count = get_chat_receivers_for_user(request.user)
cur_chat_msgs = None cur_chat_msgs = None

View File

@@ -15,7 +15,7 @@ def get_chat_page_content_Dict(request, receiver_id=None):
except User.DoesNotExist: except User.DoesNotExist:
cur_receiver = None cur_receiver = None
receivers = get_chat_receivers_for_user(request.user) receivers, unread_msgs_count = get_chat_receivers_for_user(request.user)
Dict = { Dict = {
'cur_receiver': cur_receiver, 'cur_receiver': cur_receiver,
@@ -35,7 +35,7 @@ def get_msgs_for_chat_w_users(user1, user2):
).order_by('-modifiedDT') ).order_by('-modifiedDT')
return msgs return msgs
def get_chat_receivers_for_user(user): def get_chat_receivers_for_user(user, cur_receiver=None):
msgs = Message.objects.filter( msgs = Message.objects.filter(
Q(sender=user) | Q(receiver=user), Q(sender=user) | Q(receiver=user),
group=None group=None
@@ -43,6 +43,7 @@ def get_chat_receivers_for_user(user):
receivers_list = [] receivers_list = []
unread_msgs_count = 0
for msg in msgs: for msg in msgs:
if msg.receiver not in receivers_list and msg.receiver != user: if msg.receiver not in receivers_list and msg.receiver != user:
@@ -54,12 +55,13 @@ def get_chat_receivers_for_user(user):
receivers_list.append(msg.sender) receivers_list.append(msg.sender)
msg.sender.last_msg = msg.text msg.sender.last_msg = msg.text
if msg.receiver == user: if msg.receiver == user and (not cur_receiver or msg.sender != cur_receiver):
if msg.status == 'sended': if msg.status == 'sended':
i = receivers_list.index(msg.sender) i = receivers_list.index(msg.sender)
receivers_list[i].unread_msgs_count += 1 receivers_list[i].unread_msgs_count += 1
unread_msgs_count += 1
return receivers_list return receivers_list, unread_msgs_count
# receivers_list.extend((item.sender for item in receivers if item.sender != user)) # 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)) # receivers_list.extend((item.receiver for item in receivers if item.receiver != user))

View File

@@ -51,6 +51,8 @@ def update_chat_ajax(request):
last_message_modifiedDT = None last_message_modifiedDT = None
required_beep = False
try: try:
data = json.loads(request.body) data = json.loads(request.body)
@@ -70,7 +72,7 @@ def update_chat_ajax(request):
if 'receiver' in data and data['receiver']: if 'receiver' in data and data['receiver']:
receiver = User.objects.get(id=data['receiver']) receiver = User.objects.get(id=data['receiver'])
res_Dict.update({'cur_receiver': receiver}) context_Dict.update({'cur_receiver': receiver})
if ticket: if ticket:
@@ -84,32 +86,49 @@ def update_chat_ajax(request):
tickets_list_html = render_to_string( tickets_list_html = render_to_string(
'blocks/profile/b_list_of_tickets_support_chat.html', context_Dict, request=request) 'blocks/profile/b_list_of_tickets_support_chat.html', context_Dict, request=request)
res_Dict.update({'tickets_list_html': tickets_list_html}) res_Dict.update({
'tickets_list_html': tickets_list_html,
'msgs_count': len(msgs)
})
else: else:
# получаем правую панель с получателями
receivers, unread_msgs_count = get_chat_receivers_for_user(request.user, receiver)
saved_unread_msgs_count = request.user.user_profile.get_node_by_name('receivers_unread_msgs_count')
if saved_unread_msgs_count == None or saved_unread_msgs_count != unread_msgs_count:
request.user.user_profile.add_node_to_json_data({'receivers_unread_msgs_count': unread_msgs_count}, save=True)
# 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,
'unread_msgs_count': unread_msgs_count
})
# если есть получатель - получаем сообщения чата # если есть получатель - получаем сообщения чата
if receiver: if receiver:
msgs = get_msgs_for_chat_w_users(sender, receiver) msgs = get_msgs_for_chat_w_users(sender, receiver)
context_Dict.update({'messages': msgs}) unreaded_msgs = msgs.filter(status='sended')
chat_html = render_to_string(tpl_name, context_Dict, request=request) if msgs and unreaded_msgs:
res_Dict.update({'chat_html': chat_html}) 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
unreaded_msgs.update(status='seen')
# получаем правую панель с получателями # 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):
receivers = get_chat_receivers_for_user(request.user) # Dict.update({
context_Dict.update({'receivers': receivers}) # 'required_beep': False
users_list_html = render_to_string( # })
'blocks/profile/b_list_of_users_messenger.html', context_Dict, request=request) # return JsonResponse(Dict, status=200)
res_Dict.update({'users_list_html': users_list_html})
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({ res_Dict.update({
'required_beep': True, 'required_beep': required_beep,
}) })
return JsonResponse(res_Dict, status=200) return JsonResponse(res_Dict, status=200)
@@ -206,7 +225,7 @@ def send_msg_ajax(request):
else: else:
msgs = get_msgs_for_chat_w_users(sender, receiver) 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({ res_Dict.update({

View File

@@ -11,9 +11,9 @@ from django.conf import settings
def MainPage(request): def MainPage(request):
from ReferenceDataApp.funcs import parse_data, search_cities_in_db, search_airports_in_db # from ReferenceDataApp.funcs import parse_data, search_cities_in_db, search_airports_in_db
res = search_airports_in_db('ang') # res = search_airports_in_db('ang')
res = parse_data() # res = parse_data()
page = StaticPage.objects.get(url='main') page = StaticPage.objects.get(url='main')

View File

@@ -8,11 +8,16 @@ window.onload = function () {
// ) // )
function funcFocus(){ function funcFocus(){
let window = document.querySelector(".container-messages")
let inp = document.querySelector(".enter-message-inp") if (window !== null){
if (inp !== null){ let inp = document.querySelector(".enter-message-inp")
inp.focus() if (inp !== null){
inp.focus()
}
} else{
check_new_messages_timeout(60000)
} }
} }
@@ -54,6 +59,7 @@ function check_new_messages_timeout(timeout_time=1000){
// let user_online = userOnline('set') // let user_online = userOnline('set')
window = document.querySelector(".container-messages") window = document.querySelector(".container-messages")
if (window === null){ if (window === null){
check_new_messages(window,true)
// let new_timeout_time = 60000 // let new_timeout_time = 60000
// //
// check_new_messages_timeout(new_timeout_time,it_set_func,it_func) // check_new_messages_timeout(new_timeout_time,it_set_func,it_func)
@@ -63,7 +69,7 @@ function check_new_messages_timeout(timeout_time=1000){
// it_func++ // it_func++
// check_new_messages_timeout(new_timeout_time,it_set_func,it_func) // check_new_messages_timeout(new_timeout_time,it_set_func,it_func)
// } // }
check_new_messages(window) check_new_messages(window,false)
} }
}, },
@@ -75,17 +81,25 @@ function check_new_messages_timeout(timeout_time=1000){
var data_new_messages = null var data_new_messages = null
function check_new_messages (window){ function check_new_messages (window,only_sender_mode){
// if (it === 0){ // if (it === 0){
let data_set = document.querySelector(".container-messages").dataset if (only_sender_mode === false){
let sender = data_set['userId']; let data_set = document.querySelector(".container-messages").dataset
let receiver = data_set['curReceiver']; let sender = data_set['userId'];
let ticket_id = data_set['ticketId']; let receiver = data_set['curReceiver'];
data_new_messages = { let ticket_id = data_set['ticketId'];
'sender': sender, data_new_messages = {
'receiver': receiver, 'sender': sender,
'ticket_id': ticket_id 'receiver': receiver,
// 'last_message_modifiteDT':last_message_time 'ticket_id': ticket_id
// 'last_message_modifiteDT':last_message_time
}
} else {
let profile_data_set = document.querySelector(".button_profile_header").dataset
let sender = profile_data_set['userId']
data_new_messages = {
'sender': sender
}
} }
// } // }
// let user_online_check = document.addEventListener("mouseover"); // let user_online_check = document.addEventListener("mouseover");
@@ -125,35 +139,50 @@ function check_new_messages (window){
function success_check_new_messages (data) { function success_check_new_messages (data) {
let window = document.querySelector(".container-messages")
if (window === null){ if (window === null){
clearTimeout(check_msg) clearTimeout(check_msg)
} else { } else {
if (data.html) { if (data !== null) {
if (data_new_messages['ticket_id'] !== 'null') { if (data_new_messages['ticket_id'] && data_new_messages['ticket_id'] !== "null") {
if (data.msgs_count > 1) { if (data.msgs_count > 1) {
document.querySelector(".container-messages").innerHTML = data.html; if (document.querySelector(".container-messages")) {
document.querySelector(".container-messages").innerHTML = data.html;
}
else if (data.tickets_list_html){
if (document.querySelector(".block-list-of-users")) {
document.querySelector(".block-list-of-users").innerHTML = data.tickets_list_html
}
}
} else { } else {
document.querySelector(".info_profile").innerHTML = data.html; document.querySelector(".info_profile").innerHTML = data.html;
} }
} else {
document.querySelector(".container-messages").innerHTML = data.html;
} }
else if (data.chat_html) {
if (document.querySelector(".container-messages")) {
document.querySelector(".container-messages").innerHTML = data.chat_html;
}
if (data.users_list_html){
if (document.querySelector(".block-list-of-users")) {
document.querySelector(".block-list-of-users").innerHTML = data.users_list_html;
}
}
}
if (data.required_beep === true){
const beep = new Audio('/static/sounds/beep_2.mp3')
beep.play()
}
} }
if (data.users_list_html){
document.querySelector(".block-list-of-users").innerHTML = data.users_list_html.html;
}
}
if (data.required_beep === true){
const beep = new Audio('/static/sounds/beep_2.mp3')
beep.play()
} }
if (data.users_list_html){
document.querySelector(".block-list-of-users").innerHTML = data.users_list_html
}
if (data.tickets_list_html){
document.querySelector(".block-list-of-users").innerHTML = data.tickets_list_html
}
// let updatedCookie = encodeURIComponent(name_cookie) + "=" + encodeURIComponent(''); // let updatedCookie = encodeURIComponent(name_cookie) + "=" + encodeURIComponent('');
// let search_cookie = document.cookie.match("(^|[^;]+)\s*" + name_cookie + "\s*=\s*([^;]+)")[0].substring(1) // let search_cookie = document.cookie.match("(^|[^;]+)\s*" + name_cookie + "\s*=\s*([^;]+)")[0].substring(1)
// let search_cookie = getCookieValue('user_alerts') // let search_cookie = getCookieValue('user_alerts')

View File

@@ -4,11 +4,20 @@ $(document).ready(function (){
function getNewMessageSession(){ function getNewMessageSession(){
let window_messages = document.querySelector(".container-messages") let window_messages = document.querySelector(".container-messages")
let new_timeout_time;
if (window_messages !== null){ if (window_messages !== null){
check_new_messages(window) // check_new_messages(window)
new_timeout_time = 1000
} else {
new_timeout_time = 60000
} }
if (check_msg !== null){
clearInterval(check_msg)
}
check_new_messages_timeout(new_timeout_time)
} }
// var window_messages = document.querySelector(".container-messages") // var window_messages = document.querySelector(".container-messages")
// function getNewMessageSession (){ // function getNewMessageSession (){

View File

@@ -201,6 +201,7 @@ function sendMessage(id_ticket=null,sender,receiver){
event.preventDefault() event.preventDefault()
let text = document.querySelector(".enter-message-inp").value let text = document.querySelector(".enter-message-inp").value
document.querySelector(".enter-message-inp").value = null
if (text.length === 0){ if (text.length === 0){
// //
@@ -238,14 +239,12 @@ function sendMessage(id_ticket=null,sender,receiver){
getNewMessageSession() getNewMessageSession()
document.querySelector(".container-messages").innerHTML = data.html; document.querySelector(".container-messages").innerHTML = data.html;
document.querySelector(".enter-message-inp").value = null
document.querySelector(".enter-message-inp").focus() document.querySelector(".enter-message-inp").focus()
}, },
error: function (data){ error: function (data){
document.querySelector(".container-messages").innerHTML = data.responseJSON.error; document.querySelector(".container-messages").innerHTML = data.responseJSON.error;
document.querySelector(".enter-message-inp").value = null
document.querySelector(".enter-message-inp").focus() document.querySelector(".enter-message-inp").focus()
} }
}); });

View File

@@ -10,7 +10,7 @@
<div><a href="#"><img src="/static/img/png/ru.png" alt=""></a></div> <div><a href="#"><img src="/static/img/png/ru.png" alt=""></a></div>
<div><img class="svg" src="/static/img/svg/Helpdesk_%20Icon.svg"><a href="#">Служба поддержки</a></div> <div><img class="svg" src="/static/img/svg/Helpdesk_%20Icon.svg"><a href="#">Служба поддержки</a></div>
{% if user.is_authenticated %} {% if user.is_authenticated %}
<a <a class="button_profile_header" data-user-id="{{ user.id }}"
href="{% url "user_profile" %}"> href="{% url "user_profile" %}">
{{ user.username }} {{ user.username }}