1
0
Fork 0
mirror of https://github.com/Sonarr/Sonarr synced 2025-01-04 06:21:07 +00:00
Sonarr/UI/Instrumentation/ErrorHandler.js

82 lines
2.3 KiB
JavaScript
Raw Normal View History

2013-06-25 05:12:42 +00:00
'use strict';
2013-05-05 21:24:33 +00:00
(function () {
window.alert = function (message) {
window.Messenger().post(message);
};
window.onerror = function (msg, url, line) {
try {
var a = document.createElement('a');
a.href = url;
2013-07-01 18:25:37 +00:00
var filename = a.pathname.split('/').pop();
//Suppress Firefox debug errors when console window is closed
if (filename.toLowerCase() === 'markupview.jsm' || filename.toLowerCase() === 'markup-view.js') {
2013-07-01 18:25:37 +00:00
return false;
}
var messageText = filename + ' : ' + line + '</br>' + msg;
var message = {
message : messageText,
type : 'error',
2013-05-04 02:15:46 +00:00
hideAfter : 1000,
showCloseButton: true
};
window.Messenger().post(message);
2013-06-25 05:12:42 +00:00
}
catch (error) {
2013-06-22 06:24:24 +00:00
console.log('An error occurred while reporting error. ' + error);
console.log(msg);
window.alert('Couldn\'t report JS error. ' + msg);
}
return false; //don't suppress default alerts and logs.
};
$(document).ajaxError(function (event, xmlHttpRequest, ajaxOptions) {
//don't report 200 error codes
if (xmlHttpRequest.status >= 200 && xmlHttpRequest.status <= 300) {
return undefined;
}
//don't report aborted requests
if (xmlHttpRequest.statusText === 'abort') {
return undefined;
}
var message = {
type : 'error',
2013-05-04 02:15:46 +00:00
hideAfter : 1000,
showCloseButton: true
};
if (xmlHttpRequest.status === 0 && xmlHttpRequest.readyState === 0) {
return false;
//message.message = 'NzbDrone Server Not Reachable. make sure NzbDrone is running.';
2013-06-25 05:12:42 +00:00
}
2013-08-22 00:36:35 +00:00
else if (xmlHttpRequest.status === 400 && ajaxOptions.isValidatedCall) {
return false;
}
else if (xmlHttpRequest.status === 503) {
message.message = xmlHttpRequest.responseJSON.message;
}
2013-08-22 00:36:35 +00:00
else
{
message.message = '[{0}] {1} : {2}'.format(ajaxOptions.type, xmlHttpRequest.statusText, ajaxOptions.url);
}
2013-08-22 00:36:35 +00:00
window.Messenger().post(message);
return false;
});
2013-05-05 21:24:33 +00:00
})();