From d75ecc3db215f0e01c3f22f3f16e03ec9aea57b5 Mon Sep 17 00:00:00 2001 From: Steve Green Date: Tue, 15 Jan 2019 10:23:09 +1100 Subject: [PATCH] Added server errors in chat area * Show server error such as session timeout in chat window * Enforced node >=8.15.0 to resolve 502 errors with node 6.15.0 * Added 1 second pause before scrolling chat window to fix image loading in chat window --- package-lock.json | 2 +- package.json | 4 ++++ public/js/api.js | 17 +++++++++++++++-- public/js/conversation.js | 9 ++++++++- 4 files changed, 28 insertions(+), 4 deletions(-) diff --git a/package-lock.json b/package-lock.json index 24459ab9..7786ca27 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1557,7 +1557,7 @@ }, "csv-stringify": { "version": "1.0.4", - "resolved": "http://registry.npmjs.org/csv-stringify/-/csv-stringify-1.0.4.tgz", + "resolved": "https://registry.npmjs.org/csv-stringify/-/csv-stringify-1.0.4.tgz", "integrity": "sha1-vBi6ua1M7zGV/SV5gLWLR5xC0+U=", "requires": { "lodash.get": "^4.0.0" diff --git a/package.json b/package.json index 08ec6c1d..4af8feed 100644 --- a/package.json +++ b/package.json @@ -28,6 +28,10 @@ "registry": "https://registry.npmjs.org/", "access": "public" }, + "engines": { + "node": ">=8.15.0" + }, + "engineStrict": true, "devDependencies": { "babel-eslint": "^8.2.6", "casperjs": "^1.1.4", diff --git a/public/js/api.js b/public/js/api.js index 7f84f2b5..ad2f772b 100644 --- a/public/js/api.js +++ b/public/js/api.js @@ -27,6 +27,8 @@ var Api = (function() { }, setResponsePayload: function(newPayloadStr) { responsePayload = JSON.parse(newPayloadStr); + }, + setErrorPayload: function() { } }; @@ -35,7 +37,7 @@ var Api = (function() { http.open('GET', sessionEndpoint, true); http.setRequestHeader('Content-type', 'application/json'); http.onreadystatechange = function () { - if (http.readyState == XMLHttpRequest.DONE) { + if (http.readyState === XMLHttpRequest.DONE) { var res = JSON.parse(http.responseText); sessionId = res.session_id; callback(); @@ -65,8 +67,19 @@ var Api = (function() { http.open('POST', messageEndpoint, true); http.setRequestHeader('Content-type', 'application/json'); http.onreadystatechange = function() { - if (http.readyState === 4 && http.status === 200 && http.responseText) { + if (http.readyState === XMLHttpRequest.DONE && http.status === 200 && http.responseText) { Api.setResponsePayload(http.responseText); + } else if (http.readyState === XMLHttpRequest.DONE && http.status !== 200) { + Api.setErrorPayload({ + 'output': { + 'generic': [ + { + 'response_type': 'text', + 'text': 'I\'m having trouble connecting to the server, please refresh the page' + } + ], + } + }); } }; diff --git a/public/js/conversation.js b/public/js/conversation.js index eaae0ec3..e737f592 100644 --- a/public/js/conversation.js +++ b/public/js/conversation.js @@ -46,6 +46,10 @@ var ConversationPanel = (function () { currentResponsePayloadSetter.call(Api, newPayloadStr); displayMessage(JSON.parse(newPayloadStr), settings.authorTypes.watson); }; + + Api.setErrorPayload = function (newPayload) { + displayMessage(newPayload, settings.authorTypes.watson); + }; } // Set up the input box to underline text as it is typed @@ -146,7 +150,10 @@ var ConversationPanel = (function () { // Class to start fade in animation currentDiv.classList.add('load'); // Move chat to the most recent messages when new messages are added - scrollToChatBottom(); + setTimeout(function () { + // wait a sec before scrolling + scrollToChatBottom(); + }, 1000); setResponse(responses, isUser, chatBoxElement, index + 1, false); } else { var userTypringField = document.getElementById('user-typing-field');