277 lines
8.6 KiB
JavaScript
Raw Normal View History

2017-06-05 10:12:38 +02:00
/**
2017-06-07 19:24:48 +02:00
* Conversations list window
2017-06-05 10:12:38 +02:00
*
* @author Pierre HUBERT
*/
const ConversationsList = {
2017-06-05 10:12:38 +02:00
/**
2017-06-07 19:24:48 +02:00
* Display conversations list window
2017-06-05 10:12:38 +02:00
*
* @param {HTMLElement} nodeBefore The node before the destination
* @return {Boolean} True for a success
*/
display: function(nodeBefore){
//Log action
ComunicWeb.debug.logMessage("INFO : initialize conversation list box.");
//Create a window
2017-06-07 19:24:48 +02:00
var listBox = ComunicWeb.components.conversations.windows.create(nodeBefore);
2017-06-05 10:12:38 +02:00
//Change box title
2017-06-07 19:24:48 +02:00
listBox.boxTitle.innerHTML = "Conversations";
2017-06-05 10:12:38 +02:00
2017-06-13 16:42:09 +02:00
//Change box root elem class
listBox.rootElem.className += " conversations-list-box";
2017-06-05 10:12:38 +02:00
//Remove footer
listBox.boxFooter.remove();
2017-06-05 11:02:10 +02:00
//Add the create button
2017-06-13 11:58:08 +02:00
/*var createButton = createElem("button");
2017-06-05 11:02:10 +02:00
listBox.boxTools.insertBefore(createButton, listBox.boxTools.children[0]);
createButton.className = "btn btn-box-tool";
createButton.onclick = function(){
2017-06-07 19:24:48 +02:00
ComunicWeb.components.conversations.list.displayCreateForm(listBox);
2017-06-11 15:14:23 +02:00
this.remove();
2017-06-05 11:02:10 +02:00
}
//Button icon
var createButtonIcon = createElem("i", createButton);
2017-06-13 11:58:08 +02:00
createButtonIcon.className = "fa fa-pencil";*/
2017-06-05 11:02:10 +02:00
2017-06-10 15:18:03 +02:00
//Get and display conversations list
2017-06-13 11:58:08 +02:00
this.showConversationsList(listBox);
2017-06-05 11:02:10 +02:00
2017-06-05 10:12:38 +02:00
//Success
return true;
},
2017-06-05 11:02:10 +02:00
/**
2017-06-07 19:24:48 +02:00
* Display the form to create a new conversation
2017-06-05 11:02:10 +02:00
*
* @param {Object} listBox Informations about the listbox target
* @return {Boolean} True for a success
*/
displayCreateForm: function(listBox){
//Log action
2017-06-07 19:24:48 +02:00
ComunicWeb.debug.logMessage("INFO : initialize create conversation form");
2017-06-05 11:02:10 +02:00
//Hide boxy body contents
var boxBodyElem = listBox.boxBody.children;
for(i in boxBodyElem){
if(boxBodyElem[i].style)
boxBodyElem[i].style.display = "none";
}
//Change box title
listBox.boxTitle.innerHTML = tr("New conversation");
2017-06-05 11:02:10 +02:00
2017-06-17 11:33:15 +02:00
//Create the form
var form = ConversationsUtils.createConversationForm(listBox.boxBody);
2017-06-05 11:02:10 +02:00
//Generate a summary object about all the informations we have got
var infos = {
listBox: listBox,
2017-06-17 11:33:15 +02:00
usersElement: form.usersElement,
conversationNameInput: form.conversationNameInput,
conversationColorInput: form.conversationColorInput,
2017-06-17 11:33:15 +02:00
followConversationInput: form.followConversationInput,
allowEveryoneToAddMembersInput: form.allowEveryoneToAddMembers,
};
//Make button lives
form.createButton.onclick = () => {
this.submitCreateConversationForm(infos);
};
2017-06-05 11:02:10 +02:00
//Success
return true;
},
/**
2017-06-07 19:24:48 +02:00
* Submit a create a conversation form
*
* @param {Object} infos Data to pass to the function
2017-06-07 19:24:48 +02:00
* * @info {Object} listBox Informations about the listbox creating the conversation
2017-06-07 16:55:47 +02:00
* * @info {HTMLElement} usersElement Pointer on userElement
2017-06-07 19:24:48 +02:00
* * @info {HTMLElement} conversationNameInput Pointer on the input of the form of the conversation
* * @info {HTMLElement} followConversationInput Pointer on the "follow conversation" checkbox
* * @info {HTMLElement} allowEveryoneToAddMembersInput
* @return {Boolean} True for a success
*/
2017-06-07 19:24:48 +02:00
submitCreateConversationForm: function(infos){
//First, get the list of users
2017-06-07 16:55:47 +02:00
var selectedUsers = ComunicWeb.components.userSelect.getResults(infos.usersElement);
//We check if less than one user was selected
if(selectedUsers.length < 1){
//Display an error notification
ComunicWeb.common.notificationSystem.showNotification("Please select at least one user!", "danger", 2);
return false;
}
//Add current user to the list
selectedUsers.push(ComunicWeb.user.userLogin.getUserID());
//Prepare the creation of the conversation
//Get all required informations
2017-06-07 19:24:48 +02:00
var conversationInformations = {
2017-06-07 16:55:47 +02:00
users: selectedUsers,
2017-06-07 19:24:48 +02:00
follow: infos.followConversationInput.checked,
2021-03-09 18:59:15 +01:00
conversationName: (infos.conversationNameInput.value == "" ? null : infos.conversationNameInput.value),
color: infos.conversationColorInput.value == "" ? null : infos.conversationColorInput.value,
allowEveryoneToAddMembersInput: infos.allowEveryoneToAddMembersInput.checked,
2017-06-07 16:55:47 +02:00
};
//Change box body style
var splashScreen = ComunicWeb.common.page.showTransparentWaitSplashScreen(infos.listBox.boxBody);
//Contact the interface to create the conversation
ConversationsInterface.createConversation(conversationInformations, function(response){
2017-06-10 09:42:09 +02:00
//First, remove splash screen
splashScreen.remove();
//Check for errors
if(response.error){
//Make an error notification
notifMessage = "An error occured while trying to create conversation. Please try again.";
ComunicWeb.common.notificationSystem.showNotification(notifMessage, "danger", 3);
return false;
}
//Success
2017-06-10 15:18:03 +02:00
notifMessage = "The conversation was successfully created !";
ComunicWeb.common.notificationSystem.showNotification(notifMessage, "success", 2);
//Remove the conversation box
infos.listBox.rootElem.remove();
//Add & open the conversation
2021-03-06 18:54:50 +01:00
ComunicWeb.components.conversations.manager.addConversation(response.conversationID);
2017-06-10 09:42:09 +02:00
})
2017-06-11 15:14:23 +02:00
},
/**
* Show the conversations list
*
2017-06-13 11:58:08 +02:00
* @param {Object} listBox HTML elements about the listBox
2017-06-11 15:14:23 +02:00
* @return {Boolean} True for a success
*/
2017-06-13 11:58:08 +02:00
showConversationsList: function(listBox){
2017-06-11 15:14:23 +02:00
//Get and show the conversation list
2017-06-13 11:58:08 +02:00
ComunicWeb.components.conversations.interface.getList(function(conversations){
//Add the "create a conversation button"
var createConversationButton = createElem("button", listBox.boxBody);
createConversationButton.style.width = "100%";
createConversationButton.style.marginBottom = "5px";
createConversationButton.className = "btn btn-default btn-flat";
createConversationButton.innerHTML = "Create a new conversation";
//Create a ul element that will contain conversation list
var ulElem = createElem("ul", listBox.boxBody);
ulElem.className = "nav nav-pills nav-stacked";
//Make create converstion button lives
createConversationButton.onclick = function(){
ComunicWeb.components.conversations.list.displayCreateForm(listBox);
};
//Process each conversation elements
for(i in conversations){
//Extract conversation informations
var conversationInfos = conversations[i];
//Create subElement
var liElem = createElem("li", ulElem);
//Display entry
2017-06-13 16:54:23 +02:00
ComunicWeb.components.conversations.list.showConversationEntry(conversationInfos, liElem, listBox);
2017-06-13 11:58:08 +02:00
}
2017-06-11 15:14:23 +02:00
//Enable scrollbar
$(ulElem).slimScroll({
height: '100%'
});
2017-06-11 15:14:23 +02:00
}, true);
//Success
return true;
},
2017-06-13 11:58:08 +02:00
/**
* Show a conversation entry
*
2021-03-06 12:04:01 +01:00
* @param {Conversation} conv Information about the conversation
2017-06-13 11:58:08 +02:00
* @param {HTMLElement} entryTarget The target for the entry
2017-06-13 16:54:23 +02:00
* @param {Object} listBox HTML elements about the listBox
2017-06-13 11:58:08 +02:00
* @return {Boolean} True for a success
*/
2021-03-06 12:04:01 +01:00
showConversationEntry: function(conv, entryTarget, listBox){
2017-06-13 11:58:08 +02:00
//Create link element
var linkElem = createElem("a", entryTarget);
2017-06-13 16:54:23 +02:00
//Make the link element live
linkElem.onclick = function(){
//Remove conversations list
listBox.rootElem.remove();
2017-06-13 11:58:08 +02:00
//Add & open conversation
2021-03-06 12:04:01 +01:00
ComunicWeb.components.conversations.manager.addConversation(conv.id);
2017-06-13 16:54:23 +02:00
}
2017-06-13 16:42:09 +02:00
//Add conversations last activity
var lastActivityElem = createElem("small", linkElem);
lastActivityElem.className = "pull-right last-activity";
var lastActivityIcon = createElem("i", lastActivityElem);
lastActivityIcon.className = "fa fa-clock-o";
var lastActivityValueElem = createElem("span", lastActivityElem);
//Calculate last conversation activity
var currentTime = ComunicWeb.common.date.time();
2021-03-06 12:04:01 +01:00
lastActivityValueElem.innerHTML = " "+ComunicWeb.common.date.diffToStr(currentTime - conv.last_activity);
2017-06-13 16:42:09 +02:00
2017-06-13 11:58:08 +02:00
//Create the conversation name element
var conversationNameElem = createElem("strong", linkElem);
//Put conversation name field in a waiting state
conversationNameElem.style.fontSize = "90%";
conversationNameElem.innerHTML = "Loading...";
//Get conversation name and apply it
2021-03-06 12:04:01 +01:00
ComunicWeb.components.conversations.utils.getName(conv, function(conversationName){
conversationNameElem.innerHTML = conversationName;
});
2017-06-13 11:58:08 +02:00
//Add members number
//Create paragraph
var membersNumberParagraphElem = createElem("p", linkElem);
membersNumberParagraphElem.className = "conversations-members-numbers";
var membersNumberSmallElem = createElem("small", membersNumberParagraphElem);
//Add icon
var membersNumberIconElem = createElem("i", membersNumberSmallElem);
membersNumberIconElem.className = "fa fa-users";
//Specify value
var membersNumberValueElem = createElem("span", membersNumberSmallElem);
2021-03-06 12:04:01 +01:00
membersNumberValueElem.innerHTML = (conv.members.length === 1 ? tr("1 member") : conv.members.length + " members");
2017-06-13 11:58:08 +02:00
//Success
return true;
}
}
ComunicWeb.components.conversations.list = ConversationsList;