196 lines
5.5 KiB
JavaScript
Raw Normal View History

/**
* Menubar for authenticated users complements
*
* @author Pierre HUBERT
*/
ComunicWeb.components.menuBar.authenticated = {
/**
* Add authenticated user specific elements
*
* @param {HTMLElement} container The container element of the Menubar
*/
addElements: function(container){
//Create an auto-collapsed element
var navbarCollapse = createElem("div", container);
navbarCollapse.id = "navbar-collapse";
2017-05-26 11:38:37 +02:00
navbarCollapse.className = "navbar-collapse pull-left collapse";
//Create navbar elements list
2017-05-26 11:38:37 +02:00
var navbarCollapseElemList = createElem("ul", navbarCollapse);
navbarCollapseElemList.className = "nav navbar-nav";
//Add search form
this.addSearchForm(navbarCollapseElemList);
//Navbar right elements
var navbarRight = createElem("div", container);
navbarRight.className = "navbar-custom-menu";
var navbarRightElemList = createElem("ul", navbarRight);
navbarRightElemList.className = "nav navbar-nav";
2017-05-25 15:06:01 +02:00
//Add user name
2017-05-26 11:38:37 +02:00
this.addUserName(navbarRightElemList);
2017-05-25 15:06:01 +02:00
2017-06-03 15:41:04 +02:00
//Add friends list button
this.addFriendListButton(navbarRightElemList);
2018-02-18 19:12:17 +01:00
//Add notifications dropdown
ComunicWeb.components.notifications.dropdown.display(navbarRightElemList);
//Add dropdown menu
2017-05-26 11:38:37 +02:00
this.addDropdown(navbarRightElemList);
},
/**
* Add dropdown menu
*
* @param {HTMLElement} navbarElem The target navbarlist element
2017-05-25 15:06:01 +02:00
* @return {HTMLElement} The dropdown content element
*/
addDropdown: function(navbarElem){
//Create dropdown menu
var dropdown = createElem("li", navbarElem);
2017-05-26 11:38:37 +02:00
dropdown.className = "dropdown dropdown-user-menu-action";
//Add dropdown button
var dropdownButton = createElem("a", dropdown);
dropdownButton.className = "dropdown-toggle";
dropdownButton.setAttribute("data-toggle", "dropdown");
2017-05-25 14:06:37 +02:00
//Add dropdown button icon
var dropdownButtonIcon = createElem("i", dropdownButton);
dropdownButtonIcon.className = "fa fa-gear";
2017-05-25 15:06:01 +02:00
//Add space
2017-05-25 14:06:37 +02:00
dropdownButton.innerHTML += " ";
//Add dropdown button arrow
var dropdownButtonArrow = createElem("span", dropdownButton);
dropdownButtonArrow.className = "caret";
//Create dropdown menu content
var dropdownContent = createElem("ul", dropdown);
dropdownContent.className = "dropdown-menu"
dropdownContent.setAttribute("role", "menu");
2018-04-12 16:17:41 +02:00
//Add settings link
var settingsButton = createElem2({
appendTo: dropdownContent,
type: "li"
});
var settingsLink = createElem2({
appendTo: settingsButton,
type: "a",
innerHTML: "Settings"
});
settingsButton.onclick = function(){
openPage("settings");
};
//Add logout link
var logoutButton = createElem("li", dropdownContent);
var logoutButtonLink = createElem("a", logoutButton);
2018-03-11 16:55:44 +01:00
logoutButtonLink.innerHTML = lang("_menu_bar_action_logout");
2017-05-25 13:57:38 +02:00
logoutButton.onclick = function(){openPage("logout")};
2017-05-25 15:06:01 +02:00
//Return dropdown content element
return dropdownContent;
},
2017-06-03 15:41:04 +02:00
/**
* Add friendsList toggle button
*
* @param {HTMLElement} navbarElem The target navbarlist element
* @return {HTMLElement} The button element
*/
addFriendListButton: function(navbarElem){
//Create button
var friendButton = createElem("li", navbarElem);
friendButton.className = "friendToggleButton";
//Create link
var friendButtonLink = createElem("a", friendButton);
var friendIcon = createElem("i", friendButtonLink);
friendIcon.className = "fa fa-users";
//Makes link live
friendButtonLink.onclick = function(){
ComunicWeb.components.friends.bar.toggleShowHide();
};
return friendButtonLink;
},
2017-05-25 15:06:01 +02:00
/**
* Add user name element
*
* @param {HTMLElement} navbarElem The target navbarlist element
* @return {HTMLElement} The user element
*/
addUserName: function(navbarElem){
//Create user element
var userelement = createElem("li", navbarElem);
userelement.className = "user-menu";
//Add user link element
var userlinkelement = createElem("a", userelement);
//Add user image
var userimage = createElem("img", userlinkelement);
userimage.className = "user-image";
userimage.src = ComunicWeb.__config.assetsURL + "img/defaultAvatar.png";
//Add user name
var userNameElem = createElem("span", userlinkelement);
2017-05-26 11:38:37 +02:00
userNameElem.className = "hidden-xs";
2018-03-11 16:55:44 +01:00
userNameElem.innerHTML = lang("_loading");
2017-05-25 15:06:01 +02:00
//Make a request to get informations about the user
2017-05-27 11:57:05 +02:00
ComunicWeb.user.userInfos.getUserInfos("current", (function(userInfos){
2017-05-25 15:25:39 +02:00
//Change user name
userNameElem.innerHTML = userInfos.firstName + " "+ userInfos.lastName;
//Change avatar url
userimage.src = userInfos.accountImage;
2018-01-02 19:11:29 +01:00
userlinkelement.onclick = function(){
openUserPage(userIDorPath(userInfos));
}
2017-05-27 15:35:10 +02:00
}), true);
2017-05-25 15:06:01 +02:00
},
2017-05-26 11:38:37 +02:00
/**
* Add search form element
*
* @param {HTMLElement} navbarElem The target navbarlist element
* @return {HTMLElement} The user element
*/
addSearchForm: function(navbarElem){
//Create form element
2017-05-26 12:01:54 +02:00
var searchForm = createElem("li", navbarElem);
2017-05-27 11:57:05 +02:00
searchForm.className = "dropdown navbar-form navbar-left messages-menu";
2017-05-26 11:38:37 +02:00
searchForm.setAttribute("role", "search");
//Create form group
var formGroup = createElem("div", searchForm);
formGroup.className = "form-group";
//Create search input
var searchInput = createElem("input", formGroup);
searchInput.className = "form-control";
2018-03-11 16:55:44 +01:00
searchInput.placeholder = lang("_menu_bar_search_placeholder");
2017-05-26 11:38:37 +02:00
searchInput.type = "text";
searchInput.id = "navbar-search-input";
2017-05-26 12:01:54 +02:00
2017-05-26 16:11:41 +02:00
//Create dropdown container
var dropdownContainer = createElem("ul", searchForm);
dropdownContainer.className = "dropdown-menu";
//Initializate menu
ComunicWeb.components.searchForm.init(searchInput, dropdownContainer);
2017-05-26 11:38:37 +02:00
}
};