Site
- new file pour handler request allListUser - add function on button new conversation in chat - remove cookies from js Django - fix new_msg.sender.id
This commit is contained in:
@ -6,7 +6,7 @@
|
|||||||
# By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ #
|
# By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ #
|
||||||
# +#+#+#+#+#+ +#+ #
|
# +#+#+#+#+#+ +#+ #
|
||||||
# Created: 2024/08/04 13:44:11 by edbernar #+# #+# #
|
# Created: 2024/08/04 13:44:11 by edbernar #+# #+# #
|
||||||
# Updated: 2024/08/25 21:49:02 by tomoron ### ########.fr #
|
# Updated: 2024/08/26 00:37:41 by edbernar ### ########.fr #
|
||||||
# #
|
# #
|
||||||
# **************************************************************************** #
|
# **************************************************************************** #
|
||||||
|
|
||||||
@ -30,7 +30,7 @@ def sendPrivateMessage(socket, content):
|
|||||||
new_msg = Message.objects.create(sender=user[0], to=dest[0], content=content["content"])
|
new_msg = Message.objects.create(sender=user[0], to=dest[0], content=content["content"])
|
||||||
new_msg.save()
|
new_msg.save()
|
||||||
jsonVar = {"type": "new_private_message", "content": {
|
jsonVar = {"type": "new_private_message", "content": {
|
||||||
"from": content["from"],
|
"from": new_msg.sender.id,
|
||||||
"channel": content["to"],
|
"channel": content["to"],
|
||||||
"content": content["content"],
|
"content": content["content"],
|
||||||
"date": new_msg.date.strftime("%H:%M:%S %d/%m/%Y")
|
"date": new_msg.date.strftime("%H:%M:%S %d/%m/%Y")
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
/* By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ */
|
/* By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/08/04 19:17:54 by edbernar #+# #+# */
|
/* Created: 2024/08/04 19:17:54 by edbernar #+# #+# */
|
||||||
/* Updated: 2024/08/25 21:24:06 by edbernar ### ########.fr */
|
/* Updated: 2024/08/26 00:40:11 by edbernar ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -86,7 +86,6 @@ async function displayAllMessage(divMessageListChatHome)
|
|||||||
newDiv = document.createElement("div");
|
newDiv = document.createElement("div");
|
||||||
contentNode = document.createTextNode(element.content);
|
contentNode = document.createTextNode(element.content);
|
||||||
dateNode = document.createTextNode(element.date);
|
dateNode = document.createTextNode(element.date);
|
||||||
console.log(element.from, userMeInfo.id);
|
|
||||||
newDiv.classList.add(element.from === userMeInfo.id ? "meMessage" : "opponentMessage");
|
newDiv.classList.add(element.from === userMeInfo.id ? "meMessage" : "opponentMessage");
|
||||||
tmp = document.createElement("p");
|
tmp = document.createElement("p");
|
||||||
tmp.classList.add("content");
|
tmp.classList.add("content");
|
||||||
|
@ -6,11 +6,12 @@
|
|||||||
/* By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ */
|
/* By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/08/04 19:21:10 by edbernar #+# #+# */
|
/* Created: 2024/08/04 19:21:10 by edbernar #+# #+# */
|
||||||
/* Updated: 2024/08/24 23:31:19 by edbernar ### ########.fr */
|
/* Updated: 2024/08/26 01:24:28 by edbernar ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
import { waitForUserList } from "/static/javascript/typeResponse/typePrivateListUser.js";
|
import { waitForUserList } from "/static/javascript/typeResponse/typePrivateListUser.js";
|
||||||
|
import { waitForallListUser } from "/static/javascript/typeResponse/typeAllListUser.js";
|
||||||
import { userList } from "/static/javascript/typeResponse/typePrivateListUser.js";
|
import { userList } from "/static/javascript/typeResponse/typePrivateListUser.js";
|
||||||
import { showPrivateChat } from "/static/javascript/liveChat/showPrivateChat.js";
|
import { showPrivateChat } from "/static/javascript/liveChat/showPrivateChat.js";
|
||||||
import { sendRequest } from "/static/javascript/websocket.js";
|
import { sendRequest } from "/static/javascript/websocket.js";
|
||||||
@ -41,13 +42,33 @@ async function showListUser() {
|
|||||||
divMessageListChatHome.appendChild(user);
|
divMessageListChatHome.appendChild(user);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
divMessageListChatHome.innerHTML += "<p style='text-align: center; margin-top: 20px;'>New conversation +</p>";
|
divMessageListChatHome.innerHTML += "<p id='newConversation' style='text-align: center; margin-top: 20px; cursor: pointer;'>New conversation +</p>";
|
||||||
divUser = document.getElementsByClassName("user");
|
divUser = document.getElementsByClassName("user");
|
||||||
for (let i = 0; i < divUser.length; i++) {
|
for (let i = 0; i < divUser.length; i++) {
|
||||||
divUser[i].addEventListener("click", async () => {
|
divUser[i].addEventListener("click", async () => {
|
||||||
await showPrivateChat(userList[i]);
|
await showPrivateChat(userList[i]);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
document.getElementById('newConversation').addEventListener('mouseup', () => {
|
||||||
|
divMessageListChatHome.innerText = 'Loading...';
|
||||||
|
sendRequest("get_all_list_user", {});
|
||||||
|
waitForallListUser().then((listUser) => {
|
||||||
|
divMessageListChatHome.innerText = '';
|
||||||
|
listUser.forEach(element => {
|
||||||
|
let user = document.createElement("div");
|
||||||
|
user.classList.add("user");
|
||||||
|
user.innerHTML = `
|
||||||
|
<div class="status ${element.status}">
|
||||||
|
<img>
|
||||||
|
</div>
|
||||||
|
<h3></h3>
|
||||||
|
`
|
||||||
|
user.querySelector("img").src = element.pfp;
|
||||||
|
user.querySelector("h3").innerText = element.name;
|
||||||
|
divMessageListChatHome.appendChild(user);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export { showListUser };
|
export { showListUser };
|
@ -0,0 +1,39 @@
|
|||||||
|
/* ************************************************************************** */
|
||||||
|
/* */
|
||||||
|
/* ::: :::::::: */
|
||||||
|
/* typeAllListUser.js :+: :+: :+: */
|
||||||
|
/* +:+ +:+ +:+ */
|
||||||
|
/* By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ */
|
||||||
|
/* +#+#+#+#+#+ +#+ */
|
||||||
|
/* Created: 2024/08/26 01:00:35 by edbernar #+# #+# */
|
||||||
|
/* Updated: 2024/08/26 01:11:49 by edbernar ### ########.fr */
|
||||||
|
/* */
|
||||||
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
let allListUser = [];
|
||||||
|
let allListUserAvailable = false;
|
||||||
|
let allListUserResolve = null;
|
||||||
|
|
||||||
|
|
||||||
|
function waitForallListUser() {
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
|
||||||
|
if (allListUserAvailable)
|
||||||
|
resolve();
|
||||||
|
else
|
||||||
|
allListUserResolve = resolve;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function typePrivateListMessage(list) {
|
||||||
|
allListUser = list;
|
||||||
|
allListUserAvailable = true;
|
||||||
|
if (allListUserResolve)
|
||||||
|
{
|
||||||
|
allListUserResolve(allListUser);
|
||||||
|
allListUserResolve = null;
|
||||||
|
allListUserAvailable = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export { waitForallListUser, typePrivateListMessage, allListUser };
|
@ -6,7 +6,7 @@
|
|||||||
/* By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ */
|
/* By: edbernar <edbernar@student.42angouleme. +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/07/31 22:17:24 by edbernar #+# #+# */
|
/* Created: 2024/07/31 22:17:24 by edbernar #+# #+# */
|
||||||
/* Updated: 2024/08/25 18:09:25 by edbernar ### ########.fr */
|
/* Updated: 2024/08/25 23:25:30 by edbernar ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -28,23 +28,7 @@ const errorFunction = [typeErrorInvalidPassword, typeErrorInvalidToken42, typeEr
|
|||||||
|
|
||||||
let status = 0;
|
let status = 0;
|
||||||
|
|
||||||
function getCookie(name)
|
|
||||||
{
|
|
||||||
const value = `; ${document.cookie}`;
|
|
||||||
const parts = value.split(`; ${name}=`);
|
|
||||||
let token = null;
|
|
||||||
|
|
||||||
if (parts.length === 2)
|
|
||||||
{
|
|
||||||
token = parts.pop().split(';').shift();
|
|
||||||
token = token.substring(1, token.length - 1);
|
|
||||||
}
|
|
||||||
return (token);
|
|
||||||
}
|
|
||||||
|
|
||||||
socket.onopen = () => {
|
socket.onopen = () => {
|
||||||
let token = getCookie("token");
|
|
||||||
|
|
||||||
status = 1;
|
status = 1;
|
||||||
console.log('Connected');
|
console.log('Connected');
|
||||||
};
|
};
|
||||||
@ -92,21 +76,10 @@ function sendRequest(type, content) {
|
|||||||
coc = JSON.stringify(content);
|
coc = JSON.stringify(content);
|
||||||
else
|
else
|
||||||
coc = content;
|
coc = content;
|
||||||
if (getCookie("token"))
|
socket.send(JSON.stringify({
|
||||||
{
|
type: type,
|
||||||
socket.send(JSON.stringify({
|
content: content
|
||||||
type: type,
|
}));
|
||||||
token: getCookie("token"),
|
|
||||||
content: content
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
socket.send(JSON.stringify({
|
|
||||||
type: type,
|
|
||||||
content: content
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export { socket, sendRequest };
|
export { socket, sendRequest };
|
Reference in New Issue
Block a user