Can delete friend from the list

This commit is contained in:
Pierre 2018-03-11 09:56:42 +01:00
parent 411800b46f
commit fb1f702c77
3 changed files with 162 additions and 2 deletions

View File

@ -11,14 +11,16 @@
margin: 5px;
}
.personnal-friends-list .friend a,
.friends-list-ro .friend a {
color: white;
}
.personnal-friends-list .friend a:hover,
.friends-list-ro .friend a:hover {
color: #001F3F;
}
.personnal-friends-list .friend img,
.friends-list-ro .friend img {
margin: auto 10px auto auto;
max-width: 40px;
@ -27,10 +29,20 @@
visibility: visible;
}
.personnal-friends-list .friend .friends-name,
.friends-list-ro .friend .friends-name {
display: inline-block;
white-space: normal;
max-width: 100px;
text-align: left;
vertical-align: middle;
}
.personnal-friends-list .friend {
margin-bottom: 10px;
}
.personnal-friends-list .friend .friends-name {
width: 200px;
max-width: 200px;
}

View File

@ -44,6 +44,25 @@ ComunicWeb.components.friends.interface = {
//Perform API request
ComunicWeb.common.api.makeAPIrequest(apiURI, params, true, callback);
},
/**
* Remove a user from the friend list
*
* @param {numbert} userID The ID of the user to remove
* @param {function} callback What to do once we got a response
*/
remove_friend: function(userID, callback){
//Prepare API request
var apiURI = "friends/remove";
var params = {
friendID: userID
};
//Perform API request
ComunicWeb.common.api.makeAPIrequest(apiURI, params, true, callback);
}
}

View File

@ -136,7 +136,13 @@ ComunicWeb.components.friends.listModal = {
closeModal.onclick = respond;
//Display the right version of the friends list
if(userID() != user){
if(userID() == user){
//Show the friends list of the user
this._show_personnal(modalBody, list);
}
else {
//Display a read-only list of friends
this._show_read_only(modalBody, list, user);
@ -219,4 +225,127 @@ ComunicWeb.components.friends.listModal = {
},
/**
* Show the list of friends of the user
*
* @param {HTMLElement} target The target element for the list
* @param {array} list The list of friends of the user
*/
_show_personnal: function(target, list){
//Get the list of friends ID
var usersID = ComunicWeb.components.friends.utils.getUsersIdFromPersonnalList(list);
//Create list target
var listTarget = createElem2({
appendTo: target,
type: "div",
class: "personnal-friends-list"
});
//Get informations about the users
ComunicWeb.user.userInfos.getMultipleUsersInfos(usersID, function(users){
//Check for errors
if(users.error){
ComunicWeb.common.notificationSystem.showNotification("Could not get informations about friends !", "danger");
return;
}
//Display each friend
list.forEach(friend => {
//Get informations about the friend
const friendID = friend.ID_friend;
//Create friend contener
const friendContener = createElem2({
appendTo: listTarget,
type: "div",
class: "friend"
});
//Create user link
const userLink = createElem2({
appendTo: friendContener,
type: "a"
});
//Add user account image
createElem2({
appendTo: userLink,
type: "img",
src: users["user-" + friendID].accountImage
});
//Add users name
createElem2({
appendTo: userLink,
type: "div",
class: "friends-name",
innerHTML: userFullName(users["user-" + friendID])
});
//Make the link button lives
userLink.onclick = function(){
//Open user page
openUserPage(userIDorPath(users["user-" + friendID]));
//Close all modals
$(".modal").modal("hide");
}
//Check if the friendship has been accepted or not
//Display following state
//Check if the user can post text on user page
//Offer to delete friendship
const deleteLink = createElem2({
appendTo: friendContener,
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
friendContener.style.visibility = "hidden";
ComunicWeb.components.friends.interface.remove_friend(friendID, function(result){
//Make friend contener visible
friendContener.style.visibility = "visible";
//Check for errors
if(result.error){
ComunicWeb.common.notificationSystem.showNotification("Could not delete friend !", "danger");
return;
}
//Delete the element
friendContener.remove();
});
}));
}
});
});
}
};