mirror of
https://github.com/pierre42100/ComunicWeb
synced 2025-01-15 03:47:42 +00:00
169 lines
4.3 KiB
JavaScript
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"
|
|
});
|
|
},
|
|
|
|
|
|
} |