Network errors can be handled by the app

This commit is contained in:
Pierre 2017-06-07 17:26:51 +02:00
parent bb14c3bb49
commit ee02b522bf
5 changed files with 120 additions and 49 deletions

View File

@ -0,0 +1,14 @@
/**
* Network error stylesheet
*
* @author Pierre HUBERT
*/
#networkErrorMessage {
position: fixed;
bottom: 2px;
left: 1px;
width: 300px;
max-width: 100%;
text-align: justify;
}

View File

@ -51,6 +51,17 @@ ComunicWeb.common.api.makeAPIrequest = function(apiURI, params, requireLoginToke
apiXHR.onreadystatechange = function(){
//We continue only if request is terminated
if(apiXHR.readyState == 4){
//Check if response code is 0
if(apiXHR.status == 0){
//An error occured
ComunicWeb.common.network.setStatus(false);
}
else{
//It is a success
ComunicWeb.common.network.setStatus(true);
}
//Prepare result
var result = JSON.parse(apiXHR.responseText);

View File

@ -202,6 +202,11 @@ var ComunicWeb = {
* Make a get request
*/
getRequest: function(url, cache, GETnextAction){},
/**
* Update the status of the network
*/
setStatus: function(success){},
},
/**

View File

@ -63,4 +63,44 @@ ComunicWeb.common.network = {
//Perform request
xhrRequest.send(null);
},
/**
* Update the status of the network
*
* @param {Boolean} success True for a successful request, false else
* @return {Boolean} True for a success
*/
setStatus: function(success){
//If the request is the success, hide error message
if(success){
//Check if an error message was present on the screen
if(byId("networkErrorMessage")){
//Hide it
byId("networkErrorMessage").style.display = "none";
}
}
//If we encountered a network error, display an error message
if(!success){
//Log state
ComunicWeb.debug.logMessage("NETWORK ERROR : It's seems a network request has just echoed... Please check the network !");
//Check if error message exists or not
if(!byId("networkErrorMessage")){
//Create error message contener
var networkErrorMessage = createElem("div", document.body);
networkErrorMessage.id = "networkErrorMessage";
//Create a callout element within it
var errorName = "<i class='fa fa-warning'></i> "+"Network error";
var errorMessage = "It seems that there is a network error, and Comunic can't access to the Internet anymore... Please check your internet connexion...";
var errorCallout = ComunicWeb.common.messages.createCalloutElem(errorName, errorMessage, "danger");
networkErrorMessage.appendChild(errorCallout)
}
//Make sure the error message is visible on the screen
byId("networkErrorMessage").style.display = "block";
}
}
};

View File

@ -23,6 +23,7 @@ $config['CSSfiles'] = array(
//App stylesheets
"%PATH_ASSETS%css/common/global.css",
"%PATH_ASSETS%css/common/page/waitSplashScreen.css",
"%PATH_ASSETS%css/common/network/networkError.css",
//Components stylesheets
"%PATH_ASSETS%css/components/menuBar.css",