diff --git a/frontends/ycdl_flask/static/js/common.js b/frontends/ycdl_flask/static/js/common.js index c0900a9..051ef95 100644 --- a/frontends/ycdl_flask/static/js/common.js +++ b/frontends/ycdl_flask/static/js/common.js @@ -40,6 +40,17 @@ function refresh() window.location.reload(); } +common.refresh_or_alert = +function refresh_or_alert(response) +{ + if (response.meta.status !== 200) + { + alert(JSON.stringify(response)); + return; + } + window.location.reload(); +} + //////////////////////////////////////////////////////////////////////////////////////////////////// // HTTP //////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////// @@ -52,8 +63,8 @@ function _request(method, url, callback) The response will have the following structure: { - "completed": true / false, "meta": { + "completed": true / false, "status": If the connection failed or request otherwise could not complete, `status` will be 0. If the request completed, `status` will be the HTTP response code. @@ -63,13 +74,12 @@ function _request(method, url, callback) and `response.data` will be undefined. "request_url": The URL exactly as given to this call. } - "data": {JSON parsed from server response}. + "data": {JSON parsed from server response if json_ok}. } */ const request = new XMLHttpRequest(); const response = { - "completed": false, - "meta": {"status": 0}, + "meta": {"completed": false, "status": 0}, }; request.onreadystatechange = function() @@ -93,7 +103,7 @@ function _request(method, url, callback) if (request.status != 0) { - response.completed = true; + response.meta.completed = true; try { response.data = JSON.parse(request.responseText);