ComunicWeb/assets/js/user/userInfos.js
2017-06-13 16:42:09 +02:00

203 lines
5.0 KiB
JavaScript

/**
* User informations functions
*
* @author Pierre HUBERT
*/
ComunicWeb.user.userInfos = {
/**
* @var {String} User infos cache
*/
usersInfos: {},
/**
* Get user informations
*
* @param {String} userID User on which to make request (current to get connected user)
* @param {function} afterGetUserInfos What to do once user informations are available
* @param {Boolean} forceRequest Force the request to be made
* @return {Boolean} True for a success
*/
getUserInfos: function(userID, afterGetUserInfos, forceRequest){
//Check if current user infos were required
if(userID == "current")
userID = ComunicWeb.user.userLogin.getUserID();
//getMultipleUsersInfos mirror
var usersID = [userID];
return this.getMultipleUsersInfos(usersID, function(result){
//We check if an error occured
if(result.error)
afterGetUserInfos(result);
//Return a simple array
else
afterGetUserInfos(result["user-"+userID]);
}, forceRequest);
},
/**
* Get multiple users informations
*
* @param {Array~Object} usersID User on which to make request (current to get connected user)
* @param {function} afterGetUserInfos What to do once users informations are available
* @param {Boolean} forceRequest Force the request to be made
* @return {Boolean} True for a success
*/
getMultipleUsersInfos: function(usersID, afterGetUserInfos, forceRequest){
//First, check if informations are already available in the cache for some users
var cachedInformations = {};
var needRequest = false; //By default the request isn't required
var usersToGetList = "";
for(i in usersID){
//Extract userID
var processUserID = usersID[i];
//Check the local cache
if(this.usersInfos["user-"+processUserID] && !forceRequest){
//Add user information to cached informations
cachedInformations["user-"+processUserID] = this.usersInfos["user-"+processUserID];
}
else {
//Else we'll have to get data
needRequest = true;
usersToGetList += processUserID + ",";
}
}
//Check if an API request is not required
if(!needRequest){
//Go immediatly to the next step
afterGetUserInfos(cachedInformations);
return true;
}
//Perform API request
var apiURI = "user/getInfosMultiple";
var params = {
usersID: usersToGetList,
}
//Specify what to do next
var onceGetUserInfos = function(result){
if(result.error){
//Log error
ComunicWeb.debug.logMessage("ERROR : couldn't get infos about users ID !");
//Returns the error to the next function
afterGetUserInfos(result);
//Something went wrong
return false;
}
else {
//Prepare return
var returnInformations = cachedInformations;
//Save results and prepare return
for(i in result){
//Get user ID
var userID = result[i]['userID'];
//Store
ComunicWeb.user.userInfos.usersInfos["user-"+userID] = result[i];
returnInformations["user-"+userID] = result[i];
}
//Return results
afterGetUserInfos(returnInformations);
}
}
//Perform request
ComunicWeb.common.api.makeAPIrequest(apiURI, params, true, onceGetUserInfos);
//Everything is OK
return true;
},
/**
* Empty user informations cache
* Remove all entries from user informations cache
*
* @return {Boolean} True for a success
*/
emptyUserInfosCache: function(){
this.userInfos = undefined; //Mark user info cache as undefined
this.userInfos = {}; //Create a new variable
return true;
},
/**
* Given a query, search for users and return the result
*
* @param {String} query The query to search
* @param {Function} afterSearch What to do once we got results
* @return {Boolean} True for a success
*/
search: function(query, afterSearch){
//Perform a request on the server
apiURI = "user/search";
params = {
query: query,
};
ComunicWeb.common.api.makeAPIrequest(apiURI, params, true, function(response){
//Continue only in case of success
if(response.error){
afterSearch(false);
return false;
}
//Preload users informations
ComunicWeb.user.userInfos.getMultipleUsersInfos(response, function(usersInfos){
//Go to next action
afterSearch(usersInfos);
});
});
},
/**
* Given user IDs (in an array) the function return their names in a string
*
* @param {Array} usersID The users to return as a string
* @param {Function} afterNames What to do once we have got the names
* @return {Boolean} True for a success
*/
getNames: function(usersID, afterNames){
//Get users informations
this.getMultipleUsersInfos(usersID, function(usersInfo){
//Check for errors
if(usersInfo.error){
afterNames("Error");
}
//Prepare conversation name
var usersName = "";
//Process users informations
for(i in usersInfo){
if(usersInfo[i].firstName)
//Add a coma if required
if(usersName != "")
usersName += ", ";
usersName += usersInfo[i].firstName + " " + usersInfo[i].lastName;
}
//Perform next action with result
afterNames(usersName);
});
},
}