ComunicWeb/assets/js/pages/userPage/friendshipStatus.js
2018-08-04 09:32:40 +02:00

212 lines
5.3 KiB
JavaScript

/**
* Handle the update of the friendship status
*
* @author Pierre HUBERT
*/
ComunicWeb.pages.userPage.friendshipStatus = {
/**
* Display the friendship status
*
* @param {Integer} userID The ID of the target user
* @param {HTMLElement} target The target element
*/
display: function(userID, target){
//Get the current status of the friendship
ComunicWeb.components.friends.list.getStatus(userID, function(response){
//Empty the target area
emptyElem(target);
target.innerHTML = "";
//Check for errors
if(response.error){
message = ComunicWeb.common.messages.createCalloutElem(
lang("user_page_friendship_section_err_load_title"),
lang("user_page_friendship_section_err_load_message"), "danger");
target.appendChild(message);
return;
}
//Check if the user has received a friendship request
if(response.received_request){
//Offer the user to reject a frienship request
var rejectRequest = createElem2({
appendTo: target,
type: "button",
class: "btn btn-xs btn-danger",
innerHTML: lang("user_page_friendship_section_reject_request")
});
createElem2({
appendTo: target,
type: "span",
innerHTML: " ",
})
//Offer the user to accept a frienship request
var acceptRequest = createElem2({
appendTo: target,
type: "button",
class: "btn btn-xs btn-success",
innerHTML: lang("user_page_friendship_section_accept_request")
});
//Prepare the buttons
acceptRequest.setAttribute("data-accept", "true");
rejectRequest.setAttribute("data-accept", "false");
//Setup the action
var respondRequest = function(){
//Lock the buttons
acceptRequest.disabled = true;
rejectRequest.disabled = true;
//Get the status of the request
var accept = this.getAttribute("data-accept") == "true";
//Perform the action
ComunicWeb.components.friends.list.respondRequest(userID, accept, function(response){
//Unlock the buttons
acceptRequest.disabled = false;
rejectRequest.disabled = false;
//Check for errors
if(response.error){
ComunicWeb.common.notificationSystem.showNotification(lang("user_page_friendship_section_err_update_request_status"),
"danger", 5);
}
else {
//Reopen user page
openUserPageFromID(userID);
}
});
}
acceptRequest.onclick = respondRequest;
rejectRequest.onclick = respondRequest;
}
//Check if user has sent a friendship request
else if(response.sent_request){
//Offer the user to cancel a frienship request
var cancelRequest = createElem2({
appendTo: target,
type: "button",
class: "btn btn-xs btn-danger",
innerHTML: lang("user_page_friendship_section_cancel_request")
});
cancelRequest.onclick = function(){
//Lock button
this.disabled = true;
//Send the request
ComunicWeb.components.friends.list.removeRequest(userID, function(response){
//Check for errors
if(response.error){
ComunicWeb.common.notificationSystem.showNotification(lang("user_page_friendship_section_err_remove_request"));
}
//Reload this component
ComunicWeb.pages.userPage.friendshipStatus.display(userID, target);
});
}
}
//Display send request message
else if(response.are_friend == false) {
//Offer the user to send a frienship request
var sendRequestButton = createElem2({
appendTo: target,
type: "button",
class: "btn btn-xs btn-primary",
innerHTML: lang("user_page_friendship_section_send_request")
});
sendRequestButton.onclick = function(){
//Lock button
this.disabled = true;
//Send the request
ComunicWeb.components.friends.list.sendRequest(userID, function(response){
//Check for errors
if(response.error){
ComunicWeb.common.notificationSystem.showNotification(lang("user_page_friendship_section_err_send_request"));
}
//Reload this component
ComunicWeb.pages.userPage.friendshipStatus.display(userID, target);
});
}
}
//Offer user to follow other user
else {
//Setup button
var followButton = createElem2({
appendTo: target,
type: "button",
class: "btn btn-primary btn-block",
});
if(response.following){
followButton.innerHTML = lang("user_page_friendship_section_following");
followButton.setAttribute("data-following", "true");
}
else {
followButton.innerHTML = lang("user_page_friendship_section_follow");
followButton.setAttribute("data-following", "false");
}
//Make the follow button live
followButton.onclick = function(){
//Lock button
this.disabled = true;
//Check if the user has to be followed or not (reverse current state)
var follow = this.getAttribute("data-following") == "false";
ComunicWeb.components.friends.list.setFollowing(userID, follow, function(response){
//Check for errors
if(response.error){
ComunicWeb.common.notificationSystem.showNotification(lang("user_page_friendship_section_err_update_following_status"));
}
//Reload this component
ComunicWeb.pages.userPage.friendshipStatus.display(userID, target);
});
}
}
});
}
}