2024-09-01 22:11:28 +00:00
|
|
|
let LocalHistoryId = 0;
|
|
|
|
|
|
|
|
function genSentBase(){
|
|
|
|
return {
|
|
|
|
'chatUpdReq': {
|
2024-09-02 09:34:49 +00:00
|
|
|
'LocalHistoryId': LocalHistoryId,
|
|
|
|
'chatId': openedchat.id
|
2024-09-01 22:11:28 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
let members = new Map();
|
|
|
|
let memberBoxes = new Map();
|
|
|
|
let myRoleHere = null; // Dung local state updates should be updated first
|
|
|
|
|
|
|
|
let userDeletionWinStoredUId = -1;
|
|
|
|
|
|
|
|
function shouldShowDeleteButton(memberSt){
|
2024-09-02 09:34:49 +00:00
|
|
|
return userinfo.uid !== memberSt.userId && myRoleHere === userChatRoleAdmin && memberSt.roleHere !== userChatRoleDeleted;
|
2024-09-01 22:11:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function updateBoxWithSt(box, memberSt){
|
|
|
|
let ID = memberSt.userId;
|
|
|
|
let roleP = box.querySelector(".CM-member-box-role");
|
|
|
|
roleP.innerText = memberSt.roleHere;
|
|
|
|
box.style.backgroundColor = roleToColor(memberSt.roleHere);
|
|
|
|
box.querySelector(".CM-member-box-leave-btn").style.display =
|
|
|
|
(shouldShowDeleteButton(memberSt) ? "block" : "none");
|
|
|
|
}
|
|
|
|
|
|
|
|
function convertMemberStToBox(memberSt){
|
|
|
|
let ID = memberSt.userId;
|
|
|
|
let userProfileURI = "/user/" + memberSt.nickname;
|
|
|
|
|
|
|
|
let box = document.createElement("div");
|
|
|
|
box.className = "dynamic-block-list-el CM-member-box";
|
|
|
|
box.style.backgroundColor = roleToColor(memberSt.roleHere);
|
|
|
|
|
|
|
|
let inBoxNickname = document.createElement("a");
|
|
|
|
box.appendChild(inBoxNickname);
|
|
|
|
inBoxNickname.className = "entity-nickname-txt CM-member-box-nickname";
|
|
|
|
inBoxNickname.innerText = memberSt.nickname;
|
|
|
|
inBoxNickname.href = userProfileURI;
|
|
|
|
|
|
|
|
let inBoxName = document.createElement("a");
|
|
|
|
box.appendChild(inBoxName);
|
|
|
|
inBoxName.className = "entity-reg-field-txt CM-member-box-name";
|
|
|
|
inBoxName.innerText = memberSt.name;
|
|
|
|
inBoxName.href = userProfileURI;
|
|
|
|
|
|
|
|
let inBoxUserRoleHere = document.createElement("p");
|
|
|
|
box.appendChild(inBoxUserRoleHere);
|
|
|
|
inBoxUserRoleHere.className = "entity-reg-field-txt CM-member-box-role";
|
|
|
|
inBoxUserRoleHere.innerText = memberSt.roleHere;
|
|
|
|
|
|
|
|
let inBoxLeaveBtn = document.createElement("img");
|
|
|
|
box.appendChild(inBoxLeaveBtn);
|
|
|
|
inBoxLeaveBtn.className = "CM-member-box-leave-btn";
|
|
|
|
inBoxLeaveBtn.src = "/assets/img/delete.svg";
|
|
|
|
inBoxLeaveBtn.onclick = function (ev) {
|
|
|
|
if (ev.button !== 0)
|
|
|
|
return;
|
|
|
|
userDeletionWinStoredUId = ID;
|
|
|
|
document.getElementById("user-deletion-win-title").innerText =
|
|
|
|
"Do you really want to kick user " + memberSt.nickname + "?";
|
2024-09-02 09:34:49 +00:00
|
|
|
activatePopupWindowById("user-deletion-win");
|
2024-09-01 22:11:28 +00:00
|
|
|
};
|
|
|
|
box.querySelector(".CM-member-box-leave-btn").style.display =
|
|
|
|
(shouldShowDeleteButton(memberSt) ? "block" : "none");
|
|
|
|
|
|
|
|
return box;
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateLocalStateFromChatUpdResp(chatUpdResp){
|
|
|
|
LocalHistoryId = chatUpdResp.HistoryId;
|
|
|
|
// If my role is updated, we need to update all the boes of already set users (kick button can appear and disappear)
|
|
|
|
let literalMemberList = document.getElementById("CM-list");
|
|
|
|
// We ignore messages and everything related to them. Dang, I really should add an argument to disable message lookup here
|
|
|
|
for (let memberSt of chatUpdResp.members){
|
2024-09-02 09:34:49 +00:00
|
|
|
console.log([memberSt, userinfo.uid, myRoleHere]);
|
|
|
|
if (memberSt.userId === userinfo.uid && myRoleHere !== memberSt.roleHere){
|
2024-09-01 22:11:28 +00:00
|
|
|
myRoleHere = memberSt.roleHere;
|
|
|
|
for (let [id, memberSt] of members){
|
|
|
|
let box = memberBoxes.get(id);
|
|
|
|
updateBoxWithSt(box, memberSt);
|
|
|
|
}
|
2024-09-02 09:34:49 +00:00
|
|
|
document.getElementById("CM-btn-add").style.display =
|
|
|
|
(memberSt.roleHere === userChatRoleAdmin ? "block" : "none");
|
|
|
|
console.log("DEBUG " + (memberSt.roleHere === userChatRoleAdmin ? "block" : "none"));
|
2024-09-01 22:11:28 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for (let memberSt of chatUpdResp.members){
|
|
|
|
let id = memberSt.userId;
|
2024-09-02 09:34:49 +00:00
|
|
|
if (members.has(id)){
|
|
|
|
updateBoxWithSt(memberBoxes.get(id), memberSt);
|
|
|
|
} else {
|
|
|
|
if (memberSt.roleHere !== userChatRoleDeleted){
|
|
|
|
members.set(id, memberSt);
|
|
|
|
let box = convertMemberStToBox(memberSt);
|
|
|
|
memberBoxes.set(id, box);
|
|
|
|
literalMemberList.appendChild(box);
|
|
|
|
}
|
|
|
|
}
|
2024-09-01 22:11:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-02 09:34:49 +00:00
|
|
|
function updateLocalStateFromRecv(Recv){
|
|
|
|
updateLocalStateFromChatUpdResp(Recv.chatUpdResp);
|
|
|
|
}
|
|
|
|
|
|
|
|
function configureSummonUserInterface(){
|
|
|
|
document.getElementById("user-summoning-yes").onclick = function(ev ){
|
|
|
|
if (ev.button !==0)
|
|
|
|
return;
|
2024-09-04 09:39:39 +00:00
|
|
|
let nickname = String(document.getElementById("summoned-user-nickname").value);
|
2024-09-02 09:34:49 +00:00
|
|
|
let isReadOnly = document.getElementById("summoned-user-is-read-only").checked;
|
|
|
|
deactivateActivePopup();
|
|
|
|
let Sent = genSentBase();
|
|
|
|
Sent.nickname = nickname;
|
|
|
|
Sent.makeReadOnly = Boolean(isReadOnly);
|
|
|
|
apiRequest("addMemberToChat", Sent).
|
|
|
|
then((Recv) => {
|
|
|
|
updateLocalStateFromRecv(Recv);
|
|
|
|
}).catch((e) => {
|
|
|
|
console.log(e);
|
|
|
|
alert("Failed to add user to chat");
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
document.getElementById("user-summoning-no").onclick = function (ev) {
|
|
|
|
if (ev.button !== 0)
|
|
|
|
return;
|
|
|
|
deactivateActivePopup();
|
|
|
|
};
|
|
|
|
|
|
|
|
document.getElementById("CM-btn-add").onclick = function(ev) {
|
|
|
|
if (ev.button !== 0)
|
|
|
|
return;
|
|
|
|
document.getElementById("summoned-user-nickname").value = "";
|
|
|
|
// read-only flag persists throughout user summoning sessions, and IT IS NOT A BUG
|
|
|
|
activatePopupWindowById("user-summoning-win");
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Popup activation button is configured for each box separately */
|
|
|
|
function configureKickUserInterfaceWinPart(){
|
|
|
|
document.getElementById("user-deletion-yes").onclick = function (ev){
|
|
|
|
if (ev.button !== 0)
|
|
|
|
return;
|
|
|
|
deactivateActivePopup();
|
|
|
|
if (userDeletionWinStoredUId < 0)
|
|
|
|
throw new Error("Karaul");
|
|
|
|
let Sent = genSentBase();
|
|
|
|
Sent.userId = userDeletionWinStoredUId;
|
|
|
|
apiRequest("removeMemberFromChat", Sent).
|
|
|
|
then((Recv) => {
|
|
|
|
updateLocalStateFromRecv(Recv);
|
|
|
|
}).catch((e) => {
|
|
|
|
console.log(e);
|
|
|
|
alert("Failed to kick user from chat");
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
document.getElementById("user-deletion-no").onclick = function (ev) {
|
|
|
|
if (ev.button !== 0)
|
|
|
|
return;
|
|
|
|
deactivateActivePopup();
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2024-09-01 22:11:28 +00:00
|
|
|
__mainloopDelayMS = 5000;
|
|
|
|
__guestMainloopPollerAction = function (){
|
|
|
|
console.log("Hello, world");
|
2024-09-04 09:39:39 +00:00
|
|
|
apiRequest("chatPollEvents", genSentBase()).
|
2024-09-02 09:34:49 +00:00
|
|
|
then((Recv) => {
|
|
|
|
console.log(Recv);
|
|
|
|
updateLocalStateFromRecv(Recv);
|
|
|
|
});
|
2024-09-01 22:11:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
window.onload = function(){
|
|
|
|
console.log("Page loaded");
|
2024-09-02 09:34:49 +00:00
|
|
|
configureSummonUserInterface();
|
|
|
|
configureKickUserInterfaceWinPart();
|
2024-09-01 22:11:28 +00:00
|
|
|
updateLocalStateFromChatUpdResp(initial_chatUpdResp);
|
|
|
|
mainloopPoller();
|
|
|
|
}
|