From 7a646a292bd0ca6783ae425226409a50013bb86e Mon Sep 17 00:00:00 2001 From: Dan Stillman Date: Thu, 16 Aug 2018 00:50:36 -0400 Subject: [PATCH] Pass response data to Zotero.WebProgressFinishListener callback Pass an object with 'status' and 'contentType' if available --- chrome/content/zotero/xpcom/zotero.js | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/chrome/content/zotero/xpcom/zotero.js b/chrome/content/zotero/xpcom/zotero.js index 9b3e84394b..01feb1c3f1 100644 --- a/chrome/content/zotero/xpcom/zotero.js +++ b/chrome/content/zotero/xpcom/zotero.js @@ -2815,17 +2815,36 @@ Zotero.Browser = new function() { */ Zotero.WebProgressFinishListener = function(onFinish) { var _request; + var _finished = false; this.getRequest = function () { return _request; }; this.onStateChange = function(wp, req, stateFlags, status) { - //Zotero.debug('onStageChange: ' + stateFlags); + //Zotero.debug('onStateChange: ' + stateFlags); if (stateFlags & Components.interfaces.nsIWebProgressListener.STATE_STOP && stateFlags & Components.interfaces.nsIWebProgressListener.STATE_IS_NETWORK) { + if (_finished) { + return; + } + + // Get status code and content ype + let status = null; + let contentType = null; + try { + let r = _request || req; + _request.QueryInterface(Components.interfaces.nsIHttpChannel); + status = r.responseStatus; + contentType = r.contentType; + } + catch (e) { + Zotero.debug(e, 2); + } + _request = null; - onFinish(); + onFinish({ status, contentType }); + _finished = true; } else { _request = req;