mirror of
https://github.com/pierre42100/ComunicWeb
synced 2025-01-13 19:07:44 +00:00
250 lines
6.0 KiB
JavaScript
250 lines
6.0 KiB
JavaScript
/**
|
|
* Friend user interface script
|
|
*
|
|
* @author Pierre HUBERT
|
|
*/
|
|
|
|
ComunicWeb.components.friends.ui = {
|
|
|
|
/**
|
|
* Display a single friend informations
|
|
*
|
|
* @param {HTMLElement} target The target to display the friend
|
|
* @param {Object} friend Informations about the friendship
|
|
* @param {Object} user Informations about the user
|
|
*/
|
|
show_personnal_friend: function(target, friend, user){
|
|
|
|
//Create friend container, if required
|
|
if(target.className == "friend"){
|
|
var friendContainer = target;
|
|
emptyElem(friendContainer);
|
|
}
|
|
else
|
|
var friendContainer = createElem2({
|
|
appendTo: target,
|
|
type: "div",
|
|
class: "friend"
|
|
});
|
|
|
|
//Get informations about the friend
|
|
const friendID = friend.ID_friend;
|
|
|
|
//Create user link
|
|
const userLink = createElem2({
|
|
appendTo: friendContainer,
|
|
type: "a"
|
|
});
|
|
|
|
//Add user account image
|
|
createElem2({
|
|
appendTo: userLink,
|
|
type: "img",
|
|
src: user.accountImage
|
|
});
|
|
|
|
//Add users name
|
|
createElem2({
|
|
appendTo: userLink,
|
|
type: "div",
|
|
class: "friends-name",
|
|
innerHTML: userFullName(user)
|
|
});
|
|
|
|
//Make the link button lives
|
|
userLink.onclick = function(){
|
|
|
|
//Open user page
|
|
openUserPage(userIDorPath(user));
|
|
|
|
//Close all modals
|
|
$(".modal").modal("hide");
|
|
|
|
}
|
|
|
|
//Create actions area
|
|
var actionsOnFriendArea = createElem2({
|
|
appendTo: friendContainer,
|
|
type: "div",
|
|
class: "friends-actions"
|
|
});
|
|
|
|
//Check if the friendship has been accepted or not
|
|
if(friend.accepted == 0){
|
|
|
|
//Offer the user to accept or reject friendship request
|
|
//Reject
|
|
var rejectRequestBtn = createElem2({
|
|
appendTo: actionsOnFriendArea,
|
|
type: "input",
|
|
elemType: "button",
|
|
class: "btn btn-danger",
|
|
value: "Refuser"
|
|
});
|
|
rejectRequestBtn.setAttribute("data-accept-request", "false");
|
|
|
|
add_space(actionsOnFriendArea);
|
|
|
|
//Accept
|
|
var acceptRequestBtn = createElem2({
|
|
appendTo: actionsOnFriendArea,
|
|
type: "button",
|
|
class: "btn btn-success",
|
|
innerHTML: "Accepter"
|
|
});
|
|
acceptRequestBtn.setAttribute("data-accept-request", "true");
|
|
|
|
add_space(actionsOnFriendArea);
|
|
|
|
//Make the buttons lives
|
|
var respond = function(){
|
|
|
|
//Check whether the request was accepted or not
|
|
var accept = this.getAttribute("data-accept-request") == "true";
|
|
|
|
//Perform the request on the server
|
|
ComunicWeb.components.friends.list.respondRequest(friendID, accept, function(r){
|
|
|
|
//Check for error
|
|
if(r.error){
|
|
ComunicWeb.common.notificationSystem.showNotification("Could not respond to request !", "danger");
|
|
return;
|
|
}
|
|
|
|
if(!accept){
|
|
friendContainer.remove();
|
|
}
|
|
else {
|
|
|
|
//Update friendship informations
|
|
ComunicWeb.components.friends.actions.refresh_single_personnal(friendID, friendContainer);
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
acceptRequestBtn.onclick = respond;
|
|
rejectRequestBtn.onclick = respond;
|
|
}
|
|
|
|
else {
|
|
|
|
//Display following state
|
|
var followButton = createElem2({
|
|
appendTo: actionsOnFriendArea,
|
|
type: "button",
|
|
class: "btn btn-primary"
|
|
});
|
|
|
|
if(friend.following == 0){
|
|
followButton.innerHTML = "Follow";
|
|
followButton.setAttribute("data-set-following", "true");
|
|
}
|
|
else {
|
|
followButton.innerHTML = "<i class='fa fa-check'></i> Following";
|
|
followButton.setAttribute("data-set-following", "false");
|
|
}
|
|
|
|
add_space(actionsOnFriendArea);
|
|
|
|
followButton.onclick = function(){
|
|
|
|
//Check if the request is to follow or not the user
|
|
var follow = this.getAttribute("data-set-following") == "true";
|
|
|
|
//Lock button
|
|
followButton.disabled = true;
|
|
|
|
//Perform callback action
|
|
ComunicWeb.components.friends.list.setFollowing(friendID, follow, function(r){
|
|
|
|
//Check for errors
|
|
if(r.error){
|
|
ComunicWeb.common.notificationSystem.showNotification("Could not update follow state !", "danger");
|
|
}
|
|
|
|
//Update friendship informations
|
|
ComunicWeb.components.friends.actions.refresh_single_personnal(friendID, friendContainer);
|
|
});
|
|
|
|
}
|
|
|
|
//Check if the user can post text on user page
|
|
var postTextsButton = createElem2({
|
|
appendTo: actionsOnFriendArea,
|
|
type: "button",
|
|
class: "btn btn-primary"
|
|
});
|
|
|
|
if(friend.canPostTexts){
|
|
postTextsButton.innerHTML = "<i class='fa fa-check'></i> Post Texts";
|
|
postTextsButton.setAttribute("data-allow-post-texts", "false");
|
|
}
|
|
else {
|
|
postTextsButton.innerHTML = "Post Texts";
|
|
postTextsButton.setAttribute("data-allow-post-texts", "true");
|
|
}
|
|
|
|
//Make the button lives
|
|
postTextsButton.onclick = function(){
|
|
|
|
//Check out if we have to allow or disallow texts post
|
|
var allow_post = this.getAttribute("data-allow-post-texts") == "true";
|
|
|
|
//Update the status
|
|
ComunicWeb.components.friends.interface.set_can_post_texts(friendID, allow_post, function(r){
|
|
|
|
if(r.error)
|
|
ComunicWeb.common.notificationSystem.showNotification("Could not update posts creation status !", "danger");
|
|
|
|
//Update friendship informations
|
|
ComunicWeb.components.friends.actions.refresh_single_personnal(friendID, friendContainer);
|
|
|
|
});
|
|
}
|
|
}
|
|
|
|
|
|
|
|
//Offer to delete friendship
|
|
const deleteLink = createElem2({
|
|
appendTo: friendContainer,
|
|
type: "a",
|
|
innerHTML: "<i class='fa fa-trash'></i>"
|
|
});
|
|
|
|
//Make the delete button lives
|
|
deleteLink.onclick = function(){
|
|
|
|
//Prompt user confirmation
|
|
if(ComunicWeb.common.messages.confirm("Do you really want to delete this user from your friends list ?", function(confirm){
|
|
|
|
//Check if the user cancelled the operation
|
|
if(!confirm)
|
|
return;
|
|
|
|
//Try to delete the friend from the list
|
|
friendContainer.style.visibility = "hidden";
|
|
ComunicWeb.components.friends.interface.remove_friend(friendID, function(result){
|
|
|
|
//Make friend container visible
|
|
friendContainer.style.visibility = "visible";
|
|
|
|
//Check for errors
|
|
if(result.error){
|
|
ComunicWeb.common.notificationSystem.showNotification("Could not delete friend !", "danger");
|
|
return;
|
|
}
|
|
|
|
//Delete the element
|
|
friendContainer.remove();
|
|
|
|
});
|
|
|
|
}));
|
|
}
|
|
|
|
}
|
|
|
|
} |