2018-08-02 09:23:38 +02:00

169 lines
4.3 KiB
JavaScript

/**
* Notifications UI script
*
* @author Pierre HUBERT
*/
ComunicWeb.components.notifications.ui = {
/**
* Display a single notification
*
* @param {Object} data Informations about the notification
* @param {HTMLElement} target The target of the notification
* @param {Object} users Informations about users that might be required
* to display the notification
* @param {Object} groups Information about the potential related groups
*/
display_notification: function(data, target, users, groups){
//Generate the informations about the notifications
var from_user = users["user-"+data.from_user_id];
//Generate the appropriate string
//Notification author
var message = userFullName(from_user) + " ";
//Notification action
//Comment
if(data.type == "comment_created")
message += "posted a comment";
//About friendship requests
if(data.type == "sent_friend_request")
message += "sent you a friendship request.";
if(data.type == "accepted_friend_request")
message += "accepted your friendship request.";
if(data.type == "rejected_friend_request")
message += "rejected your friendship request.";
//About group membership
if(data.type == "sent_group_membership_invitation")
message += "invited you to join the group";
if(data.type == "accepted_group_membership_invitation")
message += "accepted his invitation to join the group";
if(data.type == "rejected_group_membership_invitation")
message += "rejected his invitation to join the group";
if(data.type == "sent_group_membership_request")
message += "sent a request to join the group";
if(data.type == "accepted_group_membership_request")
message += "accepted your request to join the group";
if(data.type == "rejected_group_membership_request")
message += "rejected your request to join the group";
//Generic element creation
if(data.type == "elem_created"){
if(data.on_elem_type == "post")
message += "created a new post";
}
//Space separator
message += " ";
//Notification target
//User page
if(data.from_container_type == "user_page"){
if(data.from_user_id == data.from_container_id)
message += "on his / her page";
else
message += "on "+userFullName(users["user-"+data.from_container_id])+"'s page";
}
//Group page
if(data.from_container_type == "group_page"){
message += "on the group "+groups[data.from_container_id].name+".";
}
//Group membership
if(data.on_elem_type == "group_membership")
message += groups[data.on_elem_id].name;
//Create notification action
var action = function(){
//Mark the notification as seen
ComunicWeb.components.notifications.interface.mark_seen(data.id, true);
//Process specific action
//For the post
if(data.on_elem_type == "post"){
//Open associated post page
openPage("post/" + data.on_elem_id);
}
//For the friendship requests
if(data.on_elem_type == "friend_request"){
//Open user page
openUserPageFromID(data.from_user_id);
}
//For the group membership
if(data.on_elem_type == "group_membership"){
//Open appropriate page
if(data.type == "sent_group_membership_request")
openPage("groups/"+data.on_elem_id+"/members");
else
openGroupPage(groups[data.on_elem_id]);
}
};
//Create the notification object
var notificationContainer = createElem2({
appendTo: target,
type: "li",
class: "notification-container"
});
//Create notification link
var notificationLink = createElem2({
appendTo: notificationContainer,
type: "a"
});
notificationLink.onclick = action;
//Add notification left content
var notificationLeftContent = createElem2({
appendTo: notificationLink,
type: "div",
class: "pull-left"
});
//Add user image
var userImage = createElem2({
appendTo: notificationLeftContent,
type: "img",
src: from_user.accountImage,
class: "img-circle"
});
//Add the notification message
var notificationMessage = createElem2({
appendTo: notificationLink,
type: "p",
innerHTML: message
});
//Add notification date
var notificationCreationTime = createElem2({
appendTo: notificationLink,
type: "small",
class: "notification-creation-time",
innerHTML: '<i class="fa fa-clock-o"></i> ' + ComunicWeb.common.date.timeDiffToStr(data.time_create) + " ago"
});
},
}