2017-05-26 12:01:54 +02:00
|
|
|
/**
|
|
|
|
* Search form component
|
|
|
|
*
|
|
|
|
* @author Pierre HUBERT
|
|
|
|
*/
|
|
|
|
|
2018-07-29 08:08:23 +02:00
|
|
|
ComunicWeb.components.search.form = {
|
2018-01-02 19:07:18 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Store the text input area
|
|
|
|
*/
|
|
|
|
_textInput: null,
|
|
|
|
|
2017-05-26 12:01:54 +02:00
|
|
|
/**
|
|
|
|
* Initializate a search form element
|
|
|
|
*
|
2017-05-26 16:11:41 +02:00
|
|
|
* @param {HTMLElement} textInput The text input node
|
|
|
|
* @param {HTMLElement} searchResultBox The target of the results
|
|
|
|
* @return {Boolean} True for a success
|
2017-05-26 12:01:54 +02:00
|
|
|
*/
|
2017-05-26 16:11:41 +02:00
|
|
|
init: function(textInput, searchResultBox){
|
|
|
|
//Log action
|
|
|
|
ComunicWeb.debug.logMessage("Initializate search menu");
|
2017-05-26 12:01:54 +02:00
|
|
|
|
2017-05-26 16:11:41 +02:00
|
|
|
//Create header
|
|
|
|
var searchHeader = createElem("li", searchResultBox);
|
|
|
|
searchHeader.className = "header";
|
|
|
|
searchHeader.innerHTML = "Search results";
|
|
|
|
|
|
|
|
//Box core
|
|
|
|
var searchBoxCore = createElem("li", searchResultBox);
|
|
|
|
var searchBoxContainer = createElem("div", searchBoxCore);
|
|
|
|
searchBoxContainer.className = "searchBoxResultsContainer";
|
|
|
|
|
|
|
|
//Create footer
|
|
|
|
var searchFooter = createElem("li", searchResultBox);
|
|
|
|
searchFooter.className = "footer";
|
|
|
|
|
|
|
|
//Footer link
|
|
|
|
var footerLink = createElem("a", searchFooter);
|
|
|
|
footerLink.innerHTML = "See more results";
|
|
|
|
footerLink.onclick = function(){
|
|
|
|
openPage("search?q=" + this.getAttribute("data-searchValue"));
|
2018-07-29 17:12:52 +02:00
|
|
|
ComunicWeb.components.search.form.close();
|
2017-05-26 16:11:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//Make input text lives
|
|
|
|
textInput.onkeyup = function(){
|
2018-07-29 08:08:23 +02:00
|
|
|
ComunicWeb.components.search.form.ontextchange(textInput, searchResultBox, searchBoxContainer, footerLink);
|
2017-05-26 16:11:41 +02:00
|
|
|
}
|
|
|
|
|
2018-01-02 19:07:18 +01:00
|
|
|
//Cache textinput area
|
|
|
|
this._textInput = textInput;
|
|
|
|
|
2017-05-26 16:11:41 +02:00
|
|
|
return true;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* What to do on text change
|
|
|
|
*
|
|
|
|
* @param {HTMLElement} textInput The text input node
|
|
|
|
* @param {HTMLElement} searchResultBox The main search box
|
|
|
|
* @param {HTMLElement} searchBoxContainer The target of the results
|
|
|
|
* @param {HTMLElement} footerLink The footer element
|
|
|
|
* @return {Boolean} True for a success
|
|
|
|
*/
|
|
|
|
ontextchange: function(textInput, searchResultBox, searchBoxContainer, footerLink){
|
|
|
|
//We check if the text was removed
|
|
|
|
if(textInput.value == ""){
|
|
|
|
//Text was removed
|
|
|
|
//Hide box
|
|
|
|
searchResultBox.style.display = "none";
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//We show the box
|
|
|
|
searchResultBox.style.display = "block";
|
|
|
|
|
|
|
|
//Change "see more result" value
|
|
|
|
footerLink.setAttribute("data-searchValue", textInput.value);
|
2017-05-26 16:15:13 +02:00
|
|
|
|
|
|
|
//Perform a request on the server
|
2018-07-29 17:11:38 +02:00
|
|
|
ComunicWeb.components.search.interface.global(textInput.value, function(results){
|
2017-05-27 11:57:05 +02:00
|
|
|
|
|
|
|
//Continue only in case of success
|
2018-07-29 17:11:38 +02:00
|
|
|
if(results.error)
|
2017-05-27 11:57:05 +02:00
|
|
|
return false;
|
|
|
|
|
2018-07-29 17:11:38 +02:00
|
|
|
//Get information about related groups and users
|
|
|
|
getMultipleUsersInfos(ComunicWeb.components.search.utils.getUsersId(results), function(usersInfo){
|
|
|
|
|
|
|
|
//Check for errors
|
|
|
|
if(usersInfo.error)
|
|
|
|
return;
|
|
|
|
|
|
|
|
getInfoMultipleGroups(ComunicWeb.components.search.utils.getGroupsId(results), function(groupsInfo){
|
|
|
|
|
|
|
|
//Remove any remainging element in searchResultBox
|
|
|
|
emptyElem(searchBoxContainer);
|
|
|
|
|
|
|
|
//Create menu list
|
|
|
|
var menuList = createElem("ul", searchBoxContainer);
|
|
|
|
menuList.className = "menu";
|
|
|
|
|
|
|
|
if(groupsInfo.error)
|
|
|
|
return;
|
|
|
|
|
|
|
|
//Process the list of results
|
|
|
|
results.forEach(function(result){
|
|
|
|
ComunicWeb.components.search.ui.display(result, usersInfo, groupsInfo, function(){
|
|
|
|
ComunicWeb.components.search.form.close();
|
|
|
|
}, menuList);
|
|
|
|
});
|
|
|
|
|
|
|
|
//Enable slimscroll
|
|
|
|
$(menuList).slimScroll({
|
|
|
|
height: '100%'
|
|
|
|
});
|
2017-05-27 15:11:30 +02:00
|
|
|
});
|
2018-07-29 17:11:38 +02:00
|
|
|
|
2017-05-27 11:57:05 +02:00
|
|
|
});
|
2018-07-29 17:11:38 +02:00
|
|
|
|
2017-05-26 16:15:13 +02:00
|
|
|
});
|
2017-05-27 11:57:05 +02:00
|
|
|
|
|
|
|
},
|
|
|
|
|
2018-01-02 19:07:18 +01:00
|
|
|
/**
|
|
|
|
* Close and clear the search form
|
|
|
|
*/
|
|
|
|
close: function(){
|
|
|
|
this._textInput.value = "";
|
|
|
|
this._textInput.onkeyup();
|
|
|
|
}
|
2017-05-26 12:01:54 +02:00
|
|
|
}
|